/* ============================================================
   AYA INNOVATIONS — design tokens
   ============================================================ */
:root{
  --cream:#F8F7F3;
  --cream-deep:#EFEDE4;
  --ink:#1A1A1A;
  --ink-soft:#34332F;
  --gold:#C39639;
  --gold-bright:#D8AC4B;
  --muted:#86827A;
  --line:rgba(26,26,26,.13);
  --line-soft:rgba(26,26,26,.07);
  --line-light:rgba(248,247,243,.16);
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Hanken Grotesk',sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
  text-size-adjust:100%;-webkit-text-size-adjust:100%;
}
body.menu-open{overflow:hidden;}
::selection{background:var(--gold);color:var(--ink);}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
section,header{position:relative;scroll-margin-top:84px;}

/* paper grain overlay */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.04;mix-blend-mode:multiply;
  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.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   typography helpers
   ============================================================ */
.display{
  font-family:'Fraunces',serif;
  font-weight:500;
  line-height:1;
  letter-spacing:-.018em;
}
.serif-it{font-family:'Fraunces',serif;font-style:italic;font-weight:400;}
.eyebrow{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.26em;
  font-weight:600;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:24px;height:1px;background:var(--gold);display:inline-block;
}
.eyebrow.center::after{
  content:"";width:24px;height:1px;background:var(--gold);display:inline-block;
}

/* ============================================================
   layout
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px;}
.section-pad{padding:140px 0;}

/* ============================================================
   buttons
   ============================================================ */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  font-size:.86rem;font-weight:600;letter-spacing:.02em;
  padding:17px 30px;border-radius:100px;cursor:pointer;
  transition:color .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease),transform .4s var(--ease);
  border:1px solid transparent;overflow:hidden;
}
.btn .arrow{transition:transform .45s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}
.btn-primary{background:var(--ink);color:var(--cream);}
.btn-primary:hover{background:var(--gold);color:var(--ink);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.btn-light{background:var(--cream);color:var(--ink);}
.btn-light:hover{background:var(--gold);color:var(--ink);}

/* ============================================================
   brand mark
   ============================================================ */
.mark{display:block;}
.mark .node{transform-box:fill-box;transform-origin:center;}
.wordmark{
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.04em;font-size:1.05rem;
}
.wordmark .y{color:var(--gold);}
.lockup{display:flex;align-items:center;gap:13px;}

/* ============================================================
   intro loader
   ============================================================ */
.loader{
  position:fixed;inset:0;z-index:9999;background:var(--cream);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transition:opacity .7s var(--ease),visibility .7s;
}
.loader.done{opacity:0;visibility:hidden;}
.loader .mark{width:64px;}
.loader-line{
  margin-top:26px;width:0;height:1px;background:var(--gold);
  animation:loadline 1s var(--ease) .15s forwards;
}
@keyframes loadline{to{width:120px;}}
.loader-label{
  margin-top:16px;font-size:.66rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--muted);
  opacity:0;animation:fadein .6s ease .5s forwards;
}
@keyframes fadein{to{opacity:1;}}
.draw{stroke-dasharray:240;stroke-dashoffset:240;animation:draw 1.1s var(--ease) forwards;}
@keyframes draw{to{stroke-dashoffset:0;}}

/* ============================================================
   navigation
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .45s var(--ease),box-shadow .45s var(--ease),padding .45s var(--ease);
  padding:26px 0;
}
.nav.scrolled{
  background:rgba(248,247,243,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-soft);
  padding:16px 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;}
.nav-links{display:flex;align-items:center;gap:38px;}
.nav-links a.link{
  font-size:.83rem;font-weight:500;letter-spacing:.01em;
  position:relative;color:var(--ink-soft);transition:color .3s var(--ease);
}
.nav-links a.link::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;
  background:var(--gold);transition:width .4s var(--ease);
}
.nav-links a.link:hover,.nav-links a.link.active{color:var(--ink);}
.nav-links a.link:hover::after,.nav-links a.link.active::after{width:100%;}
.nav .btn{padding:12px 24px;}
.nav-toggle{
  display:none;width:42px;height:42px;border:1px solid var(--line);
  border-radius:50%;background:transparent;cursor:pointer;
  position:relative;flex-shrink:0;
}
.nav-toggle span{
  position:absolute;left:11px;width:20px;height:1.6px;background:var(--ink);
  transition:transform .4s var(--ease),opacity .3s var(--ease);
}
.nav-toggle span:nth-child(1){top:16px;}
.nav-toggle span:nth-child(2){top:24px;}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(4px) rotate(45deg);}
body.menu-open .nav-toggle span:nth-child(2){transform:translateY(-4px) rotate(-45deg);}

/* mobile overlay menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--ink);
  display:flex;flex-direction:column;justify-content:safe center;padding:90px 48px;
  overflow-y:auto;
  transform:translateY(-100%);transition:transform .7s var(--ease);
}
body.menu-open .mobile-menu{transform:translateY(0);}
.mobile-menu a{
  font-family:'Fraunces',serif;font-size:clamp(2.4rem,9vw,3.6rem);
  color:var(--cream);padding:10px 0;display:flex;align-items:baseline;gap:18px;
  opacity:0;transform:translateY(20px);
}
body.menu-open .mobile-menu a{
  animation:menuin .6s var(--ease-out) forwards;
}
body.menu-open .mobile-menu a:nth-child(1){animation-delay:.18s;}
body.menu-open .mobile-menu a:nth-child(2){animation-delay:.25s;}
body.menu-open .mobile-menu a:nth-child(3){animation-delay:.32s;}
body.menu-open .mobile-menu a:nth-child(4){animation-delay:.39s;}
body.menu-open .mobile-menu a:nth-child(5){animation-delay:.46s;}
@keyframes menuin{to{opacity:1;transform:translateY(0);}}
.mobile-menu a .idx{font-family:'Hanken Grotesk',sans-serif;font-size:.8rem;color:var(--gold);font-weight:600;}
.mobile-menu .mm-foot{
  margin-top:48px;color:var(--muted);font-size:.85rem;
  display:flex;gap:24px;flex-wrap:wrap;
}
.mobile-menu .mm-foot a{font-family:'Hanken Grotesk',sans-serif;font-size:.85rem;color:var(--muted);padding:0;}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:160px 0 90px;overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.18fr .82fr;gap:40px;
  width:100%;align-items:center;
}
.hero-eyebrow{margin-bottom:34px;}
.hero h1{
  font-size:clamp(2.6rem,8.4vw,7.6rem);
  font-family:'Fraunces',serif;font-weight:500;
  line-height:.99;letter-spacing:-.024em;
}
.hero h1 em{
  font-style:italic;font-weight:400;color:var(--gold);
  position:relative;
}
.hero p.lead{
  margin-top:34px;max-width:480px;font-size:1.16rem;
  color:var(--ink-soft);line-height:1.62;
}
.hero-actions{margin-top:42px;display:flex;gap:14px;flex-wrap:wrap;}
.hero-visual{position:relative;height:520px;}
.hero-visual svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;}
#constellation{transition:transform .9s var(--ease-out);}
.star{transform-box:fill-box;transform-origin:center;}
.star.pulse{animation:starpulse 4s ease-in-out infinite;}
@keyframes starpulse{0%,100%{opacity:.5;}50%{opacity:1;}}

.hero-meta{
  margin-top:70px;display:flex;gap:48px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:28px;
}
.hero-meta .mi span{
  display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);margin-bottom:6px;font-weight:600;
}
.hero-meta .mi strong{
  font-family:'Fraunces',serif;font-weight:500;font-size:1.18rem;
}

/* scroll cue */
.scrollcue{
  position:absolute;left:48px;bottom:38px;display:flex;align-items:center;gap:12px;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);
}
.scrollcue .dot{
  width:24px;height:38px;border:1px solid var(--line);border-radius:14px;
  position:relative;
}
.scrollcue .dot::after{
  content:"";position:absolute;left:50%;top:8px;width:3px;height:6px;
  background:var(--gold);border-radius:2px;transform:translateX(-50%);
  animation:cue 1.8s var(--ease) infinite;
}
@keyframes cue{0%{opacity:0;transform:translate(-50%,0);}40%{opacity:1;}80%,100%{opacity:0;transform:translate(-50%,12px);}}

/* ============================================================
   marquee divider
   ============================================================ */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;overflow:hidden;white-space:nowrap;
}
.marquee-track{display:inline-flex;align-items:center;animation:slide 38s linear infinite;}
.marquee-track span{
  font-family:'Fraunces',serif;font-size:1.5rem;font-style:italic;
  color:var(--ink);padding:0 30px;display:inline-flex;align-items:center;gap:60px;
}
.marquee-track span::after{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);
}
@keyframes slide{to{transform:translateX(-50%);}}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{padding:150px 0;}
.manifesto .wrap{display:grid;grid-template-columns:.3fr .7fr;gap:40px;}
.manifesto-label{align-self:start;}
.manifesto h2{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(1.9rem,3.8vw,3.3rem);line-height:1.18;
  letter-spacing:-.015em;max-width:760px;
}
.manifesto h2 em{font-style:italic;color:var(--gold);font-weight:400;}
.manifesto .sig{
  margin-top:42px;display:flex;align-items:center;gap:16px;
  font-size:.86rem;color:var(--muted);
}
.manifesto .sig .ln{flex:0 0 60px;height:1px;background:var(--gold);}

/* section header (shared) */
.sec-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:30px;margin-bottom:72px;flex-wrap:wrap;
}
.sec-head h2{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(2.3rem,4.6vw,4rem);line-height:1.04;
  letter-spacing:-.02em;max-width:620px;
}
.sec-head h2 em{font-style:italic;color:var(--gold);font-weight:400;}
.sec-head .sh-side{max-width:330px;color:var(--ink-soft);font-size:1rem;}

/* ============================================================
   SERVICES
   ============================================================ */
.services .wrap{}
.svc-list{border-top:1px solid var(--line);}
.svc{
  display:grid;grid-template-columns:80px 1fr 1.1fr auto;
  gap:40px;align-items:start;padding:46px 0;
  border-bottom:1px solid var(--line);
  position:relative;transition:padding .5s var(--ease);
}
.svc::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:0;
  background:linear-gradient(90deg,rgba(195,150,57,.06),transparent 70%);
  transition:width .6s var(--ease);pointer-events:none;
}
.svc:hover::before{width:100%;}
.svc:hover{padding-left:18px;}
.svc-num{
  display:flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:600;color:var(--muted);letter-spacing:.06em;
}
.svc-num .nd{
  width:9px;height:9px;border-radius:50%;border:1.5px solid var(--gold);
  transition:background .4s var(--ease);
}
.svc:hover .svc-num .nd{background:var(--gold);}
.svc h3{
  font-family:'Fraunces',serif;font-weight:500;font-size:1.85rem;
  letter-spacing:-.01em;line-height:1.12;
}
.svc-desc{color:var(--ink-soft);font-size:1.02rem;line-height:1.6;}
.svc-tags{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap;}
.svc-tags span{
  font-size:.72rem;letter-spacing:.04em;color:var(--muted);
  border:1px solid var(--line);border-radius:100px;padding:5px 12px;
}
.svc-mark{
  width:46px;height:46px;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .45s var(--ease),border-color .45s var(--ease),transform .45s var(--ease);
}
.svc-mark svg{transition:stroke .45s var(--ease),transform .45s var(--ease);}
.svc:hover .svc-mark{background:var(--ink);border-color:var(--ink);transform:rotate(45deg);}
.svc:hover .svc-mark svg{stroke:var(--cream);}

/* ============================================================
   APPROACH (dark)
   ============================================================ */
.approach{
  background:var(--ink);color:var(--cream);
  padding:150px 0;overflow:hidden;
}
.approach .eyebrow{color:rgba(248,247,243,.55);}
.approach .eyebrow::before{background:var(--gold);}
.approach .sec-head h2{color:var(--cream);}
.approach .sec-head .sh-side{color:rgba(248,247,243,.6);}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line-light);
}
.step{
  padding:48px 40px;position:relative;
  border-right:1px solid var(--line-light);
}
.step:first-child{padding-left:0;}
.step:last-child{border-right:none;padding-right:0;}
.step:not(:last-child)::after{
  content:"";position:absolute;right:-4.5px;top:48px;
  width:8px;height:8px;border-radius:50%;background:var(--gold);
}
.step .snum{
  font-family:'Fraunces',serif;font-style:italic;font-size:3.4rem;
  color:var(--gold);line-height:1;font-weight:400;
}
.step h3{
  margin-top:18px;font-family:'Fraunces',serif;font-weight:500;
  font-size:1.45rem;
}
.step p{
  margin-top:12px;color:rgba(248,247,243,.62);font-size:.96rem;line-height:1.6;
}

/* ============================================================
   WORK
   ============================================================ */
.work{padding:150px 0;}
.work-grid{display:grid;grid-template-columns:minmax(0,720px);justify-content:center;gap:30px;}
.proj{
  cursor:pointer;position:relative;
}
.proj-canvas{
  aspect-ratio:1/.78;background:var(--cream-deep);border-radius:6px;
  overflow:hidden;position:relative;
  border:1px solid var(--line-soft);
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);
}
.proj-canvas svg{width:100%;height:100%;display:block;}
.proj:hover .proj-canvas{
  transform:translateY(-8px);
  box-shadow:0 30px 60px -28px rgba(26,26,26,.32);
}
.proj-chip{
  position:absolute;top:18px;left:18px;z-index:2;
  font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;
  background:rgba(248,247,243,.9);color:var(--muted);
  padding:6px 11px;border-radius:100px;font-weight:600;
  backdrop-filter:blur(4px);
}
.proj-meta{
  margin-top:20px;display:flex;justify-content:space-between;align-items:baseline;gap:20px;
}
.proj-meta h3{
  font-family:'Fraunces',serif;font-weight:500;font-size:1.7rem;
  display:flex;align-items:baseline;gap:12px;
}
.proj-meta h3 .pidx{font-family:'Hanken Grotesk',sans-serif;font-size:.78rem;color:var(--gold);font-weight:600;}
.proj-meta .pcat{font-size:.84rem;color:var(--muted);}
.proj-meta .parrow{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .4s var(--ease),transform .4s var(--ease);
}
.proj:hover .proj-meta .parrow{background:var(--gold);transform:rotate(-45deg);}
.work-note{
  margin-top:46px;text-align:center;font-size:.88rem;color:var(--muted);
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.work-note .ln{width:40px;height:1px;background:var(--line);}

/* ============================================================
   STUDIO FACTS
   ============================================================ */
.facts{
  background:var(--cream-deep);padding:90px 0;
}
.facts-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
}
.fact{text-align:left;}
.fact .fnum{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(2.6rem,4.5vw,3.6rem);line-height:1;letter-spacing:-.02em;
}
.fact .fnum em{font-style:italic;color:var(--gold);font-weight:400;}
.fact .flabel{
  margin-top:12px;font-size:.84rem;color:var(--ink-soft);
  padding-top:12px;border-top:1px solid var(--line);
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:150px 0 120px;}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;}
.contact h2{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(2.6rem,5.4vw,4.6rem);line-height:1.02;letter-spacing:-.022em;
}
.contact h2 em{font-style:italic;color:var(--gold);font-weight:400;}
.contact .c-lead{
  margin-top:28px;color:var(--ink-soft);max-width:420px;font-size:1.06rem;
}
.contact .c-loc{
  margin-top:40px;display:flex;align-items:center;gap:12px;
  font-size:.85rem;color:var(--muted);
}
.contact .c-loc .pin{width:7px;height:7px;border-radius:50%;background:var(--gold);}

.channels{display:flex;flex-direction:column;}
.channel{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:26px 4px;border-top:1px solid var(--line);
  transition:padding .45s var(--ease);
}
.channel:last-child{border-bottom:1px solid var(--line);}
.channel:hover{padding-left:16px;}
.channel .ch-l{display:flex;flex-direction:column;gap:3px;min-width:0;}
.channel .ch-type{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}
.channel .ch-val{
  font-family:'Fraunces',serif;font-size:1.5rem;font-weight:500;
  transition:color .35s var(--ease);overflow-wrap:anywhere;
}
.channel:hover .ch-val{color:var(--gold);}
.channel .ch-arrow{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .4s var(--ease),border-color .4s var(--ease);
}
.channel:hover .ch-arrow{background:var(--ink);border-color:var(--ink);}
.channel:hover .ch-arrow svg{stroke:var(--cream);transform:translate(2px,-2px);}
.channel .ch-arrow svg{transition:stroke .4s var(--ease),transform .4s var(--ease);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--ink);color:var(--cream);
  padding:90px 0 36px;
}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;
  padding-bottom:64px;border-bottom:1px solid var(--line-light);
}
.footer .wordmark .y{color:var(--gold);}
.footer-brand p{
  margin-top:22px;color:rgba(248,247,243,.55);max-width:300px;font-size:.95rem;
}
.footer-col h4{
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;font-weight:600;
}
.footer-col a{
  display:block;padding:7px 0;color:rgba(248,247,243,.66);
  font-size:.95rem;transition:color .3s var(--ease),transform .3s var(--ease);
}
.footer-col a:hover{color:var(--cream);transform:translateX(4px);}
.footer-bottom{
  padding-top:32px;display:flex;justify-content:space-between;
  align-items:center;gap:20px;flex-wrap:wrap;
  font-size:.8rem;color:rgba(248,247,243,.42);
}
.footer-bottom .totop{
  display:flex;align-items:center;gap:9px;cursor:pointer;
  color:rgba(248,247,243,.6);transition:color .3s var(--ease);
}
.footer-bottom .totop:hover{color:var(--gold);}

/* ============================================================
   reveal animations
   ============================================================ */
[data-rise]{opacity:0;transform:translateY(34px);
  transition:opacity 1s var(--ease-out),transform 1s var(--ease-out);}
[data-rise].in{opacity:1;transform:translateY(0);}
[data-rise].d1{transition-delay:.08s;}
[data-rise].d2{transition-delay:.16s;}
[data-rise].d3{transition-delay:.24s;}
[data-rise].d4{transition-delay:.32s;}

/* hero load sequence */
body:not(.loaded) .hero-stagger{opacity:0;transform:translateY(30px);}
.hero-stagger{
  transition:opacity 1s var(--ease-out),transform 1s var(--ease-out);
}
body.loaded .hero-stagger{opacity:1;transform:translateY(0);}
body.loaded .s1{transition-delay:.15s;}
body.loaded .s2{transition-delay:.27s;}
body.loaded .s3{transition-delay:.39s;}
body.loaded .s4{transition-delay:.51s;}
body.loaded .s5{transition-delay:.63s;}

/* ============================================================
   responsive
   ============================================================ */
/* nav contents stay visible over the dark mobile menu */
body.menu-open .nav{background:transparent;box-shadow:none;}
body.menu-open .nav .mark .nl{stroke:#F8F7F3;}
body.menu-open .nav .mark .nn{fill:#F8F7F3;}
body.menu-open .wordmark{color:#F8F7F3;}
body.menu-open .nav-toggle{border-color:rgba(248,247,243,.32);}
body.menu-open .nav-toggle span{background:#F8F7F3;}

/* ---- tablet / small laptop ---- */
@media(max-width:1080px){
  .wrap{padding:0 40px;}
  .section-pad{padding:118px 0;}
  .hero-grid{grid-template-columns:1fr;gap:8px;}
  .hero-visual{height:380px;order:-1;}
  .manifesto{padding:118px 0;}
  .manifesto .wrap{grid-template-columns:1fr;gap:24px;}
  .svc{grid-template-columns:64px 1fr;gap:16px 26px;}
  .svc-desc{grid-column:2/3;}
  .svc-mark{display:none;}
  .approach,.work,.contact{padding-top:118px;padding-bottom:118px;}
  .steps{grid-template-columns:1fr 1fr;column-gap:44px;}
  .step{border-right:none;border-bottom:1px solid var(--line-light);padding:42px 0;}
  .step:not(:last-child)::after{display:none;}
  .facts-grid{grid-template-columns:1fr 1fr;gap:40px 30px;}
  .contact-grid{grid-template-columns:1fr;gap:52px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:44px;}
}

/* ---- large phone / portrait tablet ---- */
@media(max-width:760px){
  body{font-size:16px;}
  .wrap{padding:0 24px;}
  .section-pad,.manifesto,.approach,.work,.contact{padding:90px 0;}
  .nav{padding:18px 0;}
  .nav.scrolled{padding:13px 0;}
  .nav-links{display:none;}
  .nav .btn{display:none;}
  .nav-toggle{display:flex;align-items:center;justify-content:center;}
  .scrollcue{display:none;}
  .hero{padding:118px 0 60px;min-height:auto;}
  .hero-eyebrow{margin-bottom:24px;}
  .hero p.lead{font-size:1.05rem;margin-top:24px;}
  .hero-actions{margin-top:32px;}
  .hero-visual{height:330px;}
  .hero-meta{gap:26px 34px;margin-top:44px;padding-top:22px;}
  .marquee{padding:20px 0;}
  .marquee-track span{font-size:1.12rem;padding:0 20px;gap:40px;}
  .manifesto .sig{margin-top:30px;}
  .sec-head{margin-bottom:44px;gap:18px;}
  .work-grid{grid-template-columns:1fr;gap:34px;}
  .contact .c-lead{font-size:1rem;}
  .contact .c-loc{margin-top:32px;}
  .channels{margin-top:4px;}
  .channel{padding:22px 2px;gap:14px;}
  .channel .ch-val{font-size:1.22rem;}
  .footer{padding:72px 0 32px;}
  .footer-top{grid-template-columns:1fr;gap:38px;padding-bottom:48px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px;}
}

/* ---- standard phone ---- */
@media(max-width:600px){
  .section-pad,.manifesto,.approach,.work,.contact{padding:78px 0;}
  .facts{padding:64px 0;}
  .hero h1{line-height:1.04;}
  .steps{grid-template-columns:1fr;}
  .step{padding:32px 0;}
  .step .snum{font-size:2.9rem;}
  .svc{grid-template-columns:1fr;gap:14px;padding:36px 0;}
  .svc-desc{grid-column:auto;}
  .svc h3{font-size:1.6rem;}
  .hero-visual{height:288px;}
  .sec-head{margin-bottom:38px;}
  .mobile-menu{padding:84px 28px;}
  .btn{padding:15px 25px;}
}

/* ---- small phone ---- */
@media(max-width:430px){
  .wrap{padding:0 20px;}
  .hero h1{font-size:2.3rem;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{justify-content:center;}
  .facts-grid{grid-template-columns:1fr;gap:28px;}
  .marquee-track span{font-size:1rem;}
  .channel .ch-val{font-size:1.1rem;}
}

/* ============================================================
   SIGNATURE LAYER — scroll progress, custom cursor, definition,
   starfield, giant footer type, tilt & magnetic affordances
   ============================================================ */

/* scroll progress hairline */
.progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:1002;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright));
  transform:scaleX(0);transform-origin:0 50%;pointer-events:none;
}

/* custom cursor — gold star-dot + trailing ring (pointer:fine only) */
body.has-cursor,
body.has-cursor a,
body.has-cursor button,
body.has-cursor .proj,
body.has-cursor .totop{cursor:none;}
.cur-dot{
  position:fixed;top:-4px;left:-4px;width:8px;height:8px;border-radius:50%;
  background:var(--gold);z-index:9990;pointer-events:none;
  transition:opacity .3s ease;
}
.cur-ring{
  position:fixed;top:-19px;left:-19px;width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(195,150,57,.55);z-index:9989;pointer-events:none;
  transition:width .35s var(--ease),height .35s var(--ease),
             top .35s var(--ease),left .35s var(--ease),
             border-color .35s var(--ease),opacity .3s ease;
}
body.cur-hover .cur-ring{
  width:62px;height:62px;top:-31px;left:-31px;
  border-color:var(--gold);
}

/* hero — "aya" dictionary entry */
.aya-def{
  margin-top:32px;max-width:480px;
  display:flex;align-items:center;gap:20px;
  padding:18px 22px;border:1px solid var(--line);border-radius:8px;
  background:rgba(239,237,228,.55);
  position:relative;
}
.aya-def::before{
  content:"";position:absolute;left:-1px;top:14px;bottom:14px;width:2px;
  background:var(--gold);border-radius:2px;
}
.aya-def .ar{
  font-family:'Amiri',serif;font-size:2.3rem;line-height:1;
  color:var(--gold);flex-shrink:0;
}
.aya-def .def-body{font-size:.88rem;color:var(--ink-soft);line-height:1.55;}
.aya-def .def-body em{font-family:'Fraunces',serif;font-size:1rem;}
.aya-def .phon{color:var(--muted);}
.aya-def .pos{font-style:italic;color:var(--muted);}
body.loaded .s6{transition-delay:.75s;}

/* hero em — drawn gold underline */
.hero h1 em::after{
  content:"";position:absolute;left:.02em;right:.02em;bottom:.03em;height:.055em;
  background:var(--gold);opacity:.4;border-radius:2px;
  transform:scaleX(0);transform-origin:left center;
  transition:transform .9s var(--ease-out) 1.15s;
}
body.loaded .hero h1 em::after{transform:scaleX(1);}

/* hero orbit ring — slow rotation */
.orbit{
  transform-box:fill-box;transform-origin:center;
  animation:orbit 80s linear infinite;
}
@keyframes orbit{to{transform:rotate(360deg);}}

/* marquee — bilingual + eight-point star separators */
.marquee-track .ar{
  font-family:'Amiri',serif;font-style:normal;font-size:1.55rem;
  color:var(--gold);
  direction:ltr; /* keep the ✦ separator on the trailing side of the flex row */
}
.marquee-track span::after{
  content:"✦";width:auto;height:auto;border-radius:0;background:none;
  color:var(--gold);font-size:.85rem;line-height:1;
}

/* approach — starfield night sky */
.approach .sky{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.approach .sky span{
  position:absolute;border-radius:50%;
  background:rgba(248,247,243,.5);opacity:.4;
  animation:twinkle 5s ease-in-out infinite;
}
@keyframes twinkle{0%,100%{opacity:.1;}50%{opacity:.85;}}
.approach .wrap{position:relative;z-index:1;}

/* work cards — 3D tilt stage */
.proj{perspective:1000px;}
.proj-canvas{will-change:transform;}

/* footer — monumental outlined wordmark */
.footer-giant{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(5rem,21vw,19rem);line-height:.84;
  text-align:center;letter-spacing:.02em;
  color:transparent;-webkit-text-stroke:1.5px rgba(248,247,243,.13);
  margin:70px 0 -8px;user-select:none;pointer-events:none;
}
.footer-giant .gy{-webkit-text-stroke-color:rgba(195,150,57,.4);}

/* project category line (was inline) */
.pcat{color:var(--muted);font-size:.84rem;margin-top:-12px;}

@media(max-width:760px){
  .aya-def{gap:16px;padding:15px 18px;}
  .aya-def .ar{font-size:1.9rem;}
  .aya-def .def-body{font-size:.82rem;}
  .footer-giant{margin:48px 0 -4px;}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .draw{stroke-dashoffset:0;}
  /* keep the marquee gently scrolling — much slower, non-distracting */
  .marquee-track{
    animation-duration:120s!important;
    animation-iteration-count:infinite!important;
  }
}
