/* ================================================
   main.css — Conexión IT
   Paleta: #0C4478 / #185FA5 / #3A9B6F
================================================ */
:root{
  --navy:#0C4478; --blue:#185FA5; --blue-lt:#2176C7;
  --green:#3A9B6F; --green-dk:#2D8560;
  --white:#fff; --off:#F4F7FB; --border:#DDE3EE;
  --text:#0F1C2E; --muted:#64748B; --muted-lt:#94A3B8;
  --radius:12px;
  --shadow:0 2px 16px rgba(12,68,120,.09);
  --shadow-lg:0 12px 48px rgba(12,68,120,.18);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:#fff;line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;line-height:1.2}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:'Inter',sans-serif}

/* ── HEADER ── */
#hdr-placeholder{min-height:116px;background:var(--navy)}.hdr{position:sticky;top:0;z-index:200;background:var(--navy);transition:box-shadow .3s}
.hdr.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.35)}
.hdr-inner{max-width:1200px;margin:auto;padding:0 32px;height:116px;display:flex;align-items:center;gap:32px}
.hdr-logo img{height:102px;width:auto;cursor:pointer;transition:opacity .2s;display:block;background:transparent}
.hdr-logo img:hover{opacity:.82}
.hdr-logo{background:transparent;display:flex;align-items:center}
.hdr-nav{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav-a{padding:8px 15px;border-radius:8px;font-size:14px;font-weight:500;color:rgba(255,255,255,.72);border:none;background:none;cursor:pointer;transition:color .2s,background .2s}
.nav-a:hover,.nav-a.on{color:#fff;background:rgba(255,255,255,.1)}
.hdr-acts{display:flex;align-items:center;gap:8px;margin-left:8px}
.btn-cart{position:relative;width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}
.btn-cart:hover{background:rgba(255,255,255,.2)}
.cart-ct{position:absolute;top:-5px;right:-5px;width:19px;height:19px;border-radius:50%;background:var(--green);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ham{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px}
.ham span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:.3s}

/* ── MOBILE NAV ── */
.mob-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300}
.mob-bg.on{display:block}
.mob-nav{position:fixed;top:0;left:-300px;width:280px;height:100vh;background:var(--navy);z-index:400;transition:left .3s ease;display:flex;flex-direction:column}
.mob-nav.on{left:0}
.mob-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}
.mob-hd img{height:26px}
.mob-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:22px}
.mob-links{padding:16px;flex:1;display:flex;flex-direction:column;gap:2px}
.mob-link{display:block;padding:12px 16px;border-radius:8px;color:rgba(255,255,255,.8);font-size:15px;font-weight:500;border:none;background:none;text-align:left;transition:.2s;cursor:pointer}
.mob-link:hover{background:rgba(255,255,255,.1);color:#fff}
.mob-ft{padding:20px 24px;border-top:1px solid rgba(255,255,255,.1)}
.mob-ft p{color:rgba(255,255,255,.4);font-size:13px;margin-bottom:6px}

/* ── PAGE HERO (inner pages) ── */
.page-hero{position:relative;overflow:hidden;padding:80px 32px;
  background:radial-gradient(ellipse at 75% 30%, rgba(33,118,199,.45) 0%, transparent 55%),
              linear-gradient(135deg, #06203D 0%, var(--navy) 45%, #0A3460 100%)}
.page-hero .hero-pattern{opacity:.06}
#pageHeroWaves{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none;opacity:.7}
.page-hero .hero-glow{width:600px;height:600px;top:50%;left:75%}
.page-hero .hero-glow-2{width:340px;height:340px;top:10%;right:0}
.page-hero-inner{max-width:1200px;margin:auto;position:relative;z-index:1}
.page-hero h1{font-size:42px;font-weight:900;color:#fff;margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,.6);font-size:17px}
.breadcrumb{display:flex;gap:8px;font-size:13px;color:rgba(255,255,255,.35);margin-bottom:18px}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .2s}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.35)}

/* ── SECTION ── */
.sec{max-width:1200px;margin:auto;padding:96px 32px}
.sec-tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:12px;display:block}
.sec-h2{font-size:clamp(28px,3.5vw,42px);font-weight:800;color:var(--navy);margin-bottom:14px}
.sec-sub{font-size:16px;color:var(--muted);max-width:540px;line-height:1.7}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;
  background:radial-gradient(ellipse at 75% 30%, rgba(33,118,199,.45) 0%, transparent 55%),
              linear-gradient(135deg, #06203D 0%, var(--navy) 45%, #0A3460 100%);
  min-height:clamp(480px,80vh,900px);display:flex;align-items:center}
.hero-pattern{position:absolute;inset:0;z-index:0;opacity:.08;pointer-events:none;
  background-image:linear-gradient(rgba(137,199,254,.5) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(137,199,254,.5) 1px,transparent 1px);
  background-size:64px 64px}
#heroWaves{position:absolute;inset:0;z-index:1;width:100%;height:100%;pointer-events:none}
#heroCanvas{position:absolute;inset:0;z-index:0;opacity:.25;pointer-events:none}
.hero-glow{position:absolute;width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,155,111,.26) 0%,transparent 65%);
  top:42%;left:62%;transform:translate(-50%,-50%);z-index:1;pointer-events:none;
  animation:glowPulse 7s ease-in-out infinite}
.hero-glow-2{position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(137,199,254,.18) 0%,transparent 65%);
  top:16%;right:6%;z-index:1;pointer-events:none}
@keyframes glowPulse{0%,100%{opacity:1}50%{opacity:.7}}
#heroFloatParticles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-particle{position:absolute;bottom:-20px;border-radius:50%;background:#7FD8B5;
  opacity:0;animation-name:floatUp;animation-timing-function:linear;animation-iteration-count:infinite}
@keyframes floatUp{
  0%{transform:translateY(0) scale(0);opacity:0}
  8%{opacity:.3}
  92%{opacity:.12}
  100%{transform:translateY(-100vh) scale(1);opacity:0}
}
.hero-inner{position:relative;z-index:2;max-width:1200px;margin:auto;padding:80px 32px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;background:rgba(58,155,111,.12);border:1px solid rgba(58,155,111,.45);color:#7FE8C2;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:9px 22px;border-radius:30px;margin-bottom:28px}
.hero-eyebrow::before{content:'';width:8px;height:8px;border-radius:50%;background:#3A9B6F;display:inline-block;box-shadow:0 0 0 4px rgba(58,155,111,.25);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.hero-h1{font-size:clamp(40px,5.5vw,68px);font-weight:900;color:#fff;margin-bottom:24px;letter-spacing:-1.5px;line-height:1.08}
.hero-h1 em{color:var(--green);font-style:normal;position:relative}
.hero-h1 em::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),transparent);border-radius:2px}
.gradient-text{background:linear-gradient(90deg,var(--blue-lt) 0%,var(--green) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-p{font-size:17px;color:rgba(255,255,255,.68);max-width:480px;margin-bottom:40px;line-height:1.78}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{display:flex;align-items:center;justify-content:center}
#networkCanvas{border-radius:20px;cursor:pointer;max-width:100%}

/* ── STATS ── */
.stats-strip{background:var(--off);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-inner{max-width:1200px;margin:auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{padding:36px 20px;text-align:center;border-right:1px solid var(--border);position:relative;overflow:hidden;transition:background .25s}
.stat-cell:last-child{border-right:none}
.stat-cell:hover{background:rgba(12,68,120,.04)}
.stat-cell::before{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:linear-gradient(90deg,var(--navy),var(--green));transition:width .4s ease;border-radius:2px}
.stat-cell:hover::before{width:60%}
.stat-n{font-family:'Montserrat',sans-serif;font-size:40px;font-weight:900;color:var(--navy);display:block;margin-bottom:4px;line-height:1}
.stat-l{font-size:13px;color:var(--muted);font-weight:500}

/* ── SERVICES CARDS ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;position:relative;overflow:hidden;transition:box-shadow .3s,transform .3s,border-color .3s}
.svc-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.svc:hover{box-shadow:var(--shadow-lg);transform:translateY(-7px);border-color:transparent}
.svc:hover .svc-bar{transform:scaleX(1)}
.svc-ico{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:20px;box-shadow:0 4px 16px rgba(12,68,120,.28);transition:transform .3s,box-shadow .3s}
.svc:hover .svc-ico{transform:scale(1.1) rotate(-3deg);box-shadow:0 8px 24px rgba(12,68,120,.4)}
.svc h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:10px}
.svc p{font-size:14px;color:var(--muted);line-height:1.7}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.svc-tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:10px;background:var(--off);color:var(--navy);border:1px solid var(--border)}
.svc-cta{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:13px;font-weight:600;color:var(--blue);border:none;background:none;padding:0;cursor:pointer;transition:gap .2s,color .2s}
.svc-cta:hover{gap:10px;color:var(--navy)}

/* ── CHART SECTION ── */
.chart-section{background:var(--navy);padding:100px 0;position:relative;overflow:hidden}
.chart-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(24,95,165,.45) 0%,transparent 70%)}
.chart-inner{max-width:1200px;margin:auto;padding:0 32px;position:relative;z-index:1}
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.chart-left .sec-h2{color:#fff}
.chart-left .sec-sub{color:rgba(255,255,255,.6)}
.chart-items{margin-top:32px;display:flex;flex-direction:column;gap:20px}
.chart-item-label{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:600}
.chart-item-label span:first-child{color:rgba(255,255,255,.8)}
.chart-item-label span:last-child{color:var(--green)}
.bar-track{height:8px;background:rgba(255,255,255,.1);border-radius:8px;overflow:hidden}
.bar-fill{height:100%;border-radius:8px;width:0%;background:linear-gradient(90deg,var(--green-dk),var(--green));transition:width 1.5s cubic-bezier(.25,.46,.45,.94);box-shadow:0 0 12px rgba(58,155,111,.5)}
.chart-right{display:flex;align-items:center;justify-content:center}
.donut-wrap{position:relative;width:280px;height:280px}
#donutCanvas{width:280px;height:280px}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.donut-center span{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:900;color:#fff;display:block}
.donut-center small{color:rgba(255,255,255,.5);font-size:12px}
.donut-legend{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px}
.dl-item{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.6)}
.dl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* ── WHY US ── */
.why{background:var(--off);padding:100px 0}
.why-inner{max-width:1200px;margin:auto;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.why-right{display:flex;flex-direction:column;justify-content:center}
.why-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px;transition:box-shadow .25s,transform .25s}
.why-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.why-card-ico{font-size:32px;margin-bottom:12px}
.why-card h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px}
.why-card p{font-size:13px;color:var(--muted);line-height:1.6}
.ring-visual{position:relative;width:260px;height:260px;margin:auto}
.rv-ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(12,68,120,.12);animation:ringSpinA 18s linear infinite}
.rv-ring-2{position:absolute;inset:28px;border-radius:50%;border:1px dashed rgba(58,155,111,.2);animation:ringSpinA 12s linear infinite reverse}
@keyframes ringSpinA{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.rv-center{position:absolute;inset:56px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 32px rgba(12,68,120,.35)}
.rv-center b{font-family:'Montserrat',sans-serif;font-size:38px;font-weight:900;line-height:1}
.rv-center small{font-size:11px;opacity:.7;text-align:center;margin-top:4px}

/* ── PROCESS ── */
.process{padding:100px 0}
.process-inner{max-width:1200px;margin:auto;padding:0 32px}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;position:relative}
.process-steps::before{content:'';position:absolute;top:32px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,var(--navy),var(--green));z-index:0}
.ps{text-align:center;padding:0 16px;position:relative;z-index:1;opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}
.ps.visible{opacity:1;transform:translateY(0)}
.ps-num{width:64px;height:64px;border-radius:50%;background:#fff;border:3px solid var(--navy);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:22px;font-weight:900;color:var(--navy);margin:0 auto 20px;box-shadow:var(--shadow);transition:background .3s,color .3s}
.ps:hover .ps-num{background:var(--navy);color:#fff}
.ps h4{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px}
.ps p{font-size:13px;color:var(--muted);line-height:1.6}

/* ── TESTIMONIALS ── */
.testi{background:var(--navy);padding:100px 0;position:relative;overflow:hidden}
.testi::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 20% 50%,rgba(58,155,111,.15) 0%,transparent 65%)}
.testi-inner{max-width:1200px;margin:auto;padding:0 32px;position:relative;z-index:1}
.testi-head{text-align:center;margin-bottom:56px}
.testi-head .sec-h2{color:#fff}
.testi-head .sec-sub{margin:0 auto;color:rgba(255,255,255,.55)}
.testi-track{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tc{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px;backdrop-filter:blur(12px);transition:background .25s,transform .25s}
.tc:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.tc-stars{color:#FBBF24;font-size:14px;margin-bottom:14px;letter-spacing:2px}
.tc-text{font-size:14px;color:rgba(255,255,255,.75);line-height:1.75;margin-bottom:20px;font-style:italic}
.tc-author{display:flex;align-items:center;gap:12px}
.tc-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--green-dk),var(--green));display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}
.tc-name{font-weight:700;font-size:14px;color:#fff;margin-bottom:2px}
.tc-company{font-size:12px;color:rgba(255,255,255,.45)}

/* ── CTA BAND ── */
.cta-band{background:linear-gradient(135deg,var(--green-dk),var(--green));padding:80px 32px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(255,255,255,.08) 0%,transparent 65%)}
.cta-band h2{font-size:clamp(24px,3.5vw,38px);font-weight:800;color:#fff;margin-bottom:12px;position:relative}
.cta-band p{color:rgba(255,255,255,.8);font-size:16px;margin-bottom:32px;position:relative}

/* ── SERVICIOS PAGE ── */
.svc-detail-list{display:flex;flex-direction:column;gap:0}
.svc-detail{display:grid;grid-template-columns:70px 1fr;gap:32px;align-items:start;padding:48px 0;border-bottom:1px solid var(--border)}
.svc-detail:last-child{border-bottom:none}
.svc-num{font-family:'Montserrat',sans-serif;font-size:52px;font-weight:900;color:var(--border);line-height:1}
.svc-detail h3{font-size:22px;font-weight:700;color:var(--navy);margin-bottom:12px}
.svc-detail p{font-size:15px;color:var(--muted);margin-bottom:16px;line-height:1.75}
.stags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.stag{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:600;background:var(--off);color:var(--navy);border:1px solid var(--border)}
.btn-cot{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;border:none;padding:11px 22px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}
.btn-cot:hover{background:var(--blue);transform:translateX(3px)}

/* ── PRODUCTOS PAGE ── */
.filter-wrap{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.f-btn{padding:8px 20px;border-radius:20px;border:1.5px solid var(--border);background:#fff;font-size:13px;font-weight:600;color:var(--muted);transition:.2s;cursor:pointer}
.f-btn:hover{border-color:var(--blue);color:var(--blue)}
.f-btn.on{background:var(--navy);border-color:var(--navy);color:#fff}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.prod{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:box-shadow .25s,transform .25s;display:flex;flex-direction:column}
.prod:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}
.prod-thumb{height:160px;background:linear-gradient(135deg,var(--off),#E8EFF8);display:flex;align-items:center;justify-content:center;font-size:56px;position:relative;flex-shrink:0}
.prod-badge{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:12px;text-transform:uppercase}
.prod-body{padding:20px;display:flex;flex-direction:column;flex:1}
.prod-name{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--text);margin-bottom:6px}
.prod-desc{font-size:13px;color:var(--muted);margin-bottom:16px;line-height:1.5;flex:1}
.prod-price{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:900;color:var(--navy);margin-bottom:16px}
.prod-price small{font-size:12px;font-weight:400;color:var(--muted)}
.prod-actions{display:flex;gap:8px}
.btn-add{flex:1;background:var(--navy);color:#fff;border:none;padding:10px;border-radius:8px;font-weight:700;font-size:13px;transition:background .2s;cursor:pointer}
.btn-add:hover{background:var(--blue)}
.btn-wa-p{width:42px;border-radius:8px;border:none;background:#25D366;color:#fff;font-size:18px;transition:background .2s;display:flex;align-items:center;justify-content:center;cursor:pointer}
.btn-wa-p:hover{background:#1ebe5d}

/* ── NOSOTROS PAGE ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:80px}
.about-visual{position:relative}
.about-visual-main{width:100%;aspect-ratio:1;max-width:420px;background:linear-gradient(135deg,#F3F6FB,#E4ECF7);border-radius:24px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}
.about-visual-main::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(58,155,111,.3) 0%,transparent 60%)}
.about-logo-inner{position:relative;z-index:1;width:135%;padding:0;filter:drop-shadow(0 4px 24px rgba(12,68,120,.12))}
.about-badge{position:absolute;bottom:-18px;right:-18px;width:110px;height:110px;border-radius:50%;background:var(--green);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(58,155,111,.4);border:4px solid #fff}
.about-badge b{font-family:'Montserrat',sans-serif;font-size:28px;font-weight:900;line-height:1}
.about-badge small{font-size:9px;opacity:.85;text-align:center;line-height:1.4}
.about-text h2{font-size:34px;font-weight:800;color:var(--navy);margin-bottom:20px}
.about-text p{font-size:15px;color:var(--muted);margin-bottom:14px;line-height:1.75}
.mv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:80px}
.mv-c{background:var(--off);border:1px solid var(--border);border-radius:14px;padding:28px;transition:box-shadow .25s}
.mv-c:hover{box-shadow:var(--shadow)}
.mv-ico{font-size:36px;margin-bottom:14px}
.mv-c h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:8px}
.mv-c p{font-size:14px;color:var(--muted);line-height:1.65}
.team-grid{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin-bottom:80px}
.team-c{background:#fff;border:1px solid var(--border);border-radius:16px;padding:36px 28px;text-align:center;flex:1;min-width:220px;max-width:300px;transition:box-shadow .25s,transform .25s}
.team-c:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.team-av{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--green));margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:20px;font-weight:800;color:#fff}
.team-c h4{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:4px}
.team-role{font-size:13px;color:var(--green);font-weight:600;margin-bottom:10px}
.team-bio{font-size:13px;color:var(--muted);line-height:1.6}
.tl-wrap{max-width:680px;margin:0 auto;position:relative}
.tl-wrap::before{content:'';position:absolute;left:20px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--blue),var(--green))}
.tl-item{display:flex;gap:28px;margin-bottom:40px}
.tl-dot{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--navy);border:3px solid #fff;box-shadow:0 0 0 2px var(--blue);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:800;color:#fff;position:relative;z-index:1}
.tl-body{padding-top:6px}
.tl-year{display:inline-block;background:var(--navy);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:4px;margin-bottom:6px}
.tl-body h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px}
.tl-body p{font-size:13px;color:var(--muted)}

/* ── CONTACTO PAGE ── */
.contact-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.contact-info h3{font-size:22px;font-weight:700;color:var(--navy);margin-bottom:24px}
.c-items{display:flex;flex-direction:column;gap:18px;margin-bottom:24px}
.c-item{display:flex;gap:14px;align-items:flex-start}
.c-ico{width:44px;height:44px;border-radius:10px;flex-shrink:0;background:var(--off);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px}
.c-item strong{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:2px}
.c-item p{font-size:14px;color:var(--muted);margin:0}
.btn-wa-big{display:flex;align-items:center;gap:12px;background:#25D366;color:#fff;border:none;padding:15px 24px;border-radius:10px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;width:100%;justify-content:center;transition:background .2s,transform .15s;cursor:pointer}
.btn-wa-big:hover{background:#1ebe5d;transform:translateY(-1px)}
.cf-wrap{background:var(--off);border:1px solid var(--border);border-radius:16px;padding:36px;position:relative;z-index:1}
.cf-wrap h3{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:24px}
.cf{display:flex;flex-direction:column;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg label{font-size:13px;font-weight:600;color:var(--text)}
.fg input,.fg select,.fg textarea{padding:12px 16px;border:1.5px solid var(--border);border-radius:9px;font-family:'Inter',sans-serif;font-size:14px;color:var(--text);background:#fff;transition:border-color .2s,box-shadow .2s;resize:vertical}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(24,95,165,.12)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ── CART ── */
.cart-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500}
.cart-bg.on{display:block}
.cart-panel{position:fixed;top:0;right:-420px;width:400px;height:100vh;background:#fff;z-index:600;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 48px rgba(0,0,0,.2)}
.cart-panel.on{right:0}
.cart-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--navy);color:#fff}
.cart-hd h3{font-size:16px;font-weight:700}
.cart-hd button{background:none;border:none;color:rgba(255,255,255,.6);font-size:20px;cursor:pointer}
.cart-body{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty-msg{text-align:center;padding:60px 0;color:var(--muted)}
.cart-empty-msg div{font-size:48px;margin-bottom:16px}
.cart-empty-msg p{margin-bottom:16px;font-size:15px}
.ci{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--off)}
.ci-icon{font-size:28px;flex-shrink:0;width:44px;height:44px;background:var(--off);border-radius:8px;display:flex;align-items:center;justify-content:center}
.ci-info{flex:1}
.ci-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.ci-uprice{font-size:12px;color:var(--muted)}
.ci-ctrl{display:flex;align-items:center;gap:8px;margin-top:8px}
.q-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s;cursor:pointer}
.q-btn:hover{background:var(--off)}
.q-n{font-weight:700;font-size:14px;min-width:22px;text-align:center}
.ci-sub{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--navy);align-self:center;white-space:nowrap}
.ci-del{background:none;border:none;color:var(--muted);font-size:16px;margin-left:4px;transition:color .15s;cursor:pointer}
.ci-del:hover{color:#dc2626}
.cart-ft{padding:20px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.cart-tot-row{display:flex;justify-content:space-between;align-items:center}
.cart-tot-row span{font-size:15px;color:var(--muted)}
.cart-tot-row strong{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:900;color:var(--navy)}

/* ── CHECKOUT MODAL ── */
.mo-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:700}
.mo-bg.on{display:block}
.mo{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:700px;max-height:90vh;background:#fff;border-radius:18px;z-index:800;display:none;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.28);overflow:hidden}
.mo.on{display:flex}
.mo-hd{background:var(--navy);color:#fff;padding:20px 28px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mo-hd h2{font-size:18px;font-weight:700}
.mo-hd button{background:none;border:none;color:rgba(255,255,255,.6);font-size:22px;cursor:pointer}
.mo-body{overflow-y:auto;padding:28px;flex:1}
.mo-section{margin-bottom:24px}
.mo-section h4{font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.order-items-sum{background:var(--off);border-radius:10px;padding:16px 20px;margin-bottom:16px}
.osi{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);padding:4px 0}
.osi-total{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);margin-top:10px;padding-top:12px}
.osi-total span{font-size:14px;font-weight:600;color:var(--text)}
.osi-total strong{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:900;color:var(--navy)}
.pm-opts{display:flex;flex-direction:column;gap:10px}
.pm-lbl{cursor:pointer}
.pm-lbl input{display:none}
.pm-card{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:10px;border:2px solid var(--border);background:#fff;transition:.2s}
.pm-card:hover{border-color:var(--blue)}
.pm-card.sel{border-color:var(--navy);background:#EFF6FF}
.pm-ico{font-size:22px}
.pm-name{font-weight:600;font-size:14px;color:var(--text)}
.pm-desc{font-size:12px;color:var(--muted)}
.bank-box{background:var(--off);border:1px solid var(--border);border-radius:10px;padding:20px;margin-top:12px}
.bank-box h5{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:12px}
.bank-row{display:flex;justify-content:space-between;font-size:13px;padding:8px 12px;background:#fff;border-radius:7px;border:1px solid var(--border);margin-bottom:6px}
.bank-row span{color:var(--muted)}
.bank-row strong{color:var(--text)}
.steps-note{background:#FFF7ED;border-left:3px solid #F59E0B;border-radius:6px;padding:14px 16px;margin:14px 0}
.steps-note p{font-size:12px;font-weight:700;color:#92400E;margin-bottom:8px}
.steps-note ol{margin-left:16px}
.steps-note ol li{font-size:12px;color:#92400E;margin-bottom:5px}
.pp-unavail{background:#FEF3C7;border:1px solid #F59E0B;border-radius:8px;padding:14px;font-size:13px;color:#92400E;text-align:center}
.confirm-scr{text-align:center;padding:48px 24px}
.confirm-scr .tick{font-size:72px;margin-bottom:20px}
.confirm-scr h2{font-size:28px;font-weight:800;color:var(--navy);margin-bottom:12px}
.confirm-scr p{font-size:16px;color:var(--muted);margin-bottom:24px}
.order-tag{display:inline-block;background:var(--off);border:1px solid var(--border);border-radius:8px;padding:10px 24px;font-size:14px;color:var(--muted);margin-bottom:32px}
.order-tag strong{color:var(--navy);font-size:18px}
.confirm-acts{display:flex;flex-direction:column;gap:12px;max-width:340px;margin:auto}

/* ── WA FAB ── */
.wa-fab{position:fixed;bottom:28px;right:28px;width:64px;height:64px;border-radius:50%;z-index:900;border:none;background:none;cursor:pointer;filter:drop-shadow(0 4px 20px rgba(37,211,102,.5));transition:transform .2s}
@media(max-width:480px){.wa-fab{width:52px;height:52px;bottom:16px;right:14px}}
.wa-fab:hover{transform:scale(1.1)}
.wa-fab img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.wa-tip{position:absolute;right:76px;top:50%;transform:translateY(-50%);background:var(--text);color:#fff;font-size:13px;font-weight:600;padding:7px 14px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.wa-tip::after{content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-left-color:var(--text)}
.wa-fab:hover .wa-tip{opacity:1}

/* ── TOAST ── */
.toast{position:fixed;bottom:104px;right:28px;background:var(--text);color:#fff;padding:13px 20px;border-radius:10px;font-size:14px;font-weight:500;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s;z-index:950;max-width:280px;pointer-events:none}
.toast.on{opacity:1;transform:translateY(0)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── BUTTONS ── */
.btn-primary{background:var(--green);color:#fff;border:none;padding:14px 30px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.btn-primary:hover{background:var(--green-dk);transform:translateY(-2px);box-shadow:0 6px 20px rgba(58,155,111,.38)}
.btn-outline-w{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35);padding:14px 30px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:600;transition:.2s;cursor:pointer}
.btn-outline-w:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-white{background:#fff;color:var(--green-dk);border:none;padding:14px 32px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .2s;cursor:pointer}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--border);padding:12px 24px;border-radius:9px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;transition:.2s;cursor:pointer}
.btn-ghost:hover{border-color:var(--navy)}
.btn-ghost-gray{background:transparent;color:var(--muted);border:1px solid var(--border);padding:12px 24px;border-radius:9px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;transition:.2s;cursor:pointer}
.btn-ghost-gray:hover{background:var(--off)}
.btn-full{width:100%;justify-content:center}
.btn-outline-dk{background:transparent;color:var(--navy);border:1.5px solid var(--navy);padding:12px 24px;border-radius:9px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;transition:.2s;cursor:pointer}
.btn-outline-dk:hover{background:var(--navy);color:#fff}

/* ── FOOTER ── */
.footer{background:#070D18;padding:64px 0 0}
.footer-inner{max-width:1200px;margin:auto;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-brand img{height:28px;margin-bottom:16px}
.ft-brand p{font-size:13px;color:rgba(255,255,255,.38);line-height:1.7;max-width:200px}
.ft-col h5{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px}
.ft-col a,.ft-col p{display:block;font-size:13px;color:rgba(255,255,255,.45);margin-bottom:9px;transition:color .2s}
.ft-col a:hover{color:#fff}
.footer-bottom{max-width:1200px;margin:auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.18)}

/* ── RESPONSIVE ── */
/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile First
   Breakpoints:
   · 1200px — Laptop pequeño / pantalla 15"
   · 960px  — Tablet landscape / pantalla pequeña
   · 768px  — Tablet portrait
   · 480px  — Mobile L / phablet
   · 375px  — Mobile M (iPhone)
   · 320px  — Mobile S (mínimo soportado)
══════════════════════════════════════════════════════════════ */

/* ── 1200px: Ajustes para laptops 15" ── */
@media(max-width:1200px){
  .hdr-inner{padding:0 20px}
  .sec{padding:80px 24px}
  .hero-inner{padding:60px 24px;gap:40px}
  .why-inner{gap:48px;padding:0 24px}
  .chart-inner,.testi-inner,.process-inner{padding:0 24px}
  .footer-inner{padding:0 24px;gap:32px}
  .page-hero{padding:60px 24px}
}

/* ── 960px: Tablet landscape ── */
@media(max-width:960px){
  /* Header */
  .hdr-nav{display:none}
  .ham{display:flex}
  #hdr-placeholder{min-height:72px}
  .hdr-inner{height:72px;padding:0 20px}

  /* Hero */
  .hero{min-height:auto;padding-bottom:60px}
  .hero-inner{grid-template-columns:1fr;gap:0;padding:60px 24px 40px;text-align:left}
  .hero-visual{display:none}
  .hero-left{max-width:640px;margin:0 auto;width:100%}
  .hero-p{max-width:100%;font-size:16px}
  .hero-btns{justify-content:flex-start}

  /* Stats */
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:0;padding:0 20px}
  .stat-cell{padding:24px 16px}

  /* Servicios home grid */
  .services-grid{grid-template-columns:repeat(2,1fr)}

  /* Chart / Impacto */
  .chart-grid{grid-template-columns:1fr}
  .chart-right{display:none}
  .chart-left{padding:0}

  /* Why us */
  .why-inner{grid-template-columns:1fr;gap:40px;padding:0 24px}
  .why-cards{grid-template-columns:1fr 1fr}
  .why-right{text-align:center}
  .ring-visual{margin:0 auto}

  /* Process */
  .process-steps{grid-template-columns:repeat(2,1fr);gap:32px}
  .process-steps::before{display:none}
  .ps{text-align:center}
  .ps-num{margin:0 auto 12px}

  /* Testimonios */
  .testi-track{grid-template-columns:1fr}

  /* About (nosotros) */
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-visual{display:none}
  .mv-grid{grid-template-columns:1fr 1fr}

  /* Planes */
  .planes-grid{grid-template-columns:1fr 1fr}
  .plan-card.featured{transform:none}

  /* Footer */
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px;padding:0 20px}

  /* Contacto */
  .contact-layout{grid-template-columns:1fr;gap:40px}

  /* Servicios detail */
  .svc-detail{grid-template-columns:1fr}
  .svc-num{display:none}

  /* Productos */
  .prod-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

  /* Secciones generales */
  .sec{padding:64px 24px}
  .sec-h2{font-size:clamp(24px,4vw,42px)}
  .page-hero{padding:48px 24px}
  .page-hero h1{font-size:clamp(28px,4vw,48px)}
}

/* ── 768px: Tablet portrait ── */
@media(max-width:768px){
  /* Header */
  .hdr-inner{height:64px;padding:0 16px}
  .hdr-logo img{height:44px}

  /* Hero */
  .hero-inner{padding:48px 20px 36px}
  .hero-h1{font-size:clamp(32px,7vw,52px);letter-spacing:-1px}
  .hero-p{font-size:15px}
  .hero-btns{gap:10px}
  .btn-primary,.btn-outline-w{padding:13px 22px;font-size:14px}
  .hero-eyebrow{font-size:10px;padding:7px 16px}

  /* Stats — 2×2 */
  .stat-n{font-size:clamp(28px,6vw,42px)}
  .stat-l{font-size:12px}

  /* Why */
  .why-cards{grid-template-columns:1fr 1fr;gap:12px}
  .why-card{padding:20px 16px}
  .ring-visual{width:200px;height:200px}
  .rv-ring{width:180px;height:180px}
  .rv-ring-2{width:200px;height:200px}
  .rv-center{width:100px;height:100px}

  /* Process */
  .process-steps{grid-template-columns:repeat(2,1fr);gap:24px}

  /* Planes */
  .planes-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .plan-card.featured{transform:none}
  .planes-toggle-wrap{gap:12px;margin-bottom:32px}

  /* Team grid */
  .team-grid{grid-template-columns:1fr 1fr}

  /* Footer */
  .footer-inner{grid-template-columns:1fr 1fr;gap:24px}

  /* Cart panel */
  .cart-panel{width:100%;right:-100%}
  .mo{width:100%;max-height:100vh;border-radius:0;top:0;left:0;transform:none}
  .mo.on{transform:none}

  /* ALV Grid admin */
  .alv-toolbar{flex-direction:column;align-items:stretch}
  .alv-table{font-size:12px}
  .alv-table th,.alv-table td{padding:8px 10px}

  /* Secciones */
  .sec{padding:56px 20px}
  .sec-h2{font-size:clamp(22px,5vw,36px)}
  .sec-sub{font-size:15px}
  .page-hero{padding:40px 20px}
  .page-hero h1{font-size:clamp(26px,5vw,40px)}
  .page-hero p{font-size:15px}

  /* CTA band */
  .cta-band{padding:48px 24px}
  .cta-band h2{font-size:clamp(22px,5vw,36px)}
}

/* ── 480px: Mobile L / Phablets ── */
@media(max-width:480px){
  /* Header */
  #hdr-placeholder{min-height:60px}
  .hdr-inner{padding:0 14px;height:60px}
  .hdr-logo img{height:38px}
  .btn-auth,.cart-btn{width:36px;height:36px}

  /* Hero */
  .hero-inner{padding:40px 16px 32px}
  .hero-h1{font-size:clamp(28px,8vw,44px)}
  .hero-btns{flex-direction:column;gap:10px}
  .hero-btns a{text-align:center;justify-content:center;width:100%}

  /* Stats — 2×2 compact */
  .stats-inner{padding:0}
  .stat-cell{padding:20px 12px}
  .stat-n{font-size:clamp(26px,7vw,38px)}

  /* Servicios home — 1 columna */
  .services-grid{grid-template-columns:1fr}
  .svc-ico{width:48px;height:48px;font-size:20px}

  /* Why — 1 columna */
  .why-inner{grid-template-columns:1fr}
  .why-cards{grid-template-columns:1fr}
  .why-card{padding:18px 14px}
  .ring-visual{margin:24px auto 0}

  /* Process — 1 columna */
  .process-steps{grid-template-columns:1fr;gap:16px}
  .process-steps::before{display:none}
  .ps{text-align:center;padding:20px 16px;background:var(--off);border-radius:12px}
  .ps-num{margin:0 auto 12px;width:44px;height:44px;font-size:16px}

  /* Testimonios — 1 columna */
  .testi-track{grid-template-columns:1fr}
  .tc{padding:20px 16px}
  .tc-text{font-size:14px}

  /* Chart — ocultar donut en móvil, mostrar solo barras */
  .chart-grid{grid-template-columns:1fr}
  .chart-right{display:none}

  /* Planes — 1 columna */
  .planes-grid{grid-template-columns:1fr;max-width:100%}
  .plan-card{padding:24px 18px}
  .plan-card.featured{transform:none}
  .plan-price .amount{font-size:34px}

  /* Nosotros about */
  .about-grid{grid-template-columns:1fr}
  .about-visual{display:none}
  .about-badge{width:90px;height:90px;right:-10px;bottom:-10px}
  .about-badge b{font-size:18px}
  .about-badge small{font-size:8px}

  /* Misión/Visión — 1 columna */
  .mv-grid{grid-template-columns:1fr}

  /* Team — 1 columna */
  .team-grid{grid-template-columns:1fr}
  .team-c{padding:24px 16px}

  /* Historia */
  .tl-item{gap:12px}
  .tl-dot{width:36px;height:36px;font-size:11px;flex-shrink:0}

  /* Footer — 1 columna */
  .footer-inner{grid-template-columns:1fr;gap:24px}
  .ft-col{padding:0}

  /* Secciones */
  .sec{padding:48px 16px}
  .sec-h2{font-size:clamp(20px,6vw,32px)}
  .sec-tag{font-size:10px}
  .page-hero{padding:36px 16px}
  .page-hero h1{font-size:clamp(22px,6vw,34px)}

  /* CTA */
  .cta-band{padding:40px 16px}
  .cta-band h2{font-size:clamp(20px,5vw,30px)}
  .btn-white{padding:14px 24px;font-size:14px;width:100%;justify-content:center}

  /* Contacto */
  .contact-layout{grid-template-columns:1fr}
  .c-items{gap:12px}
  .c-item{flex-direction:row;align-items:flex-start}
  .c-ico{width:36px;height:36px;font-size:16px;flex-shrink:0}

  /* Carrito modal */
  .mo-inner{padding:16px}
  .mo{width:100%;max-height:95vh}

  /* Filtros productos — wrap */
  .filter-wrap{gap:8px;flex-wrap:wrap}
  .f-btn{padding:8px 14px;font-size:12px}

  /* Prod cards — 1 columna en móvil pequeño */
  .prod-grid{grid-template-columns:1fr;gap:12px}
  .prod{border-radius:10px}
  .prod-img{height:160px}
  .prod-body{padding:12px}
  .prod-name{font-size:14px}
  .prod-price{font-size:16px}

  /* Formulario contacto */
  .cf-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* ── 375px: Mobile M ── */
@media(max-width:375px){
  .hdr-inner{padding:0 12px}
  .hdr-logo img{height:34px}
  .hero-inner{padding:36px 14px 28px}
  .hero-h1{font-size:clamp(26px,8vw,36px);letter-spacing:-.5px}
  .hero-eyebrow{font-size:9px;padding:6px 12px}
  .hero-btns{flex-direction:column}
  .hero-btns a{width:100%;justify-content:center;text-align:center}
  .sec{padding:40px 14px}
  .sec-h2{font-size:clamp(19px,6vw,28px)}
  /* Forzar 1 columna en todo */
  .prod-grid,.services-grid,.why-cards,.testi-track,
  .planes-grid,.team-grid,.mv-grid,.footer-inner,
  .process-steps,.chart-grid,.contact-layout,
  .about-grid,.cf-grid{grid-template-columns:1fr !important}
  .stat-n{font-size:28px}
  .stat-l{font-size:11px}
  .footer-inner{gap:20px}
  .chart-right,.about-visual{display:none}
  .plan-card.featured{transform:none}
}

/* ── 320px: Mobile S ── */
@media(max-width:320px){
  .hdr-inner{padding:0 10px;height:56px}
  .hero-inner{padding:30px 12px 24px}
  .hero-h1{font-size:24px}
  .sec{padding:36px 12px}
  .btn-primary,.btn-outline-w,.btn-white{padding:11px 16px;font-size:13px}
  .stat-cell{padding:16px 8px}
  .stat-n{font-size:24px}
  .plan-card{padding:20px 14px}
}

/* ── 1400px+: Pantallas grandes 18"-24" ── */
@media(min-width:1400px){
  .sec,.footer-inner,.chart-inner,.testi-inner,.process-inner{max-width:1320px}
  .hdr-inner{max-width:1320px;padding:0 40px}
  .hero-inner{max-width:1320px;padding:100px 40px}
  .page-hero{padding:100px 40px}
  .page-hero-inner{max-width:1320px}
  .hero-h1{font-size:clamp(56px,4vw,80px)}
  .services-grid{grid-template-columns:repeat(3,1fr);gap:28px}
  .testi-track{grid-template-columns:repeat(3,1fr);gap:32px}
  .prod-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
  .footer-inner{gap:60px}
}

/* ── 1920px+: Pantallas 24" ── */
@media(min-width:1920px){
  .sec,.footer-inner,.chart-inner,.testi-inner,.process-inner{max-width:1440px}
  .hdr-inner{max-width:1440px;padding:0 48px}
  .hero-inner{max-width:1440px;padding:120px 48px}
  .page-hero-inner{max-width:1440px}
  .hero-h1{font-size:clamp(64px,4vw,88px)}
  body{font-size:17px}
}

/* ══════════════════════════════════════════
   AUTH — Login Google · User Menu · Orders
══════════════════════════════════════════ */

/* Botón de auth en el header */
.btn-auth {
  width:42px; height:42px; border-radius:10px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.12);
  color:#fff; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s; flex-shrink:0;
}
.btn-auth:hover { background:rgba(255,255,255,.2); }
.btn-auth img   { width:30px; height:30px; border-radius:50%; object-fit:cover; }

/* Saludo en header (visible solo en desktop) */
.auth-greeting {
  font-size:13px; font-weight:600; color:rgba(255,255,255,.8);
  white-space:nowrap;
}

/* Menú desplegable de usuario */
.user-menu-drop {
  position:fixed; z-index:1000;
  background:#fff; border-radius:14px;
  box-shadow:0 8px 40px rgba(0,0,0,.18);
  border:1px solid var(--border);
  min-width:240px; overflow:hidden;
  animation:dropIn .15s ease;
}
@keyframes dropIn {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0); }
}
.um-header {
  display:flex; align-items:center; gap:12px;
  padding:18px 20px;
  background:var(--off);
  border-bottom:1px solid var(--border);
}
.um-avatar {
  width:44px; height:44px; border-radius:50%;
  object-fit:cover; border:2px solid var(--border);
  flex-shrink:0;
}
.um-name  { font-size:14px; font-weight:700; color:var(--text); margin-bottom:2px; }
.um-email { font-size:12px; color:var(--muted); }
.um-divider { height:1px; background:var(--border); }
.um-item {
  display:flex; align-items:center; gap:10px;
  width:100%; padding:13px 20px;
  background:none; border:none;
  font-size:14px; font-weight:500; color:var(--text);
  cursor:pointer; transition:background .15s; text-align:left;
}
.um-item:hover { background:var(--off); }
.um-item-danger { color:var(--red,#DC2626); }
.um-item-danger:hover { background:#FEF2F2; }

/* Modal Mis Pedidos */
.orders-modal-bg {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:900;
  align-items:center; justify-content:center;
}
.orders-modal {
  background:#fff; border-radius:18px;
  width:90%; max-width:600px; max-height:80vh;
  display:flex; flex-direction:column;
  box-shadow:0 24px 80px rgba(0,0,0,.25);
  overflow:hidden;
}
.orders-modal-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; background:var(--navy); color:#fff; flex-shrink:0;
}
.orders-modal-hd h3 { font-size:17px; font-weight:700; }
.orders-modal-hd button { background:none; border:none; color:rgba(255,255,255,.6); font-size:20px; cursor:pointer; }
.orders-modal-body { overflow-y:auto; padding:20px 24px; flex:1; }
.orders-loading { text-align:center; padding:40px; color:var(--muted); font-size:15px; }
.orders-empty   { text-align:center; padding:48px 20px; color:var(--muted); }

.order-row {
  background:var(--off); border:1px solid var(--border);
  border-radius:12px; padding:16px 18px; margin-bottom:12px;
  transition:box-shadow .2s;
}
.order-row:hover { box-shadow:var(--shadow); }
.order-row-top {
  display:flex; align-items:center; gap:10px; margin-bottom:8px;
}
.order-row-id   { font-family:'Montserrat',sans-serif; font-weight:700; font-size:13px; color:var(--navy); }
.order-row-date { font-size:12px; color:var(--muted); margin-left:auto; }
.order-row-items { font-size:13px; color:var(--muted); margin-bottom:8px; line-height:1.5; }
.order-row-items span { display:inline-block; margin-right:4px; }
.order-row-total { font-family:'Montserrat',sans-serif; font-weight:800; font-size:17px; color:var(--navy); }
.badge-pp { background:rgba(24,95,165,.1); color:var(--blue); padding:2px 10px; border-radius:10px; font-size:11px; font-weight:700; }
.badge-tr { background:rgba(58,155,111,.1); color:var(--green-dk); padding:2px 10px; border-radius:10px; font-size:11px; font-weight:700; }

/* Banner login en carrito (si no está logueado) */
.cart-login-banner {
  background:var(--off); border:1px solid var(--border);
  border-radius:10px; padding:14px 16px; margin-bottom:14px;
  text-align:center;
}
.cart-login-banner p { font-size:13px; color:var(--muted); margin-bottom:10px; }
.btn-google {
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; border:1.5px solid var(--border);
  padding:9px 18px; border-radius:8px;
  font-size:13px; font-weight:600; color:var(--text);
  cursor:pointer; transition:.2s;
}
.btn-google:hover { border-color:var(--blue); background:#F8FAFF; }
.btn-google img { width:18px; height:18px; }

/* Panel Admin — pedidos Firestore */
.order-card-user {
  display:flex; align-items:center; gap:8px; margin-top:6px;
}
.order-card-user img {
  width:20px; height:20px; border-radius:50%; object-fit:cover;
}
.order-card-user span { font-size:12px; color:var(--muted); }

/* ══════════════════════════════════════════
   ORDER TRACKING — Timeline estilo Amazon
   Usado en: modal usuario + panel admin
══════════════════════════════════════════ */

/* ── Status badges ── */
.status-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 12px; border-radius:20px;
  font-size:11px; font-weight:700; letter-spacing:.3px;
  white-space:nowrap;
}
.status-confirmado  { background:#EFF6FF; color:#185FA5; border:1px solid #BFDBFE; }
.status-preparando  { background:#F5F3FF; color:#7C3AED; border:1px solid #DDD6FE; }
.status-enviado     { background:#FFFBEB; color:#D97706; border:1px solid #FDE68A; }
.status-en_transito { background:#EFF6FF; color:#2176C7; border:1px solid #BAE6FD; }
.status-entregado   { background:#F0FDF4; color:#15803D; border:1px solid #BBF7D0; }
.status-cancelado   { background:#FEF2F2; color:#DC2626; border:1px solid #FECACA; }

/* ── Timeline horizontal (modal usuario) ── */
.track-timeline {
  display:flex; align-items:flex-start;
  gap:0; margin:24px 0 8px; position:relative;
}
.track-step {
  flex:1; display:flex; flex-direction:column; align-items:center;
  position:relative; gap:8px;
}
/* Connector line between steps */
.track-step:not(:last-child)::after {
  content:''; position:absolute;
  top:16px; left:50%; width:100%; height:2px;
  background:var(--border); z-index:0;
  transition:background .4s;
}
.track-step.done:not(:last-child)::after { background:var(--green); }
.track-step.active:not(:last-child)::after { background:var(--border); }

.track-dot {
  width:32px; height:32px; border-radius:50%;
  background:#fff; border:2px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; z-index:1; position:relative;
  transition:all .3s;
}
.track-step.done   .track-dot { background:var(--green);   border-color:var(--green);   }
.track-step.active .track-dot { background:var(--navy);    border-color:var(--navy);    box-shadow:0 0 0 4px rgba(12,68,120,.15); }
.track-step.done   .track-dot .track-ico { filter:brightness(0) invert(1); }
.track-step.active .track-dot .track-ico { filter:brightness(0) invert(1); }

.track-ico { font-size:13px; line-height:1; }
.track-label {
  font-size:10px; font-weight:600; color:var(--muted);
  text-align:center; line-height:1.3; max-width:64px;
}
.track-step.done   .track-label { color:var(--green-dk); }
.track-step.active .track-label { color:var(--navy); font-weight:700; }

/* Cancelled state */
.track-cancelled {
  text-align:center; padding:20px;
  background:#FEF2F2; border-radius:10px; margin:16px 0;
  border:1px solid #FECACA;
}
.track-cancelled-icon { font-size:36px; margin-bottom:8px; }
.track-cancelled p { font-size:14px; color:#DC2626; font-weight:600; }

/* Tracking number display */
.track-number {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--off); border:1px solid var(--border);
  border-radius:8px; padding:8px 14px; margin-top:12px;
  font-size:13px; color:var(--muted);
}
.track-number strong { color:var(--text); font-family:monospace; }

/* Status history log */
.status-log { margin-top:16px; }
.status-log-item {
  display:flex; gap:12px; padding:10px 0;
  border-bottom:1px solid var(--off);
  font-size:13px;
}
.status-log-item:last-child { border-bottom:none; }
.status-log-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--green); margin-top:4px; flex-shrink:0;
}
.status-log-date { color:var(--muted); font-size:11px; margin-top:2px; }

/* ══════════════════════════════════════════
   PANEL VENTAS (admin)
══════════════════════════════════════════ */
.ventas-filters {
  display:flex; gap:8px; flex-wrap:wrap;
  margin-bottom:20px;
}
.vf-btn {
  padding:6px 16px; border-radius:20px;
  border:1.5px solid var(--border); background:#fff;
  font-size:12px; font-weight:600; color:var(--muted);
  cursor:pointer; transition:.2s; display:flex; align-items:center; gap:5px;
}
.vf-btn:hover { border-color:var(--blue); color:var(--blue); }
.vf-btn.on    { background:var(--navy); border-color:var(--navy); color:#fff; }

.ventas-kpis {
  display:grid; grid-template-columns:repeat(5,1fr); gap:12px;
  margin-bottom:24px;
}
.vk { background:#fff; border:1px solid var(--border); border-radius:10px; padding:14px 16px; }
.vk-val { font-family:'Montserrat',sans-serif; font-size:22px; font-weight:800; color:var(--navy); }
.vk-lbl { font-size:11px; color:var(--muted); margin-top:3px; }
.vk.accent { background:var(--navy); }
.vk.accent .vk-val, .vk.accent .vk-lbl { color:#fff; }
.vk.accent .vk-lbl { color:rgba(255,255,255,.6); }

.venta-card {
  background:#fff; border:1px solid var(--border);
  border-radius:12px; overflow:hidden;
  margin-bottom:12px; transition:box-shadow .2s;
}
.venta-card:hover { box-shadow:var(--shadow-lg); }
.venta-card-hd {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--border);
  background:var(--off);
}
.vc-id   { font-family:'Montserrat',sans-serif; font-weight:800; font-size:14px; color:var(--navy); }
.vc-date { font-size:12px; color:var(--muted); }
.vc-total{ font-family:'Montserrat',sans-serif; font-weight:800; font-size:16px;
           color:var(--navy); margin-left:auto; }
.venta-card-body { padding:14px 18px; display:flex; gap:20px; flex-wrap:wrap; align-items:flex-start; }
.vc-info { flex:1; min-width:200px; }
.vc-name  { font-size:14px; font-weight:600; color:var(--text); margin-bottom:2px; }
.vc-email { font-size:12px; color:var(--muted); margin-bottom:6px; }
.vc-items { font-size:13px; color:var(--muted); }
.vc-status-col { display:flex; flex-direction:column; align-items:flex-end; gap:10px; min-width:200px; }
.vc-status-select {
  padding:8px 12px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff;
  font-size:13px; font-weight:600; color:var(--text);
  cursor:pointer; min-width:180px;
  transition:border-color .2s;
}
.vc-status-select:focus { outline:none; border-color:var(--blue); }
.vc-track-input {
  padding:8px 12px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff;
  font-size:13px; color:var(--text); width:100%;
  transition:border-color .2s;
}
.vc-track-input:focus { outline:none; border-color:var(--blue); }
.vc-note-input {
  padding:8px 12px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff;
  font-size:13px; color:var(--text); width:100%; resize:vertical;
  transition:border-color .2s;
}
.vc-note-input:focus { outline:none; border-color:var(--blue); }
.btn-update-status {
  background:var(--navy); color:#fff; border:none;
  padding:9px 18px; border-radius:8px;
  font-family:'Montserrat',sans-serif; font-size:13px; font-weight:700;
  cursor:pointer; transition:background .2s;
  display:flex; align-items:center; gap:6px;
}
.btn-update-status:hover { background:var(--blue); }

/* Timeline vertical en card de venta */
.vc-timeline { margin-top:12px; }
.vct-item {
  display:flex; gap:10px; font-size:12px; color:var(--muted);
  padding:6px 0; border-left:2px solid var(--border);
  padding-left:12px; margin-left:3px; position:relative;
}
.vct-item::before {
  content:''; position:absolute; left:-5px; top:10px;
  width:8px; height:8px; border-radius:50%;
  background:var(--border);
}
.vct-item.latest { color:var(--text); border-color:var(--green); }
.vct-item.latest::before { background:var(--green); }
.vct-date { color:var(--muted-lt); min-width:80px; }
.vct-label { font-weight:600; }
.vct-note { color:var(--muted); margin-top:1px; }

/* Empty ventas */
.ventas-empty {
  text-align:center; padding:80px 20px;
  background:#fff; border:1px solid var(--border); border-radius:12px;
}
.ventas-empty div { font-size:48px; margin-bottom:16px; }
.ventas-empty h3  { font-size:18px; font-weight:700; color:var(--text); margin-bottom:8px; }
.ventas-empty p   { font-size:14px; color:var(--muted); }

/* Status modal (cambio de estado) */
.status-modal-bg {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:800;
  align-items:center; justify-content:center;
}
.status-modal-bg.on { display:flex; }
.status-modal {
  background:#fff; border-radius:16px;
  width:90%; max-width:460px;
  box-shadow:0 24px 80px rgba(0,0,0,.22);
  overflow:hidden;
}
.status-modal-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 22px; background:var(--navy); color:#fff;
}
.status-modal-hd h3 { font-size:16px; font-weight:700; }
.status-modal-hd button { background:none; border:none; color:rgba(255,255,255,.6); font-size:20px; cursor:pointer; }
.status-modal-body { padding:22px; }

@media(max-width:768px){
  .ventas-kpis { grid-template-columns:repeat(2,1fr); }
  .venta-card-body { flex-direction:column; }
  .vc-status-col { align-items:stretch; min-width:auto; }
}

/* ══════════════════════════════════════════
   ACCESIBILIDAD & PREFERENCIAS DE SISTEMA
══════════════════════════════════════════ */

/* Reduced motion — usuarios con sensibilidad al movimiento */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  .hero-glow { animation: none !important; }
  .rv-ring, .rv-ring-2 { animation: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
}

/* Dark mode — respeta la preferencia del sistema */

/* Focus visible — navegación por teclado */
:focus-visible {
  outline: 2px solid var(--blue);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ══════════════════════════════════════════
   ALV GRID — Tabla tipo SAP para Pedidos/Ventas
══════════════════════════════════════════ */
.alv-toolbar {
  display:flex; flex-wrap:wrap; gap:10px; align-items:center;
  margin-bottom:16px; padding:14px 16px;
  background:var(--off); border:1px solid var(--border); border-radius:10px;
}
.alv-toolbar .alv-search {
  flex:1; min-width:180px;
  padding:8px 12px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff;
  font-size:13px; color:var(--text);
}
.alv-toolbar .alv-search:focus { outline:none; border-color:var(--blue); }
.alv-toolbar select, .alv-toolbar input[type="date"] {
  padding:8px 12px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff;
  font-size:13px; color:var(--text); cursor:pointer;
}
.alv-toolbar select:focus, .alv-toolbar input[type="date"]:focus { outline:none; border-color:var(--blue); }
.alv-toolbar label {
  font-size:11px; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.4px;
  display:flex; flex-direction:column; gap:4px;
}
.alv-toolbar .alv-group { display:flex; flex-direction:column; gap:4px; }
.btn-export {
  background:var(--green); color:#fff; border:none;
  padding:9px 16px; border-radius:8px;
  font-family:'Montserrat',sans-serif; font-size:13px; font-weight:700;
  cursor:pointer; transition:background .2s;
  display:flex; align-items:center; gap:6px; white-space:nowrap;
}
.btn-export:hover { background:var(--green-dk); }
.alv-clear {
  background:transparent; border:1.5px solid var(--border);
  color:var(--muted); padding:8px 14px; border-radius:8px;
  font-size:12px; font-weight:600; cursor:pointer; transition:.2s;
}
.alv-clear:hover { border-color:var(--red,#DC2626); color:var(--red,#DC2626); }

/* Grid wrapper */
.alv-wrap {
  background:#fff; border:1px solid var(--border); border-radius:12px;
  overflow:hidden; overflow-x:auto;
}
.alv-table { width:100%; border-collapse:collapse; font-size:13px; min-width:760px; }
.alv-table thead th {
  background:var(--navy); color:#fff;
  padding:11px 14px; text-align:left; font-weight:700;
  font-size:11px; text-transform:uppercase; letter-spacing:.4px;
  white-space:nowrap; position:sticky; top:0; z-index:2;
  cursor:pointer; user-select:none; transition:background .15s;
}
.alv-table thead th:hover { background:var(--blue); }
.alv-table thead th .sort-ico { font-size:9px; opacity:.6; margin-left:4px; }
.alv-table thead th.sorted .sort-ico { opacity:1; }
.alv-table tbody tr {
  border-bottom:1px solid var(--off);
  transition:background .12s;
}
.alv-table tbody tr:hover { background:var(--off); }
.alv-table tbody tr:nth-child(even) { background:rgba(0,0,0,.012); }
.alv-table tbody tr:nth-child(even):hover { background:var(--off); }
.alv-table td {
  padding:10px 14px; vertical-align:middle;
  white-space:nowrap; color:var(--text);
}
.alv-table td.wrap { white-space:normal; max-width:240px; }
.alv-table td.num  { text-align:right; font-family:'Montserrat',sans-serif; font-weight:700; }
.alv-table td.center { text-align:center; }
.alv-table tfoot td {
  padding:12px 14px; font-weight:800; background:var(--off);
  border-top:2px solid var(--border); font-family:'Montserrat',sans-serif;
}

/* Status select inline en grid */
.alv-status-select {
  padding:5px 10px; border-radius:6px;
  border:1.5px solid var(--border); background:#fff;
  font-size:12px; font-weight:600; cursor:pointer; color:var(--text);
}
.alv-track-input {
  padding:5px 8px; border-radius:6px; border:1.5px solid var(--border);
  background:#fff; font-size:12px; width:110px; color:var(--text);
}
.alv-row-actions { display:flex; gap:6px; }
.alv-icon-btn {
  width:28px; height:28px; border-radius:6px;
  border:1px solid var(--border); background:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:.15s; font-size:13px;
}
.alv-icon-btn:hover { border-color:var(--blue); background:var(--off); }
.alv-icon-btn.danger:hover { border-color:var(--red,#DC2626); color:var(--red,#DC2626); }

/* Pagination */
.alv-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; font-size:12px; color:var(--muted);
  border-top:1px solid var(--border); background:var(--off);
  flex-wrap:wrap; gap:10px;
}
.alv-pager { display:flex; gap:6px; align-items:center; }
.alv-pager button {
  width:30px; height:30px; border-radius:6px;
  border:1px solid var(--border); background:#fff;
  cursor:pointer; font-size:12px; font-weight:600; color:var(--text);
  transition:.15s;
}
.alv-pager button:hover:not(:disabled) { border-color:var(--blue); color:var(--blue); }
.alv-pager button:disabled { opacity:.35; cursor:default; }
.alv-pager button.on { background:var(--navy); color:#fff; border-color:var(--navy); }

/* Empty state */
.alv-empty { text-align:center; padding:60px 20px; color:var(--muted); }
.alv-empty div { font-size:40px; margin-bottom:12px; }

/* Toggle table/card view */
.alv-view-toggle { display:flex; gap:4px; background:var(--off); border-radius:8px; padding:3px; }
.alv-view-toggle button {
  padding:6px 12px; border:none; background:transparent; border-radius:6px;
  font-size:12px; font-weight:600; color:var(--muted); cursor:pointer; transition:.15s;
}
.alv-view-toggle button.on { background:#fff; color:var(--navy); box-shadow:var(--shadow); }

@media(max-width:768px){
  .alv-toolbar { flex-direction:column; align-items:stretch; }
  .alv-toolbar .alv-search { min-width:0; }
}

/* ── PLANES (PRICING) ── */
.planes-toggle-wrap{display:flex;align-items:center;justify-content:center;gap:16px;margin:40px auto 48px}
.planes-toggle-wrap .toggle-label{font-size:14px;font-weight:600;color:var(--muted);transition:color .2s;cursor:pointer}
.planes-toggle-wrap .toggle-label.active{color:var(--navy)}
.planes-save-badge{display:inline-block;margin-left:6px;background:rgba(58,155,111,.14);color:var(--green-dk);font-size:11px;font-weight:700;padding:2px 9px;border-radius:10px}
.planes-toggle-switch{width:54px;height:30px;border-radius:30px;background:var(--border);position:relative;cursor:pointer;transition:background .25s;flex-shrink:0}
.planes-toggle-switch.on{background:var(--green)}
.planes-toggle-knob{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform .25s}
.planes-toggle-switch.on .planes-toggle-knob{transform:translateX(24px)}

.planes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.plan-card{background:#fff;border:1.5px solid var(--border);border-radius:18px;padding:36px 28px;text-align:center;position:relative;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s}
.plan-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.plan-card.featured{border-color:var(--green);background:linear-gradient(180deg,#fff 0%,#F2FBF7 100%);transform:scale(1.03);box-shadow:0 16px 48px rgba(58,155,111,.18)}
.plan-card.featured:hover{transform:scale(1.03) translateY(-6px)}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;padding:5px 16px;border-radius:20px;text-transform:uppercase;box-shadow:0 4px 14px rgba(58,155,111,.35);white-space:nowrap}
.plan-price{font-family:'Montserrat',sans-serif;margin-bottom:4px}
.plan-price .amount{font-size:42px;font-weight:900;color:var(--navy)}
.plan-price .period{font-size:14px;color:var(--muted);font-weight:600}
.plan-note{font-size:12px;color:var(--green-dk);font-weight:600;min-height:18px;margin-bottom:8px}
.plan-card h5{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;color:var(--navy);margin:6px 0 18px}
.plan-divider{height:1px;background:var(--border);margin-bottom:20px}
.plan-features{list-style:none;text-align:left;display:flex;flex-direction:column;gap:12px;margin-bottom:28px;flex:1}
.plan-features li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--text);line-height:1.4}
.plan-features li::before{content:'✓';color:var(--green);font-weight:800;flex-shrink:0;width:18px;height:18px;border-radius:50%;background:rgba(58,155,111,.12);display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:1px}
.plan-card .btn-plan{margin-top:auto}

@media(max-width:960px){
  .planes-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}
  .plan-card.featured{transform:none}
  .plan-card.featured:hover{transform:translateY(-6px)}
}
