/* ============================================================
   WIGGLY STUDIO — Landing page
   ============================================================ */
:root{
  --bg:        #0a0a0b;
  --bg-soft:   #121214;
  --ink:       #f3efe7;   /* warm cream */
  --ink-dim:   #8c8a85;
  --blue:      #a9cdf4;   /* brand periwinkle */
  --blue-deep: #6fa9ec;
  --line:      rgba(243,239,231,.12);
  --easing:    cubic-bezier(.6,.01,.05,1);
  --pad:       clamp(20px, 5vw, 80px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:400;
  line-height:1.4;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:auto;
}
body.loading{overflow:hidden;height:100vh}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--blue);color:#08203b}

/* ---- Display type helper ---- */
.disp{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;
  letter-spacing:-.02em;
  line-height:.92;
}

/* ============================================================
   GRAIN + CURSOR
   ============================================================ */
.grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.cursor{
  position:fixed;top:0;left:0;z-index:10000;pointer-events:none;
  width:14px;height:14px;border-radius:50%;
  background:var(--blue);
  transform:translate(-50%,-50%);
  transition:width .3s var(--easing),height .3s var(--easing),background .3s,mix-blend-mode .2s;
  mix-blend-mode:difference;
  display:flex;align-items:center;justify-content:center;
}
.cursor.is-hover{width:64px;height:64px;background:var(--ink)}
.cursor.is-label{width:84px;height:84px;background:var(--blue);mix-blend-mode:normal}
.cursor__label{
  font-size:11px;font-weight:500;color:#08203b;opacity:0;
  text-transform:uppercase;letter-spacing:.05em;transition:opacity .2s;
  font-family:'Inter';
}
.cursor.is-label .cursor__label{opacity:1}
@media (hover:none){.cursor{display:none}}

/* ============================================================
   LOADER
   ============================================================ */
.loader{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
.loader__inner{width:min(60vw,360px);text-align:center}
.loader__logo{width:140px;margin:0 auto 32px;opacity:.95}
.loader__bar{height:2px;background:var(--line);position:relative;overflow:hidden;border-radius:2px}
.loader__bar span{position:absolute;inset:0;width:0;background:var(--blue);transition:width .2s linear}
.loader__count{margin-top:14px;font-size:12px;letter-spacing:.1em;color:var(--ink-dim)}

/* ============================================================
   SOUND TOGGLE
   ============================================================ */
.sound{
  position:fixed;right:var(--pad);bottom:28px;z-index:200;
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;border:1px solid var(--line);border-radius:40px;
  background:rgba(10,10,11,.5);backdrop-filter:blur(8px);
  font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);
  transition:border-color .3s,color .3s;
}
.sound:hover{border-color:var(--blue);color:var(--ink)}
.sound__bars{display:flex;align-items:flex-end;gap:2px;height:14px}
.sound__bars i{width:2px;height:4px;background:var(--blue);border-radius:2px;transition:height .2s}
.sound.is-on .sound__bars i{animation:eq .8s ease-in-out infinite}
.sound.is-on .sound__bars i:nth-child(2){animation-delay:.15s}
.sound.is-on .sound__bars i:nth-child(3){animation-delay:.3s}
.sound.is-on .sound__bars i:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:4px}50%{height:14px}}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  background:transparent;
  backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);
  border-bottom:1px solid transparent;
  transition:background .45s var(--easing),border-color .45s var(--easing),padding .45s var(--easing),backdrop-filter .45s var(--easing);
}
.nav.is-scrolled{
  background:rgba(10,10,11,.6);
  backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
  padding:13px var(--pad);
}
.nav__logo img{width:100px;transition:transform .4s var(--easing)}
.nav__logo:hover img{transform:rotate(-3deg) scale(1.04)}
.nav__links{display:flex;align-items:center;gap:8px;font-size:14px}
.nav__links a{
  position:relative;color:var(--ink);opacity:.82;
  padding:9px 15px;border-radius:30px;
  transition:opacity .3s,background .35s var(--easing),color .3s;
}
.nav__links a:not(.nav__cta):hover{opacity:1;background:rgba(243,239,231,.08)}
.nav__links a:not(.nav__cta)::after{
  content:'';position:absolute;left:15px;bottom:4px;width:0;height:1px;background:var(--blue);
  transition:width .35s var(--easing);
}
.nav__links a:not(.nav__cta):hover::after{width:calc(100% - 30px)}
.nav__cta{display:flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid var(--ink);border-radius:30px;margin-left:14px;transition:background .3s,color .3s,border-color .3s}
.nav__cta:hover{background:var(--blue);border-color:var(--blue);color:#08203b}
.nav__cta span{font-size:12px}
.nav__burger{display:none;flex-direction:column;gap:5px;width:28px}
.nav__burger span{height:1.6px;width:100%;background:var(--ink);transition:.3s var(--easing)}
body.menu-open .nav__burger span:nth-child(1){transform:translateY(3.3px) rotate(45deg)}
body.menu-open .nav__burger span:nth-child(2){transform:translateY(-3.3px) rotate(-45deg)}

/* Mobile menu */
.menu{
  position:fixed;inset:0;z-index:250;background:var(--bg-soft);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 var(--pad);
  transform:translateY(-100%);transition:transform .7s var(--easing);
}
body.menu-open .menu{transform:translateY(0)}
.menu a{
  font-family:'Bricolage Grotesque';font-weight:600;font-size:13vw;line-height:1.05;
  letter-spacing:-.02em;color:var(--ink);opacity:0;transform:translateY(30px);
  transition:opacity .5s,transform .5s,color .3s;
}
.menu a:hover{color:var(--blue)}
body.menu-open .menu a{opacity:1;transform:translateY(0)}
body.menu-open .menu a:nth-child(1){transition-delay:.18s}
body.menu-open .menu a:nth-child(2){transition-delay:.26s}
body.menu-open .menu a:nth-child(3){transition-delay:.34s}
body.menu-open .menu a:nth-child(4){transition-delay:.42s}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(120px,16vh,170px) var(--pad) 96px;overflow:hidden;
}
#webgl{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero__inner{position:relative;z-index:3;max-width:1400px;margin:0 auto;width:100%}
.hero__eyebrow{
  font-size:13px;text-transform:uppercase;letter-spacing:.2em;color:var(--blue);
  margin-bottom:30px;overflow:hidden;
}
.hero__eyebrow span{display:inline-block}
.hero__title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:clamp(48px,9.6vw,150px);line-height:.92;letter-spacing:-.03em;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .word{display:inline-block;transform:translateY(110%)}
.hero__title .amp{color:var(--blue);font-style:italic;font-family:'Bricolage Grotesque'}
.hero__sub{
  margin-top:32px;max-width:54ch;font-size:clamp(15px,1.5vw,19px);color:var(--ink-dim);line-height:1.7;
}
.hero__actions{margin-top:42px;display:flex;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 26px;border-radius:40px;
  font-size:15px;font-weight:500;white-space:nowrap;transition:transform .4s var(--easing),background .3s,color .3s;
}
.btn span{transition:transform .3s var(--easing)}
.btn:hover span{transform:translate(3px,-3px)}
.btn--primary{background:var(--blue);color:#08203b}
.btn--primary:hover{background:var(--ink)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink)}
.hero__scroll{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-dim);
}
.hero__scroll i{width:1px;height:34px;background:var(--ink-dim);position:relative;overflow:hidden}
.hero__scroll i::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;background:var(--blue);animation:scrolldn 1.8s var(--easing) infinite}
@keyframes scrolldn{to{top:100%}}
.hero__wordmark{
  position:absolute;left:0;bottom:-4%;width:100%;z-index:1;opacity:.05;pointer-events:none;
  display:flex;justify-content:center;
}
.hero__wordmark img{width:120%;max-width:none}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;overflow:hidden;white-space:nowrap;background:var(--bg);
}
.marquee__track{display:inline-flex;will-change:transform}
.marquee__track span{
  font-family:'Bricolage Grotesque';font-weight:600;font-size:clamp(28px,4.4vw,58px);
  letter-spacing:-.01em;padding-right:.4em;
}
.marquee__track i{color:var(--blue);font-style:normal;padding:0 .25em;font-size:.6em;vertical-align:middle}

/* ============================================================
   SECTION SHARED
   ============================================================ */
.section__index{
  font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-dim);
  margin-bottom:42px;
}
.section__index.light{color:var(--ink-dim)}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(90px,14vh,180px) var(--pad)}
.about__statement{
  font-family:'Bricolage Grotesque';font-weight:500;
  font-size:clamp(28px,5.2vw,76px);line-height:1.04;letter-spacing:-.02em;
  max-width:18ch;
}
.about__statement .w{display:block;overflow:hidden}
.about__statement .w span,
.about__statement .w em{display:inline-block}
.about__statement em{font-style:italic;color:var(--blue)}
.about__meta{
  margin-top:90px;display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  border-top:1px solid var(--line);padding-top:50px;
}
.about__col h3{font-size:20px;font-weight:600;margin-bottom:14px;font-family:'Bricolage Grotesque'}
.about__col p{color:var(--ink-dim);font-size:15px;line-height:1.75;max-width:36ch}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:clamp(60px,8vh,120px) 0 0}
.services__head{padding:0 var(--pad);margin-bottom:84px}
.services__head .section__index{margin-bottom:44px}
.services__headrow{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(30px,5vw,72px);align-items:end}
.services__title{
  font-family:'Bricolage Grotesque';font-weight:700;
  font-size:clamp(40px,7.5vw,116px);line-height:.94;letter-spacing:-.03em;
}
.service{
  position:relative;display:grid;grid-template-columns:120px 1fr 320px;gap:40px;align-items:center;
  padding:56px var(--pad);border-top:1px solid var(--line);overflow:hidden;
  transition:color .45s var(--easing);
}
.service::before{
  content:'';position:absolute;inset:0;background:var(--ink);z-index:0;
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .55s var(--easing);
}
.service:hover::before{transform:scaleY(1)}
.service>*{position:relative;z-index:1}
.service:last-child{border-bottom:1px solid var(--line)}
.service__num{
  font-family:'Bricolage Grotesque';font-weight:700;font-size:clamp(40px,5vw,72px);
  color:transparent;-webkit-text-stroke:1px var(--ink-dim);line-height:1;
  transition:-webkit-text-stroke .4s,color .4s;
}
.service:hover .service__num{color:var(--blue-deep);-webkit-text-stroke:1px var(--blue-deep)}
.service__name{
  display:flex;align-items:center;gap:.4em;flex-wrap:wrap;
  font-family:'Bricolage Grotesque';font-weight:600;
  font-size:clamp(28px,4vw,52px);line-height:1;letter-spacing:-.02em;margin-bottom:18px;
  transition:transform .45s var(--easing),color .4s;
}
.service__arrow{
  display:inline-flex;font-size:.7em;color:var(--blue-deep);
  opacity:0;transform:translateX(-14px);
  transition:opacity .45s var(--easing),transform .45s var(--easing);
}
.service:hover .service__name{transform:translateX(14px);color:#0a0a0b}
.service:hover .service__arrow{opacity:1;transform:translateX(0)}
.service__desc{color:var(--ink-dim);font-size:clamp(14px,1.4vw,17px);line-height:1.75;max-width:58ch;transition:color .4s,transform .45s var(--easing)}
.service:hover .service__desc{color:rgba(10,10,11,.66);transform:translateX(14px)}
.service__tags{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;transition:transform .45s var(--easing)}
.service:hover .service__tags{transform:translateX(14px)}
.service__tags li{
  font-size:12px;color:var(--ink);border:1px solid var(--line);border-radius:30px;
  padding:7px 14px;transition:border-color .3s,color .3s,background .3s;
}
.service:hover .service__tags li{border-color:rgba(10,10,11,.18);color:#0a0a0b;background:rgba(10,10,11,.04)}
.service__visual{
  height:200px;border-radius:18px;border:1px solid var(--line);position:relative;overflow:hidden;
  background:radial-gradient(120% 120% at 70% 20%,rgba(169,205,244,.16),transparent 60%);
  transition:background .45s var(--easing),border-color .45s var(--easing);
}
.service:hover .service__visual{background:#0a0a0b;border-color:rgba(10,10,11,.15)}
.service__visual::before{
  content:'';position:absolute;inset:0;
  background-position:center;background-repeat:no-repeat;background-size:contain;
  opacity:.9;transition:transform .8s var(--easing);
}
.service__visual[data-shape="mail"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 140'%3E%3Cg fill='none' stroke='%23a9cdf4' stroke-width='2.4'%3E%3Crect x='40' y='38' width='120' height='80' rx='8'/%3E%3Cpath d='M40 50l60 40 60-40'/%3E%3C/g%3E%3C/svg%3E");
}
.service__visual[data-shape="bot"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 140'%3E%3Cg fill='none' stroke='%23a9cdf4' stroke-width='2.4'%3E%3Crect x='62' y='48' width='76' height='60' rx='12'/%3E%3Ccircle cx='84' cy='78' r='6'/%3E%3Ccircle cx='116' cy='78' r='6'/%3E%3Cpath d='M100 30v18M86 108v12M114 108v12'/%3E%3Ccircle cx='100' cy='26' r='5'/%3E%3C/g%3E%3C/svg%3E");
}
.service:hover .service__visual::before{transform:scale(1.08) rotate(2deg)}

/* ============================================================
   PROCESS
   ============================================================ */
.process{padding:clamp(90px,14vh,180px) var(--pad)}
.process__head{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:end;margin-bottom:80px}
.process__title{font-family:'Bricolage Grotesque';font-weight:700;font-size:clamp(40px,7vw,104px);line-height:.92;letter-spacing:-.03em}
.process__lead{color:var(--ink-dim);font-size:clamp(15px,1.6vw,20px);max-width:40ch;line-height:1.65}
.process__steps{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{position:relative;background:var(--bg);padding:48px;overflow:hidden;transition:color .45s var(--easing)}
.step::before{
  content:'';position:absolute;inset:0;background:var(--ink);z-index:0;
  transform:translateY(101%);transition:transform .55s var(--easing);
}
.step:hover::before{transform:translateY(0)}
.step::after{
  content:'\2197';position:absolute;top:40px;right:44px;z-index:1;
  font-size:24px;color:#0a0a0b;opacity:0;transform:translate(-8px,8px);
  transition:opacity .45s var(--easing),transform .45s var(--easing);
}
.step:hover::after{opacity:1;transform:translate(0,0)}
.step>*{position:relative;z-index:1}
.step__no{font-size:12px;letter-spacing:.12em;color:var(--blue);display:block;margin-bottom:26px;transition:color .4s}
.step:hover .step__no{color:var(--blue-deep)}
.step h3{font-family:'Bricolage Grotesque';font-weight:600;font-size:clamp(22px,2.4vw,32px);line-height:1.08;margin-bottom:18px;letter-spacing:-.01em;transition:color .4s}
.step:hover h3{color:#0a0a0b}
.step p{color:var(--ink-dim);font-size:15px;line-height:1.75;max-width:42ch;transition:color .4s}
.step:hover p{color:rgba(10,10,11,.66)}

/* ============================================================
   CTA
   ============================================================ */
.cta{padding:clamp(100px,18vh,220px) var(--pad);text-align:center;position:relative;overflow:hidden}
.cta__eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--blue);margin-bottom:36px}
.cta__title{
  font-family:'Bricolage Grotesque';font-weight:700;
  font-size:clamp(44px,10vw,150px);line-height:.92;letter-spacing:-.03em;
}
.cta__title .line{display:block;overflow:hidden}
.cta__title .line>span{display:inline-block}
.cta__title .accent{color:var(--blue);font-style:italic}
.cta__title .arrow{color:var(--blue)}
.cta__btn{
  display:inline-flex;align-items:center;gap:10px;margin-top:54px;
  padding:20px 38px;border-radius:50px;background:var(--ink);color:#0a0a0b;
  font-size:18px;font-weight:500;transition:transform .4s var(--easing),background .3s;
}
.cta__btn span{transition:transform .3s var(--easing)}
.cta__btn:hover{background:var(--blue)}
.cta__btn:hover span{transform:translate(4px,-4px)}
.cta__actions{margin-top:54px;display:flex;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap}
.cta__alt{font-size:15px;color:var(--ink-dim);transition:color .3s}
.cta__alt:hover{color:var(--ink)}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact{
  padding:clamp(80px,12vh,150px) var(--pad);
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,7vw,110px);align-items:start;
  border-top:1px solid var(--line);
}
.contact__title{
  font-family:'Bricolage Grotesque';font-weight:700;
  font-size:clamp(40px,6vw,90px);line-height:.92;letter-spacing:-.03em;margin-bottom:28px;
}
.contact__lead{color:var(--ink-dim);font-size:clamp(15px,1.5vw,18px);line-height:1.6;max-width:36ch}
.contact__lead a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.form{display:flex;flex-direction:column;gap:26px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.field{display:flex;flex-direction:column;gap:10px}
.field label,.field__label{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-dim)}
.field input,.field textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);
  color:var(--ink);font-family:'Inter';font-size:17px;padding:12px 0;
  transition:border-color .3s;resize:none;border-radius:0;
}
.field input::placeholder,.field textarea::placeholder{color:#5c5a56}
.field input:focus,.field textarea:focus{outline:none;border-bottom-color:var(--blue)}

/* Custom dropdown */
.cselect{position:relative}
.cselect__trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:transparent;border:none;border-bottom:1px solid var(--line);
  color:var(--ink);font-family:'Inter';font-size:17px;padding:12px 0;cursor:pointer;
  transition:border-color .3s;text-align:left;
}
.cselect.is-open .cselect__trigger,.cselect__trigger:focus-visible{outline:none;border-bottom-color:var(--blue)}
.cselect__chev{
  width:11px;height:11px;border-right:1.6px solid var(--blue);border-bottom:1.6px solid var(--blue);
  transform:rotate(45deg);margin-bottom:4px;flex:none;
  transition:transform .35s var(--easing);
}
.cselect.is-open .cselect__chev{transform:rotate(-135deg);margin-bottom:-2px}
.cselect__list{
  position:absolute;top:calc(100% + 10px);left:0;width:100%;z-index:40;list-style:none;
  background:#14141a;border:1px solid var(--line);border-radius:14px;padding:6px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;transform:translateY(-8px) scale(.98);transform-origin:top;
  transition:opacity .3s var(--easing),transform .3s var(--easing),visibility .3s;
}
.cselect.is-open .cselect__list{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.cselect__list li{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:13px 14px;border-radius:9px;font-size:15px;color:var(--ink-dim);cursor:pointer;
  transition:background .25s var(--easing),color .25s var(--easing);
}
.cselect__list li:hover,.cselect__list li.is-active{background:rgba(243,239,231,.06);color:var(--ink)}
.cselect__list li.is-selected{color:var(--ink)}
.cselect__list li.is-selected::after{
  content:'';width:7px;height:7px;border-radius:50%;background:var(--blue);flex:none;
}
.form__submit{
  align-self:flex-start;display:inline-flex;align-items:center;gap:10px;margin-top:6px;
  padding:16px 30px;border-radius:40px;background:var(--blue);color:#08203b;
  font-size:16px;font-weight:500;transition:transform .4s var(--easing),background .3s,opacity .3s;
}
.form__submit span{transition:transform .3s var(--easing)}
.form__submit:hover{background:var(--ink)}
.form__submit:hover span{transform:translate(3px,-3px)}
.form__submit:disabled{opacity:.5;cursor:default}
.form__status{font-size:14px;color:var(--ink-dim);min-height:1.2em}
.form__status.is-ok{color:var(--blue)}
.form__status.is-err{color:#f0a3a3}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:80px var(--pad) 36px;border-top:1px solid var(--line)}
.footer__top{display:flex;justify-content:space-between;gap:60px;flex-wrap:wrap;padding-bottom:80px}
.footer__brand img{width:160px;margin-bottom:20px}
.footer__brand p{color:var(--ink-dim);font-family:'Caveat';font-size:24px}
.footer__links{display:flex;gap:80px}
.footer__links>div{display:flex;flex-direction:column;gap:14px}
.footer__h{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-dim);margin-bottom:6px}
.footer__links a{font-size:16px;color:var(--ink);opacity:.8;transition:opacity .3s,color .3s}
.footer__links a:hover{opacity:1;color:var(--blue)}
.footer__bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding-top:30px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-dim)}
.footer__totop:hover{color:var(--ink)}

/* ============================================================
   REVEAL STATES (set by JS)
   ============================================================ */
.reveal-fade{opacity:0;transform:translateY(24px)}
.reveal-step{opacity:0;transform:translateY(40px)}

/* ============================================================
   HERO PROOF + extras
   ============================================================ */
.hero__sub strong{color:var(--ink);font-weight:500}
.hero__proof{
  display:flex;align-items:center;gap:10px;margin-top:30px;
  font-size:13px;color:var(--ink-dim);max-width:64ch;line-height:1.5;
}
.hero__proof-dot{
  width:8px;height:8px;border-radius:50%;background:#5fd07a;flex:none;
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(95,208,122,.5)}
  70%{box-shadow:0 0 0 8px rgba(95,208,122,0)}
  100%{box-shadow:0 0 0 0 rgba(95,208,122,0)}
}

/* ============================================================
   PROBLEM
   ============================================================ */
.problem{padding:clamp(90px,14vh,170px) var(--pad)}
.problem__statement{
  font-family:'Bricolage Grotesque';font-weight:500;
  font-size:clamp(30px,5.4vw,80px);line-height:1.03;letter-spacing:-.02em;
  max-width:20ch;margin-bottom:54px;
}
.problem__statement .w{display:block;overflow:hidden}
.problem__statement em{font-style:italic;color:var(--blue)}
.problem__list{list-style:none;border-top:1px solid var(--line)}
.problem__list li{
  display:flex;align-items:baseline;gap:20px;padding:26px 4px;border-bottom:1px solid var(--line);
  font-family:'Bricolage Grotesque';font-weight:500;letter-spacing:-.01em;
  font-size:clamp(17px,2.1vw,27px);color:var(--ink);
  transition:color .35s,padding-left .4s var(--easing);
}
.problem__list li:hover{padding-left:18px;color:#fff}
.problem__list li>span{font-size:13px;color:var(--blue);font-family:'Inter';flex:none;font-weight:500;transform:translateY(-.15em)}
.problem__list li em{font-style:normal;color:var(--blue)}
.problem__cta{margin-top:58px;display:flex;flex-direction:column;gap:28px;align-items:flex-start;max-width:54ch}
.problem__cta p{font-size:clamp(16px,1.7vw,22px);color:var(--ink-dim);line-height:1.6}

/* ============================================================
   SERVICES — lead + cta + new visuals
   ============================================================ */
.services__lead{margin-top:0;color:var(--ink-dim);font-size:clamp(15px,1.55vw,19px);max-width:42ch;line-height:1.7}
.services__cta{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center;padding:74px var(--pad) 0}
.services__cta p{font-family:'Bricolage Grotesque';font-weight:500;font-size:clamp(20px,2.6vw,34px);letter-spacing:-.01em;max-width:18ch}
.service__visual[data-shape="web"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 140'%3E%3Cg fill='none' stroke='%23a9cdf4' stroke-width='2.4'%3E%3Crect x='38' y='34' width='124' height='84' rx='8'/%3E%3Cpath d='M38 54h124'/%3E%3Ccircle cx='50' cy='44' r='2.4'/%3E%3Ccircle cx='60' cy='44' r='2.4'/%3E%3Ccircle cx='70' cy='44' r='2.4'/%3E%3Cpath d='M54 72h44M54 84h74M54 96h58'/%3E%3C/g%3E%3C/svg%3E");
}
.service__visual[data-shape="page"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 140'%3E%3Cg fill='none' stroke='%23a9cdf4' stroke-width='2.4'%3E%3Crect x='66' y='22' width='68' height='96' rx='7'/%3E%3Cpath d='M78 40h44M78 50h30'/%3E%3Crect x='78' y='62' width='44' height='22' rx='5'/%3E%3Cpath d='M86 100h28'/%3E%3C/g%3E%3C/svg%3E");
}
.service__visual[data-shape="funnel"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 140'%3E%3Cg fill='none' stroke='%23a9cdf4' stroke-width='2.4'%3E%3Cpath d='M52 42h96l-30 34v26l-36 16V76z'/%3E%3Ccircle cx='100' cy='30' r='4'/%3E%3Cpath d='M88 116h24'/%3E%3C/g%3E%3C/svg%3E");
}

/* ============================================================
   ABOUT — photo grid
   ============================================================ */
.about__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(44px,6vw,96px);
  align-items:start;margin-bottom:100px;
}
.about__photo{
  width:128px;height:128px;border-radius:22px;background:#f5f1e9;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  box-shadow:0 18px 44px rgba(0,0,0,.4);
}
.about__photo img{width:94%;height:auto}
.about__badge{
  display:inline-flex;margin:26px 0 30px;white-space:nowrap;
  background:var(--blue);color:#08203b;font-size:12px;font-weight:500;
  padding:9px 18px;border-radius:30px;
}
.about__statement{
  font-family:'Bricolage Grotesque';font-weight:500;
  font-size:clamp(28px,3.6vw,52px);line-height:1.1;letter-spacing:-.02em;max-width:15ch;
}
.about__statement .w{display:block;overflow:hidden}
.about__statement em{font-style:italic;color:var(--blue)}
.about__content{padding-top:6px}
.about__text{margin:0 0 24px;color:var(--ink-dim);font-size:clamp(15px,1.45vw,18px);line-height:1.78;max-width:58ch}
.about__text:last-of-type{margin-bottom:0}
.about__text strong{color:var(--ink);font-weight:500}
.about__actions{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}

/* ============================================================
   CTA sub
   ============================================================ */
.cta__sub{margin:28px auto 0;font-size:clamp(15px,1.6vw,19px);color:var(--ink-dim);max-width:44ch;line-height:1.5}

/* ============================================================
   FOOTER (redesigned)
   ============================================================ */
.footer{padding:0 var(--pad) 34px;border-top:1px solid var(--line);overflow:hidden}
.footer__cta{padding:clamp(60px,8vh,100px) 0 clamp(50px,6vh,80px);border-bottom:1px solid var(--line);text-align:center}
.footer__kicker{font-size:13px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-dim);margin-bottom:24px}
.footer__bigcta{
  display:inline-flex;align-items:center;gap:.3em;
  font-family:'Bricolage Grotesque';font-weight:700;font-size:clamp(34px,5.4vw,68px);
  letter-spacing:-.03em;line-height:1;color:var(--ink);transition:color .4s var(--easing);
}
.footer__bigcta span{font-size:.5em;color:var(--blue);transition:transform .4s var(--easing)}
.footer__bigcta:hover{color:var(--blue)}
.footer__bigcta:hover span{transform:translate(8px,-8px)}
.footer__top{display:grid;grid-template-columns:1.5fr .8fr 1fr 1.1fr;gap:48px;padding:70px 0 48px}
.footer__brand{display:flex;flex-direction:column;gap:18px}
.footer__logo{width:128px}
.footer__brand .footer__tag{font-family:'Caveat';font-size:22px;color:var(--ink-dim);max-width:18ch}
.footer__h{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-dim);margin-bottom:24px}
.footer__col{display:flex;flex-direction:column;gap:14px}
/* interactive footer links — animated underline + slide */
.footer__nav a,.footer__details a{
  position:relative;width:fit-content;color:var(--ink);opacity:.78;font-size:16px;
  transition:opacity .3s,color .3s,transform .35s var(--easing);
}
.footer__nav a::after,.footer__details a::after{
  content:'';position:absolute;left:0;bottom:-3px;height:1px;width:0;background:var(--blue);
  transition:width .35s var(--easing);
}
.footer__nav a:hover,.footer__details a:hover{opacity:1;color:var(--blue);transform:translateX(4px)}
.footer__nav a:hover::after,.footer__details a:hover::after{width:100%}
.footer__social a{
  display:inline-flex;align-items:center;gap:8px;width:fit-content;
  font-family:'Bricolage Grotesque';font-weight:500;font-size:clamp(19px,1.9vw,24px);letter-spacing:-.01em;
  color:var(--ink);transition:color .3s,transform .35s var(--easing);
}
.footer__social a span{font-size:.6em;color:var(--ink-dim);transition:color .3s,transform .35s var(--easing)}
.footer__social a:hover{color:var(--blue);transform:translateX(8px)}
.footer__social a:hover span{color:var(--blue);transform:translate(2px,-2px)}
.footer__details p{margin-top:16px;color:var(--ink-dim);font-size:14px;line-height:1.7}
.footer__time{margin-top:14px!important}
.footer__time #clock{color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:.01em}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  padding-top:28px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-dim);
}
.footer__totop{position:relative;transition:color .3s}
.footer__totop:hover{color:var(--blue)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .service{grid-template-columns:80px 1fr;gap:28px}
  .service__visual{display:none}
  .about__meta{grid-template-columns:1fr;gap:36px}
  .about__grid{grid-template-columns:1fr;gap:38px;margin-bottom:74px}
  .services__headrow{grid-template-columns:1fr;gap:28px;align-items:start}
  .process__head{grid-template-columns:1fr;align-items:start}
  .contact{grid-template-columns:1fr;gap:46px}
  .footer__top{grid-template-columns:1fr 1fr;gap:48px}
  .footer__brand{grid-column:1 / -1}
}
@media (max-width:760px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .hero__title{font-size:clamp(48px,13vw,88px)}
  .hero__sub br{display:none}
  .hero__scroll{display:none}
  .service{grid-template-columns:1fr;gap:18px;padding:44px var(--pad)}
  .service__num{font-size:44px}
  .process__steps{grid-template-columns:1fr}
  .step{padding:36px var(--pad)}
  .footer__top{grid-template-columns:1fr;gap:40px}
  .footer__brand{grid-column:auto}
  .sound{bottom:18px}
  .cta__btn{width:100%;justify-content:center}
  .cta__actions{flex-direction:column;gap:18px}
  .form__row{grid-template-columns:1fr}
  .form__submit{align-self:stretch;justify-content:center}
  .problem__cta .btn,.services__cta .btn{width:100%}
  .hero__actions,.about__actions{flex-direction:column;align-items:stretch;gap:12px}
  .hero__actions .btn,.about__actions .btn{width:100%}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal-fade,.reveal-step{opacity:1;transform:none}
}
