*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0a0906;
  --cream:#f7f4ee;
  --warm:#f0ead8;
  --sand:#e8dfc8;
  --fire:#e63c1e;
  --electric:#1a1aff;
  --gold:#c9a84c;
  --muted:#9b917e;
  --serif:'Instrument Serif',Georgia,serif;
  --display:'Bebas Neue',impact,sans-serif;
  --body:'Cabinet Grotesk',sans-serif;
}

html{scroll-behavior:smooth;cursor:none}
body{font-family:var(--body);background:var(--cream);color:var(--ink);overflow-x:hidden;cursor:none}

/* ── CUSTOM CURSOR ── */
#cursor{position:fixed;width:12px;height:12px;background:var(--fire);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,width .3s,height .3s,background .3s;mix-blend-mode:multiply}
#cursor-ring{position:fixed;width:40px;height:40px;border:1px solid var(--fire);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .08s linear,width .3s,height .3s,opacity .3s;opacity:.5}
body:has(a:hover) #cursor,body:has(button:hover) #cursor{width:48px;height:48px;background:var(--fire);mix-blend-mode:multiply}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:72px;
  background:rgba(247,244,238,0.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(10,9,6,0.06);
}
.logo-nav{font-family:var(--display);font-size:28px;letter-spacing:2px;color:var(--ink);text-decoration:none;line-height:1;flex-shrink:0}
.nav-center{display:flex;gap:32px;list-style:none;position:absolute;left:50%;transform:translateX(-50%)}
.nav-center a{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);text-decoration:none;opacity:.5;transition:opacity .2s;white-space:nowrap}
.nav-center a:hover{opacity:1}
.nav-right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.nav-dot{width:8px;height:8px;background:var(--fire);border-radius:50%;animation:blink 2s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nav-time{font-size:11px;font-weight:500;letter-spacing:.1em;color:var(--muted);white-space:nowrap}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.mobile-menu{
  display:none;position:fixed;top:72px;left:0;right:0;z-index:199;
  background:var(--cream);border-bottom:1px solid rgba(10,9,6,.1);
  flex-direction:column;padding:24px 24px 32px;gap:0;
}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:22px;font-family:var(--display);letter-spacing:1px;color:var(--ink);text-decoration:none;padding:14px 0;border-bottom:1px solid rgba(10,9,6,.06);transition:color .2s}
.mobile-menu a:hover{color:var(--fire)}
.mobile-menu .mob-cta{margin-top:20px;background:var(--fire);color:#fff;padding:14px 28px;border-radius:100px;text-align:center;font-size:13px;font-weight:700;letter-spacing:.08em;border:none}

/* ── HERO ── */
.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:72px 48px 60px;position:relative;overflow:hidden;
  background:var(--cream);
}
.hero-bg-text{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--display);font-size:clamp(140px,20vw,300px);
  color:transparent;-webkit-text-stroke:1px rgba(10,9,6,.07);
  white-space:nowrap;pointer-events:none;letter-spacing:4px;
  animation:driftBg 20s ease-in-out infinite;user-select:none;
  z-index:0;
}
@keyframes driftBg{0%,100%{transform:translate(-50%,-50%) skewX(0deg)}50%{transform:translate(-50%,-52%) skewX(-1deg)}}
.hero-top-row{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:auto;padding-top:40px;
}
.hero-eyebrow{
  writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
}
.hero-award{
  background:var(--ink);color:var(--cream);padding:10px 18px;
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  border-radius:100px;display:flex;align-items:center;gap:8px;
}
.hero-award::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%}
.hero-main-title{
  font-family:var(--display);
  font-size:clamp(72px,12vw,190px);
  line-height:.92;letter-spacing:-1px;
  color:var(--ink);
  position:relative;z-index:2;
  margin-bottom:0;
}
.hero-main-title .italic-word{
  font-family:var(--serif);font-style:italic;
  color:var(--fire);
}
.hero-bottom{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:24px;gap:24px;
}
.hero-desc{
  max-width:380px;font-size:16px;line-height:1.7;color:var(--muted);font-weight:400;
}
.hero-cta-group{display:flex;flex-direction:column;align-items:flex-end;gap:16px;flex-shrink:0}
.cta-pill{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--fire);color:#fff;
  padding:16px 28px;border-radius:100px;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.cta-pill:hover{transform:scale(1.04) translateY(-2px);box-shadow:0 20px 40px rgba(230,60,30,.3)}
.cta-pill .arrow{
  width:28px;height:28px;background:rgba(255,255,255,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:14px;
  transition:transform .3s;
}
.cta-pill:hover .arrow{transform:rotate(45deg)}
.hero-scroll-hint{
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:8px;
}
.scroll-line{width:40px;height:1px;background:var(--muted)}

/* ── HORIZONTAL SCROLLER ── */
.h-scroll{
  overflow-x:auto;display:flex;gap:0;
  border-top:1px solid rgba(10,9,6,.1);border-bottom:1px solid rgba(10,9,6,.1);
  scrollbar-width:none;
}
.h-scroll::-webkit-scrollbar{display:none}
.h-scroll-inner{display:flex;gap:0;width:max-content;animation:hscroll 30s linear infinite}
@keyframes hscroll{to{transform:translateX(-50%)}}
.ticker-item{
  display:flex;align-items:center;gap:20px;
  padding:18px 40px;border-right:1px solid rgba(10,9,6,.08);
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  white-space:nowrap;
}
.ticker-star{color:var(--fire);font-size:16px}

/* ── ABOUT ── */
.about{
  display:grid;grid-template-columns:1fr 1fr;min-height:90vh;
}
.about-left{
  background:var(--ink);padding:80px 60px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.about-left::before{
  content:'SINCE\A2019';white-space:pre;
  position:absolute;right:-20px;bottom:-20px;
  font-family:var(--display);font-size:120px;line-height:.85;
  color:rgba(255,255,255,.04);letter-spacing:2px;
  pointer-events:none;
}
.about-label{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:60px}
.about-big-num{
  font-family:var(--display);font-size:clamp(100px,12vw,160px);
  color:var(--fire);line-height:.85;letter-spacing:-2px;
}
.about-num-label{font-size:14px;color:rgba(255,255,255,.5);margin-top:12px;font-weight:400}
.about-quote{
  font-family:var(--serif);font-style:italic;font-size:clamp(24px,3vw,38px);
  color:#fff;line-height:1.3;border-top:1px solid rgba(255,255,255,.1);padding-top:32px;
  margin-top:40px;
}
.about-right{padding:80px 60px;display:flex;flex-direction:column;justify-content:center;background:var(--warm)}
.section-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--fire);
  margin-bottom:24px;
}
.section-tag::before{content:'';width:20px;height:2px;background:var(--fire)}
.about-title{
  font-family:var(--display);font-size:clamp(42px,5vw,72px);
  line-height:.95;letter-spacing:1px;color:var(--ink);margin-bottom:28px;
}
.about-title em{font-family:var(--serif);font-style:italic;color:var(--fire)}
.about-body{font-size:16px;line-height:1.8;color:var(--muted);max-width:440px;font-weight:400;margin-bottom:40px}
.stat-row{display:flex;gap:40px;border-top:1px solid rgba(10,9,6,.1);padding-top:32px}
.stat .n{font-family:var(--display);font-size:40px;letter-spacing:0;color:var(--ink);line-height:1}
.stat .n span{color:var(--fire)}
.stat .l{font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.04em}

/* ── TECH STACK BADGES ── */
.tech-stack{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px;padding-top:32px;border-top:1px solid rgba(10,9,6,.1)}
.tech-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--sand);color:var(--ink);
  padding:8px 16px;border-radius:100px;
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(10,9,6,.08);transition:all .25s;
}
.tech-badge:hover{background:var(--fire);color:#fff;border-color:var(--fire)}
.tech-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--fire);flex-shrink:0}
.tech-badge:hover .dot{background:#fff}

/* ── SERVICES ── */
.services{padding:100px 48px;background:var(--cream)}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;gap:40px}
.services-title{
  font-family:var(--display);font-size:clamp(52px,6vw,88px);
  line-height:.92;letter-spacing:1px;color:var(--ink);
}
.services-title em{font-family:var(--serif);font-style:italic}
.services-desc{max-width:300px;font-size:15px;color:var(--muted);line-height:1.7}
.services-list{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(10,9,6,.1)}
.svc-row{
  display:grid;grid-template-columns:60px 1fr auto auto;
  align-items:center;gap:32px;
  padding:32px 0;border-bottom:1px solid rgba(10,9,6,.1);
  cursor:default;transition:background .25s;position:relative;
  overflow:hidden;
}
.svc-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--fire);transition:width .35s cubic-bezier(.25,.46,.45,.94);
  z-index:0;
}
.svc-row:hover::before{width:4px}
.svc-row>*{position:relative;z-index:1}
.svc-num{font-family:var(--display);font-size:18px;color:rgba(10,9,6,.2);letter-spacing:.04em}
.svc-name{font-family:var(--display);font-size:clamp(28px,3.5vw,48px);letter-spacing:.5px;color:var(--ink);transition:color .25s}
.svc-row:hover .svc-name{color:var(--fire)}
.svc-tags{display:flex;gap:8px;flex-wrap:wrap}
.svc-tag{background:var(--sand);color:var(--muted);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:100px}
.svc-arrow{width:44px;height:44px;border:1px solid rgba(10,9,6,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .25s;color:var(--ink)}
.svc-row:hover .svc-arrow{background:var(--fire);border-color:var(--fire);color:#fff;transform:rotate(45deg)}

/* ── WORK ── */
.work{padding:0 48px 100px;background:var(--cream)}
.work-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}
.work-title{font-family:var(--display);font-size:clamp(48px,5.5vw,80px);letter-spacing:1px;line-height:.95}
.view-all{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.view-all:hover{color:var(--fire);border-color:var(--fire)}
.work-bento{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto;gap:12px}
.work-item{
  position:relative;overflow:hidden;border-radius:4px;cursor:pointer;
  background:var(--sand);
}
.work-item.big{grid-column:span 2;aspect-ratio:16/9}
.work-item.tall{grid-row:span 2;aspect-ratio:unset}
.work-item.tall>.wi-inner{height:100%}
.work-item.sm{aspect-ratio:4/3}
.wi-inner{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:64px;position:relative;
  transition:transform .6s cubic-bezier(.25,.46,.45,.94);
}
.work-item:hover .wi-inner{transform:scale(1.04)}
.wi-bg-1{background:linear-gradient(135deg,#1a1aff 0%,#6666ff 100%)}
.wi-bg-2{background:linear-gradient(135deg,#e63c1e 0%,#ff8c5a 100%)}
.wi-bg-3{background:linear-gradient(135deg,#0a0906 0%,#3a3026 100%)}
.wi-bg-4{background:linear-gradient(135deg,#c9a84c 0%,#e8d4a0 100%)}
.wi-bg-5{background:linear-gradient(135deg,#2d4a22 0%,#6a9a55 100%)}
.work-hover{
  position:absolute;inset:0;
  background:rgba(10,9,6,.85);
  opacity:0;transition:opacity .3s;
  display:flex;flex-direction:column;justify-content:flex-end;padding:28px;
}
.work-item:hover .work-hover{opacity:1}
.wh-cat{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--fire);margin-bottom:8px}
.wh-name{font-family:var(--display);font-size:26px;color:#fff;letter-spacing:.5px;line-height:1.1}
.wh-year{font-size:12px;color:rgba(255,255,255,.4);margin-top:6px}

/* ── MARQUEE DARK ── */
.mq-dark{background:var(--ink);border:none;overflow:hidden;padding:20px 0}
.mq-dark .h-scroll-inner{animation:hscroll 20s linear infinite}
.mq-dark .ticker-item{color:rgba(255,255,255,.25);border-right-color:rgba(255,255,255,.08);font-size:12px}
.mq-dark .ticker-star{color:var(--fire);opacity:.8}

/* ── TEAM ── */
.team{padding:100px 48px;background:var(--warm)}
.team-head{margin-bottom:60px}
.team-title{font-family:var(--display);font-size:clamp(52px,6vw,88px);letter-spacing:1px;line-height:.92}
.team-title em{font-family:var(--serif);font-style:italic;color:var(--fire)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.team-card{position:relative;overflow:hidden;border-radius:4px;cursor:pointer}
.tc-photo{
  aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  font-size:80px;transition:transform .5s cubic-bezier(.25,.46,.45,.94);
}
.tc-bg-1{background:linear-gradient(160deg,#ddd5c5,#c0b09a)}
.tc-bg-2{background:linear-gradient(160deg,#c5cedd,#9aaac0)}
.tc-bg-3{background:linear-gradient(160deg,#cdddc5,#9ac0aa)}
.tc-bg-4{background:linear-gradient(160deg,#ddc5c5,#c09a9a)}
.team-card:hover .tc-photo{transform:scale(1.06)}
.tc-overlay{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(10,9,6,.9) 0%,transparent 60%);
  padding:24px 20px 20px;
  transform:translateY(8px);transition:transform .3s;
}
.team-card:hover .tc-overlay{transform:translateY(0)}
.tc-name{font-family:var(--display);font-size:20px;color:#fff;letter-spacing:.5px}
.tc-role{font-size:11px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.tc-social{
  display:flex;gap:8px;margin-top:10px;
  opacity:0;transform:translateY(8px);transition:all .3s .05s;
}
.team-card:hover .tc-social{opacity:1;transform:translateY(0)}
.tc-s{width:28px;height:28px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:rgba(255,255,255,.6);transition:all .2s;text-decoration:none}
.tc-s:hover{background:var(--fire);border-color:var(--fire);color:#fff}

/* ── TESTIMONIALS ── */
.testi{padding:100px 48px;background:var(--ink);position:relative;overflow:hidden}
.testi::before{
  content:'★★★★★';
  position:absolute;right:-40px;top:-20px;
  font-size:200px;color:rgba(255,255,255,.02);letter-spacing:-10px;
  pointer-events:none;white-space:nowrap;
}
.testi-label{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:10px;margin-bottom:60px}
.testi-label::before{content:'';width:20px;height:2px;background:var(--fire)}
.testi-big-quote{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(32px,4vw,58px);color:#fff;line-height:1.25;
  max-width:860px;margin-bottom:48px;
}
.testi-big-quote strong{color:var(--fire);font-style:normal;font-weight:400}
.testi-author{display:flex;align-items:center;gap:20px;border-top:1px solid rgba(255,255,255,.08);padding-top:32px}
.ta-avatar{width:52px;height:52px;border-radius:50%;background:var(--fire);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:20px;color:#fff}
.ta-name{font-family:var(--display);font-size:18px;color:#fff;letter-spacing:.5px}
.ta-role{font-size:12px;color:rgba(255,255,255,.35);margin-top:2px;text-transform:uppercase;letter-spacing:.1em}
.ta-rating{margin-left:auto;display:flex;gap:4px;color:var(--gold);font-size:16px}
.testi-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px}
.t-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:4px;padding:32px;
}
.t-card-stars{color:var(--gold);font-size:13px;letter-spacing:3px;margin-bottom:16px}
.t-card-text{font-size:15px;color:rgba(255,255,255,.5);line-height:1.75;font-style:italic;margin-bottom:20px}
.t-card-auth{font-size:12px;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:.1em;font-weight:700}

/* ── PROCESS ── */
.process{padding:100px 48px;background:var(--cream)}
.process-title{font-family:var(--display);font-size:clamp(52px,6vw,88px);letter-spacing:1px;line-height:.92;margin-bottom:60px}
.process-title em{font-family:var(--serif);font-style:italic;color:var(--fire)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(10,9,6,.1)}
.p-step{
  padding:40px 32px;border-right:1px solid rgba(10,9,6,.1);
  position:relative;overflow:hidden;transition:background .3s;
}
.p-step:last-child{border-right:none}
.p-step:hover{background:var(--fire)}
.p-step-num{
  font-family:var(--display);font-size:72px;color:rgba(10,9,6,.06);
  line-height:1;margin-bottom:32px;transition:color .3s;
}
.p-step:hover .p-step-num{color:rgba(255,255,255,.2)}
.p-step-icon{font-size:28px;margin-bottom:16px}
.p-step-name{font-family:var(--display);font-size:24px;color:var(--ink);margin-bottom:12px;transition:color .3s;letter-spacing:.5px}
.p-step:hover .p-step-name{color:#fff}
.p-step-desc{font-size:13px;line-height:1.75;color:var(--muted);transition:color .3s}
.p-step:hover .p-step-desc{color:rgba(255,255,255,.65)}

/* ── CTA ── */
.cta-section{
  padding:120px 48px;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;text-align:center;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'LET\'S BUILD';
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--display);font-size:clamp(140px,18vw,240px);letter-spacing:4px;
  color:rgba(255,255,255,.03);white-space:nowrap;pointer-events:none;
}
.cta-eyebrow{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--fire);margin-bottom:24px}
.cta-title{
  font-family:var(--display);font-size:clamp(56px,8vw,120px);
  color:#fff;line-height:.9;letter-spacing:1px;margin-bottom:40px;
  position:relative;z-index:1;
}
.cta-title em{font-family:var(--serif);font-style:italic;color:var(--fire)}
.cta-actions{display:flex;gap:16px;align-items:center;position:relative;z-index:1}
.cta-btn-main{
  background:var(--fire);color:#fff;padding:18px 40px;border-radius:100px;
  font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.cta-btn-main:hover{transform:scale(1.05);box-shadow:0 20px 50px rgba(230,60,30,.4)}
.cta-btn-ghost{
  color:rgba(255,255,255,.5);font-size:13px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.cta-btn-ghost:hover{color:#fff;border-color:#fff}
.cta-contacts{display:flex;gap:48px;margin-top:80px;position:relative;z-index:1}
.cta-contact-item{text-align:left}
.cci-label{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:6px}
.cci-val{font-size:15px;color:rgba(255,255,255,.6);font-weight:400}
.cci-val a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.cci-val a:hover{color:var(--fire)}

/* ── CLIENTS ── */
.clients{padding:60px 48px;background:var(--warm);border-top:1px solid rgba(10,9,6,.08)}
.cl-label{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:36px;text-align:center}
.cl-logos{display:flex;justify-content:center;align-items:center;gap:52px;flex-wrap:wrap}
.cl-logo{font-family:var(--display);font-size:20px;letter-spacing:1px;color:rgba(10,9,6,.2);transition:color .25s;cursor:default}
.cl-logo:hover{color:var(--ink)}

/* ── CONTACT ── */
.contact{
  padding:100px 20px;
  background:var(--cream);
  display:flex;
  justify-content:center;
  align-items:center;
}
.contact-container{
  width:100%;max-width:600px;background:var(--warm);
  padding:40px;border-radius:8px;
  box-shadow:0 10px 30px rgba(0,0,0,0.05);
}
.contact-title{font-family:var(--display);font-size:clamp(36px,5vw,60px);margin-bottom:10px}
.contact-title em{font-family:var(--serif);color:var(--fire)}
.contact-sub{font-size:14px;color:var(--muted);margin-bottom:30px}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form input,.contact-form textarea{
  width:100%;padding:14px 16px;border:1px solid #ddd;
  border-radius:6px;font-size:14px;outline:none;transition:0.3s;
  font-family:var(--body);background:var(--cream);
}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--fire)}
.contact-form button{
  background:var(--fire);color:#fff;padding:14px;border:none;
  border-radius:6px;font-size:13px;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;cursor:pointer;transition:0.3s;font-family:var(--body);
}
.contact-form button:hover{background:#000}

/* ── FOOTER ── */
footer{background:var(--ink)}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  padding:80px 48px;border-bottom:1px solid rgba(255,255,255,.06);
}
.ft-logo{font-family:var(--display);font-size:32px;letter-spacing:2px;color:#fff;display:block;margin-bottom:20px;text-decoration:none}
.ft-logo span{color:var(--fire)}
.ft-desc{font-size:14px;color:rgba(255,255,255,.35);line-height:1.8;margin-bottom:28px;max-width:320px}
.ft-socials{display:flex;gap:10px}
.ft-s{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:13px;text-decoration:none;transition:all .2s}
.ft-s:hover{background:var(--fire);border-color:var(--fire);color:#fff}
.ft-col h5{font-family:var(--display);font-size:13px;letter-spacing:.12em;color:rgba(255,255,255,.35);text-transform:uppercase;margin-bottom:20px}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.ft-col a{font-size:14px;color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s}
.ft-col a:hover{color:#fff}
.footer-bottom{
  padding:24px 48px;display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:rgba(255,255,255,.2);
}
.footer-bottom a{color:var(--fire);text-decoration:none}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(50px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* ── TABLET ── */
@media(max-width:1024px){
  nav{padding:0 32px}
  .nav-center{gap:20px}
  .nav-center a{font-size:11px}
  .nav-time{display:none}
  .hero{padding:72px 32px 48px}
  .services{padding:80px 32px}
  .services-head{flex-direction:column;align-items:flex-start;gap:16px}
  .work{padding:0 32px 80px}
  .team{padding:80px 32px}
  .testi{padding:80px 32px}
  .process{padding:80px 32px}
  .contact{padding:80px 32px}
  .cta-section{padding:80px 32px}
  .clients{padding:48px 32px}
  .about-left{padding:60px 32px}
  .about-right{padding:60px 32px}
  .footer-top{padding:60px 32px;gap:40px}
  .footer-bottom{padding:20px 32px}
  .cl-logos{gap:32px}
}

/* ── MOBILE LARGE ── */
@media(max-width:900px){
  nav{padding:0 20px;height:64px}
  .nav-center{display:none}
  .nav-time{display:none}
  .nav-hamburger{display:flex}
  .nav-right .cta-pill{display:none}
  .mobile-menu{top:64px}
  .hero{padding:64px 20px 48px;min-height:100svh}
  .hero-top-row{padding-top:24px}
  .hero-eyebrow{display:none}
  .hero-main-title{font-size:clamp(60px,14vw,120px)}
  .hero-bottom{flex-direction:column;align-items:flex-start;gap:24px}
  .hero-cta-group{align-items:flex-start;width:100%}
  .hero-scroll-hint{display:none}
  .about{grid-template-columns:1fr}
  .about-left{padding:60px 20px;min-height:auto}
  .about-right{padding:60px 20px}
  .services{padding:60px 20px}
  .services-head{flex-direction:column;align-items:flex-start;gap:16px}
  .svc-row{grid-template-columns:40px 1fr auto;gap:16px}
  .svc-tags{display:none}
  .work{padding:0 20px 60px}
  .work-bento{grid-template-columns:1fr 1fr}
  .work-item.big{grid-column:span 2}
  .work-item.tall{grid-row:span 1;aspect-ratio:4/3}
  .work-head{flex-direction:column;align-items:flex-start;gap:16px}
  .team{padding:60px 20px}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .testi{padding:60px 20px}
  .testi-cards{grid-template-columns:1fr}
  .ta-rating{display:none}
  .process{padding:60px 20px}
  .process-steps{grid-template-columns:1fr 1fr}
  .p-step{padding:28px 20px;border-bottom:1px solid rgba(10,9,6,.1)}
  .p-step:nth-child(odd){border-right:1px solid rgba(10,9,6,.1)}
  .p-step:nth-child(even){border-right:none}
  .p-step:nth-child(3),.p-step:nth-child(4){border-bottom:none}
  .cta-section{padding:80px 20px}
  .cta-actions{flex-direction:column;align-items:center;gap:16px}
  .cta-contacts{flex-direction:column;gap:24px;align-items:center}
  .cta-contact-item{text-align:center}
  .clients{padding:40px 20px}
  .cl-logos{gap:20px}
  .cl-logo{font-size:15px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;padding:48px 20px}
  .footer-top>div:first-child{grid-column:span 2}
  .footer-bottom{padding:20px;flex-direction:column;gap:8px;text-align:center}
}

/* ── MOBILE SMALL ── */
@media(max-width:480px){
  nav{padding:0 16px}
  .hero{padding:64px 16px 40px}
  .hero-main-title{font-size:clamp(52px,16vw,90px)}
  .hero-award{font-size:9px;padding:8px 14px}
  .about-left{padding:48px 16px}
  .about-right{padding:48px 16px}
  .stat-row{flex-direction:column;gap:20px}
  .tech-stack{gap:8px}
  .services{padding:48px 16px}
  .svc-row{gap:12px;padding:24px 0}
  .svc-num{font-size:14px;min-width:28px}
  .svc-name{font-size:clamp(22px,7vw,36px)}
  .svc-arrow{width:36px;height:36px;font-size:13px;flex-shrink:0}
  .work{padding:0 16px 48px}
  .work-bento{grid-template-columns:1fr}
  .work-item.big,.work-item.tall,.work-item.sm{grid-column:span 1;aspect-ratio:4/3;grid-row:span 1}
  .wi-inner{height:100%}
  .team{padding:48px 16px}
  .team-grid{grid-template-columns:1fr 1fr;gap:10px}
  .testi{padding:48px 16px}
  .testi-big-quote{font-size:clamp(22px,6vw,36px)}
  .process{padding:48px 16px}
  .process-steps{grid-template-columns:1fr}
  .p-step{border-right:none!important;border-bottom:1px solid rgba(10,9,6,.1)!important}
  .p-step:last-child{border-bottom:none!important}
  .cta-section{padding:60px 16px}
  .cta-actions{width:100%}
  .cta-btn-main{width:100%;text-align:center}
  .clients{padding:32px 16px}
  .cl-logos{gap:16px}
  .cl-logo{font-size:13px}
  .footer-top{grid-template-columns:1fr;padding:40px 16px;gap:32px}
  .footer-top>div:first-child{grid-column:span 1}
  .footer-bottom{padding:16px;font-size:11px}
}



#formMsg {
  margin-top: 10px;
  font-weight: 500;
}

.success {
  color: #28a745;
}

.error {
  color: #dc3545;
}

#formMsg:empty {
  display: none;
}