/* ============================================================
   PVT PLN — site.css
   Shared MARKETING-SITE chrome + page primitives.
   Loads AFTER pvtpln.css (which owns all tokens + components).
   Extracted from home.html so every Phase-2 page is consistent.
   Night cabin is the default everywhere.
   ============================================================ */

/* ---- Top bar / nav ---- */
.topbar { position: fixed; top: 0; left: 0; right: 0; z-index: 60; background: rgba(7,16,26,0.72); backdrop-filter: blur(20px) saturate(140%); border-bottom: 1px solid var(--ink-line); }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px; }
.tb-mark { display: flex; align-items: center; gap: 12px; }
.tb-mark .wm-img { height: 26px; }
.nav { display: flex; gap: 26px; align-items: center; }
.nav a { font-size: 13px; font-weight: 500; color: var(--cream-80); position: relative; padding: 8px 0; transition: color .2s; }
.nav a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px; background: var(--gold-100); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease); }
.nav a:hover, .nav a.on { color: var(--cream-100); }
.nav a:hover::after, .nav a.on::after { transform: scaleX(1); }
.tb-util { display: flex; align-items: center; gap: 10px; }
.tb-util .login { font-size: 13px; color: var(--cream-60); padding: 9px 12px; }
.tb-util .req { font-size: 12px; font-weight: 600; padding: 9px 16px; border: 1px solid var(--cream-20); border-radius: 999px; transition: all .2s; }
.tb-util .req:hover { background: var(--gold-100); color: var(--ink-0); border-color: var(--gold-100); }
@media (max-width: 980px){ .nav { display: none; } .tb-util .login { display:none; } }

/* ---- Section frame ---- */
section.frame { padding: 88px 0; position: relative; }
.frame-head { margin-bottom: 44px; }
.frame-head .eyebrow-gold { display:block; margin-bottom: 18px; }
.frame-head h2 { max-width: 24ch; }
.frame.tight { padding: 60px 0; }
.frame.alt { background: var(--ink-0); border-top: 1px solid var(--ink-line); border-bottom: 1px solid var(--ink-line); }

/* ---- Page hero (interior pages; not the home WebGL hero) ---- */
.page-hero { position: relative; padding: 168px 0 70px; overflow: hidden; border-bottom: 1px solid var(--ink-line); }
.page-hero::after { content:""; position:absolute; inset:0; background: radial-gradient(70% 90% at 80% 0%, rgba(212,168,81,0.10), transparent 60%); pointer-events:none; }
.page-hero .wrap { position: relative; z-index: 2; }
.ph-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 26px; }
.ph-meta .where { font-size: 10.5px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--cream-60); }
.ph-meta .line { flex: 1; height: 1px; background: var(--ink-line); max-width: 220px; }
.page-hero h1 { font-family: var(--f-display); font-weight: 200; font-size: clamp(40px, 5.4vw, 74px); line-height: 0.98; letter-spacing: -0.04em; margin: 0; max-width: 18ch; }
.page-hero h1 em { font-family: var(--f-serif); font-style: italic; font-weight: 300; }
.page-hero .lead { margin-top: 26px; max-width: 56ch; font-size: 17px; line-height: 1.55; color: var(--cream-80); }
.page-hero .lead b { color: var(--cream-100); font-weight: 500; }
.page-hero .hero-cta { display: flex; align-items: center; gap: 12px; margin-top: 32px; flex-wrap: wrap; }

/* ---- Outclass annotation (the "beats X by Y" device) ---- */
.outclass-float { display:inline-flex; margin-top: 26px; }

/* ---- Generic media slot (photography placeholders) ---- */
.media { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--ink-line); background: var(--ink-2); }
.media.photo::after { font-family: var(--f-mono); }

/* ---- Two-column editorial split ---- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split.narrow { gap: 40px; }
@media (max-width: 900px){ .split { grid-template-columns: 1fr; gap: 36px; } }

/* ---- Feature rows (icon + copy) ---- */
.feat-row { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--ink-line); }
.feat-row:last-child { border-bottom: none; }
.feat-row .fic { width: 34px; height: 34px; flex-shrink: 0; border-radius: 10px; background: var(--gold-08); border: 1px solid var(--gold-30); display: grid; place-items: center; color: var(--gold-100); }
.feat-row .fic svg { width: 17px; height: 17px; stroke: currentColor; stroke-width: 1.6; fill: none; }
.feat-row .ftx b { font-family: var(--f-display); font-weight: 500; font-size: 16px; display: block; letter-spacing: -0.01em; }
.feat-row .ftx p { font-size: 13.5px; color: var(--cream-60); margin: 5px 0 0; line-height: 1.5; }

/* ---- CTA band (shared closer) ---- */
.cta-band { padding: 110px 0; text-align: center; position: relative; overflow: hidden; }
.cta-band::before { content:""; position:absolute; inset:0; background: radial-gradient(60% 80% at 50% 0%, rgba(212,168,81,0.12), transparent 60%); }
.cta-band .wrap { position: relative; z-index: 1; }
.cta-band h2 { font-family: var(--f-display); font-weight: 200; font-size: clamp(40px,6vw,72px); letter-spacing: -0.04em; line-height: 0.98; margin: 18px 0 0; }
.cta-band h2 em { font-family: var(--f-serif); font-style: italic; font-weight: 300; }
.cta-band .hero-cta { display: flex; gap: 12px; justify-content: center; margin-top: 34px; flex-wrap: wrap; }

/* ---- Footer ---- */
footer { background: var(--ink-0); border-top: 1px solid var(--ink-line); padding: 64px 0 40px; }
.foot-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; margin-bottom: 48px; }
@media (max-width: 800px){ .foot-grid { grid-template-columns: 1fr 1fr; } }
.foot-col h4 { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream-40); margin: 0 0 16px; }
.foot-col a { display: block; font-size: 13.5px; color: var(--cream-80); padding: 6px 0; transition: color .15s; }
.foot-col a:hover { color: var(--gold-100); }
.foot-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 28px; border-top: 1px solid var(--ink-line); font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--cream-40); text-transform: uppercase; flex-wrap: wrap; gap: 16px; }

/* ---- Scroll-reveal (shared, respects reduced-motion) ---- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1; transform: none; transition: none; } }

/* ---- Mobile topbar: emblem + menu button ---- */
.nav-menu-btn { display: none; width: 38px; height: 38px; flex-shrink: 0; border: 1px solid var(--ink-line); border-radius: 9px; background: var(--ink-2); cursor: pointer; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 0; }
.nav-menu-btn span { display: block; width: 16px; height: 1.6px; background: var(--cream-80); transition: transform .22s var(--ease), opacity .2s; }
.nav-menu-btn.on span:nth-child(1){ transform: translateY(5.6px) rotate(45deg); }
.nav-menu-btn.on span:nth-child(2){ opacity: 0; }
.nav-menu-btn.on span:nth-child(3){ transform: translateY(-5.6px) rotate(-45deg); }
.nav-drawer { display: none; position: absolute; top: 100%; left: 0; right: 0; background: rgba(7,16,26,0.97); backdrop-filter: blur(20px) saturate(140%); border-bottom: 1px solid var(--ink-line); flex-direction: column; padding: 8px 18px 16px; z-index: 59; box-shadow: 0 24px 50px -20px rgba(0,0,0,0.7); }
.nav-drawer.open { display: flex; }
.nav-drawer a { padding: 13px 4px; font-size: 15px; font-weight: 500; color: var(--cream-80); border-bottom: 1px solid var(--ink-line); }
.nav-drawer a:last-child { border-bottom: none; }
.nav-drawer a.on, .nav-drawer a:hover { color: var(--gold-100); }
.nav-drawer .nd-extra { color: var(--gold-100); }
@media (max-width: 980px){
  .nav-menu-btn { display: flex; }
  .tb-util .launch-btn { display: none !important; }
  .tb-mark .wm-img.is-emblem { height: 32px !important; width: 32px; object-fit: contain; }
}

/* ---- Responsive review tweak (floating control + preview overlay) ---- */
.vp-fab { position: fixed; right: 16px; bottom: 16px; z-index: 300; font-family: "JetBrains Mono", ui-monospace, monospace; }
.vp-fab-btn { display: inline-flex; align-items: center; gap: 9px; padding: 9px 15px; background: rgba(10,18,27,0.92); backdrop-filter: blur(14px); border: 1px solid var(--ink-line-strong); border-radius: 999px; color: var(--cream-80); font-family: inherit; font-size: 11px; letter-spacing: 0.08em; cursor: pointer; box-shadow: 0 14px 40px -14px rgba(0,0,0,0.7); }
.vp-fab-btn:hover { color: var(--gold-100); border-color: var(--gold-30); }
.vp-fab-btn .d { width: 6px; height: 6px; border-radius: 50%; background: var(--cream-40); transition: all .2s; }
.vp-fab.active .vp-fab-btn { color: var(--gold-100); border-color: var(--gold-30); }
.vp-fab.active .vp-fab-btn .d { background: var(--gold-100); box-shadow: 0 0 8px var(--gold-100); }
.vp-fab-menu { display: none; position: absolute; right: 0; bottom: 48px; width: 208px; background: rgba(10,18,27,0.97); backdrop-filter: blur(16px); border: 1px solid var(--ink-line-strong); border-radius: 12px; padding: 7px; box-shadow: 0 24px 60px -20px rgba(0,0,0,0.8); }
.vp-fab.open .vp-fab-menu { display: block; }
.vp-chip { display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%; padding: 8px 11px; background: transparent; border: 1px solid transparent; border-radius: 8px; color: var(--cream-60); font-family: inherit; font-size: 11px; cursor: pointer; text-align: left; }
.vp-chip:hover { background: var(--ink-2); color: var(--cream-100); }
.vp-chip.on { background: var(--gold-08); border-color: var(--gold-30); color: var(--gold-100); }
.vp-chip .l { font-size: 9px; color: var(--cream-40); letter-spacing: 0.1em; text-transform: uppercase; }
.vp-chip.on .l { color: var(--gold-100); }
.vp-scrim { position: fixed; inset: 0; z-index: 290; display: none; align-items: center; justify-content: center; background: rgba(3,6,10,0.92); backdrop-filter: blur(6px); }
.vp-scrim.on { display: flex; }
.vp-dev { background: #0a121b; border: 1px solid var(--ink-line-strong); border-radius: 16px; overflow: hidden; box-shadow: 0 40px 120px -30px rgba(0,0,0,0.85); }
.vp-dev iframe { border: 0; display: block; background: var(--ink-0); transform-origin: top left; }
.vp-cap { position: fixed; bottom: 20px; left: 0; right: 0; text-align: center; font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cream-40); pointer-events: none; }
.vp-cap b { color: var(--gold-100); }
