/* ============================================================
   TAYLORMADE ACADEMY — design system v2
   Light. Blue. Modern community platform. Inter.
   (Variable + class names kept from v1 so all pages adopt the
   new look; "gold" tokens/classes now map to the blue accent.)
   ============================================================ */
:root{
  /* surfaces + text */
  --bg:#ffffff;
  --paper:#ffffff;          /* (compat) page bg */
  --paper-2:#f8fafc;        /* (compat) soft panel */
  --bg-soft:#f8fafc;
  --bg-soft2:#f1f5f9;
  --ink:#0f172a;            /* slate-900 headings */
  --ink-2:#334155;          /* slate-700 body */
  --muted:#64748b;          /* slate-500 */
  --muted-ink:#94a3b8;
  --hair:#e2e8f0;           /* slate-200 borders */
  --hair-soft:#eef2f7;
  --line:#e2e8f0;
  /* brand accent (blue) — "gold" kept as an alias so old markup works */
  --blue:#2563eb;
  --blue-2:#3b82f6;
  --blue-deep:#1d4ed8;
  --blue-soft:#eff6ff;
  --gold:#2563eb;
  --gold-deep:#1d4ed8;
  --emerald:#10b981;
  --emerald-soft:#ecfdf5;
  --amber:#f59e0b;
  --clay:#ef4444;           /* destructive / unread / live */
  --ink-panel:#0b1220;      /* dark thumbnails + bands */
  --maxw:1200px;
  --gut:clamp(20px,5vw,48px);
  --r:16px; --r-lg:22px; --r-sm:10px;
  --ease:cubic-bezier(.23,1,.32,1);
  --shadow:0 12px 34px -14px rgba(15,23,42,.22);
  --shadow-sm:0 2px 10px rgba(15,23,42,.06);
  --shadow-card:0 6px 24px -10px rgba(15,23,42,.16);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--bg);color:var(--ink-2);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--blue);color:#fff;}

/* ---------- type ---------- */
.serif,h1,h2,h3,.display{font-family:var(--font);}
h1,h2,h3{color:var(--ink);line-height:1.08;font-weight:800;letter-spacing:-.02em;}
.display-xl{font-size:clamp(40px,6.4vw,72px);line-height:1.02;font-weight:800;letter-spacing:-.035em;color:var(--ink);}
.display-l{font-size:clamp(30px,4.4vw,52px);line-height:1.04;font-weight:800;letter-spacing:-.03em;}
.display-m{font-size:clamp(24px,3vw,38px);line-height:1.08;font-weight:800;letter-spacing:-.02em;}
.lead{font-size:clamp(17px,1.6vw,20px);line-height:1.55;color:var(--muted);max-width:46ch;}
p{max-width:68ch;}
.blue{color:var(--blue);}
.kicker{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.kicker.gold{color:var(--blue);}
.mono{font-family:ui-monospace,'SF Mono','JetBrains Mono',Menlo,monospace;font-size:12px;letter-spacing:.06em;color:var(--muted);}

/* ---------- rules / dots ---------- */
.rule{height:2px;background:var(--ink);border:0;}
.rule.gold{background:var(--blue);}
.rule.hair{height:1px;background:var(--hair);}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:currentColor;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);width:100%;}
.section{padding-block:clamp(48px,7vw,92px);}
.section.tight{padding-block:clamp(34px,5vw,60px);}
.on-ink{background:var(--ink-panel);color:#cbd5e1;}
.on-ink h1,.on-ink h2,.on-ink h3{color:#fff;}
.on-ink .kicker{color:var(--blue-2);}
.g-12{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,3vw,32px);}
.sec-head{max-width:62ch;}
.eyebrow-row{display:flex;align-items:center;gap:16px;}
.eyebrow-row .rule{flex:1;}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--hair);}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:18px;height:72px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand .logo{width:38px;height:38px;flex:0 0 auto;border-radius:10px;}
.brand .mark{font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--ink);}
.brand .mark b{font-weight:800;color:var(--ink);}
.brand .by{display:none;}
.nav{display:flex;align-items:center;gap:2px;}
.navlink{font-family:var(--font);font-size:15px;font-weight:600;color:var(--muted);padding:9px 14px;border-radius:9px;transition:color .15s,background .15s;}
.navlink:hover{color:var(--ink);background:var(--bg-soft);}
.navlink.active{color:var(--blue);}
.nav-cta{display:flex;align-items:center;gap:12px;}
.burger{display:none;width:42px;height:42px;border:1px solid var(--hair);border-radius:10px;background:#fff;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px;}
.burger span{width:18px;height:2px;background:var(--ink);border-radius:2px;}
.mobile-nav{display:none;flex-direction:column;gap:4px;padding:14px var(--gut) 20px;border-bottom:1px solid var(--hair);background:#fff;}
.mobile-nav.open{display:flex;}
.mobile-nav a{padding:11px 8px;font-weight:600;color:var(--ink-2);border-radius:8px;}
.mobile-nav a.btn{justify-content:center;margin-top:6px;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font);font-weight:600;font-size:15px;line-height:1;padding:13px 20px;border-radius:11px;border:1.5px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,transform .08s,box-shadow .15s;white-space:nowrap;}
.btn.sm{padding:10px 15px;font-size:14px;border-radius:9px;}
.btn{background:#fff;border-color:var(--hair);color:var(--ink);}
.btn:hover{border-color:var(--muted-ink);}
.btn.gold,.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 6px 16px -6px rgba(37,99,235,.5);}
.btn.gold:hover,.btn.primary:hover{background:var(--blue-deep);border-color:var(--blue-deep);}
.btn.ghost{background:#fff;border-color:var(--hair);color:var(--ink);box-shadow:none;}
.btn.ghost:hover{border-color:var(--muted-ink);background:var(--bg-soft);}
.btn.dark{background:var(--ink);border-color:var(--ink);color:#fff;}
.btn:active{transform:translateY(1px);}
.arr{transition:transform .15s;}
.btn:hover .arr{transform:translateX(3px);}
.textlink{color:var(--blue);font-weight:600;}
.textlink:hover{text-decoration:underline;}

/* ---------- tags ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font);font-size:11.5px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);background:var(--bg-soft);border:1px solid var(--hair);border-radius:100px;padding:5px 11px;}
.tag.gold{color:var(--blue);background:var(--blue-soft);border-color:#dbeafe;}
.tag.gold .dot{background:var(--blue);}
.tag.live{color:#b45309;background:#fffbeb;border-color:#fde68a;}
.tag.live .dot{background:var(--amber);}
.tag.solid{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ---------- hero ---------- */
.hero{padding-block:clamp(40px,6vw,84px);}
.h-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;}
.hero-copy .sub{font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:48ch;margin-top:18px;}
.kicker.pill,.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--blue-soft);color:var(--blue-deep);border:1px solid #dbeafe;border-radius:100px;padding:7px 14px;font-size:13px;font-weight:700;letter-spacing:0;text-transform:none;}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;align-items:center;}
.statline{display:flex;flex-wrap:wrap;gap:26px;margin-top:30px;}
.statline .s .n{font-size:22px;font-weight:800;color:var(--ink);}
.statline .s .l{font-size:13px;color:var(--muted);margin-top:2px;}

/* product-preview panel (hero art) */
.preview{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;}
.preview .pv-top{display:flex;gap:0;}
.preview .pv-side{width:128px;background:var(--ink-panel);padding:16px 12px;display:flex;flex-direction:column;gap:7px;flex:0 0 auto;}
.preview .pv-side .pv-logo{width:24px;height:24px;border-radius:7px;background:linear-gradient(135deg,var(--blue-2),var(--blue));margin-bottom:8px;}
.preview .pv-side .pv-i{font-size:11px;color:#94a3b8;padding:6px 8px;border-radius:7px;display:flex;align-items:center;gap:7px;}
.preview .pv-side .pv-i.on{background:rgba(59,130,246,.18);color:#fff;}
.preview .pv-side .pv-i::before{content:"";width:11px;height:11px;border-radius:3px;background:currentColor;opacity:.7;}
.preview .pv-main{flex:1;padding:16px;min-width:0;}
.preview .pv-h{font-size:13px;color:var(--muted);}
.preview .pv-h b{display:block;font-size:17px;color:var(--ink);margin-top:1px;}
.preview .pv-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:13px;}
.preview .pv-card{background:var(--bg-soft);border:1px solid var(--hair);border-radius:10px;padding:9px;}
.preview .pv-card .t{font-size:9px;color:var(--muted);}
.preview .pv-card .v{font-size:15px;font-weight:800;color:var(--ink);margin-top:2px;}
.preview .pv-wide{margin-top:10px;background:var(--bg-soft);border:1px solid var(--hair);border-radius:10px;padding:11px;display:flex;align-items:center;gap:10px;}
.preview .pv-wide .thumb{width:54px;height:38px;border-radius:7px;background:linear-gradient(135deg,#1e293b,var(--ink-panel));flex:0 0 auto;}
.preview .pv-wide .b{font-size:12px;font-weight:700;color:var(--ink);}
.preview .pv-wide .s{font-size:10px;color:var(--muted);margin-top:2px;}
.preview .pv-bar{height:4px;border-radius:3px;background:var(--hair);margin-top:6px;overflow:hidden;}
.preview .pv-bar i{display:block;height:100%;width:64%;background:var(--blue);}

/* ---------- proof / feature bar ---------- */
.proof .row{display:flex;flex-wrap:wrap;gap:14px;}
.featurebar{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);box-shadow:var(--shadow-card);padding:22px;}
.featurebar .f .ic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;margin-bottom:11px;}
.featurebar .f .h{font-weight:700;font-size:15px;color:var(--ink);}
.featurebar .f .d{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.5;}

/* ---------- cards / products ---------- */
.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px;}
.pcard{background:#fff;border:1px solid var(--hair);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s;}
.pcard:hover{box-shadow:var(--shadow-card);transform:translateY(-2px);}
.pcard .top{display:block;}
.pcard .cover{width:100%;aspect-ratio:16/10;object-fit:cover;background:var(--ink-panel);}
.pcard .cover-ph{width:100%;aspect-ratio:16/10;background:linear-gradient(135deg,#1e293b,var(--ink-panel));color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;letter-spacing:.1em;text-align:center;}
.pcard .meta{padding:16px;display:flex;flex-direction:column;gap:8px;}
.pcard .tagrow{display:flex;gap:8px;flex-wrap:wrap;}
.pcard h3{font-size:18px;font-weight:700;letter-spacing:-.01em;}
.pcard .blurb{font-size:14px;color:var(--muted);line-height:1.55;}
.pcard .foot{margin-top:auto;padding:0 16px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.price{font-size:20px;font-weight:800;color:var(--ink);}
.price.big{font-size:30px;}
.price .ph{font-size:13px;font-weight:600;color:var(--muted);}
.flist{list-style:none;display:flex;flex-direction:column;gap:9px;margin-top:8px;}
.flist li{position:relative;padding-left:26px;font-size:15px;color:var(--ink-2);}
.flist li::before{content:"";position:absolute;left:0;top:3px;width:17px;height:17px;border-radius:50%;background:var(--emerald-soft);}
.flist li::after{content:"";position:absolute;left:5px;top:8px;width:6px;height:3px;border-left:2px solid var(--emerald);border-bottom:2px solid var(--emerald);transform:rotate(-45deg);}

/* ---------- feature / audience grid ---------- */
.audience{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-top:8px;}
.audience .a{background:#fff;border:1px solid var(--hair);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-sm);}
.audience .a .h{font-weight:700;font-size:16px;color:var(--ink);}
.audience .a .d{font-size:14px;color:var(--muted);margin-top:7px;line-height:1.5;}
.on-ink .audience .a{background:#0f1626;border-color:#1e293b;}
.on-ink .audience .a .h{color:#fff;}
.on-ink .audience .a .d{color:#94a3b8;}

/* ---------- pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.tier{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);padding:26px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);}
.tier.feat{border-color:var(--blue);box-shadow:0 16px 40px -18px rgba(37,99,235,.45);position:relative;}
.tier .pname{font-weight:700;font-size:17px;color:var(--ink);}
.tier .pprice{font-size:38px;font-weight:800;color:var(--ink);margin:8px 0 2px;letter-spacing:-.02em;}
.tier .pprice span{font-size:15px;font-weight:600;color:var(--muted);}
.tier .pdesc{font-size:14px;color:var(--muted);}

/* ---------- cta band ---------- */
.cta-band{text-align:center;background:var(--blue-soft);}
.cta-band .wrap{max-width:760px;}

/* ---------- footer ---------- */
.site-footer{background:var(--bg-soft);border-top:1px solid var(--hair);padding-block:clamp(40px,6vw,68px) 28px;}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:32px;}
.foot-brand .mark{font-weight:800;font-size:18px;color:var(--ink);}
.foot-brand .mark b{color:var(--ink);}
.foot-brand p{font-size:14px;color:var(--muted);margin-top:10px;max-width:34ch;}
.foot-col h4{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:12px;letter-spacing:.02em;}
.foot-col a{display:block;font-size:14px;color:var(--muted);padding:5px 0;}
.foot-col a:hover{color:var(--blue);}
.foot-bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;margin-top:34px;padding-top:22px;border-top:1px solid var(--hair);}
.foot-bottom span{font-size:13px;color:var(--muted);}

/* ---------- misc ---------- */
.badge{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--hair);border-radius:100px;padding:7px 13px;font-size:12.5px;font-weight:700;color:var(--ink);box-shadow:var(--shadow-sm);}
.badge .dot{background:var(--emerald);}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:13px 20px;border-radius:12px;font-size:14.5px;font-weight:500;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:200;max-width:90vw;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast b{font-weight:700;}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .nav{display:none;}
  .nav-cta .navlink,.nav-cta .btn{display:none;}
  .burger{display:flex;}
  .h-grid{grid-template-columns:1fr;}
  .hero-art{order:-1;}
  .featurebar{grid-template-columns:1fr 1fr;}
  .tiers{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr 1fr;}
  .g-12>*{grid-column:1/-1 !important;}
}
@media(max-width:560px){
  .featurebar{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;}
  .preview .pv-side{display:none;}
}

/* ---------- cart ---------- */
.cart-btn{position:relative;}
.cart-btn .cc{position:absolute;top:-7px;right:-7px;background:var(--clay);color:#fff;font-size:10px;min-width:17px;height:17px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;padding:0 4px;}
.cart-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.42);opacity:0;pointer-events:none;transition:opacity .25s;z-index:90;}
.cart-backdrop.open{opacity:1;pointer-events:auto;}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:384px;max-width:92vw;background:#fff;box-shadow:-16px 0 50px -20px rgba(15,23,42,.35);transform:translateX(100%);transition:transform .28s var(--ease);z-index:100;display:flex;flex-direction:column;}
.cart-drawer.open{transform:none;}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--hair);font-size:17px;font-weight:800;}
.cart-items{flex:1;overflow-y:auto;padding:4px 20px;}
.cart-item{display:flex;align-items:center;gap:12px;padding:15px 0;border-bottom:1px solid var(--hair-soft);}
.cart-item .ci-t{font-weight:600;font-size:14.5px;color:var(--ink);overflow-wrap:anywhere;}
.cart-item .ci-p{font-weight:800;color:var(--ink);margin-top:3px;font-size:15px;}
.ci-x{appearance:none;border:0;background:none;font-size:22px;line-height:1;color:var(--muted-ink);cursor:pointer;padding:2px 4px;flex:0 0 auto;}
.ci-x:hover{color:var(--clay);}
.cart-foot{padding:18px 20px;border-top:1px solid var(--hair);background:var(--bg-soft);}
.cart-sub{display:flex;justify-content:space-between;font-weight:800;font-size:18px;margin-bottom:14px;}
.cart-up{margin-top:14px;background:#fff;border:1px solid var(--hair);border-radius:12px;padding:14px;}
.cart-up .h{font-weight:700;font-size:14px;}
.cart-up p{font-size:12.5px;color:var(--muted);margin:5px 0 10px;}
@media(max-width:920px){ .nav-cta .cart-btn{display:inline-flex !important;} }

/* ---------- filter chips (store / generic) ---------- */
.chips{display:flex;gap:8px;flex-wrap:wrap;}
.chip{appearance:none;border:1.5px solid var(--hair);background:#fff;font-family:var(--font);font-size:13.5px;font-weight:600;color:var(--muted);padding:8px 16px;border-radius:100px;cursor:pointer;}
.chip:hover{border-color:var(--muted-ink);}
.chip.active{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);}

/* ---------- hero photo (cutout on blob) ---------- */
.hero-photo{position:relative;display:flex;align-items:flex-end;justify-content:center;min-height:clamp(360px,42vw,520px);}
.hero-photo .blob{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
.hero-photo .hero-cut{position:relative;z-index:2;max-height:clamp(360px,42vw,540px);width:auto;max-width:100%;object-fit:contain;filter:drop-shadow(0 24px 44px rgba(15,23,42,.2));}
.hero-photo .spark{position:absolute;z-index:1;line-height:0;}
.hero-photo .spark.s1{top:8%;left:5%;} .hero-photo .spark.s2{top:26%;right:3%;}
