/* ─── TOKENS ─────────────────────────────────────────── */
:root {
  --bg:        #07070d;
  --bg2:       #0d0d16;
  --bg3:       #12121c;
  --bg4:       #181824;
  --border:    rgba(255,255,255,0.055);
  --border-hi: rgba(255,255,255,0.11);
  --text:      #dddde8;
  --muted:     #70708a;
  --silver:    #c4c8d8;
  --orange:    #FF6B00;
  --orange-hi: #FF8C35;
  --teal:      #00C8E0;
  --teal-hi:   #30E0F4;
  --t: 0.25s ease;
  --rad: 4px;
  --container: 1160px;

  /* scroll + load driven metallic vars */
  --shimmer:       200%;
  --shine-x:       120%;
  --shine-y:       -80%;
  /* reactive text shadow — shifts direction with the light */
  --title-shadow:  drop-shadow(-8px 5px 18px rgba(0,0,0,0.85)) drop-shadow(2px -1px 10px rgba(255,255,255,0.05));
}

/* ─── RESET ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:'Inter',sans-serif;
  font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden; /* prevents band animation from causing horizontal scroll */
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}

/* ─── LAYOUT ───────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}

/* ─── TYPE ──────────────────────────────────────────────── */
.sec-eye{
  display:block;font-size:.72rem;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--orange);margin-bottom:14px;
}
.sec-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:clamp(2rem,3.5vw,2.8rem);
  line-height:1.1;text-transform:uppercase;
  letter-spacing:.03em;color:#fff;margin-bottom:18px;
}
.sec-desc{color:var(--muted);font-size:.95rem;line-height:1.75;max-width:520px}
.sec-hd{text-align:center;margin-bottom:64px}
.sec-hd .sec-desc{margin:0 auto}

/* ─── BUTTONS ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.9rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:13px 32px;border-radius:var(--rad);
  transition:var(--t);white-space:nowrap;
  border:1px solid transparent;
}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-primary:hover{background:var(--orange-hi);border-color:var(--orange-hi);transform:translateY(-1px);box-shadow:0 4px 20px rgba(255,107,0,.35)}
.btn-ghost{background:transparent;color:var(--silver);border-color:var(--border-hi)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-full{width:100%;justify-content:center}
.btn-lg{padding:16px 40px;font-size:.95rem}

/* ─── NAV ───────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(7,7,13,.55);
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-bottom:1px solid var(--border);
  transition:background var(--t),border-color var(--t);
}
.nav.scrolled{background:rgba(7,7,13,.97);border-color:var(--border-hi)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo-img{
  height:48px;
  width:48px;
  object-fit:cover;
  object-position:50% 10%;   /* crops to the tree icon, skips the text */
  border-radius:6px;
  mix-blend-mode:screen;     /* dark background of image melts into the nav */
}
.logo-name{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:1.15rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:#fff;line-height:1;
}
.logo-sub{
  font-size:.58rem;font-weight:400;letter-spacing:.2em;
  text-transform:uppercase;color:var(--muted);margin-top:3px;
}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a:not(.btn){
  font-size:.72rem;font-weight:400;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);transition:color var(--t);
}
.nav-links a:not(.btn):hover,
.nav-links a.active{color:var(--text)}
.burger{display:none;flex-direction:column;gap:5px;padding:4px}
.burger span{display:block;width:22px;height:1.5px;background:var(--silver);transition:var(--t)}
.mob-menu{
  display:none;flex-direction:column;
  padding:16px 32px 24px;border-top:1px solid var(--border);
  background:rgba(7,7,13,.98);
}
.mob-menu a{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text);padding:12px 0;border-bottom:1px solid var(--border);
}
.mob-menu .btn{margin-top:14px;justify-content:center}
.mob-menu.open{display:flex}

/* ─── HERO ──────────────────────────────────────────────── */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;
  justify-content:center;
  /* overflow:hidden removed — it was clipping drop-shadow on the title.
     body overflow-x:hidden handles any band animation bleed instead. */
}

/* Layer 1: base */
.hero-base{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 90% 70% at 55% 45%, #0e0e20 0%, #07070d 100%);
}

/* Layer 2: diagonal metallic bands — bright and visible */
.hero-band{
  position:absolute;inset:0;
  background:
    linear-gradient(
      112deg,
      transparent           0%,
      transparent          18%,
      rgba(255,107,0,.06)  23%,
      rgba(255,150,60,.15) 28%,   /* orange band */
      rgba(255,255,255,.30) 33%,  /* primary bright white band */
      rgba(60,220,240,.16) 38%,   /* teal band */
      rgba(0,200,224,.06)  43%,
      transparent          50%,
      transparent          72%,
      rgba(255,255,255,.10) 78%,  /* secondary band */
      transparent          84%
    );
  animation: bandDrift 10s ease-in-out infinite alternate;
}
@keyframes bandDrift{
  0%  {transform:translateX(-6%) skewX(-2deg) scaleX(1.06)}
  100%{transform:translateX( 6%) skewX( 2deg) scaleX(1.06)}
}

/* Layer 3: scroll+load driven radial hotspot */
.hero-sheen{
  position:absolute;inset:0;
  background:
    radial-gradient(
      ellipse 65% 48% at var(--shine-x) var(--shine-y),
      rgba(255,255,255,.28) 0%,    /* noticeably bright */
      rgba(200,225,255,.14) 28%,
      rgba(100,180,220,.05) 52%,
      transparent 68%
    );
  pointer-events:none;
}

/* Layer 4: vignette */
.hero-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 110% 100% at 50% 50%, transparent 35%, rgba(0,0,0,.7) 100%);
  pointer-events:none;
}

.hero-content{
  position:relative;z-index:2;
  padding-top:130px;padding-bottom:60px;
  max-width:1100px;   /* wider so long words don't overflow the gradient box */
  width:100%;
}
.hero-label{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:400;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);margin-bottom:36px;
  opacity:0;animation:fadeUp .7s .1s forwards;
}
.hero-label::before{
  content:'';display:block;width:32px;height:1px;
  background:linear-gradient(to right,transparent,var(--orange));
}

/* ── THE METALLIC HERO TITLE ── */
.hero-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  font-size:clamp(4rem,8.5vw,8.5rem);
  line-height:.92;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin-bottom:32px;

  /* Orange → White → Teal metallic sweep — logo colors */
  background:linear-gradient(
    90deg,
    #7a2800  0%,
    #c84a00  5%,
    #ff6b00  11%,
    #ff9060  17%,
    #ffd4b0  23%,
    #ffffff  29%,   /* primary bright peak */
    #ccf0ff  35%,
    #40d8f0  41%,
    #00c8e0  47%,
    #0090a8  55%,
    #004858  63%,
    #8898a8  72%,   /* steel recovery */
    #dce4ec  80%,
    #ffffff  86%,   /* secondary bright peak */
    #b0bcc8  92%,
    #6a7888  100%
  );
  background-size:350% 100%;
  background-position:var(--shimmer) 0%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;

  /* shadow reacts to light direction — driven by JS via CSS var */
  filter: var(--title-shadow);

  opacity:0;
  animation:fadeUp .8s .2s forwards;
}
.hero-title-indent{padding-left:clamp(1.5rem,4vw,4rem)}

.hero-sub{
  font-size:.98rem;font-weight:300;
  color:var(--muted);max-width:460px;
  line-height:1.8;margin-bottom:44px;
  opacity:0;animation:fadeUp .7s .45s forwards;
}
.hero-ctas{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .7s .6s forwards;
}

/* proof bar */
.hero-proof{
  position:relative;z-index:2;
  border-top:1px solid var(--border);
  background:rgba(7,7,13,.6);backdrop-filter:blur(12px);
}
.hero-proof-inner{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;padding:26px 32px;
}
.proof-item{display:flex;flex-direction:column;align-items:center;padding:0 40px}
.proof-val{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:1.7rem;
  color:var(--orange);line-height:1;
}
.proof-plus{font-size:1rem}
.proof-lbl{
  font-size:.62rem;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);margin-top:4px;
}
.proof-rule{width:1px;height:32px;background:var(--border-hi)}

/* ─── SERVICES ──────────────────────────────────────────── */
.services{padding:110px 0;background:var(--bg2)}
.srv-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
}
.srv-card{
  background:var(--bg2);padding:40px 36px;
  transition:background var(--t);position:relative;overflow:hidden;
}
.srv-card::after{
  content:'';position:absolute;bottom:0;left:36px;right:36px;height:1px;
  background:linear-gradient(to right,transparent,var(--orange),transparent);
  opacity:0;transition:opacity var(--t);
}
.srv-card:hover{background:var(--bg3)}
.srv-card:hover::after{opacity:.6}
.srv-num{
  font-family:'Barlow Condensed',sans-serif;
  font-size:3.5rem;font-weight:300;
  color:rgba(255,107,0,.12);line-height:1;margin-bottom:20px;
}
.srv-card h3{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:1.4rem;text-transform:uppercase;
  letter-spacing:.04em;color:#fff;margin-bottom:12px;line-height:1.15;
}
.srv-card p{font-size:.88rem;color:var(--muted);line-height:1.75;margin-bottom:24px}
.srv-tags{display:flex;flex-wrap:wrap;gap:7px}
.srv-tags li{
  font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--border-hi);padding:4px 10px;border-radius:2px;
}

/* ─── ABOUT ─────────────────────────────────────────────── */
.about{padding:110px 0;background:var(--bg)}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center}
.about-logo-wrap{
  border-radius:8px;overflow:hidden;
 
}
.about-logo-wrap img{width:100%;height:auto;display:block}
.about-quote{
  margin-top:24px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.1rem;font-weight:400;font-style:italic;
  color:var(--muted);text-align:center;
  letter-spacing:.04em;line-height:1.6;
}
.about-desc{font-size:.95rem;color:var(--muted);line-height:1.8;margin:16px 0 32px}
.about-list{display:flex;flex-direction:column;gap:13px}
.about-list li{display:flex;align-items:center;gap:12px;font-size:.9rem;color:var(--text)}
.chk{
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,107,0,.1);color:var(--orange);font-size:.7rem;font-weight:600;
  border:1px solid rgba(255,107,0,.25);flex-shrink:0;
}

/* ─── WHY ───────────────────────────────────────────────── */
.why{padding:110px 0;background:var(--bg2)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 56px}
.why-line{
  width:32px;height:2px;
  background:linear-gradient(to right,var(--orange),var(--teal));
  margin-bottom:20px;
}
.why-item h3{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:1.25rem;text-transform:uppercase;
  letter-spacing:.04em;color:#fff;margin-bottom:10px;
}
.why-item p{font-size:.88rem;color:var(--muted);line-height:1.75}

/* ─── CTA BAND ──────────────────────────────────────────── */
.cta-band{
  padding:88px 0;
  background:linear-gradient(135deg,var(--bg3),var(--bg4));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(112deg,transparent 25%,rgba(255,107,0,.04) 35%,rgba(255,255,255,.04) 40%,rgba(0,200,224,.03) 47%,transparent 58%);
}
.cta-inner{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;
  gap:48px;flex-wrap:wrap;
}
.cta-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:clamp(1.8rem,3vw,2.8rem);
  text-transform:uppercase;letter-spacing:.03em;
  color:#fff;margin-bottom:8px;line-height:1.1;
}
.cta-sub{font-size:.9rem;color:var(--muted)}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ─── CONTACT ───────────────────────────────────────────── */
.contact{padding:110px 0;background:var(--bg)}
.contact-inner{display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:start}
.contact-desc{color:var(--muted);margin:14px 0 40px;font-size:.9rem;line-height:1.8}
.contact-list{display:flex;flex-direction:column;gap:24px;margin-bottom:40px}
.contact-list li{display:flex;align-items:flex-start;gap:16px}
.ci{
  width:38px;height:38px;border-radius:4px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:rgba(255,107,0,.07);border:1px solid rgba(255,107,0,.15);color:var(--orange);
}
.ci svg{width:16px;height:16px}
.contact-list div{display:flex;flex-direction:column;gap:2px}
.c-lbl{font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.c-small{font-size:.82rem;opacity:.6}
.contact-list a{font-size:.95rem;color:var(--text);transition:color var(--t)}
.contact-list a:hover{color:var(--orange)}
.social-row{display:flex;align-items:center;gap:16px}
.social-lbl{font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.social-icons{display:flex;gap:8px}
.soc-icon{
  width:36px;height:36px;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);border:1px solid var(--border-hi);
  color:var(--muted);transition:all var(--t);
}
.soc-icon svg{width:16px;height:16px}
.soc-icon:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-2px)}

/* ─── FORM ──────────────────────────────────────────────── */
.cform{background:var(--bg3);border:1px solid var(--border-hi);padding:44px;position:relative}
.cform::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--orange) 40%,var(--teal) 60%,transparent);
}
.cform h3{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:1.8rem;text-transform:uppercase;
  letter-spacing:.04em;color:#fff;margin-bottom:28px;
}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:.65rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.fg input,.fg select,.fg textarea{
  background:var(--bg4);border:1px solid var(--border);
  color:var(--text);padding:12px 16px;font-size:.9rem;resize:vertical;
  transition:border-color var(--t);
}
.fg input::placeholder,.fg textarea::placeholder{color:#303040}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--orange)}
.fg select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%2370708a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.fg select option{background:var(--bg4)}
.f-note{font-size:.72rem;color:var(--muted);text-align:center;margin-top:14px}
.f-success{
  display:none;position:absolute;inset:0;background:var(--bg3);
  flex-direction:column;align-items:center;justify-content:center;
  gap:18px;text-align:center;padding:48px;
}
.f-success.show{display:flex}
.f-success svg{width:52px;height:52px}
.f-success p{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:1.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--teal);
}

/* ─── FOOTER ────────────────────────────────────────────── */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:72px 0 0}
.foot-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:56px;padding-bottom:56px}
.foot-brand{display:flex;flex-direction:column;gap:16px}
.foot-logo{display:flex;align-items:center}
.foot-logo-img{
  height:110px;
  width:auto;
  object-fit:contain;
  mix-blend-mode:screen;     /* blends the dark bg away, logo floats on footer */
}
.foot-tagline{font-size:.85rem;color:var(--muted);line-height:1.6;max-width:280px}
.foot-social{display:flex;gap:8px}
.footer h4{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--orange);margin-bottom:18px;
}
.foot-list{display:flex;flex-direction:column;gap:10px}
.foot-list li{font-size:.85rem;color:var(--muted)}
.foot-ct{display:flex;flex-direction:column;gap:10px}
.foot-ct a{font-size:.85rem;color:var(--muted);transition:color var(--t)}
.foot-ct a:hover{color:var(--orange)}
.foot-bot{border-top:1px solid var(--border);padding:22px 0}
.foot-bot-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.foot-bot p{font-size:.75rem;color:var(--muted);letter-spacing:.06em}
.foot-bot-soc{display:flex;gap:18px}
.foot-bot-soc a{color:var(--muted);transition:color var(--t)}
.foot-bot-soc a:hover{color:var(--orange)}

/* ─── SCROLL REVEAL ─────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* ─── KEYFRAMES ─────────────────────────────────────────── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes bandDrift{
  0%  {transform:translateX(-6%) skewX(-2deg)}
  100%{transform:translateX( 6%) skewX( 2deg)}
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1024px){
  .srv-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .about-inner{grid-template-columns:1fr;gap:48px}
}
@media(max-width:900px){
  .contact-inner{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}

/* ── 768px: tablet / large phone ── */
@media(max-width:768px){
  .nav-links{display:none}
  .burger{display:flex}

  /* Hero — center-aligned on mobile, each word gets its own moment */
  .hero-content{padding-top:100px;padding-bottom:40px;text-align:center}
  .hero-label{justify-content:center}
  .hero-label::before{display:none} /* remove left line on center layout */
  .hero-title{
    font-size:clamp(2.8rem,11vw,5rem);
    text-align:center;
  }
  .hero-title-indent{padding-left:0} /* no indent — centered layout handles it */
  .hero-sub{margin-left:auto;margin-right:auto;text-align:center}
  .hero-ctas{justify-content:center}

  /* Proof bar — 2×2 grid */
  .hero-proof-inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:0;
    padding:0;
  }
  .proof-item{
    padding:22px 16px;
    border:1px solid var(--border);
    display:flex;flex-direction:column;align-items:center;
  }
  .proof-rule{display:none}

  .srv-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;align-items:flex-start}
  .foot-inner{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .foot-bot-inner{flex-direction:column;text-align:center}
  .foot-bot-soc{justify-content:center}
}

/* ── 480px: standard phones ── */
@media(max-width:480px){
  .container{padding:0 20px}
  .hero-content{padding-top:90px}
  .hero-title{font-size:clamp(2.3rem,10vw,3.8rem)}
  .hero-ctas,.cta-actions{flex-direction:column;align-items:center}
  .hero-ctas .btn,.cta-actions .btn{width:100%;justify-content:center}
  .cform{padding:24px 18px}
  .srv-card{padding:28px 22px}
  .why-item{padding:0}
  .cta-inner{align-items:center;text-align:center}
  .cta-title{font-size:clamp(1.6rem,7vw,2.2rem)}
  .cta-sub{text-align:center}
  .contact-info .sec-title{font-size:clamp(1.6rem,7vw,2.2rem)}
  .foot-logo-img{height:80px}
}

/* ── 380px: small phones (iPhone SE etc.) ── */
@media(max-width:380px){
  .container{padding:0 16px}
  .hero-content{padding-top:80px}
  .hero-title{font-size:clamp(2rem,9.5vw,3.2rem)}

  /* Nav — slim it down */
  .nav-inner{height:60px}
  .logo-sub{display:none}
  .nav-logo-img{height:38px;width:38px}
  .logo-name{font-size:1rem}

  /* Proof bar — stack fully, drop the grid gap */
  .hero-proof-inner{grid-template-columns:1fr 1fr}
  .proof-item{padding:16px 10px}
  .proof-val{font-size:1.3rem}
  .proof-lbl{font-size:.58rem}

  /* Simplify hero label */
  .hero-label{font-size:.62rem;letter-spacing:.18em}

  /* Services */
  .srv-num{font-size:2.5rem}
  .srv-card{padding:24px 18px}

  /* Footer */
  .foot-logo-img{height:60px}
  .footer{padding:48px 0 0}
  .foot-inner{gap:32px;padding-bottom:32px}

  /* Form */
  .cform{padding:20px 16px}
  .cform h3{font-size:1.4rem}
}

/* ── 320px: absolute minimum ── */
@media(max-width:320px){
  .container{padding:0 12px}
  .hero-title{font-size:clamp(1.75rem,9vw,2.6rem)}
  .hero-sub{font-size:.85rem}
  .hero-label{display:none} /* clean it up at this tiny size */
  .proof-val{font-size:1.1rem}
  .proof-lbl{font-size:.52rem;letter-spacing:.1em}
  .btn-lg{padding:13px 24px;font-size:.85rem}
  .sec-title{font-size:clamp(1.5rem,7.5vw,2rem)}
  .srv-card h3{font-size:1.2rem}
  .cta-title{font-size:1.5rem}

  /* proof bar: stack vertically at 320 — 2 cols is too tight */
  .hero-proof-inner{grid-template-columns:1fr}
  .proof-item{
    flex-direction:row;gap:12px;
    align-items:center;justify-content:center;
    padding:12px 16px;
    border-top:none;border-left:none;border-right:none;
  }
  .proof-val{font-size:1.1rem}
}
