/* Lockstock TCG — marketing site shared styles. V5 blue brand. */
:root {
  --blue:#2F66F2; --blue-700:#2452CC; --ink:#0E1320; --slate:#4A5364; --slate-2:#828DA1;
  --line:#E2E8F2; --bg:#F1F4F9; --surface:#fff; --bone:#EFF3F9; --green:#15924D;
  --display:'Space Grotesk',system-ui,sans-serif; --sans:'IBM Plex Sans',system-ui,sans-serif; --mono:'IBM Plex Mono',monospace;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:var(--sans); color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased; line-height:1.6; }
a { color:inherit; text-decoration:none; }
.wrap { max-width:1080px; margin:0 auto; padding:0 24px; }
.eyebrow { font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--blue); }
h1,h2,h3,h4 { font-family:var(--display); font-weight:600; letter-spacing:-.02em; line-height:1.08; margin:0; }
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--sans); font-weight:600; font-size:15px; border-radius:10px; padding:12px 20px; cursor:pointer; border:1.5px solid transparent; transition:background .15s, border-color .15s, transform .05s; }
.btn:active { transform:scale(.98); }
.btn-primary { background:var(--blue); color:#fff; }
.btn-primary:hover { background:var(--blue-700); }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover { border-color:var(--slate-2); }

/* Logo lockup */
.lockup { display:inline-flex; align-items:center; gap:9px; }
.lockup .mk { height:30px; width:auto; display:block; }
.lockup .wm { font-family:var(--display); font-weight:700; font-size:19px; letter-spacing:-.03em; color:var(--ink); }
.lockup .tcg { font-family:var(--mono); font-size:9px; font-weight:500; letter-spacing:.14em; color:var(--ink); border:1.5px solid var(--ink); border-radius:5px; padding:2px 5px 1px; line-height:1; }
.lockup.inv .wm { color:#fff; } .lockup.inv .tcg { color:var(--bone); border-color:rgba(239,243,249,.5); }

/* Header / nav */
header.nav { position:sticky; top:0; z-index:30; background:rgba(241,244,249,.88); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.nav .row { display:flex; align-items:center; justify-content:space-between; height:68px; }
.nav .links { display:flex; align-items:center; gap:28px; }
.nav .links a { font-size:14.5px; font-weight:500; color:var(--slate); }
.nav .links a:hover, .nav .links a.on { color:var(--ink); }
.nav .cta { display:flex; align-items:center; gap:12px; }
.navtoggle { display:none; background:transparent; border:1.5px solid var(--line); border-radius:9px; width:40px; height:38px; font-size:18px; color:var(--ink); cursor:pointer; }
.mobnav { display:none; flex-direction:column; gap:4px; padding:8px 24px 18px; border-bottom:1px solid var(--line); background:var(--bg); }
.mobnav.open { display:flex; }
.mobnav a { padding:11px 4px; font-size:16px; font-weight:500; color:var(--ink); border-bottom:1px solid var(--line); }
.mobnav a.btn { border:0; justify-content:center; margin-top:8px; color:#fff; }

/* Page hero (inner pages) */
.phero { padding:74px 0 40px; }
.phero h1 { font-size:46px; margin:16px 0 0; max-width:680px; }
.phero h1 .sig { color:var(--blue); }
.phero p.lead { font-size:18px; color:var(--slate); max-width:600px; margin:20px 0 0; }

/* Home hero */
.hero { padding:80px 0 64px; }
.hero .grid { display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1 { font-size:58px; margin:18px 0 0; }
.hero h1 .sig { color:var(--blue); }
.hero p.lead { font-size:18px; color:var(--slate); max-width:520px; margin:22px 0 0; }
.hero .actions { display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.hero .micro { font-family:var(--mono); font-size:12px; color:var(--slate-2); margin-top:18px; }

/* Hero visual — "synced sale" card */
.panel { background:var(--surface); border:1px solid var(--line); border-radius:18px; box-shadow:0 24px 60px rgba(14,19,32,.10); padding:20px; }
.panel .ph { display:flex; align-items:center; justify-content:space-between; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--slate-2); }
.dot { display:inline-flex; align-items:center; gap:7px; color:var(--green); font-weight:600; }
.dot::before { content:''; width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 0 rgba(21,146,77,.5); animation:pulse 2s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(21,146,77,.45);} 70%{box-shadow:0 0 0 9px rgba(21,146,77,0);} 100%{box-shadow:0 0 0 0 rgba(21,146,77,0);} }
.salecard { display:flex; gap:14px; align-items:center; margin:16px 0 14px; }
.salecard .thumb { width:54px; height:75px; border-radius:8px; background:linear-gradient(150deg,#2F66F2,#1B3F8F); flex:none; position:relative; }
.salecard .thumb::after { content:''; position:absolute; inset:9px; border:2px solid rgba(255,255,255,.85); border-radius:4px; }
.salecard .nm { font-family:var(--display); font-weight:600; font-size:17px; }
.salecard .sub { font-size:13px; color:var(--slate); }
.salecard .pr { margin-left:auto; font-family:var(--display); font-weight:700; font-size:22px; }
.chips { display:flex; flex-wrap:wrap; gap:7px; }
.chip { font-family:var(--mono); font-size:11px; padding:4px 9px; border-radius:999px; border:1px solid var(--line); color:var(--slate); display:inline-flex; align-items:center; gap:6px; }
.chip.done { color:var(--green); border-color:rgba(21,146,77,.3); background:rgba(21,146,77,.06); }

/* Connectors strip */
.strip { border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--surface); }
.strip .row { display:flex; align-items:center; gap:14px 34px; flex-wrap:wrap; justify-content:center; padding:22px 0; }
.strip .lbl { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--slate-2); }
.strip .name { font-family:var(--display); font-weight:600; font-size:18px; color:var(--slate); }
.strip .name small { font-family:var(--mono); font-size:9px; color:var(--slate-2); vertical-align:6px; margin-left:3px; letter-spacing:.1em; }

/* Sections */
section { padding:84px 0; }
.sec-head { max-width:640px; }
.sec-head.center { margin:0 auto; text-align:center; }
.sec-head h2 { font-size:38px; margin-top:14px; }
.sec-head p { font-size:17px; color:var(--slate); margin:14px 0 0; }

/* Feature cards (home) */
.features { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:40px; }
.feature { background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:26px; }
.feature .ic { width:42px; height:42px; border-radius:11px; background:rgba(47,102,242,.10); display:grid; place-items:center; margin-bottom:16px; }
.feature .ic svg { width:22px; height:22px; stroke:var(--blue); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.feature h3 { font-size:20px; }
.feature p { font-size:15px; color:var(--slate); margin:9px 0 0; }

/* Feature detail rows (features page) */
.frow { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; padding:44px 0; border-top:1px solid var(--line); }
.frow:nth-child(even) .ftext { order:2; }
.frow .eyebrow { margin-bottom:10px; display:block; }
.frow h3 { font-size:28px; }
.frow p { font-size:16px; color:var(--slate); margin:14px 0 0; }
.frow ul { list-style:none; padding:0; margin:16px 0 0; }
.frow li { font-size:15px; color:var(--slate); padding:6px 0 6px 24px; position:relative; }
.frow li::before { content:'✓'; position:absolute; left:0; color:var(--blue); font-weight:700; }
.fart { background:var(--surface); border:1px solid var(--line); border-radius:18px; box-shadow:0 18px 50px rgba(14,19,32,.08); padding:22px; min-height:200px; }

/* Steps */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.step { padding:26px; border-radius:16px; background:var(--surface); border:1px solid var(--line); }
.step .n { font-family:var(--mono); font-size:13px; color:var(--blue); font-weight:500; }
.step h3 { font-size:19px; margin-top:10px; }
.step p { font-size:14.5px; color:var(--slate); margin:8px 0 0; }

/* Vendor band (dark) */
.vendor { background:var(--ink); color:var(--bone); border-radius:24px; padding:56px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.vendor h2 { color:#fff; font-size:34px; }
.vendor p { color:#AEB7C6; font-size:16px; margin:14px 0 0; }
.vendor .flow { display:flex; flex-direction:column; gap:10px; }
.vendor .vstep { display:flex; align-items:center; gap:13px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); border-radius:12px; padding:14px 16px; }
.vendor .vstep b { font-family:var(--mono); font-size:12px; color:#7DA0F5; background:rgba(47,102,242,.18); border-radius:6px; padding:4px 8px; }
.vendor .vstep span { font-size:14.5px; }

/* Pricing tiers */
.tiers { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin:40px auto 0; max-width:760px; }
.tier { background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:30px; }
.tier.feat { border:2px solid var(--blue); position:relative; }
.tier .tag { position:absolute; top:-11px; left:26px; background:var(--blue); color:#fff; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:3px 10px; border-radius:999px; }
.tier h3 { font-size:21px; }
.tier .tdesc { font-size:14px; color:var(--slate); margin:6px 0 0; }
.tier .price { font-family:var(--display); font-weight:700; font-size:42px; margin:16px 0 2px; }
.tier .price small { font-family:var(--sans); font-weight:500; font-size:15px; color:var(--slate-2); }
.tier ul { list-style:none; padding:0; margin:18px 0 0; }
.tier li { font-size:14.5px; color:var(--slate); padding:7px 0 7px 26px; position:relative; }
.tier li::before { content:'✓'; position:absolute; left:0; color:var(--blue); font-weight:700; }
.tier .btn { width:100%; justify-content:center; margin-top:22px; }
.pricing .note { font-family:var(--mono); font-size:12px; color:var(--slate-2); margin-top:22px; text-align:center; }

/* FAQ */
.faq { max-width:760px; margin:36px auto 0; }
.faq details { border-top:1px solid var(--line); padding:6px 0; }
.faq details:last-child { border-bottom:1px solid var(--line); }
.faq summary { list-style:none; cursor:pointer; font-family:var(--display); font-weight:600; font-size:17px; padding:16px 30px 16px 0; position:relative; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; position:absolute; right:4px; top:14px; color:var(--blue); font-size:22px; font-weight:400; }
.faq details[open] summary::after { content:'–'; }
.faq p { font-size:15px; color:var(--slate); margin:0 0 16px; max-width:680px; }

/* About / story */
.prose { max-width:680px; }
.prose p { font-size:17px; color:var(--slate); margin:0 0 18px; }
.prose p strong { color:var(--ink); font-weight:600; }
.values { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.value { background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:24px; }
.value h3 { font-size:18px; } .value p { font-size:14.5px; color:var(--slate); margin:8px 0 0; }

/* Waitlist CTA band */
.ctaband { background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line); text-align:center; padding:76px 24px; }
.ctaband h2 { font-size:38px; margin-top:12px; }
.ctaband p { font-size:17px; color:var(--slate); margin:14px auto 0; max-width:540px; }
.waitlist { display:flex; gap:10px; justify-content:center; margin:28px auto 0; max-width:480px; flex-wrap:wrap; }
.waitlist input { flex:1; min-width:220px; font-family:var(--sans); font-size:15px; padding:13px 16px; border:1.5px solid var(--line); border-radius:10px; background:var(--bg); color:var(--ink); outline:none; }
.waitlist input:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(47,102,242,.14); }
.ctaband .micro { font-family:var(--mono); font-size:12px; color:var(--slate-2); margin-top:16px; }
.wl-done { font-family:var(--display); font-weight:600; font-size:18px; color:var(--green); margin-top:24px; }

/* Footer */
footer.site { background:var(--surface); border-top:1px solid var(--line); padding:48px 0 30px; }
footer.site .fwrap { display:grid; grid-template-columns:2fr 1fr 1fr; gap:32px; }
footer.site .fbrand p { color:var(--slate); font-size:14.5px; margin:14px 0 0; max-width:280px; }
footer.site h4 { font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--slate-2); font-weight:500; margin:0 0 12px; }
footer.site .fcol a { display:block; font-size:14.5px; color:var(--slate); padding:5px 0; }
footer.site .fcol a:hover { color:var(--ink); }
footer.site .fbottom { display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:36px; padding-top:22px; border-top:1px solid var(--line); font-family:var(--mono); font-size:12px; color:var(--slate-2); }

/* "See it in action" — product UI mockups */
.showcase { background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.shotgrid { display:grid; grid-template-columns:1.45fr 1fr; gap:26px; margin-top:40px; align-items:start; }
.shot { background:var(--ink); border-radius:14px; padding:10px; box-shadow:0 30px 70px rgba(14,19,32,.22); }
.shot-bar { display:flex; gap:6px; padding:4px 6px 8px; }
.shot-bar span { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.22); }
.shot-body { background:var(--bg); border-radius:8px; overflow:hidden; }
.ms-glyph { width:17px; height:23px; border-radius:4px; background:var(--blue); position:relative; flex:none; }
.ms-glyph::after { content:''; position:absolute; inset:4px 4px 7px; border:1.5px solid rgba(255,255,255,.9); border-radius:2px; }
.mock-dash { display:grid; grid-template-columns:152px 1fr; min-height:312px; font-size:12px; }
.mock-side { background:#0E1320; padding:14px 12px; }
.ms-logo { display:flex; align-items:center; gap:6px; color:#fff; font-family:var(--display); font-weight:700; font-size:14px; }
.ms-tcg { font-family:var(--mono); font-size:7px; border:1px solid rgba(239,243,249,.5); border-radius:3px; padding:1px 3px; color:var(--bone); }
.ms-nav { margin-top:16px; display:flex; flex-direction:column; gap:2px; }
.ms-nav a { color:rgba(239,243,249,.6); padding:6px 8px; border-radius:6px; }
.ms-nav a.on { background:rgba(47,102,242,.2); color:#fff; }
.mock-main { padding:15px; }
.mm-kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.mm-kpi { background:#fff; border:1px solid var(--line); border-radius:8px; padding:10px; }
.mm-kpi b { font-family:var(--display); font-size:18px; display:block; line-height:1.2; }
.mm-kpi span { color:var(--slate-2); font-size:10px; }
.mm-panel { background:#fff; border:1px solid var(--line); border-radius:8px; margin-top:10px; overflow:hidden; }
.mm-ptitle { font-family:var(--display); font-weight:600; padding:9px 12px; border-bottom:1px solid var(--line); }
.mm-day { background:var(--surface-2); padding:6px 12px; font-weight:600; font-size:11px; }
.mm-order { display:flex; align-items:center; gap:7px; padding:6px 12px 6px 22px; border-top:1px solid var(--line-soft); }
.mm-order .pill { font-size:9px; border:1px solid var(--line); border-radius:999px; padding:1px 6px; color:var(--slate); }
.mm-order .ref { font-family:var(--mono); font-weight:700; }
.mm-order .amt { margin-left:auto; font-weight:700; } .mm-order .tm { color:var(--slate-2); }
.mm-card { display:flex; padding:7px 12px 7px 34px; border-top:1px solid var(--line-soft); }
.mm-card .amt { margin-left:auto; font-weight:700; } .mm-card small { color:var(--slate-2); display:block; font-size:11px; }
.shot.phone { max-width:300px; margin:0 auto; }
.mv-head { background:#0E1320; color:#fff; padding:13px 14px; display:flex; align-items:center; gap:7px; font-family:var(--display); font-weight:700; }
.mv-vendor { font-family:var(--mono); font-size:8px; letter-spacing:.14em; color:#7DA0F5; }
.mv-card { display:flex; align-items:center; gap:11px; padding:14px; background:#fff; margin:12px; border-radius:12px; border:1px solid var(--line); }
.mv-thumb { width:44px; height:62px; border-radius:6px; background:linear-gradient(150deg,#2F66F2,#1B3F8F); flex:none; }
.mv-card b { font-family:var(--display); font-size:14px; } .mv-card small { color:var(--slate); display:block; font-size:11px; }
.mv-pr { margin-left:auto; font-family:var(--display); font-weight:700; font-size:18px; }
.mv-pay { display:grid; grid-template-columns:1fr 1fr; gap:8px; padding:0 12px; }
.mv-pay button { border:1px solid var(--line); border-radius:10px; padding:11px; font-weight:600; font-size:13px; background:#fff; color:var(--ink); }
.mv-pay button.green { background:var(--green); color:#fff; border:0; }
.mv-sync { color:var(--green); font-size:12px; font-weight:600; padding:13px 14px 16px; }

/* Early-access perks on the waitlist CTA */
.perks { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; max-width:720px; margin:30px auto 0; text-align:left; }
.perk { background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:16px; }
.perk b { font-family:var(--display); font-size:15px; display:block; }
.perk span { color:var(--slate); font-size:13px; }

@media (max-width:840px) {
  .shotgrid, .mock-dash, .perks { grid-template-columns:1fr; } .shot.phone { max-width:none; }
  .hero .grid, .vendor, .features, .steps, .tiers, .frow, .values, footer.site .fwrap { grid-template-columns:1fr; }
  .frow:nth-child(even) .ftext { order:0; }
  .hero { padding:52px 0 44px; } .hero h1 { font-size:40px; } .phero h1 { font-size:34px; }
  .nav .links, .nav .cta .btn { display:none; } .navtoggle { display:inline-flex; align-items:center; justify-content:center; }
  section { padding:58px 0; } .sec-head h2, .ctaband h2 { font-size:28px; } .vendor { padding:34px; } .tier .price { font-size:36px; }
}
