/* ═══════════════════════════════════════════════════════════════
   Inkgility Page Shell — shared nav + footer + theme + ambient FX
   Used by any marketing page that includes inkgility-page-shell.js
   Mirrors the canonical brand system from index.html
   ═══════════════════════════════════════════════════════════════ */

/* ── Tokens (canonical from index.html) ────────────────────────── */
:root{
  /* Brand */
  --purple:#8E21CA;
  --purple-deep:#7C3AED;
  --purple-soft:#C58BEB;
  --blue:#254AAD;
  --blue-light:#3A5BC7;
  --magenta:#D946EF;
  --green:#1A8B4E;
  --red:#C0392B;

  /* Light theme (default) */
  --dark:#F3EBEF;
  --dark2:#E8DDE3;
  --cream:#1A1625;
  --bg-warm:#F6EEF2;
  --section-alt:#E1D4DC;
  --text-heading:#1A1218;
  --text-body:#1F1828;
  --text-caption:#2E2540; /* 12.3:1 on --dark #F3EBEF, 10.0:1 on --section-alt #E1D4DC, WCAG AA */
  --muted:rgba(32,26,20,0.82); /* 8.8:1 on --dark #F3EBEF, 7.2:1 on --section-alt #E1D4DC, WCAG AA */
  --dim:rgba(32,26,20,0.10);
  --border:rgba(32,26,20,0.18);
  --border-strong:rgba(32,26,20,0.32);
  --tc:32,26,20;
  --oc:243,235,239;

  /* Gradients */
  --btn-gradient:linear-gradient(129deg,#9B3FD4,#3A5BC7);
  --gradient-line:linear-gradient(90deg,transparent,rgba(142,33,202,0.35),rgba(217,70,239,0.25),rgba(37,74,173,0.35),transparent);

  /* Shadows */
  --shadow-sm:0 1px 3px rgba(32,26,20,.06);
  --shadow-card:0 4px 18px rgba(32,26,20,.09),0 1px 4px rgba(32,26,20,.10);
  --shadow-hover:0 18px 50px rgba(32,26,20,.16),0 6px 14px rgba(32,26,20,.08);
  --shadow-3d:0 30px 70px rgba(32,26,20,.20),0 10px 24px rgba(32,26,20,.10);

  /* FX */
  --noise-opacity:0.014;
  --orb-purple:0.10;
  --orb-magenta:0.07;
  --orb-blue:0.06;
  --nav-scrolled-bg:rgba(243,235,239,0.94);

  /* System */
  --max:1320px;
  --gutter:clamp(20px,4vw,48px);
  --serif:'Instrument Serif',Georgia,serif;
  --body:'DM Sans',system-ui,sans-serif;
  --mono:'Space Mono',monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
}

[data-theme="dark"]{
  --dark:#0A0810;
  --dark2:#100D18;
  --cream:#FFFDF9;
  --bg-warm:#16102A;
  --section-alt:#0D0A14;
  --text-heading:#FFFDF9;
  --text-body:rgba(255,253,249,0.78);
  --text-caption:rgba(255,253,249,0.58);
  --muted:rgba(255,253,249,0.62);
  --dim:rgba(255,253,249,0.06);
  --border:rgba(255,253,249,0.10);
  --border-strong:rgba(255,253,249,0.22);
  --tc:255,253,249;
  --oc:10,8,16;
  --btn-gradient:linear-gradient(129deg,#8E21CA,#254AAD);
  --noise-opacity:0.030;
  --orb-purple:0.20;
  --orb-magenta:0.12;
  --orb-blue:0.10;
  --nav-scrolled-bg:rgba(10,8,16,0.94);
  --shadow-card:none;
  --shadow-hover:none;
  --shadow-3d:0 30px 80px rgba(0,0,0,.45),0 10px 24px rgba(0,0,0,.30);
}

/* ── Reset / base ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--body);
  background:var(--dark);color:var(--text-body);
  font-size:16px;line-height:1.6;overflow-x:hidden;
  transition:background .4s,color .4s;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:rgba(142,33,202,0.20);color:inherit}
[data-theme="dark"] ::selection{background:rgba(142,33,202,0.36)}

/* ── Typography primitives ────────────────────────────────────── */
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.015em}
.serif em,.h1 em,.h2 em,.h3 em{font-style:italic;color:var(--purple)}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);font-weight:700;display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--purple)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before,.eyebrow.center::after{content:'';width:24px;height:1px;background:var(--purple)}

/* ═══════════════════════════════════════════════════════════════
   AMBIENT FX — noise overlay + floating gradient orbs
   ═══════════════════════════════════════════════════════════════ */
body::after{
  content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:var(--noise-opacity);mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
[data-theme="dark"] body::after{mix-blend-mode:screen}

/* ═══ Page atmosphere (matches index.html — sitewide via shell) ═══ */
#page-atmosphere{position:fixed;inset:0;z-index:100;pointer-events:none;overflow:hidden;contain:layout style;mix-blend-mode:normal}
#page-atmosphere > *{position:absolute;pointer-events:none}

/* Orbs */
.pa-orb{border-radius:50%;filter:blur(130px);will-change:transform}
.pa-orb-1{width:600px;height:600px;background:rgba(142,33,202,.14);top:-12%;left:-8%;animation:paOrb1 24s ease-in-out infinite}
.pa-orb-2{width:520px;height:520px;background:rgba(142,33,202,.10);bottom:-10%;right:-8%;animation:paOrb2 28s ease-in-out infinite}
.pa-orb-3{width:460px;height:460px;background:rgba(212,73,170,.10);top:38%;right:6%;animation:paOrb3 22s ease-in-out infinite}
.pa-orb-4{width:480px;height:480px;background:rgba(37,74,173,.10);bottom:20%;left:14%;animation:paOrb4 26s ease-in-out infinite}
[data-theme="dark"] .pa-orb-1{background:rgba(142,33,202,.22)}
[data-theme="dark"] .pa-orb-2{background:rgba(142,33,202,.18)}
[data-theme="dark"] .pa-orb-3{background:rgba(212,73,170,.16)}
[data-theme="dark"] .pa-orb-4{background:rgba(37,74,173,.14)}
.pa-orb,.pa-ink{mix-blend-mode:multiply;will-change:transform,opacity}
[data-theme="dark"] .pa-orb,[data-theme="dark"] .pa-ink{mix-blend-mode:screen}
@keyframes paOrb1{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(50px,-30px,0)}}
@keyframes paOrb2{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-40px,25px,0)}}
@keyframes paOrb3{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-35px,40px,0)}}
@keyframes paOrb4{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(45px,-20px,0)}}

/* Ink blooms */
.pa-ink{border-radius:50%;filter:blur(70px);opacity:0;animation:paInk 22s ease-in-out infinite}
.pa-ink-1{width:520px;height:520px;background:radial-gradient(circle,rgba(142,33,202,.32),transparent 70%);top:18%;left:22%}
.pa-ink-2{width:460px;height:460px;background:radial-gradient(circle,rgba(212,73,170,.28),transparent 70%);bottom:14%;right:18%;animation-delay:11s}
@keyframes paInk{0%,100%{opacity:0;transform:scale(.85)}40%{opacity:.45;transform:scale(1.08)}70%{opacity:.25;transform:scale(1)}}

/* Drifting grid */
.pa-grid{inset:0;background-image:linear-gradient(rgba(142,33,202,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(142,33,202,.16) 1px,transparent 1px);background-size:80px 80px;animation:paGrid 18s linear infinite;opacity:.04;mask-image:radial-gradient(ellipse 90% 75% at 50% 50%,#000,transparent 92%)}
[data-theme="dark"] .pa-grid{opacity:.10}
@keyframes paGrid{from{background-position:0 0}to{background-position:80px 80px}}

/* Cursor spotlight */
.pa-spot{width:700px;height:700px;background:radial-gradient(circle,rgba(142,33,202,.22) 0%,rgba(142,33,202,.10) 30%,transparent 60%);filter:blur(14px);opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1);mix-blend-mode:multiply;will-change:transform,opacity;top:0;left:0}
[data-theme="dark"] .pa-spot{mix-blend-mode:screen;background:radial-gradient(circle,rgba(142,33,202,.30) 0%,rgba(142,33,202,.14) 30%,transparent 60%)}
.pa-spot.on{opacity:1}

/* Reduced-motion + mobile gating */
@media(prefers-reduced-motion:reduce){.pa-orb,.pa-ink,.pa-grid,.pa-spot{animation:none!important}}
@media(max-width:760px){.pa-orb-3,.pa-orb-4,.pa-ink,.pa-spot{display:none}.pa-orb-1,.pa-orb-2{width:300px;height:300px}}

/* Body needs position:relative for atmosphere stacking */
body{position:relative}

/* Legacy .fx-orb retained as a transparent shim so older pages don't break */
.fx-orb{display:none}

/* ═══════════════════════════════════════════════════════════════
   PAGE LOADER
   ═══════════════════════════════════════════════════════════════ */
.page-loader{position:fixed;inset:0;background:var(--dark);z-index:9998;display:flex;align-items:center;justify-content:center;transition:opacity .4s ease;pointer-events:none}
.page-loader.hidden{opacity:0;pointer-events:none}
.loader-ring{width:38px;height:38px;border:2px solid var(--dim);border-top-color:var(--purple);border-radius:50%;animation:loaderSpin 1s linear infinite}
@keyframes loaderSpin{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════════════════════════════
   SITE NAV
   ═══════════════════════════════════════════════════════════════ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:18px var(--gutter);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  background:transparent;backdrop-filter:none;border-bottom:1px solid transparent;
  transition:background .5s var(--ease),box-shadow .5s,border-color .5s,backdrop-filter .5s,padding .3s;
}
.site-nav.scrolled{
  background:var(--nav-scrolled-bg);backdrop-filter:blur(20px) saturate(160%);
  border-bottom-color:var(--border);
  box-shadow:0 2px 32px rgba(0,0,0,0.06);
  padding:12px var(--gutter);
}
.site-nav::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:var(--gradient-line);background-size:200% 100%;
  animation:navShimmer 7s linear infinite;opacity:0;transition:opacity .4s;
}
.site-nav.scrolled::after{opacity:1}
@keyframes navShimmer{0%{background-position:0% 0%}100%{background-position:200% 0%}}

.nav-left{display:flex;align-items:center;gap:14px;animation:navFadeIn .6s ease .2s both}
.nav-logo{display:flex;justify-content:center;animation:navFadeIn .6s ease .1s both}
.nav-logo img{width:160px;max-width:40vw;height:auto;display:block;transition:opacity .3s}
[data-theme="dark"] .nav-logo img{content:url('https://www.inkgility.com/theme/site/assets/inkgility-logo-white.svg')}
.nav-right{display:flex;align-items:center;gap:18px;justify-self:end;animation:navFadeIn .6s ease .3s both}
@keyframes navFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

.menu-btn,.search-btn{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);padding:8px 0;transition:color .3s;display:inline-flex;align-items:center;gap:8px;
}
.menu-btn:hover,.search-btn:hover{color:var(--cream)}
.search-btn svg{width:14px;height:14px;stroke:currentColor;fill:none}
.theme-toggle{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  color:var(--muted);transition:color .3s,background .3s;position:relative;
}
.theme-toggle:hover{color:var(--cream);background:var(--dim)}
.theme-toggle svg{width:16px;height:16px;stroke:currentColor;fill:none;position:absolute;transition:opacity .3s,transform .3s}
.theme-icon-sun{opacity:0;transform:scale(.8) rotate(-90deg)}
.theme-icon-moon{opacity:1}
[data-theme="dark"] .theme-icon-sun{opacity:1;transform:scale(1) rotate(0)}
[data-theme="dark"] .theme-icon-moon{opacity:0;transform:scale(.8) rotate(90deg)}

.start-btn{
  font-family:var(--serif);font-size:15px;font-style:italic;font-weight:400;
  padding:10px 22px;border-radius:60px;color:#fff;
  background:var(--btn-gradient);
  transition:box-shadow .3s,transform .3s;
  animation:startBtnPulse 3s ease-in-out infinite;
}
.start-btn:hover{box-shadow:0 0 32px rgba(142,33,202,.25);transform:scale(1.03);animation:none}
@keyframes startBtnPulse{0%,100%{box-shadow:0 0 0 0 rgba(142,33,202,0)}50%{box-shadow:0 0 20px 4px rgba(142,33,202,.15)}}

/* ═══════════════════════════════════════════════════════════════
   MEGA MENU
   ═══════════════════════════════════════════════════════════════ */
.mega-menu{
  position:fixed;inset:0;z-index:190;
  background:rgba(243,235,239,0.96);backdrop-filter:blur(40px);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:110px 24px 24px;overflow:hidden;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease),visibility .4s var(--ease);
}
[data-theme="dark"] .mega-menu{background:rgba(10,8,16,0.96)}
.mega-menu.open{opacity:1;visibility:visible}
.menu-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);z-index:0}
.menu-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(142,33,202,.10),transparent 70%);top:-5%;left:10%}
.menu-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(217,70,239,.08),transparent 70%);bottom:-5%;right:10%}
.menu-orb-3{width:280px;height:280px;background:radial-gradient(circle,rgba(37,74,173,.06),transparent 70%);top:40%;left:50%;transform:translateX(-50%)}
[data-theme="dark"] .menu-orb-1{background:radial-gradient(circle,rgba(142,33,202,.18),transparent 70%)}
[data-theme="dark"] .menu-orb-2{background:radial-gradient(circle,rgba(217,70,239,.12),transparent 70%)}
[data-theme="dark"] .menu-orb-3{background:radial-gradient(circle,rgba(37,74,173,.10),transparent 70%)}

.menu-inner{max-width:1200px;width:100%;position:relative;z-index:1;opacity:0;transform:translateY(12px) scale(.985);transition:opacity .45s var(--ease) .08s,transform .45s var(--ease) .08s}
.mega-menu.open .menu-inner{opacity:1;transform:translateY(0) scale(1)}
.menu-cats{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-bottom:1px solid var(--border);margin-bottom:32px;position:relative}
@media(max-width:880px){.menu-cats{grid-template-columns:repeat(3,1fr)}}
.menu-cats-underline{position:absolute;bottom:-1px;height:2px;background:var(--btn-gradient);border-radius:2px;transition:left .35s var(--ease),width .35s var(--ease)}
.menu-cat{padding:16px 0;text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(var(--tc),0.55);cursor:pointer;transition:color .3s;font-weight:700}
.menu-cat:hover{color:var(--cream)}
.menu-cat.active{color:var(--purple)}

.menu-items{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-height:calc(100vh - 320px);overflow-y:auto;padding-right:4px}
@media(max-width:760px){.menu-items{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.menu-items{grid-template-columns:1fr}}
.menu-items::-webkit-scrollbar{width:4px}.menu-items::-webkit-scrollbar-thumb{background:rgba(var(--tc),.12);border-radius:4px}
.menu-item{padding:0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;transition:all .25s var(--ease);border:1px solid transparent;overflow:hidden;text-decoration:none;opacity:0;transform:translateY(8px)}
.mega-menu.open .menu-item{opacity:1;transform:translateY(0)}
.menu-item:hover{border-color:rgba(142,33,202,.18);box-shadow:0 0 24px rgba(142,33,202,.08)}
.menu-item-thumb{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(142,33,202,.08),rgba(37,74,173,.06));transition:background .25s}
.menu-item:hover .menu-item-thumb{background:linear-gradient(135deg,rgba(142,33,202,.14),rgba(37,74,173,.10))}
.menu-item-thumb svg{width:32px;height:32px;stroke:var(--purple);fill:none;stroke-width:1.5}
.menu-item-content{padding:12px 14px}
.menu-item-name{font-family:var(--body);font-size:13px;font-weight:600;color:var(--text-heading);margin-bottom:3px}
.menu-item-desc{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--muted)}
.menu-bottom{margin-top:32px;text-align:center;padding-top:20px;border-top:1px solid var(--border)}
.menu-bottom-link{font-family:var(--serif);font-size:17px;font-style:italic;color:var(--purple);cursor:pointer}
.menu-bottom-link:hover{opacity:.7}

/* ═══════════════════════════════════════════════════════════════
   SEARCH OVERLAY
   ═══════════════════════════════════════════════════════════════ */
.search-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(243,235,239,0.92);backdrop-filter:blur(0);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:16vh;opacity:0;visibility:hidden;
  transition:opacity .35s var(--ease),backdrop-filter .5s var(--ease),visibility .35s;
}
[data-theme="dark"] .search-overlay{background:rgba(10,8,16,0.92)}
.search-overlay.open{opacity:1;visibility:visible;backdrop-filter:blur(30px)}
.search-box{width:90%;max-width:680px;position:relative;opacity:0;transform:translateY(-20px) scale(.97);transition:opacity .4s cubic-bezier(.34,1.56,.64,1) .08s,transform .4s cubic-bezier(.34,1.56,.64,1) .08s}
.search-overlay.open .search-box{opacity:1;transform:translateY(0) scale(1)}
.search-input{
  width:100%;font-family:var(--serif);font-size:clamp(24px,4vw,42px);
  background:none;border:none;border-bottom:1.5px solid rgba(var(--tc),.10);
  color:var(--cream);padding:12px 0;outline:none;transition:border-color .3s;
}
.search-input::placeholder{color:rgba(var(--tc),.40)}
.search-input:focus{border-bottom-color:rgba(var(--tc),.20)}
.search-close{position:absolute;top:-44px;right:0;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);background:none;border:none;cursor:pointer}
.search-close:hover{color:var(--cream)}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-foot{
  background:var(--dark);position:relative;padding:96px var(--gutter) 36px;
  border-top:1px solid var(--border);overflow:hidden;
}
.site-foot::before{
  content:'';position:absolute;top:-180px;left:50%;transform:translateX(-50%);
  width:80%;max-width:1100px;height:360px;
  background:radial-gradient(ellipse,rgba(142,33,202,.10),transparent 60%);
  filter:blur(60px);pointer-events:none;
}
[data-theme="dark"] .site-foot::before{background:radial-gradient(ellipse,rgba(142,33,202,.18),transparent 60%)}
.foot-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:48px;border-bottom:1px solid var(--border)}
@media(max-width:980px){.foot-grid{grid-template-columns:1fr 1fr 1fr;gap:32px}}
@media(max-width:640px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:440px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{display:flex;flex-direction:column;gap:14px;max-width:300px}
.foot-logo img{width:180px;height:auto;max-width:100%;display:block}
/* dark-theme content swap removed — local SVG works in both */
.foot-tagline{font-family:var(--serif);font-size:18px;color:var(--text-heading);font-style:italic;line-height:1.3}
.foot-contact{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}
.foot-socials{display:grid;grid-template-columns:repeat(4,40px);gap:10px;margin-top:18px;justify-content:start}
.foot-social{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);background:rgba(var(--tc),0.02);transition:.2s var(--ease);text-decoration:none}
.foot-social svg{width:18px;height:18px;display:block;color:inherit;fill:currentColor;transition:transform .2s}
.foot-social:hover{color:var(--purple);border-color:var(--purple);background:rgba(142,33,202,0.10);box-shadow:0 0 16px rgba(142,33,202,0.15);transform:translateY(-2px)}
.foot-social:hover svg{transform:scale(1.08)}
@media(max-width:520px){.foot-socials{grid-template-columns:repeat(4,36px)}.foot-social{width:36px;height:36px}.foot-social svg{width:16px;height:16px}}
.foot-col-title{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--purple);font-weight:700;margin-bottom:18px}
.foot-link{display:block;padding:6px 0;font-family:var(--body);font-size:14px;color:var(--text-body);transition:color .15s}
.foot-link:hover{color:var(--purple)}
.foot-bottom{max-width:var(--max);margin:0 auto;padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted)}
.foot-bottom-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-bottom-links a:hover{color:var(--purple)}

/* ═══════════════════════════════════════════════════════════════
   SHARED PAGE FRAME (top padding for fixed nav)
   ═══════════════════════════════════════════════════════════════ */
#page-content{padding-top:80px;position:relative;z-index:1}

/* ═══════════════════════════════════════════════════════════════
   REVEAL ON SCROLL
   ═══════════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.06s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.18s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.24s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.30s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.36s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.42s}

/* ═══════════════════════════════════════════════════════════════
   3D HOVER EFFECTS (cards/screenshots)
   ═══════════════════════════════════════════════════════════════ */
.tilt-card{transform-style:preserve-3d;transition:transform .35s var(--ease),box-shadow .35s var(--ease);will-change:transform}
.tilt-card:hover{transform:perspective(1200px) rotateY(-3deg) rotateX(2deg) translateY(-4px);box-shadow:var(--shadow-3d)}

/* ═══════════════════════════════════════════════════════════════
   UTILITIES
   ═══════════════════════════════════════════════════════════════ */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.h1{font-family:var(--serif);font-weight:400;font-size:clamp(42px,6.5vw,92px);letter-spacing:-0.025em;line-height:.98}
.h2{font-family:var(--serif);font-weight:400;font-size:clamp(34px,4.5vw,60px);letter-spacing:-0.02em;line-height:1.05}
.h3{font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.4vw,30px);letter-spacing:-0.012em;line-height:1.15}
.lede{font-size:clamp(17px,1.5vw,21px);color:var(--text-body);line-height:1.55;max-width:60ch}
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:60px;background:var(--btn-gradient);color:#fff;font-family:var(--serif);font-style:italic;font-size:16px;box-shadow:0 8px 32px rgba(142,33,202,.22),inset 0 1px 0 rgba(255,255,255,.18);transition:.25s var(--ease)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(142,33,202,.32);filter:brightness(1.06)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:14px 0;border-bottom:1px solid var(--text-heading);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--text-heading)}
.btn-ghost:hover{color:var(--purple);border-color:var(--purple)}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE NAV (mobile)
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:760px){
  .site-nav{padding:14px 16px}
  .site-nav.scrolled{padding:10px 16px}
  .nav-left .menu-btn{font-size:10px}
  .nav-logo img{width:120px}
  .nav-right{gap:10px}
  .start-btn{padding:8px 16px;font-size:13px}
  .search-btn span,.menu-btn:not(:first-child){display:none}
  #page-content{padding-top:64px}
}

/* ═══════════════════════════════════════════════════════════════
   FOCUS VISIBLE
   ═══════════════════════════════════════════════════════════════ */
:focus-visible{outline:2px solid var(--purple);outline-offset:3px;border-radius:2px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--purple);color:#fff;padding:10px 18px;border-radius:0 0 8px 0;z-index:9999}
.skip-link:focus{left:0}


/* ═══ Cart button (nav) + peek modal ═══ */
.cart-btn{position:relative;background:transparent;border:none;padding:8px;cursor:pointer;color:var(--cream);display:inline-flex;align-items:center;justify-content:center;border-radius:6px;transition:.15s}
.cart-btn:hover{background:rgba(142,33,202,.10);color:var(--purple)}
.cart-btn svg{width:20px;height:20px}
.cart-count{position:absolute;top:-2px;right:-2px;background:var(--purple);color:#fff;font-family:'Space Mono',monospace;font-size:9px;font-weight:700;padding:2px 6px;border-radius:30px;line-height:1;min-width:18px;text-align:center}
.cart-count:empty{display:none}

.peek-cart-scrim{position:fixed;inset:0;background:rgba(0,0,0,.50);z-index:240;opacity:0;visibility:hidden;transition:.25s;backdrop-filter:blur(4px)}
.peek-cart-scrim.open{opacity:1;visibility:visible}
.peek-cart{position:fixed;top:0;right:0;width:380px;max-width:100vw;height:100vh;background:var(--dark);border-left:1px solid var(--border);z-index:250;transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,.30)}
.peek-cart.open{transform:translateX(0)}
.peek-cart-head{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.peek-cart-title{font-family:'Instrument Serif',serif;font-size:24px;color:var(--text-heading);letter-spacing:-.01em}
.peek-cart-close{background:none;border:none;color:var(--text-caption);font-size:24px;cursor:pointer;padding:4px 10px;border-radius:6px;line-height:1}
.peek-cart-close:hover{background:rgba(142,33,202,.06);color:var(--text-heading)}
.peek-cart-body{flex:1;overflow-y:auto;padding:14px 20px}
.peek-cart-empty{text-align:center;padding:48px 20px}
.peek-cart-empty svg{width:36px;height:36px;color:var(--purple);opacity:.4;margin-bottom:10px}
.peek-cart-empty p{font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--text-caption)}

.peek-row{display:grid;grid-template-columns:50px 1fr auto;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.peek-row:last-child{border-bottom:none}
.peek-row-pic{width:50px;aspect-ratio:1.75/1;border-radius:5px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.18)}
.peek-row-pic span{font-family:'Space Mono',monospace;font-size:8px;font-weight:700;color:#fff;letter-spacing:.06em;text-shadow:0 1px 2px rgba(0,0,0,.40)}
.peek-row-body{min-width:0}
.peek-row-name{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--text-heading);line-height:1.3;margin-bottom:3px}
.peek-row-specs{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-caption);line-height:1.45;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.peek-row-qty{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:5px;margin-top:6px;overflow:hidden}
.peek-row-qty button{width:22px;height:22px;background:var(--bg-warm);border:none;color:var(--text-body);cursor:pointer;font-size:13px;font-weight:600;padding:0}
.peek-row-qty button:hover{background:rgba(142,33,202,.10);color:var(--purple)}
.peek-row-qty span{padding:0 8px;font-family:'Space Mono',monospace;font-size:11px;color:var(--text-heading);font-weight:700;min-width:24px;text-align:center;line-height:22px}
.peek-row-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.peek-row-price{font-family:'Instrument Serif',serif;font-size:15px;color:var(--text-heading);font-variant-numeric:tabular-nums}
.peek-row-rm{background:none;border:none;color:var(--text-caption);font-family:'DM Sans',sans-serif;font-size:10.5px;cursor:pointer;text-decoration:underline;padding:0}
.peek-row-rm:hover{color:#E74C3C}

.peek-cart-foot{padding:18px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;flex-shrink:0;background:var(--bg-warm)}
.peek-cart-sub{display:flex;justify-content:space-between;align-items:baseline;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text-body)}
.peek-cart-sub strong{font-family:'Instrument Serif',serif;font-size:22px;color:var(--text-heading);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.peek-cart-cta{display:block;text-align:center;padding:12px;background:var(--btn-gradient);color:#fff!important;text-decoration:none;border-radius:60px;font-family:'Instrument Serif',serif;font-style:italic;font-size:15px;font-weight:500;transition:.2s;box-shadow:0 6px 22px rgba(142,33,202,.25)}
.peek-cart-cta:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(142,33,202,.35)}
@media(max-width:520px){.peek-cart{width:100vw}}
