/* work.css — portfolio + project case-study pages (DevHive Studio) */
:root{ --wk-soft:#f4f8fb; }

/* ---------- shared section heading ---------- */
.wk-wrap{max-width:var(--maxw,1180px);margin:0 auto;padding:0 26px}
.wk-eyebrow{display:inline-flex;align-items:center;gap:8px;font:700 12px/1 'JetBrains Mono',monospace;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);background:rgba(0,189,195,.08);border:1px solid rgba(0,189,195,.22);padding:8px 13px;border-radius:30px}
.wk-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal)}

/* ---------- portfolio hero ---------- */
.pf-hero{position:relative;background:linear-gradient(180deg,#071a27,#0b1f2e 60%,#0e2536);color:#fff;padding:120px 0 64px;overflow:hidden}
.pf-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 420px at 80% -10%,rgba(0,189,195,.22),transparent 60%),radial-gradient(600px 400px at 0% 110%,rgba(59,130,246,.18),transparent 55%)}
.pf-hero .wk-wrap{position:relative;z-index:1}
.pf-hero .crumb{font:600 12px 'JetBrains Mono',monospace;color:#7fa6bd;letter-spacing:.08em;margin-bottom:16px}
.pf-hero h1{color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(34px,5.6vw,58px);line-height:1.04;letter-spacing:-.02em;margin:14px 0 16px}
.pf-hero h1 .grad{background:linear-gradient(120deg,var(--teal),#7fe6ea 60%,#8fd0ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.pf-hero p{color:#b8cad8;font-size:17px;line-height:1.65;max-width:640px}
.pf-stats{display:flex;gap:34px;flex-wrap:wrap;margin-top:30px}
.pf-stats .s b{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:30px;display:block}
.pf-stats .s span{color:#88a3b6;font-size:12.5px;font-weight:600}

/* ---------- featured client project ---------- */
.pf-section{padding:64px 0}
.pf-section.alt{background:var(--wk-soft)}
.sec-head{margin-bottom:30px}
.sec-head h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(24px,3.4vw,34px);letter-spacing:-.01em;margin-top:14px;color:var(--ink)}
.sec-head p{color:#5c6b78;font-size:15.5px;margin-top:8px;max-width:620px}

.feat{display:grid;grid-template-columns:1.05fr .95fr;gap:0;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:#fff;box-shadow:0 30px 70px -30px rgba(11,31,46,.3)}
.feat .feat-media{position:relative;min-height:420px;background:linear-gradient(135deg,#0b1f2e,#123043);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:40px}
.feat .feat-media::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 70% 10%,rgba(0,189,195,.3),transparent 60%)}
.feat .badge-wm{position:relative;text-align:center;color:#fff}
.feat .badge-wm .ring{width:96px;height:96px;border-radius:26px;background:linear-gradient(135deg,var(--teal),#0a8bd6);display:grid;place-items:center;margin:0 auto 20px;box-shadow:0 20px 50px rgba(0,189,195,.4);font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:38px}
.feat .badge-wm h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:30px;letter-spacing:-.01em}
.feat .badge-wm .k{font:600 12px 'JetBrains Mono',monospace;letter-spacing:.14em;text-transform:uppercase;color:#7fe6ea;margin-top:8px}
.feat .feat-body{padding:42px 40px;display:flex;flex-direction:column;justify-content:center}
.feat .chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chip{font:700 11px 'JetBrains Mono',monospace;letter-spacing:.04em;color:var(--teal);background:rgba(0,189,195,.08);border:1px solid rgba(0,189,195,.22);padding:5px 11px;border-radius:20px}
.chip.client{color:#0a8bd6;background:rgba(10,139,214,.08);border-color:rgba(10,139,214,.25)}
.feat .feat-body h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:26px;color:var(--ink);letter-spacing:-.01em;margin-bottom:10px}
.feat .feat-body p{color:#566472;font-size:15px;line-height:1.7;margin-bottom:14px}
.feat .feat-metrics{display:flex;gap:26px;flex-wrap:wrap;margin:6px 0 22px}
.feat .feat-metrics .m b{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:22px;color:var(--ink);display:block}
.feat .feat-metrics .m span{color:#7c8896;font-size:12px;font-weight:600}

/* ---------- demos grid ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.work-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:transform .3s cubic-bezier(.22,.61,.36,1),box-shadow .3s;text-decoration:none}
.work-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(11,31,46,.4)}
.work-card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:#0b1f2e}
.work-card .thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s ease}
.work-card:hover .thumb img{transform:scale(1.04)}
.work-card .thumb .tag{position:absolute;top:13px;left:13px;font:700 10.5px 'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:rgba(11,31,46,.7);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.16);padding:6px 11px;border-radius:20px}
.work-card .thumb .live{position:absolute;top:13px;right:13px;display:inline-flex;align-items:center;gap:6px;font:700 10px 'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;color:#0b1f2e;background:#41e3a0;padding:6px 10px;border-radius:20px}
.work-card .thumb .live i{width:6px;height:6px;border-radius:50%;background:#0b1f2e}
.work-card .wc-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.work-card .wc-cat{font:600 11.5px 'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;color:var(--teal)}
.work-card h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:21px;color:var(--ink);margin:7px 0 8px;letter-spacing:-.01em}
.work-card p{color:#5c6b78;font-size:14px;line-height:1.6;margin-bottom:16px;flex:1}
.work-card .wc-foot{display:flex;align-items:center;gap:14px;color:var(--teal);font-weight:700;font-size:13.5px}
.work-card .wc-foot svg{width:17px;height:17px}
.work-card .wc-foot .open{margin-left:auto;color:#8b97a6;font-weight:600;font-size:12.5px}

/* ---------- project detail page ---------- */
.pj-hero{position:relative;background:linear-gradient(180deg,#071a27,#0b1f2e);color:#fff;padding:116px 0 0;overflow:hidden}
.pj-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 85% -10%,rgba(0,189,195,.2),transparent 60%)}
.pj-hero .wk-wrap{position:relative;z-index:1}
.pj-hero .crumb{font:600 12px 'JetBrains Mono',monospace;color:#7fa6bd;letter-spacing:.06em}
.pj-hero .crumb a{color:#7fa6bd;text-decoration:none}
.pj-cat{display:inline-flex;align-items:center;gap:8px;font:700 12px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#7fe6ea;margin:18px 0 12px}
.pj-hero h1{color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(32px,5vw,52px);line-height:1.05;letter-spacing:-.02em}
.pj-hero .tagline{color:#b8cad8;font-size:18px;line-height:1.6;max-width:640px;margin-top:14px}
.pj-hero .pj-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.pj-banner{position:relative;z-index:1;margin-top:46px;border-radius:18px 18px 0 0;overflow:hidden;border:1px solid rgba(255,255,255,.12);border-bottom:0;box-shadow:0 -10px 60px rgba(0,189,195,.15)}
.pj-banner img{width:100%;display:block}

.pj-main{padding:54px 0}
.pj-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.pj-content h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:26px;color:var(--ink);letter-spacing:-.01em;margin:34px 0 14px}
.pj-content h2:first-child{margin-top:0}
.pj-content p{color:#4f5d6a;font-size:15.5px;line-height:1.75;margin-bottom:14px}
.pj-feats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}
.pj-feat{border:1px solid var(--line);border-radius:14px;padding:18px;background:#fff}
.pj-feat .fi{width:38px;height:38px;border-radius:11px;background:rgba(0,189,195,.1);display:grid;place-items:center;color:var(--teal);margin-bottom:12px}
.pj-feat .fi svg{width:20px;height:20px}
.pj-feat b{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:15px;color:var(--ink);margin-bottom:5px}
.pj-feat span{color:#697885;font-size:13.5px;line-height:1.55}
.pj-shots{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.pj-shots figure{border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 20px 44px -28px rgba(11,31,46,.35)}
.pj-shots img{width:100%;display:block}
.pj-shots figcaption{padding:11px 16px;color:#7c8896;font-size:12.5px;font-weight:600;background:#fff;border-top:1px solid var(--line)}

/* sidebar */
.pj-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px}
.pj-card{border:1px solid var(--line);border-radius:16px;padding:20px;background:#fff}
.pj-card h4{font:700 11px 'JetBrains Mono',monospace;letter-spacing:.12em;text-transform:uppercase;color:#8b97a6;margin-bottom:14px}
.pj-meta-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.pj-meta-row:last-child{border-bottom:0}
.pj-meta-row .k{color:#8b97a6;font-weight:600}
.pj-meta-row .v{color:var(--ink);font-weight:700;text-align:right}
.pj-tags{display:flex;flex-wrap:wrap;gap:7px}
.pj-tags span{font:600 11.5px 'JetBrains Mono',monospace;color:#566472;background:var(--wk-soft);border:1px solid var(--line);padding:5px 10px;border-radius:8px}
.pj-cta-card{background:linear-gradient(135deg,#0b1f2e,#123043);color:#fff;border:0}
.pj-cta-card h4{color:#7fe6ea}
.pj-cta-card p{color:#b8cad8;font-size:13.5px;line-height:1.6;margin-bottom:14px}
.pj-cta-card .btn{width:100%;justify-content:center}
.note-line{display:flex;gap:9px;align-items:flex-start;color:#8b97a6;font-size:12.5px;line-height:1.55;margin-top:22px;padding-top:16px;border-top:1px solid var(--line)}
.note-line svg{width:15px;height:15px;flex:none;margin-top:1px;color:#b0bcc8}

.btn-live{background:linear-gradient(120deg,var(--teal),#0a8bd6);color:#fff!important;border:0}
.next-cta{text-align:center;padding:54px 0 64px}
.next-cta h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:30px;color:var(--ink);margin-bottom:10px}
.next-cta p{color:#5c6b78;margin-bottom:22px}

@media(max-width:900px){
  .feat{grid-template-columns:1fr}.feat .feat-media{min-height:280px}
  .work-grid{grid-template-columns:1fr}
  .pj-layout{grid-template-columns:1fr;gap:30px}
  .pj-side{position:static}
  .pj-feats{grid-template-columns:1fr}
}

/* ============================================================
   PORTFOLIO + CASE STUDY  —  full dark rebuild (v3)
   New approach: Living Index hero · Spotlight feature ·
   Zig-zag editorial demos · Disciplines marquee.
   No orbit / no window-chrome / no terminal · no vanity numbers.
   ============================================================ */

/* ---- dark atmosphere, scoped to .portfolio body ---- */
.portfolio{background:#0b1422;color:#9fb2c6}
.portfolio main{position:relative;z-index:1}
.portfolio::before,.portfolio::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0}
.portfolio::before{
  background:
    radial-gradient(900px 620px at 12% -8%,rgba(0,189,195,.16),transparent 60%),
    radial-gradient(820px 600px at 92% 4%,rgba(123,108,255,.15),transparent 60%),
    radial-gradient(1000px 760px at 50% 118%,rgba(2,119,212,.15),transparent 60%),
    linear-gradient(180deg,#0d1828,#0a1322 45%,#0b1525 100%);
  animation:auroraDriftPF 26s ease-in-out infinite alternate;
}
.portfolio::after{
  background-image:linear-gradient(rgba(122,170,200,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(122,170,200,.045) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 78% 60% at 50% 20%,#000,transparent 88%);mask-image:radial-gradient(ellipse 78% 60% at 50% 20%,#000,transparent 88%);
  opacity:.5;
}
@keyframes auroraDriftPF{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(0,-22px,0) scale(1.04)}}

/* ---- entrance + scroll reveal ---- */
.pf-rise{opacity:0;transform:translateY(30px);animation:pfRise .85s var(--ease,cubic-bezier(.22,1,.36,1)) forwards}
.pf-rise.d1{animation-delay:.08s}.pf-rise.d2{animation-delay:.18s}.pf-rise.d3{animation-delay:.30s}.pf-rise.d4{animation-delay:.42s}.pf-rise.d5{animation-delay:.54s}
@keyframes pfRise{to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease,cubic-bezier(.22,1,.36,1)),transform .8s var(--ease,cubic-bezier(.22,1,.36,1)),clip-path .9s var(--ease,cubic-bezier(.22,1,.36,1))}
.reveal.in{opacity:1;transform:none}
.reveal.fromL{transform:translateX(-46px)}.reveal.fromR{transform:translateX(46px)}
.reveal.fromL.in,.reveal.fromR.in{transform:none}
.reveal.r2{transition-delay:.12s}.reveal.r3{transition-delay:.24s}.reveal.r4{transition-delay:.36s}
@media(prefers-reduced-motion:reduce){.pf-rise,.reveal{animation:none!important;opacity:1!important;transform:none!important;transition:none!important}}

/* ============================================================
   HERO — "Living Index": an auto-cycling editorial directory
   ============================================================ */
.pfx-hero{position:relative;padding:130px 0 86px}
.pfx-hero .wk-wrap{position:relative;z-index:2}
.pfx-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:center}
.pfx-head .crumb{font:600 12px var(--mono,'JetBrains Mono',monospace);color:#7fa6bd;letter-spacing:.08em;margin-bottom:16px}
.pfx-head h1{color:#fff;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(36px,5.4vw,60px);line-height:1.02;letter-spacing:-.025em;margin:14px 0 18px}
.pfx-head h1 .grad{background:linear-gradient(120deg,#7ff0e6,#5fd0ff 55%,#9b8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.pfx-head .lead-p{color:#9fb8c8;font-size:17.5px;line-height:1.72;max-width:480px}
.pfx-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.pfx-cta .btn svg{width:18px;height:18px}
.pfx-note{display:flex;align-items:center;gap:10px;margin-top:26px;font:600 12px var(--mono,'JetBrains Mono',monospace);letter-spacing:.06em;color:#6f879b}
.pfx-note .ln{width:34px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--teal),transparent);position:relative;overflow:hidden}
.pfx-note .ln::after{content:"";position:absolute;inset:0;width:40%;background:#7ff0e6;border-radius:2px;animation:noteSweep 2.6s ease-in-out infinite}
@keyframes noteSweep{0%{transform:translateX(-120%)}100%{transform:translateX(320%)}}

/* the living index */
.idx{position:relative;padding-left:30px}
.idx-rail{position:absolute;left:0;top:6px;bottom:6px;width:2px;background:rgba(255,255,255,.08);border-radius:2px;overflow:visible}
.idx-rail .dot{position:absolute;left:50%;top:0;width:13px;height:13px;border-radius:50%;background:linear-gradient(135deg,#7ff0e6,#5fd0ff);transform:translate(-50%,0);box-shadow:0 0 0 4px rgba(0,189,195,.16),0 0 18px rgba(0,189,195,.6);transition:top .55s var(--ease,cubic-bezier(.22,1,.36,1))}
.idx-list{display:flex;flex-direction:column;gap:2px}
.idx-row{position:relative;display:flex;align-items:baseline;gap:14px;padding:12px 16px;border-radius:14px;text-decoration:none;transition:transform .5s var(--ease,cubic-bezier(.22,1,.36,1)),background .5s}
.idx-row::before{content:"";position:absolute;inset:0;border-radius:14px;background:radial-gradient(380px 120px at 0% 50%,rgba(0,189,195,.16),transparent 70%);opacity:0;transition:opacity .5s}
.idx-row .n{font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(24px,3.4vw,40px);line-height:1.06;letter-spacing:-.02em;color:#5f7689;transition:color .45s,background .45s;white-space:nowrap}
.idx-row .c{font:600 11px var(--mono,'JetBrains Mono',monospace);letter-spacing:.12em;text-transform:uppercase;color:#5fe0d6;opacity:0;transform:translateX(-8px);transition:opacity .45s,transform .45s;white-space:nowrap}
.idx-row .go{margin-left:auto;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#0b1f2e;background:linear-gradient(135deg,#7ff0e6,#5fd0ff);opacity:0;transform:scale(.6) translateX(8px);transition:opacity .45s,transform .45s}
.idx-row .go svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2.4}
.idx-row.on{transform:translateX(8px)}
.idx-row.on::before{opacity:1}
.idx-row.on .n{background:linear-gradient(110deg,#fff,#bfe9f2);-webkit-background-clip:text;background-clip:text;color:transparent}
.idx-row.on .c{opacity:1;transform:none}
.idx-row.on .go{opacity:1;transform:none}
.idx-row:hover .n{color:#cfe0ec}

/* ============================================================
   FEATURED — clean two-column, floating animated screenshot
   ============================================================ */
.spot{position:relative;padding:30px 0 80px}
.feat2{display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
.feat2-media{position:relative}
.feat2-glow{position:absolute;inset:-12% -8% -12% -8%;z-index:0;border-radius:50%;background:radial-gradient(circle at 50% 45%,rgba(0,189,195,.26),rgba(123,108,255,.14) 48%,transparent 72%);filter:blur(6px);animation:featGlow 8s ease-in-out infinite;pointer-events:none}
@keyframes featGlow{0%,100%{opacity:.65;transform:scale(.97)}50%{opacity:1;transform:scale(1.05)}}
.feat2-shot{position:relative;z-index:1;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:0 50px 110px -40px rgba(0,8,20,.9),inset 0 1px 0 rgba(255,255,255,.05);animation:featFloat 6.5s ease-in-out infinite}
@keyframes featFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.feat2-shot img{display:block;width:100%;animation:featPan 20s ease-in-out infinite alternate}
@keyframes featPan{from{transform:scale(1.03) translateY(0)}to{transform:scale(1.08) translateY(-3%)}}
.feat2-shot .spot-live{position:absolute;top:16px;left:16px;display:inline-flex;align-items:center;gap:7px;font:700 10px var(--mono,'JetBrains Mono',monospace);letter-spacing:.12em;color:#0b1f2e;background:#41e3a0;padding:6px 12px;border-radius:20px;box-shadow:0 10px 24px rgba(65,227,160,.45)}
.feat2-shot .spot-live i{width:6px;height:6px;border-radius:50%;background:#0b1f2e;animation:dotPulsePF 1.4s ease-in-out infinite}
@keyframes dotPulsePF{0%,100%{opacity:1}50%{opacity:.4}}
.feat2-body .wk-eyebrow{margin-bottom:16px}
.feat2-body .chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.feat2-body h3{font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(26px,3vw,32px);color:#fff;letter-spacing:-.01em;margin-bottom:12px}
.feat2-body p{color:#a9bccb;font-size:15.5px;line-height:1.72;margin-bottom:22px;max-width:520px}
.tickrow{display:flex;flex-direction:column;gap:11px;margin-bottom:26px}
.tick{display:flex;align-items:center;gap:11px;color:#bcd0de;font-size:14.5px}
.tick svg{width:19px;height:19px;stroke:#5fe0d6;fill:none;stroke-width:2.2;flex:none}
.chip{font:700 11px var(--mono,'JetBrains Mono',monospace);letter-spacing:.04em;color:var(--teal);background:rgba(0,189,195,.08);border:1px solid rgba(0,189,195,.22);padding:5px 11px;border-radius:20px}
.chip.client{color:#7fb8e6;background:rgba(10,139,214,.10);border-color:rgba(10,139,214,.3)}
@media(prefers-reduced-motion:reduce){.feat2-shot,.feat2-shot img,.feat2-glow{animation:none!important}}

/* ============================================================
   DISCIPLINES — infinite marquee strip
   ============================================================ */
.disc{position:relative;padding:6px 0 70px;overflow:hidden}
.disc-lab{text-align:center;font:600 11.5px var(--mono,'JetBrains Mono',monospace);letter-spacing:.18em;text-transform:uppercase;color:#6f879b;margin-bottom:22px}
.disc-mask{position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.disc-track{display:flex;gap:14px;width:max-content;animation:discScroll 28s linear infinite}
.disc:hover .disc-track{animation-play-state:paused}
@keyframes discScroll{to{transform:translateX(-50%)}}
.disc-chip{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:700;font-size:18px;color:#cfe0ec;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);padding:12px 20px;border-radius:50px}
.disc-chip i{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#7ff0e6,#5fd0ff);flex:none}

/* ============================================================
   DEMOS — zig-zag editorial rows w/ alternating reveals
   ============================================================ */
.zz{padding:6px 0 30px}
.zz-head{margin-bottom:46px}
.zz-head h2{color:#fff}
.zz-head p{color:#8ba2b5;max-width:620px}
.zz-row{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:30px 0}
.zz-row:nth-child(even) .zz-media{order:2}
.zz-media{position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.10);box-shadow:0 40px 80px -40px rgba(0,8,20,.9)}
.zz-media a{display:block;position:relative}
.zz-media img{display:block;width:100%;transition:transform .7s var(--ease,cubic-bezier(.22,1,.36,1))}
.zz-media:hover img{transform:scale(1.04)}
.zz-media::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.16),transparent);transform:skewX(-18deg);pointer-events:none}
.zz-media.in::after{animation:shine 1.1s ease .25s 1}
@keyframes shine{from{left:-60%}to{left:130%}}
.zz-ix{position:absolute;top:14px;left:16px;font:700 13px var(--mono,'JetBrains Mono',monospace);color:#fff;background:rgba(8,18,30,.7);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.14);padding:5px 11px;border-radius:20px;letter-spacing:.04em}
.zz-body .cat{display:inline-flex;align-items:center;gap:8px;font:700 11.5px var(--mono,'JetBrains Mono',monospace);letter-spacing:.1em;text-transform:uppercase;color:#5fe0d6}
.zz-body .cat i{width:7px;height:7px;border-radius:50%;background:#5fe0d6}
.zz-body h3{font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(24px,3vw,32px);color:#fff;letter-spacing:-.015em;margin:12px 0 12px}
.zz-body p{color:#9fb5c5;font-size:15.5px;line-height:1.72;margin-bottom:18px;max-width:520px}
.zz-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:20px}
.zz-tags span{font:600 11.5px var(--mono,'JetBrains Mono',monospace);color:#9fb5c5;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);padding:5px 10px;border-radius:8px}
.zz-link{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;color:var(--teal)}
.zz-link svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .3s var(--ease,cubic-bezier(.22,1,.36,1))}
.zz-link:hover svg{transform:translateX(5px)}

/* ============================================================
   CTA band
   ============================================================ */
.next-cta{background:transparent;text-align:center;padding:60px 0 80px}
.next-cta .wk-wrap{position:relative;border:1px solid rgba(255,255,255,.10);border-radius:26px;padding:60px 30px;overflow:hidden;background:linear-gradient(160deg,rgba(0,189,195,.10),rgba(123,108,255,.08))}
.next-cta .wk-wrap::before{content:"";position:absolute;width:420px;height:420px;left:50%;top:-40%;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(0,189,195,.3),transparent 65%);animation:ctaGlowPF 7s ease-in-out infinite}
@keyframes ctaGlowPF{0%,100%{opacity:.6;transform:translateX(-50%) scale(.95)}50%{opacity:1;transform:translateX(-50%) scale(1.08)}}
.next-cta h2{position:relative;color:#fff;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(28px,3.6vw,40px);margin-bottom:12px}
.next-cta p{position:relative;color:#a9bccb;margin-bottom:24px}
.next-cta .btn{position:relative}

/* ============================================================
   HOW WE WORK — 4-step process with connecting line
   ============================================================ */
.how{padding:8px 0 24px;position:relative}
.how-head{margin-bottom:40px}
.how-head h2{color:#fff}
.how-head p{color:#8ba2b5;max-width:600px}
.how-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.how-grid::before{content:"";position:absolute;top:42px;left:9%;right:9%;height:2px;background:linear-gradient(90deg,rgba(0,189,195,.5),rgba(123,108,255,.4));opacity:.5;z-index:0}
.how-card{position:relative;z-index:1;background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:24px 22px 24px;transition:transform .5s var(--ease,cubic-bezier(.22,1,.36,1)),opacity .7s var(--ease,cubic-bezier(.22,1,.36,1)),border-color .5s,box-shadow .5s}
.how-card:hover{transform:translateY(-6px);border-color:rgba(0,189,195,.3);box-shadow:0 30px 60px -34px rgba(0,8,20,.85)}
.how-card .hi{position:relative;z-index:1;width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#00bdc3,#0a8bd6);box-shadow:0 12px 26px -8px rgba(0,189,195,.6);margin-bottom:16px}
.how-card .hi svg{width:24px;height:24px}
.how-card .hn{position:absolute;top:18px;right:20px;font:800 13px var(--mono,'JetBrains Mono',monospace);color:rgba(255,255,255,.18);letter-spacing:.04em}
.how-card h4{font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:700;font-size:17px;color:#fff;margin-bottom:7px}
.how-card p{color:#93a8ba;font-size:13.6px;line-height:1.6;margin:0}

/* ============================================================
   CASE STUDY (project pages) — dark theme
   ============================================================ */
.pj-hero{background:transparent;padding-bottom:0}
.pj-hero::before{content:none}
.pj-hero .pj-rise{opacity:0;transform:translateY(26px);animation:pfRise .8s var(--ease,cubic-bezier(.22,1,.36,1)) forwards}
.pj-hero .pj-rise.d1{animation-delay:.06s}.pj-hero .pj-rise.d2{animation-delay:.16s}.pj-hero .pj-rise.d3{animation-delay:.26s}.pj-hero .pj-rise.d4{animation-delay:.36s}
.pj-banner{box-shadow:0 -10px 60px rgba(0,189,195,.18)}
.pj-main{background:transparent}
.pj-content h2{color:#fff}
.pj-content p{color:#9fb5c5}
.pj-feat{background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.10)}
.pj-feat b{color:#fff}.pj-feat span{color:#90a6b8}
.pj-shots figure{border:1px solid rgba(255,255,255,.10);box-shadow:0 24px 50px -28px rgba(0,8,20,.8)}
.pj-shots figcaption{background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.08);color:#8197a9}
.pj-card{background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.10)}
.pj-card h4{color:#7fb0c4}
.pj-meta-row{border-bottom:1px solid rgba(255,255,255,.08)}
.pj-meta-row .k{color:#8197a9}.pj-meta-row .v{color:#fff}
.pj-tags span{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);color:#a9bccb}
.pj-cta-card{background:linear-gradient(135deg,#0a1c2c,#123043);border:1px solid rgba(255,255,255,.08)}
.note-line{border-top:1px solid rgba(255,255,255,.08);color:#7c93a6}
.note-line svg{color:#6f879b}
.btn-visit{background:linear-gradient(120deg,var(--teal),#0a8bd6);color:#fff!important;border:0;box-shadow:0 12px 30px rgba(3,140,200,.35)}
.btn-visit:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(3,140,200,.45)}

/* why band */
.pj-why{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);padding:60px 0;position:relative;overflow:hidden}
.pj-why::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 12% -10%,rgba(0,189,195,.16),transparent 60%)}
.pj-why .wk-wrap{position:relative;z-index:1}
.pj-why .why-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:start}
.pj-why h2{color:#fff;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:clamp(24px,3.2vw,32px);letter-spacing:-.01em;margin-bottom:14px}
.pj-why p{color:#a9bccb;font-size:15.5px;line-height:1.75;margin-bottom:13px}
.pj-why .why-points{display:flex;flex-direction:column;gap:14px}
.pj-why .wp{display:flex;gap:13px;align-items:flex-start;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:16px 17px}
.pj-why .wp .wpi{width:36px;height:36px;border-radius:10px;flex:none;display:grid;place-items:center;background:rgba(0,189,195,.14);color:#5fe0d6}
.pj-why .wp .wpi svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2}
.pj-why .wp b{display:block;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:700;font-size:15px;color:#fff;margin-bottom:3px}
.pj-why .wp span{color:#90a6b8;font-size:13px;line-height:1.55}

/* process timeline */
.pj-process{padding:8px 0 4px}
.pj-process h2{margin-bottom:8px;color:#fff}
.proc{position:relative;margin-top:24px;display:grid;gap:18px}
.proc::before{content:"";position:absolute;left:19px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--teal),rgba(0,189,195,.08))}
.proc-step{position:relative;padding-left:54px}
.proc-step .pn{position:absolute;left:0;top:0;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:15px;color:#fff;background:linear-gradient(135deg,var(--teal),#0a8bd6);box-shadow:0 10px 24px -8px rgba(0,189,195,.6)}
.proc-step h4{font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:700;font-size:16.5px;color:#fff;margin-bottom:5px}
.proc-step p{color:#93a8ba;font-size:14.5px;line-height:1.65;margin:0}

/* outcome (qualitative — no vanity metrics) */
.pj-results{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.pj-results .r{border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:20px 18px;background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.02))}
.pj-results .r b{display:block;font-family:var(--display,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:19px;background:linear-gradient(120deg,#7ff0e6,#8fd0ff);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.15}
.pj-results .r span{display:block;color:#90a6b8;font-size:13px;font-weight:600;margin-top:7px;line-height:1.4}

/* anchor offset so #featured / #work clear the fixed header */
.portfolio section[id]{scroll-margin-top:92px}

/* ---- consistent vertical rhythm ---- */
.pfx-hero{padding:128px 0 30px}
.spot{padding:48px 0 64px}
.disc{padding:8px 0 56px}
.zz{padding:8px 0 24px}
.zz-head{margin-bottom:40px}
.next-cta{padding:48px 0 84px}

/* ---------- tablet / small desktop ---------- */
@media(max-width:1080px){
  .pfx-grid{gap:46px}
  .idx-row .n{font-size:clamp(22px,3.2vw,34px)}
  .zz-row{gap:36px}
}

/* ---------- stack point ---------- */
@media(max-width:920px){
  .pfx-hero{padding:108px 0 26px}
  .pfx-grid{grid-template-columns:1fr;gap:40px}
  .pfx-head h1{font-size:clamp(34px,7vw,48px)}
  .pfx-head .lead-p{max-width:100%}
  .idx{max-width:100%;padding-left:26px}
  .idx-row{padding:12px 12px}
  .idx-row .n{font-size:clamp(26px,6.4vw,40px)}
  .spot{padding:36px 0 56px}
  .feat2{grid-template-columns:1fr;gap:30px}
  .feat2-shot{margin:0 4px}
  .feat2-body p{max-width:100%}
  .how-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .how-grid::before{display:none}
  .spot-wrap{grid-template-columns:1fr}
  .spot-media{margin:0 6px}
  .spot-card{margin:-30px 14px 0;padding:26px 22px 28px}
  .zz-row{grid-template-columns:1fr;gap:20px;padding:22px 0}
  .zz-row:nth-child(even) .zz-media{order:0}
  .zz-body h3{font-size:clamp(24px,6vw,30px)}
  .pj-why .why-grid{grid-template-columns:1fr;gap:24px}
  .pj-results{grid-template-columns:1fr}
}

/* ---------- phones ---------- */
@media(max-width:620px){
  .wk-wrap{padding:0 20px}
  .pfx-hero{padding:100px 0 22px}
  .pfx-cta{gap:10px}
  .pfx-cta .btn{flex:1 1 auto;justify-content:center}
  .pfx-note{margin-top:22px;font-size:11px}
  /* living index: keep name + arrow on one line, let category drop below */
  .idx{padding-left:22px}
  .idx-rail{top:4px;bottom:4px}
  .idx-row{flex-wrap:wrap;align-items:center;gap:6px 10px;padding:11px 12px}
  .idx-row .n{font-size:clamp(22px,8vw,30px);flex:1 1 auto;min-width:0;white-space:normal;line-height:1.1}
  .idx-row .c{order:3;flex-basis:100%;margin-top:2px}
  .idx-row.on .c{opacity:1}
  .idx-row .go{width:30px;height:30px;flex:none}
  .spot-eyebrow .wk-eyebrow,.zz .wk-eyebrow{font-size:10.5px;letter-spacing:.1em;padding:7px 11px}
  .spot-card{margin:-24px 0 0;border-radius:16px;padding:22px 18px 24px}
  .spot-card h3{font-size:23px}
  .spot-media{margin:0}
  .disc{padding:6px 0 46px}
  .disc-chip{font-size:15px;padding:10px 16px}
  .how-grid{grid-template-columns:1fr}
  .how-card{padding:20px 18px}
  .zz-head{margin-bottom:30px}
  .zz-body h3{margin:10px 0 10px}
  .zz-body p{font-size:15px}
  .next-cta{padding:40px 0 70px}
  .next-cta .wk-wrap{padding:44px 22px}
}
