
/* ============================================================
   TECHNOPOINT — Landing Page
   Design system
   ============================================================ */
:root{
  /* brand */
  --brand: #0E5FB4;          /* azul Technopoint */
  --brand-600: #0B4E96;
  --brand-700: #093F7A;
  --brand-100: #E5F0FB;
  --brand-50: #F2F8FE;

  --navy: #0A1A30;           /* seções premium escuras */
  --navy-2: #0E2440;
  --navy-soft: #122944;

  --wa: #1FA855;             /* WhatsApp CTA */
  --wa-600: #178A45;

  /* neutrals (cool-tinted) */
  --ink: #0F1A28;
  --ink-2: #33414F;
  --muted: #647386;
  --line: #E4E9F0;
  --line-2: #EFF3F8;
  --bg: #FFFFFF;
  --bg-soft: #F6F9FC;
  --bg-soft-2: #EEF3F9;
  --white: #FFFFFF;

  --shadow-sm: 0 1px 2px rgba(15,26,40,.06), 0 1px 3px rgba(15,26,40,.05);
  --shadow-md: 0 10px 30px -12px rgba(13,60,120,.22);
  --shadow-lg: 0 30px 60px -20px rgba(10,26,48,.35);

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;

  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);

  --font-display: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Manrope", ui-sans-serif, system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; letter-spacing:-.02em; margin:0; color:var(--ink); }
p{ margin:0; }
::selection{ background:var(--brand); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px, 9vw, 120px); }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:600;
  font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brand-600);
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--brand); border-radius:2px; }
.eyebrow.on-dark{ color:#7FB6F0; }
.eyebrow.on-dark::before{ background:#3F8DDB; }

.h2{ font-size:clamp(30px, 4.6vw, 50px); }
.lead{ font-size:clamp(17px,1.9vw,21px); color:var(--ink-2); max-width:60ch; }
.muted{ color:var(--muted); }
.center{ text-align:center; margin-inline:auto; }

/* buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-display); font-weight:600; font-size:16px;
  padding:15px 26px; border-radius:999px; border:1.5px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  line-height:1; white-space:nowrap;
}
.btn svg{ width:20px; height:20px; }
.btn:active{ transform:translateY(1px); }
.btn-wa{ background:var(--wa); color:#fff; box-shadow:0 10px 24px -10px rgba(31,168,85,.7); }
.btn-wa:hover{ background:var(--wa-600); transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(31,168,85,.7); }
.btn-primary{ background:var(--brand); color:#fff; box-shadow:0 10px 24px -10px rgba(14,95,180,.6); }
.btn-primary:hover{ background:var(--brand-600); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--brand); color:var(--brand-600); }
.btn-ghost.on-dark{ color:#fff; border-color:rgba(255,255,255,.28); }
.btn-ghost.on-dark:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.btn-lg{ padding:18px 32px; font-size:17px; }
.btn-block{ width:100%; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.site-header.scrolled{ border-color:var(--line); box-shadow:var(--shadow-sm); }
.nav{ display:flex; align-items:center; gap:28px; height:74px; }
.brand{ display:flex; align-items:center; gap:10px; margin-right:auto; }
.brand img{ height:23px; width:auto; }
.brand-name{ display:flex; flex-direction:column; line-height:1; }
.brand-name b{ font-family:var(--font-display); font-weight:600; font-size:19px; letter-spacing:-.01em; color:var(--brand-600); }
.brand-name span{ font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:3px; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-weight:600; font-size:15px; color:var(--ink-2); transition:color .15s; white-space:nowrap; }
.nav-links a:hover{ color:var(--brand-600); }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-toggle{ display:none; background:none; border:0; padding:8px; color:var(--ink); }
.nav-toggle svg{ width:28px; height:28px; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:55;
  background:rgba(10,26,48,.5); backdrop-filter:blur(4px);
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.mobile-menu.open{ opacity:1; pointer-events:auto; }
.mobile-panel{
  position:absolute; top:0; right:0; height:100%; width:min(86vw,360px);
  background:#fff; box-shadow:var(--shadow-lg);
  transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; padding:24px;
}
.mobile-menu.open .mobile-panel{ transform:translateX(0); }
.mobile-panel .mm-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
.mobile-panel a.mm-link{ font-family:var(--font-display); font-weight:600; font-size:20px; padding:15px 0; border-bottom:1px solid var(--line-2); color:var(--ink); }
.mobile-panel a.mm-link:hover{ color:var(--brand-600); }
.mm-close{ background:none; border:0; padding:6px; color:var(--ink); }
.mm-close svg{ width:28px; height:28px; }
.mm-foot{ margin-top:auto; padding-top:20px; }

/* ============================================================
   HERO — 3 variantes
   ============================================================ */
.hero{ display:none; }
body[data-hero="a"] #hero-a{ display:block; }
body[data-hero="b"] #hero-b{ display:block; }
body[data-hero="c"] #hero-c{ display:block; }

.trust-chips{ display:flex; flex-wrap:wrap; gap:10px 14px; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13.5px; font-weight:600; color:var(--ink-2);
  background:var(--bg-soft); border:1px solid var(--line);
  padding:8px 14px; border-radius:999px;
}
.chip svg{ width:16px; height:16px; color:var(--brand); }
.chip.on-dark{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.16); color:#D8E4F2; }
.chip.on-dark svg{ color:#5AA0E6; }

.cta-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* Variante A — split */
#hero-a{ padding-block:clamp(48px,7vw,90px); }
.hero-a-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; }
#hero-a h1{ font-size:clamp(38px,5.4vw,68px); margin:18px 0 0; }
#hero-a .hero-copy > .lead{ margin-top:22px; }
#hero-a .cta-row{ margin-top:34px; }
#hero-a .trust-chips{ margin-top:30px; }
.hero-photo{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio:4/4.6; background:var(--bg-soft-2);
}
.hero-photo img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{
  position:absolute; left:18px; bottom:18px; right:18px;
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  border-radius:var(--r-md); padding:14px 16px; box-shadow:var(--shadow-md);
}
.hero-badge .hb-num{ font-family:var(--font-display); font-weight:600; font-size:28px; color:var(--brand-600); line-height:1; }
.hero-badge .hb-txt{ font-size:13.5px; color:var(--ink-2); line-height:1.3; }
.hero-badge .hb-div{ width:1px; align-self:stretch; background:var(--line); }

/* Variante B — full dark image */
#hero-b{ position:relative; color:#fff; padding-block:clamp(90px,13vw,160px); overflow:hidden; }
#hero-b .hero-bg{ position:absolute; inset:0; z-index:0; }
#hero-b .hero-bg img{ width:100%; height:100%; object-fit:cover; }
#hero-b .hero-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(100deg, rgba(7,18,34,.93) 0%, rgba(8,22,42,.82) 42%, rgba(9,30,58,.55) 100%);
}
#hero-b .wrap{ position:relative; z-index:1; }
#hero-b h1{ font-size:clamp(40px,6vw,76px); color:#fff; margin:20px 0 0; max-width:16ch; }
#hero-b .lead{ color:#C7D6E8; margin-top:24px; }
#hero-b .cta-row{ margin-top:36px; }
#hero-b .trust-chips{ margin-top:34px; }

/* Variante C — minimal centrado */
#hero-c{ padding-block:clamp(56px,8vw,104px); background:
  radial-gradient(1200px 500px at 50% -10%, var(--brand-50), transparent 70%); }
#hero-c .inner{ max-width:880px; margin-inline:auto; text-align:center; }
#hero-c h1{ font-size:clamp(40px,6.4vw,76px); margin:18px auto 0; }
#hero-c .lead{ margin:24px auto 0; }
#hero-c .cta-row{ margin-top:34px; justify-content:center; }
#hero-c .trust-chips{ margin-top:30px; justify-content:center; }
#hero-c .hero-strip{
  margin-top:54px; display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
#hero-c .hero-strip .hs{ border-radius:var(--r-md); overflow:hidden; aspect-ratio:1/1; box-shadow:var(--shadow-md); background:var(--bg-soft-2); }
#hero-c .hero-strip img{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   STATS STRIP
   ============================================================ */
.stats{ background:var(--navy); color:#fff; }
.stats .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding-block:46px; }
.stat{ text-align:center; }
.stat b{ font-family:var(--font-display); font-weight:600; font-size:clamp(30px,3.6vw,44px); color:#fff; display:block; letter-spacing:-.02em; }
.stat span{ font-size:14px; color:#9FB4CC; margin-top:6px; display:block; }
.stat .accent{ color:#5AA0E6; }

/* ============================================================
   SERVICES
   ============================================================ */
.sec-head{ max-width:640px; }
.sec-head.center{ margin-inline:auto; }
.sec-head h2{ margin-top:14px; }
.sec-head p{ margin-top:16px; }
.services-grid{
  margin-top:clamp(40px,5vw,60px);
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.svc{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px 26px 28px; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--brand-100); }
.svc-ico{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:var(--brand-100); color:var(--brand-600); margin-bottom:18px;
}
.svc-ico svg{ width:27px; height:27px; }
.svc h3{ font-size:20px; }
.svc p{ margin-top:9px; font-size:15px; color:var(--muted); }

/* ============================================================
   STEPS
   ============================================================ */
.steps{ background:var(--bg-soft); }
.steps-grid{ margin-top:clamp(40px,5vw,56px); display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.step{ position:relative; padding:32px 28px; background:#fff; border-radius:var(--r-lg); border:1px solid var(--line); }
.step-n{
  font-family:var(--font-display); font-weight:600; font-size:18px;
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:var(--brand); color:#fff; margin-bottom:20px;
}
.step h3{ font-size:20px; }
.step p{ margin-top:10px; color:var(--muted); font-size:15.5px; }

/* ============================================================
   ADVANCED REPAIRS (dark)
   ============================================================ */
.advanced{ background:var(--navy); color:#fff; overflow:hidden; }
.adv-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,80px); align-items:center; }
.advanced h2{ color:#fff; margin-top:14px; }
.advanced .lead{ color:#BCCDE2; margin-top:18px; }
.adv-list{ margin-top:28px; display:grid; gap:16px; }
.adv-item{ display:flex; gap:14px; align-items:flex-start; }
.adv-item .ck{ flex:none; width:26px; height:26px; border-radius:50%; background:rgba(90,160,230,.16); color:#5AA0E6; display:grid; place-items:center; margin-top:2px; }
.adv-item .ck svg{ width:15px; height:15px; }
.adv-item b{ font-family:var(--font-display); font-weight:600; font-size:17px; color:#fff; }
.adv-item span{ display:block; color:#9FB4CC; font-size:14.5px; margin-top:3px; }
.adv-photo{ border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/4.4; }
.adv-photo img{ width:100%; height:100%; object-fit:cover; }
.advanced .cta-row{ margin-top:32px; }

/* ============================================================
   ACCESSORIES
   ============================================================ */
.acc-grid{ margin-top:clamp(40px,5vw,56px); display:grid; grid-template-columns:repeat(12,1fr); gap:16px; }
.acc-card{ position:relative; border-radius:var(--r-lg); overflow:hidden; background:var(--bg-soft-2); box-shadow:var(--shadow-sm); }
.acc-card img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.acc-card:hover img{ transform:scale(1.04); }
.acc-card .cap{
  position:absolute; left:0; right:0; bottom:0; padding:24px 22px 20px;
  background:linear-gradient(to top, rgba(10,26,48,.85), transparent);
  color:#fff;
}
.acc-card .cap b{ font-family:var(--font-display); font-weight:600; font-size:19px; display:block; }
.acc-card .cap span{ font-size:13.5px; color:#D8E4F2; }
.acc-tall{ grid-column:span 5; aspect-ratio:5/6; }
.acc-wide{ grid-column:span 7; }
.acc-half{ grid-column:span 6; aspect-ratio:3/2; }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{ background:var(--bg-soft); }
.rev-top{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.gscore{ display:flex; align-items:center; gap:16px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:16px 22px; box-shadow:var(--shadow-sm); }
.gscore .num{ font-family:var(--font-display); font-weight:600; font-size:42px; line-height:1; color:var(--ink); }
.stars{ display:inline-flex; gap:2px; color:#F5A623; }
.stars svg{ width:18px; height:18px; }
.gscore small{ color:var(--muted); font-size:13px; display:block; margin-top:4px; }
.rev-grid{ margin-top:clamp(36px,4vw,48px); display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rev{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:26px 24px; display:flex; flex-direction:column; gap:14px; }
.rev p{ font-size:15.5px; color:var(--ink-2); line-height:1.55; }
.rev .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.rev .av{ width:42px; height:42px; border-radius:50%; background:var(--brand-100); color:var(--brand-600); display:grid; place-items:center; font-family:var(--font-display); font-weight:600; }
.rev .who b{ font-size:15px; font-family:var(--font-display); }
.rev .who span{ font-size:12.5px; color:var(--muted); display:block; }

/* ============================================================
   LEAD FORM
   ============================================================ */
.quote{ background:var(--navy); color:#fff; }
.quote-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(36px,6vw,72px); align-items:center; }
.quote h2{ color:#fff; margin-top:14px; }
.quote .lead{ color:#BCCDE2; margin-top:18px; }
.quote-points{ margin-top:26px; display:grid; gap:14px; }
.quote-points li{ list-style:none; display:flex; gap:12px; align-items:center; color:#D8E4F2; font-size:15.5px; }
.quote-points .ck{ flex:none; width:24px; height:24px; border-radius:50%; background:rgba(31,168,85,.18); color:#43C97B; display:grid; place-items:center; }
.quote-points .ck svg{ width:14px; height:14px; }
.form-card{ background:#fff; border-radius:var(--r-xl); padding:clamp(26px,3vw,40px); box-shadow:var(--shadow-lg); color:var(--ink); }
.form-card h3{ font-size:24px; }
.form-card .fc-sub{ color:var(--muted); font-size:15px; margin-top:6px; }
.field{ margin-top:18px; }
.field label{ display:block; font-weight:600; font-size:14px; margin-bottom:7px; color:var(--ink-2); }
.field input, .field select, .field textarea{
  width:100%; font-family:inherit; font-size:16px; color:var(--ink);
  padding:14px 15px; border:1.5px solid var(--line); border-radius:12px;
  background:#fff; transition:border-color .15s, box-shadow .15s;
}
.field textarea{ resize:vertical; min-height:90px; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--brand); box-shadow:0 0 0 4px var(--brand-50);
}
.field input.err, .field select.err{ border-color:#E0483D; box-shadow:0 0 0 4px rgba(224,72,61,.1); }
.field .msg{ font-size:12.5px; color:#E0483D; margin-top:6px; display:none; }
.field.invalid .msg{ display:block; }
.form-grid2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-card .submit{ margin-top:22px; }
.form-fine{ font-size:12.5px; color:var(--muted); margin-top:14px; text-align:center; }
.form-fine a{ color:var(--brand-600); font-weight:600; }

/* ============================================================
   LOCATION / FOOTER
   ============================================================ */
.local-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,56px); align-items:stretch; }
.local-info .info-list{ margin-top:28px; display:grid; gap:22px; }
.info-row{ display:flex; gap:16px; align-items:flex-start; }
.info-row .ico{ flex:none; width:46px; height:46px; border-radius:13px; background:var(--brand-100); color:var(--brand-600); display:grid; place-items:center; }
.info-row .ico svg{ width:22px; height:22px; }
.info-row b{ font-family:var(--font-display); font-weight:600; font-size:16px; display:block; }
.info-row p{ color:var(--muted); font-size:15px; margin-top:3px; }
.info-row a{ color:var(--brand-600); font-weight:600; }
.map-card{ border-radius:var(--r-lg); overflow:hidden; min-height:340px; position:relative; border:1px solid var(--line); background:var(--bg-soft); }
.map-card iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; }
.map-card .map-open{ position:absolute; right:14px; bottom:14px; display:inline-flex; align-items:center; gap:7px; padding:10px 16px; background:var(--brand); color:#fff; font-family:var(--font-display); font-weight:600; font-size:14px; border-radius:999px; text-decoration:none; box-shadow:0 10px 24px -8px rgba(14,95,180,.6); transition:transform .15s ease, background .15s ease; }
.map-card .map-open:hover{ background:var(--brand-600); transform:translateY(-1px); }
.map-card .map-open svg{ width:17px; height:17px; }

.site-footer{ background:var(--navy); color:#9FB4CC; padding-block:56px 32px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.foot-brand img{ height:30px; margin-bottom:16px; }
.foot-brand p{ font-size:14.5px; max-width:34ch; line-height:1.6; }
.foot-col h4{ color:#fff; font-size:14px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:16px; }
.foot-col a, .foot-col p{ display:block; font-size:14.5px; color:#9FB4CC; margin-bottom:10px; transition:color .15s; }
.foot-col a:hover{ color:#fff; }
.foot-social{ display:flex; gap:12px; margin-top:6px; }
.foot-social a{ width:42px; height:42px; border-radius:12px; background:rgba(255,255,255,.07); display:grid; place-items:center; color:#C7D6E8; transition:background .15s; }
.foot-social a:hover{ background:var(--brand); color:#fff; }
.foot-social svg{ width:20px; height:20px; }
.foot-bottom{ margin-top:44px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; }

/* Floating WA */
.wa-float{
  position:fixed; right:20px; bottom:20px; z-index:50;
  display:flex; align-items:center; gap:0; overflow:hidden;
  background:var(--wa); color:#fff; border-radius:999px;
  box-shadow:0 14px 30px -10px rgba(31,168,85,.7);
  padding:0; height:60px; transition:transform .2s ease, box-shadow .2s;
}
.wa-float:hover{ transform:translateY(-2px) scale(1.02); }
.wa-float .ic{ width:60px; height:60px; display:grid; place-items:center; flex:none; }
.wa-float .ic svg{ width:30px; height:30px; }
.wa-float .lb{ font-family:var(--font-display); font-weight:600; font-size:15px; padding-right:22px; max-width:0; opacity:0; white-space:nowrap; transition:max-width .3s ease, opacity .25s, padding .3s; }
@media(hover:hover){ .wa-float:hover .lb{ max-width:200px; opacity:1; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 940px){
  .nav-links, .nav-cta .btn-desktop{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .hero-a-grid{ grid-template-columns:1fr; }
  #hero-a .hero-media{ order:-1; }
  .adv-grid, .quote-grid, .local-grid{ grid-template-columns:1fr; }
  .adv-photo{ aspect-ratio:16/10; }
  .quote .quote-media{ order:-1; }
  .services-grid, .steps-grid, .rev-grid{ grid-template-columns:repeat(2,1fr); }
  .stats .wrap{ grid-template-columns:repeat(2,1fr); gap:32px 16px; }
  .acc-tall{ grid-column:span 6; }
  .acc-wide{ grid-column:span 6; }
  .acc-half{ grid-column:span 6; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .foot-brand{ grid-column:1 / -1; }
}
@media (max-width: 600px){
  body{ font-size:16px; }
  .services-grid, .steps-grid, .rev-grid{ grid-template-columns:1fr; }
  .form-grid2{ grid-template-columns:1fr; }
  #hero-c .hero-strip{ grid-template-columns:repeat(3,1fr); gap:10px; }
  .acc-tall, .acc-wide, .acc-half{ grid-column:1 / -1; aspect-ratio:16/10; }
  .rev-top{ align-items:flex-start; }
  .foot-grid{ grid-template-columns:1fr; }
  .brand-name span{ display:none; }
  .hero-badge{ left:12px; right:12px; bottom:12px; padding:12px; }
}
@media (max-width: 380px){
  .stats .wrap{ grid-template-columns:1fr; }
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }


.brand .wordmark{height:10px;width:auto;display:block}
@media(max-width:600px){.brand .wordmark{height:9px}.brand img{height:21px}}
.apple{background:var(--bg-soft);border-block:1px solid var(--line)}
.apple-head{max-width:780px}
.apple-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(34px,4vw,46px)}
.apple-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 22px;transition:transform .2s ease,box-shadow .2s ease}
.apple-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.apple-card .ai{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:var(--ink);color:#fff;margin-bottom:16px}
.apple-card .ai svg{width:25px;height:25px}
.apple-card h3{font-size:17.5px}
.apple-card p{margin-top:8px;font-size:14px;color:var(--muted)}
.apple-note{margin-top:28px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;padding:18px 22px;background:var(--brand-50);border:1px solid var(--brand-100);border-radius:var(--r-md);font-size:15.5px;color:var(--ink-2)}
.apple-note svg{width:24px;height:24px;color:var(--brand-600);flex:none}
@media(max-width:940px){.apple-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.apple-grid{grid-template-columns:1fr}}


.apple-verify{margin-top:28px;display:flex;gap:22px;align-items:center;flex-wrap:wrap;padding:24px 28px;background:var(--ink);color:#fff;border-radius:var(--r-lg)}
.apple-verify .av-badge{flex:none;width:56px;height:56px;border-radius:50%;background:rgba(67,201,123,.16);color:#43C97B;display:grid;place-items:center}
.apple-verify .av-badge svg{width:32px;height:32px}
.apple-verify .av-body{flex:1;min-width:250px}
.apple-verify .av-tag{font-family:var(--font-display);font-weight:600;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:#7FB6F0;display:block;margin-bottom:7px}
.apple-verify .av-body b{font-family:var(--font-display);font-weight:600;font-size:18px;color:#fff;display:block;line-height:1.25}
.apple-verify .av-body p{color:#9FB4CC;font-size:13.5px;margin-top:7px;line-height:1.5}
.apple-verify .btn{flex:none}
.apple-verify .av-steps{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px 18px}
.apple-verify .av-steps li{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#CFE0F2;line-height:1.35}
.apple-verify .av-steps li b{color:#fff;font-weight:600;font-size:13px}
.apple-verify .av-step-n{flex:none;width:19px;height:19px;border-radius:50%;background:rgba(67,201,123,.16);color:#43C97B;font-family:var(--font-display);font-weight:600;font-size:11px;display:grid;place-items:center}
@media(max-width:620px){.apple-verify{padding:22px}.apple-verify .btn{width:100%}}

.apple-fine{margin-top:18px;font-size:12.5px;line-height:1.55;color:var(--muted);max-width:82ch}

.team{background:#fff}
.team-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(32px,5vw,64px);align-items:center}
.team-photo{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:3/2}
.team-points{margin-top:26px;display:grid;gap:16px}
.team-point{display:flex;gap:13px;align-items:flex-start}
.team-point .ck{flex:none;width:26px;height:26px;border-radius:50%;background:var(--brand-100);color:var(--brand-600);display:grid;place-items:center;margin-top:2px}
.team-point .ck svg{width:15px;height:15px}
.team-point b{font-family:var(--font-display);font-weight:600;font-size:16.5px;color:var(--ink)}
.team-point span{display:block;color:var(--muted);font-size:14.5px;margin-top:2px}
@media(max-width:940px){.team-grid{grid-template-columns:1fr}.team .team-media{order:-1}}

