/*
Theme Name: Sunny
Theme URI: https://aethera.dev
Author: Aethera
Description: 全栈 WordPress 品牌官网主题 — 一人交付，Gutenberg 原生支持。
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: sunny
*/

:root{--green:#1A3C1A;--green2:#2D5A27;--moss:#6B8E6B;--grass:#B8D4B8;--cream:#F5F0E8;--cream2:#FAF8F5;--gray:#E8E4DC;--amber:#C4956A;--gold:#A67B5B;--ink:#1A1A1A;--text:#6B6B6B;--soft:#9B9B9B;--line:rgba(26,60,26,.15);--glass:rgba(250,248,245,.72);--shadow:0 30px 90px rgba(26,60,26,.16);--font:"Inter",-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",system-ui,sans-serif;--display:"Instrument Serif",Georgia,"Times New Roman",serif;--mono:"SF Mono","Cascadia Code",ui-monospace,Menlo,monospace;--black:#000;--gray2:#6F6F6F;--white:#FFF}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--black);background:var(--white);overflow-x:hidden}
/* ── Curtain transition ── */
.curtain{position:fixed;inset:0;z-index:9999;pointer-events:all}
.curtain-half{position:absolute;top:0;width:50vw;height:100%;background:#1a1a1a}
.curtain-left{left:0}.curtain-right{left:50%}
.curtain-logo{position:absolute;bottom:calc(clamp(40px,8vh,80px) + 52px);left:50%;transform:translateX(-50%);font-family:var(--display);font-size:1.875rem;letter-spacing:-.02em;color:#fff;line-height:1;white-space:nowrap}.curtain-logo sup{font-size:.55em;top:-.4em;position:relative;font-family:var(--font)}
.curtain-progress{position:absolute;bottom:clamp(40px,8vh,80px);left:50%;transform:translateX(-50%);width:clamp(180px,20vw,300px);height:3px;background:rgba(255,255,255,.18);border-radius:3px}
.curtain-progress-bar{height:100%;width:0;background:#fff;border-radius:3px;will-change:width;position:relative;overflow:hidden}.curtain-progress-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transform:translateX(-100%);animation:shimmer 1.2s ease-in-out infinite}@keyframes shimmer{to{transform:translateX(100%)}}@keyframes curtainTimeout{0%,99%{visibility:visible}to{visibility:hidden}}@keyframes curtainAutoHide{0%,94%{visibility:visible;opacity:1}to{visibility:hidden;opacity:0;pointer-events:none}}.curtain{animation:curtainAutoHide 7.5s forwards}@media (scripting: none){.curtain{animation:curtainTimeout .1s forwards;animation-delay:.6s}}
a{text-decoration:none;color:inherit}button,input,textarea,select{font:inherit}button{border:0;cursor:pointer}img{max-width:100%;display:block}
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:99;background:var(--black);pointer-events:none}
.nav-video{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px clamp(28px,6vw,80px);max-width:1440px;margin:0 auto}
.nav-logo{font-family:var(--display);font-size:1.875rem;letter-spacing:-.02em;color:var(--black);line-height:1; z-index: 52;}
.nav-logo sup{font-size:.55em;top:-.4em;position:relative;font-family:var(--font)}
.nav-links{display:flex;align-items:center;gap:32px;transition:background .35s ease,padding .35s ease,border-radius .35s ease,box-shadow .35s ease}
.nav-scrolled .nav-links{background:rgba(255,255,255,.88);backdrop-filter:blur(16px);padding:10px 22px;border-radius:40px;box-shadow:0 4px 24px rgba(0,0,0,.06)}
.nav-open .nav-links{padding:0;border-radius:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);box-shadow:none}
.nav-links a{font-family:var(--font);font-size:.875rem;color:var(--gray2);transition:color .25s ease}
.nav-links a:hover,.nav-links a.active{color:var(--black)}
.nav-cta-video{padding:10px 24px;border-radius:999px;font-family:var(--font);font-size:.875rem;font-weight:600;color:var(--white);background:var(--black);transition:transform .25s ease}
/* ── Mobile hamburger ── */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:0;background:none;border:0;cursor:pointer;z-index:51;position:relative}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--black);border-radius:1px;transition:transform .3s ease,opacity .3s ease;transform-origin:center}
.nav-open .nav-toggle span:nth-child(1){transform:rotate(45deg) translate(4.9px,4.9px)}
.nav-open .nav-toggle span:nth-child(2){opacity:0}
.nav-open .nav-toggle span:nth-child(3){transform:rotate(-45deg) translate(4.9px,-4.9px)}
/* mobile menu panel */
@media (max-width:980px){
  .nav-toggle{display:flex}
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;flex-direction:column;align-items:center;justify-content:center;gap:36px;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);z-index:50}
  .nav-open .nav-links{display:flex}
  .nav-links a{font-size:1.5rem;font-weight:600;color:var(--black)}
  .nav-cta-video{position:relative;z-index:51}
}
.nav-cta-video:hover{transform:scale(1.03)}

/* ── Video hero (homepage only) ── */
.hero-video-content{position:relative;height:200vh;padding:0}
.hero-video-wrap{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;padding-top:140px;background:#1a1a1a}
.hero-video-wrap video,.hero-video-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,var(--white),transparent 25%,transparent 75%,var(--white))}
.hero-text-overlay{position:relative;z-index:2;padding:0 24px;will-change:opacity}
.hero-text-overlay .eyebrow{font-family:var(--font);font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gray2);margin-bottom:24px}
.hero-text-overlay .eyebrow:before{display:none}
.hero-text-overlay h1{font-family:var(--display);font-size:clamp(2.4rem,5.5vw,7rem);font-weight:400;line-height:.95;letter-spacing:-2px;color:var(--black);max-width:64rem;margin:0 auto;white-space:nowrap}
.hero-text-overlay .hero-desc{font-family:var(--font);font-size:clamp(.9rem,1.15vw,1.125rem);max-width:42rem;margin:32px auto 0;line-height:1.75;color:var(--gray2)}
.hero-text-overlay .actions{margin-top:48px}
.hero-text-overlay .btn.primary-video{padding:18px 56px;border-radius:999px;font-family:var(--font);font-size:1rem;font-weight:600;color:var(--white);background:var(--black);transition:transform .3s ease}
.hero-text-overlay .btn.primary-video:hover{transform:scale(1.03)}
.hero-scroll-hint{position:absolute;z-index:2;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--gray2);font-family:var(--font);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}
.scroll-chevron{width:1px;height:28px;background:var(--gray2);position:relative;animation:scrollBounce 2s ease-in-out infinite}
.scroll-chevron:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--gray2)}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(8px);opacity:1}}

/* ── Page header (inner pages) ── */
.page-header{min-height:55vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:160px 24px 80px}
.page-header .eyebrow:before{display:none}
.page-header h1{font-family:var(--display);font-size:clamp(2.4rem,5.5vw,5.5rem);font-weight:400;line-height:1.15;letter-spacing:-2px;color:var(--black);max-width:100%}
.page-header .hero-desc{font-family:var(--font);font-size:clamp(.9rem,1.15vw,1.125rem);max-width:100%;margin:24px auto 0;line-height:1.75;color:var(--gray2)}

.container{width:min(1180px,calc(100% - 40px));margin:auto}
.wide{width:min(1460px,calc(100% - 28px));margin:auto}
section{padding:80px 0}
.eyebrow{display:inline-flex;align-items:center;gap:9px;margin-bottom:18px;color:var(--green2);font-size:11px;font-weight:900;letter-spacing:.22em;text-transform:uppercase}
.eyebrow:before{content:"";width:28px;height:1px;background:currentColor;opacity:.55}
h1,h2,h3,h4,p{margin:0}h1,h2,h3{letter-spacing:-.03em;line-height:1.08}
h1{max-width:100%;font-size:clamp(32px,4vw,52px);font-weight:740}
h2{max-width:100%;font-size:clamp(28px,3.6vw,44px);font-weight:720}
h3{font-size:clamp(22px,2.2vw,32px);font-weight:700}
.lead{color:var(--text);font-size:clamp(15px,1.15vw,17px);line-height:1.75}
.small{color:var(--text);font-size:14px;line-height:1.7}
.tag{display:inline-flex;width:max-content;padding:7px 10px;border-radius:999px;color:var(--green);background:rgba(184,212,184,.34);font-family:var(--mono);font-size:11px;font-weight:850;letter-spacing:.1em;text-transform:uppercase}
.btn{position:relative;min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:999px;overflow:hidden;font-weight:850;font-size:14px;transition:transform .25s ease,box-shadow .25s ease}
.btn:before{content:"";position:absolute;inset:-1px;background:linear-gradient(110deg,transparent,rgba(255,255,255,.36),transparent);transform:translateX(-115%);transition:.65s ease}
.btn:hover:before{transform:translateX(115%)}
.btn.primary{color:#fff;background:linear-gradient(135deg,var(--green),var(--green2));box-shadow:0 18px 40px rgba(26,60,26,.22)}
.btn.ghost{color:var(--green);border:1px solid rgba(26,60,26,.16);background:rgba(250,248,245,.62);backdrop-filter:blur(14px)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;overflow:hidden;border:1px solid var(--line);border-radius:30px;background:var(--line);box-shadow:0 20px 50px rgba(26,60,26,.07);margin-top:40px}
.stat{padding:22px;background:rgba(250,248,245,.68);backdrop-filter:blur(14px)}
.stat b{display:flex;align-items:baseline;gap:4px;color:var(--green);font-family:var(--mono);font-size:14px}
.stat span{display:block;margin-top:6px;color:var(--text);font-size:13px;line-height:1.5}
.head{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,400px);gap:36px;align-items:end;margin-bottom:36px}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.filter-btn{padding:10px 14px;border-radius:999px;border:1px solid rgba(26,60,26,.14);color:var(--green);background:rgba(250,248,245,.6);font-size:12px;font-weight:850;letter-spacing:.1em;text-transform:uppercase;transition:all .25s ease}
.filter-btn.active,.filter-btn:hover{color:#fff;background:var(--green)}
/* ── Horizontal scroll panel (精选案例) ── */
.horizontal-panel{overflow:hidden;margin-top:24px;padding:30px 0}
.horizontal-track{display:flex;gap:20px;will-change:transform;width:max-content}
.horizontal-track .case{flex:0 0 auto;width:clamp(380px,32vw,480px);min-height:460px}
.horizontal-track .case.large{width:clamp(440px,38vw,560px)}
.horizontal-track .case.tall{width:clamp(400px,34vw,500px)}
.horizontal-track .case .media{height:280px}
.horizontal-track .case.large .media{height:280px}
.case{grid-column:span 4;min-height:460px;overflow:hidden;border:1px solid rgba(255,255,255,.68);border-radius:32px;background:var(--glass);}
.case.large{grid-column:span 7}.case.tall{grid-column:span 5}
.case.hide{display:none}
.media{position:relative;height:280px;margin:12px;overflow:hidden;border-radius:24px;background:linear-gradient(145deg,rgba(26,60,26,.92),rgba(107,142,107,.35)),var(--cream)}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;border:3px solid var(--green);border-radius:24px;filter:grayscale(1);transition:filter .4s ease}
.case:hover .media img{filter:grayscale(0)}
.media-cta{position:absolute;right:18px;bottom:18px;padding:10px 14px;border-radius:999px;color:#fff;background:rgba(26,60,26,.72);font-size:12px;font-weight:850;letter-spacing:.08em;text-decoration:none;opacity:0;transform:translateY(12px);transition:.35s ease;pointer-events:none;z-index:2}
.case:hover .media-cta{opacity:1;transform:translateY(0);pointer-events:auto}
.media-cta:hover{background:var(--green);transform:translateY(0) scale(1.05)}
.case-body{padding:4px 22px 24px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.case-body h3{font-size:28px}.case-body p{margin-top:10px;color:var(--text);line-height:1.6;font-size:14px}
.services{display:grid;gap:26px}
/* cursor-follow image */
.cursor-img{position:fixed;top:0;left:0;pointer-events:none;z-index:60;width:380px;height:260px;border-radius:0;object-fit:cover;object-position:top;border:0;opacity:0;box-shadow:0 24px 60px rgba(26,60,26,.22);will-change:transform,opacity}
.service{display:grid;grid-template-columns:100px minmax(0,1fr) 200px;gap:20px;align-items:center;padding:22px;border:1px solid rgba(26,60,26,.12);border-radius:0;background:rgba(250,248,245,.63);backdrop-filter:blur(18px);transition:transform .28s ease,background .28s ease}
.service:hover{background:rgba(250,248,245,.85)}
.num{width:max-content;padding:7px 10px;border-radius:999px;color:var(--green);background:rgba(184,212,184,.35);font-family:var(--mono);font-weight:850;font-size:13px}
.service p{color:var(--text);line-height:1.6;font-size:14px}
.price{justify-self:end;color:var(--green);font-size:24px;font-weight:900;letter-spacing:-.04em}
.card{padding:26px;border:1px solid rgba(26,60,26,.12);border-radius:30px;background:rgba(250,248,245,.64);backdrop-filter:blur(18px);box-shadow:0 18px 44px rgba(26,60,26,.05)}
.card h3{font-size:28px}.card p{margin-top:10px;color:var(--text);line-height:1.65;font-size:14px}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.cap-card{min-height:230px}.cap-card .num{margin-bottom:44px}
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.process .card{min-height:270px;display:flex;flex-direction:column;justify-content:space-between}
.deliverables{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dlist{display:grid;gap:8px;margin-top:14px;padding:0;list-style:none}
.dlist li{display:flex;gap:10px;color:var(--text);line-height:1.5;font-size:14px}
.dlist li:before{content:"";width:6px;height:6px;flex:0 0 6px;margin-top:7px;border-radius:50%;background:var(--moss)}
.story{display:grid;grid-template-columns:380px 1fr;gap:48px;align-items:start}
.sticky{position:sticky;top:120px;min-height:460px;padding:30px;color:#fff;background:radial-gradient(circle at 80% 12%,rgba(196,149,106,.24),transparent 25%),linear-gradient(145deg,rgba(26,60,26,.96),rgba(45,90,39,.86));box-shadow:0 36px 80px rgba(26,60,26,.2)}
.sticky h3{margin-top:90px;color:#fff;font-size:40px}.sticky p{margin-top:14px;color:rgba(250,248,245,.74);line-height:1.7;font-size:14px}
.timeline{display:grid;gap:16px;position:relative;padding-left:36px}
/* vertical progress line */
.timeline-progress{position:absolute;left:13px;top:0;width:2px;height:0;background:linear-gradient(to bottom,var(--green),var(--moss));border-radius:2px;z-index:0}
/* leading dot on progress line */
.timeline-progress:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--green);border-radius:50%;}
.titem{position:relative;min-height:180px;padding:28px 28px 28px 32px;border:1px solid rgba(26,60,26,.12); border-right:none;  border-left:3px solid transparent;border-radius:0 0 0 0;background:rgba(250,248,245,.64);backdrop-filter:blur(18px);transition:border-color .5s ease,}
/* dot marker on each card connecting to progress line */
.titem:before{content:"";position:absolute;left:-33px;top:33px;width:12px;height:12px;border-radius:50%;background:var(--cream);border:2px solid var(--line);z-index:1;}
/* reached state — passed by progress line */
.titem.reached{border-left-color:var(--green);}
.titem.reached:before{background:var(--green);border-color:var(--green);}
.titem:hover{transform:translateX(0)}
.titem .num{margin-bottom:14px}
.titem h3{margin-top:16px !important;font-size:28px}.titem p{margin-top:10px;color:var(--text);line-height:1.65;font-size:14px}
.marquee{overflow:hidden;padding:20px 0;border-block:1px solid rgba(26,60,26,.14);background:rgba(250,248,245,.36);-webkit-mask-image:linear-gradient(to right,transparent,#000 18%,#000 82%,transparent);mask-image:linear-gradient(to right,transparent,#000 18%,#000 82%,transparent)}
.track{display:flex;width:max-content;gap:14px;flex-shrink:0;animation:marquee 26s linear infinite}
@keyframes marquee{to{transform:translateX(-50%)}}
.logo-chip{min-width:170px;padding:16px 20px;border:1px solid rgba(26,60,26,.12);border-radius:999px;color:var(--green);background:rgba(250,248,245,.74);font-size:13px;font-weight:900;text-align:center}
.quotes,.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote,.article,.form-card,.contact-card{padding:26px;border:1px solid rgba(26,60,26,.12);border-radius:32px;background:rgba(250,248,245,.66);backdrop-filter:blur(18px)}
.quote{min-height:270px;display:flex;flex-direction:column;justify-content:space-between}
.quote p{font-size:17px;line-height:1.55}.quote footer{margin-top:22px;color:var(--text);font-size:13px}
.article{min-height:250px;transition:transform .28s ease}.article:hover{transform:translateY(-6px)}
/* ── Pagination ── */
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:48px}
.page-btn{min-width:40px;height:40px;padding:0 12px;border:1px solid rgba(26,60,26,.14);border-radius:20px;background:var(--cream2);color:var(--green);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}
.page-btn:hover:not(:disabled){background:var(--green);color:#fff;border-color:var(--green)}
.page-btn.active{background:var(--green);color:#fff;border-color:var(--green)}
.page-btn:disabled{opacity:.35;cursor:default}
.article h3{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article p{margin-top:12px;color:var(--text);line-height:1.65;font-size:14px;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article .tag{margin-bottom:20px}
.faq-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:30px}
.faq-list{display:grid;gap:12px}
.faq-item{border:1px solid rgba(26,60,26,.12);border-radius:22px;background:rgba(250,248,245,.64);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;gap:20px;padding:20px 22px;text-align:left;color:var(--green);font-weight:850;font-size:14px}
.faq-a{display:none;padding:0 22px 22px;color:var(--text);line-height:1.7;font-size:14px}
.faq-item.open .faq-a{display:block}
.contact-wrap{display:grid;grid-template-columns:.86fr 1fr;gap:36px}
.contact-card{min-height:480px;color:#fff;background:radial-gradient(circle at 70% 14%,rgba(184,212,184,.45),transparent 25%),linear-gradient(145deg,rgba(26,60,26,.96),rgba(45,90,39,.86))}
.contact-card h2{color:#fff;font-size:52px}.contact-card p{margin-top:18px;color:rgba(250,248,245,.76);font-size:16px;line-height:1.7}
.methods{display:grid;gap:12px;margin-top:60px}
.method{display:flex;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid rgba(250,248,245,.16);color:rgba(250,248,245,.86);font-size:14px}
form{display:grid;gap:14px}label{display:grid;gap:6px;color:var(--green);font-size:11px;font-weight:900;letter-spacing:.18em;text-transform:uppercase}
input,textarea,select{width:100%;padding:14px 16px;border:1px solid rgba(26,60,26,.16);border-radius:16px;color:var(--ink);background:rgba(255,255,255,.6);outline:0;font-size:14px}
textarea{min-height:120px;resize:vertical}
input:focus,textarea:focus,select:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(184,212,184,.3)}
.footer{padding:34px 0;border-top:1px solid rgba(26,60,26,.12);color:var(--text);font-size:13px}
.footer .container{display:flex;justify-content:space-between;gap:20px}
.reveal{opacity:1;transform:none;transition:opacity .6s ease}
.js .reveal{opacity:0}
.js .reveal.show{opacity:1;transform:none}
/* ── Magnetic button active ── */
.magnetic{cursor:pointer;will-change:transform}
/* ── Case card 3D tilt (no CSS transition — GSAP quickTo handles it) ── */
.case{will-change:transform}
/* ── Text reveal stagger (for per-word animations) ── */
.split-word{display:inline-block;will-change:transform,opacity}
/* ── Stats counter ── */
.stat b .count{display:inline;font-family:var(--display);font-size:clamp(32px,4.5vw,48px);color:var(--green);line-height:1;vertical-align:baseline;font-variant-numeric:tabular-nums}
/* ── Article detail (news-detail) ── */
.article-detail{width:min(860px,calc(100% - 40px));margin:auto;padding:160px 0 80px}
.article-header{margin-bottom:48px}
.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:28px;color:var(--green);font-size:13px;font-weight:600;transition:opacity .25s ease}
.back-link:hover{opacity:.7}
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:24px}
.article-date,.article-author{color:var(--text);font-size:13px}
.article-header h1{font-family:var(--display);font-size:clamp(2rem,4.5vw,3.5rem);font-weight:400;line-height:1.08;letter-spacing:-1.5px;max-width:100%}
.article-lead{margin-top:20px;color:var(--text);font-size:clamp(1rem,1.2vw,1.125rem);line-height:1.75}
.article-body h2{margin:56px 0 18px;font-size:clamp(1.4rem,2vw,1.75rem);font-weight:700}
.article-body h2:first-child{margin-top:0}
.article-body p{margin:0 0 18px;color:var(--text);font-size:15px;line-height:1.85}
.article-body ul,.article-body ol{margin:0 0 18px;padding-left:22px;color:var(--text);font-size:15px;line-height:1.85}
.article-body li{margin-bottom:6px}
.article-body strong{color:var(--ink);font-weight:650}
.stats-compare{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin:28px 0;overflow:hidden;border:1px solid var(--line);border-radius:24px;background:var(--line)}
.stat-item{padding:22px;background:var(--cream2);text-align:center}
.stat-item b{display:block;color:var(--green);font-family:var(--mono);font-size:24px}
.stat-item span{display:block;margin-top:6px;color:var(--text);font-size:12px;line-height:1.5}
#related{padding:60px 0 80px;border-top:1px solid var(--line)}
.article{display:block}@media (max-width:980px){.head,.story,.contact-wrap,.faq-wrap{grid-template-columns:1fr}.hero-video-content{height:180vh}.hero-text-overlay h1,.page-header h1{font-size:clamp(2rem,7vw,4rem)}.stats,.stats-compare{grid-template-columns:repeat(2,1fr)}.case,.case.large,.case.tall{grid-column:span 6}.service{grid-template-columns:1fr}.price{justify-self:start}.sticky{position:relative;top:auto;min-height:300px}.quotes,.blog-grid,.cap-grid,.process,.deliverables{grid-template-columns:1fr}.horizontal-panel{overflow:visible;padding:20px 0}.horizontal-track{width:100%;flex-wrap:wrap}.horizontal-track .case,.horizontal-track .case.large,.horizontal-track .case.tall{flex:1 1 auto;width:auto;min-width:260px;min-height:380px}.horizontal-track .case .media,.horizontal-track .case.large .media{height:200px}.cursor-img{width:280px;height:190px}}
@media (max-width:640px){.nav-video{padding:16px 20px}.nav-cta-video{padding:8px 18px;font-size:.8rem}h1{font-size:clamp(26px,9vw,36px)}h2{font-size:clamp(22px,7vw,30px)}section{padding:54px 0}.container{width:calc(100% - 28px)}.wide{width:calc(100% - 20px)}.hero-video-content{height:160vh}.hero-video-wrap{height:100dvh;padding-top:100px}.hero-text-overlay h1,.page-header h1{font-size:clamp(1.6rem,8vw,2.8rem);letter-spacing:-1px}.hero-text-overlay .hero-desc,.page-header .hero-desc{font-size:.85rem;margin-top:20px}.hero-text-overlay .actions{margin-top:28px}.hero-text-overlay .btn.primary-video{padding:14px 36px;font-size:.9rem}.stats{grid-template-columns:1fr}.case,.case.large,.case.tall{grid-column:span 12}.media,.case.large .media,.horizontal-track .case .media,.horizontal-track .case.large .media{height:240px}.cursor-img{width:220px;height:150px}.contact-card h2{font-size:36px}.footer .container{display:grid}}
