/* ============================================================
   PINTO STUDIO — styles.css
   A warm-dark editorial system. Everything is CSS; no images.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  /* Warm-dark palette */
  --ink-900:#0c0b09;   /* deepest base */
  --ink-850:#100e0b;
  --ink-800:#15130f;
  --ink-700:#1c1914;   /* elevated surface */
  --ink-600:#26221b;
  --ink-500:#332d24;   /* borders / hairlines */
  --brown-700:#3a2f24;
  --brown-500:#5a4636;
  --brown-300:#8a6c52;
  --sand-500:#b79a76;
  --sand-300:#d6c3a5;
  --gold:#c9a86a;      /* primary accent */
  --gold-soft:#d8bd8b;
  --terra:#c07a4c;     /* secondary warm accent */
  --cream:#f2ede3;     /* primary text */
  --cream-dim:#cfc7ba;
  --gray:#9a9086;      /* muted text */
  --gray-dim:#6f675e;

  --bg:var(--ink-850);
  --text:var(--cream);
  --muted:var(--gray);
  --line:rgba(214,195,165,.12);
  --line-strong:rgba(214,195,165,.22);

  /* Type */
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;

  /* Layout */
  --pad:clamp(1.25rem,5vw,6rem);
  --maxw:1320px;
  --radius:18px;

  /* Motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  letter-spacing:-.01em;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* Warm ambient wash so the black never feels flat */
  background-image:
    radial-gradient(1200px 800px at 15% -10%, rgba(201,168,106,.06), transparent 60%),
    radial-gradient(1000px 700px at 100% 8%, rgba(192,122,76,.05), transparent 55%);
  background-attachment:fixed;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,textarea{font:inherit;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--gold);color:var(--ink-900)}

/* ---------- Focus visibility ---------- */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ---------- Skip link ---------- */
.skip{
  position:fixed;top:-100px;left:1rem;z-index:200;
  background:var(--gold);color:var(--ink-900);
  padding:.7rem 1.1rem;border-radius:10px;font-weight:600;
  transition:top .25s var(--ease);
}
.skip:focus{top:1rem}

/* ---------- Grain ---------- */
.grain{
  position:fixed;inset:-50%;z-index:1;pointer-events:none;
  opacity:.045;mix-blend-mode:overlay;
  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='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)}10%{transform:translate(-4%,-4%)}
  30%{transform:translate(3%,-2%)}50%{transform:translate(-2%,4%)}
  70%{transform:translate(4%,2%)}90%{transform:translate(-3%,1%)}
}

/* ---------- Scroll progress ---------- */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:120;background:transparent}
.progress__bar{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--terra),var(--gold));
  box-shadow:0 0 14px rgba(201,168,106,.5);
}

/* ---------- Custom cursor ---------- */
.cursor{position:fixed;top:0;left:0;z-index:150;pointer-events:none;display:none}
.cursor__dot{
  position:fixed;width:6px;height:6px;border-radius:50%;background:var(--gold);
  transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;
}
.cursor__ring{
  position:fixed;width:34px;height:34px;border-radius:50%;
  border:1px solid rgba(201,168,106,.5);
  transform:translate(-50%,-50%);
  transition:width .28s var(--ease),height .28s var(--ease),
             border-color .28s,background .28s,opacity .28s;
}
.cursor.is-focus .cursor__ring{width:56px;height:56px;border-color:var(--gold);background:rgba(201,168,106,.08)}
.cursor.is-focus .cursor__dot{width:0;height:0}
.cursor.is-view .cursor__ring{width:92px;height:92px;background:rgba(201,168,106,.1);border-color:transparent}
.cursor.is-view .cursor__dot{width:0;height:0}
.cursor__label{
  position:fixed;transform:translate(-50%,-50%);color:var(--ink-900);
  font:600 11px/1 var(--mono);letter-spacing:.05em;text-transform:uppercase;
  opacity:0;transition:opacity .2s;
}
.cursor.is-view .cursor__label{opacity:1}
@media (pointer:fine){
  .cursor{display:block}
  body.has-cursor{cursor:none}
  body.has-cursor a,body.has-cursor button,body.has-cursor input,
  body.has-cursor textarea,body.has-cursor label{cursor:none}
}

/* ---------- Reveal system ----------
   Hidden-initial states are scoped to .js so that if scripting is
   unavailable, everything renders fully visible (no stuck opacity:0). */
.js [data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}

.js [data-reveal-word]{display:inline-block;opacity:0;transform:translateY(90%) rotate(2deg);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .hero__title.in [data-reveal-word]{opacity:1;transform:none}

.js [data-reveal-line]{display:block;opacity:0;transform:translateY(115%);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .in [data-reveal-line]{opacity:1;transform:none}

/* ---------- Buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  padding:1em 1.6em;border-radius:100px;font-weight:500;font-size:.95rem;
  letter-spacing:-.01em;white-space:nowrap;overflow:hidden;
  transition:transform .5s var(--ease),color .4s,background .4s,border-color .4s;
  will-change:transform;
}
.btn__arrow{transition:transform .45s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(4px)}

.btn--primary{background:var(--gold);color:var(--ink-900);font-weight:600}
.btn--primary::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,var(--gold-soft),var(--terra));
  opacity:0;transition:opacity .45s var(--ease);
}
.btn--primary:hover::before{opacity:1}
.btn--primary:hover{color:var(--ink-900)}

.btn--ghost{border:1px solid var(--line-strong);color:var(--cream)}
.btn--ghost:hover{border-color:var(--gold);background:rgba(201,168,106,.06)}

.btn--nav{padding:.7em 1.25em;font-size:.9rem;background:transparent;border:1px solid var(--line-strong)}
.btn--nav:hover{border-color:var(--gold);background:rgba(201,168,106,.06)}

.btn--block{display:flex;width:100%;justify-content:center}
.btn--submit{margin-top:.4rem}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:110;transition:transform .5s var(--ease)}
.nav__inner{
  display:flex;align-items:center;gap:1.5rem;
  max-width:var(--maxw);margin:0 auto;
  padding:1.4rem var(--pad);
  transition:padding .4s var(--ease);
}
.nav.scrolled .nav__inner{padding-top:.85rem;padding-bottom:.85rem}
.nav::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:rgba(16,14,11,.55);backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid transparent;
  opacity:0;transition:opacity .5s var(--ease),border-color .5s;
}
.nav.scrolled::before{opacity:1;border-bottom-color:var(--line)}

.brand{display:flex;align-items:baseline;gap:.5rem;font-family:var(--serif)}
.brand__mark{color:var(--gold);align-self:center;transition:transform .6s var(--ease)}
.brand:hover .brand__mark{transform:rotate(-8deg) scale(1.06)}
.brand__word{font-size:1.4rem;font-weight:500;letter-spacing:-.02em}
.brand__sup{font:400 .62rem/1 var(--mono);letter-spacing:.28em;text-transform:uppercase;color:var(--gray);align-self:center}

.nav__links{display:flex;gap:.4rem;margin-left:auto}
.nav__links a{position:relative;padding:.5rem .9rem;font-size:.92rem;color:var(--cream-dim);overflow:hidden}
.nav__links a span{position:relative;display:inline-block;transition:transform .45s var(--ease)}
.nav__links a::after{
  content:"";position:absolute;left:.9rem;right:.9rem;bottom:.35rem;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.nav__links a:hover{color:var(--cream)}
.nav__links a:hover::after{transform:scaleX(1)}

.nav .btn--nav{margin-left:.4rem}
.nav__toggle{display:none;flex-direction:column;gap:5px;padding:.6rem;margin-left:auto}
.nav__toggle span{display:block;width:24px;height:1.5px;background:var(--cream);transition:transform .4s var(--ease),opacity .3s}

/* Mobile menu */
.mobile{
  position:fixed;inset:0;z-index:105;background:var(--ink-900);
  padding:6rem var(--pad) 2rem;display:flex;flex-direction:column;justify-content:space-between;
  transform:translateY(-100%);transition:transform .6s var(--ease);
  visibility:hidden;
}
.mobile.open{transform:none;visibility:visible}
.mobile__nav{display:flex;flex-direction:column}
.mobile__nav a{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--serif);font-size:clamp(2.2rem,11vw,3.4rem);font-weight:400;
  padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--cream);
}
.mobile__nav a em{font:400 .8rem/1 var(--mono);color:var(--gold);font-style:normal}
.mobile__foot{display:flex;flex-direction:column;gap:.4rem;font-family:var(--mono);font-size:.85rem;color:var(--gray)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:8rem var(--pad) 4rem;overflow:hidden}
.hero__inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}

.hero__aura{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(900px 620px at 20% 30%, rgba(192,122,76,.22), transparent 60%),
    radial-gradient(760px 620px at 82% 18%, rgba(201,168,106,.18), transparent 55%),
    radial-gradient(700px 700px at 60% 100%, rgba(90,70,54,.28), transparent 60%);
  filter:blur(6px);
  animation:aura 18s ease-in-out infinite alternate;
}
@keyframes aura{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-3%,2%,0) scale(1.08)}}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font:500 .8rem/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;
  color:var(--sand-300);margin-bottom:1.8rem;
}
.eyebrow__dot{width:7px;height:7px;border-radius:2px;background:var(--gold)}

.hero__title{
  font-family:var(--serif);
  font-size:clamp(3.2rem,10.5vw,9.5rem);
  line-height:.94;font-weight:400;letter-spacing:-.035em;
  margin-bottom:2rem;
}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.06em}
.hero__title .italic{font-style:italic;color:var(--gold-soft);font-weight:300}
.hero__title [data-reveal-word]:nth-child(1){transition-delay:.05s}
.hero__title [data-reveal-word]:nth-child(2){transition-delay:.12s}
.hero__title [data-reveal-word]:nth-child(3){transition-delay:.19s}
.hero__title .line:last-child [data-reveal-word]:nth-child(1){transition-delay:.28s}
.hero__title .line:last-child [data-reveal-word]:nth-child(2){transition-delay:.35s}
.hero__title .line:last-child [data-reveal-word]:nth-child(3){transition-delay:.42s}

.hero__lede{max-width:46ch;font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--cream-dim);line-height:1.55}
.hero__lede{transition-delay:.15s}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem;transition-delay:.25s}

.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,4rem);margin-top:4rem;transition-delay:.35s}
.hero__stats dt{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--gold);line-height:1}
.hero__stats dd{font-size:.82rem;color:var(--gray);margin-top:.5rem;max-width:16ch}

/* Hero portrait — desktop only; echoes the About-section portrait card */
.hero__portrait{position:relative;display:none;justify-self:end;width:min(100%,380px);margin:0;z-index:3}
.hero__portrait::before{content:"";position:absolute;top:-14px;right:-14px;bottom:14px;left:14px;
  border:1px solid rgba(201,168,106,.25);border-radius:var(--radius);pointer-events:none}
.hero__portrait-media{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line-strong);background:var(--ink-700)}
.hero__portrait-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(12,11,9,0) 55%,rgba(12,11,9,.5))}
.hero__portrait img{display:block;width:100%;height:100%;object-fit:cover;object-position:center 22%;
  filter:saturate(.92) contrast(1.03)}
@media (min-width:1080px){
  .hero__inner{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,380px);
    align-items:center;gap:clamp(2.5rem,5vw,5rem)}
  .hero__portrait{display:block}
}

.hero__scroll{position:absolute;left:var(--pad);bottom:2rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.hero__scroll-line{width:1px;height:52px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--cream);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-120%)}100%{transform:translateY(260%)}}
.hero__scroll-text{writing-mode:vertical-rl;font:500 .68rem/1 var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--gray)}

/* ---------- Credentials strip ---------- */
.cred{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(12,11,9,.5)}
.cred__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:repeat(4,1fr)}
.cred__item{display:flex;flex-direction:column;gap:.45rem;padding:1.7rem 1.4rem;border-left:1px solid var(--line)}
.cred__item:first-child{border-left:none;padding-left:0}
.cred__k{font:500 .68rem/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.cred__v{font-size:.88rem;color:var(--cream-dim);line-height:1.45}

/* ---------- Section scaffold ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,11vw,9rem) var(--pad)}
.section__head{max-width:64rem;margin-bottom:clamp(3rem,6vw,5rem)}
.section__head--split{display:flex;flex-wrap:wrap;gap:2rem 4rem;justify-content:space-between;align-items:flex-end;max-width:100%}
.section__head--split>div{flex:1 1 22rem}
.index{font:500 .8rem/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
.section__title{font-family:var(--serif);font-size:clamp(2.1rem,5.2vw,4rem);font-weight:400;line-height:1.02;letter-spacing:-.03em}
.section__sub{max-width:48ch;margin-top:1.4rem;font-size:clamp(1rem,1.4vw,1.15rem);color:var(--cream-dim)}
.section__head--split .section__sub{margin-top:0;flex:0 1 34rem}

/* ---------- Services cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.card{
  position:relative;padding:2rem 1.7rem 1.9rem;border-radius:var(--radius);
  background:linear-gradient(180deg,var(--ink-700),var(--ink-800));
  border:1px solid var(--line);overflow:hidden;
  transition:transform .6s var(--ease),border-color .5s,background .5s;
}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,rgba(201,168,106,.4),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s}
.card:hover{transform:translateY(-6px);border-color:transparent;background:linear-gradient(180deg,var(--ink-600),var(--ink-700))}
.card:hover::after{opacity:1}
.card__num{font:500 .72rem/1 var(--mono);color:var(--gray);letter-spacing:.1em}
.card__glyph{width:56px;height:56px;margin:1.4rem 0 1.5rem;border-radius:14px;position:relative;overflow:hidden;background:var(--ink-900);border:1px solid var(--line)}
.card h3{font-family:var(--serif);font-size:1.35rem;font-weight:400;margin-bottom:.6rem;letter-spacing:-.02em}
.card p{font-size:.92rem;color:var(--cream-dim);line-height:1.5}
.card__list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.3rem}
.card__list li{font:500 .72rem/1 var(--mono);color:var(--sand-300);padding:.4rem .6rem;border:1px solid var(--line);border-radius:100px}

/* CSS glyph art */
.glyph--design::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 30% 30%,var(--gold) 0 6px,transparent 7px),
  radial-gradient(circle at 70% 70%,var(--terra) 0 6px,transparent 7px),
  linear-gradient(45deg,transparent 47%,var(--sand-500) 47% 53%,transparent 53%)}
.glyph--build::before{content:"";position:absolute;inset:8px;border:2px solid var(--gold);border-radius:4px;
  background:repeating-linear-gradient(90deg,transparent 0 6px,rgba(201,168,106,.25) 6px 8px)}
.glyph--motion::before{content:"";position:absolute;inset:0;background:
  conic-gradient(from 0deg at 50% 50%,var(--terra),var(--gold),var(--sand-500),var(--terra));
  border-radius:50%;transform:scale(.62);animation:spin 9s linear infinite}
@keyframes spin{to{transform:scale(.62) rotate(360deg)}}
.glyph--grow::before{content:"";position:absolute;left:10px;right:10px;bottom:10px;height:34px;background:
  linear-gradient(var(--gold),var(--gold)) left 0 bottom 0/6px 40% no-repeat,
  linear-gradient(var(--sand-500),var(--sand-500)) left 12px bottom 0/6px 70% no-repeat,
  linear-gradient(var(--terra),var(--terra)) left 24px bottom 0/6px 100% no-repeat,
  linear-gradient(var(--gold-soft),var(--gold-soft)) left 36px bottom 0/6px 55% no-repeat}

/* ---------- Work / projects ---------- */
.projects{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.5rem,3vw,2.6rem)}
.project{cursor:pointer}
.project__thumb{position:relative;aspect-ratio:16/11;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--ink-900)}
.thumb__art{position:absolute;inset:0;transition:transform 1.1s var(--ease),filter .6s}
.project:hover .thumb__art{transform:scale(1.06)}
.project__meta{padding:1.3rem .2rem 0}
.project__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.project__meta h3{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:400;letter-spacing:-.02em;transition:color .4s}
.project:hover .project__meta h3{color:var(--gold-soft)}
.project__year{font:500 .8rem/1 var(--mono);color:var(--gray)}
.project__meta p{color:var(--cream-dim);font-size:.95rem;margin-top:.4rem}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.tags li{font:500 .68rem/1 var(--mono);color:var(--sand-300);padding:.35rem .55rem;border:1px solid var(--line);border-radius:100px;letter-spacing:.03em}

/* Placeholder art — drawn in CSS, no images */
/* Rutgers build: muted scarlet glow over an abstract portico of columns */
.thumb--rutgers .thumb__art{background:
  radial-gradient(110% 90% at 78% 12%,rgba(158,43,61,.55),transparent 55%),
  radial-gradient(80% 70% at 15% 90%,rgba(90,70,54,.5),transparent 60%),
  linear-gradient(180deg,#171310,#0c0b09)}
.thumb--rutgers .thumb__art::before{content:"";position:absolute;left:16%;right:16%;bottom:0;height:50%;
  background:repeating-linear-gradient(90deg,rgba(214,195,165,.18) 0 10px,transparent 10px 44px);
  mask:linear-gradient(#000 55%,transparent);-webkit-mask:linear-gradient(#000 55%,transparent)}
.thumb--rutgers .thumb__art::after{content:"";position:absolute;left:14%;right:14%;bottom:50%;height:9px;
  border-radius:2px;background:linear-gradient(180deg,var(--sand-500),var(--brown-500));
  box-shadow:0 -16px 0 -3px rgba(158,43,61,.5)}
/* Outreach: a hub of customers connecting to one local business */
.thumb--outreach .thumb__art{background:
  radial-gradient(90% 90% at 80% 15%,rgba(201,168,106,.25),transparent 60%),
  linear-gradient(180deg,#16130e,#0c0b09)}
.thumb--outreach .thumb__art::before{content:"";position:absolute;inset:0;opacity:.9;
  background:
    linear-gradient(33deg,transparent calc(50% - 1px),rgba(214,195,165,.3) 50%,transparent calc(50% + 1px)),
    linear-gradient(-28deg,transparent calc(50% - 1px),rgba(214,195,165,.22) 50%,transparent calc(50% + 1px)),
    linear-gradient(78deg,transparent calc(50% - 1px),rgba(214,195,165,.16) 50%,transparent calc(50% + 1px))}
.thumb--outreach .thumb__art::after{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 50% 52%,var(--gold) 0 9px,rgba(201,168,106,.25) 10px 14px,transparent 15px),
  radial-gradient(circle at 18% 26%,var(--sand-500) 0 5px,transparent 6px),
  radial-gradient(circle at 82% 22%,var(--terra) 0 6px,transparent 7px),
  radial-gradient(circle at 84% 78%,var(--sand-300) 0 5px,transparent 6px),
  radial-gradient(circle at 16% 78%,var(--brown-300) 0 6px,transparent 7px)}

/* Project card rendered as an external link */
.project--link{display:block;color:inherit}

/* "Your business, next" CTA card */
.project--cta{grid-column:1/-1;display:flex;align-items:center;gap:clamp(1.2rem,3vw,2.4rem);
  padding:clamp(1.6rem,3.5vw,2.4rem);border:1px dashed var(--line-strong);border-radius:var(--radius);
  transition:border-color .5s,background .5s,transform .6s var(--ease)}
.project--cta:hover{border-color:var(--gold);background:rgba(201,168,106,.05);transform:translateY(-4px)}
.cta__mark{flex:none;display:grid;place-items:center;width:58px;height:58px;border-radius:50%;
  border:1px solid var(--line-strong);font-family:var(--serif);font-size:1.8rem;color:var(--gold);
  transition:transform .6s var(--ease),background .4s,color .4s}
.project--cta:hover .cta__mark{transform:rotate(90deg);background:var(--gold);color:var(--ink-900)}
.cta__body h3{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:400;letter-spacing:-.02em}
.cta__body p{color:var(--cream-dim);font-size:.95rem;margin-top:.4rem;max-width:56ch}
.cta__arrow{margin-left:auto;flex:none;font-size:1.5rem;color:var(--gold);transition:transform .5s var(--ease)}
.project--cta:hover .cta__arrow{transform:translateX(8px)}

/* ---------- Manifesto ---------- */
.manifesto{padding:clamp(5rem,10vw,8rem) var(--pad);max-width:var(--maxw);margin:0 auto;text-align:center}
.manifesto__text{font-family:var(--serif);font-size:clamp(1.6rem,4.2vw,3.2rem);font-weight:300;line-height:1.18;letter-spacing:-.02em;color:var(--cream-dim)}
.manifesto__text span{display:block;overflow:hidden}
.manifesto__text .accent{color:var(--gold-soft);font-style:italic}

/* ---------- Process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.step{background:var(--ink-850);padding:2.2rem 1.6rem;transition:background .5s var(--ease);position:relative}
.step:hover{background:var(--ink-700)}
.step__no{font-family:var(--serif);font-size:2.4rem;color:var(--brown-300);font-weight:300;display:block;margin-bottom:1.2rem;transition:color .5s}
.step:hover .step__no{color:var(--gold)}
.step h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.6rem;letter-spacing:-.02em}
.step p{font-size:.9rem;color:var(--cream-dim);line-height:1.55}

/* ---------- Pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-bottom:clamp(2.5rem,5vw,4rem)}
.tier{position:relative;padding:1.9rem 1.5rem;border-radius:var(--radius);border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-800),var(--ink-850));transition:transform .6s var(--ease),border-color .5s}
.tier:hover{transform:translateY(-6px);border-color:var(--line-strong)}
.tier--feature{background:linear-gradient(180deg,rgba(58,47,36,.6),var(--ink-800));border-color:rgba(201,168,106,.35)}
.tier__flag{position:absolute;top:-1px;right:1.2rem;transform:translateY(-50%);background:var(--gold);color:var(--ink-900);font:600 .66rem/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;padding:.4rem .7rem;border-radius:100px}
.tier header h3{font-family:var(--serif);font-size:1.5rem;font-weight:400}
.tier header p{font-size:.82rem;color:var(--gray);margin-top:.15rem}
.tier__price{font-family:var(--serif);font-size:2.1rem;font-weight:400;color:var(--gold-soft);margin:1rem 0 .3rem;letter-spacing:-.02em}
.tier__time{font:500 .72rem/1.4 var(--mono);color:var(--sand-300);letter-spacing:.03em;margin-bottom:1.1rem}
.tier ul{display:flex;flex-direction:column;gap:.6rem;padding-top:1.2rem;border-top:1px solid var(--line)}
.tier ul li{position:relative;padding-left:1.4rem;font-size:.9rem;color:var(--cream-dim)}
.tier ul li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.8}
.tier__for{margin-top:1.3rem;font-size:.82rem;color:var(--gray);font-style:italic}

/* Mini site previews inside tier cards — pure CSS wireframes that hint at
   what each package's site actually contains */
.tier__preview{position:relative;height:86px;border-radius:10px;border:1px solid var(--line);
  background:var(--ink-900);overflow:hidden;margin-bottom:1.3rem}
.tier:hover .tier__preview{border-color:var(--line-strong)}
.tp__bar{position:absolute;top:0;left:0;right:0;height:15px;border-bottom:1px solid var(--line);background:var(--ink-800)}
.tp__bar::before{content:"";position:absolute;left:7px;top:5.5px;width:4px;height:4px;border-radius:50%;
  background:var(--terra);box-shadow:8px 0 0 var(--sand-500),16px 0 0 var(--gold)}
.tp__body{position:absolute;inset:15px 0 0}
/* 1 — one-pager: headline, copy lines, one strong CTA */
.tp--1 .tp__body{background:
  linear-gradient(var(--gold-soft) 0 0) 12px 12px/44% 9px no-repeat,
  linear-gradient(rgba(207,199,186,.4) 0 0) 12px 28px/62% 4px no-repeat,
  linear-gradient(rgba(207,199,186,.25) 0 0) 12px 37px/48% 4px no-repeat,
  linear-gradient(var(--gold) 0 0) 12px 50px/26% 9px no-repeat}
/* 2 — business site: nav + three service columns */
.tp--2 .tp__body{background:
  linear-gradient(rgba(207,199,186,.4) 0 0) 12px 8px/34% 5px no-repeat,
  linear-gradient(var(--gold) 0 0) 12px 22px/27% 3px no-repeat,
  linear-gradient(var(--sand-500) 0 0) 50% 22px/27% 3px no-repeat,
  linear-gradient(var(--terra) 0 0) calc(100% - 12px) 22px/27% 3px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 12px 25px/27% 32px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 50% 25px/27% 32px no-repeat,
  linear-gradient(var(--ink-600) 0 0) calc(100% - 12px) 25px/27% 32px no-repeat}
/* 3 — content + booking: sidebar plus stacked booking slots */
.tp--3 .tp__body{background:
  linear-gradient(var(--gold) 0 0) 12px 8px/24% 4px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 12px 12px/24% 46px no-repeat,
  linear-gradient(rgba(207,199,186,.35) 0 0) 46% 10px/48% 5px no-repeat,
  linear-gradient(var(--sand-500) 0 0) 46% 24px/32% 8px no-repeat,
  linear-gradient(rgba(207,199,186,.25) 0 0) 46% 40px/48% 5px no-repeat,
  linear-gradient(var(--terra) 0 0) 46% 52px/24% 8px no-repeat}
/* 4 — commerce: product grid, price ticks, cart dot */
.tp--4 .tp__body{background:
  radial-gradient(circle,var(--gold) 0 5px,transparent 6px) calc(100% - 10px) 6px/12px 12px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 12px 8px/28% 24px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 48% 8px/28% 24px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 12px 38px/28% 24px no-repeat,
  linear-gradient(var(--ink-600) 0 0) 48% 38px/28% 24px no-repeat,
  linear-gradient(var(--gold) 0 0) 12px 34px/14% 3px no-repeat,
  linear-gradient(var(--gold) 0 0) 48% 34px/14% 3px no-repeat}

/* How pricing works */
.pricing__notes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:clamp(2.5rem,5vw,4rem)}
.pnote{padding:1.5rem 1.6rem;border-left:2px solid var(--gold);border-radius:0 12px 12px 0;
  background:linear-gradient(90deg,rgba(201,168,106,.05),transparent 70%)}
.pnote__k{display:block;font:500 .78rem/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.pnote p{font-size:.9rem;color:var(--cream-dim);line-height:1.55}

/* ---------- Estimator ---------- */
.estimator{display:grid;grid-template-columns:1.5fr 1fr;gap:1.2rem;align-items:start}
.estimator__panel{padding:clamp(1.6rem,3vw,2.6rem);border-radius:var(--radius);border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-800),var(--ink-850))}
.estimator__eyebrow{font:500 .78rem/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.estimator__title{font-family:var(--serif);font-size:1.7rem;font-weight:400;margin-bottom:2rem;letter-spacing:-.02em}
.est-field{margin-bottom:1.8rem}
.est-field>label{display:flex;justify-content:space-between;align-items:baseline;font-size:.9rem;color:var(--cream-dim);margin-bottom:.8rem;font-weight:450}
.est-field__val{font-family:var(--mono);color:var(--gold);font-size:.95rem}
.est-note{font-size:.78rem;color:var(--gray);margin-top:.6rem;line-height:1.4}

.chipset{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{padding:.6rem 1rem;border:1px solid var(--line);border-radius:100px;font-size:.85rem;color:var(--cream-dim);transition:all .35s var(--ease)}
.chip:hover{border-color:var(--line-strong);color:var(--cream)}
.chip.is-active{background:var(--gold);border-color:var(--gold);color:var(--ink-900);font-weight:600}

.addons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.addon{display:flex;align-items:center;gap:.6rem;padding:.75rem .9rem;border:1px solid var(--line);border-radius:12px;font-size:.85rem;color:var(--cream-dim);text-align:left;transition:all .35s var(--ease)}
.addon i{display:grid;place-items:center;width:20px;height:20px;border-radius:6px;border:1px solid var(--line-strong);font-style:normal;font-size:.9rem;color:var(--gold);transition:all .3s}
.addon:hover{border-color:var(--line-strong);color:var(--cream)}
.addon.is-active{border-color:var(--gold);background:rgba(201,168,106,.08);color:var(--cream)}
.addon.is-active i{background:var(--gold);border-color:var(--gold);color:var(--ink-900);transform:rotate(45deg)}

/* Range slider */
.slider{-webkit-appearance:none;appearance:none;width:100%;height:3px;border-radius:3px;background:var(--ink-500);outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--gold);border:3px solid var(--ink-850);box-shadow:0 0 0 1px var(--gold),0 4px 12px rgba(0,0,0,.4);cursor:pointer;transition:transform .2s}
.slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--gold);border:3px solid var(--ink-850);box-shadow:0 0 0 1px var(--gold);cursor:pointer}
.est-field__scale{display:flex;justify-content:space-between;font:500 .7rem/1 var(--mono);color:var(--gray-dim);margin-top:.5rem}

/* Care checkbox */
.care{display:flex;align-items:flex-start;gap:.8rem;padding:1rem 1.1rem;border:1px solid var(--line);border-radius:12px;font-size:.85rem;color:var(--cream-dim);transition:border-color .3s;cursor:pointer}
.care:hover{border-color:var(--line-strong)}
.care input{position:absolute;opacity:0;pointer-events:none}
.care__box{flex:none;width:20px;height:20px;border-radius:6px;border:1px solid var(--line-strong);position:relative;transition:all .3s;margin-top:.05rem}
.care__box::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;font-size:.8rem;color:var(--ink-900);opacity:0;transform:scale(.5);transition:all .25s}
.care input:checked+.care__box{background:var(--gold);border-color:var(--gold)}
.care input:checked+.care__box::after{opacity:1;transform:scale(1)}
.care strong{color:var(--gold-soft);font-weight:600}

/* Result panel */
.estimator__result{position:relative}
.result__sticky{position:sticky;top:6rem;padding:clamp(1.6rem,3vw,2.2rem);border-radius:var(--radius);border:1px solid rgba(201,168,106,.28);background:linear-gradient(180deg,rgba(58,47,36,.5),var(--ink-800));overflow:hidden}
.result__sticky::before{content:"";position:absolute;top:-40%;right:-30%;width:70%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(201,168,106,.18),transparent 70%);pointer-events:none}
.result__label{font:500 .76rem/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--sand-300)}
.result__figure{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap;margin:.8rem 0 1.2rem}
.result__amount{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.7rem);font-weight:400;color:var(--cream);letter-spacing:-.02em}
.result__dash{color:var(--gold);font-size:1.6rem}
.result__time{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  font:500 .76rem/1 var(--mono);color:var(--gray);margin:-.4rem 0 .9rem}
.result__time strong{color:var(--gold-soft);font-weight:500;font-size:.85rem}
.result__care{font:500 .82rem/1 var(--mono);color:var(--gold-soft);margin:-.2rem 0 1rem}

.result__bars{display:flex;flex-direction:column;gap:.7rem;margin:1.2rem 0 1.4rem;padding:1.2rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.rbar{display:flex;align-items:center;gap:.8rem;font:500 .74rem/1 var(--mono);color:var(--gray)}
.rbar span{width:3.4rem;flex:none}
.rbar i{display:block;height:5px;border-radius:5px;width:var(--w);background:linear-gradient(90deg,var(--terra),var(--gold));transition:width .8s var(--ease)}

.result__lines{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.4rem;min-height:1rem}
.result__lines li{display:flex;justify-content:space-between;gap:1rem;font-size:.83rem;color:var(--cream-dim)}
.result__lines li span:last-child{color:var(--sand-300);font-family:var(--mono);font-size:.78rem;white-space:nowrap}
.result__fine{font-size:.74rem;color:var(--gray);text-align:center;margin-top:.7rem}

/* ---------- Studio ---------- */
.studio__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.studio__portrait{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.portrait__art{position:absolute;inset:0;background:
  radial-gradient(80% 60% at 50% 22%,rgba(216,189,139,.5),transparent 60%),
  radial-gradient(90% 70% at 50% 105%,rgba(90,70,54,.9),transparent 55%),
  linear-gradient(180deg,#241d16,#100e0b)}
.portrait__art::before{content:"";position:absolute;left:50%;top:30%;transform:translateX(-50%);width:42%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--sand-300),var(--brown-500) 70%);
  box-shadow:0 30px 80px rgba(0,0,0,.5)}
.portrait__art::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:64%;height:34%;border-radius:60% 60% 0 0;
  background:linear-gradient(180deg,var(--brown-500),var(--ink-800))}
.portrait__photo{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center 22%}
.portrait__tag{position:absolute;left:1rem;bottom:1rem;z-index:2;font:500 .7rem/1 var(--mono);letter-spacing:.06em;color:var(--cream);background:rgba(12,11,9,.6);backdrop-filter:blur(6px);padding:.55rem .8rem;border-radius:100px;border:1px solid var(--line)}
.studio__lede{font-size:clamp(1.1rem,1.7vw,1.35rem);color:var(--cream);margin-top:1.4rem;line-height:1.5;font-weight:450}
.studio__para{color:var(--cream-dim);margin-top:1.2rem;max-width:52ch}
.studio__values{display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem;margin-top:2.4rem;padding-top:2rem;border-top:1px solid var(--line)}
.value{flex:1 1 12rem}
.value span{font-family:var(--serif);font-size:1.25rem;color:var(--gold-soft);display:block;margin-bottom:.3rem}
.value p{font-size:.88rem;color:var(--gray)}

/* ---------- Contact ---------- */
.contact{position:relative;overflow:hidden}
.contact__aura{position:absolute;inset:0;z-index:0;background:
  radial-gradient(700px 500px at 12% 20%,rgba(192,122,76,.14),transparent 60%),
  radial-gradient(600px 500px at 90% 90%,rgba(201,168,106,.12),transparent 55%);pointer-events:none}
.contact__grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:start}
.contact__intro .section__title{margin-top:.4rem}
.contact__direct{display:flex;flex-direction:column;gap:.8rem;margin-top:2.5rem}
.direct{display:flex;flex-direction:column;gap:.25rem;padding:1.2rem 1.4rem;border:1px solid var(--line);border-radius:14px;transition:all .45s var(--ease);background:rgba(20,18,14,.4)}
.direct:hover{border-color:var(--gold);transform:translateX(6px);background:rgba(201,168,106,.06)}
.direct__k{font:500 .72rem/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.direct__v{font-family:var(--serif);font-size:clamp(1.15rem,2.4vw,1.6rem);color:var(--cream)}
.direct__gmail{display:inline-block;margin-top:.2rem;font:500 .78rem/1.4 var(--mono);color:var(--gray);
  letter-spacing:.02em;transition:color .3s}
.direct__gmail:hover{color:var(--gold)}
.contact__hours{margin-top:1.8rem;font:500 .8rem/1.5 var(--mono);color:var(--sand-300);letter-spacing:.02em}

/* Form — vertical rhythm driven by one flex gap so spacing stays even */
.brief{display:flex;flex-direction:column;gap:1.8rem;padding:clamp(1.8rem,3.4vw,2.8rem);border-radius:var(--radius);border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-800),var(--ink-850))}
.brief__row{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem}
.field{position:relative}
.field input,.field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-strong);padding:1.45rem 0 .65rem;font-size:1rem;transition:border-color .4s}
.field textarea{resize:vertical;min-height:6rem}
.field label{position:absolute;left:0;top:1.45rem;color:var(--gray);pointer-events:none;transition:all .35s var(--ease);font-size:1rem}
.field input:focus~label,.field input:not(:placeholder-shown)~label,
.field textarea:focus~label,.field textarea:not(:placeholder-shown)~label{top:.1rem;font-size:.7rem;color:var(--gold);letter-spacing:.08em;text-transform:uppercase}
.field__line{position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.field input:focus~.field__line,.field textarea:focus~.field__line{transform:scaleX(1)}
.fgroup{display:flex;flex-direction:column;gap:.85rem}
.fgroup>label{font:500 .72rem/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--sand-300)}
.opt{color:var(--gray-dim);font-size:.85em;text-transform:none;letter-spacing:0}
.chipset--form{gap:.55rem}
.field.invalid input{border-bottom-color:var(--terra)}
.field.invalid label{color:var(--terra)}
.brief .btn--submit{margin-top:.2rem}
.brief__note{font-size:.8rem;color:var(--gray);text-align:center;margin-top:-.9rem}
.brief__note.ok{color:var(--gold-soft)}
.brief__note.err{color:var(--terra)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.btn--submit[disabled]{opacity:.55;pointer-events:none}

/* ---------- Footer ---------- */
.footer{position:relative;border-top:1px solid var(--line);overflow:hidden}
.footer__big{padding:clamp(2rem,5vw,3rem) var(--pad) 0;max-width:var(--maxw);margin:0 auto;overflow:hidden;line-height:.8}
.footer__big span{display:block;font-family:var(--serif);font-size:clamp(3.4rem,15vw,11.5rem);font-weight:400;letter-spacing:-.04em;line-height:.9;
  background:linear-gradient(180deg,var(--brown-500),rgba(90,70,54,.15) 92%);-webkit-background-clip:text;background-clip:text;color:transparent}
.footer__big span:last-child{margin-left:clamp(2rem,14vw,11rem)}
.footer__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:2rem var(--pad);display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1fr;gap:2rem;border-top:1px solid var(--line)}
.footer__brand{font-family:var(--serif);font-size:1.5rem;margin-bottom:.5rem}
.footer__tag{font-size:.85rem;color:var(--gray);line-height:1.5}
.footer__label{font:500 .72rem/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:1rem}
.footer__col a{display:block;color:var(--cream-dim);font-size:.92rem;padding:.28rem 0;transition:color .3s,transform .3s var(--ease)}
.footer__col a:hover{color:var(--gold);transform:translateX(4px)}
.footer__avail{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--cream-dim);margin-bottom:.8rem}
.pulse{width:8px;height:8px;border-radius:50%;background:#7bbf6a;box-shadow:0 0 0 0 rgba(123,191,106,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(123,191,106,.5)}70%{box-shadow:0 0 0 8px rgba(123,191,106,0)}100%{box-shadow:0 0 0 0 rgba(123,191,106,0)}}
.footer__cta{color:var(--gold)!important;font-weight:500}
.footer__base{max-width:var(--maxw);margin:0 auto;padding:1.4rem var(--pad);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--line);font:500 .78rem/1 var(--mono);color:var(--gray-dim)}
.footer__legal{color:var(--gray);transition:color .3s}
.footer__legal:hover{color:var(--gold)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .tiers{grid-template-columns:repeat(2,1fr)}
  .estimator{grid-template-columns:1fr}
  .result__sticky{position:static}
  .footer__inner{grid-template-columns:1fr 1fr}
  .cred__inner{grid-template-columns:1fr 1fr}
  .cred__item:nth-child(odd){border-left:none;padding-left:0}
  .cred__item:nth-child(n+3){border-top:1px solid var(--line)}
  .pricing__notes{grid-template-columns:1fr}
}
@media (max-width:820px){
  .nav__links{display:none}
  .nav .btn--nav{display:none}
  .nav__toggle{display:flex}
  .nav__toggle.open span:first-child{transform:translateY(3.5px) rotate(45deg)}
  .nav__toggle.open span:last-child{transform:translateY(-3px) rotate(-45deg)}
  .studio__grid{grid-template-columns:1fr}
  .studio__portrait{max-width:22rem}
  .contact__grid{grid-template-columns:1fr}
  .projects{grid-template-columns:1fr}
  .hero__scroll{display:none}
}
@media (max-width:560px){
  .cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .tiers{grid-template-columns:1fr}
  .addons{grid-template-columns:1fr}
  .brief__row{grid-template-columns:1fr;gap:1.8rem}
  .footer__inner{grid-template-columns:1fr;gap:1.6rem}
  .hero__stats{gap:1.4rem}
  .btn{width:100%;justify-content:center}
  .hero__actions .btn{width:auto}
  .cred__inner{grid-template-columns:1fr}
  .cred__item{border-left:none;padding:1.2rem 0}
  .cred__item:nth-child(n+2){border-top:1px solid var(--line)}
  .project--cta{flex-direction:column;align-items:flex-start}
  .cta__arrow{margin-left:0}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  [data-reveal],[data-reveal-word],[data-reveal-line]{opacity:1!important;transform:none!important}
  .cursor{display:none!important}
  body.has-cursor{cursor:auto!important}
}
