/* ═══════════════════════════════════════
   THEME TOKENS
═══════════════════════════════════════ */
:root {
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-in: cubic-bezier(.55,0,1,.45);
  --trans: background .45s var(--ease), color .45s var(--ease),
           border-color .45s var(--ease), box-shadow .45s var(--ease);
}
[data-theme="dark"] {
  --bg:       #07070c;
  --bg2:      #0c0b14;
  --surface:  rgba(255,255,255,.03);
  --text:     #ece7de;
  --muted:    #6b6456;
  --accent:   #cac5aa;
  --accent-lt:#e2ddc8;
  --accent-dk:#7a7562;
  --brd:      rgba(202,197,170,.1);
  --brd2:     rgba(202,197,170,.24);
  --glow-sm:  rgba(202,197,170,.13);
  --glow-md:  rgba(202,197,170,.26);
  --glow-lg:  rgba(202,197,170,.42);
  --nav-bg:   rgba(7,7,12,.65);
  --nav-bg2:  rgba(7,7,12,.94);
  --canvas-op:.45;
  color-scheme: dark;
}

/* ═══════════════════════════════════════
   RESET
═══════════════════════════════════════ */
*,*::before,*::after { margin:0;padding:0;box-sizing:border-box }
html { scroll-behavior:smooth;-webkit-text-size-adjust:100% }
body {
  background:var(--bg);color:var(--text);
  font-family:'Space Grotesk',sans-serif;
  font-weight:400;line-height:1.65;
  overflow-x:hidden;cursor:none;
  transition:var(--trans);
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{background:none;border:none;cursor:none;font-family:inherit}
@media(hover:none){body,a,button{cursor:auto}}

/* ═══════════════════════════════════════
   CURSOR
═══════════════════════════════════════ */
#cur-dot,#cur-ring {
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);border-radius:50%;
}
#cur-dot { width:7px;height:7px;background:var(--accent);box-shadow:0 0 14px var(--glow-md);transition:background .4s }
#cur-ring {
  width:38px;height:38px;border:1px solid rgba(202,197,170,.4);
  transition:width .35s var(--ease),height .35s var(--ease),border-color .35s,background .35s;
}
#cur-ring.h { width:56px;height:56px;border-color:rgba(202,197,170,.7);background:rgba(202,197,170,.04) }
@media(hover:none){#cur-dot,#cur-ring{display:none}body{cursor:auto}a,button{cursor:pointer}}

/* ═══════════════════════════════════════
   CANVAS
═══════════════════════════════════════ */
#cv { position:fixed;inset:0;pointer-events:none;z-index:0;opacity:var(--canvas-op);transition:opacity .45s }
@media(max-width:767px){ #cv { display:none!important } }

/* ═══════════════════════════════════════
   MOBILE ATMOSPHERE ORBS (index only)
═══════════════════════════════════════ */
.m-atm { display:none;position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden }
@media(max-width:767px){ .m-atm { display:block } }
.m-orb { position:absolute;border-radius:50%;filter:blur(72px);background:radial-gradient(circle,rgba(202,197,170,.32) 0%,transparent 70%);will-change:transform }
.m-orb1 { width:320px;height:320px;top:-100px;left:-100px;animation:morb1 13s ease-in-out infinite }
.m-orb2 { width:260px;height:260px;bottom:25%;right:-80px;animation:morb2 17s ease-in-out infinite 4s }
.m-orb3 { width:200px;height:200px;top:45%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(202,197,170,.18) 0%,transparent 70%);animation:morb3 11s ease-in-out infinite 8s }
@keyframes morb1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(50px,70px) scale(1.15)}66%{transform:translate(-30px,90px) scale(.88)}}
@keyframes morb2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-70px,-50px) scale(1.3)}}
@keyframes morb3{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.6);opacity:1}}

/* ═══════════════════════════════════════
   SCROLL PROGRESS BAR
═══════════════════════════════════════ */
.scroll-prog {
  position:fixed;top:0;left:0;width:0%;height:2px;z-index:9999;
  background:linear-gradient(to right,var(--accent-dk),var(--accent),var(--accent-lt));
  pointer-events:none;transition:width .08s linear;box-shadow:0 0 10px var(--glow-sm);
}

/* ═══════════════════════════════════════
   FLOATING ACTION BAR — mobile
═══════════════════════════════════════ */
.mob-fab {
  display:none;position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  z-index:850;background:var(--nav-bg2);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--brd2);border-radius:100px;
  padding:6px 6px 6px 16px;gap:8px;align-items:center;
  box-shadow:0 8px 32px rgba(0,0,0,.45),0 0 0 1px rgba(202,197,170,.08);
  transition:transform .4s var(--ease),opacity .4s,bottom .4s;white-space:nowrap;
}
.mob-fab.hidden-fab { transform:translateX(-50%) translateY(100px);opacity:0 }
@media(max-width:899px){ .mob-fab{display:flex} }
.mob-fab-label { font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--muted) }
.mob-fab-cta {
  display:inline-flex;align-items:center;gap:7px;
  background:var(--accent);color:var(--bg);
  padding:10px 18px;border-radius:100px;
  font-size:12.5px;font-weight:600;letter-spacing:.03em;
  transition:background .3s,box-shadow .3s;
}
.mob-fab-cta:hover { background:var(--accent-lt);box-shadow:0 0 20px var(--glow-md) }
.mob-fab-wa {
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.28);color:#25d366;
  transition:background .3s,box-shadow .3s;
}
.mob-fab-wa:hover { background:rgba(37,211,102,.18);box-shadow:0 0 16px rgba(37,211,102,.3) }
@media(hover:none){ .mob-fab-cta,.mob-fab-wa{cursor:pointer} }
@media(max-width:899px){ footer { padding-bottom:80px } }

/* ═══════════════════════════════════════
   TOUCH RIPPLE
═══════════════════════════════════════ */
.ripple-ring {
  position:absolute;border-radius:50%;background:rgba(202,197,170,.14);
  width:10px;height:10px;transform:scale(0);pointer-events:none;
  animation:ripple-out .65s ease-out forwards;
}
@keyframes ripple-out{to{transform:scale(35);opacity:0}}
@media(hover:none){ .svc-item:active{background:rgba(202,197,170,.04)} }

/* ═══════════════════════════════════════
   MOBILE SWIPE HINT
═══════════════════════════════════════ */
@media(max-width:767px){
  .work-scroll-wrap { position:relative }
  .swipe-hint {
    display:flex;align-items:center;gap:5px;justify-content:center;
    padding:10px 0 0;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
    color:var(--muted);opacity:.6;animation:swipe-fade 3s ease 1.5s forwards;
  }
  .swipe-hint svg { animation:swipe-move 1.5s ease-in-out infinite }
  @keyframes swipe-move{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}
  @keyframes swipe-fade{0%{opacity:.6}100%{opacity:0;pointer-events:none}}
}
@media(min-width:768px){ .swipe-hint{display:none!important} }

/* ═══════════════════════════════════════
   MOBILE MENU
═══════════════════════════════════════ */
.mob-menu {
  position:fixed;inset:0;z-index:800;background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;
  padding:80px 36px 60px;transform:translateX(100%);
  transition:transform .55s var(--ease),background .45s;overflow:hidden;
}
.mob-menu.open { transform:translateX(0) }
.mob-menu::before {
  content:'';position:absolute;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,var(--glow-sm) 0%,transparent 70%);
  top:-80px;right:-80px;pointer-events:none;
}
.mob-links { display:flex;flex-direction:column;gap:4px;margin-bottom:48px }
.mob-links a,.mob-links li a {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,12vw,58px);font-weight:600;line-height:1.15;
  color:var(--text);letter-spacing:-.02em;
  transition:color .3s,transform .3s var(--ease);display:inline-block;
}
.mob-links a:hover,.mob-links li a:hover,.mob-links a.active { color:var(--accent);transform:translateX(8px) }
.mob-bot { display:flex;flex-direction:column;gap:10px }
.mob-cl { font-size:13px;color:var(--accent);display:flex;align-items:center;gap:8px;transition:color .3s;opacity:.7 }
.mob-cl:hover { color:var(--accent);opacity:1 }
.mob-wa {
  display:inline-flex;align-items:center;gap:10px;margin-top:20px;padding:13px 22px;
  border-radius:100px;background:rgba(37,211,102,.06);border:1px solid rgba(37,211,102,.25);
  color:#25d366;font-size:13.5px;font-weight:500;width:fit-content;
  transition:background .3s,box-shadow .3s;
}
.mob-wa:hover { background:rgba(37,211,102,.12);box-shadow:0 0 20px rgba(37,211,102,.15) }

/* ═══════════════════════════════════════
   NAV
═══════════════════════════════════════ */
#nav {
  position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:900;
  display:flex;align-items:center;padding:8px 8px 8px 14px;
  background:var(--nav-bg);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border:1px solid var(--brd);border-radius:100px;gap:4px;
  transition:background .4s,border-color .4s,box-shadow .4s;max-width:calc(100vw - 28px);
}
#nav.on { background:var(--nav-bg2);border-color:var(--brd2);box-shadow:0 6px 36px rgba(0,0,0,.25) }
.n-logo { display:flex;align-items:center;gap:10px;text-decoration:none;cursor:none;margin-right:6px;flex-shrink:0 }
.n-mark{
  width:24px;
  height:24px;
  border-radius:50%;
  overflow:hidden;
  flex-shrink:0;
  box-shadow:0 0 18px rgba(202,197,170,.12);
}
.n-mark svg{width:100%;height:100%;display:block}
.n-brand {
  font-family:'Playfair Display',serif;
  font-size:16px;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--accent);
  text-transform:none;
  transition:color .3s,text-shadow .3s;
}
.n-logo:hover .n-brand { color:var(--text);text-shadow:0 0 18px rgba(202,197,170,.14) }
.n-links,.n-links ul { display:none;align-items:center;gap:2px }
@media(min-width:768px){ .n-links,.n-links ul{display:flex} }
.n-links a,.n-links ul a {
  font-size:12.5px;font-weight:500;letter-spacing:.04em;color:var(--muted);
  padding:6px 12px;border-radius:100px;cursor:none;white-space:nowrap;
  transition:color .2s,background .2s;
}
.n-links a:hover,.n-links ul a:hover,.n-links a.active,.n-links ul a.active { color:var(--text);background:var(--surface) }
.n-links a.active,.n-links ul a.active { color:var(--accent) }
.n-right { display:flex;align-items:center;gap:6px;margin-left:auto }
.n-wa {
  width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(37,211,102,.22);color:#25d366;background:rgba(37,211,102,.06);
  cursor:none;flex-shrink:0;transition:background .3s,box-shadow .3s,border-color .3s;
}
.n-wa:hover { background:rgba(37,211,102,.14);box-shadow:0 0 16px rgba(37,211,102,.25);border-color:rgba(37,211,102,.45) }
.n-cta {
  display:none;font-size:12.5px;font-weight:600;letter-spacing:.04em;
  background:var(--accent);color:var(--bg);padding:8px 18px;border-radius:100px;
  cursor:none;white-space:nowrap;transition:box-shadow .3s,background .3s,color .3s;
}
.n-cta:hover { background:var(--accent-lt);box-shadow:0 0 22px var(--glow-md) }
@media(min-width:660px){ .n-cta{display:inline-flex;align-items:center;gap:6px} }
.n-burger {
  width:36px;height:36px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:5px;
  border-radius:10px;border:1px solid var(--brd);cursor:none;flex-shrink:0;
  transition:border-color .3s,background .3s;
}
.n-burger:hover { background:var(--surface);border-color:var(--brd2) }
.n-burger span {
  display:block;width:16px;height:1.5px;background:var(--muted);border-radius:2px;
  transition:transform .4s var(--ease),opacity .3s,background .3s,width .3s;
}
.n-burger.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg);background:var(--accent);width:18px }
.n-burger.open span:nth-child(2){ opacity:0;transform:scaleX(0) }
.n-burger.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg);background:var(--accent);width:18px }
@media(min-width:900px){ .n-burger{display:none} }

/* ═══════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════ */
.r { opacity:0;transform:translateY(30px);transition:opacity .85s var(--ease),transform .85s var(--ease) }
.r.in { opacity:1;transform:translateY(0) }
.r.d1{transition-delay:.1s}.r.d2{transition-delay:.2s}.r.d3{transition-delay:.3s}
.r.d4{transition-delay:.42s}.r.d5{transition-delay:.55s}

/* ═══════════════════════════════════════
   SHARED ATOMS
═══════════════════════════════════════ */
.eyebrow {
  display:inline-flex;align-items:center;gap:10px;
  font-size:10.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:12px;transition:color .45s;
}
.eyebrow::before{ content:'';width:18px;height:1px;background:var(--accent) }

.h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(34px,5vw,58px);font-weight:600;line-height:1.06;letter-spacing:-.022em;
  transition:color .45s;
}
.h2 em { font-style:italic;color:var(--accent) }

.btn {
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:13px;font-weight:600;letter-spacing:.05em;
  padding:13px 24px;border-radius:100px;border:none;cursor:none;
  transition:transform .25s var(--ease),box-shadow .3s,background .35s,color .35s;
}
.btn:hover { transform:translateY(-2px) }
.btn svg { transition:transform .35s var(--ease) }
.btn:hover svg { transform:translateX(4px) }
.btn-fill { background:var(--accent);color:var(--bg) }
.btn-fill:hover { background:var(--accent-lt);box-shadow:0 0 28px var(--glow-md) }
.btn-ghost { background:transparent;color:var(--muted);border:1px solid var(--brd) }
.btn-ghost:hover { color:var(--text);border-color:var(--brd2) }
@media(hover:none){ .btn{cursor:pointer} }

/* ═══════════════════════════════════════
   FOOTER (shared)
═══════════════════════════════════════ */
footer {
  position:relative;z-index:1;border-top:1px solid var(--brd);padding:24px;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  transition:border-color .45s,background .45s;
}
.f-logo{display:flex;align-items:center;gap:10px;cursor:none}
.f-icon{width:28px;height:28px;border-radius:7px;overflow:hidden;flex-shrink:0}
.f-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;color:var(--accent);letter-spacing:.02em;text-shadow:0 0 18px var(--glow-sm);transition:color .45s,text-shadow .45s}
.f-copy{font-size:11px;color:var(--muted);transition:color .45s}
.ft-brand{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:700;color:var(--accent);letter-spacing:.05em;transition:color .45s}
.ft-copy{font-size:11.5px;color:var(--muted);transition:color .45s}
.socials{display:flex;gap:8px}
.socials a{width:36px;height:36px;border-radius:8px;border:1px solid var(--brd);display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:none;transition:color .3s,border-color .3s,box-shadow .3s}
.socials a:hover{color:var(--accent);border-color:var(--accent-dk);box-shadow:0 0 12px var(--glow-sm)}
@media(min-width:600px){footer{flex-direction:row;justify-content:space-between;padding:24px clamp(24px,6vw,100px);max-width:1280px;margin-inline:auto;text-align:left}}

/* ═══════════════════════════════════════
   CTA STRIP (work + project pages)
═══════════════════════════════════════ */
.cta-strip {
  position:relative;z-index:1;padding:80px 24px 100px;text-align:center;
  border-top:1px solid var(--brd);transition:border-color .45s;
}
.cta-strip .h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,5vw,52px);font-weight:600;line-height:1.08;letter-spacing:-.022em;
  margin-bottom:28px;transition:color .45s;
}
.cta-strip .h2 em { font-style:italic;color:var(--accent);transition:color .45s }

/* ═══════════════════════════════════════
   ── INDEX PAGE ──
═══════════════════════════════════════ */

/* HERO */
.hero {
  position:relative;z-index:1;min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px 20px 64px;overflow:hidden;
}
.h-glow { position:absolute;pointer-events:none;border-radius:50%;filter:blur(90px);transition:background .45s }
.h-glow-a { width:480px;height:480px;background:radial-gradient(circle,var(--glow-md) 0%,transparent 65%);top:-120px;left:50%;transform:translateX(-50%);animation:breathe 9s ease-in-out infinite }
.h-glow-b { width:300px;height:300px;background:radial-gradient(circle,var(--glow-sm) 0%,transparent 65%);bottom:40px;right:-60px;animation:breathe2 11s ease-in-out infinite 3s }
@keyframes breathe{0%,100%{transform:translateX(-50%) scale(1);opacity:.7}50%{transform:translateX(-50%) scale(1.4);opacity:1}}
@keyframes breathe2{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.4);opacity:1}}
.h-geo { position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);width:min(80vw,400px);height:min(80vw,400px);pointer-events:none;opacity:.48;transition:opacity .45s }
.geo-s{animation:spin 45s linear infinite}
.geo-r{animation:spin 28s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.h-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.h-badge{display:inline-flex;align-items:center;gap:9px;font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:22px;opacity:0;transform:translateY(16px);animation:fadeUp .7s var(--ease) .2s forwards;transition:color .45s}
.h-badge-line{width:20px;height:1px;background:var(--accent);transition:background .45s}
.h-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 2.2s ease-in-out infinite;transition:background .45s}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.h1{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.0;letter-spacing:-.025em;font-size:clamp(52px,14vw,86px);margin-bottom:22px;opacity:0;transform:translateY(28px);animation:fadeUp 1s var(--ease) .4s forwards;transition:color .45s}
.h1 .l-sm{display:block;font-size:.72em;font-weight:300;font-style:normal;color:var(--text);opacity:.9}
.h1 .l-accent{display:block;font-style:italic;color:var(--accent);text-shadow:0 0 60px var(--glow-md),0 0 120px var(--glow-sm);transition:color .45s,text-shadow .45s}
.h-sub{font-size:clamp(14px,3.5vw,16px);color:var(--muted);line-height:1.85;max-width:420px;margin-bottom:36px;opacity:0;transform:translateY(18px);animation:fadeUp .8s var(--ease) .7s forwards;transition:color .45s}
.h-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(14px);animation:fadeUp .7s var(--ease) .92s forwards}
.h-ftag{display:none;position:absolute;background:var(--nav-bg2);border:1px solid var(--brd);border-radius:10px;padding:9px 14px;font-size:11.5px;font-weight:500;color:var(--muted);backdrop-filter:blur(12px);white-space:nowrap;transition:background .45s,border-color .45s,color .45s}
.h-ftag span{color:var(--accent);margin-right:5px;transition:color .45s}
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:0;animation:fadeUp .6s var(--ease) 1.3s forwards}
.scroll-line{width:1px;height:38px;background:linear-gradient(to bottom,var(--accent),transparent);animation:linefall 2.2s ease-in-out infinite;transition:background .45s}
@keyframes linefall{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(1);transform-origin:bottom;opacity:0}}
@media(min-width:1024px){
  .hero{display:grid;grid-template-columns:1fr 1fr;text-align:left;align-items:center;padding:0 max(clamp(40px,6vw,100px),(100vw - 1280px)/2);gap:0}
  .h-content{align-items:flex-start}
  .h-actions{justify-content:flex-start}
  .h-sub{max-width:460px}
  .h-geo{position:relative;top:auto;left:auto;transform:none;opacity:1;width:clamp(280px,36vw,500px);height:clamp(280px,36vw,500px);grid-column:2;grid-row:1;align-self:center;justify-self:center}
  .h-glow-a{left:-80px;top:-100px;transform:none}
  @keyframes breathe{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.4);opacity:1}}
  .h-ftag{display:block}
  .ftag-1{top:4%;right:-10px;animation:float 6s ease-in-out infinite}
  .ftag-2{bottom:16%;left:-30px;animation:float 8s ease-in-out infinite reverse}
  .ftag-3{top:44%;right:-40px;animation:float 5.5s ease-in-out infinite 2s}
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
}
@media(max-width:767px){
  .h1 .l-accent{animation:fadeUp 1s var(--ease) .4s forwards,aurore 4s ease-in-out 1.4s infinite alternate}
  @keyframes aurore{from{text-shadow:0 0 40px rgba(202,197,170,.35),0 0 80px rgba(202,197,170,.18)}to{text-shadow:0 0 70px rgba(202,197,170,.6),0 0 140px rgba(202,197,170,.32)}}
  .hero{padding:88px 20px 56px}
  .h-geo{opacity:.55}
  .scroll-cue{bottom:18px;font-size:9px}
  .stat-n{font-size:38px}
  .w-card{flex:0 0 86vw;max-width:340px;height:270px}
  .cf-row{grid-template-columns:1fr}
}

/* TICKER */
.ticker{position:relative;z-index:1;border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);padding:16px 0;overflow:hidden;transition:border-color .45s}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;width:80px;height:100%;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.ticker-track{display:flex;width:max-content;animation:tick 30s linear infinite}
@keyframes tick{to{transform:translateX(-50%)}}
.t-item{display:flex;align-items:center;gap:18px;padding:0 30px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap;transition:color .45s}
.t-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);flex-shrink:0;transition:background .45s,box-shadow .45s}

/* SERVICES */
.svc{position:relative;z-index:1;padding:80px 24px;transition:background .45s}
.svc-hd{margin-bottom:32px}
.svc-note{margin-top:10px;font-size:14px;color:color-mix(in srgb,var(--text) 62%, transparent);line-height:1.75;max-width:340px;transition:color .45s}
.svc-list{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  transition:border-color .45s;
}
.svc-item{
  position:relative;
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  padding:16px;
  min-height:212px;
  border:1px solid var(--brd);
  border-radius:18px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015)),
    radial-gradient(circle at top right,rgba(202,197,170,.12),transparent 44%),
    var(--bg2);
  cursor:none;
  overflow:hidden;
  isolation:isolate;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s,background .35s;
}
.svc-item::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(145deg,rgba(202,197,170,.09),transparent 45%,rgba(202,197,170,.05) 100%);
  opacity:.38;
  transition:opacity .35s;
  z-index:-1;
}
.svc-item:hover,
.svc-item:focus-visible{
  transform:translateY(-4px);
  border-color:var(--brd2);
  box-shadow:0 16px 44px rgba(0,0,0,.26),0 0 0 1px rgba(202,197,170,.08);
}
.svc-item:hover::before,
.svc-item:focus-visible::before{opacity:.8}
.svc-item:focus-visible{outline:none}
.svc-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.svc-num{
  font-size:10px;
  font-weight:700;
  color:var(--accent-dk);
  letter-spacing:.16em;
  transition:color .45s;
}
.svc-kicker{
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  opacity:.9;
}
.svc-icon{
  width:48px;
  height:48px;
  border:1px solid var(--brd2);
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--accent-lt);
  background:rgba(202,197,170,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .35s var(--ease),color .3s,border-color .3s,background .3s,box-shadow .3s;
}
.svc-item:hover .svc-icon,
.svc-item:focus-visible .svc-icon{
  transform:translateY(-2px) scale(1.03);
  color:var(--accent);
  border-color:rgba(202,197,170,.38);
  background:rgba(202,197,170,.12);
  box-shadow:0 10px 22px rgba(0,0,0,.18);
}
.svc-text h3{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(22px,5vw,28px);
  font-weight:600;
  line-height:1.05;
  color:var(--text);
  transition:color .3s;
}
.svc-item:hover .svc-text h3,
.svc-item:focus-visible .svc-text h3{color:var(--accent-lt)}
.svc-text p{
  margin-top:7px;
  font-size:13px;
  color:color-mix(in srgb,var(--text) 72%, transparent);
  line-height:1.65;
}
.svc-points{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:auto;
}
.svc-points span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(202,197,170,.12);
  background:rgba(255,255,255,.03);
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.05em;
  color:color-mix(in srgb,var(--text) 72%, transparent);
}
.svc-arr{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:2px;
  padding-top:10px;
  border-top:1px solid rgba(202,197,170,.08);
  color:var(--muted);
  transition:color .3s,transform .35s var(--ease),border-color .35s;
  white-space:nowrap;
}
.svc-item:hover .svc-arr,
.svc-item:focus-visible .svc-arr{
  color:var(--accent);
  border-color:rgba(202,197,170,.18);
}
.svc-quote-hint{
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:inherit;
}
@media(min-width:380px){
  .svc-list{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(min-width:768px){
  .svc{padding:110px clamp(32px,6vw,100px);max-width:1280px;margin-inline:auto}
  .svc-list{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
  .svc-item{flex:1 1 calc(33.333% - 24px); min-width:300px; padding:24px;min-height:240px; border-radius: 20px;}
  .svc-hd{display:flex;justify-content:space-between;align-items:flex-end}
  .svc-note{margin-top:0;text-align:right}
}

/* WORK CAROUSEL (index) */
.work{position:relative;z-index:1;background:var(--bg2);padding:80px 0;overflow:hidden;transition:background .45s}
.work::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,var(--glow-sm) 0%,transparent 70%);top:-120px;right:-80px;pointer-events:none}
.work-hd{padding:0 24px;margin-bottom:36px;display:flex;justify-content:space-between;align-items:flex-end}
.see-all{font-size:12.5px;font-weight:500;color:var(--accent);letter-spacing:.06em;display:flex;align-items:center;gap:6px;cursor:none;transition:gap .3s,color .45s}
.see-all:hover{gap:12px}
.work-scroll{display:flex;gap:12px;padding:0 24px 20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.work-scroll::-webkit-scrollbar{display:none}
.w-card{flex:0 0 82vw;max-width:300px;height:260px;position:relative;overflow:hidden;border:1px solid var(--brd);border-radius:14px;cursor:none;scroll-snap-align:start;transition:border-color .4s,box-shadow .4s}
.w-card:hover{border-color:var(--brd2);box-shadow:0 0 40px rgba(0,0,0,.35)}
.w-bg{position:absolute;inset:0;transition:transform .7s var(--ease)}
.w-card:hover .w-bg{transform:scale(1.05)}
.w-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s var(--ease),transform .7s var(--ease);z-index:1}
.w-card:hover .w-img{transform:scale(1.05)}
.wbg-1{background:#0e0b05}.wbg-1::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 40%,rgba(200,120,20,.2) 0%,transparent 60%)}
.wbg-2{background:#090810}.wbg-2::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(80,60,180,.18) 0%,transparent 55%)}
.wbg-3{background:#09080c}.wbg-3::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(140,80,180,.18) 0%,transparent 55%)}
.wbg-7{background:#080a0d}.wbg-7::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 45% 55%,rgba(40,80,140,.2) 0%,transparent 55%)}
.w-deco{position:absolute;font-family:'Cormorant Garamond',serif;font-size:clamp(80px,18vw,130px);font-weight:700;line-height:1;letter-spacing:-.06em;color:rgba(202,197,170,.055);pointer-events:none;white-space:nowrap;bottom:-8px;right:-6px;user-select:none}
.w-info{position:absolute;bottom:0;left:0;right:0;padding:20px 22px;background:linear-gradient(to top,rgba(7,7,12,.92) 0%,transparent 100%);z-index:2}
.w-tag{font-size:9.5px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;transition:color .45s}
.w-title{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,4vw,22px);font-weight:600;line-height:1.2;color:var(--text);transition:color .3s}
.w-card:hover .w-title{color:var(--accent-lt)}
.w-line{width:0;height:1px;background:var(--accent);margin-top:9px;transition:width .45s var(--ease),background .45s}
.w-card:hover .w-line{width:32px}
.w-num{position:absolute;top:16px;right:18px;font-size:10px;color:var(--muted);letter-spacing:.1em;opacity:.5}
.w-dots{display:flex;gap:6px;justify-content:center;padding:16px 24px 0}
.w-dot{width:5px;height:5px;border-radius:50%;background:var(--muted);opacity:.3;transition:opacity .3s,background .3s}
.w-dot.on{opacity:1;background:var(--accent)}
@media(min-width:768px){
  .work{padding:120px 0}
  .work-hd{padding:0 clamp(32px,6vw,100px);max-width:1280px;margin-inline:auto;margin-bottom:56px;}
  .work-scroll{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:24px;padding:0 clamp(32px,6vw,100px);overflow:visible;max-width:1280px;margin-inline:auto}
  .w-card{flex:none;max-width:none;height:auto;aspect-ratio:4/3;border-radius:18px;scroll-snap-align:none}
  .w-dots{display:none}
}

/* ABOUT */
.about{position:relative;z-index:1;padding:80px 24px;transition:background .45s}
.about-grid{display:flex;flex-direction:column;gap:52px}
.about-quote{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,6vw,54px);font-weight:400;font-style:italic;line-height:1.2;color:var(--text);margin-bottom:24px;transition:color .45s}
.about-quote em{font-style:normal;font-weight:600;color:var(--accent);transition:color .45s}
.about-body{font-size:16px;color:var(--muted);line-height:1.8;margin-bottom:40px;transition:color .45s}
.about-portrait{width:160px;height:160px;border-radius:50%;overflow:hidden;border:2px solid var(--brd);margin-bottom:32px;background:var(--bg2);transition:border-color .45s}
.about-portrait img{width:100%;height:100%;object-fit:cover}
.stats{display:flex;gap:36px;flex-wrap:wrap}
.stat{display:flex;flex-direction:column;gap:3px}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:700;color:var(--accent);line-height:1;text-shadow:0 0 30px var(--glow-md);transition:color .45s,text-shadow .45s}
.stat-l{font-size:11.5px;color:var(--muted);letter-spacing:.03em;transition:color .45s}
.about-card{padding:20px 22px;border:1px solid var(--brd);border-radius:12px;background:var(--surface);transition:border-color .45s,background .45s}
.about-card p{font-size:13.5px;color:var(--muted);line-height:1.8;font-style:italic;transition:color .45s}
.process-label{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;transition:color .45s}
.process-list{display:flex;flex-direction:column;gap:0}
.process-step{display:flex;gap:18px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--brd);transition:border-color .45s}
.process-step:first-child{border-top:1px solid var(--brd)}
.ps-num{font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:600;letter-spacing:.1em;color:var(--accent-dk);flex-shrink:0;padding-top:2px;transition:color .45s}
.ps-title{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;line-height:1.2;color:var(--text);margin-bottom:5px;transition:color .45s}
.ps-desc{font-size:12.5px;color:var(--muted);line-height:1.65;transition:color .45s}
@media(min-width:860px){
  .about{padding:110px clamp(32px,6vw,100px);max-width:1280px;margin-inline:auto}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,80px);align-items:start}
}

/* CTA SECTION (index) */
.cta{position:relative;z-index:1;background:var(--bg2);padding:80px 24px;text-align:center;overflow:hidden;transition:background .45s}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--glow-sm) 0%,transparent 60%);pointer-events:none;animation:breathe2 7s ease-in-out infinite}
.cta-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,11vw,84px);font-weight:600;line-height:1.0;letter-spacing:-.025em;margin-bottom:20px;transition:color .45s}
.cta-h2 em{font-style:italic;color:var(--accent);text-shadow:0 0 60px var(--glow-md),0 0 120px var(--glow-sm);transition:color .45s,text-shadow .45s}
.cta-body{font-size:15px;color:var(--muted);max-width:400px;margin:0 auto 40px;line-height:1.8;transition:color .45s}
.cta-contacts{margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:14px}
.c-link{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px;cursor:none;transition:color .3s}
.c-link:hover{color:var(--accent)}
@media(min-width:600px){.cta{padding:110px 40px}.cta-contacts{flex-direction:row;justify-content:center;gap:36px}}

/* CONTACT FORM */
.cf-section{position:relative;z-index:1;background:var(--bg2);padding:80px 24px;transition:background .45s}
.cf-inner{max-width:1000px;margin-inline:auto;display:grid;grid-template-columns:1fr;gap:52px}
@media(min-width:860px){
  .cf-section{padding:120px clamp(32px,6vw,100px)}
  .cf-inner{grid-template-columns:1fr 1fr;gap:64px;align-items:center}
}
.cf-tagline{font-size:15px;color:var(--muted);line-height:1.85;margin:16px 0 32px;transition:color .45s}
.cf-ctcts{display:flex;flex-direction:column;gap:12px}
.cf-form{display:flex;flex-direction:column;gap:18px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.cf-row{grid-template-columns:1fr}}
.cf-field{display:flex;flex-direction:column;gap:7px}
.cf-label{font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:color .45s}
.cf-input{background:var(--surface);border:1px solid var(--brd);border-radius:10px;padding:13px 16px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:14px;outline:none;resize:none;appearance:none;transition:border-color .3s,box-shadow .3s,background .45s,color .45s}
.cf-input::placeholder{color:var(--muted)}
.cf-input:focus{border-color:var(--accent-dk);box-shadow:0 0 0 3px var(--glow-sm)}
.cf-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6456' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}
.cf-submit{width:100%;justify-content:center;margin-top:4px}
.cf-success{display:none;text-align:center;padding:20px;border-radius:10px;border:1px solid rgba(37,211,102,.25);background:rgba(37,211,102,.05);color:#25d366;font-size:13.5px;line-height:1.75}
.cf-success.show{display:block}
@keyframes prefill-glow{0%{box-shadow:0 0 0 0 rgba(202,197,170,.5)}60%{box-shadow:0 0 0 8px rgba(202,197,170,0)}100%{box-shadow:0 0 0 3px var(--glow-sm)}}
.cf-input.prefilled{border-color:var(--accent-dk);animation:prefill-glow .75s ease forwards}
.cf-prefill-note{display:none;align-items:center;gap:12px;padding:12px 16px;background:rgba(202,197,170,.06);border:1px solid var(--brd2);border-radius:10px;font-size:13px;color:var(--muted);transition:background .3s}
.cf-prefill-note.show{display:flex}
.cf-prefill-note strong{color:var(--accent-lt);font-weight:600}
.cf-prefill-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--accent);box-shadow:0 0 8px var(--glow-md);animation:blink 2s ease-in-out infinite}
.cf-prefill-clear{margin-left:auto;padding:3px 7px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:none;border:1px solid var(--brd);cursor:none;transition:color .2s,border-color .2s}
.cf-prefill-clear:hover{color:var(--text);border-color:var(--brd2)}
@media(hover:none){.cf-prefill-clear{cursor:pointer}}

/* ═══════════════════════════════════════
   ── WORK PAGE ──
═══════════════════════════════════════ */
.page-hero{position:relative;z-index:1;padding:120px 24px 48px;max-width:860px;margin:0 auto}
.ph-title{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,10vw,86px);font-weight:600;line-height:1.0;letter-spacing:-.025em;margin-bottom:16px;transition:color .45s}
.ph-title em{font-style:italic;color:var(--accent);transition:color .45s}
.ph-sub{font-size:clamp(14px,2vw,16px);color:var(--muted);max-width:520px;line-height:1.75;transition:color .45s}
@media(min-width:768px){.page-hero{padding:130px clamp(32px,6vw,100px) 56px;max-width:1280px}}

.filter-wrap{padding:0 24px;margin-bottom:32px}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap}
.f-btn{font-family:'Space Grotesk',sans-serif;font-size:11.5px;font-weight:600;letter-spacing:.08em;padding:8px 18px;border-radius:100px;border:1px solid var(--brd);color:var(--muted);cursor:none;transition:border-color .3s,color .3s,background .3s}
.f-btn:hover{border-color:var(--brd2);color:var(--text)}
.f-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
@media(hover:none){.f-btn{cursor:pointer}}
@media(min-width:768px){.filter-wrap{padding:0 clamp(32px,6vw,100px);max-width:1280px;margin-inline:auto}}

.work-section{position:relative;z-index:1;padding:0 24px 80px}
.work-count{font-size:11.5px;color:var(--muted);letter-spacing:.06em;margin-bottom:24px;transition:color .45s}
@media(min-width:768px){.work-section{padding:0 clamp(32px,6vw,100px) 100px;max-width:1280px;margin-inline:auto}}

.work-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:560px){.work-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.work-grid{grid-template-columns:repeat(3,1fr)}}

.work-card{display:block;border-radius:16px;overflow:hidden;border:1px solid var(--brd);background:var(--bg2);transition:border-color .4s,box-shadow .4s,transform .5s var(--ease),background .45s}
.work-card:hover{border-color:var(--brd2);box-shadow:0 8px 40px rgba(0,0,0,.3);transform:translateY(-4px)}
.work-card.hidden{display:none!important}
.wc-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bg)}
.wc-img img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s var(--ease),transform .7s var(--ease)}
.wc-img img.loaded{opacity:1}
.wc-img.img-loaded img{opacity:1}
.wc-img:hover img{transform:scale(1.05)}
.wc-type{position:absolute;top:14px;left:14px;font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--nav-bg2);backdrop-filter:blur(10px);border:1px solid var(--brd);padding:4px 10px;border-radius:100px;transition:color .45s,background .45s}
.wc-overlay{position:absolute;inset:0;background:rgba(7,7,12,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s}
.work-card:hover .wc-overlay{opacity:1}
.wc-view{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--accent-lt)}
.wc-view svg{width:14px;height:14px;flex-shrink:0}
.wc-info{padding:20px 22px 24px}
.wc-cats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.wc-cat{font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:var(--surface);border:1px solid var(--brd);padding:3px 9px;border-radius:100px;transition:color .45s,background .45s}
.wc-name{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,3.5vw,26px);font-weight:600;line-height:1.15;color:var(--text);margin-bottom:8px;transition:color .3s}
.work-card:hover .wc-name{color:var(--accent)}
.wc-desc{font-size:12.5px;color:var(--muted);line-height:1.7;transition:color .45s}

/* ═══════════════════════════════════════
   ── PROJECT PAGE ──
═══════════════════════════════════════ */
.back-bar{position:relative;z-index:1;padding:100px 24px 0;max-width:900px;margin:0 auto}
.back-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:none;transition:color .25s,transform .3s var(--ease)}
.back-link:hover{color:var(--accent);transform:translateX(-4px)}
.back-link svg{transition:transform .3s var(--ease)}
.back-link:hover svg{transform:translateX(-3px)}
@media(hover:none){.back-link{cursor:pointer}}

.proj-hero{position:relative;z-index:1;padding:32px 24px 48px;max-width:900px;margin:0 auto}
.proj-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.proj-cat{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:var(--surface);border:1px solid var(--brd);padding:4px 12px;border-radius:100px;transition:color .45s,background .45s,border-color .45s}
.proj-title{font-family:'Cormorant Garamond',serif;font-size:clamp(42px,9vw,78px);font-weight:600;line-height:1.0;letter-spacing:-.025em;margin-bottom:20px;transition:color .45s}
.proj-title em{font-style:italic;color:var(--accent);transition:color .45s}
.proj-tagline{font-size:clamp(15px,2.2vw,18px);color:var(--muted);max-width:580px;line-height:1.6;transition:color .45s}
.proj-live{display:inline-flex;align-items:center;gap:9px;margin-top:24px;font-size:12.5px;font-weight:600;letter-spacing:.06em;color:var(--accent);border:1px solid var(--brd2);padding:8px 18px;border-radius:100px;cursor:none;transition:background .3s,box-shadow .3s,border-color .3s,color .45s}
.proj-live:hover{background:var(--surface);border-color:var(--accent);box-shadow:0 0 20px var(--glow-sm)}
.proj-live-dot{width:7px;height:7px;border-radius:50%;background:#3dd68c;box-shadow:0 0 8px rgba(61,214,140,.6);animation:blink 2s ease-in-out infinite}
@media(hover:none){.proj-live{cursor:pointer}}

.proj-cover{position:relative;z-index:1;padding:0 24px;max-width:1100px;margin:0 auto 64px}
.proj-cover-inner{border-radius:20px;overflow:hidden;border:1px solid var(--brd);aspect-ratio:4/3;background:var(--bg2);transition:border-color .45s,background .45s;position:relative}
.proj-cover-inner img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.proj-cover-inner:hover img{transform:scale(1.03)}
.proj-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:clamp(36px,8vw,72px);font-weight:600;font-style:italic;color:var(--brd2);letter-spacing:-.02em;transition:color .45s}

.proj-body{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:0 24px 48px;display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:768px){.proj-body{grid-template-columns:1fr 280px;align-items:start}}
.proj-overview-label{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;transition:color .45s}
.proj-overview{font-size:clamp(15px,1.9vw,17px);line-height:1.72;color:var(--text);opacity:.88;transition:color .45s}
.proj-overview p+p{margin-top:1em}
.proj-blocks{margin-top:36px;display:flex;flex-direction:column;gap:24px}
.proj-block{padding:20px 22px;border-radius:14px;background:var(--bg2);border:1px solid var(--brd);transition:background .45s,border-color .45s}
.proj-block-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;transition:color .45s}
.proj-block-text{font-size:14px;line-height:1.65;color:var(--muted);transition:color .45s}
.proj-meta{padding:22px;border-radius:16px;background:var(--bg2);border:1px solid var(--brd);display:flex;flex-direction:column;gap:18px;position:sticky;top:92px;transition:background .45s,border-color .45s}
.proj-meta-label{font-size:9.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;transition:color .45s}
.proj-meta-val{font-size:13.5px;font-weight:500;color:var(--text);transition:color .45s}
.proj-meta-val a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:transparent;transition:text-decoration-color .2s,color .45s}
.proj-meta-val a:hover{text-decoration-color:var(--accent)}

.proj-gallery{position:relative;z-index:1;max-width:1100px;margin:0 auto 80px;padding:0 24px}
.gallery-label{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;transition:color .45s}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:560px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gallery-item{border-radius:14px;overflow:hidden;border:1px solid var(--brd);background:var(--bg2);aspect-ratio:4/3;cursor:none;position:relative;transition:border-color .4s,transform .5s var(--ease),background .45s}
.gallery-item:hover{border-color:var(--brd2);transform:translateY(-4px)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s;filter:saturate(.92)}
.gallery-item:hover img{transform:scale(1.05);filter:saturate(1)}
.gallery-item-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;font-style:italic;color:var(--brd2);letter-spacing:-.01em;transition:color .45s}
@media(hover:none){.gallery-item{cursor:pointer}}

.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .35s}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:100%;max-height:90vh;border-radius:12px;object-fit:contain;transform:scale(.9);transition:transform .4s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lb-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:none;transition:background .2s}
.lb-close:hover{background:rgba(255,255,255,.2)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:none;transition:background .2s}
.lb-prev{left:16px}.lb-next{right:16px}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.2)}
@media(hover:none){.lb-close,.lb-prev,.lb-next{cursor:pointer}}

.proj-nav{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:1fr 1fr;gap:16px;border-top:1px solid var(--brd);transition:border-color .45s}
.pn-link{display:flex;flex-direction:column;gap:6px;padding:20px;border-radius:14px;border:1px solid var(--brd);background:var(--bg2);cursor:none;transition:border-color .4s,background .4s var(--ease),box-shadow .4s}
.pn-link:hover{border-color:var(--brd2);box-shadow:0 6px 24px rgba(0,0,0,.15)}
.pn-link.next{text-align:right}
.pn-dir{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px;transition:color .45s}
.pn-link.next .pn-dir{justify-content:flex-end}
.pn-name{font-family:'Cormorant Garamond',serif;font-size:clamp(17px,2.5vw,22px);font-weight:600;letter-spacing:-.015em;color:var(--text);transition:color .45s}
.pn-link:hover .pn-name{color:var(--accent)}
@media(hover:none){.pn-link{cursor:pointer}}

.not-found{position:relative;z-index:1;min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:100px 24px;gap:16px}
.nf-title{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,10vw,80px);font-weight:600;font-style:italic;color:var(--accent);transition:color .45s}
.nf-sub{font-size:15px;color:var(--muted);transition:color .45s}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
