/* ============================================================================
   MatrixInn Solutions — Shared Design System (app.css)
   Faithfully extracted from the homepage (index.php) so every page + the blog
   share the exact same premium dark look. Sub-page components appended below.
   ============================================================================ */

/* ===== Tokens ===== */
:root{
  --ink:#0a0c12; --ink-2:#0e111a; --panel:#141926; --panel-2:#1a2030;
  --paper:#eef0f6; --paper-dim:#b7c0d2; --muted:#8b93a8;
  --blue:#3a6bff; --blue-lt:#7d9cff; --blue-deep:#274ed6;
  --lime:#c9f24e; --lime-deep:#a9d62f;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.16);
  --r:14px; --r-lg:22px; --r-xl:30px;
  --wrap:1240px;
  --serif:'Bricolage Grotesque',Georgia,serif;
  --sans:'Hanken Grotesk',ui-sans-serif,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --ease:cubic-bezier(.2,.7,.3,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--sans); background:var(--ink); color:var(--paper);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; position:relative;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none;padding:0}
::selection{background:var(--lime);color:var(--ink)}
:focus-visible{outline:2px solid var(--lime);outline-offset:3px;border-radius:4px}

/* ===== Texture layers ===== */
.bg-grid,.bg-grain{position:fixed;inset:0;pointer-events:none;z-index:0}
.bg-grid{
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; opacity:.5;
  -webkit-mask-image:radial-gradient(ellipse 100% 100% at 50% 0%,#000 0%,transparent 80%);
  mask-image:radial-gradient(ellipse 100% 100% at 50% 0%,#000 0%,transparent 80%);
}
.bg-grain{
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.glow-orb{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;opacity:.5}
.orb-1{top:-200px;left:-150px;width:560px;height:560px;background:radial-gradient(circle,rgba(58,107,255,.55),transparent 70%)}
.orb-2{top:30vh;right:-200px;width:480px;height:480px;background:radial-gradient(circle,rgba(201,242,78,.18),transparent 70%)}

/* ===== Custom cursor ===== */
.cursor-ring,.cursor-dot{position:fixed;top:0;left:0;z-index:9000;pointer-events:none;border-radius:50%;
  transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor-ring{width:38px;height:38px;border:1.5px solid #fff;transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .3s}
.cursor-dot{width:5px;height:5px;background:#fff}
body.cursor-hover .cursor-ring{width:64px;height:64px;background:rgba(255,255,255,.12);border-color:transparent}
@media (hover:none),(pointer:coarse){.cursor-ring,.cursor-dot{display:none}}

/* ===== Scroll progress ===== */
.scrollbar{position:fixed;top:0;left:0;height:2px;width:100%;background:linear-gradient(90deg,var(--blue),var(--lime));z-index:8000;transform:scaleX(0);transform-origin:left;will-change:transform}

/* ===== Layout ===== */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:28px;position:relative;z-index:2}
section{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;color:var(--lime)}
.eyebrow .bar{width:26px;height:1px;background:var(--lime);opacity:.7}
.sec-label{position:absolute;top:0;left:28px;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.1em}

h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.02;letter-spacing:-.02em}
.display{font-size:clamp(2.9rem,7.5vw,6.4rem);font-weight:800;letter-spacing:-.035em;line-height:.95}
.h2{font-size:clamp(2.1rem,4.8vw,3.9rem);font-weight:700;letter-spacing:-.03em;line-height:1}
.lead{font-size:clamp(1.06rem,1.5vw,1.32rem);color:var(--paper-dim);line-height:1.62;max-width:56ch}
.outline-word{-webkit-text-stroke:1.4px var(--paper);color:transparent}
.accent{color:var(--lime)}.blueon{color:var(--blue-lt)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:15.5px;
  padding:15px 26px;border-radius:999px;position:relative;transition:transform .3s var(--ease-out),background .25s,color .25s,box-shadow .25s;will-change:transform}
.btn .arr{transition:transform .3s var(--ease-out)}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--lime);color:var(--ink);box-shadow:0 0 0 0 rgba(201,242,78,.5)}
.btn-primary:hover{box-shadow:0 14px 40px -10px rgba(201,242,78,.6)}
.btn-glass{border:1px solid var(--line-2);color:var(--paper);background:rgba(255,255,255,.02)}
.btn-glass:hover{background:rgba(255,255,255,.07);border-color:var(--paper)}
.btn-lg{padding:18px 32px;font-size:17px}

/* ===== Nav ===== */
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:var(--wrap);
  z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:20px;border-radius:999px;border:1px solid rgba(255,255,255,.7);
  background:rgba(255,255,255,.88);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 10px 34px -14px rgba(0,0,0,.55);transition:background .3s,box-shadow .3s,border-color .3s}
.nav.scrolled{background:#fff;box-shadow:0 18px 44px -16px rgba(0,0,0,.5);border-color:#fff}
.nav-logo{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--ink)}
.nav-logo img{height:40px;width:auto}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-size:16px;font-weight:500;color:#3c465a;padding:9px 15px;border-radius:999px;transition:color .2s,background .2s}
.nav-links a:hover{color:var(--ink);background:rgba(10,12,18,.06)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-burger{display:none;width:44px;height:44px;border-radius:999px;border:1px solid rgba(10,12,18,.14)}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);margin:4px auto;border-radius:2px;transition:.3s}

/* ===== Hero ===== */
.hero{padding:170px 0 90px;position:relative}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(340px,480px);gap:52px;align-items:center}
.hero-grid>div:first-child{min-width:0}
.hero-badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--paper-dim);border:1px solid var(--line);border-radius:999px;padding:8px 15px;margin-bottom:30px;
  background:rgba(255,255,255,.02)}
.dotpulse{width:8px;height:8px;border-radius:50%;background:var(--lime)}
@media (prefers-reduced-motion:no-preference){.dotpulse{animation:pulse 2.2s infinite}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(201,242,78,.6)}70%{box-shadow:0 0 0 9px rgba(201,242,78,0)}100%{box-shadow:0 0 0 0 rgba(201,242,78,0)}}
.hero h1{margin-bottom:26px}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:block;transform:translateY(110%)}
.hero p.sub{margin-bottom:36px;font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--paper-dim);max-width:46ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero-meta{display:flex;gap:26px;flex-wrap:wrap}
.hero-meta .m .n{font-family:var(--serif);font-weight:700;font-size:1.5rem}
.hero-meta .m .l{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-top:2px}

/* hero product showcase */
.showcase{position:relative;width:100%;aspect-ratio:1/.96;max-width:560px;margin-inline:auto;transition:transform .3s var(--ease)}
.sc-card{position:absolute;border-radius:18px;border:1px solid var(--line-2);background:var(--panel);
  box-shadow:0 34px 70px -28px rgba(0,0,0,.8);overflow:hidden;will-change:transform}
@media (prefers-reduced-motion:no-preference){.sc-card{animation:floaty 7s ease-in-out infinite}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.sc-dash{top:4%;left:5%;width:74%}
.sc-phone{bottom:0;left:0;width:32%;aspect-ratio:.52/1;animation-delay:1.3s;background:#0b0f17}
.sc-ai{bottom:11%;right:0;width:53%;padding:16px;animation-delay:.6s;background:linear-gradient(145deg,rgba(58,107,255,.2),var(--panel))}
.sc-win{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:10px;color:var(--muted)}
.sc-win i{width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.sc-win b{margin-left:auto;font-weight:500;letter-spacing:.1em;text-transform:uppercase}
.sc-dash-body{padding:18px}
.sc-kpi-v{font-family:var(--serif);font-weight:800;font-size:1.85rem;line-height:1}
.sc-kpi-l{font-family:var(--mono);font-size:11px;color:var(--lime);margin:4px 0 16px}
.sc-bars{display:flex;align-items:flex-end;gap:8px;height:92px}
.sc-bars i{flex:1;height:var(--h);background:linear-gradient(to top,var(--blue),var(--blue-lt));border-radius:5px 5px 0 0;transform-origin:bottom}
@media (prefers-reduced-motion:no-preference){.sc-bars i{animation:grow 1s var(--ease-out) backwards}
  .sc-bars i:nth-child(2){animation-delay:.08s}.sc-bars i:nth-child(3){animation-delay:.16s}.sc-bars i:nth-child(4){animation-delay:.24s}.sc-bars i:nth-child(5){animation-delay:.32s}.sc-bars i:nth-child(6){animation-delay:.4s}}
@keyframes grow{from{transform:scaleY(0)}}
.sc-phone-notch{width:36%;height:6px;background:#000;border-radius:0 0 9px 9px;margin:0 auto}
.sc-phone-screen{padding:14px 11px}
.sc-app-h{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--paper-dim);margin-bottom:14px}
.sc-app-h i{width:8px;height:8px;border-radius:50%;background:var(--lime)}
.sc-row{height:32px;border-radius:9px;background:rgba(255,255,255,.05);margin-bottom:9px}
.sc-row.hl{background:rgba(58,107,255,.22)}
.sc-ai-h{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:700;font-size:14px;margin-bottom:12px;color:#fff}
.sc-ai-av{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--lime);color:var(--ink);font-family:var(--mono);font-size:10.5px;font-weight:600}
.sc-ai-msg{font-size:12.5px;color:var(--paper-dim);background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:10px}
.sc-typing{display:flex;gap:5px}
.sc-typing i{width:7px;height:7px;border-radius:50%;background:var(--lime)}
@media (prefers-reduced-motion:no-preference){.sc-typing i{animation:blink 1.3s infinite}.sc-typing i:nth-child(2){animation-delay:.2s}.sc-typing i:nth-child(3){animation-delay:.4s}}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1}}

/* ===== Marquee ===== */
.marq{border-block:1px solid var(--line);padding:26px 0;overflow:hidden;background:var(--ink-2)}
.marq-row{display:flex;gap:0;width:max-content}
@media (prefers-reduced-motion:no-preference){.marq-row{animation:scroll 34s linear infinite}}
@keyframes scroll{to{transform:translateX(-50%)}}
.marq-item{display:inline-flex;align-items:center;gap:13px;padding:0 30px;font-family:var(--serif);font-weight:600;
  font-size:1.45rem;color:var(--paper-dim);white-space:nowrap}
.marq-item .st{color:var(--blue-lt);font-size:1rem}

/* ===== Section heading ===== */
.sec{padding:clamp(80px,10vw,150px) 0}
.sec-head{max-width:760px;margin-bottom:62px}
.sec-head .h2{margin-top:18px}
.sec-head p{margin-top:20px}

/* ===== Capabilities ===== */
.caps{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.cap{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;background:var(--ink-2);
  overflow:hidden;transition:border-color .3s,transform .3s var(--ease-out)}
.cap::before{content:'';position:absolute;inset:-1px;border-radius:inherit;opacity:0;transition:opacity .35s;
  background:radial-gradient(380px circle at var(--x,50%) var(--y,50%),rgba(58,107,255,.16),transparent 60%)}
.cap:hover{border-color:var(--line-2);transform:translateY(-4px)}
.cap:hover::before{opacity:1}
.cap::after{content:'';position:absolute;top:-1px;left:-1px;height:2px;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--blue),var(--lime));transition:width .45s var(--ease);z-index:3}
.cap:hover::after{width:calc(100% + 2px)}
.cap>*{position:relative}
.cap .no{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em}
.cap .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin:18px 0 16px;
  border:1px solid var(--line-2);color:var(--lime);background:rgba(201,242,78,.05);
  transition:transform .4s var(--ease-out),color .3s,background .3s}
.cap:hover .ic{transform:translateY(-2px) rotate(-7deg);background:rgba(201,242,78,.12)}
.cap .go{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;color:var(--lime);
  margin-top:16px;opacity:0;transform:translateY(7px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.cap .go svg{transition:transform .3s var(--ease)}
.cap:hover .go{opacity:1;transform:none}
.cap:hover .go svg{transform:translateX(3px)}
.cap h3{font-size:1.5rem;margin-bottom:9px}
.cap p{color:var(--muted);font-size:15px}
.cap .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.cap .tag{font-family:var(--mono);font-size:11px;color:var(--paper-dim);border:1px solid var(--line);padding:4px 10px;border-radius:999px}
.cap-6{grid-column:span 6}.cap-4{grid-column:span 4}.cap-3{grid-column:span 3}
.cap.feature{background:linear-gradient(135deg,rgba(58,107,255,.14),transparent 60%),var(--ink-2)}
.cap.feature .ic{color:var(--blue-lt);background:rgba(58,107,255,.08)}

/* ===== Process ===== */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;counter-reset:step}
.proc-track{position:absolute;top:30px;left:5%;right:5%;height:1px;background:var(--line)}
.proc-track .fill{height:100%;width:100%;background:linear-gradient(90deg,var(--blue),var(--lime))}
.pstep{position:relative}
.pstep .ring{width:60px;height:60px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;
  font-family:var(--mono);font-size:15px;color:var(--lime);background:var(--ink);margin-bottom:20px}
.pstep h4,.pstep-h{font-size:1.22rem;margin-bottom:9px}
.pstep p{color:var(--muted);font-size:14.5px}

/* ===== Work ===== */
.work{display:grid;gap:18px}
.case{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;padding:30px 4px;border-top:1px solid var(--line);
  transition:background .3s,padding-left .3s var(--ease);cursor:pointer}
.case:last-child{border-bottom:1px solid var(--line)}
.case:hover{padding-left:18px}
.case .cno{font-family:var(--mono);font-size:13px;color:var(--muted)}
.case .ctitle{font-family:var(--serif);font-weight:700;font-size:clamp(1.5rem,3vw,2.4rem);transition:color .3s}
.case:hover .ctitle{color:var(--lime)}
.case .cmeta{font-family:var(--mono);font-size:12px;color:var(--paper-dim);letter-spacing:.04em}
.case .cgo{width:48px;height:48px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;transition:.3s var(--ease-out)}
.case:hover .cgo{background:var(--lime);color:var(--ink);transform:rotate(-45deg)}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.stat{background:var(--ink-2);padding:40px 26px;text-align:center}
.stat .v{font-family:var(--serif);font-weight:800;font-size:clamp(2.6rem,5vw,3.8rem);letter-spacing:-.03em;line-height:1}
.stat .v .sfx{color:var(--lime)}
.stat .l{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.06em;margin-top:10px;text-transform:uppercase}

/* ===== Quote ===== */
.quote-wrap{max-width:1000px}
.quote{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3.8vw,3rem);line-height:1.2;letter-spacing:-.02em}
.quote .hl{background:linear-gradient(120deg,var(--blue-lt),var(--lime));-webkit-background-clip:text;background-clip:text;color:transparent}
.quote-by{display:flex;align-items:center;gap:14px;margin-top:34px;font-family:var(--mono);font-size:13px;color:var(--muted);letter-spacing:.06em}
.quote-by .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--lime))}

/* ===== FAQ ===== */
.faq{max-width:880px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:26px 4px;cursor:pointer;
  font-family:var(--serif);font-weight:600;font-size:clamp(1.1rem,2vw,1.4rem);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex-shrink:0;width:30px;height:30px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--lime);transition:transform .3s var(--ease),background .3s}
.faq details[open] summary .pm{transform:rotate(135deg);background:var(--lime);color:var(--ink)}
.faq .a{padding:0 4px 28px;color:var(--paper-dim);font-size:16px;max-width:72ch}

/* ===== CTA ===== */
.cta{position:relative;border:1px solid var(--line-2);border-radius:var(--r-xl);padding:clamp(44px,7vw,84px);overflow:hidden;
  background:radial-gradient(120% 120% at 0% 0%,rgba(58,107,255,.2),transparent 55%),var(--ink-2);text-align:center}
.cta::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;right:-120px;bottom:-160px;
  background:radial-gradient(circle,rgba(201,242,78,.22),transparent 65%);filter:blur(20px)}
.cta h2{position:relative}
.cta-row{position:relative;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}

/* ===== Footer ===== */
.footer{border-top:1px solid var(--line);padding:74px 0 40px;background:var(--ink-2)}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid var(--line)}
.foot-brand .nav-logo{color:#fff}
.foot-brand .nav-logo img{height:40px;width:auto}
.foot-brand p{color:var(--muted);max-width:32ch;margin-top:16px;font-size:15px}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:16px}
.foot-col li{margin-bottom:11px}
.foot-col a{color:var(--muted);font-size:14.5px;transition:color .2s}
.foot-col a:hover{color:var(--lime)}
.foot-bot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.08em}

/* ===== Modal ===== */
.ov{position:fixed;inset:0;z-index:5000;background:rgba(5,7,12,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:24px}
.ov.open{display:flex;animation:fade .3s}
@keyframes fade{from{opacity:0}}
.mbox{position:relative;width:100%;max-width:480px;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:38px}
.mbox h3{font-size:1.6rem;margin:12px 0 10px}
.mbox p{color:var(--muted);font-size:15px;margin-bottom:22px}
.minput{width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:11px;background:var(--ink);color:var(--paper);font:inherit;font-size:15px;transition:border-color .2s}
.minput::placeholder{color:var(--muted)}
.minput:focus{outline:none;border-color:var(--lime)}
.mclose{position:absolute;top:16px;right:18px;color:var(--muted);font-size:20px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ===== Reveal ===== */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.rv.in{opacity:1;transform:none}
.rv[data-d="1"]{transition-delay:.09s}.rv[data-d="2"]{transition-delay:.18s}.rv[data-d="3"]{transition-delay:.27s}.rv[data-d="4"]{transition-delay:.36s}.rv[data-d="5"]{transition-delay:.45s}

/* ===== Responsive ===== */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .pipe{max-width:520px}
  .cap-6,.cap-4,.cap-3{grid-column:span 6}
  .proc{grid-template-columns:1fr 1fr;gap:34px}.proc-track{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  body{font-size:16px}
  .nav-burger{display:block}
  /* ── Full-screen canvas menu ────────────────────────────── */
  .nav-links{
    display:flex!important;flex-direction:column;align-items:stretch;
    position:fixed;inset:0;
    width:100vw;height:100dvh;
    background:linear-gradient(150deg,#090b14 0%,#0d1022 55%,#080a10 100%);
    z-index:9998;
    padding:clamp(90px,13vh,116px) clamp(28px,7vw,48px) clamp(36px,6vh,56px);
    overflow-y:auto;overflow-x:hidden;
    opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .3s var(--ease),visibility 0s .3s;
  }
  .nav-links.open{
    opacity:1;visibility:visible;pointer-events:auto;
    transition:opacity .3s var(--ease),visibility 0s 0s;
  }
  /* Each item slides up + fades in with stagger */
  .nav-links>a,.nav-links>.nav-drop-wrap{
    opacity:0;transform:translateY(20px);
    transition:opacity .35s var(--ease),transform .35s var(--ease),color .18s;
  }
  .nav-links.open>a,.nav-links.open>.nav-drop-wrap{opacity:1;transform:translateY(0)}
  .nav-links.open>*:nth-child(1){transition-delay:.07s}
  .nav-links.open>*:nth-child(2){transition-delay:.12s}
  .nav-links.open>*:nth-child(3){transition-delay:.17s}
  .nav-links.open>*:nth-child(4){transition-delay:.22s}
  .nav-links.open>*:nth-child(5){transition-delay:.27s}
  .nav-links.open>*:nth-child(6){transition-delay:.32s}
  .nav-links.open>*:nth-child(7){transition-delay:.37s}
  /* Large typographic links */
  .nav-links>a{
    display:block;
    font-family:var(--serif);font-size:clamp(28px,7vw,38px);font-weight:700;
    color:rgba(255,255,255,.38);letter-spacing:-.02em;line-height:1.05;
    padding:13px 0;border-bottom:1px solid rgba(255,255,255,.06);
    transition:color .2s;
  }
  .nav-links>a:hover{color:rgba(255,255,255,.85)}
  .nav-links>a.active{color:var(--lime)}
  /* Glow accent behind menu */
  .nav-links::before{
    content:'';position:absolute;top:-80px;right:-100px;
    width:360px;height:360px;border-radius:50%;
    background:radial-gradient(circle,rgba(58,107,255,.14),transparent 70%);
    pointer-events:none;
  }
  .nav-links::after{
    content:'';position:absolute;bottom:-60px;left:-80px;
    width:280px;height:280px;border-radius:50%;
    background:radial-gradient(circle,rgba(201,242,78,.07),transparent 70%);
    pointer-events:none;
  }
  /* Burger → ✕ */
  .nav-burger span{transition:transform .28s var(--ease),opacity .2s}
  .nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
  .nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .stats{grid-template-columns:1fr 1fr}
  .case{grid-template-columns:auto 1fr;gap:16px}.case .cgo{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){.caps .cap{grid-column:span 6}.foot-grid{grid-template-columns:1fr}.hero-meta{gap:18px}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .rv{opacity:1;transform:none}.hero h1 .line span{transform:none}
}

/* ============================================================================
   SUB-PAGE + BLOG COMPONENTS  (added for site-wide rollout)
   Same dark palette/tokens as the homepage above.
   ========================================================================== */

/* ---- Nav dropdown (light card, matches the white nav pill) ---------------- */
.nav-drop-wrap{position:relative;display:flex;align-items:center}
.nav-drop-trigger{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.nav-chevron{transition:transform .25s var(--ease)}
.nav-drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  width:300px;background:#fff;border:1px solid rgba(10,12,18,.10);border-radius:16px;
  box-shadow:0 26px 60px -18px rgba(0,0,0,.42);padding:10px;opacity:0;visibility:hidden;
  transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:9999;isolation:isolate}
.nav-drop-wrap:hover .nav-drop,.nav-drop-wrap:focus-within .nav-drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop-wrap:hover .nav-chevron{transform:rotate(180deg)}
.nav-drop a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-size:14.5px;font-weight:500;color:#3c465a;transition:background .18s,color .18s}
.nav-drop a:hover{background:#f1f3f8;color:var(--ink)}
.nd-ic{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;background:#eef1ff;color:var(--blue-deep);flex-shrink:0}
.nd-sep{height:1px;background:rgba(10,12,18,.08);margin:8px 6px}
.nd-section-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:#8b93a8;padding:6px 12px 4px}
@media(max-width:768px){
  /* ── Dropdown inside dark popup ───────────────────────── */
  .nav-drop-wrap{flex-direction:column;align-items:stretch;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-drop-trigger{
    display:flex!important;align-items:center;justify-content:space-between;
    width:100%;padding:13px 0;border-radius:0;border-bottom:none;background:none!important;
    font-family:var(--serif);font-size:clamp(28px,7vw,38px);font-weight:700;
    color:rgba(255,255,255,.38);letter-spacing:-.02em;line-height:1.05;
    transition:color .2s;white-space:normal;
  }
  .nav-drop-trigger:hover{color:rgba(255,255,255,.85)!important;background:none!important}
  .nav-drop-wrap.mob-open>.nav-drop-trigger{color:rgba(255,255,255,.85)!important;background:none!important}
  .nav-chevron{display:block!important;flex-shrink:0;width:20px;height:20px;color:rgba(255,255,255,.25);transition:transform .25s var(--ease),color .2s}
  .nav-drop-wrap.mob-open>.nav-drop-trigger .nav-chevron{transform:rotate(180deg);color:var(--lime)}
  /* Kill desktop hover/focus-within transform + visibility on mobile */
  .nav-drop-wrap:hover .nav-drop,.nav-drop-wrap:focus-within .nav-drop{
    transform:none!important;left:auto!important;
    opacity:1;visibility:visible;
  }
  .nav-drop-wrap:hover .nav-chevron{transform:none}
  /* Submenu card */
  .nav-drop{
    display:none;position:static;opacity:1;visibility:visible;transform:none!important;
    box-shadow:none;border:1px solid rgba(255,255,255,.07);border-radius:10px;
    width:100%;padding:6px;background:rgba(255,255,255,.04);margin:4px 0 8px;
    left:auto!important;
  }
  .nav-drop-wrap.mob-open>.nav-drop{display:block}
  .nav-drop a{color:rgba(255,255,255,.5)!important;font-size:13.5px!important;
    font-weight:500!important;padding:8px 10px!important;border-radius:8px!important}
  .nav-drop a:hover{color:#fff!important;background:rgba(255,255,255,.07)!important}
  .nd-ic{background:rgba(255,255,255,.07)!important;color:rgba(255,255,255,.45)!important;
    width:28px!important;height:28px!important;border-radius:7px!important}
  .nd-sep{background:rgba(255,255,255,.07)!important;margin:6px 4px}
  .nd-section-label{color:rgba(255,255,255,.3)!important}
}

/* ---- Page hero (sub-pages) ------------------------------------------------ */
.phero{position:relative;padding:clamp(120px,14vh,160px) 0 clamp(24px,3vw,40px);overflow:hidden}
.phero-sm{padding-top:clamp(90px,11vh,120px)!important;padding-bottom:clamp(14px,2vw,24px)!important}
.phero-inner{max-width:var(--wrap);position:relative;z-index:2}
.phero h1{margin-bottom:8px}
.phero .lead{margin-top:20px}
.breadcrumb{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted);margin-bottom:24px}
.breadcrumb a{color:var(--paper-dim);transition:color .2s}
.breadcrumb a:hover{color:var(--lime)}
.breadcrumb .sep{opacity:.45}
.svc-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--lime);border:1px solid var(--line);background:rgba(201,242,78,.06);padding:7px 14px;border-radius:999px;margin-bottom:22px}
.svc-badge.blue{color:var(--blue-lt);background:rgba(58,107,255,.08);border-color:rgba(58,107,255,.2)}
.svc-badge.green{color:#4ade80;background:rgba(74,222,128,.08);border-color:rgba(74,222,128,.2)}
.svc-badge.purple{color:#c084fc;background:rgba(192,132,252,.08);border-color:rgba(192,132,252,.2)}
.svc-badge.orange{color:#fb923c;background:rgba(251,146,60,.08);border-color:rgba(251,146,60,.2)}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px}
.back-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;
  color:var(--muted);letter-spacing:.04em;margin-bottom:18px;transition:color .2s}
.back-link:hover{color:var(--lime)}
.btn-outline-white{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;
  border:1px solid var(--line-2);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:15.5px;
  transition:border-color .2s,background .2s,transform .25s var(--ease-out)}
.btn-outline-white:hover{border-color:var(--paper);background:rgba(255,255,255,.06);transform:translateY(-2px)}

/* ---- Layout utilities ----------------------------------------------------- */
.two-col{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,56px);align-items:start}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}
.center{text-align:center}
.mx-auto{margin-inline:auto}
.narrow{max-width:760px}

/* ---- Check list (SVG ticks, replaces emoji bullets) ----------------------- */
.check-list{display:grid;gap:14px;margin-top:6px}
.check-list li{display:flex;gap:13px;align-items:flex-start;color:var(--paper-dim);font-size:16px;line-height:1.5}
.check-list .ck{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;margin-top:1px;
  background:rgba(201,242,78,.1);color:var(--lime);border:1px solid var(--line)}

/* ---- Tech tags ------------------------------------------------------------ */
.tags-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.tech-tag{font-family:var(--mono);font-size:12.5px;color:var(--paper-dim);background:var(--ink-2);border:1px solid var(--line);padding:8px 15px;border-radius:999px;transition:.2s}
.tech-tag:hover{border-color:var(--line-2);color:var(--paper)}

/* ---- Code block (dark) ---------------------------------------------------- */
.codeblock{font-family:var(--mono);font-size:14px;line-height:1.95;background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:26px 28px;color:var(--paper-dim);overflow:auto;box-shadow:inset 0 0 60px -30px rgba(0,0,0,.8)}
.codeblock .c-cm{color:var(--muted)}.codeblock .c-kw{color:var(--blue-lt)}.codeblock .c-pr{color:var(--lime)}.codeblock .c-vl{color:#ffd9a0}

/* ---- Prose (articles, legal, help) ---------------------------------------- */
.prose{max-width:740px;color:var(--paper-dim);font-size:17px;line-height:1.75}
.prose>*+*{margin-top:1.15em}
.prose h2{font-family:var(--serif);font-weight:700;font-size:clamp(1.55rem,3vw,2.1rem);color:#fff;letter-spacing:-.02em;line-height:1.15;margin-top:1.9em;scroll-margin-top:120px}
.prose h3{font-family:var(--serif);font-weight:700;font-size:1.32rem;color:#fff;margin-top:1.6em}
.prose a{color:var(--lime);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(201,242,78,.4)}
.prose a:hover{text-decoration-color:var(--lime)}
.prose strong{color:var(--paper);font-weight:600}
.prose ul,.prose ol{padding-left:1.3em;display:grid;gap:.55em}
.prose ul{list-style:none;padding-left:0}
.prose ul li{position:relative;padding-left:1.4em;color:var(--paper-dim)}
.prose ul li::before{content:'';position:absolute;left:.1em;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--lime)}
.prose ol{list-style:decimal}.prose ol li{color:var(--paper-dim);padding-left:.3em}
.prose blockquote{border-left:2px solid var(--lime);padding:4px 0 4px 22px;color:#fff;font-family:var(--serif);font-size:1.25rem;line-height:1.4}
.prose code{font-family:var(--mono);font-size:.88em;background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:2px 7px;color:var(--blue-lt)}
.prose pre{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:20px;overflow:auto}
.prose pre code{background:none;border:none;padding:0}
.prose hr{border:none;border-top:1px solid var(--line);margin:2.2em 0}
.prose img{border-radius:var(--r);border:1px solid var(--line);width:100%}
.prose .lead-p{font-size:1.22rem;color:var(--paper);line-height:1.6}

/* ---- Blog index ----------------------------------------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr}}
.post-card{position:relative;display:flex;flex-direction:column;background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;transition:transform .3s var(--ease-out),border-color .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:0 32px 64px -30px rgba(0,0,0,.75)}
.post-thumb{aspect-ratio:16/9;position:relative;overflow:hidden;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 80% 0%,rgba(58,107,255,.22),transparent 60%),var(--panel)}
.post-thumb .ic{color:var(--lime);opacity:.92;position:relative;z-index:2}
.tool-badge{position:absolute;top:14px;left:14px;z-index:10;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:999px;background:rgba(10,12,18,.75);border:1px solid var(--line-2);color:var(--paper-dim);backdrop-filter:blur(6px)}
.post-thumb::after{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:30px 30px;opacity:.5}
.pc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.pc-cat{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);margin-bottom:12px}
.post-card h3{font-family:var(--serif);font-weight:700;font-size:1.3rem;line-height:1.2;color:#fff;margin-bottom:10px;transition:color .25s}
.post-card:hover h3{color:var(--lime)}
.post-card p{color:var(--muted);font-size:14.5px;line-height:1.55;flex:1}
.pc-meta{display:flex;align-items:center;gap:9px;margin-top:18px;font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.pc-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--line-2)}
.post-feature{grid-column:span 3;display:grid;grid-template-columns:1.15fr 1fr;background:var(--ink-2)}
.post-feature .post-thumb{aspect-ratio:auto;min-height:300px}
.post-feature .pc-body{padding:clamp(28px,4vw,46px);justify-content:center}
.post-feature h3{font-size:clamp(1.6rem,3vw,2.3rem)}
@media(max-width:980px){.post-feature{grid-column:span 2;grid-template-columns:1fr}.post-feature .post-thumb{min-height:220px}}
@media(max-width:640px){.post-feature{grid-column:span 1}}

/* ---- Single article ------------------------------------------------------- */
.post-hero{padding:clamp(140px,16vh,176px) 0 0;position:relative;overflow:hidden}
.post-head{max-width:840px;margin-inline:auto;text-align:center;position:relative;z-index:2}
.post-title{font-family:var(--serif);font-weight:800;font-size:clamp(2.1rem,5vw,3.5rem);letter-spacing:-.03em;line-height:1.05;color:#fff;margin:16px 0 18px}
.post-byline{display:flex;align-items:center;justify-content:center;gap:11px;font-family:var(--mono);font-size:12.5px;color:var(--muted);letter-spacing:.03em;flex-wrap:wrap}
.post-byline .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--lime))}
.post-byline .dot{width:3px;height:3px;border-radius:50%;background:var(--line-2)}
.post-cover{max-width:1000px;margin:clamp(34px,5vw,52px) auto 0;aspect-ratio:21/9;border-radius:var(--r-xl);border:1px solid var(--line);
  background:radial-gradient(110% 130% at 75% 0%,rgba(58,107,255,.25),transparent 55%),var(--panel);position:relative;overflow:hidden;display:grid;place-items:center}
.post-cover .ic{color:var(--lime);opacity:.9}
.article{padding:clamp(48px,6vw,72px) 0 0;display:grid;justify-items:center}
.post-foot{max-width:740px;margin:56px auto 0;padding-top:30px;border-top:1px solid var(--line)}

/* ---- Pagination / chips --------------------------------------------------- */
.pager{display:flex;justify-content:center;gap:8px;margin-top:52px}
.pager a,.pager span{min-width:42px;height:42px;padding:0 12px;display:grid;place-items:center;border-radius:11px;border:1px solid var(--line);color:var(--paper-dim);font-family:var(--mono);font-size:14px;transition:.2s}
.pager a:hover{border-color:var(--lime);color:var(--lime)}
.pager .cur{background:var(--lime);color:var(--ink);border-color:var(--lime)}
.chip-row{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-family:var(--mono);font-size:12px;color:var(--paper-dim);border:1px solid var(--line);padding:7px 14px;border-radius:999px;transition:.2s;cursor:pointer}
.chip:hover,.chip.active{border-color:var(--lime);color:var(--lime)}

/* ---- Forms (contact) ------------------------------------------------------ */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.field label{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--paper-dim)}
.input,.textarea,.select{width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:11px;background:var(--ink);color:var(--paper);font:inherit;font-size:15px;transition:border-color .2s}
.input::placeholder,.textarea::placeholder{color:var(--muted)}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--lime)}

/* ---- Contact page --------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.contact-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px}
.contact-icon-wrap{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}
.contact-icon-wrap.blue{background:rgba(58,107,255,.12);border:1px solid rgba(58,107,255,.25)}
.contact-icon-wrap.green{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2)}
.contact-icon-wrap.slate{background:rgba(71,85,105,.15);border:1px solid rgba(71,85,105,.25)}
.contact-item-label{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.contact-item-val{font-size:15px;color:var(--paper);font-weight:500}
.contact-item-val.green{color:#22c55e}
.contact-item-val.gray{color:var(--paper-dim)}
a.contact-item-val:hover{color:var(--lime)}
.social-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.social-btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--paper-dim);border:1px solid var(--line-2);border-radius:999px;padding:8px 16px;transition:color .2s,border-color .2s}
.social-btn:hover{color:var(--lime);border-color:var(--lime)}
.contact-form-wrap{display:flex;flex-direction:column;gap:0}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.form-row-2{grid-template-columns:1fr}}
.form-label{font-family:var(--mono);font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--paper-dim)}
.form-input,.form-select,.form-textarea{width:100%;padding:13px 16px;border:1px solid var(--line-2);border-radius:11px;background:rgba(255,255,255,.03);color:var(--paper);font:inherit;font-size:15px;transition:border-color .2s;-webkit-appearance:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--lime)}
.form-select option{background:var(--panel);color:var(--paper)}
.form-btn{margin-top:8px;padding:15px 32px;background:var(--lime);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:16px;border:none;border-radius:999px;cursor:pointer;transition:box-shadow .25s,transform .2s}
.form-btn:hover{box-shadow:0 10px 30px -8px rgba(201,242,78,.55);transform:translateY(-1px)}
.form-success{text-align:center;padding:40px 20px}
.form-success h3{font-family:var(--serif);font-size:1.8rem;color:#fff;margin-bottom:8px}
.form-success p{color:var(--paper-dim)}
.form-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px 16px;border-radius:10px;font-size:14px}

/* ---- Generic info tiles --------------------------------------------------- */
.tilegrid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.tile{background:var(--ink-2);padding:28px}
.tile .ti{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(201,242,78,.07);border:1px solid var(--line);color:var(--lime);margin-bottom:16px}
.tile h3{font-family:var(--serif);font-size:1.25rem;color:#fff;margin-bottom:8px}
.tile p{color:var(--muted);font-size:14.5px;line-height:1.55}

/* ============================================================================
   INNER PAGE COMPONENTS — dark theme (same tokens as homepage)
   ============================================================================ */

/* ---- Page layout ---------------------------------------------------------- */
.page-white{background:var(--ink)!important;color:var(--paper)!important}
.page-hero{position:relative;padding:clamp(130px,16vh,170px) 0 clamp(44px,6vw,60px);overflow:hidden}
.page-hero.centered{display:flex;flex-direction:column;align-items:center;text-align:center}
.page-hero .inner{position:relative;z-index:2;max-width:820px}
.page-hero.centered .inner{margin-inline:auto}
.page-hero h1{font-family:var(--serif);font-weight:800;font-size:clamp(2.6rem,5.5vw,4.4rem);color:#fff;letter-spacing:-.03em;line-height:1.02;margin-bottom:18px}
.page-hero p{color:var(--paper-dim);font-size:clamp(1.06rem,1.5vw,1.25rem);max-width:58ch;line-height:1.6}
.page-hero.centered p{margin-inline:auto}
.page-section{padding:clamp(60px,8vw,120px) 0;position:relative}
.page-section.light{background:rgba(255,255,255,.02);border-top:1px solid var(--line)}
.page-inner{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(18px,4vw,28px);position:relative;z-index:2}
.prod-wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(18px,4vw,28px);position:relative;z-index:2}
.pg-h2{font-family:var(--serif);font-weight:800;font-size:clamp(2.1rem,4.8vw,3.5rem);color:#fff;letter-spacing:-.03em;line-height:1.05}
.pg-sub{color:var(--paper-dim);font-size:1.1rem;line-height:1.6;margin-top:14px}
.pg-h2.center,.pg-sub.center{text-align:center}
.narrow.centered{max-width:680px;margin-inline:auto;text-align:center}

/* ---- Inner page buttons (all match .btn base: 15px 26px / 15.5px / gap 10px) ----- */
.btn-store{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;
  background:var(--lime);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:15.5px;
  transition:background .2s,box-shadow .2s,transform .25s var(--ease-out)}
.btn-store:hover{background:var(--lime-deep);box-shadow:0 14px 36px -10px rgba(201,242,78,.55);transform:translateY(-2px)}
.btn-gh{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;
  border:1px solid var(--line-2);color:var(--paper-dim);font-family:var(--sans);font-weight:600;font-size:15.5px;
  transition:border-color .2s,color .2s,background .2s,transform .25s var(--ease-out)}
.btn-gh:hover{border-color:var(--paper);color:var(--paper);background:rgba(255,255,255,.05);transform:translateY(-2px)}
.btn-brand{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;
  background:var(--lime);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:15.5px;
  transition:background .2s,box-shadow .2s,transform .25s var(--ease-out)}
.btn-brand:hover{background:var(--lime-deep);box-shadow:0 14px 40px -10px rgba(201,242,78,.6);transform:translateY(-2px)}
.prod-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.prod-section-label{display:flex;align-items:center;gap:14px;margin-bottom:20px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.prod-section-label::before,.prod-section-label::after{content:'';flex:1;height:1px;background:var(--line)}

/* ---- Work / Case study cards ---------------------------------------------- */
.work-case{display:grid;grid-template-columns:380px 1fr;border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;margin-bottom:24px;background:var(--ink-2)}
.wc-thumb{position:relative;min-height:300px;overflow:hidden}
.wc-body{padding:clamp(28px,4vw,44px);display:flex;flex-direction:column;gap:18px}
.wc-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.wc-badge{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;
  padding:4px 12px;border-radius:999px;border:1px solid var(--line)}
.wc-year{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em}
.wc-body h2{font-family:var(--serif);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);
  color:#fff;letter-spacing:-.025em;line-height:1.05;margin:0}
.wc-tagline{font-size:1.1rem;color:var(--paper-dim);font-weight:500;margin:0}
.wc-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.wc-cols h4{font-family:var(--serif);font-size:1rem;color:var(--paper);margin-bottom:8px}
.wc-cols p{color:var(--muted);font-size:14.5px;line-height:1.6}
.wc-stack h4{font-family:var(--serif);font-size:1rem;color:var(--paper);margin-bottom:10px}
.wc-tags{display:flex;flex-wrap:wrap;gap:8px}
.wc-tags span{font-family:var(--mono);font-size:11.5px;color:var(--paper-dim);
  background:var(--ink);border:1px solid var(--line);padding:5px 12px;border-radius:999px}
.wc-results{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.wc-stat{background:var(--ink-2);padding:18px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}
.wc-num{font-family:var(--serif);font-weight:800;font-size:2rem;color:var(--lime);line-height:1}
.wc-stat span:last-child{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em}
.wc-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:auto;padding-top:4px}
/* browser chrome mock */
.browser-chrome{position:absolute;top:0;left:0;right:0;height:32px;
  background:rgba(255,255,255,.04);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:6px;padding:0 14px}
.browser-chrome span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.15)}
.browser-chrome span:nth-child(1){background:rgba(255,80,80,.45)}
.browser-chrome span:nth-child(2){background:rgba(255,190,0,.45)}
.browser-chrome span:nth-child(3){background:rgba(0,200,80,.45)}
.ph{position:absolute;font-family:var(--mono);color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.wa-btn-demo{position:absolute;bottom:20px;right:18px;width:48px;height:48px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.4)}
@media(max-width:900px){.work-case{grid-template-columns:1fr}}

/* ---- Products page -------------------------------------------------------- */
.prod-feat{display:grid;grid-template-columns:360px 1fr;border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;margin-bottom:24px;background:var(--ink-2)}
.prod-feat-flip .prod-visual{order:2}
.prod-feat-flip .prod-content{order:1}
.prod-visual{position:relative;min-height:420px;display:flex;align-items:center;
  justify-content:center;overflow:hidden;border-right:1px solid var(--line)}
.prod-feat-flip .prod-visual{border-right:none;border-left:1px solid var(--line)}
.pv-green{background:radial-gradient(ellipse 90% 80% at 50% 50%,rgba(34,197,94,.1),transparent 70%),var(--panel)}
.pv-rose{background:radial-gradient(ellipse 90% 80% at 50% 50%,rgba(244,63,94,.1),transparent 70%),var(--panel)}
.pv-label{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.14em;
  text-transform:uppercase;white-space:nowrap}
.prod-content{padding:clamp(28px,4vw,44px);display:flex;flex-direction:column;gap:16px}
.prod-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.prod-badge{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;
  padding:4px 12px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.prod-h2{font-family:var(--serif);font-weight:800;font-size:clamp(1.8rem,3.5vw,2.6rem);
  color:#fff;letter-spacing:-.025em;margin:0;line-height:1.05}
.prod-tagline{font-size:1.08rem;color:var(--paper-dim);font-weight:500;margin:0}
.prod-desc{color:var(--muted);font-size:15.5px;line-height:1.65;margin:0;max-width:56ch}
/* pricing plans */
.prod-plans{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.prod-plan{background:var(--ink);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.pp-starter{background:rgba(58,107,255,.06);border-color:rgba(58,107,255,.25)}
.pp-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:14px}
.pp-name{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}
.pp-starter .pp-name{color:var(--blue-lt)}
.pp-price{font-family:var(--serif);font-weight:800;font-size:1.6rem;color:#fff;line-height:1}
.pp-starter .pp-price{color:var(--blue-lt)}
.pp-per{font-size:.82rem;color:var(--muted);font-weight:400}
.pp-list{display:grid;gap:9px;padding:0}
.pp-list li{font-size:13.5px;color:var(--paper-dim);display:flex;align-items:flex-start;gap:8px}
.pp-list li::before{content:'✓';color:var(--lime);font-weight:700;flex-shrink:0}
.pp-starter .pp-list li::before{color:var(--blue-lt)}
/* extension grid */
.prod-ext-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.prod-ext-card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:36px;display:flex;flex-direction:column;
  transition:border-color .3s,transform .3s var(--ease-out),box-shadow .3s}
.prod-ext-card:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:0 28px 60px -28px rgba(0,0,0,.8)}
.pec-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;margin-bottom:18px}
.pec-icon-blue{background:rgba(58,107,255,.12);color:var(--blue-lt);border:1px solid rgba(58,107,255,.2)}
.pec-icon-purple{background:rgba(168,85,247,.12);color:#c084fc;border:1px solid rgba(168,85,247,.2)}
.pec-badge-blue{background:rgba(58,107,255,.1);color:var(--blue-lt);border-color:rgba(58,107,255,.2)!important}
.pec-badge-purple{background:rgba(168,85,247,.1);color:#c084fc;border-color:rgba(168,85,247,.2)!important}
.pec-h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:#fff;margin:12px 0 8px}
.pec-tagline{color:var(--paper-dim);font-size:15px;margin-bottom:16px}
.pec-list{display:grid;gap:10px;padding:0}
.pec-list li{font-size:14px;color:var(--muted);display:flex;align-items:flex-start;gap:8px}
.pec-list li::before{content:'—';color:var(--lime);font-weight:700;flex-shrink:0}
/* WA phone mock — dark version */
.wa-mock-phone{width:155px;height:296px;border:1.5px solid rgba(34,197,94,.25);
  border-radius:30px;background:var(--panel-2);position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,.6),0 4px 20px rgba(34,197,94,.1);overflow:hidden}
.wmp-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:40%;height:20px;background:var(--ink);border-radius:0 0 12px 12px;z-index:2}
.wmp-screen{position:absolute;inset:0;padding:24px 12px 12px;
  display:flex;flex-direction:column;gap:8px}
.wmp-urlbar{height:18px;background:rgba(255,255,255,.06);border-radius:999px}
.wmp-img-ph{height:80px;background:rgba(34,197,94,.08);border-radius:8px;margin-top:4px}
.wmp-line{height:7px;background:rgba(255,255,255,.07);border-radius:4px}
.wmp-btn-ph{height:26px;background:rgba(34,197,94,.12);border-radius:8px;margin-top:2px}
.wmp-fab{position:absolute;bottom:14px;right:12px;width:38px;height:38px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(37,211,102,.4)}
@media(max-width:900px){.prod-feat{grid-template-columns:1fr}.prod-feat-flip .prod-visual{order:-1}.prod-feat-flip .prod-content{order:0}}
@media(max-width:640px){.prod-ext-grid{grid-template-columns:1fr}.prod-plans{grid-template-columns:1fr}}

/* ---- Service page components ---------------------------------------------- */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:640px){.feat-grid{grid-template-columns:1fr}}
.feat-card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;
  transition:border-color .3s,transform .3s var(--ease-out)}
.feat-card:hover{border-color:var(--line-2);transform:translateY(-3px)}
.fc-icon{font-size:28px;margin-bottom:14px;line-height:1}
.feat-card h3{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:8px}
.feat-card p{color:var(--muted);font-size:14.5px;line-height:1.55}

/* code block (service pages) */
.code-block{font-family:var(--mono);font-size:14px;line-height:2;background:var(--ink-2);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 32px;color:var(--paper-dim);
  box-shadow:inset 0 0 60px -30px rgba(0,0,0,.8)}
.code-comment{color:var(--muted)}
.code-kw{color:var(--blue-lt)}
.code-prop{color:var(--lime)}
.code-val{color:#ffd9a0}

/* stack table */
.stack-table{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.stack-table h3{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);padding:18px 20px 14px;border-bottom:1px solid var(--line)}
.stack-row{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px 20px;border-bottom:1px solid var(--line)}
.stack-row:last-child{border-bottom:none}
.stack-label{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}
.stack-val{font-family:var(--mono);font-size:12px;color:var(--lime)}

/* extension showcase */
.ext-showcase{display:flex;flex-direction:column;gap:12px}
.ext-showcase h3{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.ext-card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px}
.ext-card.blue{border-left:2px solid var(--blue-lt)}
.ext-card.green{border-left:2px solid var(--lime)}
.ext-card h4{font-family:var(--serif);font-weight:700;color:#fff;font-size:1rem;margin-bottom:4px}
.ext-card p{color:var(--muted);font-size:13.5px}
.ext-link{font-family:var(--mono);font-size:13px;color:var(--lime);letter-spacing:.02em;margin-top:4px;transition:letter-spacing .2s}
.ext-link:hover{letter-spacing:.06em}

/* phone mockup (mobile apps page) */
.phone-mockup-wrap{display:flex;gap:20px;align-items:flex-end;justify-content:center}
.phone-mockup{width:120px;background:var(--panel);border:1.5px solid var(--line-2);border-radius:22px;
  padding:12px 10px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7)}
.phone-mockup.offset{transform:translateY(-20px);background:var(--panel-2)}
.phone-dot{width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.phone-screen{width:100%;height:140px;background:var(--ink-2);border-radius:12px;position:relative;overflow:hidden}
.phone-screen.brand{background:linear-gradient(135deg,rgba(58,107,255,.3),var(--ink-2))}
.app-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:12px;background:var(--lime)}
.phone-home{width:36px;height:4px;background:var(--line-2);border-radius:2px}

/* page CTA section */
.page-cta{padding:clamp(60px,8vw,100px) 0;text-align:center;position:relative}
.page-cta .inner{max-width:600px;margin-inline:auto;position:relative;z-index:2}
.page-cta h2{font-family:var(--serif);font-weight:800;font-size:clamp(2rem,4vw,3rem);
  color:#fff;letter-spacing:-.03em;margin-bottom:14px}
.page-cta p{color:var(--paper-dim);font-size:1.1rem;margin-bottom:28px}

/* check-list SVG variant (service pages use direct SVG not .ck span) */
.check-list li svg{flex-shrink:0;margin-top:2px}

/* ── Privacy / Terms pages ───────────────────────────────────────────────── */
.privacy-wrap{max-width:800px;margin:0 auto;padding:clamp(40px,5vh,64px) 24px clamp(48px,6vh,80px)}
.privacy-back{display:inline-block;color:var(--lime);font-size:14px;margin-bottom:28px;transition:opacity .2s;text-decoration:none}
.privacy-back:hover{opacity:.7}
.privacy-h1{font-size:clamp(24px,4vw,40px);font-weight:800;color:var(--paper);margin:0 0 4px;line-height:1.15;font-family:var(--serif)}
.privacy-date{color:var(--muted);font-size:13px;margin:0 0 40px;font-family:var(--mono);letter-spacing:.02em}
.privacy-section{margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.07)}
.privacy-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.privacy-h2{font-size:clamp(16px,2.5vw,20px);font-weight:700;color:var(--paper);margin:0 0 12px;font-family:var(--serif)}
.privacy-section h3{font-weight:600;color:var(--paper-dim)!important;margin:16px 0 8px;font-size:16px}
.privacy-p{color:var(--muted);line-height:1.75;margin:0 0 12px;font-size:15px}
.privacy-ul{color:var(--muted);line-height:1.75;padding-left:20px;margin:8px 0 12px;font-size:15px}
.privacy-ul li{margin-bottom:6px}
.privacy-code{background:rgba(255,255,255,.08);color:var(--lime);padding:1px 6px;border-radius:4px;font-family:var(--mono);font-size:13px}
.privacy-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px 24px;margin-top:16px}
.privacy-box p{color:var(--muted);margin:4px 0;font-size:15px}
.privacy-box a{color:var(--lime)}
.privacy-wrap hr{border:none;border-top:1px solid rgba(255,255,255,.1);margin:48px 0 40px}
.privacy-wrap .shopify-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(22,163,74,.12);border:1px solid rgba(22,163,74,.3);border-radius:8px;padding:8px 16px;margin-bottom:20px}
.privacy-wrap .shopify-badge span{font-size:13px;font-weight:600;color:#4ade80}
/* override any leftover light inline colours inside .privacy-wrap */
.privacy-wrap a:not([style]){color:var(--lime)}
