/* ═══════════════════════════════════════
   MunPOS v6 — Production CSS
   Premium warm-tech design
   ═══════════════════════════════════════ */
:root{
  --ink:#0f1729;--ink2:#1b2540;--txt:#404a60;--muted:#717d96;--faint:#a8b2c6;--border:#e4e7ed;
  --bg:#ffffff;--bg2:#f6f5f2;--bg3:#efeee9;
  --teal:#0c6b62;--teal-h:#0a5c54;--teal-10:rgba(12,107,98,.08);--teal-20:rgba(12,107,98,.15);
  --coral:#c9512a;--coral-h:#b5461f;--coral-10:rgba(201,81,42,.07);--coral-20:rgba(201,81,42,.14);
  --green:#168240;--amber:#a8520c;--rose:#b01838;--sky:#0862a0;
  --font:'Sora',system-ui,-apple-system,sans-serif;
  --body:'DM Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --r:10px;--r-lg:14px;--r-xl:20px;--r-pill:999px;
  --s1:0 1px 2px rgba(0,0,0,.04);
  --s2:0 2px 6px rgba(0,0,0,.03),0 6px 20px rgba(0,0,0,.05);
  --s3:0 4px 12px rgba(0,0,0,.04),0 16px 48px rgba(0,0,0,.07);
  --ease:cubic-bezier(.4,0,.2,1);
  --mw:1140px;--gx:clamp(1.25rem,4vw,2.5rem)
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--body);font-size:1rem;line-height:1.72;color:var(--txt);background:var(--bg)}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block;height:auto}
button{cursor:pointer;border:none;background:none;font-family:inherit}ul{list-style:none}
.container{max-width:var(--mw);margin:0 auto;padding:0 var(--gx)}
.c{max-width:var(--mw);margin:0 auto;padding:0 var(--gx)}

h1,h2,h3,h4{font-family:var(--font);color:var(--ink);line-height:1.15;font-weight:700;letter-spacing:-.025em}
h1{font-size:clamp(2.3rem,5.2vw,3.6rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(1.65rem,3.2vw,2.35rem)}
h3{font-size:1.08rem;letter-spacing:-.01em}

/* ── Labels / Tags ── */
.tag,.label{font-family:var(--mono);font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:8px;margin-bottom:14px}
.tag::before,.label::before{content:'';width:18px;height:1.5px;background:var(--teal);border-radius:1px;opacity:.5}

/* ── Section header ── */
.hd,.section-header{text-align:center;max-width:600px;margin:0 auto 3.5rem}
.hd p,.section-header p{color:var(--muted);font-size:1rem;margin-top:.5rem;line-height:1.8}

/* ── Page header (interior pages) ── */
.ph,.page-header{padding:8rem 0 3.5rem;background:var(--bg2);border-bottom:1px solid var(--border);text-align:center}
.ph h1,.page-header h1{margin-bottom:.5rem}
.ph p,.page-header p{color:var(--muted);font-size:1rem;max-width:560px;margin:0 auto}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:.88rem 2.1rem;border-radius:var(--r-pill);font-family:var(--body);font-weight:600;font-size:.88rem;letter-spacing:-.005em;transition:all .25s var(--ease);border:1.5px solid transparent;min-height:50px;white-space:nowrap}
.btn svg{width:15px;height:15px;flex-shrink:0;transition:transform .2s}
.btn:hover svg{transform:translateX(2px)}

.btn-primary,.btn-c{background:var(--coral);color:#fff;box-shadow:0 1px 3px var(--coral-20),inset 0 1px 0 rgba(255,255,255,.12)}
.btn-primary:hover,.btn-c:hover{background:var(--coral-h);transform:translateY(-2px);box-shadow:0 4px 12px var(--coral-20),0 12px 36px rgba(201,81,42,.1);color:#fff}
.btn-primary:active,.btn-c:active{transform:translateY(0)}

.btn-outline,.btn-o{border-color:var(--border);color:var(--ink);background:var(--bg);box-shadow:var(--s1)}
.btn-outline:hover,.btn-o:hover{border-color:var(--teal);color:var(--teal);box-shadow:var(--s2);transform:translateY(-1px)}

.btn-teal,.btn-t{background:var(--teal);color:#fff;box-shadow:0 1px 3px var(--teal-20)}
.btn-teal:hover,.btn-t:hover{background:var(--teal-h);transform:translateY(-1px);color:#fff}

.btn-lg{padding:1rem 2.6rem;font-size:.92rem;min-height:54px}
.btn-sm{padding:.5rem 1.2rem;font-size:.78rem;min-height:38px}

/* ═══ SECTIONS ═══ */
.section,.sec{padding:clamp(4.5rem,7vw,7rem) 0}
.section-warm,.sec-w{background:var(--bg2)}

/* ═══ SITE HEADER ═══ */
.site-header,.hdr{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:.3s var(--ease)}
.site-header.scrolled,.hdr.sc{background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.6rem 0;box-shadow:var(--s1);border-bottom:1px solid rgba(0,0,0,.04)}
.site-header:not(.scrolled) .logo-name,.hdr:not(.sc) .ln{color:#fff}
.site-header:not(.scrolled) .main-nav a,.hdr:not(.sc) .nv a{color:rgba(255,255,255,.55)}
.site-header:not(.scrolled) .main-nav a:hover,.hdr:not(.sc) .nv a:hover{color:#fff}
.site-header:not(.scrolled) .header-phone,.hdr:not(.sc) .hp{color:rgba(255,255,255,.35)}
.site-header:not(.scrolled) .header-divider,.hdr:not(.sc) .dv{background:rgba(255,255,255,.08)}

.header-inner,.hi{display:flex;align-items:center;justify-content:space-between;max-width:var(--mw);margin:0 auto;padding:0 var(--gx)}
.logo{display:flex;align-items:center;gap:9px}
.logo-mark,.lm{width:32px;height:32px;border-radius:8px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;font-family:var(--font);position:relative;overflow:hidden}
.logo-mark::after,.lm::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent)}
.logo-name,.ln{font-family:var(--font);font-size:1.1rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.logo-name b,.ln b{color:var(--teal)}
.logo-sub{font-family:var(--mono);font-size:.55rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;display:block}

.main-nav,.nv{display:flex;gap:1.6rem}
.main-nav a,.main-nav ul,.main-nav li{list-style:none}
.main-nav ul{display:flex;gap:1.6rem;padding:0;margin:0}
.main-nav a,.nv a{font-size:.84rem;font-weight:500;color:var(--muted);transition:.15s}
.main-nav a:hover,.nv a:hover{color:var(--teal)}

.header-right,.hr{display:flex;align-items:center;gap:12px}
.header-phone,.hp{display:flex;align-items:center;gap:5px;font-size:.82rem;font-weight:500;color:var(--muted)}
.header-phone svg,.hp svg{width:14px;height:14px}
.header-divider,.dv{width:1px;height:18px;background:var(--border)}

.menu-toggle,.mt{display:none;flex-direction:column;gap:4px;padding:6px}
.menu-toggle span,.mt span{width:20px;height:2px;background:currentColor;border-radius:2px}

/* Mobile nav */
.mobile-overlay{display:none;position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.98);backdrop-filter:blur(14px);flex-direction:column;align-items:center;justify-content:center;gap:.25rem;opacity:0;pointer-events:none;transition:.3s}
.mobile-overlay.open{display:flex;opacity:1;pointer-events:auto}
.mobile-overlay a{display:block;font-family:var(--font);font-size:1.3rem;font-weight:700;color:var(--ink);padding:8px 0}

/* ═══ HERO ═══ */
.hero{min-height:100vh;display:flex;align-items:center;background:var(--ink);position:relative;overflow:hidden;padding:7rem 0 5rem;color:#fff}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:32px 32px;mask-image:radial-gradient(ellipse 50% 45% at 40% 40%,black,transparent);-webkit-mask-image:radial-gradient(ellipse 50% 45% at 40% 40%,black,transparent)}
.hero::after{content:'';position:absolute;bottom:-30%;right:-5%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(12,107,98,.1),transparent 60%)}
.hero-container{position:relative;z-index:1;max-width:var(--mw);margin:0 auto;padding:0 var(--gx);display:grid;grid-template-columns:1fr 1.05fr;gap:4rem;align-items:center}
.hero-text{animation:fu .8s ease both}
@keyframes fu{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 13px 4px 7px;border-radius:var(--r-pill);background:rgba(12,107,98,.1);border:1px solid rgba(12,107,98,.15);font-family:var(--mono);font-size:.65rem;font-weight:500;color:rgba(255,255,255,.6);margin-bottom:1.5rem}
.hero-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(22,130,64,.5)}
.hero h1{color:#fff;margin-bottom:1.25rem}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--coral),#e8734a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.55);line-height:1.85;margin-bottom:2rem;max-width:460px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:2rem}
.hero-trust{display:flex;align-items:center;gap:8px;font-size:.78rem;color:rgba(255,255,255,.4)}
.hero-trust svg{width:14px;height:14px;color:var(--green);flex-shrink:0}
.hero-visual{animation:fu .8s ease .2s both;position:relative}

/* ═══ APP MOCKUP ═══ */
.app{background:#141d2f;border:1px solid rgba(255,255,255,.05);border-radius:var(--r-xl);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.4)}
.app-top{display:flex;align-items:center;gap:6px;padding:10px 14px;background:rgba(0,0,0,.25);border-bottom:1px solid rgba(255,255,255,.04)}
.app-dot{width:7px;height:7px;border-radius:50%}
.app-dot:nth-child(1){background:#ff5f57}.app-dot:nth-child(2){background:#ffbd2e}.app-dot:nth-child(3){background:#28ca41}
.app-url{flex:1;text-align:center;font-family:var(--mono);font-size:.58rem;color:rgba(255,255,255,.15)}
.app-body{display:grid;grid-template-columns:48px 1fr;min-height:320px}
.app-rail{background:rgba(0,0,0,.15);padding:12px 0;display:flex;flex-direction:column;align-items:center;gap:2px;border-right:1px solid rgba(255,255,255,.03)}
.app-rail-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:rgba(255,255,255,.15)}
.app-rail-icon.active{background:var(--teal);color:#fff}
.app-main{padding:14px;display:flex;flex-direction:column;gap:10px}
.app-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.app-stat{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:12px 10px}
.app-stat-value{font-family:var(--font);font-size:1.2rem;font-weight:800;letter-spacing:-.02em}
.app-stat-label{font-size:.52rem;color:rgba(255,255,255,.2);margin-top:2px;text-transform:uppercase;letter-spacing:.06em}
.app-chart{flex:1;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:10px 8px 6px;display:flex;flex-direction:column}
.app-chart-title{font-size:.55rem;color:rgba(255,255,255,.15);margin-bottom:6px;font-weight:600}
.app-bars{flex:1;display:flex;align-items:flex-end;gap:3px}
.app-bar{flex:1;border-radius:3px 3px 0 0;min-height:4px;background:rgba(94,234,212,.3)}
.app-bar.hi{background:#5eead4}

/* Floating cards */
.float{position:absolute;background:rgba(20,29,47,.9);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);padding:10px 14px;box-shadow:0 8px 28px rgba(0,0,0,.3);animation:flt 5s ease-in-out infinite}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float-1{top:6%;right:-5%;z-index:2}
.float-2{bottom:10%;left:-3%;animation-delay:-2s;z-index:2}
.float-row{display:flex;align-items:center;gap:10px}
.float-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.78rem}
.float-label{font-size:.55rem;color:rgba(255,255,255,.25)}
.float-value{font-size:.8rem;font-weight:700;color:#fff}

/* ═══ BRAND STRIP / TICKER ═══ */
.brand-strip,.ticker{padding:15px 0;border-bottom:1px solid var(--border);overflow:hidden;background:var(--bg)}
.brand-strip-inner,.ticker-track{display:flex;gap:2.5rem;animation:slide 45s linear infinite;width:max-content}
@keyframes slide{to{transform:translateX(-50%)}}
.brand-strip-item,.ticker-item{font-size:.72rem;font-weight:600;color:var(--faint);white-space:nowrap;display:flex;align-items:center;gap:8px;letter-spacing:.03em}
.brand-strip-item::before,.ticker-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--teal);opacity:.4}

/* ═══ TRUST NUMBERS ═══ */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;padding:3rem 0;border-bottom:1px solid var(--border)}
.trust-item{text-align:center;padding:1.25rem .75rem}
.trust-num{font-family:var(--font);font-size:2rem;font-weight:800;color:var(--teal);letter-spacing:-.03em}
.trust-label{font-size:.78rem;color:var(--muted);margin-top:4px;line-height:1.5}

/* ═══ SPLIT LAYOUT ═══ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split-visual{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);min-height:360px;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}
.checks{display:flex;flex-direction:column;gap:9px;margin-top:1.25rem}
.checks li{display:flex;align-items:flex-start;gap:9px;font-size:.88rem;color:var(--txt)}
.checks li svg{width:17px;height:17px;color:var(--teal);flex-shrink:0;margin-top:3px}

/* ═══ PRODUCT SCREEN FRAME ═══ */
.screen{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--s2);width:100%;transition:all .3s}
.screen:hover{box-shadow:var(--s3);transform:translateY(-2px)}
.screen-bar{display:flex;align-items:center;gap:5px;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border);font-family:var(--mono);font-size:.55rem;color:var(--faint)}
.screen-bar::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green)}
.screen-bar span{margin-left:auto}
.screen-body{padding:12px}

/* Comanda UI */
.ui-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ui-mesa{font-family:var(--font);font-size:.82rem;font-weight:700;color:var(--ink)}
.ui-status{font-family:var(--mono);font-size:.5rem;padding:3px 8px;border-radius:var(--r-pill);background:var(--teal-10);color:var(--teal);font-weight:600}
.ui-cats{display:flex;gap:3px;margin-bottom:8px;flex-wrap:wrap}
.ui-cat{font-size:.55rem;font-weight:600;padding:3px 8px;border-radius:var(--r-pill);background:var(--bg2);color:var(--muted);border:1px solid var(--border)}
.ui-cat.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.ui-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg2);border-radius:5px;font-size:.68rem;margin-bottom:3px}
.ui-item-name{font-weight:500;color:var(--ink);flex:1}
.ui-dest{font-size:.45rem;padding:2px 6px;border-radius:var(--r-pill);font-weight:700;text-transform:uppercase;margin:0 6px;letter-spacing:.04em}
.ui-dest.cocina{background:rgba(176,24,56,.06);color:var(--rose)}
.ui-dest.barra{background:rgba(168,82,12,.06);color:var(--amber)}
.ui-price{font-family:var(--mono);font-weight:600;color:var(--ink);font-size:.62rem}
.ui-total{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid var(--border);margin-top:4px}
.ui-total-val{font-family:var(--font);font-size:1rem;font-weight:800;color:var(--ink)}
.ui-send{width:100%;padding:8px;background:var(--teal);color:#fff;border-radius:6px;font-size:.7rem;font-weight:600;margin-top:6px;text-align:center}

/* KDS */
.kds{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;width:100%}
.kt{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px;border-top:3px solid}
.kt:nth-child(1){border-top-color:var(--rose)}
.kt:nth-child(2){border-top-color:var(--amber)}
.kt:nth-child(3){border-top-color:var(--green)}
.kh{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.km{font-family:var(--mono);font-size:.6rem;font-weight:600;color:var(--ink)}
.ktm{font-family:var(--mono);font-size:.55rem;font-weight:600}
.ki{font-size:.62rem;color:var(--muted);padding:3px 0;border-bottom:1px dashed rgba(0,0,0,.04);display:flex;justify-content:space-between;align-items:center}
.ki:last-child{border:none}
.ki-badge{font-size:.42rem;padding:1px 5px;border-radius:3px;font-weight:700;text-transform:uppercase}
.ki-ready{background:rgba(22,130,64,.08);color:var(--green)}
.ki-prep{background:rgba(168,82,12,.08);color:var(--amber)}

/* Caja */
.cx-ln{display:flex;justify-content:space-between;padding:3px 0;font-size:.65rem;color:var(--txt)}
.cx-sep{border-top:1px dashed var(--border);margin:5px 0}
.cx-tot{display:flex;justify-content:space-between;padding:7px 0;font-size:.85rem;font-weight:800;color:var(--ink);border-top:2px solid var(--ink);margin-top:4px}
.cx-act{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-top:7px}
.cx-btn{padding:7px;border-radius:5px;font-size:.6rem;font-weight:600;text-align:center;border:1px solid var(--border);color:var(--ink);font-family:var(--body)}
.cx-btn.primary{background:var(--teal);color:#fff;border-color:var(--teal)}
.cx-vf{text-align:center;margin-top:6px;font-family:var(--mono);font-size:.5rem;color:var(--teal);font-weight:600;letter-spacing:.08em}

/* Dashboard */
.ds-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:5px;margin-bottom:7px}
.ds-s{background:var(--bg2);border-radius:6px;padding:8px}
.ds-sv{font-family:var(--font);font-size:.9rem;font-weight:800;color:var(--ink)}
.ds-sl{font-size:.45rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:1px}
.ds-sc{font-size:.45rem;font-weight:600;margin-top:1px}
.ds-sc.up{color:var(--green)}
.ds-sc.dn{color:var(--rose)}
.ds-bars{display:flex;align-items:flex-end;gap:2px;height:55px;background:var(--bg2);border-radius:5px;padding:6px 5px 3px}
.ds-bar{flex:1;border-radius:2px 2px 0 0;background:var(--teal);opacity:.5}

/* Floor map */
.floor{width:100%;max-width:320px}
.floor-zone{font-family:var(--mono);font-size:.5rem;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;padding-left:3px}
.mesas{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;width:100%}
.mesa{aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font);font-size:.7rem;font-weight:700;border:2px solid;transition:.15s}
.mesa.ok{border-color:var(--green);background:rgba(22,130,64,.03);color:var(--green)}
.mesa.bu{border-color:var(--rose);background:rgba(176,24,56,.02);color:var(--rose)}
.mesa.rs{border-color:var(--amber);background:rgba(168,82,12,.03);color:var(--amber)}
.mesa span{font-size:.42rem;font-weight:500;opacity:.55;margin-top:1px}
.floor-legend{display:flex;gap:12px;margin-top:10px;justify-content:center}
.floor-legend-item{display:flex;align-items:center;gap:4px;font-size:.5rem;color:var(--muted);font-weight:500}
.floor-legend-dot{width:8px;height:8px;border-radius:3px}

/* ═══ FLOW PIPELINE ═══ */
.flow{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.flow-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem .5rem}
.flow-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:.5rem;border:2px solid var(--border);background:var(--bg);box-shadow:var(--s1);transition:.2s}
.flow-step:hover .flow-icon{border-color:var(--teal);background:var(--teal-10);box-shadow:var(--s2)}
.flow-step h4{font-size:.75rem;margin-bottom:2px}
.flow-step p{font-size:.58rem;color:var(--muted);max-width:90px;line-height:1.35}
.flow-arrow{font-size:1rem;color:var(--faint);padding:0 .15rem;margin-top:-.6rem}

/* ═══ FEATURES GRID ═══ */
.features-grid,.fg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem}
.feature-card,.fc{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem 1.5rem;transition:.25s var(--ease)}
.feature-card:hover,.fc:hover{border-color:var(--teal-20);box-shadow:var(--s2);transform:translateY(-3px)}
.feature-icon,.fic{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.15rem;font-size:1.1rem;background:var(--teal-10);color:var(--teal)}
.feature-card h3,.fc h3{margin-bottom:6px}
.feature-card p,.fc p{font-size:.84rem;color:var(--muted);line-height:1.6}
.feature-tag,.ftg{display:inline-block;margin-top:12px;padding:2px 9px;border-radius:var(--r-pill);font-family:var(--mono);font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--teal-10);color:var(--teal)}

/* ═══ WHY CARDS ═══ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem}
.why-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:.25s var(--ease)}
.why-card:hover{box-shadow:var(--s2);transform:translateY(-3px);border-color:var(--teal-20)}
.why-icon{font-size:1.5rem;margin-bottom:.75rem}
.why-card h3{margin-bottom:6px;font-size:1rem}
.why-card p{font-size:.82rem;color:var(--muted);line-height:1.6}

/* ═══ SCENARIOS ═══ */
.scenarios-grid,.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem}
.scenario,.sc{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:.25s var(--ease)}
.scenario:hover,.sc:hover{box-shadow:var(--s2);transform:translateY(-3px)}
.scenario-tag,.stg{font-family:var(--mono);font-size:.58rem;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;display:block}
.scenario h3,.sc h3{font-size:1rem;margin-bottom:8px;line-height:1.35}
.scenario p,.sc p{font-size:.82rem;color:var(--muted);line-height:1.6}

/* ═══ COMPLIANCE ═══ */
.compliance-grid,.ccg{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.compliance,.cc{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.25rem;position:relative;overflow:hidden}
.compliance::before,.cc::before{content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;filter:blur(50px);pointer-events:none}
.compliance.verifactu::before,.cc.ccT::before{background:rgba(12,107,98,.05)}
.compliance.ticketbai::before,.cc.ccV::before{background:rgba(8,98,160,.05)}
.compliance-badge,.ccb{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-pill);font-family:var(--mono);font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.15rem}
.compliance.verifactu .compliance-badge,.cc.ccT .ccb{background:var(--teal-10);color:var(--teal);border:1px solid var(--teal-20)}
.compliance.ticketbai .compliance-badge,.cc.ccV .ccb{background:rgba(8,98,160,.05);color:var(--sky);border:1px solid rgba(8,98,160,.15)}
.compliance h3,.cc h3{font-size:1.15rem;margin-bottom:.6rem}
.compliance p,.cc p{font-size:.85rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.compliance-list,.ccl{list-style:none;padding:0;margin:0}
.compliance-list li,.ccl li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--txt);padding:4px 0}
.compliance-list li svg,.ccl li svg{width:15px;height:15px;flex-shrink:0}
.cc.ccT .ccl li svg,.compliance.verifactu .compliance-list li svg{color:var(--teal)}
.cc.ccV .ccl li svg,.compliance.ticketbai .compliance-list li svg{color:var(--sky)}

/* ═══ IMPLANTACIÓN TIMELINE ═══ */
.impl-timeline{display:grid;gap:0;max-width:640px;margin:0 auto}
.impl-step{display:grid;grid-template-columns:48px 1fr;gap:1rem;padding:1.25rem 0;position:relative}
.impl-step:not(:last-child)::after{content:'';position:absolute;left:23px;top:60px;bottom:0;width:2px;background:var(--border)}
.impl-num{width:48px;height:48px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font);font-weight:800;font-size:1rem;position:relative;z-index:1;box-shadow:0 2px 8px var(--teal-20)}
.impl-step h4{font-size:.95rem;margin-bottom:4px}
.impl-step p{font-size:.84rem;color:var(--muted);line-height:1.65}

/* ═══ FAQ ═══ */
.faq-list,.fql{max-width:700px;margin:0 auto}
.faq,.fq{border-bottom:1px solid var(--border)}
.faq-question,.fqq{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 0;cursor:pointer;font-weight:600;color:var(--ink);font-size:.9rem;font-family:var(--font)}
.faq-question svg,.fqq svg{width:17px;height:17px;color:var(--faint);transition:.25s;flex-shrink:0}
.faq.open .faq-question svg,.fq.open .fqq svg{transform:rotate(180deg);color:var(--teal)}
.faq-answer,.fqa{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq.open .faq-answer,.fq.open .fqa{max-height:400px}
.faq-answer-inner,.fqai{padding:0 0 1.15rem;font-size:.86rem;color:var(--muted);line-height:1.75}

/* ═══ CTA DARK ═══ */
.cta-dark,.ctd{background:var(--ink);padding:clamp(4rem,8vw,7rem) 0;position:relative;overflow:hidden;color:#fff;text-align:center}
.cta-dark::before,.ctd::before{content:'';position:absolute;top:-40%;right:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(12,107,98,.08),transparent 55%)}
.cta-dark .container,.ctd .c,.cta-dark-inner{position:relative;z-index:1}
.cta-dark h2,.ctd h2{color:#fff;margin-bottom:.6rem}
.cta-dark p,.ctd p{color:rgba(255,255,255,.5);font-size:1rem;max-width:460px;margin:0 auto 2rem;line-height:1.8}
.cta-actions,.ctb{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ═══ FORMS ═══ */
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:.78rem;font-weight:600;color:var(--ink2);margin-bottom:6px}
.form-control{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--r);font-size:.9rem;font-family:var(--body);transition:.2s}
.form-control:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-20)}
textarea.form-control{resize:vertical;min-height:100px}
select.form-control{appearance:auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

.alert{padding:1rem 1.25rem;border-radius:var(--r);margin-bottom:1.5rem;font-size:.88rem;font-weight:500}
.alert-success{background:rgba(22,130,64,.06);border:1px solid rgba(22,130,64,.15);color:var(--green)}
.alert-error{background:rgba(176,24,56,.05);border:1px solid rgba(176,24,56,.15);color:var(--rose)}

/* ═══ FOOTER ═══ */
.site-footer,.ft{background:var(--ink);color:rgba(255,255,255,.4);padding:3.5rem 0 1.75rem}
.footer-grid,.ftg{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem;max-width:var(--mw);margin-left:auto;margin-right:auto;padding:0 var(--gx)}
.footer-brand,.ftb{font-family:var(--font);font-size:1.05rem;font-weight:800;color:#fff;margin-bottom:.6rem}
.footer-desc,.ftd{font-size:.82rem;line-height:1.7;max-width:260px}
.footer-col h4,.ftc h4{font-family:var(--font);font-weight:600;font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:.85rem}
.footer-col a,.ftc a{display:block;font-size:.8rem;padding:2px 0;transition:.15s;color:rgba(255,255,255,.45)}
.footer-col a:hover,.ftc a:hover{color:var(--coral)}
.footer-bottom,.fbt{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.06);font-size:.72rem;max-width:var(--mw);margin:0 auto;padding-left:var(--gx);padding-right:var(--gx)}
.footer-legal,.flg{display:flex;gap:1.15rem}
.footer-legal a:hover,.flg a:hover{color:rgba(255,255,255,.7)}

/* ═══ WHATSAPP FLOAT ═══ */
.whatsapp-float,.wa{position:fixed;bottom:1.75rem;right:1.75rem;z-index:998;width:52px;height:52px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(37,211,102,.35);transition:.25s}
.whatsapp-float:hover,.wa:hover{transform:scale(1.08) translateY(-2px);color:#fff}

/* ═══ STICKY CTA ═══ */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:997;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);padding:10px var(--gx);border-top:1px solid var(--border)}
.sticky-cta-inner{display:flex;gap:8px;max-width:var(--mw);margin:0 auto}
.sticky-cta .btn{flex:1;font-size:.78rem;padding:.65rem 1rem;min-height:42px}

/* ═══ REVEAL ═══ */
.reveal,.rv{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.visible,.rv.v{opacity:1;transform:none}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .hero-container,.split{grid-template-columns:1fr;gap:3rem}
  .hero-visual{max-width:500px;margin:0 auto}
  .float{display:none}
  .features-grid,.fg,.scenarios-grid,.sg,.why-grid{grid-template-columns:repeat(2,1fr)}
  .compliance-grid,.ccg{grid-template-columns:1fr}
  .footer-grid,.ftg{grid-template-columns:1fr 1fr}
  .trust{grid-template-columns:repeat(2,1fr)}
  .flow-arrow{display:none}
}
@media(max-width:768px){
  .main-nav,.nv,.header-phone,.hp,.header-divider,.dv{display:none}
  .menu-toggle,.mt{display:flex}
  .features-grid,.fg,.scenarios-grid,.sg,.why-grid{grid-template-columns:1fr}
  .kds{grid-template-columns:1fr 1fr}
  .mesas{grid-template-columns:repeat(3,1fr)}
  .footer-grid,.ftg{grid-template-columns:1fr;gap:2rem}
  .footer-bottom,.fbt{flex-direction:column;gap:.5rem;text-align:center}
  .app-body{grid-template-columns:1fr}
  .app-rail{display:none}
  .sticky-cta{display:block}
  .whatsapp-float,.wa{bottom:4.5rem}
  .trust{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-actions,.hacts{flex-direction:column}
  .hero-actions .btn{width:100%}
  .trust{grid-template-columns:1fr}
}

/* ═══ REFINEMENTS PREMIUM FINAL ═══ */

/* Botón outline sobre fondo oscuro — contraste visible */
.hero .btn-o,
.cta-dark .btn-o,
.ctd .btn-o {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.hero .btn-o:hover,
.cta-dark .btn-o:hover,
.ctd .btn-o:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.3);
  color: #fff;
  transform: translateY(-2px);
}

/* Hover refinado del CTA primario — micro-shine */
.btn-c,
.btn-primary {
  position: relative;
  overflow: hidden;
}
.btn-c::before,
.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
  transition: left .5s ease;
}
.btn-c:hover::before,
.btn-primary:hover::before {
  left: 100%;
}

/* Tag/label consistencia premium */
.tag,
.label {
  font-weight: 600;
  letter-spacing: .12em;
}

/* ═══ COMPARATIVA TABLA — estilos ═══ */
.compare-table {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--s2);
}
.compare-head {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  background: var(--ink);
  color: #fff;
}
.compare-head > div {
  padding: 1.25rem 1rem;
  font-family: var(--font);
  font-weight: 700;
  font-size: .95rem;
  text-align: center;
  border-left: 1px solid rgba(255,255,255,.08);
}
.compare-head > div:first-child {
  text-align: left;
  border-left: none;
  color: rgba(255,255,255,.5);
  font-weight: 500;
  font-size: .85rem;
}
.compare-head .col-mun {
  background: var(--teal);
  position: relative;
}
.compare-head .col-mun::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.08), transparent);
  pointer-events: none;
}
.compare-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  border-top: 1px solid var(--border);
}
.compare-row > div {
  padding: 1rem;
  font-size: .88rem;
  text-align: center;
  border-left: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.compare-row > div:first-child {
  text-align: left;
  justify-content: flex-start;
  border-left: none;
  color: var(--ink);
  font-weight: 500;
}
.compare-row .col-mun {
  background: var(--teal-10);
  color: var(--teal);
  font-weight: 600;
}
.compare-check {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.compare-check.yes { color: var(--teal); }
.compare-check.no { color: var(--faint); }

/* ═══ ZONA COBERTURA LOCAL ═══ */
.coverage {
  background: var(--bg2);
  border-radius: var(--r-xl);
  padding: 2.5rem 2rem;
  text-align: center;
}
.coverage-title {
  font-family: var(--font);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: .75rem;
}
.coverage-text {
  font-size: .92rem;
  color: var(--muted);
  max-width: 520px;
  margin: 0 auto 1.25rem;
  line-height: 1.75;
}
.coverage-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}
.coverage-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: .75rem;
  font-weight: 500;
  color: var(--txt);
  transition: .15s;
}
.coverage-pill:hover {
  border-color: var(--teal-20);
  color: var(--teal);
}

/* Responsive comparativa */
@media (max-width: 768px) {
  .compare-head,
  .compare-row {
    grid-template-columns: 1.4fr 1fr 1fr;
  }
  .compare-head > div,
  .compare-row > div {
    padding: .75rem .5rem;
    font-size: .78rem;
  }
}

/* ═══════════════════════════════════════════
   PREMIUM POLISH — FINAL FINISHING LAYER
   ═══════════════════════════════════════════ */

/* ═ Sistema de color ampliado ═ */
:root{
  /* Teal scale */
  --teal-50:rgba(12,107,98,.04);
  --teal-100:rgba(12,107,98,.08);
  --teal-200:rgba(12,107,98,.14);
  --teal-300:rgba(12,107,98,.22);
  --teal-500:#0c6b62;
  --teal-600:#0a5c54;
  --teal-700:#085048;
  
  /* Coral scale */
  --coral-50:rgba(201,81,42,.04);
  --coral-100:rgba(201,81,42,.08);
  --coral-200:rgba(201,81,42,.14);
  --coral-500:#c9512a;
  --coral-600:#b5461f;
  --coral-700:#9e3c18;
  
  /* Neutral refinement */
  --line:rgba(15,23,41,.06);
  --line-strong:rgba(15,23,41,.1);
  
  /* Premium shadows — 2 capas */
  --sh-sm:0 1px 2px rgba(15,23,41,.04),0 1px 1px rgba(15,23,41,.03);
  --sh-md:0 4px 6px -2px rgba(15,23,41,.03),0 2px 4px -1px rgba(15,23,41,.04);
  --sh-lg:0 10px 15px -3px rgba(15,23,41,.06),0 4px 6px -2px rgba(15,23,41,.04);
  --sh-xl:0 20px 25px -5px rgba(15,23,41,.07),0 10px 10px -5px rgba(15,23,41,.03);
  
  /* Gradient borders */
  --grad-border:linear-gradient(135deg,rgba(12,107,98,.3),rgba(201,81,42,.25));
}

/* ═ Tipografía refinada ═ */
body{font-feature-settings:"cv11","ss01","kern";text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-feature-settings:"ss01","cv11"}
h1{letter-spacing:-.04em;line-height:1.08}
h2{letter-spacing:-.025em;line-height:1.15}
p{letter-spacing:-.003em}

/* ═ Ritmo vertical ═ */
.section,.sec{padding:clamp(5rem,8vw,8rem) 0}
.section + .section,.sec + .sec{position:relative}
.section + .section::before,.sec + .sec::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--line-strong),transparent)}

/* ═ Hero — refinamiento ═ */
.hero{min-height:100vh;padding:7.5rem 0 6rem}
.hero::before{background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:40px 40px;mask-image:radial-gradient(ellipse 55% 50% at 40% 45%,black,transparent);-webkit-mask-image:radial-gradient(ellipse 55% 50% at 40% 45%,black,transparent);opacity:.7}
.hero::after{width:700px;height:700px;bottom:-35%;right:-8%;opacity:.8;background:radial-gradient(circle,rgba(12,107,98,.12),transparent 62%)}

.hero-badge{background:rgba(12,107,98,.12);border-color:rgba(12,107,98,.18);padding:5px 14px 5px 8px;font-weight:500;transition:.2s}
.hero-badge:hover{background:rgba(12,107,98,.18);border-color:rgba(12,107,98,.28)}
.hero-badge::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 50%);pointer-events:none}
.hero-dot{box-shadow:0 0 10px rgba(22,130,64,.6),0 0 0 3px rgba(22,130,64,.15);animation:pulse-dot 2.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 10px rgba(22,130,64,.6),0 0 0 3px rgba(22,130,64,.15)}50%{box-shadow:0 0 14px rgba(22,130,64,.8),0 0 0 5px rgba(22,130,64,.08)}}

.hero-sub{color:rgba(255,255,255,.58);line-height:1.8;font-size:1.08rem;max-width:480px}
.hero-actions{margin-bottom:2.25rem}
.hero-trust{color:rgba(255,255,255,.42);font-size:.8rem;letter-spacing:-.005em}
.hero-trust svg{color:#34d399;filter:drop-shadow(0 0 4px rgba(52,211,153,.3))}

/* ═ Botones — refinamiento premium ═ */
.btn{letter-spacing:-.005em;font-weight:600;box-shadow:var(--sh-sm);will-change:transform}
.btn-c,.btn-primary{
  background:linear-gradient(180deg,#d35830 0%,var(--coral) 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 1px 3px rgba(201,81,42,.25),0 4px 12px rgba(201,81,42,.08)
}
.btn-c:hover,.btn-primary:hover{
  background:linear-gradient(180deg,#c14c26 0%,#a8411d 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 6px 14px rgba(201,81,42,.25),0 18px 40px rgba(201,81,42,.12);
  transform:translateY(-2px)
}
.btn-t,.btn-teal{
  background:linear-gradient(180deg,#0f7a70 0%,var(--teal) 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 1px 3px rgba(12,107,98,.25),0 4px 12px rgba(12,107,98,.08)
}
.btn-t:hover,.btn-teal:hover{
  background:linear-gradient(180deg,#0a5c54 0%,#085048 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 6px 14px rgba(12,107,98,.25),0 18px 40px rgba(12,107,98,.12)
}
.btn-o,.btn-outline{
  border-width:1px;
  background:var(--bg);
  box-shadow:var(--sh-sm),0 0 0 1px rgba(15,23,41,.02)
}
.btn-o:hover,.btn-outline:hover{
  box-shadow:var(--sh-md),0 0 0 1px var(--teal-300);
  border-color:var(--teal)
}

/* ═ App mockup — refinamiento ═ */
.app{
  border-radius:18px;
  background:linear-gradient(180deg,#162034 0%,#121b2d 100%);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.5),
    0 24px 48px rgba(0,0,0,.28),
    0 48px 96px rgba(12,107,98,.08),
    inset 0 1px 0 rgba(255,255,255,.04);
  position:relative
}
.app::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg,rgba(255,255,255,.04),transparent 40%);
  pointer-events:none;
  z-index:1
}
.app-top{background:rgba(0,0,0,.32);border-color:rgba(255,255,255,.05)}
.app-url{font-weight:500;letter-spacing:.01em}
.app-stat{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border-color:rgba(255,255,255,.05);
  transition:.2s
}
.app-stat:hover{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border-color:rgba(255,255,255,.08)}
.app-stat-value{font-feature-settings:"tnum"}

/* Floating cards — premium */
.float{
  background:rgba(22,32,52,.88);
  backdrop-filter:blur(14px) saturate(180%);
  -webkit-backdrop-filter:blur(14px) saturate(180%);
  border-color:rgba(255,255,255,.08);
  box-shadow:0 12px 32px rgba(0,0,0,.35),0 1px 0 rgba(255,255,255,.06) inset
}

/* ═ Mockups (screens) — refinamiento ═ */
.screen{
  border-radius:14px;
  border-color:var(--line);
  box-shadow:
    0 0 0 1px rgba(15,23,41,.04),
    0 2px 4px rgba(15,23,41,.03),
    0 10px 20px rgba(15,23,41,.06),
    0 30px 60px rgba(15,23,41,.04);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)
}
.screen:hover{
  transform:translateY(-4px);
  box-shadow:
    0 0 0 1px var(--teal-200),
    0 4px 8px rgba(15,23,41,.04),
    0 16px 32px rgba(15,23,41,.08),
    0 40px 80px rgba(12,107,98,.08)
}
.screen-bar{background:linear-gradient(180deg,var(--bg2),var(--bg3));font-weight:500}
.screen-bar::before{box-shadow:0 0 6px rgba(22,130,64,.5)}

/* KDS tickets — refinamiento */
.kt{
  border-radius:9px;
  box-shadow:0 1px 2px rgba(15,23,41,.03);
  transition:.2s
}
.kt:hover{box-shadow:0 2px 6px rgba(15,23,41,.06);transform:translateY(-1px)}
.kt:nth-child(1){border-top-width:3px}
.kt:nth-child(2){border-top-width:3px}
.kt:nth-child(3){border-top-width:3px}

/* ═ Tarjetas — gradient border on hover ═ */
.feature-card,.fc,.why-card,.scenario,.sc{
  position:relative;
  border-radius:16px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  background:var(--bg)
}
.feature-card::before,.fc::before,
.why-card::before,
.scenario::before,.sc::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg,var(--teal-300),var(--coral-200));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0;
  transition:opacity .3s var(--ease);
  pointer-events:none
}
.feature-card:hover::before,.fc:hover::before,
.why-card:hover::before,
.scenario:hover::before,.sc:hover::before{opacity:1}
.feature-card:hover,.fc:hover,
.why-card:hover,
.scenario:hover,.sc:hover{
  transform:translateY(-4px);
  box-shadow:var(--sh-lg);
  border-color:transparent
}

.feature-icon,.fic{
  background:linear-gradient(135deg,var(--teal-100),var(--teal-50));
  box-shadow:0 1px 2px var(--teal-200),inset 0 1px 0 rgba(255,255,255,.4)
}

/* ═ Compliance cards — refinamiento ═ */
.compliance,.cc{
  border-radius:20px;
  box-shadow:var(--sh-lg)
}
.compliance.verifactu,.cc.ccT{border-color:var(--teal-200)}
.compliance.ticketbai,.cc.ccV{border-color:rgba(8,98,160,.15)}

/* ═ Section header — refinamiento ═ */
.section-header,.hd{margin-bottom:4rem}
.section-header h2,.hd h2{margin-top:.75rem}
.section-header p,.hd p{margin-top:.75rem;font-size:1rem;line-height:1.85}

/* ═ Tags — premium ═ */
.tag,.label{
  font-size:.64rem;
  font-weight:600;
  letter-spacing:.14em;
  color:var(--teal);
  text-transform:uppercase
}
.tag::before,.label::before{background:linear-gradient(90deg,var(--teal),transparent);width:22px;height:1.5px;opacity:.7}

/* ═ CTA dark — premium ═ */
.cta-dark,.ctd{
  padding:clamp(5rem,9vw,8rem) 0;
  background:linear-gradient(180deg,#0f1729 0%,#0a1020 100%)
}
.cta-dark::before,.ctd::before{width:600px;height:600px;top:-45%;background:radial-gradient(circle,rgba(12,107,98,.1),transparent 58%)}
.cta-dark h2,.ctd h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:.85rem}
.cta-dark p,.ctd p{font-size:1.05rem}

/* ═ Footer — refinamiento premium ═ */
.site-footer,.ft{
  background:linear-gradient(180deg,#0a1020 0%,#070b18 100%);
  padding:4.5rem 0 2rem;
  position:relative;
  color:rgba(255,255,255,.42)
}
.site-footer::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)
}
.footer-grid,.ftg{gap:3rem;margin-bottom:3rem}
.footer-brand,.ftb{
  font-size:1.2rem;
  background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.7) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  letter-spacing:-.02em
}
.footer-desc,.ftd{color:rgba(255,255,255,.5);font-size:.85rem;line-height:1.75;margin-top:.65rem}
.footer-col h4,.ftc h4{
  font-size:.68rem;
  font-weight:600;
  color:rgba(255,255,255,.55);
  margin-bottom:1rem;
  text-transform:uppercase;
  letter-spacing:.12em
}
.footer-col a,.ftc a{
  font-size:.85rem;
  padding:3px 0;
  transition:color .15s,transform .15s;
  color:rgba(255,255,255,.55);
  display:inline-block;
  position:relative
}
.footer-col a:hover,.ftc a:hover{color:#fff;transform:translateX(2px)}
.footer-bottom,.fbt{
  padding-top:1.75rem;
  border-top:1px solid rgba(255,255,255,.05);
  color:rgba(255,255,255,.35);
  font-size:.74rem
}
.footer-legal a,.flg a{color:rgba(255,255,255,.45);transition:color .15s}
.footer-legal a:hover,.flg a:hover{color:#fff}

/* Zonas de servicio — footer */
.footer-zones{
  margin-top:.6rem;
  font-size:.75rem;
  color:rgba(255,255,255,.35);
  line-height:1.65
}
.footer-zones strong{color:rgba(255,255,255,.55);font-weight:500}

/* ═ Header — refinamiento ═ */
.site-header.scrolled,.hdr.sc{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  border-bottom:1px solid var(--line)
}
.logo-mark,.lm{
  background:linear-gradient(135deg,#0f7a70 0%,var(--teal) 100%);
  box-shadow:0 1px 2px rgba(12,107,98,.25),0 4px 8px rgba(12,107,98,.1),inset 0 1px 0 rgba(255,255,255,.18)
}
.main-nav a{position:relative;padding:3px 0}
.main-nav a::after{
  content:'';
  position:absolute;
  bottom:-3px;
  left:0;
  right:0;
  height:1.5px;
  background:var(--teal);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .25s var(--ease);
  border-radius:1px
}
.main-nav a:hover::after{transform:scaleX(.7)}

/* ═ Brand strip / ticker ═ */
.brand-strip,.ticker{border-color:var(--line);padding:18px 0}
.brand-strip-item,.ticker-item{font-size:.73rem;color:var(--faint);font-weight:500}

/* ═ Trust numbers — premium ═ */
.trust{padding:3.5rem 0;gap:1.5rem;border-color:var(--line)}
.trust-item{padding:1.5rem 1rem;position:relative}
.trust-item:not(:last-child)::after{content:'';position:absolute;top:20%;right:0;bottom:20%;width:1px;background:var(--line)}
.trust-num{
  font-size:2.25rem;
  background:linear-gradient(135deg,var(--teal) 0%,#0f7a70 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  letter-spacing:-.035em
}
.trust-label{font-size:.76rem;color:var(--muted);line-height:1.55;margin-top:6px}

/* ═ Flow pipeline ═ */
.flow-icon{
  background:linear-gradient(180deg,#fff,var(--bg2));
  border-color:var(--line-strong)
}
.flow-step:hover .flow-icon{
  background:linear-gradient(180deg,var(--teal-50),var(--teal-100));
  border-color:var(--teal-300);
  box-shadow:var(--sh-md)
}

/* ═ Compare table — refinado ═ */
.compare-table{border-radius:18px;box-shadow:var(--sh-xl),0 0 0 1px var(--line)}
.compare-head{background:linear-gradient(180deg,#162034 0%,#0f1729 100%)}
.compare-head .col-mun{background:linear-gradient(180deg,#0f7a70 0%,var(--teal) 100%)}
.compare-row:hover{background:var(--bg2);transition:background .2s}
.compare-row .col-mun{background:var(--teal-50)}

/* ═ Coverage — refinado ═ */
.coverage{
  background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);
  border:1px solid var(--line);
  box-shadow:var(--sh-md),0 0 0 1px var(--line) inset
}
.coverage-title{font-size:1.3rem}
.coverage-pill{
  transition:all .2s var(--ease);
  border-color:var(--line-strong)
}
.coverage-pill:hover{
  transform:translateY(-1px);
  box-shadow:var(--sh-sm);
  border-color:var(--teal-300);
  color:var(--teal);
  background:var(--teal-50)
}

/* ═ FAQ — refinado ═ */
.faq,.fq{transition:border-color .2s}
.faq.open,.fq.open{border-color:var(--teal-300)}
.faq-question,.fqq{font-weight:600;font-size:.92rem;transition:color .15s}
.faq.open .faq-question,.fq.open .fqq{color:var(--teal)}

/* ═ Forms — refinamiento ═ */
.form-control{
  border-radius:10px;
  transition:all .18s var(--ease);
  font-size:.92rem
}
.form-control:hover{border-color:var(--line-strong)}
.form-control:focus{box-shadow:0 0 0 4px var(--teal-100)}

/* ═ Breadcrumbs ═ */
.breadcrumb{
  padding:1.25rem 0 0;
  font-size:.78rem;
  color:var(--muted)
}
.breadcrumb a{color:var(--muted);transition:color .15s}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb-sep{margin:0 6px;color:var(--faint)}
.breadcrumb-current{color:var(--ink);font-weight:500}

/* ═ Small tag local (header scrolled) ═ */
.header-local-tag{
  font-family:var(--mono);
  font-size:.55rem;
  font-weight:500;
  color:var(--muted);
  letter-spacing:.1em;
  text-transform:uppercase;
  display:none
}
.site-header.scrolled .header-local-tag{display:inline}
@media(max-width:1024px){.header-local-tag{display:none !important}}

/* ═ WhatsApp float — refinamiento ═ */
.whatsapp-float,.wa{
  box-shadow:0 4px 14px rgba(37,211,102,.35),0 1px 0 rgba(255,255,255,.2) inset,0 0 0 4px rgba(37,211,102,.08)
}
.whatsapp-float:hover,.wa:hover{
  box-shadow:0 6px 20px rgba(37,211,102,.45),0 1px 0 rgba(255,255,255,.25) inset,0 0 0 6px rgba(37,211,102,.12)
}

/* ═ Smooth scroll for sections ═ */
html{scroll-padding-top:80px}

/* ═ Selection color ═ */
::selection{background:var(--teal-200);color:var(--ink)}
::-moz-selection{background:var(--teal-200);color:var(--ink)}

/* ═ Focus visible premium ═ */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:6px}
.btn:focus-visible{outline-offset:4px}
