/* ============================================================
   WIDEWING MEDIA — design system
   "Iridescent Aurora" : bright canvas, holographic pink→violet→cyan
   flow, glossy fluid 3D, glassmorphic cards, big rounded type.
   Deliberately the opposite of the matte/brutalist sister-site:
   gradients welcome, glass welcome, soft + luminous.
   ============================================================ */
:root{
  /* canvas */
  --bg:#f5f4fb;            /* page background — cool off-white */
  --bg-2:#eef0fb;          /* alternate band */
  --paper:#ffffff;         /* solid cards */
  --ink:#14121f;           /* near-black violet ink */
  --ink-soft:#3a3550;
  --muted:#6f6a86;
  --muted-2:#9a96ad;
  --line:rgba(20,18,31,.10);
  --line-2:rgba(20,18,31,.06);

  /* iridescent spectrum */
  --c-pink:#ff5fa2;
  --c-coral:#ff8a5c;
  --c-violet:#7b5cff;
  --c-indigo:#5468ff;
  --c-cyan:#36d6ff;
  --c-mint:#5cf0c8;
  --accent:#7b5cff;        /* primary brand violet */
  --accent-deep:#5a3ff0;

  /* glass */
  --glass:rgba(255,255,255,.55);
  --glass-strong:rgba(255,255,255,.72);
  --glass-line:rgba(255,255,255,.7);
  --glass-shadow:0 24px 60px -28px rgba(56,40,120,.42);

  /* signature gradients */
  --grad-aurora:linear-gradient(110deg,#ff5fa2 0%,#7b5cff 38%,#5468ff 60%,#36d6ff 100%);
  --grad-aurora-soft:linear-gradient(120deg,rgba(255,95,162,.9),rgba(123,92,255,.9),rgba(54,214,255,.9));
  --grad-warm:linear-gradient(120deg,#ff8a5c,#ff5fa2,#7b5cff);
  --grad-cool:linear-gradient(120deg,#7b5cff,#5468ff,#36d6ff);

  --display:"Sora","Noto Sans SC",system-ui,sans-serif;
  --sans:"Plus Jakarta Sans","Noto Sans SC",system-ui,sans-serif;
  --maxw:1280px;
  --r-sm:14px; --r:22px; --r-lg:30px; --r-xl:42px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg);color:var(--ink);
  line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  position:relative;
}
a{color:inherit;text-decoration:none}
img,canvas{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit}
::selection{background:var(--c-violet);color:#fff}

/* language visibility */
body[data-lang="en"] [data-lang-zh]{display:none}
body[data-lang="zh"] [data-lang-en]{display:none}

/* ambient aurora wash behind everything */
.aurora-bg{
  position:fixed;inset:-20vh -10vw;z-index:-2;pointer-events:none;filter:blur(70px);opacity:.55;
}
.aurora-bg span{position:absolute;border-radius:50%;mix-blend-mode:multiply;will-change:transform}
.aurora-bg span:nth-child(1){width:48vw;height:48vw;left:-8vw;top:-6vh;background:radial-gradient(circle at 30% 30%,#ff5fa2,transparent 62%);animation:drift1 26s var(--ease) infinite alternate}
.aurora-bg span:nth-child(2){width:42vw;height:42vw;right:-6vw;top:8vh;background:radial-gradient(circle at 60% 40%,#36d6ff,transparent 60%);animation:drift2 30s var(--ease) infinite alternate}
.aurora-bg span:nth-child(3){width:40vw;height:40vw;left:24vw;bottom:-12vh;background:radial-gradient(circle at 50% 50%,#7b5cff,transparent 62%);animation:drift3 34s var(--ease) infinite alternate}
@keyframes drift1{to{transform:translate(8vw,10vh) scale(1.15)}}
@keyframes drift2{to{transform:translate(-7vw,12vh) scale(1.1)}}
@keyframes drift3{to{transform:translate(6vw,-8vh) scale(1.2)}}

/* fine grain for texture */
.grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   Layout helpers
   ============================================================ */
.section{padding:clamp(4.5rem,10vw,8rem) clamp(1.2rem,5vw,3rem);max-width:var(--maxw);margin-inline:auto}
.section--tight{padding-top:clamp(2.5rem,6vw,4rem)}
.band{position:relative}
.band--soft{background:linear-gradient(180deg,transparent,var(--bg-2) 14%,var(--bg-2) 86%,transparent)}

.eyebrow{
  font-family:var(--display);font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.3rem;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.eyebrow::before{content:"";width:24px;height:2px;border-radius:2px;background:var(--grad-aurora)}

.title{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,5vw,4rem);line-height:1.02;letter-spacing:-.03em}
.title-lg{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,8vw,6rem);line-height:.98;letter-spacing:-.04em}
.lead{color:var(--muted);font-size:clamp(1rem,1.5vw,1.18rem);max-width:54ch;margin-top:1.3rem}
.iri{
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;animation:hue 9s linear infinite;
}
@keyframes hue{to{background-position:200% 0}}

/* ============================================================
   Buttons — pill, gradient or glass
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.95rem 1.7rem;border:1.5px solid transparent;border-radius:999px;
  font-family:var(--display);font-size:.86rem;font-weight:600;letter-spacing:.01em;
  cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s,color .35s;
  position:relative;white-space:nowrap;
}
.btn svg{width:1em;height:1em}
.btn--lg{padding:1.15rem 2.2rem;font-size:.95rem}
.btn--sm{padding:.62rem 1.15rem;font-size:.78rem}
.btn--grad{background:var(--grad-aurora);background-size:160% 100%;color:#fff;box-shadow:0 14px 30px -12px rgba(123,92,255,.7)}
.btn--grad:hover{transform:translateY(-3px);box-shadow:0 22px 44px -14px rgba(123,92,255,.85);background-position:100% 0}
.btn--glass{background:var(--glass-strong);border-color:var(--glass-line);color:var(--ink);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--glass-shadow)}
.btn--glass:hover{transform:translateY(-3px);border-color:rgba(123,92,255,.5)}
.btn--ghost{border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn--block{width:100%}

/* ============================================================
   Glass card primitive
   ============================================================ */
.glass{
  background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-lg);
  backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);
  box-shadow:var(--glass-shadow);
}
.card{
  background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-lg);
  backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:var(--glass-shadow);padding:clamp(1.4rem,2.4vw,2.1rem);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
  position:relative;overflow:hidden;
}
.card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:var(--grad-aurora);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s;
}
.card:hover{transform:translateY(-6px);box-shadow:0 34px 70px -30px rgba(56,40,120,.55)}
.card:hover::after{opacity:.9}

/* ============================================================
   Top navigation
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1.2rem,5vw,3rem);transition:padding .4s var(--ease),background .4s;
}
.nav::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;transition:opacity .4s;
  background:rgba(245,244,251,.7);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid var(--line-2);
}
.nav.is-stuck{padding-top:.7rem;padding-bottom:.7rem}
.nav.is-stuck::before{opacity:1}
.brand{display:inline-flex;align-items:center;gap:.62rem;font-family:var(--display);font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.brand__mark{width:30px;height:30px;flex:none;border-radius:9px;background:var(--grad-aurora);position:relative;box-shadow:0 6px 16px -6px rgba(123,92,255,.8)}
.brand__mark::before,.brand__mark::after{content:"";position:absolute;inset:0;border-radius:inherit}
.brand__mark::before{background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.85),transparent 45%)}
.brand__mark::after{
  /* tiny wing glyph */
  inset:7px;background:
    conic-gradient(from -45deg at 50% 60%, #fff 0deg 90deg, transparent 90deg 360deg);
  -webkit-mask:radial-gradient(circle at 50% 130%, transparent 58%, #000 60%);
          mask:radial-gradient(circle at 50% 130%, transparent 58%, #000 60%);
  opacity:.92;border-radius:0;
}
.brand small{font-weight:500;color:var(--muted);font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;margin-left:.1rem}

.nav__links{display:flex;align-items:center;gap:.35rem}
.nav__links a{
  font-family:var(--display);font-size:.9rem;font-weight:500;color:var(--ink-soft);
  padding:.55rem .9rem;border-radius:999px;transition:color .3s,background .3s;position:relative;
}
.nav__links a:hover{color:var(--ink);background:rgba(123,92,255,.08)}
.nav__links a.is-active{color:var(--accent)}
.nav__links a.is-active::after{content:"";position:absolute;left:50%;bottom:.18rem;width:5px;height:5px;border-radius:50%;background:var(--grad-aurora);transform:translateX(-50%)}

.nav__right{display:flex;align-items:center;gap:.7rem}
.lang{
  display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--glass-strong);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.lang button{border:none;background:none;cursor:pointer;font-family:var(--display);font-weight:600;font-size:.74rem;
  padding:.42rem .72rem;color:var(--muted);transition:color .3s,background .3s}
.lang button.is-active{background:var(--grad-aurora);color:#fff}

.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:12px;background:var(--glass-strong);
  cursor:pointer;position:relative}
.nav__burger span{position:absolute;left:11px;right:11px;height:2px;border-radius:2px;background:var(--ink);transition:.3s var(--ease)}
.nav__burger span:nth-child(1){top:15px}.nav__burger span:nth-child(2){top:21px}.nav__burger span:nth-child(3){top:27px}
body.menu-open .nav__burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .nav__burger span:nth-child(2){opacity:0}
body.menu-open .nav__burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:999;background:rgba(245,244,251,.92);backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  padding:2rem clamp(1.2rem,6vw,3rem);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;
}
body.menu-open .drawer{opacity:1;visibility:visible}
.drawer a{font-family:var(--display);font-weight:600;font-size:clamp(2rem,9vw,3.4rem);color:var(--ink);letter-spacing:-.03em;
  padding:.4rem 0;border-bottom:1px solid var(--line-2);transform:translateY(14px);opacity:0;transition:.5s var(--ease)}
body.menu-open .drawer a{transform:none;opacity:1}
body.menu-open .drawer a:nth-child(1){transition-delay:.06s}
body.menu-open .drawer a:nth-child(2){transition-delay:.12s}
body.menu-open .drawer a:nth-child(3){transition-delay:.18s}
body.menu-open .drawer a:nth-child(4){transition-delay:.24s}
body.menu-open .drawer a:nth-child(5){transition-delay:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto;padding:7rem clamp(1.2rem,5vw,3rem) 4rem;width:100%}
.hero__badge{
  display:inline-flex;align-items:center;gap:.55rem;padding:.45rem .9rem;border-radius:999px;
  background:var(--glass-strong);border:1px solid var(--glass-line);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  font-family:var(--display);font-size:.76rem;font-weight:600;color:var(--ink-soft);margin-bottom:1.6rem;box-shadow:var(--glass-shadow)}
.hero__badge i{width:8px;height:8px;border-radius:50%;background:var(--grad-aurora);box-shadow:0 0 0 4px rgba(123,92,255,.18)}
.hero__title{font-family:var(--display);font-weight:700;font-size:clamp(2.7rem,8.5vw,7rem);line-height:.96;letter-spacing:-.045em;max-width:16ch}
.hero__sub{color:var(--ink-soft);font-size:clamp(1.05rem,1.8vw,1.35rem);max-width:46ch;margin-top:1.6rem;font-weight:400}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}
.hero__hint{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--display);
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.6rem}
.hero__hint::before{content:"";width:30px;height:1px;background:var(--muted-2)}
.hero__scroll{width:22px;height:34px;border:1.5px solid var(--muted-2);border-radius:12px;position:relative}
.hero__scroll::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;border-radius:2px;background:var(--accent);transform:translateX(-50%);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* ============================================================
   Marquee
   ============================================================ */
.marquee{overflow:hidden;border-block:1px solid var(--line-2);padding:1.1rem 0;background:linear-gradient(90deg,rgba(255,95,162,.05),rgba(54,214,255,.05))}
.marquee__track{display:flex;gap:1.6rem;align-items:center;white-space:nowrap;width:max-content;animation:marquee 28s linear infinite;font-family:var(--display);font-weight:700;font-size:clamp(1.1rem,2.2vw,1.7rem);letter-spacing:-.02em}
.marquee__track span{color:var(--ink)}
.marquee__track .dot{color:transparent;background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   Stats
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-2);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-2)}
.stat{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:clamp(1.5rem,3vw,2.4rem)}
.stat__n{font-family:var(--display);font-weight:700;font-size:clamp(2rem,4vw,3rem);letter-spacing:-.03em;line-height:1;display:block}
.stat__l{color:var(--muted);font-size:.86rem;margin-top:.55rem;display:block}

/* ============================================================
   Intro grid
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.split__body{color:var(--muted);font-size:1.08rem}
.split__body p+p{margin-top:1.1rem}

/* ============================================================
   Services
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.2rem;margin-top:2.6rem}
.svc{padding:clamp(1.5rem,2.6vw,2.2rem)}
.svc__ico{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:1.2rem;color:#fff;font-family:var(--display);font-weight:700;font-size:1.3rem;box-shadow:0 12px 26px -12px rgba(123,92,255,.7)}
.svc__t{font-family:var(--display);font-weight:600;font-size:1.22rem;letter-spacing:-.01em}
.svc__d{color:var(--muted);font-size:.96rem;margin-top:.6rem}
.svc__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.1rem}
.tag{font-family:var(--display);font-size:.72rem;font-weight:500;color:var(--ink-soft);padding:.28rem .68rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.4)}

/* interactive capability explorer (services page) */
.cap{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center;margin-top:2.4rem}
.cap__list{display:flex;flex-direction:column;gap:.5rem}
.cap__btn{text-align:left;border:1px solid var(--line);background:var(--glass);border-radius:var(--r);padding:1.05rem 1.3rem;cursor:pointer;
  transition:.35s var(--ease);display:flex;align-items:center;gap:1rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.cap__btn:hover{transform:translateX(4px)}
.cap__btn.is-active{border-color:transparent;background:var(--grad-aurora);color:#fff;box-shadow:0 18px 36px -18px rgba(123,92,255,.8)}
.cap__btn.is-active .cap__num,.cap__btn.is-active .cap__sub{color:rgba(255,255,255,.85)}
.cap__num{font-family:var(--display);font-weight:700;font-size:.8rem;opacity:.6}
.cap__name{font-family:var(--display);font-weight:600;font-size:1.12rem;display:block}
.cap__sub{font-size:.82rem;color:var(--muted)}
.cap__stage{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:440px;
  background:linear-gradient(160deg,rgba(123,92,255,.1),rgba(54,214,255,.08));border:1px solid var(--glass-line);box-shadow:var(--glass-shadow)}
.cap__stage canvas{position:absolute;inset:0;width:100%;height:100%}
.cap__caption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.6rem;z-index:2;
  background:linear-gradient(0deg,rgba(255,255,255,.8),transparent);backdrop-filter:blur(4px)}
.cap__caption h4{font-family:var(--display);font-weight:600;font-size:1.1rem}
.cap__caption p{color:var(--muted);font-size:.9rem;margin-top:.25rem}

/* ============================================================
   Work / portfolio
   ============================================================ */
.work-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.4rem;margin-top:2.6rem}
.work{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:340px;cursor:pointer;border:1px solid var(--glass-line);
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff;isolation:isolate;box-shadow:var(--glass-shadow)}
.work__bg{position:absolute;inset:0;z-index:-2;transition:transform .8s var(--ease)}
.work:hover .work__bg{transform:scale(1.07)}
.work__art{position:absolute;inset:0;z-index:-2;mix-blend-mode:screen;opacity:.85;pointer-events:none;transition:transform .8s var(--ease)}
.work__art svg{width:100%;height:100%;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.18))}
.work:hover .work__art{transform:scale(1.04) translateY(-4px)}
.work::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,18,31,0) 30%,rgba(20,18,31,.72))}
.work__meta{padding:1.5rem;transform:translateY(8px);transition:transform .5s var(--ease)}
.work:hover .work__meta{transform:none}
.work__cat{font-family:var(--display);font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;opacity:.85}
.work__t{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;margin-top:.3rem}
.work__d{font-size:.92rem;opacity:.85;margin-top:.4rem;max-width:40ch;max-height:0;overflow:hidden;opacity:0;transition:.5s var(--ease)}
.work:hover .work__d{max-height:120px;opacity:.9;margin-top:.5rem}
.work__open{position:absolute;top:1.2rem;right:1.2rem;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:var(--glass-strong);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--ink);
  transform:rotate(-30deg) scale(.8);opacity:0;transition:.45s var(--ease)}
.work:hover .work__open{transform:none;opacity:1}

/* logo cloud */
.logos{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;margin-top:2rem}
.logos div{background:var(--glass);padding:1.6rem 1rem;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--muted-2);letter-spacing:-.02em;transition:.3s}
.logos div:hover{color:var(--ink);background:rgba(255,255,255,.7)}

/* ============================================================
   Process steps
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem;margin-top:2.6rem;counter-reset:step}
.step{padding:1.6rem;position:relative}
.step__n{font-family:var(--display);font-weight:700;font-size:2.4rem;letter-spacing:-.03em;line-height:1;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.step__t{font-family:var(--display);font-weight:600;font-size:1.12rem;margin-top:.6rem}
.step__d{color:var(--muted);font-size:.92rem;margin-top:.4rem}

/* ============================================================
   Quote / testimonial
   ============================================================ */
.quote{padding:clamp(2rem,5vw,3.6rem);text-align:center}
.quote__q{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,3.2vw,2.4rem);line-height:1.22;letter-spacing:-.02em;max-width:24ch;margin-inline:auto}
.quote__a{color:var(--muted);font-size:.95rem;margin-top:1.4rem}

/* ============================================================
   CTA banner
   ============================================================ */
.cta-band{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:clamp(2.6rem,6vw,5rem);text-align:center;color:#fff;isolation:isolate}
.cta-band canvas{position:absolute;inset:0;z-index:-2;width:100%;height:100%}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--grad-aurora);opacity:.92}
.cta-band h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.03em;line-height:1.04}
.cta-band p{max-width:46ch;margin:1.1rem auto 0;opacity:.92;font-size:1.05rem}
.cta-band .btn{margin-top:2rem}
.cta-band .btn--glass{background:rgba(255,255,255,.92);color:var(--ink);border-color:transparent}

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--display);font-weight:600;font-size:.82rem;margin-bottom:.45rem;color:var(--ink-soft)}
.field input,.field textarea,.field select{
  width:100%;padding:.95rem 1.1rem;border:1px solid var(--line);border-radius:var(--r-sm);background:rgba(255,255,255,.7);
  font-family:var(--sans);font-size:.98rem;color:var(--ink);transition:.3s;backdrop-filter:blur(6px)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(123,92,255,.14)}
.field textarea{resize:vertical;min-height:130px}
.info-row{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem 0;border-bottom:1px solid var(--line-2)}
.info-row__ico{width:44px;height:44px;flex:none;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--grad-aurora);box-shadow:0 10px 22px -10px rgba(123,92,255,.7)}
.info-row__k{font-family:var(--display);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.info-row__v{font-size:1rem;margin-top:.15rem;line-height:1.45}
.form-note{font-size:.82rem;color:var(--muted-2);margin-top:.6rem}
.form-ok{display:none;padding:1rem 1.2rem;border-radius:var(--r-sm);background:rgba(92,240,200,.18);border:1px solid rgba(92,240,200,.5);color:#0a7a5c;font-size:.92rem;margin-top:1rem}
.form-ok.show{display:block}

/* page header (inner pages) */
.page-head{position:relative;padding:9rem clamp(1.2rem,5vw,3rem) clamp(2.5rem,6vw,4rem);max-width:var(--maxw);margin-inline:auto;overflow:hidden}
.page-head__canvas{position:absolute;inset:0;z-index:-1;opacity:.9}
.page-head .title-lg{max-width:18ch}

/* ============================================================
   Footer
   ============================================================ */
.footer{position:relative;margin-top:4rem;border-top:1px solid var(--line-2)}
.footer__inner{max-width:var(--maxw);margin-inline:auto;padding:clamp(3rem,6vw,4.5rem) clamp(1.2rem,5vw,3rem) 2.4rem;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.4rem}
.footer__brand p{color:var(--muted);font-size:.95rem;max-width:34ch;margin-top:1rem}
.footer h5{font-family:var(--display);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.footer ul li{margin-bottom:.6rem}
.footer ul a{color:var(--ink-soft);font-size:.94rem;transition:color .3s}
.footer ul a:hover{color:var(--accent)}
.footer__bottom{max-width:var(--maxw);margin-inline:auto;padding:1.4rem clamp(1.2rem,5vw,3rem);border-top:1px solid var(--line-2);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;color:var(--muted);font-size:.85rem}

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* ============================================================
   Viewer modal (3D)
   ============================================================ */
.viewer{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:1.2rem;
  background:rgba(20,18,31,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.viewer.open{display:flex}
.viewer__box{width:min(960px,100%);height:min(640px,86vh);border-radius:var(--r-xl);overflow:hidden;position:relative;
  background:var(--paper);box-shadow:0 50px 120px -40px rgba(20,18,31,.6)}
.viewer__canvas{position:absolute;inset:0;width:100%;height:100%}
.viewer__info{position:absolute;left:0;bottom:0;right:0;padding:1.8rem 2rem;
  background:linear-gradient(0deg,rgba(255,255,255,.92),transparent);backdrop-filter:blur(4px)}
.viewer__info h3{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em}
.viewer__info p{color:var(--muted);margin-top:.35rem;max-width:54ch}
.viewer__close{position:absolute;top:1.1rem;right:1.1rem;z-index:3;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  background:var(--glass-strong);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-size:1.3rem;color:var(--ink);
  display:grid;place-items:center;transition:.3s}
.viewer__close:hover{transform:rotate(90deg);background:#fff}
.viewer__hint{position:absolute;top:1.2rem;left:1.4rem;z-index:3;font-family:var(--display);font-size:.74rem;font-weight:500;color:var(--muted);
  background:var(--glass-strong);padding:.4rem .8rem;border-radius:999px;backdrop-filter:blur(8px)}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .split{grid-template-columns:1fr}
  .cap{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .nav__right .btn--grad{display:none}
  .footer__inner{grid-template-columns:1fr}
}
@media (max-width:520px){
  .stats{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   IMMERSIVE JOURNEY (index) — one continuous 3D world you fly
   through by scrolling. No stacked sections, no top pill nav.
   ============================================================ */
body.immersive{background:
  radial-gradient(120% 90% at 20% 0%, #ffe3f1 0%, transparent 55%),
  radial-gradient(120% 90% at 90% 20%, #d8f4ff 0%, transparent 55%),
  linear-gradient(180deg,#f3eefc,#eaf2ff 60%,#f1eaff);
  background-attachment:fixed;overflow-x:hidden}

.j-canvas{position:fixed;inset:0;width:100%;height:100vh;z-index:0}
/* tall transparent spacer that creates the scroll length */
.j-scroll{position:relative;z-index:1;width:1px;pointer-events:none}

/* progress bar */
.j-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:var(--grad-aurora);box-shadow:0 0 14px rgba(123,92,255,.6);transition:width .1s linear}

/* slim top bar */
.j-top{position:fixed;top:0;left:0;right:0;z-index:55;display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.2rem,5vw,3rem);pointer-events:none}
.j-top > *{pointer-events:auto}

/* chapter overlays — fixed, fade in/out by scroll proximity */
.j-stage{position:fixed;inset:0;z-index:20;pointer-events:none}
.chapter{position:absolute;inset:0;display:grid;align-content:center;
  padding:0 clamp(1.4rem,7vw,8rem);opacity:0;will-change:opacity,transform}
.chapter__inner{max-width:760px;transform:translateY(30px);will-change:transform}
.chapter[data-align="center"]{justify-items:center;text-align:center}
.chapter[data-align="center"] .chapter__inner{margin-inline:auto}
.chapter__eyebrow{font-family:var(--display);font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:1.1rem;
  display:inline-flex;align-items:center;gap:.6rem}
.chapter__eyebrow::before{content:"";width:30px;height:2px;border-radius:2px;background:var(--grad-aurora)}
.chapter__title{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,7vw,5.6rem);line-height:1;letter-spacing:-.04em}
.chapter__body{color:var(--ink-soft);font-size:clamp(1.05rem,1.9vw,1.4rem);max-width:46ch;margin-top:1.4rem;line-height:1.55}
.chapter[data-align="center"] .chapter__body{margin-inline:auto}
.chapter__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem;pointer-events:auto}
.chapter .glass-plate{background:rgba(255,255,255,.34);border:1px solid var(--glass-line);border-radius:var(--r-xl);
  backdrop-filter:blur(8px) saturate(1.3);-webkit-backdrop-filter:blur(8px) saturate(1.3);padding:clamp(1.6rem,3vw,2.8rem)}

/* capability node labels (chapter 2) */
.j-caps{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem;pointer-events:auto}
.j-cap{font-family:var(--display);font-weight:600;font-size:.92rem;padding:.6rem 1.1rem;border-radius:999px;
  background:var(--glass-strong);border:1px solid var(--glass-line);backdrop-filter:blur(10px);
  box-shadow:var(--glass-shadow);display:inline-flex;align-items:center;gap:.5rem}
.j-cap i{width:9px;height:9px;border-radius:50%;background:var(--grad-aurora)}

/* work planet picker (chapter 3) */
.j-work{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;margin-top:1.8rem;
  max-width:620px;pointer-events:auto}
.j-work button{text-align:left;border:1px solid var(--glass-line);background:var(--glass);border-radius:var(--r);
  padding:.85rem 1rem;cursor:pointer;backdrop-filter:blur(10px);transition:.3s var(--ease);color:var(--ink)}
.j-work button:hover{transform:translateY(-3px);box-shadow:var(--glass-shadow)}
.j-work b{font-family:var(--display);font-weight:600;font-size:.96rem;display:block}
.j-work span{font-size:.76rem;color:var(--muted)}

/* big floating stats (chapter 4) */
.j-stats{display:grid;grid-template-columns:repeat(2,auto);gap:clamp(1.4rem,4vw,3.4rem);margin-top:2rem;justify-content:center}
.j-stat{text-align:center}
.j-stat b{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,6vw,4.4rem);letter-spacing:-.03em;line-height:1;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.j-stat span{color:var(--muted);font-size:.92rem;margin-top:.4rem;display:block}

/* contact card (chapter 5) */
.j-contact{display:flex;flex-wrap:wrap;gap:1.6rem 2.6rem;margin-top:1.8rem;pointer-events:auto}
.j-contact a,.j-contact div{font-size:1rem}
.j-contact .k{font-family:var(--display);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.2rem}

/* right-side chapter nav dots */
.j-dots{position:fixed;right:clamp(.9rem,2.5vw,1.8rem);top:50%;transform:translateY(-50%);z-index:55;
  display:flex;flex-direction:column;gap:.9rem;pointer-events:auto}
.j-dots button{position:relative;width:12px;height:12px;border-radius:50%;border:1.5px solid var(--muted-2);background:transparent;cursor:pointer;transition:.3s var(--ease)}
.j-dots button.is-active{border-color:transparent;background:var(--grad-aurora);transform:scale(1.25);box-shadow:0 0 12px rgba(123,92,255,.6)}
.j-dots button::after{content:attr(data-label);position:absolute;right:24px;top:50%;transform:translateY(-50%);
  font-family:var(--display);font-size:.74rem;font-weight:600;white-space:nowrap;color:var(--ink-soft);
  background:var(--glass-strong);padding:.3rem .65rem;border-radius:999px;opacity:0;pointer-events:none;transition:.3s;backdrop-filter:blur(8px)}
.j-dots button:hover::after{opacity:1}

/* scroll cue */
.j-cue{position:fixed;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:55;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-family:var(--display);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:opacity .4s}
.j-cue .m{width:22px;height:34px;border:1.5px solid var(--muted-2);border-radius:12px;position:relative}
.j-cue .m::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;border-radius:2px;background:var(--accent);transform:translateX(-50%);animation:scrolldot 1.8s var(--ease) infinite}

@media (max-width:720px){
  .j-dots{display:none}
  .chapter{padding:0 1.4rem}
  .j-stats{grid-template-columns:1fr 1fr;gap:1.4rem}
}

/* ============================================================
   EXPANDED CONTENT COMPONENTS (services / work / studio /
   insights / contact). Aurora-glass language, content-dense.
   ============================================================ */

/* --- service detail rows --- */
.detail-list{display:flex;flex-direction:column;gap:1.2rem;margin-top:2.6rem}
.detail{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-lg);
  backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);box-shadow:var(--glass-shadow);
  padding:clamp(1.5rem,3vw,2.4rem);display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(1.2rem,3vw,2.6rem);scroll-margin-top:90px}
.detail__head{grid-column:1/-1;display:flex;align-items:center;gap:1rem;position:relative}
.detail__ico{width:54px;height:54px;flex:none;border-radius:16px;display:grid;place-items:center;color:#fff;font-size:1.3rem;
  box-shadow:0 12px 26px -12px rgba(123,92,255,.7)}
.detail__t{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.7rem);letter-spacing:-.02em}
.detail__good{color:var(--muted);font-size:.88rem;margin-top:.2rem}
.detail__good span{color:var(--accent);font-weight:600}
.detail__n{margin-left:auto;font-family:var(--display);font-weight:700;font-size:1.6rem;letter-spacing:-.02em;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.detail__lead{color:var(--ink-soft);font-size:1.04rem;line-height:1.6}
.detail__deliver h4{font-family:var(--display);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.8rem}
.detail__deliver ul{display:flex;flex-direction:column;gap:.5rem}
.detail__deliver li{position:relative;padding-left:1.4rem;font-size:.95rem;color:var(--ink-soft)}
.detail__deliver li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--grad-aurora)}

/* --- engagement / culture glyph cards --- */
.engage__glyph{font-size:1.8rem;background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.8rem}
.engage__list{margin-top:1rem;display:flex;flex-direction:column;gap:.45rem}
.engage__list li{position:relative;padding-left:1.3rem;font-size:.9rem;color:var(--ink-soft)}
.engage__list li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}

/* --- case studies --- */
.cases{display:flex;flex-direction:column;gap:clamp(1.6rem,4vw,3rem);margin-top:2.6rem}
.case{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:center}
.case--alt .case__media{order:2}
.case__media{position:relative;min-height:340px;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  display:flex;align-items:flex-end;padding:1.5rem;box-shadow:var(--glass-shadow);transition:transform .4s var(--ease)}
.case__media:hover{transform:translateY(-5px)}
.case__media::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 80% 10%,rgba(255,255,255,.4),transparent 50%)}
.case__client{font-family:var(--display);font-weight:700;font-size:1.5rem;color:#fff;position:relative;z-index:1;text-shadow:0 2px 18px rgba(20,18,31,.25)}
.case__view{position:absolute;top:1.2rem;right:1.3rem;z-index:1;font-family:var(--display);font-size:.76rem;font-weight:600;color:var(--ink);
  background:var(--glass-strong);padding:.4rem .8rem;border-radius:999px;backdrop-filter:blur(8px)}
.case__sector{font-family:var(--display);font-size:.76rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.case__title{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,2.8vw,2.1rem);letter-spacing:-.02em;margin:.6rem 0 1.1rem;line-height:1.08}
.case__block{margin-bottom:1rem}
.case__block h4{font-family:var(--display);font-weight:600;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.case__block p{color:var(--ink-soft);font-size:.98rem;line-height:1.55}
.case__results{display:flex;gap:1.6rem;margin-top:1.3rem;flex-wrap:wrap}
.case__results b{font-family:var(--display);font-weight:700;font-size:1.8rem;letter-spacing:-.02em;display:block;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.case__results span{font-size:.82rem;color:var(--muted)}

/* --- testimonials --- */
.testi blockquote{font-family:var(--display);font-weight:500;font-size:1.12rem;line-height:1.5;letter-spacing:-.01em}
.testi figcaption{color:var(--muted);font-size:.88rem;margin-top:1.1rem}

/* --- timeline --- */
.timeline{position:relative;margin-top:2.6rem;padding-left:1.4rem}
.timeline::before{content:"";position:absolute;left:0;top:.4rem;bottom:.4rem;width:2px;border-radius:2px;background:var(--grad-aurora);opacity:.5}
.tl__item{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.4rem;padding:0 0 1.8rem .6rem;align-items:start}
.tl__year{font-family:var(--display);font-weight:700;font-size:1.05rem;letter-spacing:-.01em;min-width:3.2rem;
  background:var(--grad-aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.tl__dot{position:absolute;left:-1.4rem;top:.35rem;width:14px;height:14px;border-radius:50%;background:var(--grad-aurora);box-shadow:0 0 0 4px var(--bg)}
.tl__body h3{font-family:var(--display);font-weight:600;font-size:1.1rem}
.tl__body p{color:var(--muted);font-size:.94rem;margin-top:.25rem;max-width:52ch}

/* --- awards --- */
.awards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;margin-top:2.4rem}
.award{background:var(--glass);padding:1.4rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}
.award__org{font-family:var(--display);font-weight:700;font-size:1rem}
.award__name{color:var(--ink-soft);font-size:.9rem}
.award__year{color:var(--muted-2);font-size:.8rem;font-family:var(--display);font-weight:600}

/* --- insights / articles --- */
.article-feat{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:center;margin-top:2.4rem;
  background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--glass-shadow);cursor:pointer}
.article-feat__media{min-height:330px;position:relative}
.article-feat__media .pill{position:absolute;top:1.2rem;left:1.2rem;font-family:var(--display);font-weight:600;font-size:.74rem;
  background:var(--glass-strong);color:var(--ink);padding:.4rem .8rem;border-radius:999px;backdrop-filter:blur(8px)}
.article-feat__body{padding:clamp(1.4rem,3vw,2.4rem) clamp(1.4rem,3vw,2.4rem) clamp(1.4rem,3vw,2.4rem) 0}
.article-feat__title{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:-.025em;line-height:1.08;margin:.5rem 0 .8rem}
.article-feat__excerpt{color:var(--ink-soft);font-size:1.02rem;line-height:1.55;margin-bottom:1.3rem}
.article__meta{font-size:.82rem;color:var(--muted)}
.article__cat{color:var(--accent);font-weight:600}
.articles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.4rem;margin-top:1.4rem}
.article{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column}
.article__media{height:170px}
.article .article__meta,.article__title,.article__excerpt,.article__read{padding-inline:clamp(1.2rem,2vw,1.5rem)}
.article .article__meta{padding-top:1.2rem}
.article__title{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:-.01em;line-height:1.2;margin:.5rem 0}
.article__excerpt{color:var(--muted);font-size:.92rem;line-height:1.5;flex:1}
.article__read{color:var(--muted-2);font-size:.8rem;font-family:var(--display);font-weight:600;padding-bottom:1.3rem;margin-top:.8rem}

/* --- newsletter --- */
.newsletter{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;margin-top:1rem}
.newsletter form{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;width:100%;max-width:480px}
.newsletter input{flex:1;min-width:200px;padding:.95rem 1.2rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.7);font-family:var(--sans);font-size:.96rem}
.newsletter input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(123,92,255,.14)}

/* --- FAQ accordion --- */
.faq-list{display:flex;flex-direction:column;gap:.7rem;margin-top:2.2rem;max-width:820px}
.faq{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r);overflow:hidden;backdrop-filter:blur(10px)}
.faq__q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.15rem 1.4rem;
  font-family:var(--display);font-weight:600;font-size:1.02rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__ico{font-size:1.3rem;color:var(--accent);transition:transform .3s var(--ease);flex:none}
.faq.is-open .faq__ico{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq.is-open .faq__a{max-height:260px}
.faq__a p{padding:0 1.4rem 1.2rem;color:var(--muted);font-size:.96rem;line-height:1.6}

@media (max-width:860px){
  .detail{grid-template-columns:1fr}
  .case,.case--alt .case__media,.article-feat{grid-template-columns:1fr}
  .case--alt .case__media{order:0}
}

/* ============================================================
   ROUND 2 — industries, careers, detail pages, nav for 8 items
   ============================================================ */

/* nav: tighten for 8 links, raise burger breakpoint */
.nav__links a{padding:.5rem .72rem;font-size:.86rem}
@media (max-width:1080px){ .nav__links{display:none} .nav__burger{display:block} .nav__right .btn--grad{display:none} }

/* service detail "learn more" link */
.detail__more{grid-column:1/-1;justify-self:start;font-family:var(--display);font-weight:600;font-size:.92rem;color:var(--accent);
  padding:.5rem 0;border-bottom:2px solid transparent;transition:.3s var(--ease)}
.detail__more:hover{border-color:var(--accent);transform:translateX(3px)}

/* careers — roles list */
.roles{display:flex;flex-direction:column;gap:.8rem;margin-top:2.6rem}
.role{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;
  background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-lg);padding:1.4rem 1.6rem;
  backdrop-filter:blur(12px);box-shadow:var(--glass-shadow);transition:transform .35s var(--ease)}
.role:hover{transform:translateX(4px)}
.role__t{font-family:var(--display);font-weight:600;font-size:1.2rem}
.role__d{color:var(--muted);font-size:.94rem;margin-top:.3rem;max-width:60ch}
.role__meta{display:flex;gap:.6rem;color:var(--muted-2);font-size:.82rem;font-family:var(--display);font-weight:600;margin-top:.5rem}
.role__main{flex:1;min-width:240px}

/* service page — includes grid */
.includes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem;margin-top:1.6rem}
.include{display:flex;align-items:center;gap:.8rem;background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r);
  padding:1rem 1.2rem;font-family:var(--display);font-weight:500;font-size:.98rem;backdrop-filter:blur(10px)}
.include span{width:26px;height:26px;flex:none;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:.8rem;background:var(--grad-aurora)}

/* case page — gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.gallery__cell{height:clamp(200px,26vw,320px);border-radius:var(--r-lg);box-shadow:var(--glass-shadow);
  position:relative;overflow:hidden}
.gallery__cell::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 75% 10%,rgba(255,255,255,.45),transparent 55%)}
@media (max-width:720px){ .gallery{grid-template-columns:1fr 1fr} }

/* detail page heros + back link */
.detail-hero{display:block}
.detail-hero__ico{width:60px;height:60px;border-radius:18px;font-size:1.5rem;margin-bottom:1.2rem}
.back-link{display:inline-block;font-family:var(--display);font-weight:600;font-size:.86rem;color:var(--accent);
  margin-bottom:1.4rem;transition:.3s var(--ease)}
.back-link:hover{transform:translateX(-3px)}

/* article page */
.article-page__head{max-width:840px;margin-inline:auto;padding-top:8rem}
.article-page__hero{height:clamp(240px,40vw,440px);border-radius:var(--r-xl);max-width:1100px;margin:0 auto;box-shadow:var(--glass-shadow);
  position:relative;overflow:hidden}
.article-page__hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 70% 12%,rgba(255,255,255,.4),transparent 55%)}
.article-page__body{max-width:720px;margin-inline:auto}
.article-page__lead{font-family:var(--display);font-weight:500;font-size:clamp(1.2rem,2.2vw,1.5rem);line-height:1.4;
  letter-spacing:-.01em;color:var(--ink);margin-bottom:1.8rem}
.article-page__body p{color:var(--ink-soft);font-size:1.08rem;line-height:1.75;margin-bottom:1.3rem}
.article-page__by{font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--accent);margin-top:2rem !important;
  padding-top:1.4rem;border-top:1px solid var(--line-2)}

/* ============================================================
   Media block content — decorative glyph + category label so
   gradient thumbnails / heroes read as intentional, not blank.
   ============================================================ */
.article-feat__media,.article__media,.article-page__hero{position:relative;overflow:hidden;display:grid;place-items:center}
.media-glyph{font-family:var(--display);font-weight:700;font-size:clamp(3.2rem,7vw,5.5rem);line-height:1;
  color:rgba(255,255,255,.55);text-shadow:0 6px 30px rgba(20,18,31,.18);pointer-events:none}
.media-glyph--sm{font-size:2.6rem}
.media-glyph--lg{font-size:clamp(4.5rem,13vw,9rem)}
.media-cat{position:absolute;left:1.1rem;bottom:1.1rem;font-family:var(--display);font-weight:600;font-size:.74rem;
  letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.22);
  padding:.34rem .7rem;border-radius:999px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
