/* ============================================================
   DIRECTION A — "Warm & Organic"
   Flow brand · Fraunces + Inter · blobs, curves, soft motion
   ============================================================ */
:root{
  --teal:#2E6E6A; --teal-700:#245855; --teal-900:#173a38;
  --sand:#F4EEE6; --sand-deep:#EDE4D6;
  --terra:#D77A5A; --terra-600:#c26847;
  --ink:#2D2D2D; --ink-soft:#54514c; --ink-faint:#8a857d;
  --bg:#FAF9F7; --paper:#fff;
  --line:rgba(45,45,45,.10); --line-soft:rgba(45,45,45,.06);
  --display:"Fraunces",Georgia,serif; --body:"Inter",system-ui,sans-serif;
  --maxw:1180px; --gutter:clamp(1.25rem,5vw,3.5rem);
  --ease:cubic-bezier(.22,.61,.36,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --blob:50% 50% 50% 50%/60% 60% 40% 40%;
}
*,*::before,*::after{box-sizing:border-box;}*{margin:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.6;font-size:1.0625rem;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;cursor:pointer;}
::selection{background:var(--terra);color:#fff;}

h1,h2,h3,h4{font-family:var(--display);font-weight:460;line-height:1.02;letter-spacing:-.018em;color:var(--ink);text-wrap:balance;font-optical-sizing:auto;}
.eyebrow{font-family:var(--body);font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:.6rem;}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--terra);}
.eyebrow.c::before{display:none;}
em{font-style:italic;color:var(--teal);}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.sec{padding-block:clamp(4.5rem,10vw,8rem);position:relative;}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);}
[data-reveal="fade"]{transform:none;}
[data-reveal="left"]{transform:translateX(-40px);}
[data-reveal="right"]{transform:translateX(40px);}
[data-reveal="scale"]{transform:scale(.92);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal-delay="1"]{transition-delay:.08s;}[data-reveal-delay="2"]{transition-delay:.16s;}
[data-reveal-delay="3"]{transition-delay:.24s;}[data-reveal-delay="4"]{transition-delay:.32s;}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important;}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:1rem 1.7rem;font-weight:600;font-size:1rem;border-radius:100px;border:1.5px solid transparent;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,border-color .3s,color .3s;white-space:nowrap;}
.btn .ar{transition:transform .35s var(--ease);}
.btn:hover .ar{transform:translateX(4px);}
.btn-pri{background:var(--teal);color:#fff;box-shadow:0 14px 34px rgba(46,110,106,.3);}
.btn-pri:hover{background:var(--teal-700);transform:translateY(-2px);box-shadow:0 20px 44px rgba(46,110,106,.38);}
.btn-acc{background:var(--terra);color:#fff;box-shadow:0 14px 34px rgba(215,122,90,.32);}
.btn-acc:hover{background:var(--terra-600);transform:translateY(-2px);}
.btn-gho{background:transparent;color:var(--ink);border-color:var(--line);}
.btn-gho:hover{border-color:var(--ink);transform:translateY(-2px);}
.btn-lg{padding:1.15rem 2rem;font-size:1.06rem;}
.tlink{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--teal);position:relative;}
.tlink::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);}
.tlink:hover::after{transform:scaleX(1);}
.tlink:hover .ar{transform:translateX(4px);}.tlink .ar{transition:transform .3s var(--ease);}

/* blobs */
.blob{position:absolute;border-radius:50%;filter:blur(6px);pointer-events:none;z-index:0;}

/* ---------- NAV ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;padding:1.1rem 0;transition:.4s var(--ease);}
.nav.scrolled{background:rgba(250,249,247,.82);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);box-shadow:0 1px 0 var(--line-soft),0 8px 30px rgba(45,45,45,.05);padding:.7rem 0;}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:2rem;}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:500;font-size:1.3rem;letter-spacing:-.02em;}
.brand svg{width:34px;height:34px;}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{font-size:.95rem;font-weight:500;color:var(--ink-soft);position:relative;transition:color .25s;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:0;background:var(--terra);transition:width .3s var(--ease);}
.nav-links a:hover{color:var(--ink);}.nav-links a:hover::after{width:100%;}
.burger{display:none;width:44px;height:44px;border:none;background:transparent;flex-direction:column;gap:5px;align-items:center;justify-content:center;}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;}

/* ---------- HERO ---------- */
.hero{padding-top:clamp(9rem,18vh,13rem);padding-bottom:clamp(3rem,6vw,5rem);text-align:center;position:relative;overflow:hidden;}
.hero-blob-1{width:520px;height:520px;background:radial-gradient(circle at 35% 35%,rgba(215,122,90,.30),transparent 70%);left:-10%;top:-8%;}
.hero-blob-2{width:560px;height:560px;background:radial-gradient(circle at 50% 50%,rgba(46,110,106,.22),transparent 70%);right:-12%;top:10%;}
.hero-inner{position:relative;z-index:2;max-width:960px;margin-inline:auto;}
.pill-tag{display:inline-flex;align-items:center;gap:.5rem;background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--ink-soft);box-shadow:0 6px 20px rgba(45,45,45,.05);}
.pill-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);position:relative;}
.pill-tag .dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--teal);opacity:0;animation:pulse 2.6s var(--ease) infinite;}
@keyframes pulse{0%{transform:scale(.6);opacity:.7;}80%,100%{transform:scale(1.7);opacity:0;}}
.hero h1{font-size:clamp(2.9rem,7.6vw,6rem);line-height:1.0;letter-spacing:-.03em;margin:1.6rem 0 0;padding-bottom:.08em;}
.hero h1 .em{color:var(--teal);font-style:italic;}
.hero h1 .un{position:relative;white-space:nowrap;}
.hero h1 .un svg{position:absolute;left:0;right:0;bottom:-.12em;width:100%;height:.35em;color:var(--terra);}
.hero-lead{font-size:clamp(1.12rem,1.7vw,1.35rem);color:var(--ink-soft);max-width:48ch;margin:2.4rem auto 0;line-height:1.55;text-wrap:pretty;}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.4rem;}
/* orbiting chips */
.orbit{position:absolute;z-index:3;background:var(--paper);border:1px solid var(--line-soft);border-radius:18px;box-shadow:0 12px 32px rgba(45,45,45,.10);padding:.8rem 1rem;display:flex;align-items:center;gap:.6rem;}
.orbit .ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none;}
.orbit b{font-weight:600;font-size:.88rem;}
.orbit .s{font-size:.74rem;color:var(--ink-faint);}
.o1{left:2%;top:34%;} .o2{right:1%;top:28%;} .o3{left:7%;bottom:16%;} .o4{right:6%;bottom:12%;}
@media(max-width:900px){.o1,.o2,.o3,.o4{display:none;}}

/* ---------- MARQUEE ---------- */
.marquee{padding:1.4rem 0;background:var(--teal);overflow:hidden;white-space:nowrap;border-radius:40px;margin:0 var(--gutter);}
.marquee-track{display:inline-flex;align-items:center;gap:2.5rem;animation:scroll 26s linear infinite;will-change:transform;}
.marquee:hover .marquee-track{animation-play-state:paused;}
@keyframes scroll{to{transform:translateX(-50%);}}
.marquee span{font-family:var(--display);font-size:clamp(1.3rem,2.4vw,2rem);color:#fff;font-style:italic;font-weight:400;}
.marquee .dotsep{width:9px;height:9px;border-radius:50%;background:var(--terra);display:inline-block;}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

/* ---------- WHAT WE MAKE ---------- */
.head{max-width:680px;}
.head.c{margin-inline:auto;text-align:center;}
.head h2{font-size:clamp(2rem,4.4vw,3.4rem);margin-top:1.1rem;}
.head p{font-size:clamp(1.08rem,1.6vw,1.3rem);color:var(--ink-soft);margin-top:1.1rem;line-height:1.55;text-wrap:pretty;}
.make-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:clamp(2.5rem,5vw,3.6rem);}
.make{position:relative;background:var(--paper);border:1px solid var(--line-soft);border-radius:28px;padding:2.2rem 2rem 2.4rem;box-shadow:0 2px 10px rgba(45,45,45,.04);transition:transform .5s var(--ease),box-shadow .5s var(--ease);overflow:hidden;}
.make:nth-child(2){transform:translateY(28px);}
.make:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(45,45,45,.13);}
.make:nth-child(2):hover{transform:translateY(22px);}
.make .mblob{position:absolute;width:160px;height:160px;border-radius:var(--blob);right:-30px;top:-30px;opacity:.5;transition:transform .6s var(--ease);}
.make:hover .mblob{transform:rotate(40deg) scale(1.1);}
.make:nth-child(1) .mblob{background:rgba(46,110,106,.16);}
.make:nth-child(2) .mblob{background:rgba(215,122,90,.18);}
.make:nth-child(3) .mblob{background:rgba(46,110,106,.16);}
.make .mic{position:relative;width:60px;height:60px;border-radius:18px;display:grid;place-items:center;margin-bottom:1.4rem;background:var(--sand);color:var(--teal);}
.make:nth-child(2) .mic{color:var(--terra);}
.make .tag{position:relative;display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);margin-bottom:.7rem;}
.make h3{position:relative;font-size:1.5rem;margin-bottom:.6rem;}
.make p{position:relative;color:var(--ink-soft);font-size:.98rem;}
.make ul{position:relative;list-style:none;margin-top:1.2rem;display:flex;flex-direction:column;gap:.55rem;}
.make li{display:flex;gap:.55rem;font-size:.93rem;color:var(--ink-soft);}
.make li svg{flex:none;margin-top:3px;color:var(--teal);}

/* ---------- SHOWCASE ---------- */
.work{background:var(--sand);border-radius:60px 60px 0 0;}
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem;margin-top:clamp(2.5rem,5vw,3.6rem);}
.proj{position:relative;background:var(--paper);border-radius:32px;overflow:hidden;box-shadow:0 10px 40px rgba(45,45,45,.10);transition:transform .55s var(--ease),box-shadow .55s var(--ease);}
.proj:nth-child(2){margin-top:3rem;}
.proj:hover{transform:translateY(-8px);box-shadow:0 34px 70px rgba(45,45,45,.16);}
.proj-media{aspect-ratio:16/11;overflow:hidden;position:relative;}
.proj-media image-slot{width:100%;height:100%;}
.proj-body{padding:1.8rem 1.9rem 2rem;}
.proj-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;}
.chip{font-size:.76rem;font-weight:600;color:var(--teal);background:rgba(46,110,106,.10);padding:.35rem .8rem;border-radius:100px;}
.proj h3{font-size:1.7rem;margin-bottom:.5rem;}
.proj p{color:var(--ink-soft);font-size:.98rem;margin-bottom:1.2rem;}

/* ---------- STATEMENT ---------- */
.statement{background:var(--teal);color:#fff;text-align:center;overflow:hidden;}
.statement .blob{width:600px;height:600px;background:radial-gradient(circle,rgba(215,122,90,.34),transparent 64%);right:-14%;top:-40%;}
.statement-in{position:relative;z-index:2;max-width:900px;margin-inline:auto;}
.statement h2{color:#fff;font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.08;}
.statement h2 em{color:var(--sand);}
.statement .sub{color:rgba(255,255,255,.82);font-size:clamp(1.1rem,1.7vw,1.35rem);margin-top:1.4rem;max-width:46ch;margin-inline:auto;}
.stat-row{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(2rem,6vw,5rem);margin-top:clamp(2.5rem,5vw,3.6rem);}
.stat .n{font-family:var(--display);font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;}
.stat .n .suf{color:var(--terra);}
.stat .l{color:rgba(255,255,255,.82);margin-top:.5rem;font-size:.98rem;max-width:22ch;}

/* ---------- HOW ---------- */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:clamp(2.5rem,5vw,3.6rem);counter-reset:s;position:relative;}
.stepc{position:relative;background:var(--paper);border:1px solid var(--line-soft);border-radius:26px;padding:2rem 1.9rem;box-shadow:0 2px 10px rgba(45,45,45,.04);transition:transform .5s var(--ease),box-shadow .5s var(--ease);}
.stepc:hover{transform:translateY(-6px);box-shadow:0 24px 56px rgba(45,45,45,.12);}
.stepc .num{counter-increment:s;font-family:var(--display);font-size:1.4rem;color:#fff;width:52px;height:52px;border-radius:var(--blob);background:var(--terra);display:grid;place-items:center;margin-bottom:1.2rem;}
.stepc:nth-child(2) .num{background:var(--teal);}
.stepc .num::before{content:"0" counter(s);}
.stepc h4{font-size:1.3rem;margin-bottom:.5rem;}
.stepc p{color:var(--ink-soft);font-size:.96rem;}

/* ---------- CTA ---------- */
.cta{padding-block:clamp(4rem,8vw,6.5rem);}
.cta-card{position:relative;background:var(--ink);color:#fff;border-radius:44px;padding:clamp(3rem,7vw,5.5rem) clamp(1.6rem,6vw,5rem);text-align:center;overflow:hidden;}
.cta-card .b1{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(46,110,106,.6),transparent 62%);left:-14%;top:-40%;filter:blur(6px);}
.cta-card .b2{position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(215,122,90,.46),transparent 62%);right:-12%;bottom:-44%;filter:blur(6px);}
.cta-card>*{position:relative;z-index:2;}
.cta-card h2{color:#fff;font-size:clamp(2rem,4.6vw,3.4rem);max-width:18ch;margin-inline:auto;}
.cta-card h2 em{color:var(--terra);}
.cta-card p{color:rgba(255,255,255,.8);font-size:1.15rem;margin:1.3rem auto 0;max-width:44ch;}
.cta-card .hero-cta{margin-top:2.2rem;}
.cta-meta{margin-top:1.7rem;color:rgba(255,255,255,.6);font-size:.92rem;display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;justify-content:center;}
.cta-meta span{display:inline-flex;align-items:center;gap:.45rem;}

/* ---------- FOOTER ---------- */
.foot{padding:clamp(2.5rem,5vw,3.5rem) 0 2.2rem;}
.foot-in{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;align-items:center;}
.foot .brand{font-size:1.3rem;}
.foot-links{display:flex;flex-wrap:wrap;gap:1.6rem;list-style:none;}
.foot-links a{color:var(--ink-soft);font-size:.95rem;transition:color .25s;}
.foot-links a:hover{color:var(--teal);}
.foot-bottom{margin-top:2rem;padding-top:1.4rem;border-top:1px solid var(--line-soft);color:var(--ink-faint);font-size:.86rem;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;}
.foot-tag{font-family:var(--display);font-style:italic;color:var(--teal);}

/* ---------- mobile drawer ---------- */
.drawer{display:none;position:fixed;inset:0;z-index:99;background:var(--bg);padding:6rem var(--gutter) 2rem;transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .5s var(--ease),opacity .4s;}
.drawer.show{transform:translateY(0);opacity:1;pointer-events:auto;}
.drawer ul{list-style:none;display:flex;flex-direction:column;gap:.3rem;}
.drawer a{font-family:var(--display);font-size:1.9rem;padding:.5rem 0;display:block;border-bottom:1px solid var(--line-soft);}
.drawer .btn{margin-top:1.4rem;width:100%;}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .nav-links,.nav .btn-desktop{display:none;}
  .burger{display:flex;}
  .make-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto;}
  .make:nth-child(2){transform:none;}.make:nth-child(2):hover{transform:translateY(-6px);}
  .gallery{grid-template-columns:1fr;}.proj:nth-child(2){margin-top:0;}
  .how-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto;}
}
@media(max-width:540px){
  .hero-cta{flex-direction:column;}.hero-cta .btn{width:100%;}
  .work{border-radius:36px 36px 0 0;}
}

/* ---------- production additions ---------- */
/* real project images in place of design-tool image-slots */
.proj-media img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .6s var(--ease);}
.proj:hover .proj-media img{transform:scale(1.04);}

/* accessibility: skip link + visible focus */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--teal);color:#fff;
  padding:.7rem 1.1rem;border-radius:0 0 12px 0;font-weight:600;font-size:.9rem;}
.skip-link:focus{left:0;}
a:focus-visible,.btn:focus-visible,button:focus-visible{outline:2px solid var(--terra);outline-offset:3px;border-radius:8px;}
