/* ═══════════════════════════════════════════════════════
   Site Architects — Complete Redesign
   Fonts: Cormorant Garamond (Display) + Plus Jakarta Sans (Body)
   Palette: Deep Warm Dark + Champagne Gold
═══════════════════════════════════════════════════════ */

/* ── Variables ──────────────────────────────────────── */
:root {
  /* Backgrounds */
  --bg:       #09080d;
  --bg-2:     #100f15;
  --bg-card:  #141119;

  /* Surfaces */
  --surface:  rgba(255,255,255,.042);
  --surface-h:rgba(255,255,255,.075);

  /* Borders */
  --border:   rgba(255,255,255,.075);
  --border-a: rgba(201,169,110,.32);

  /* Accent — champagne gold */
  --accent:   #c9a96e;
  --accent-l: #dfc08a;
  --grad:     linear-gradient(135deg, #c9a96e 0%, #e4a038 100%);
  --grad-text:linear-gradient(135deg, #dfc08a 0%, #c9a96e 100%);

  /* Text */
  --text:     #f0ebe3;
  --text-2:   #a89f96;
  --muted:    #6e6660;
  --subtle:   #1e1b18;

  /* Layout */
  --nav-h:    80px;
  --r:        10px;
  --ease:     cubic-bezier(.76,0,.24,1);
  --ease-out: cubic-bezier(.33,1,.68,1);
}

/* ── Reset ────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:var(--nav-h); }

body {
  font-family:'Plus Jakarta Sans', system-ui, sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
  -webkit-font-smoothing:antialiased;
  line-height:1.65;
}

body::after {
  content:'';
  position:fixed; inset:0; z-index:9998;
  pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size:200px 200px;
}

body.loading { overflow:hidden; }
a { color:inherit; text-decoration:none; }
ul,li { list-style:none; }
button { font-family:inherit; cursor:none; }

/* ── Display serif util ─────────────────────────────── */
.display { font-family:'Cormorant Garamond', Georgia, serif; }

/* ── Gradient text ──────────────────────────────────── */
.grad-text {
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline-block;
  padding-bottom:.1em;
}

/* ── Status dot ─────────────────────────────────────── */
.status-dot {
  display:inline-block;
  width:7px; height:7px; border-radius:50%;
  background:#4ade80;
  box-shadow:0 0 10px rgba(74,222,128,.55);
  animation:dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse {
  0%,100%{ opacity:1; transform:scale(1); }
  50%    { opacity:.45; transform:scale(.65); }
}

/* ════════════════════════════════════════════════════════
   PRELOADER
════════════════════════════════════════════════════════ */
.preloader {
  position:fixed; inset:0; z-index:9000;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:36px;
  transition:opacity .8s var(--ease), visibility .8s;
}
.preloader.done { opacity:0; visibility:hidden; pointer-events:none; }

.pre__logo-wrap { position:relative; width:112px; height:112px; }
.pre__logo {
  position:absolute; inset:18px;
  width:calc(100% - 36px);
  animation:preSpin 4s linear infinite;
}
@keyframes preSpin { to{ transform:rotate(360deg); } }

.pre__ring {
  position:absolute; inset:0; width:100%; height:100%;
  transform:rotate(-90deg);
}
.pre__ring-track { fill:none; stroke:var(--subtle); stroke-width:2; }
.pre__ring-fill {
  fill:none; stroke:url(#preGrad); stroke-width:2.5;
  stroke-linecap:round;
  stroke-dasharray:289; stroke-dashoffset:289;
  transition:stroke-dashoffset .05s linear;
}

.pre__bottom { display:flex; align-items:center; gap:16px; }
.pre__label {
  font-size:10px; font-weight:600;
  letter-spacing:.25em; text-transform:uppercase;
  color:var(--muted);
}
.pre__count {
  font-size:13px; font-weight:700;
  color:var(--accent); min-width:36px;
  font-variant-numeric:tabular-nums;
}

/* ════════════════════════════════════════════════════════
   CUSTOM CURSOR
════════════════════════════════════════════════════════ */
.cursor { position:fixed; top:0; left:0; z-index:8000; pointer-events:none; }

.cursor__dot {
  position:absolute;
  width:5px; height:5px;
  background:var(--accent); border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .08s, opacity .2s;
}
.cursor__ring {
  position:absolute;
  width:28px; height:28px;
  border:1px solid rgba(201,169,110,.4);
  border-radius:50%;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease-out), height .3s var(--ease-out),
             opacity .25s, border-color .25s, background .25s;
}
.cursor__label {
  position:absolute;
  transform:translate(-50%, 20px);
  font-size:9px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent); white-space:nowrap;
  opacity:0; transition:opacity .2s;
}
.cursor.expanded .cursor__ring {
  width:64px; height:64px;
  background:rgba(201,169,110,.05);
  border-color:var(--accent);
}
.cursor.has-label .cursor__label { opacity:1; }
.cursor.hidden .cursor__dot,
.cursor.hidden .cursor__ring { opacity:0; }

/* ════════════════════════════════════════════════════════
   NAV
════════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0;
  height:var(--nav-h); z-index:500;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 48px;
  transition:background .4s, border-color .4s, box-shadow .4s;
}
.nav.scrolled {
  background:rgba(9,8,13,.9);
  backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(255,255,255,.03);
}

.nav__logo {
  display:flex; align-items:center; gap:12px;
  font-size:15px; font-weight:700;
  letter-spacing:-.01em; flex-shrink:0;
}
.nav__logo-img {
  width:38px; height:38px; border-radius:9px;
  filter:drop-shadow(0 0 12px rgba(201,169,110,.4));
}

/* ── Desktop nav links ──────────────────────────────── */
.nav__links {
  display:flex; align-items:center; gap:40px;
  position:absolute; left:50%; transform:translateX(-50%);
}
.nav__link {
  font-size:13px; font-weight:500;
  color:var(--text-2); letter-spacing:.01em;
  transition:color .2s; position:relative;
}
.nav__link::after {
  content:'';
  position:absolute; bottom:-4px; left:0; right:0;
  height:1px; background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease-out);
}
.nav__link:hover { color:var(--text); }
.nav__link:hover::after { transform:scaleX(1); }

.nav__right { display:flex; align-items:center; gap:16px; }

.nav__cta {
  font-size:12px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:10px 22px;
  background:var(--accent); border-radius:var(--r);
  color:#09080d;
  transition:background .25s, transform .25s, box-shadow .3s;
}
.nav__cta:hover {
  background:var(--accent-l);
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(201,169,110,.25);
}

/* Burger */
.nav__burger {
  background:none;
  border:1px solid var(--border); border-radius:9px;
  width:40px; height:40px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:5px; padding:8px;
  transition:border-color .2s;
}
.nav__burger:hover { border-color:var(--accent); }
.burger__line {
  display:block; width:18px; height:1.5px;
  background:var(--text); border-radius:2px;
  transform-origin:center;
  transition:transform .4s var(--ease), opacity .3s, width .3s;
}
.nav__burger.open .burger__line--top { transform:rotate(45deg) translate(4.5px,4.5px); }
.nav__burger.open .burger__line--mid { opacity:0; width:0; }
.nav__burger.open .burger__line--bot { transform:rotate(-45deg) translate(4.5px,-4.5px); }

/* ════════════════════════════════════════════════════════
   OVERLAY MENU
════════════════════════════════════════════════════════ */
.overlay-menu {
  position:fixed; inset:0; z-index:400;
  visibility:hidden;
}
.overlay-menu__bg {
  position:absolute; inset:0;
  background:#09080d;
  clip-path:circle(0% at calc(100% - 60px) 40px);
  transition:clip-path .75s var(--ease);
}
.overlay-menu.open { visibility:visible; }
.overlay-menu.open .overlay-menu__bg {
  clip-path:circle(150% at calc(100% - 60px) 40px);
}
.overlay-menu__inner {
  position:relative; z-index:1; height:100%;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:130px 72px 64px;
  opacity:0; transition:opacity .4s .3s;
}
.overlay-menu.open .overlay-menu__inner { opacity:1; }
.overlay-menu__nav { display:flex; flex-direction:column; gap:0; }

.om__link {
  display:flex; align-items:baseline; gap:22px;
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(3rem, 7vw, 6rem);
  font-weight:600; letter-spacing:-.03em; line-height:1.05;
  color:rgba(240,235,227,.18);
  transition:color .35s;
  overflow:hidden; padding:6px 0;
}
.om__link em {
  font-size:11px; font-weight:700; font-style:normal;
  font-family:'Plus Jakarta Sans', sans-serif;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.15);
  transition:color .35s; flex-shrink:0;
}
.om__link:hover { color:var(--text); }
.om__link:hover em { color:var(--accent); }

.overlay-menu__footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:28px; border-top:1px solid rgba(255,255,255,.07);
}
.om__status {
  display:flex; align-items:center; gap:10px;
  font-size:12px; color:rgba(255,255,255,.38);
}
.om__socials { display:flex; gap:24px; }
.om__socials a {
  font-size:12px; color:rgba(255,255,255,.35);
  transition:color .2s;
}
.om__socials a:hover { color:var(--text); }

/* ════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════ */
.hero {
  min-height:100svh;
  display:grid; grid-template-rows:1fr auto;
  position:relative; overflow:hidden;
  padding-top:var(--nav-h);
}

.hero::before {
  content:'';
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 55% 60% at 80% 15%, rgba(201,169,110,.1) 0%, transparent 60%),
    radial-gradient(ellipse 38% 50% at 8% 85%,  rgba(201,169,110,.06) 0%, transparent 60%);
  pointer-events:none;
}

.hero__blueprint {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; opacity:.22; z-index:0;
}

.hero__text-block {
  position:relative; z-index:1;
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(24px,4vh,60px) 48px 0;
  max-width:1400px; width:100%;
}

.hero__hl-tag {
  display:inline-flex; align-items:center; gap:14px;
  font-size:10px; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent);
  margin-bottom:clamp(20px,3vh,44px);
  opacity:0; transform:translateY(10px);
  transition:opacity .6s .2s, transform .6s .2s var(--ease-out);
}
.hero__hl-tag::before {
  content:''; display:block;
  width:32px; height:1px; background:var(--accent);
}
.hero__hl-tag.revealed { opacity:1; transform:translateY(0); }

.hero__headline { line-height:.92; }
.hero__hl-row { overflow:clip; }

.hero__hl-word {
  display:block;
  font-family:'Cormorant Garamond', Georgia, serif;
  font-size:clamp(5rem, 14vw, 13rem);
  font-weight:700; letter-spacing:-.04em; line-height:.88;
  color:var(--text);
  transform:translateY(110%);
  transition:transform 1s var(--ease);
}
.hero__hl-word--site {
  font-family:'Plus Jakarta Sans', sans-serif;
  font-size:clamp(.7rem, 1.2vw, 1.1rem);
  font-weight:600; letter-spacing:.42em; line-height:1;
  color:var(--accent);
  transform:none;
  margin-bottom:clamp(8px, 1.5vh, 18px);
}
.hero__hl-word.revealed { transform:translateY(0); }

.hero__sub {
  display:flex; align-items:flex-end; justify-content:space-between; gap:40px;
  padding:clamp(28px,4.5vh,56px) 0 0;
  opacity:0; transform:translateY(16px);
  transition:opacity .7s 1.1s, transform .7s 1.1s var(--ease-out);
  position:relative; z-index:3;
}
.hero__sub.revealed { opacity:1; transform:translateY(0); }
.hero__sub p {
  font-size:clamp(.95rem, 1.5vw, 1.2rem);
  font-weight:400; line-height:1.75;
  color:var(--text-2); max-width:420px;
}
.hero__sub p strong { color:var(--text); font-weight:600; }

.hero__cta {
  display:inline-flex; align-items:center; gap:14px;
  font-size:12px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  color:#09080d; background:var(--accent);
  padding:15px 30px; border-radius:var(--r);
  transition:gap .3s var(--ease-out), background .25s, transform .3s var(--ease-out), box-shadow .3s;
  white-space:nowrap; flex-shrink:0;
}
.hero__cta:hover {
  gap:22px; background:var(--accent-l); transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(201,169,110,.28);
}
.hero__cta svg { width:15px; transition:transform .3s; }
.hero__cta:hover svg { transform:translateX(4px); }

.hero__logo-embed {
  position:absolute;
  right:clamp(24px,4vw,72px); top:50%;
  transform:translateY(-50%) scale(.5) rotate(-20deg);
  width:clamp(160px,20vw,280px); height:clamp(160px,20vw,280px);
  opacity:0;
  transition:opacity .9s .7s, transform .9s .7s var(--ease-out);
  z-index:1; pointer-events:none;
}
.hero__logo-embed.revealed {
  opacity:.14;
  transform:translateY(-50%) scale(1) rotate(0deg);
}
.hero__logo-embed img {
  width:100%; height:100%; object-fit:contain;
  filter:drop-shadow(0 0 40px rgba(201,169,110,.3));
  animation:logoFloat 8s ease-in-out infinite 2s;
}
@keyframes logoFloat {
  0%,100%{ transform:scale(1) rotate(0deg); }
  50%    { transform:scale(1.03) rotate(3deg); }
}

.hero__foot {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:18px 48px;
  border-top:1px solid var(--border);
  background:rgba(9,8,13,.55);
  backdrop-filter:blur(20px);
}
.hero__foot-item { display:flex; flex-direction:column; gap:4px; }
.hero__foot-item--right { align-items:flex-end; }
.hero__foot-label {
  font-size:9px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
}
.hero__foot-val {
  font-size:13px; font-weight:600;
  display:flex; align-items:center; gap:7px;
  color:var(--text-2);
}
.hero__foot-val--active { color:#4ade80; }

.hero__foot-scroll {
  display:flex; align-items:center; gap:12px;
  font-size:9px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--muted);
}
.scroll-track {
  width:1px; height:44px;
  background:var(--subtle); position:relative; overflow:hidden;
}
.scroll-thumb {
  position:absolute; top:-100%; width:100%; height:40%;
  background:var(--accent);
  animation:scrollDown 2.2s ease-in-out infinite;
}
@keyframes scrollDown { from{top:-40%;} to{top:140%;} }

/* ════════════════════════════════════════════════════════
   MARQUEE
════════════════════════════════════════════════════════ */
.marquee {
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:16px 0;
  background:var(--bg-2);
  -webkit-mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);
}
.marquee__track {
  display:flex; gap:32px; width:max-content;
  animation:marqueeRun 26s linear infinite;
}
@keyframes marqueeRun { from{transform:translateX(0);} to{transform:translateX(-50%);} }
.marquee__track span {
  font-size:11px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); white-space:nowrap; flex-shrink:0;
}
.marquee__dot { color:var(--accent) !important; font-size:8px !important; }

/* ════════════════════════════════════════════════════════
   MANIFESTO / ABOUT
════════════════════════════════════════════════════════ */
.manifesto {
  padding:clamp(80px,10vw,140px) 48px;
  border-bottom:1px solid var(--border);
}
.manifesto__inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:240px 1fr; gap:80px; align-items:start;
}

.manifesto__label {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent); margin-bottom:44px;
}
.manifesto__label::before { content:''; width:28px; height:1px; background:var(--accent); }

.manifesto__nums { display:flex; flex-direction:column; gap:36px; }

.m-num strong {
  display:block;
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(3rem, 5vw, 5.5rem);
  font-weight:700; letter-spacing:-.04em; line-height:.9;
  color:var(--text);
}
.m-num span {
  font-size:13px; color:var(--muted); line-height:1.55;
  margin-top:8px; display:block;
}

.manifesto__big {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(1.9rem, 3.2vw, 3.4rem);
  font-weight:600; letter-spacing:-.02em; line-height:1.28;
  margin-bottom:32px; color:var(--text);
}
.manifesto__big em {
  font-style:italic;
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline-block;
  padding-bottom:.1em;
}
.manifesto__body {
  font-size:16px; color:var(--text-2); line-height:1.9;
  max-width:560px;
}

/* ════════════════════════════════════════════════════════
   WORK
════════════════════════════════════════════════════════ */
.work {
  padding:clamp(80px,10vw,140px) 0;
  border-bottom:1px solid var(--border);
}

.work__header {
  max-width:1200px; margin:0 auto 60px;
  padding:0 48px;
  display:flex; align-items:baseline; justify-content:space-between; gap:24px;
}
.work__label {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent); flex-shrink:0;
}
.work__label::before { content:''; width:28px; height:1px; background:var(--accent); }

.work__title {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2.6rem, 5.5vw, 5.5rem);
  font-weight:700; letter-spacing:-.04em; line-height:.92;
}
.work__title em {
  font-style:italic;
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline-block;
  padding-bottom:.1em;
}

.work__list { max-width:1200px; margin:0 auto; display:flex; flex-direction:column; }

.work__item {
  border-top:1px solid var(--border);
  position:relative; overflow:hidden; cursor:pointer;
  transition:background .3s;
}
.work__item:last-child { border-bottom:1px solid var(--border); }
.work__item:hover:not(.work__item--cta) { background:rgba(201,169,110,.03); }

.work__item-inner {
  display:grid;
  grid-template-columns:56px 1fr auto auto;
  align-items:center; gap:24px;
  padding:28px 48px;
  position:relative; z-index:1;
}
.work__item-num {
  font-size:10px; font-weight:700;
  letter-spacing:.16em; color:var(--muted);
  font-variant-numeric:tabular-nums;
}
.work__item-info h3 {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(1.5rem, 3vw, 2.8rem);
  font-weight:600; letter-spacing:-.02em; line-height:1;
  transition:color .25s;
}
.work__item:hover .work__item-info h3 { color:var(--accent); }
.work__item-info p {
  font-size:14px; color:var(--muted); margin-top:7px; line-height:1.5;
}

.work__item-tags {
  display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end;
}
.work__item-tags span {
  font-size:10px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  padding:5px 12px;
  border:1px solid var(--border); border-radius:6px;
  color:var(--muted);
  transition:border-color .25s, color .25s;
}
.work__item:hover .work__item-tags span {
  border-color:var(--border-a); color:var(--accent);
}

.work__item-arrow {
  width:44px; height:44px;
  border:1px solid var(--border); border-radius:var(--r);
  display:flex; align-items:center; justify-content:center;
  transition:border-color .3s, background .3s, transform .4s var(--ease-out);
  flex-shrink:0;
}
.work__item-arrow svg { width:15px; color:var(--muted); transition:color .25s; }
.work__item:hover .work__item-arrow {
  border-color:var(--accent); background:rgba(201,169,110,.1);
  transform:rotate(45deg);
}
.work__item:hover .work__item-arrow svg { color:var(--accent); }

.work__item-preview {
  position:absolute; right:140px; top:50%;
  transform:translateY(-50%) scale(.85);
  width:260px; pointer-events:none; opacity:0;
  transition:opacity .4s var(--ease-out), transform .4s var(--ease-out);
  z-index:2;
}
.work__item:hover .work__item-preview { opacity:1; transform:translateY(-50%) scale(1); }

.wip__screen {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.8);
}
.wip__bar { height:20px; background:var(--surface); border-bottom:1px solid var(--border); }
.wip__hero {
  height:96px; padding:16px;
  display:flex; flex-direction:column; gap:8px; justify-content:center;
}
.wip__title { height:10px; width:55%; background:rgba(255,255,255,.14); border-radius:4px; }
.wip__sub   { height:8px;  width:38%; background:rgba(255,255,255,.08); border-radius:4px; }
.wip__grid  { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; padding:10px; }
.wip__grid--2 { grid-template-columns:repeat(2,1fr); }
.wip__grid div { height:30px; background:var(--surface); border-radius:5px; }

.work__item--cta { background:var(--surface); }
.work__item--cta .work__item-inner { grid-template-columns:56px 1fr auto; }
.work__item-tags--link {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent);
  border:1px solid var(--border-a); border-radius:var(--r);
  padding:12px 22px;
  transition:background .25s, border-color .25s;
  white-space:nowrap;
}
.work__item-tags--link:hover { background:rgba(201,169,110,.08); }

/* ════════════════════════════════════════════════════════
   SERVICES
════════════════════════════════════════════════════════ */
.services {
  padding:clamp(80px,10vw,140px) 0;
  border-bottom:1px solid var(--border);
  background:var(--bg-2);
}
.services__inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:300px 1fr;
  gap:80px; padding:0 48px;
}
.services__label {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent); margin-bottom:28px;
}
.services__label::before { content:''; width:28px; height:1px; background:var(--accent); }

.services__title {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2.6rem, 4.5vw, 4.5rem);
  font-weight:700; letter-spacing:-.04em; line-height:.92;
  margin-bottom:28px;
}
.services__title em {
  font-style:italic;
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline-block;
  padding-bottom:.1em;
}
.services__body { font-size:15px; color:var(--text-2); line-height:1.8; }

.services__list { display:flex; flex-direction:column; }

.srv__item {
  border-top:1px solid var(--border);
  transition:background .25s;
}
.srv__item:last-child { border-bottom:1px solid var(--border); }
.srv__item.open {
  background:rgba(201,169,110,.03);
  border-left:2px solid var(--accent);
}
.srv__item-top {
  display:grid;
  grid-template-columns:44px 1fr 36px;
  align-items:center; gap:16px;
  padding:22px 0; cursor:none;
}
.srv__num {
  font-size:10px; font-weight:700;
  letter-spacing:.16em; color:var(--muted);
}
.srv__item-top h3 {
  font-size:clamp(1rem, 1.8vw, 1.3rem);
  font-weight:600; letter-spacing:-.01em;
  transition:color .25s;
}
.srv__item:hover .srv__item-top h3,
.srv__item.open  .srv__item-top h3 { color:var(--accent); }

.srv__toggle {
  width:32px; height:32px;
  border:1px solid var(--border); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:300; color:var(--muted);
  transition:transform .4s var(--ease), border-color .25s, color .25s;
  justify-self:end;
}
.srv__item.open .srv__toggle {
  transform:rotate(45deg);
  border-color:var(--accent); color:var(--accent);
}
.srv__body {
  font-size:15px; color:var(--text-2); line-height:1.8;
  max-height:0; overflow:hidden;
  transition:max-height .5s var(--ease), padding .4s var(--ease), opacity .4s;
  opacity:0; padding:0 0 0 60px;
}
.srv__item.open .srv__body {
  max-height:200px; opacity:1; padding:0 0 22px 60px;
}

/* ════════════════════════════════════════════════════════
   CONTACT
════════════════════════════════════════════════════════ */
.contact {
  padding:clamp(80px,10vw,140px) 48px;
  border-bottom:1px solid var(--border);
}
.contact__inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start;
}
.contact__label {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent); margin-bottom:28px;
}
.contact__label::before { content:''; width:28px; height:1px; background:var(--accent); }

.contact__big {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2.2rem, 4vw, 4rem);
  font-weight:700; letter-spacing:-.04em; line-height:1.1;
  margin-bottom:44px; color:var(--text);
}
.contact__big em {
  font-style:italic;
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  padding-bottom:.1em;
  display:inline-block;
}

.contact__links { display:flex; flex-direction:column; gap:0; }
.contact__link {
  display:flex; align-items:center; gap:16px;
  padding:22px 0; border-top:1px solid var(--border);
  transition:gap .3s;
}
.contact__links .contact__link:last-child { border-bottom:1px solid var(--border); }
.contact__link:hover { gap:24px; }
.contact__link-label {
  font-size:10px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); width:72px; flex-shrink:0;
}
.contact__link-val {
  font-size:15px; font-weight:500; flex:1;
  transition:color .25s;
}
.contact__link:hover .contact__link-val { color:var(--accent); }
.contact__link svg { width:15px; color:var(--muted); transition:transform .3s, color .25s; }
.contact__link:hover svg { transform:translate(4px,-4px); color:var(--accent); }

.contact__form { display:flex; flex-direction:column; gap:20px; }
.cf__field { display:flex; flex-direction:column; gap:8px; }
.cf__field label {
  font-size:10px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
}
.cf__field input,
.cf__field select,
.cf__field textarea {
  background:var(--surface);
  border:1px solid var(--border); border-radius:var(--r); padding:14px 16px;
  font-family:'Plus Jakarta Sans', sans-serif; font-size:15px;
  color:var(--text); outline:none;
  transition:border-color .25s, background .25s, box-shadow .25s;
  resize:vertical; appearance:none; -webkit-appearance:none;
  width:100%; max-width:100%;
}
.cf__field select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236e6660' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center;
  padding-right:40px;
}
.cf__field select option { background:var(--bg-card); color:var(--text); }
.cf__field input::placeholder, .cf__field textarea::placeholder { color:var(--muted); }
.cf__field input:focus, .cf__field select:focus, .cf__field textarea:focus {
  border-color:var(--accent);
  background:rgba(201,169,110,.04);
  box-shadow:0 0 0 3px rgba(201,169,110,.12);
}

.cf__submit {
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:17px 24px;
  background:var(--accent);
  border:none; border-radius:var(--r);
  font-family:'Plus Jakarta Sans', sans-serif;
  font-size:14px; font-weight:700;
  letter-spacing:.04em; color:#09080d; cursor:none;
  transition:background .25s, transform .25s, box-shadow .3s;
}
.cf__submit:hover {
  background:var(--accent-l);
  transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(201,169,110,.28);
}
.cf__submit svg { width:17px; flex-shrink:0; }

.cf__success {
  display:none; padding:16px;
  border:1px solid rgba(201,169,110,.28); border-radius:var(--r);
  color:var(--accent); font-size:14px; font-weight:600;
  animation:fadeUp .4s var(--ease-out);
}
.cf__success.show { display:block; }
.cf__error {
  display:none; padding:16px;
  border:1px solid rgba(220,60,60,.25); border-radius:var(--r);
  color:#e05555; font-size:14px; font-weight:600;
  animation:fadeUp .4s var(--ease-out);
}
.cf__error.show { display:block; }
@keyframes fadeUp { from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:none;} }

/* ════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════ */
.footer {
  padding:32px 48px;
  border-top:1px solid var(--border);
}
.footer__inner {
  max-width:1400px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.footer__logo {
  display:flex; align-items:center; gap:10px;
  font-size:14px; font-weight:700;
}
.footer__logo img {
  width:26px; height:26px; border-radius:7px;
  filter:drop-shadow(0 0 8px rgba(201,169,110,.4));
}
.footer__mid { font-size:12px; color:var(--muted); }
.footer__right {
  display:flex; align-items:center; gap:20px;
  font-size:12px; color:var(--muted);
}
.footer__right a { transition:color .2s; }
.footer__right a:hover { color:var(--text); }

/* ════════════════════════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════════════════════════ */
[data-reveal] {
  opacity:0; transform:translateY(28px);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
[data-reveal].revealed { opacity:1; transform:none; }
[data-reveal-delay="80"]  { transition-delay:80ms; }
[data-reveal-delay="100"] { transition-delay:100ms; }
[data-reveal-delay="150"] { transition-delay:150ms; }
[data-reveal-delay="200"] { transition-delay:200ms; }
[data-reveal-delay="240"] { transition-delay:240ms; }
[data-reveal-delay="300"] { transition-delay:300ms; }
[data-reveal-delay="320"] { transition-delay:320ms; }
[data-reveal-delay="500"] { transition-delay:500ms; }

/* ════════════════════════════════════════════════════════
   TOUCH DEVICES — disable custom cursor
════════════════════════════════════════════════════════ */
@media (hover:none) and (pointer:coarse) {
  body, button, a { cursor:auto !important; }
  .cursor { display:none !important; }
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */

/* ── 1280px ─────────────────────────────────────────── */
@media (max-width:1280px) {
  .manifesto__inner { grid-template-columns:200px 1fr; gap:60px; }
  .services__inner  { grid-template-columns:240px 1fr; gap:60px; }
}

/* ── 1024px ─────────────────────────────────────────── */
@media (max-width:1024px) {
  .nav__links { display:none; }
  .manifesto__inner { grid-template-columns:1fr; gap:0; }
  .services__inner  { grid-template-columns:1fr; gap:48px; }
  .contact__inner   { grid-template-columns:1fr; gap:56px; }
  .work__item-preview { display:none; }
  .work__item-inner { grid-template-columns:44px 1fr auto; }
  .work__item-tags  { display:none; }
  .hero__logo-embed { width:clamp(140px,18vw,220px); height:clamp(140px,18vw,220px); }
  .footer__inner { flex-direction:column; gap:12px; text-align:center; }
  .footer__right { justify-content:center; }
  .manifesto__left {
    border-bottom:1px solid var(--border);
    padding-bottom:48px; margin-bottom:48px;
  }
  .manifesto__nums {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:0; padding-top:24px; border-top:1px solid var(--border);
  }
  .m-num            { padding:0 24px 0 0; border-right:1px solid var(--border); }
  .m-num + .m-num   { padding:0 24px; }
  .m-num:last-child { padding:0 0 0 24px; border-right:none; }
}

/* ── 768px ─────────────────────────────────────────── */
@media (max-width:768px) {
  :root { --nav-h:64px; }

  /* Nav */
  .nav           { padding:0 20px; }
  .nav__cta      { display:none; }
  .nav__logo-img { width:32px; height:32px; }

  /* Hero — font uses :not() so .hero__hl-word--site stays small */
  .hero__text-block { padding:20px 20px 0; }
  .hero__hl-word:not(.hero__hl-word--site) { font-size:clamp(3.2rem, 11vw, 6rem); }
  .hero__foot        { padding:12px 20px; grid-template-columns:1fr 1fr; }
  .hero__foot-scroll { display:none; }
  .hero__logo-embed  { display:none; }
  .hero__sub         { flex-direction:column; align-items:flex-start; gap:18px; padding-top:18px; }
  .hero__sub p       { font-size:15px; max-width:none; }
  .hero__cta         { padding:13px 24px; font-size:11px; align-self:flex-start; }

  /* Section vertical padding */
  .manifesto { padding:56px 20px; }
  .work      { padding:56px 0; }
  .services  { padding:56px 0; }
  .contact   { padding:56px 20px; }

  /* Work */
  .work__header     { padding:0 20px; margin-bottom:28px; }
  .work__item-inner { grid-template-columns:1fr auto; gap:14px; padding:18px 20px; }
  .work__item-num   { display:none; }
  /* Fix: CTA item also resets to 2-col so empty 56px slot disappears */
  .work__item--cta .work__item-inner { grid-template-columns:1fr auto; }

  /* Services */
  .services__inner  { padding:0 20px; gap:32px; }
  .srv__item-top    { padding:16px 0; gap:10px; grid-template-columns:1fr 34px; }
  .srv__num         { display:none; }
  .srv__body        { padding-left:0; }
  .srv__item.open .srv__body { padding:0 0 16px 0; max-height:300px; }

  /* Contact */
  .contact__inner { padding:0; gap:36px; }
  .contact__big   { font-size:clamp(1.8rem, 6vw, 2.8rem); margin-bottom:24px; }
  .contact__link  { padding:16px 0; }
  .cf__field input,
  .cf__field select,
  .cf__field textarea { font-size:16px; padding:12px 14px; }

  /* Overlay menu */
  .overlay-menu__inner { padding:90px 24px 40px; }
  .om__link            { font-size:clamp(2.5rem, 9vw, 5rem); gap:14px; }
  .om__link em         { display:none; }
  .om__socials         { display:none; }

  /* Footer */
  .footer { padding:20px 20px; }

  /* Manifesto */
  .manifesto__left  { padding-bottom:32px; margin-bottom:32px; }
  .m-num            { padding:0 16px 0 0; }
  .m-num + .m-num   { padding:0 16px; }
  .m-num:last-child { padding:0 0 0 16px; }
  .m-num strong     { font-size:clamp(2rem, 8vw, 4rem); }
}

/* ── 480px ─────────────────────────────────────────── */
@media (max-width:480px) {
  /* Hero */
  .hero__hl-word:not(.hero__hl-word--site) { font-size:clamp(2.6rem, 10.5vw, 3.6rem); }
  .hero__hl-tag  { margin-bottom:12px; }
  /* On very small screens: hero foot shows only 1 item */
  .hero__foot            { grid-template-columns:1fr; }
  .hero__foot-item--right { display:none; }

  /* Work */
  .work__item-inner   { padding:16px 20px; gap:12px; }
  .work__item-info h3 { font-size:1.1rem; }
  .work__item-info p  { font-size:13px; }
  .work__item-arrow   { width:36px; height:36px; }

  /* Manifesto */
  .manifesto__big   { font-size:clamp(1.4rem, 5vw, 2rem); }
  .m-num strong     { font-size:clamp(1.8rem, 9vw, 3rem); }
  .m-num            { padding:0 12px 0 0; }
  .m-num + .m-num   { padding:0 12px; }
  .m-num:last-child { padding:0 0 0 12px; }

  /* Services */
  .services__title  { font-size:clamp(2rem, 7vw, 3rem); }
  .srv__item-top h3 { font-size:.9rem; }

  /* Contact */
  .contact__big  { font-size:clamp(1.6rem, 6vw, 2.2rem); }
  .cf__field     { gap:6px; }
  .contact__form { gap:14px; }

  /* Overlay menu */
  .om__link { font-size:clamp(2rem, 10vw, 3.5rem); }
}

/* ── 360px ─────────────────────────────────────────── */
@media (max-width:360px) {
  :root { --nav-h:56px; }
  .nav { padding:0 14px; }
  .hero__hl-word:not(.hero__hl-word--site) { font-size:clamp(2.2rem, 10vw, 3rem); }
  .manifesto__nums {
    grid-template-columns:1fr; gap:0; border-top:none; padding-top:0;
  }
  .m-num {
    padding:12px 0 !important;
    border-right:none !important;
    border-bottom:1px solid var(--border);
  }
  .m-num:last-child { border-bottom:none; }
  .om__link { font-size:clamp(1.8rem, 10vw, 3rem); }
}


