/* =============================================================
   COMERCIAL SERVIN SpA — Industrial Dark / Orange
   1. Tokens
   ============================================================= */
:root{
  --bg:        #0c0d12;     /* dark navy-charcoal (eco del azul del logo) */
  --bg-2:      #12131a;
  --bg-3:      #181a22;     /* card */
  --bg-4:      #20222c;
  --ink:       #f4f5f7;
  --ink-2:     #c6c8d0;
  --ink-mute:  #888b96;
  --accent:    #f2530e;     /* naranjo corporativo del logo */
  --accent-2:  #ff6f2c;
  --accent-deep:#c13d06;
  --line:      rgba(244,245,247,.10);
  --line-2:    rgba(244,245,247,.16);
  --ok:        #34d27b;

  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --display: "Archivo", var(--sans);
  --mono: "JetBrains Mono", ui-monospace, monospace;

  --ease-out:  cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.25,.46,.45,.94);
  --ease-bounce: cubic-bezier(.34,1.56,.64,1);

  --container: 1240px;
  --pad: clamp(1.1rem, 4vw, 2.4rem);
  --radius: 16px;
}

/* =============================================================
   2. Reset & base
   ============================================================= */
*,*::before,*::after{ box-sizing:border-box; margin:0; }
[hidden]{ display:none !important; }
html{ -webkit-text-size-adjust:100%; tab-size:2; overflow-x:clip; scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-size:16px; line-height:1.6;
  background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:clip; overscroll-behavior-y:none;
}
img,svg,video,iframe{ display:block; max-width:100%; }
img{ height:auto; }
button{ font:inherit; color:inherit; cursor:pointer; border:0; background:none; }
a{ color:inherit; text-decoration:none; }
input,textarea,select{ font:inherit; color:inherit; }
p{ text-wrap:pretty; }
h1,h2,h3,h4{ text-wrap:balance; line-height:1.04; letter-spacing:-.02em; font-family:var(--display); font-weight:800; }
::selection{ background:var(--accent); color:#fff; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:6px; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

/* =============================================================
   3. Utilities
   ============================================================= */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }
.sr-only,.skip-link{ position:absolute; }
.sr-only{ width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0; }
.skip-link{ top:-100px; left:1rem; padding:.6rem 1rem; background:var(--accent); color:#fff; z-index:9999; border-radius:8px; font-weight:600; }
.skip-link:focus{ top:1rem; }

.kicker{
  font-family:var(--mono); font-size:.72rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--accent-2);
  display:inline-flex; align-items:center; gap:.6rem; margin-bottom:1rem;
}
.kicker-dot{ width:8px;height:8px;border-radius:50%;background:var(--accent); box-shadow:0 0 0 4px rgba(242,83,14,.16); }

.section{ padding-block:clamp(3.6rem,8vw,7rem); position:relative; }
.section-head{ max-width:760px; margin-bottom:clamp(2rem,4vw,3.4rem); }
.h2{ font-size:clamp(1.7rem,4.2vw,2.9rem); }
.section-lead{ color:var(--ink-2); margin-top:1rem; font-size:1.06rem; max-width:60ch; }

.grid-2{ display:grid; gap:clamp(2rem,5vw,4rem); align-items:center; }
@media (min-width:960px){ .grid-2{ grid-template-columns:1fr 1fr; } .grid-2-wide{ grid-template-columns:.9fr 1.1fr; } }

/* =============================================================
   4. Buttons
   ============================================================= */
.btn{
  --bh:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.95rem 1.5rem; border-radius:999px; font-weight:600; font-size:.95rem;
  letter-spacing:.01em; transition:transform .35s var(--ease-out), background .3s, box-shadow .3s, color .3s;
  white-space:nowrap; border:1px solid transparent;
}
.btn-sm{ padding:.62rem 1.1rem; font-size:.85rem; }
.btn-block{ width:100%; }
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 8px 26px -8px rgba(242,83,14,.7); }
.btn-primary:hover{ background:var(--accent-2); box-shadow:0 14px 34px -8px rgba(242,83,14,.85); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(255,255,255,.04); }
.btn-whatsapp{ background:#1faf54; color:#fff; box-shadow:0 8px 24px -10px rgba(31,175,84,.8); }
.btn-whatsapp:hover{ background:#23c25e; }

.linklike{ background:none; border:0; color:var(--accent-2); font-weight:700; cursor:pointer; padding:0; font-family:var(--mono); font-size:.85em; }
.linklike:hover{ text-decoration:underline; }

/* =============================================================
   5. Splash
   ============================================================= */
.splash{
  position:fixed; inset:0; z-index:9000; background:var(--bg);
  display:grid; place-items:center;
  animation:splashSafety .01s 4.4s forwards;
}
.splash-inner{ display:flex; flex-direction:column; align-items:center; gap:1.2rem; }
.splash-logo{ font-family:var(--display); font-weight:900; font-size:2rem; letter-spacing:.3em; color:var(--ink); padding-left:.3em; }
.splash-bar{ width:160px; height:3px; background:var(--line-2); border-radius:2px; overflow:hidden; }
.splash-bar i{ display:block; height:100%; width:40%; background:var(--accent); animation:loadbar 1.1s var(--ease-soft) infinite; }
@keyframes loadbar{ 0%{ transform:translateX(-100%);} 100%{ transform:translateX(320%);} }
.splash.is-out{ opacity:0; pointer-events:none; transition:opacity .6s var(--ease-out); }
@keyframes splashSafety{ to{ opacity:0; pointer-events:none; visibility:hidden; } }

/* =============================================================
   6. Nav
   ============================================================= */
.nav{ position:fixed; top:0; left:0; right:0; z-index:1000; transition:background .4s, border-color .4s, backdrop-filter .4s; border-bottom:1px solid transparent; }
.nav-wrap{ width:100%; max-width:var(--container); margin-inline:auto; padding:.9rem var(--pad); display:flex; align-items:center; gap:1rem; }
.nav.is-scrolled{ background:rgba(12,13,18,.85); backdrop-filter:blur(14px); border-color:var(--line); }
.brand{ display:flex; align-items:center; gap:.6rem; color:var(--ink); }
.brand-mark{ color:var(--accent); display:grid; place-items:center; }
.brand-mark img{ height:38px; width:auto; }
.brand-name{ font-family:var(--display); font-weight:700; letter-spacing:.04em; font-size:1.02rem; }
.brand-name strong{ color:var(--accent); font-weight:900; }
.brand-name .spa{ color:var(--ink-mute); font-weight:600; }
.nav-links{ display:none; gap:1.7rem; margin-left:auto; }
.nav-links a{ font-size:.92rem; color:var(--ink-2); position:relative; padding:.3rem 0; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--accent); transition:width .3s var(--ease-out); }
.nav-links a:hover{ color:var(--ink); } .nav-links a:hover::after{ width:100%; }
.nav-cta{ display:none; gap:.5rem; margin-left:1rem; }
.nav-burger{ margin-left:auto; width:42px; height:42px; display:grid; place-items:center; gap:5px; border:1px solid var(--line-2); border-radius:10px; }
.nav-burger span{ width:18px; height:2px; background:var(--ink); display:block; transition:transform .3s, opacity .3s; }
.nav-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (min-width:1080px){
  .nav-links{ display:flex; } .nav-cta{ display:flex; } .nav-burger{ display:none; }
}
/* mobile drawer */
.nav-mobile{ position:fixed; inset:0 0 0 auto; width:min(82vw,340px); background:var(--bg-2); z-index:1100;
  transform:translateX(100%); transition:transform .4s var(--ease-out); border-left:1px solid var(--line);
  display:flex; flex-direction:column; padding:5rem 1.6rem 2rem; gap:.3rem; }
.nav-mobile.is-open{ transform:translateX(0); }
.nav-mobile a{ padding:.9rem .2rem; border-bottom:1px solid var(--line); color:var(--ink); font-size:1.05rem; font-family:var(--display); font-weight:600; }
.nav-mobile .btn{ margin-top:1.2rem; }
.nav-scrim{ position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:1090; opacity:0; pointer-events:none; transition:opacity .4s; }
.nav-scrim.is-open{ opacity:1; pointer-events:auto; }

/* =============================================================
   7. Hero
   ============================================================= */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; padding-top:6rem; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-img{ width:100%; height:100%; object-fit:cover; object-position:center; }
.hero-duotone{ position:absolute; inset:0; background:
  linear-gradient(180deg, rgba(11,11,13,.55) 0%, rgba(11,11,13,.35) 38%, rgba(11,11,13,.96) 100%);
  mix-blend-mode:normal; }
.hero-tint{ position:absolute; inset:0; background:
  radial-gradient(120% 80% at 80% 0%, rgba(242,83,14,.28), transparent 55%),
  linear-gradient(90deg, rgba(11,11,13,.9) 0%, rgba(11,11,13,.2) 60%, transparent 100%);
}
.hero-stripes{ position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.5;
  background-image:repeating-linear-gradient(135deg, rgba(242,83,14,.0) 0 38px, rgba(242,83,14,.06) 38px 40px); }
.hero-inner{ position:relative; z-index:2; width:100%; max-width:var(--container); margin-inline:auto; padding:0 var(--pad) clamp(3rem,6vw,5rem); }
.hero-title{ font-size:clamp(2.3rem,6.6vw,5.2rem); font-weight:900; line-height:.98; max-width:18ch; text-transform:uppercase; letter-spacing:-.025em; }
.hero-title em{ color:var(--accent); font-style:normal; }
.hero-sub{ margin-top:1.4rem; max-width:60ch; color:var(--ink-2); font-size:clamp(1rem,1.4vw,1.15rem); }
.hero-sub strong{ color:var(--ink); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:2rem; }
.hero-chips{ display:flex; flex-wrap:wrap; gap:.6rem 1.8rem; list-style:none; margin-top:2.2rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.hero-chips li{ font-size:.9rem; color:var(--ink-mute); }
.hero-chips strong{ color:var(--ink); font-family:var(--display); font-weight:800; }
.hero-scroll{ position:absolute; left:50%; bottom:1.4rem; transform:translateX(-50%); z-index:2; width:26px; height:42px; border:2px solid var(--line-2); border-radius:14px; display:grid; justify-items:center; padding-top:7px; }
.hero-scroll span{ width:4px; height:9px; border-radius:2px; background:var(--accent); animation:scrolldot 1.6s var(--ease-soft) infinite; }
@keyframes scrolldot{ 0%{ transform:translateY(0); opacity:1;} 70%{ transform:translateY(12px); opacity:0;} 100%{ opacity:0;} }

/* =============================================================
   8. Marquee
   ============================================================= */
.marquee{ background:var(--accent); color:#1a0f06; overflow:hidden; border-block:1px solid rgba(0,0,0,.15); }
.marquee-track{ display:flex; gap:0; white-space:nowrap; width:max-content; animation:marquee 28s linear infinite; }
.marquee-item{ font-family:var(--display); font-weight:800; text-transform:uppercase; letter-spacing:.04em; font-size:clamp(1rem,1.8vw,1.3rem); padding:.85rem 2rem; display:inline-flex; align-items:center; gap:1.6rem; }
.marquee-item::after{ content:"●"; font-size:.5em; opacity:.5; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.marquee:hover .marquee-track{ animation-play-state:paused; }

/* =============================================================
   9. Nosotros
   ============================================================= */
.nosotros-media{ position:relative; border-radius:var(--radius); overflow:hidden; }
.nosotros-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; filter:contrast(1.02) saturate(1.02); transition:transform .8s var(--ease-out); }
.nosotros-media:hover img{ transform:scale(1.03); }
.nosotros-media::after{ content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg,rgba(12,13,18,.12) 0%,transparent 30%,transparent 60%,rgba(12,13,18,.66) 100%); }
.nosotros-media{ box-shadow:0 24px 60px -28px rgba(0,0,0,.8); }
.nosotros-badge{ position:absolute; left:1.1rem; bottom:1.1rem; z-index:2; background:var(--accent); color:#1a0f06; border-radius:12px; padding:.9rem 1.1rem; display:flex; align-items:center; gap:.7rem; box-shadow:0 12px 30px -12px rgba(0,0,0,.7); }
.nosotros-badge .num{ font-family:var(--display); font-weight:900; font-size:2.4rem; line-height:1; }
.nosotros-badge .lbl{ font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; line-height:1.15; }
.nosotros-text .h2{ margin-bottom:1.2rem; }
.nosotros-text p{ color:var(--ink-2); margin-bottom:1rem; }
.values{ list-style:none; display:grid; gap:.7rem; margin-top:1.8rem; }
.values li{
  display:flex; gap:1rem; align-items:center;
  padding:.95rem 1.1rem; border-radius:12px;
  background:var(--bg-3); border:1px solid var(--line);
  position:relative; overflow:hidden;
  transition:transform .45s var(--ease-out), border-color .4s, background .4s, box-shadow .4s;
}
.values li::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
  transform:scaleY(0); transform-origin:top; transition:transform .45s var(--ease-out);
}
.values li::after{
  content:""; position:absolute; right:-40%; top:-60%; width:60%; height:160%;
  background:radial-gradient(circle,rgba(242,83,14,.18),transparent 70%);
  opacity:0; transition:opacity .45s; pointer-events:none;
}
.values li:hover{
  transform:translateX(7px); border-color:rgba(242,83,14,.45); background:var(--bg-4);
  box-shadow:0 14px 34px -18px rgba(242,83,14,.6);
}
.values li:hover::before{ transform:scaleY(1); }
.values li:hover::after{ opacity:1; }
.v-ico{
  flex:none; width:40px; height:40px; border-radius:11px;
  background:linear-gradient(135deg,var(--accent),var(--accent-deep));
  color:#fff; display:grid; place-items:center; font-weight:900; font-size:1.05rem;
  box-shadow:0 6px 16px -6px rgba(242,83,14,.85);
  transition:transform .5s var(--ease-bounce), box-shadow .4s;
}
.values li:hover .v-ico{ transform:scale(1.12) rotate(-8deg); box-shadow:0 10px 22px -6px rgba(242,83,14,1); }
.values strong{ display:block; font-family:var(--display); font-size:1.04rem; letter-spacing:.01em; transition:color .3s; }
.values li:hover strong{ color:var(--accent-2); }
.values span{ color:var(--ink-mute); font-size:.9rem; transition:color .3s; }
.values li:hover span{ color:var(--ink-2); }
@media (prefers-reduced-motion:reduce){
  .values li:hover{ transform:none; }
  .values li:hover .v-ico{ transform:none; }
}

/* =============================================================
   10. Servicios
   ============================================================= */
.cards-grid{ display:grid; gap:1rem; grid-template-columns:1fr; }
@media (min-width:640px){ .cards-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .cards-grid{ grid-template-columns:repeat(3,1fr); } }
.scard{ position:relative; background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); padding:1.7rem 1.5rem 1.6rem; overflow:hidden; transition:transform .4s var(--ease-out), border-color .4s, background .4s; will-change:transform; }
.scard::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--accent); transition:width .45s var(--ease-out); }
.scard:hover{ transform:translateY(-5px); border-color:var(--line-2); background:var(--bg-4); }
.scard:hover::before{ width:100%; }
.scard-ico{ width:52px; height:52px; border-radius:12px; background:rgba(242,83,14,.12); color:var(--accent); display:grid; place-items:center; margin-bottom:1.1rem; }
.scard-ico svg{ width:28px; height:28px; }
.scard h3{ font-size:1.18rem; margin-bottom:.5rem; }
.scard p{ color:var(--ink-mute); font-size:.94rem; }
.scard-num{ position:absolute; right:1.1rem; top:1rem; font-family:var(--mono); font-size:.72rem; color:var(--ink-mute); letter-spacing:.1em; }

/* =============================================================
   11. Proceso
   ============================================================= */
.steps{ list-style:none; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media (min-width:720px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ .steps{ grid-template-columns:repeat(4,1fr); } }
.step{ background:var(--bg-2); padding:1.6rem 1.4rem 1.8rem; position:relative; transition:background .35s; }
.step:hover{ background:var(--bg-3); }
.step-n{ font-family:var(--display); font-weight:900; font-size:1.5rem; color:var(--accent); display:inline-flex; align-items:baseline; gap:.5rem; margin-bottom:.7rem; }
.step-n::after{ content:""; width:34px; height:2px; background:var(--line-2); display:inline-block; }
.step h3{ font-size:1.05rem; margin-bottom:.4rem; }
.step p{ color:var(--ink-mute); font-size:.9rem; }

/* =============================================================
   12. Estado de reparación
   ============================================================= */
.estado-panel{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,3vw,2.4rem); }
.estado-form{ display:flex; gap:.7rem; flex-wrap:wrap; }
.estado-form input{ flex:1 1 240px; min-width:0; background:var(--bg); border:1px solid var(--line-2); border-radius:999px; padding:.95rem 1.3rem; font-size:1rem; transition:border-color .3s; }
.estado-form input:focus{ outline:none; border-color:var(--accent); }
.estado-hint{ margin-top:.9rem; color:var(--ink-mute); font-size:.85rem; }
.estado-result{ margin-top:2rem; border-top:1px solid var(--line); padding-top:1.6rem; }
.estado-result[hidden]{ display:none; }
.estado-meta{ display:flex; flex-wrap:wrap; gap:1.2rem 2.4rem; margin-bottom:1.8rem; }
.estado-meta .lbl{ display:block; font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-mute); margin-bottom:.25rem; }
.estado-meta strong{ font-family:var(--display); font-size:1.05rem; }
.estado-error{ color:var(--accent-2); font-weight:600; margin-top:1.4rem; }

.tracker{ list-style:none; display:grid; gap:0; }
.tk{ display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:start; padding-bottom:1.3rem; position:relative; }
.tk:last-child{ padding-bottom:0; }
.tk-dot{ width:30px; height:30px; border-radius:50%; border:2px solid var(--line-2); display:grid; place-items:center; background:var(--bg-2); position:relative; z-index:2; color:var(--ink-mute); font-size:.8rem; transition:all .4s var(--ease-out); }
.tk:not(:last-child) .tk-dot::after{ content:""; position:absolute; top:30px; left:50%; transform:translateX(-50%); width:2px; height:calc(100% + 1.3rem - 30px); background:var(--line-2); z-index:-1; }
.tk-body strong{ display:block; font-family:var(--display); font-size:1rem; transition:color .3s; color:var(--ink-mute); }
.tk-body span{ font-size:.82rem; color:var(--ink-mute); }
/* done */
.tk.is-done .tk-dot{ background:var(--accent); border-color:var(--accent); color:#1a0f06; }
.tk.is-done .tk-body strong{ color:var(--ink-2); }
.tk.is-done:not(:last-child) .tk-dot::after{ background:var(--accent); }
/* current */
.tk.is-current .tk-dot{ background:var(--accent); border-color:var(--accent); color:#1a0f06; box-shadow:0 0 0 5px rgba(242,83,14,.2); animation:pulseDot 1.8s var(--ease-soft) infinite; }
.tk.is-current .tk-body strong{ color:var(--accent-2); }
@keyframes pulseDot{ 0%,100%{ box-shadow:0 0 0 5px rgba(242,83,14,.18);} 50%{ box-shadow:0 0 0 9px rgba(242,83,14,.05);} }

/* =============================================================
   12.5 Ingreso de siniestro online (wizard)
   ============================================================= */
.ingreso{ background:var(--bg-2); border-block:1px solid var(--line); }
.ingreso-layout{ display:grid; gap:1.6rem; }
@media (min-width:1024px){ .ingreso-layout{ grid-template-columns:.82fr 1.18fr; gap:2.4rem; align-items:start; } }

.ingreso-aside{ background:linear-gradient(160deg,var(--bg-3),var(--bg-2)); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,3vw,2rem); position:relative; overflow:hidden; }
.ingreso-aside::before{ content:""; position:absolute; right:-30%; top:-30%; width:70%; height:70%; background:radial-gradient(circle,rgba(242,83,14,.18),transparent 70%); pointer-events:none; }
.ingreso-aside h3{ font-family:var(--display); font-size:1.25rem; margin-bottom:1.1rem; }
.ingreso-points{ list-style:none; display:grid; gap:.85rem; }
.ingreso-points li{ display:flex; gap:.7rem; align-items:flex-start; color:var(--ink-2); font-size:.95rem; }
.ingreso-points li span{ color:var(--accent); font-weight:900; font-family:var(--display); }
.ingreso-points strong{ color:var(--ink); }
.ingreso-aside-note{ margin-top:1.6rem; padding-top:1.4rem; border-top:1px solid var(--line); }
.ingreso-aside-note strong{ display:block; font-family:var(--display); color:var(--accent-2); margin-bottom:.4rem; }
.ingreso-aside-note p{ color:var(--ink-mute); font-size:.9rem; }
.ingreso-track-link{ display:inline-block; margin-top:1.4rem; color:var(--accent-2); font-weight:600; font-size:.92rem; }
.ingreso-track-link:hover{ text-decoration:underline; }

.wizard{ background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.3rem,3vw,2.2rem); position:relative; }
.wz-steps{ list-style:none; display:flex; gap:.4rem; margin-bottom:1.8rem; counter-reset:wz; flex-wrap:wrap; }
.wz-step{ display:flex; align-items:center; gap:.5rem; flex:1 1 auto; min-width:0; opacity:.55; transition:opacity .35s; }
.wz-step span{ flex:none; width:30px; height:30px; border-radius:50%; border:2px solid var(--line-2); display:grid; place-items:center; font-family:var(--display); font-weight:800; font-size:.85rem; transition:all .35s var(--ease-out); }
.wz-step em{ font-style:normal; font-size:.82rem; font-weight:600; color:var(--ink-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wz-step.is-active{ opacity:1; } .wz-step.is-active span{ background:var(--accent); border-color:var(--accent); color:#fff; }
.wz-step.is-done{ opacity:1; } .wz-step.is-done span{ background:var(--accent); border-color:var(--accent); color:#fff; }
@media (max-width:639px){ .wz-step em{ display:none; } .wz-step{ flex:0 0 auto; } .wz-steps{ justify-content:flex-start; } }

.wz-panel{ border:0; padding:0; margin:0; display:none; min-inline-size:0; }
.wz-panel.is-active{ display:block; animation:wzIn .4s var(--ease-out); }
@keyframes wzIn{ from{ opacity:0; transform:translateY(10px);} to{ opacity:1; transform:none; } }
.wz-legend{ font-family:var(--display); font-weight:800; font-size:1.1rem; margin-bottom:1.1rem; color:var(--ink); padding:0; }
.wizard .form-row-3{ grid-template-columns:1fr; }
@media (min-width:560px){ .wizard .form-row-3{ grid-template-columns:repeat(3,1fr); } }
.wizard label{ display:block; font-size:.8rem; font-weight:600; color:var(--ink-2); margin-bottom:.9rem; }
.wizard input,.wizard select,.wizard textarea{ width:100%; margin-top:.4rem; background:var(--bg-2); border:1px solid var(--line-2); border-radius:10px; padding:.8rem .9rem; font-size:.95rem; font-weight:400; color:var(--ink); transition:border-color .3s, background .3s; }
.wizard input:focus,.wizard select:focus,.wizard textarea:focus{ outline:none; border-color:var(--accent); background:var(--bg); }
.wizard input.is-invalid,.wizard select.is-invalid,.wizard textarea.is-invalid{ border-color:var(--accent-2); background:rgba(242,83,14,.06); }
.wizard select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--ink-mute) 50%),linear-gradient(135deg,var(--ink-mute) 50%,transparent 50%); background-position:calc(100% - 18px) 1.25rem,calc(100% - 13px) 1.25rem; background-size:5px 5px,5px 5px; background-repeat:no-repeat; }
.wizard textarea{ resize:vertical; }

/* dropzones */
.dz-grid{ display:grid; gap:.9rem; margin:.4rem 0 1.2rem; }
@media (min-width:620px){ .dz-grid{ grid-template-columns:1fr 1fr; } .dropzone-wide{ grid-column:1 / -1; } }
.dropzone{ position:relative; border:1.5px dashed var(--line-2); border-radius:12px; padding:1.1rem; background:var(--bg-2); transition:border-color .3s, background .3s; }
.dropzone.is-drag{ border-color:var(--accent); background:rgba(242,83,14,.06); }
.dropzone input[type=file]{ position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; margin:0; }
.dz-face{ text-align:center; pointer-events:none; }
.dz-ico{ font-size:1.5rem; display:block; margin-bottom:.3rem; }
.dz-face strong{ display:block; font-family:var(--display); font-size:.95rem; }
.dz-face em{ font-style:normal; color:var(--ink-mute); font-size:.78rem; }
.dz-list{ list-style:none; display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.9rem; position:relative; z-index:2; }
.dz-list:empty{ margin-top:0; }
.dz-thumb{ position:relative; width:54px; height:54px; border-radius:8px; overflow:hidden; border:1px solid var(--line-2); }
.dz-thumb img{ width:100%; height:100%; object-fit:cover; }
.dz-file{ display:flex; align-items:center; gap:.4rem; background:var(--bg-4); border:1px solid var(--line-2); border-radius:8px; padding:.35rem .55rem; font-size:.74rem; color:var(--ink-2); max-width:100%; }
.dz-file span{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:120px; }
.dz-rm{ flex:none; width:18px; height:18px; border-radius:50%; background:rgba(0,0,0,.55); color:#fff; display:grid; place-items:center; font-size:.7rem; line-height:1; position:absolute; top:2px; right:2px; z-index:3; }
.dz-file .dz-rm{ position:static; background:transparent; color:var(--accent-2); width:auto; height:auto; }

.wz-check{ display:flex !important; gap:.6rem; align-items:flex-start; font-size:.85rem !important; color:var(--ink-2) !important; }
.wz-check input{ width:auto !important; margin-top:.25rem !important; flex:none; accent-color:var(--accent); }

.wz-nav{ display:flex; align-items:center; gap:.8rem; margin-top:1.6rem; flex-wrap:wrap; }
.wz-progress{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); margin-inline:auto; }
.wz-error{ margin-top:1rem; color:var(--accent-2); font-weight:600; font-size:.88rem; }
.wz-error[hidden]{ display:none; }

.wz-success{ text-align:center; padding:1rem 0 .4rem; animation:wzIn .5s var(--ease-out); }
.wz-success[hidden]{ display:none; }
.wz-success-badge{ color:var(--ok); display:flex; justify-content:center; margin-bottom:.6rem; }
.wz-success h3{ font-family:var(--display); font-size:1.5rem; }
.wz-success p{ color:var(--ink-2); margin-top:.5rem; }
.wz-ticket{ font-family:var(--mono); font-weight:700; font-size:clamp(1.4rem,4vw,2rem); color:var(--accent-2) !important; letter-spacing:.06em; margin:.6rem 0 !important; padding:.6rem 1rem; background:var(--bg-2); border:1px dashed var(--line-2); border-radius:10px; display:inline-block; }
.wz-success-note{ max-width:52ch; margin-inline:auto; font-size:.9rem; color:var(--ink-mute) !important; }
.wz-success-actions{ display:flex; gap:.7rem; justify-content:center; flex-wrap:wrap; margin-top:1.2rem; }
.wz-reset{ margin-top:1.2rem; display:inline-block; }
/* panels hidden by default when wizard finished */
.wizard.is-done .wz-panels,.wizard.is-done .wz-nav,.wizard.is-done .wz-steps,.wizard.is-done .wz-error{ display:none; }

/* =============================================================
   13. Indicadores
   ============================================================= */
.stats{ background:
  linear-gradient(0deg, var(--bg-2), var(--bg-2)) padding-box,
  var(--bg); border-block:1px solid var(--line); }
.stats-grid{ display:grid; gap:1px; grid-template-columns:repeat(2,1fr); background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media (min-width:860px){ .stats-grid{ grid-template-columns:repeat(4,1fr); } }
.stat{ background:var(--bg); padding:clamp(1.6rem,3vw,2.6rem) 1.2rem; text-align:center; }
.stat-val{ font-family:var(--display); font-weight:900; font-size:clamp(2.2rem,5vw,3.4rem); color:var(--ink); line-height:1; }
.stat-val b{ color:var(--accent); font-weight:900; }
.stat-lbl{ margin-top:.6rem; color:var(--ink-mute); font-size:.9rem; }

/* =============================================================
   14. Galería antes/después
   ============================================================= */
.compare{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4; max-width:540px; margin-inline:auto; border:1px solid var(--line); user-select:none; touch-action:pan-y; box-shadow:0 24px 60px -28px rgba(0,0,0,.8); background:var(--bg-2); }
.compare-pane{ position:absolute; inset:0; }
.compare-pane img{ width:100%; height:100%; object-fit:cover; display:block; }
.compare-after img{ filter:saturate(1.04) contrast(1.03); }
.compare-before{ clip-path:inset(0 50% 0 0); will-change:clip-path; }
.compare-before img{ filter:contrast(1.04) saturate(1.02); }
.compare-tag{ position:absolute; top:1rem; font-family:var(--mono); font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:.4rem .7rem; border-radius:6px; }
.tag-before{ left:1rem; background:rgba(11,11,13,.8); color:var(--ink-2); border:1px solid var(--line-2); }
.tag-after{ right:1rem; background:var(--accent); color:#1a0f06; }
.compare-range{ position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; margin:0; }
.compare-handle{ position:absolute; top:0; bottom:0; left:50%; width:3px; background:var(--accent); transform:translateX(-50%); pointer-events:none; z-index:3; }
.compare-handle i{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:42px; height:42px; border-radius:50%; background:var(--accent); color:#1a0f06; display:grid; place-items:center; box-shadow:0 4px 16px rgba(0,0,0,.5); }
.compare-handle i::before{ content:"⇆"; font-size:1.1rem; font-weight:900; }
.compare-caption{ text-align:center; margin-top:1rem; color:var(--ink-mute); font-size:.88rem; font-family:var(--mono); letter-spacing:.04em; }
.compare-caption strong{ color:var(--ink-2); }

.gallery-grid{ display:grid; gap:1rem; grid-template-columns:repeat(2,1fr); margin-top:1.4rem; }
@media (min-width:780px){ .gallery-grid{ grid-template-columns:repeat(4,1fr); } }
.gitem{ position:relative; border-radius:12px; overflow:hidden; aspect-ratio:4/5; border:1px solid var(--line); }
.gitem img{ width:100%; height:100%; object-fit:cover; filter:saturate(.9) brightness(.82); transition:transform .6s var(--ease-out), filter .4s; }
.gitem:hover img{ transform:scale(1.07); filter:saturate(1.05) brightness(.95); }
.gitem-cap{ position:absolute; inset:auto 0 0 0; padding:1rem .9rem .85rem; background:linear-gradient(0deg,rgba(11,11,13,.92),transparent); }
.gitem-cap em{ font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-2); font-style:normal; }
.gitem-cap strong{ display:block; font-family:var(--display); font-size:.95rem; margin-top:.2rem; }

/* =============================================================
   15. Aliados / marcas
   ============================================================= */
.aliados{ background:var(--bg-2); border-block:1px solid var(--line); }
.aliados-inner{ display:grid; gap:2.4rem; }
@media (min-width:960px){ .aliados-inner{ grid-template-columns:1fr 1fr; align-items:center; gap:4rem; } }
.aliados-text p{ color:var(--ink-2); margin-top:1rem; }
.brands-grid{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media (min-width:560px){ .brands-grid{ grid-template-columns:repeat(3,1fr); } }
.brand-cell{ background:var(--bg); min-height:clamp(106px,13vw,130px); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.55rem; transition:background .35s; padding:1.1rem .7rem; }
.brand-cell:hover{ background:var(--bg-3); }
.brand-logo{ height:clamp(31px,4.1vw,41px); width:auto; max-width:82%; object-fit:contain; opacity:.82; transition:opacity .35s var(--ease-out), transform .4s var(--ease-out); }
.brand-cell:hover .brand-logo{ opacity:1; transform:scale(1.06); }
.brand-cap{ font-family:var(--mono); font-size:.79rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); transition:color .3s; }
.brand-cell:hover .brand-cap{ color:var(--accent-2); }
.brand-word{ font-family:var(--display); font-weight:800; font-size:clamp(1.2rem,2.64vw,1.56rem); letter-spacing:.01em; color:var(--ink-2); transition:color .3s; text-align:center; }
.brand-cell:hover .brand-word{ color:var(--ink); }

/* aseguradoras en convenio */
.insurers{ margin-top:clamp(2.4rem,5vw,3.6rem); padding-top:clamp(2rem,4vw,3rem); border-top:1px solid var(--line); }
.insurers-head{ max-width:760px; }
.insurers-title{ font-size:clamp(1.3rem,3vw,1.95rem); margin-top:.5rem; }
.insurers-lead{ color:var(--ink-2); margin-top:.8rem; }
.insurers-grid{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; margin-top:1.8rem; }
@media (min-width:640px){ .insurers-grid{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1100px){ .insurers-grid{ grid-template-columns:repeat(6,1fr); } }
.ins-card{
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:.7rem;
  padding:1.3rem 1rem; border-radius:14px; background:var(--bg-3); border:1px solid var(--line);
  position:relative; overflow:hidden;
  transition:transform .45s var(--ease-out), border-color .4s, background .4s, box-shadow .4s;
}
.ins-card::after{
  content:""; position:absolute; left:0; right:0; top:0; height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease-out);
}
.ins-card:hover{
  transform:translateY(-6px); border-color:rgba(242,83,14,.45); background:var(--bg-4);
  box-shadow:0 16px 38px -20px rgba(242,83,14,.65);
}
.ins-card:hover::after{ transform:scaleX(1); }
.ins-badge{
  width:62px; height:62px; border-radius:14px; display:grid; place-items:center;
  background:#fff; box-shadow:0 6px 18px -8px rgba(0,0,0,.7);
  transition:transform .5s var(--ease-bounce); overflow:hidden;
}
.ins-card:hover .ins-badge{ transform:scale(1.08) rotate(-4deg); }
.ins-badge img{ width:100%; height:100%; object-fit:contain; padding:.4rem; }
.ins-mono{
  font-family:var(--display); font-weight:900; font-size:1.05rem; letter-spacing:-.01em;
  background:linear-gradient(135deg,var(--accent-deep),var(--accent)); -webkit-background-clip:text;
  background-clip:text; color:transparent;
}
.ins-name{ font-family:var(--display); font-weight:700; font-size:.9rem; color:var(--ink-2); transition:color .3s; }
.ins-card:hover .ins-name{ color:var(--ink); }
@media (prefers-reduced-motion:reduce){
  .ins-card:hover{ transform:none; }
  .ins-card:hover .ins-badge{ transform:none; }
}

/* =============================================================
   16. Forms
   ============================================================= */
.form label{ display:block; font-size:.82rem; font-weight:600; color:var(--ink-2); margin-bottom:.9rem; }
.form input,.form textarea{ width:100%; margin-top:.4rem; background:var(--bg-2); border:1px solid var(--line-2); border-radius:10px; padding:.85rem .95rem; font-size:.95rem; font-weight:400; color:var(--ink); transition:border-color .3s, background .3s; }
.repuestos .form input,.repuestos .form textarea{ background:var(--bg-3); }
.form input::placeholder,.form textarea::placeholder{ color:var(--ink-mute); }
.form input:focus,.form textarea:focus{ outline:none; border-color:var(--accent); background:var(--bg); }
.form textarea{ resize:vertical; }
.form-row{ display:grid; gap:0 1rem; }
@media (min-width:560px){ .form-row{ grid-template-columns:1fr 1fr; } }
.form-actions{ display:grid; gap:.7rem; margin-top:.4rem; }
@media (min-width:560px){ .form-actions{ grid-template-columns:1fr 1fr; } }
.form-note{ margin-top:.9rem; font-size:.86rem; color:var(--ok); min-height:1.2em; font-weight:600; }
.form-note.is-err{ color:var(--accent-2); }
.repuestos-aside .h2{ margin-bottom:1rem; }
.repuestos-aside p{ color:var(--ink-2); }
.mini-list{ list-style:none; margin-top:1.4rem; display:grid; gap:.6rem; }
.mini-list li{ padding-left:1.5rem; position:relative; color:var(--ink-2); font-size:.95rem; }
.mini-list li::before{ content:"›"; position:absolute; left:0; color:var(--accent); font-weight:900; }
.repuestos-form{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.3rem,3vw,2rem); }

/* =============================================================
   17. Testimonios
   ============================================================= */
.testi{ position:relative; min-height:220px; }
.tq{ position:absolute; inset:0; opacity:0; transform:translateY(14px); transition:opacity .6s var(--ease-out), transform .6s var(--ease-out); pointer-events:none; }
.tq.is-active{ opacity:1; transform:none; pointer-events:auto; position:relative; }
.tq blockquote{ font-family:var(--display); font-weight:600; font-size:clamp(1.2rem,2.6vw,1.8rem); line-height:1.35; max-width:60ch; }
.tq blockquote::before{ content:"“"; color:var(--accent); font-size:2.4em; line-height:0; vertical-align:-.4em; margin-right:.1em; }
.tq-author{ margin-top:1.6rem; display:flex; align-items:center; gap:.8rem; }
.tq-author .av{ width:44px; height:44px; border-radius:50%; background:var(--accent); color:#1a0f06; display:grid; place-items:center; font-family:var(--display); font-weight:900; }
.tq-author strong{ display:block; font-family:var(--display); }
.tq-author span{ color:var(--ink-mute); font-size:.85rem; }
.testi-dots{ display:flex; gap:.5rem; margin-top:1.8rem; }
.testi-dots button{ width:30px; height:4px; border-radius:2px; background:var(--line-2); transition:background .3s; }
.testi-dots button.is-active{ background:var(--accent); }

/* =============================================================
   18. Contacto
   ============================================================= */
.contacto-grid{ display:grid; gap:2rem; }
@media (min-width:960px){ .contacto-grid{ grid-template-columns:1fr 1.1fr; gap:3rem; } }
.contacto-info{ display:grid; gap:.7rem; align-content:start; }
.info-item{ display:flex; gap:.9rem; align-items:flex-start; padding:1rem 1.1rem; background:var(--bg-2); border:1px solid var(--line); border-radius:12px; transition:border-color .3s, transform .3s; }
.info-item:hover{ border-color:var(--line-2); transform:translateX(3px); }
.info-ico{ font-size:1.1rem; flex:none; }
.info-item strong{ display:block; font-family:var(--display); font-size:.95rem; margin-bottom:.15rem; }
.info-item em{ font-style:normal; color:var(--ink-mute); font-size:.9rem; line-height:1.4; }
.info-hours{ color:var(--ink-mute); font-size:.85rem; padding:.2rem .4rem; }

/* canales separados: taller / repuestos */
.info-channel{ background:var(--bg-2); border:1px solid var(--line); border-radius:12px; padding:1rem 1.1rem; position:relative; overflow:hidden; transition:border-color .3s, transform .3s; }
.info-channel::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent); }
.info-channel.ch-repuestos::before{ background:var(--accent-2); }
.info-channel:hover{ border-color:rgba(242,83,14,.4); transform:translateX(3px); }
.ch-label{ display:flex; align-items:center; gap:.5rem; font-family:var(--display); font-weight:800; font-size:1rem; }
.ch-tag{ font-size:1.05rem; }
.ch-sub{ display:block; color:var(--ink-mute); font-size:.8rem; margin:.2rem 0 .8rem; }
.ch-actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.ch-btn{ display:inline-flex; align-items:center; gap:.45rem; padding:.55rem .9rem; border-radius:999px; font-size:.88rem; font-weight:600; transition:transform .3s var(--ease-out), background .3s, border-color .3s; }
.ch-btn:hover{ transform:translateY(-2px); }
.ch-call{ background:transparent; border:1px solid var(--line-2); color:var(--ink); font-family:var(--mono); letter-spacing:.02em; }
.ch-call:hover{ border-color:var(--accent); color:var(--accent-2); }
.ch-wa{ background:#1faf54; color:#fff; }
.ch-wa:hover{ background:#23c25e; }
.map{ margin-top:.4rem; border-radius:12px; overflow:hidden; border:1px solid var(--line); aspect-ratio:16/11; background:var(--bg-3); }
.map iframe{ width:100%; height:100%; border:0; filter:grayscale(.3) invert(.92) hue-rotate(170deg) contrast(.9); }
.contacto-form{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.3rem,3vw,2rem); }

/* =============================================================
   19. Footer + FAB
   ============================================================= */
.footer{ background:var(--bg-2); border-top:1px solid var(--line); padding-top:clamp(2.6rem,5vw,4rem); }
.footer-grid{ display:grid; gap:2rem; padding-bottom:2.4rem; }
@media (min-width:780px){ .footer-grid{ grid-template-columns:2fr 1fr 1.4fr; } }
.footer-logo{ height:84px; width:auto; margin-bottom:1rem; }
.footer-brand .brand-name{ font-size:1.2rem; display:block; }
.footer-brand p{ color:var(--ink-mute); margin-top:.9rem; font-size:.92rem; }
.footer-links{ display:flex; flex-direction:column; gap:.7rem; }
.footer-links a{ color:var(--ink-2); font-size:.93rem; } .footer-links a:hover{ color:var(--accent-2); }
.footer-contact{ display:grid; gap:.5rem; color:var(--ink-2); font-size:.92rem; }
.footer-contact a:hover{ color:var(--accent-2); }
.footer-bottom{ border-top:1px solid var(--line); padding-block:1.4rem; display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between; }
.footer-bottom p{ color:var(--ink-mute); font-size:.8rem; }
.footer-credits a{ color:var(--ink-2); } .footer-credits a:hover{ color:var(--accent-2); }

.fab{ position:fixed; right:1rem; bottom:1rem; z-index:900; display:flex; flex-direction:column; gap:.6rem; }
.fab-btn{ width:54px; height:54px; border-radius:50%; display:grid; place-items:center; color:#fff; box-shadow:0 10px 26px -8px rgba(0,0,0,.6); transition:transform .3s var(--ease-bounce); }
.fab-btn:hover{ transform:scale(1.08); }
.fab-wa{ background:#1faf54; }
.fab-call{ background:var(--accent); }
.fab-call{ display:grid; }
@media (min-width:1080px){ .fab-call{ display:none; } }

/* =============================================================
   20. Reveal animations (functional — not gated by reduced-motion)
   ============================================================= */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
[data-reveal].is-in{ opacity:1; transform:none; }
.reveal-stagger > *{ opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease-out), transform .6s var(--ease-out); }
.reveal-stagger.is-in > *{ opacity:1; transform:none; }
.reveal-stagger.is-in > *:nth-child(2){ transition-delay:.06s; }
.reveal-stagger.is-in > *:nth-child(3){ transition-delay:.12s; }
.reveal-stagger.is-in > *:nth-child(4){ transition-delay:.18s; }
.reveal-stagger.is-in > *:nth-child(5){ transition-delay:.24s; }
.reveal-stagger.is-in > *:nth-child(6){ transition-delay:.3s; }

/* =============================================================
   21. Reduced motion — only intrusive effects
   ============================================================= */
@media (prefers-reduced-motion:reduce){
  .marquee-track{ animation:none; }
  .hero-scroll span{ animation:none; }
  .splash-bar i{ animation-duration:2s; }
  .tk.is-current .tk-dot{ animation:none; }
}
