/* ===========================================================
   CLASS OF NØNE — section styles
   =========================================================== */

/* ---------- HERO / COLD OPEN ---------- */
.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;overflow:hidden}
.hero #field{position:absolute;inset:0;z-index:0;display:block}
.hero .halo{position:absolute;z-index:0;left:50%;top:46%;width:min(70vw,720px);aspect-ratio:1;transform:translate(-50%,-50%);
  border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(223,231,255,.10),transparent 62%);filter:blur(8px)}
.hero .inner{position:relative;z-index:2;width:100%}
.hero h1{font-family:var(--fx-display);font-weight:800;line-height:.86;letter-spacing:-.035em;
  font-size:clamp(54px,12.5vw,210px);max-width:15ch}
.hero h1 .o{font-style:normal;position:relative;display:inline-block}
.hero h1 em{font-family:var(--fx-elegant);font-style:italic;font-weight:400;letter-spacing:-.01em}
.hero .sub{margin-top:clamp(24px,3vw,40px);display:flex;gap:clamp(20px,4vw,60px);flex-wrap:wrap;align-items:flex-start}
.hero .sub .l{max-width:46ch;font-size:clamp(15px,1.5vw,19px);line-height:1.6;color:var(--bone-dim)}
.hero .sub .l b{color:var(--bone);font-weight:500}
.hero .sub .r{font-family:var(--fx-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ash);
  line-height:2;border-left:1px solid var(--hair);padding-left:20px}
.char{display:inline-block;opacity:0;transform:translateY(115%) rotate(3deg);
  animation:charIn .95s cubic-bezier(.16,1,.3,1) forwards;will-change:transform,opacity}
@keyframes charIn{to{opacity:1;transform:none}}
[data-split].lit .char{opacity:1;transform:none;animation:none}

/* ---------- MANIFESTO ---------- */
.manifesto{position:relative;padding:clamp(120px,22vh,260px) 0;border-top:1px solid var(--hair-2)}
.manifesto .wrap{max-width:1280px;margin:0 auto}
.manifesto .tag{margin-bottom:clamp(40px,7vw,90px);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
.manifesto p{font-family:var(--fx-display);font-weight:600;letter-spacing:-.02em;line-height:1.04;
  font-size:clamp(30px,5.4vw,84px);max-width:18ch}
.manifesto p .mut{color:var(--ash-dim)}
.manifesto p em{font-family:var(--fx-elegant);font-style:italic;font-weight:400;color:var(--bone)}
.manifesto .line{display:block;overflow:hidden;padding-bottom:.14em;margin-bottom:-.06em}
.manifesto .line>span{display:inline-block;transform:translateY(110%);transition:transform 1s var(--ease)}
.manifesto .line.in>span{transform:none}

/* ---------- THE WORK — CINEMA ---------- */
.work{position:relative;height:100svh;min-height:620px;overflow:hidden;background:var(--void);
  border-top:1px solid var(--hair-2);border-bottom:1px solid var(--hair-2)}
.work .wkhead{position:absolute;top:0;left:0;right:0;z-index:6;display:flex;justify-content:space-between;
  align-items:flex-start;padding:clamp(70px,11vh,120px) clamp(20px,5vw,68px) 0;pointer-events:none}
.work .wkhead h2{font-family:var(--fx-display);font-weight:800;font-size:clamp(20px,2.4vw,30px);letter-spacing:-.01em}
.work .wkhead .hint{font-family:var(--fx-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ash);
  text-align:right;line-height:1.9}
.work .bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(70% 60% at 50% 50%,rgba(255,255,255,.025),transparent 70%)}

.track{position:absolute;top:0;bottom:0;left:0;display:flex;align-items:center;gap:clamp(28px,4vw,72px);
  padding:0 max(18vw,40px);will-change:transform;z-index:2;cursor:grab;user-select:none;-webkit-user-drag:none}
.panel,.panel *{-webkit-user-drag:none;user-select:none}
.track.drag{cursor:grabbing}
.panel{position:relative;flex:0 0 auto;width:clamp(280px,52vw,640px);height:clamp(380px,66vh,640px);
  background:linear-gradient(160deg,#101013,#08080a);border:1px solid var(--hair);border-radius:6px;overflow:hidden;
  filter:grayscale(1) brightness(.62);transition:filter 1s var(--ease),transform 1s var(--ease),border-color 1s var(--ease);
  transform:scale(.9)}
.panel.focus{filter:none;transform:scale(1);border-color:rgba(242,239,230,.22)}
.panel .art{position:absolute;inset:0}
.panel canvas.sig{position:absolute;inset:0;width:100%;height:100%}
.panel .frameline{position:absolute;inset:14px;border:1px solid rgba(242,239,230,.10);border-radius:3px;pointer-events:none;z-index:3}
.panel .pmeta{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:24px clamp(20px,3vw,30px);
  background:linear-gradient(transparent,rgba(4,4,5,.78) 42%);display:flex;justify-content:space-between;align-items:flex-end;gap:18px}
.panel .pmeta .nm{font-family:var(--fx-display);font-weight:700;font-size:clamp(24px,3.4vw,42px);line-height:.95;letter-spacing:-.01em}
.panel .pmeta .tg{font-size:clamp(12px,1.3vw,15px);color:var(--bone-dim);margin-top:8px;max-width:30ch;line-height:1.4}
.panel .pmeta .idx{font-family:var(--fx-mono);font-size:11px;letter-spacing:.2em;color:var(--ash)}
.panel .corner{position:absolute;top:14px;left:14px;z-index:4;font-family:var(--fx-mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ash);display:flex;gap:10px;align-items:center}
.panel .corner .dotc{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:0;transition:opacity .6s}
.panel.focus .corner .dotc{opacity:1}
.panel .open-tag{position:absolute;top:14px;right:14px;z-index:5;font-family:var(--fx-mono);font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--void);background:var(--bone);padding:6px 11px;border-radius:999px;opacity:0;transform:translateY(-6px);
  transition:opacity .5s,transform .5s}
.panel.focus .open-tag{opacity:1;transform:none}

/* scrubber */
.scrub{position:absolute;left:0;right:0;bottom:0;z-index:6;padding:0 clamp(20px,5vw,68px) clamp(22px,4vh,34px);pointer-events:none}
.scrub .names{display:flex;gap:26px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  font-family:var(--fx-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash-dim);margin-bottom:14px}
.scrub .names b{color:var(--ash-dim);transition:color .4s;white-space:nowrap;font-weight:400}
.scrub .names b.on{color:var(--bone)}
.scrub .bar{height:1px;background:var(--hair);position:relative}
.scrub .bar i{position:absolute;top:-1px;height:3px;background:var(--bone);left:0;width:12%;transition:left .2s var(--ease),width .3s}

/* ---------- CASE OVERLAY ---------- */
.case{position:fixed;inset:0;z-index:8000;background:rgba(4,4,5,.86);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:clamp(18px,4vw,60px);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .55s var(--ease),visibility .55s}
.case.open{opacity:1;visibility:visible;pointer-events:auto}
.case .sheet{position:relative;width:min(1140px,100%);max-height:90vh;overflow:hidden;border:1px solid var(--hair);
  border-radius:8px;background:linear-gradient(150deg,#0e0e11,#070708);display:grid;grid-template-columns:1.1fr 1fr;
  transform:translateY(28px) scale(.97);transition:transform .6s var(--ease)}
.case.open .sheet{transform:none}
.case .visual{position:relative;min-height:420px;border-right:1px solid var(--hair);overflow:hidden}
.case .visual canvas{position:absolute;inset:0;width:100%;height:100%}
.case .body{padding:clamp(28px,4vw,52px);display:flex;flex-direction:column;justify-content:center;gap:22px}
.case .body .k{font-family:var(--fx-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ash)}
.case .body h3{font-family:var(--fx-display);font-weight:800;font-size:clamp(34px,5vw,66px);line-height:.92;letter-spacing:-.02em}
.case .body .tag{font-family:var(--fx-elegant);font-style:italic;font-size:clamp(17px,2vw,24px);color:var(--bone-dim)}
.case .body p{font-size:clamp(14px,1.4vw,16px);line-height:1.7;color:var(--bone-dim);max-width:42ch}
.case .body .enter{margin-top:8px;display:inline-flex;align-items:center;gap:14px;align-self:flex-start;
  font-family:var(--fx-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  background:var(--bone);color:var(--void);padding:15px 22px;border-radius:999px;transition:transform .3s,box-shadow .3s}
.case .body .enter:hover{transform:translateY(-3px)}
.case .nav{position:absolute;bottom:clamp(20px,3vw,34px);right:clamp(28px,4vw,52px);display:flex;gap:10px;z-index:3}
.case .nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--hair);background:transparent;color:var(--bone);
  font-size:16px;cursor:pointer;transition:.25s}
.case .nav button:hover{background:var(--bone);color:var(--void)}
.case .x{position:absolute;top:clamp(16px,2vw,24px);right:clamp(16px,2vw,24px);z-index:4;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--hair);background:rgba(0,0,0,.4);color:var(--bone);cursor:pointer;font-size:15px;transition:.25s}
.case .x:hover{background:var(--bone);color:var(--void);transform:rotate(90deg)}
@media(max-width:780px){.case .sheet{grid-template-columns:1fr;max-height:92vh;overflow-y:auto}
  .case .visual{min-height:280px;border-right:0;border-bottom:1px solid var(--hair)}}

/* ---------- LINK PICKER (multi-site projects) ---------- */
.picker{position:fixed;inset:0;z-index:8200;background:rgba(4,4,5,.86);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:clamp(18px,4vw,60px);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .5s var(--ease),visibility .5s}
.picker.open{opacity:1;visibility:visible;pointer-events:auto}
.picker-sheet{position:relative;width:min(1040px,100%);max-height:90vh;overflow-y:auto;
  border:1px solid var(--hair);border-radius:10px;background:linear-gradient(150deg,#0e0e11,#070708);
  padding:clamp(34px,5vw,64px);transform:translateY(26px) scale(.97);transition:transform .55s var(--ease)}
.picker.open .picker-sheet{transform:none}
.pk-head{text-align:center;margin-bottom:clamp(28px,4vw,46px)}
.pk-head .pk-k{font-family:var(--fx-mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--ash)}
.pk-head h3{font-family:var(--fx-display);font-weight:800;font-size:clamp(34px,5vw,60px);line-height:.94;letter-spacing:-.02em;margin:12px 0 14px}
.pk-head .pk-sub{font-family:var(--fx-elegant);font-style:italic;font-size:clamp(15px,1.8vw,21px);color:var(--bone-dim)}
.pk-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px)}
.pk-opt{position:relative;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--hair);border-radius:8px;
  background:linear-gradient(160deg,#101013,#08080a);
  transition:border-color .5s var(--ease),transform .5s var(--ease),box-shadow .5s var(--ease)}
.pk-opt:hover{transform:translateY(-5px);border-color:color-mix(in oklab,var(--ac,var(--bone)),transparent 35%);
  box-shadow:0 26px 64px -30px var(--ac,#000)}
.pk-art{position:relative;height:clamp(150px,20vw,212px);border-bottom:1px solid var(--hair);overflow:hidden}
.pk-art::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(82% 82% at 50% 38%,transparent,rgba(4,4,5,.55))}
.pk-art canvas{position:absolute;inset:0;width:100%;height:100%}
.pk-meta{padding:clamp(20px,2.4vw,30px);display:flex;flex-direction:column;gap:10px;flex:1}
.pk-ok{font-family:var(--fx-mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ac,var(--ash))}
.pk-on{font-family:var(--fx-display);font-weight:700;font-size:clamp(21px,2.4vw,28px);line-height:1;letter-spacing:-.01em}
.pk-od{font-size:clamp(13px,1.3vw,15px);line-height:1.55;color:var(--bone-dim);max-width:34ch}
.pk-enter{margin-top:auto;padding-top:6px;display:inline-flex;align-items:center;gap:9px;font-family:var(--fx-mono);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash);transition:color .3s}
.pk-enter em{font-style:normal;transition:transform .3s var(--ease)}
.pk-opt:hover .pk-enter{color:var(--bone)}
.pk-opt:hover .pk-enter em{transform:translate(3px,-3px)}
.picker .px{position:absolute;top:clamp(14px,2vw,22px);right:clamp(14px,2vw,22px);z-index:4;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--hair);background:rgba(0,0,0,.4);color:var(--bone);cursor:pointer;font-size:15px;transition:.25s}
.picker .px:hover{background:var(--bone);color:var(--void);transform:rotate(90deg)}
@media(max-width:720px){.pk-grid{grid-template-columns:1fr}}

/* ---------- PROCESS / WHY ---------- */
.why{position:relative;padding:clamp(120px,20vh,240px) 0}
.why .wrap{max-width:1280px;margin:0 auto}
.why .lead{font-family:var(--fx-display);font-weight:700;font-size:clamp(28px,4.6vw,68px);line-height:1.02;letter-spacing:-.02em;
  max-width:20ch;margin-bottom:clamp(56px,9vw,120px)}
.why .lead em{font-family:var(--fx-elegant);font-style:italic;font-weight:400}
.tenets{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair-2);border:1px solid var(--hair-2)}
.tenet{background:var(--void);padding:clamp(26px,3vw,40px);min-height:230px;display:flex;flex-direction:column;
  justify-content:space-between;transition:background .5s}
.tenet:hover{background:var(--void-2)}
.tenet .n{font-family:var(--fx-mono);font-size:11px;letter-spacing:.2em;color:var(--ash)}
.tenet h4{font-family:var(--fx-display);font-weight:700;font-size:clamp(20px,2.2vw,28px);letter-spacing:-.01em;margin-top:auto}
.tenet p{font-size:14px;line-height:1.6;color:var(--ash);margin-top:12px}
@media(max-width:820px){.tenets{grid-template-columns:1fr}}

/* ---------- CTA ---------- */
.cta{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;border-top:1px solid var(--hair-2)}
.cta #portal{position:absolute;inset:0;z-index:0}
.cta .inner{position:relative;z-index:2;padding:0 24px}
.cta .eyebrow{margin-bottom:30px}
.cta h2{font-family:var(--fx-display);font-weight:800;font-size:clamp(44px,10vw,150px);line-height:.9;letter-spacing:-.03em}
.cta h2 em{font-family:var(--fx-elegant);font-style:italic;font-weight:400}
.cta .mail{display:inline-flex;align-items:center;gap:16px;margin-top:clamp(34px,5vw,54px);
  font-family:var(--fx-mono);font-size:clamp(13px,1.4vw,16px);letter-spacing:.1em;
  border:1px solid var(--hair);border-radius:999px;padding:18px 30px;transition:.35s}
.cta .mail:hover{background:var(--bone);color:var(--void);border-color:var(--bone)}
.cta .mail .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
footer.foot{position:relative;z-index:2;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding:26px clamp(20px,5vw,68px);font-family:var(--fx-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ash-dim);border-top:1px solid var(--hair-2)}

@media(max-width:640px){
  .panel{width:78vw}
  .hero .sub .r{display:none}
}
