/* ============================================================
   Born in the City — custom single-product (show) template
   Loaded only on product pages (see btc-product-preview.php).
   Reads design tokens from tokens.css. Everything scoped under
   .btc-product so it cannot leak into other templates.
   ============================================================ */
.btc-product *{box-sizing:border-box;}
.btc-product{font-family:var(--font-sans);color:var(--ink-900);background:var(--paper);}
.btc-product img{max-width:100%;display:block;}
.btc-product a{color:inherit;}
.btc-product .wrap{max-width:1120px;margin:0 auto;padding:0 32px;}
.btc-product h1,.btc-product h2,.btc-product h3{font-family:var(--font-display);font-weight:700;line-height:1.12;}
.btc-product .eyebrow{font-family:var(--font-sans);font-size:12px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--btc-orange);}

/* hero */
.btc-hero{background:var(--ink-900);color:#fff;position:relative;overflow:hidden;}
.btc-hero::before{content:"";position:absolute;top:-30%;right:-10%;width:620px;height:620px;
  background:radial-gradient(circle,rgba(255,107,53,.20),transparent 62%);pointer-events:none;}
.btc-hero .wrap{display:grid;grid-template-columns:300px 1fr;gap:56px;padding:60px 32px 68px;position:relative;}
.btc-hero .poster{border-radius:6px;overflow:hidden;box-shadow:0 30px 60px -20px rgba(0,0,0,.7);
  border:1px solid rgba(255,255,255,.08);}
.btc-hero .poster img{width:100%;height:auto;}
.btc-hero .info{align-self:center;}
.btc-badge{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:20px;margin-bottom:14px;}
.btc-badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
.btc-badge.now{background:rgba(76,175,80,.16);color:#7ed884;border:1px solid rgba(126,216,132,.3);}
.btc-badge.soon{background:rgba(255,107,53,.16);color:#ffa074;border:1px solid rgba(255,160,116,.35);}
.btc-badge.closed{background:rgba(255,255,255,.08);color:#b7b7bb;border:1px solid rgba(255,255,255,.16);}
.btc-hero h1{font-size:72px;font-weight:800;letter-spacing:-.01em;}
.btc-hero .meta{margin-top:14px;font-size:14px;color:#b9b9bd;}
.btc-hero .meta b{color:#fff;font-weight:600;}
.btc-hero .lede{margin-top:18px;font-size:17px;color:#d6d6d8;max-width:33em;}
.btc-cta{margin-top:26px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.btc-btn{font-family:var(--font-sans);font-weight:600;font-size:15px;border-radius:4px;
  padding:15px 30px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  border:2px solid transparent;cursor:pointer;transition:.16s;}
.btc-btn--primary{background:var(--btc-orange);color:#fff;border-color:var(--btc-orange);}
.btc-btn--primary:hover{background:var(--btc-orange-deep);border-color:var(--btc-orange-deep);}
.btc-btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45);}
.btc-btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.06);}
.btc-rating{margin-top:26px;display:flex;gap:28px;align-items:center;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);padding-top:22px;}
.btc-rating .lbl{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--btc-orange);font-weight:700;}
.btc-rating .line{display:flex;align-items:center;gap:10px;margin-top:5px;}
.btc-rating .num{font-family:var(--font-display);font-size:30px;font-weight:700;color:#fff;line-height:1;}
.btc-stars{font-size:19px;line-height:1;letter-spacing:2px;}
.btc-stars::before{content:"\2605\2605\2605\2605\2605";
  background:linear-gradient(90deg,var(--btc-orange) var(--pct,100%),#4a4843 var(--pct,100%));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.btc-critic{font-size:13px;color:#9a9a9f;}
.btc-critic .cnum{font-family:var(--font-display);font-size:20px;color:#fff;}
.btc-share{margin-top:22px;display:flex;align-items:center;gap:10px;}
.btc-share .lbl{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:#8a8a8f;font-weight:700;}
.btc-share a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;color:#cfcfcf;transition:.15s;text-decoration:none;}
.btc-share a:hover{border-color:var(--btc-orange);color:var(--btc-orange);background:rgba(255,107,53,.09);}
.btc-share svg{width:15px;height:15px;fill:currentColor;}

/* facts strip */
.btc-facts{background:#1a1a1a;color:#e7e7e7;}
.btc-facts .row{display:grid;grid-template-columns:repeat(4,1fr);max-width:1120px;margin:0 auto;}
.btc-facts .fact{padding:22px 8px;text-align:center;border-right:1px solid rgba(255,255,255,.08);}
.btc-facts .fact:last-child{border-right:none;}
.btc-facts .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#8d8d92;}
.btc-facts .v{font-family:var(--font-display);font-size:19px;font-weight:600;margin-top:4px;color:#fff;}

/* sections */
.btc-section{padding:70px 0;}
.btc-shead{text-align:center;margin-bottom:42px;}
.btc-shead h2{font-size:37px;margin-top:8px;}
.btc-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.btc-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:30px;}
.btc-card h3{font-size:13px;font-family:var(--font-sans);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--btc-orange);padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:18px;}
.btc-row{margin-bottom:14px;}
.btc-row .l{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);}
.btc-row .v{font-size:15px;font-weight:500;margin-top:2px;}
.btc-row a{color:var(--btc-orange);text-decoration:none;font-weight:600;}
.btc-row a:hover{text-decoration:underline;}
.btc-lottery{background:var(--ink-900);color:#ddd;border:none;padding:36px;
  display:flex;flex-direction:column;}
.btc-lottery h3{color:var(--btc-orange);border-color:rgba(255,255,255,.12);}
.btc-lottery .l{color:#9a9a9f;}
.btc-lottery .btc-row{margin-bottom:22px;}
.btc-lottery .price{font-family:var(--font-display);font-size:34px;font-weight:700;color:#fff;}
.btc-lottery .price small{font-size:14px;font-family:var(--font-sans);color:#9a9a9f;font-weight:400;}
.btc-lottery .msg{font-size:15px;color:#cfcfcf;margin-bottom:6px;}
.btc-lottery .btc-btn{margin-top:auto;width:100%;justify-content:center;}
#btc-lotteryBox{display:flex;flex-direction:column;}
.btc-cols>#btc-lotteryBox>.btc-card{flex:1;}

/* map */
/* theatre card — embedded Google Map fills the remaining card height */
.btc-theatre{display:flex;flex-direction:column;}
.btc-map{margin-top:16px;flex:1;min-height:230px;border-radius:6px;overflow:hidden;
  border:1px solid var(--line);background:var(--paper-2);}
.btc-map iframe{width:100%;height:100%;min-height:230px;border:0;display:block;}

/* writeup */
.btc-writeup{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.btc-writeup .wrap{max-width:760px;}
.btc-writeup h2{font-size:34px;}
.btc-writeup .eyebrow{margin-bottom:8px;display:block;}
.btc-writeup p{margin-top:18px;font-size:18px;line-height:1.72;}
.btc-writeup p:first-of-type{font-size:21px;}
.btc-writeup a{color:var(--btc-orange);font-weight:600;text-decoration:none;}
.btc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px;}
.btc-gallery img{border-radius:6px;height:150px;object-fit:cover;width:100%;border:1px solid var(--line);}

/* reviews */
.btc-reviews{background:var(--paper);}
.btc-verdict{background:var(--ink-900);color:#e6e6e6;border-radius:10px;padding:36px 40px;margin-bottom:30px;}
.btc-verdict .top{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;}
.btc-verdict .top.no-vn{grid-template-columns:1fr;}
.btc-verdict .vn{text-align:center;}
.btc-verdict .vn .n{font-family:var(--font-display);font-size:60px;font-weight:800;color:var(--btc-orange);line-height:1;}
.btc-verdict .vn .cap{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#9a9a9f;font-weight:700;margin-top:8px;}
.btc-verdict h3{font-family:var(--font-display);font-size:23px;color:#fff;margin-bottom:6px;}
.btc-verdict p{font-size:15px;line-height:1.6;color:#cfcfcf;}
.btc-verdict p.muted{font-size:13px;line-height:1.55;color:#9a9a9f;}
.btc-verdict .src{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;gap:26px;flex-wrap:wrap;align-items:center;font-size:13px;color:#9a9a9f;}
.btc-verdict .src b{color:#fff;font-family:var(--font-display);font-size:17px;font-weight:600;}
.btc-verdict .src a{color:var(--btc-orange);text-decoration:none;font-weight:600;}

/* reader lottery reports */
.btc-reports-head{display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:16px;flex-wrap:wrap;gap:8px;}
.btc-reports-head h3{font-family:var(--font-display);font-size:22px;color:var(--ink-900);}
.btc-reports-head .avg{font-size:13px;color:var(--ink-500);}
.btc-reports{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.btc-report{background:#fff;border:1px solid var(--line);border-radius:8px;padding:22px;
  display:flex;flex-direction:column;}
.btc-report .btc-stars{font-size:15px;}
.btc-report .quote{font-size:15px;line-height:1.55;margin:10px 0 14px;color:var(--ink-800);}
.btc-report .who{font-size:13px;color:var(--ink-500);border-top:1px solid var(--line);
  padding-top:12px;margin-top:auto;}
.btc-report .who b{color:var(--ink-900);font-weight:600;}
.btc-report .won{align-self:flex-start;background:#eef7ee;color:#2e7d32;font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:4px;margin-bottom:8px;}

/* reader reports — empty state */
.btc-reports-empty{background:#fff;border:1px dashed var(--ink-300);border-radius:10px;
  padding:46px 32px;text-align:center;}
.btc-reports-empty .ico{font-size:30px;color:var(--btc-orange);line-height:1;}
.btc-reports-empty h4{font-family:var(--font-display);font-size:21px;color:var(--ink-900);margin:12px 0 8px;}
.btc-reports-empty p{font-size:15px;line-height:1.6;color:var(--ink-500);max-width:46em;margin:0 auto;}

.btc-cta-line{text-align:center;margin-top:28px;}

/* submission — YITH native block: restyled, de-duplicated */
.btc-yith-form{margin-top:40px;padding-top:34px;border-top:1px solid var(--line);}
.btc-yith-form__title{font-family:var(--font-display);font-size:22px;color:var(--ink-900);
  text-align:center;margin-bottom:6px;}


/* related — site show-card component */
.btc-related .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.btc-show{text-decoration:none;color:inherit;display:block;background:#fff;
  border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:.16s;}
.btc-show:hover{box-shadow:0 14px 30px -16px rgba(0,0,0,.28);transform:translateY(-3px);}
.btc-show .ph{aspect-ratio:2/3;background:#e4ddd0;overflow:hidden;}
.btc-show .ph img{width:100%;height:100%;object-fit:cover;}
.btc-show .body{padding:14px 16px 18px;}
.btc-show .cat{font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--btc-orange);}
.btc-show .nm{font-family:var(--font-display);font-size:17px;font-weight:600;margin-top:6px;line-height:1.2;}
.btc-show .th{font-size:13px;color:var(--ink-500);margin-top:4px;}
.btc-show:hover .nm{color:var(--btc-orange);}

@media(max-width:860px){
  .btc-product .wrap{padding:0 20px;}
  .btc-hero .wrap{grid-template-columns:1fr;gap:30px;padding:48px 20px;}
  .btc-hero .poster{max-width:240px;margin:0 auto;}
  .btc-hero .info{text-align:center;}
  .btc-hero .lede{margin-left:auto;margin-right:auto;}
  .btc-cta,.btc-rating,.btc-share{justify-content:center;}
  .btc-hero h1{font-size:46px;}
  .btc-facts .row{grid-template-columns:repeat(2,1fr);}
  .btc-cols,.btc-gallery,.btc-reports{grid-template-columns:1fr;}
  .btc-related .grid{grid-template-columns:1fr;}
  .btc-verdict .top{grid-template-columns:1fr;text-align:center;}
}

/* ----- specificity overrides -----
   The child theme's tokens.css sets body.bitc h1/h2/h3 {color:ink} and
   body.bitc a {color:hudson-blue} at 0,1,2 specificity, which beats
   single-class component rules. These .btc-product-prefixed selectors
   (0,2,x) win and restore the intended colors. */
.btc-product .btc-hero h1{color:#fff;}
.btc-product .btc-lottery h3{color:var(--btc-orange);}
.btc-product .btc-card h3{color:var(--btc-orange);}
.btc-product .btc-verdict h3{color:#fff;}
.btc-product .btc-btn--primary{color:#fff;}
.btc-product .btc-btn--ghost{color:#fff;}
.btc-product .btc-row a{color:var(--btc-orange);}
.btc-product .btc-writeup a{color:var(--btc-orange);}
.btc-product .btc-verdict .src a{color:var(--btc-orange);}
.btc-product .btc-share a{color:#cfcfcf;}
.btc-product .btc-share a:hover{color:var(--btc-orange);}
.btc-product .btc-show .nm{color:var(--ink-900);}
.btc-product .btc-show:hover .nm{color:var(--btc-orange);}
.btc-product .btc-reports-head h3{color:var(--ink-900);}
.btc-product .btc-reports-empty h4{color:var(--ink-900);}
.btc-product .btc-yith-form__title{color:var(--ink-900);}
.btc-product .btc-yith-form[hidden]{display:none;}
/* YITH native block: keep the submission form + modal dialog; drop YITH's
   duplicate list, count heading, summary, sort filter + its own form title
   (the v7 cards above are the canonical display). */
.btc-product .btc-yith-form ol.commentlist,
.btc-product .btc-yith-form #comments > h2,
.btc-product .btc-yith-form .woocommerce-noreviews,
.btc-product .btc-yith-form .ywar-no-review,
.btc-product .btc-yith-form #reviews_summary,
.btc-product .btc-yith-form #reviews_order,
.btc-product .btc-yith-form #reply-title{display:none;}
/* Force the form full-width — YITH's own CSS boxes it into a side column. */
.btc-product .btc-yith-form #ywar_reviews,
.btc-product .btc-yith-form #reviews,
.btc-product .btc-yith-form .ywar-review-content,
.btc-product .btc-yith-form #review_form_wrapper,
.btc-product .btc-yith-form #review_form,
.btc-product .btc-yith-form #respond{width:100%!important;max-width:100%!important;
  float:none!important;display:block!important;margin-left:0!important;margin-right:0!important;}
.btc-product .btc-yith-form #review_form{background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:26px 28px;}
.btc-product .btc-yith-form a.button,
.btc-product .btc-yith-form button.button,
.btc-product .btc-yith-form input[type="submit"]{background:var(--btc-orange);
  border-color:var(--btc-orange);color:#fff;}
/* report form — CSS-only disclosure (no JS; immune to WP Rocket delay-JS) */
.btc-reportbox{margin-top:28px;}
.btc-reportbox > summary{display:block;list-style:none;text-align:center;cursor:pointer;}
.btc-reportbox > summary::-webkit-details-marker{display:none;}
.btc-reportbox > summary::marker{content:"";}
.btc-reportbox > summary .btc-btn{display:inline-flex;}
.btc-reportbox[open] .d-closed{display:none;}
.btc-reportbox:not([open]) .d-open{display:none;}
.btc-related-more{text-align:center;margin-top:34px;}
