:root{
  --dark:#061421;--blue:#1c8dd6;--cyan:#24c7ec;--cyan-deep:#1c8dd6;--cyan-soft:#c7f1fb;
  --orange:#ff7a1a;--green:#8bc53f;--red:#ee5d62;--coral:#ee5d62;--coral-deep:#d43f48;
  --text:#11293a;--muted:#64798a;--soft:#f4f8fb;
  --ink:#050d18;--ink-2:#0a1929;--ink-3:#122740;--paper:#f4f8fb;
  --r-sm:14px;--r-md:22px;--r-lg:32px;--r-xl:44px;
  --t:.32s;--ease:cubic-bezier(.22,.61,.36,1);--ease-out:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Sora','Inter',system-ui,sans-serif;
  background:var(--paper);color:var(--text);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;font-size:15.5px;line-height:1.55;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;
  opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.serif{font-family:'Instrument Serif',serif;font-weight:400;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.scrollbar{position:fixed;top:0;left:0;height:3px;border-radius:0 99px 99px 0;background:linear-gradient(90deg,var(--cyan),var(--green) 40%,var(--orange) 75%,var(--coral));z-index:300;width:0;box-shadow:0 0 14px rgba(36,199,236,.6)}

/* ── NAV ── */
.nav{
  position:fixed;top:14px;left:50%;transform:translateX(-50%);
  width:min(1280px,94%);
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:10px 12px 10px 22px;
  border-radius:99px;
  background:rgba(6,14,26,.82);
  backdrop-filter:blur(24px) saturate(1.3);
  -webkit-backdrop-filter:blur(24px) saturate(1.3);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 50px -10px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06);
  z-index:80;
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:48px;max-width:200px;object-fit:contain;transition:transform var(--t);filter:brightness(1.15) drop-shadow(0 0 12px rgba(36,199,236,.3))}
.brand:hover img{transform:rotate(-8deg) scale(1.05)}
.navlinks{display:flex;gap:4px}
.navlinks a{
  position:relative;padding:10px 16px;border-radius:99px;
  font-weight:600;font-size:13.5px;color:rgba(255,255,255,.65);
  transition:color var(--t),background var(--t);
}
.navlinks a:hover{color:#fff;background:rgba(255,255,255,.08)}
.navlinks a::after{
  content:"";position:absolute;left:50%;bottom:4px;width:0;height:2px;
  background:var(--cyan);transform:translateX(-50%);
  transition:width var(--t) var(--ease-out);
}
.navlinks a:hover::after{width:14px}
.navbtn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;border-radius:99px;
  background:linear-gradient(135deg,var(--green),var(--cyan));
  color:#fff!important;font-weight:700;font-size:13.5px;
  box-shadow:0 8px 22px rgba(36,199,236,.35),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform var(--t),box-shadow var(--t);
}
.navbtn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(36,199,236,.45)}
.navbtn-wa{
  background:linear-gradient(135deg,#25d366,#128c7e);
  box-shadow:0 8px 22px rgba(37,211,102,.35),inset 0 1px 0 rgba(255,255,255,.25);
}
.navbtn-wa:hover{box-shadow:0 14px 30px rgba(37,211,102,.5);transform:translateY(-2px)}

/* ── HERO ── */
.hero{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:center;position:relative;overflow:hidden;
  padding:130px 5% 70px;color:white;isolation:isolate;
}
.heroBg{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(80% 60% at 20% 20%,rgba(28,141,214,.45),transparent 60%),
    radial-gradient(60% 50% at 90% 80%,rgba(238,93,98,.35),transparent 65%),
    linear-gradient(100deg,rgba(4,12,24,.92) 0%,rgba(4,12,24,.75) 45%,rgba(4,12,24,.45) 100%),
    url('assets/fondo.png') center/cover no-repeat;
}
.heroBg::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);
}
/* orbs */
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:-1;pointer-events:none}
.orb.o1{width:520px;height:520px;background:var(--cyan);top:-160px;right:-100px;animation:orbit1 22s ease-in-out infinite}
.orb.o2{width:380px;height:380px;background:var(--coral);bottom:-120px;left:-80px;animation:orbit2 26s ease-in-out infinite}
.orb.o3{width:280px;height:280px;background:var(--green);top:40%;left:40%;animation:orbit3 30s ease-in-out infinite}
@keyframes orbit1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-60px,80px) scale(1.15)}}
@keyframes orbit2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(80px,-60px) scale(.9)}}
@keyframes orbit3{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-100px,60px) scale(1.1)}66%{transform:translate(80px,-40px) scale(.95)}}

.heroContent{position:relative;z-index:2;max-width:680px}
h1{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(3.2rem,7vw,7rem);line-height:.92;letter-spacing:-.02em;
  margin:24px 0 22px;
}
h1 em{font-style:italic;color:var(--cyan);position:relative}
h1 .underline{position:relative;display:inline-block}
h1 .underline svg{position:absolute;left:0;bottom:-12px;width:100%;height:18px;overflow:visible}
.hero p.lead{font-size:1.1rem;line-height:1.65;color:#dcecf5;max-width:560px;margin:0 0 32px}
.actions{display:flex;flex-wrap:wrap;gap:14px;margin:0 0 44px;align-items:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:54px;padding:0 24px;border-radius:99px;
  font-weight:700;font-size:14px;letter-spacing:.01em;border:0;cursor:pointer;
  transition:transform var(--t) var(--ease-out),box-shadow var(--t),background var(--t);
  position:relative;overflow:hidden;
}
.primary{
  background:linear-gradient(135deg,var(--orange),var(--coral));
  color:#fff;
  box-shadow:0 14px 30px -8px rgba(238,93,98,.5),inset 0 1px 0 rgba(255,255,255,.3);
}
.primary:hover{transform:translateY(-2px);box-shadow:0 22px 40px -8px rgba(238,93,98,.6)}
.primary::after{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  transition:left .8s var(--ease);
}
.primary:hover::after{left:100%}
.glass{
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  color:#fff;backdrop-filter:blur(14px);
}
.glass:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.play-link{
  display:inline-flex;align-items:center;gap:12px;
  color:#fff;font-size:13px;font-weight:500;margin-left:8px;text-decoration:none;
}
.play-circle{
  width:42px;height:42px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.4);
  display:grid;place-items:center;
  transition:all var(--t);
}
.play-link:hover .play-circle{background:#fff;color:var(--ink);border-color:#fff;transform:scale(1.05)}
.heroStats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:680px;
  padding-top:32px;border-top:1px solid rgba(255,255,255,.12);
}
.heroStats div{padding:0 6px}
.heroStats b{
  display:flex;align-items:flex-start;gap:2px;
  font-family:'Instrument Serif',serif;font-size:2rem;line-height:1;
  letter-spacing:-.02em;color:#fff;
}
.heroStats sup{font-size:.95rem;color:var(--cyan);font-family:'Sora',sans-serif;font-weight:600;margin-top:4px}
.heroStats span{
  display:block;font-size:11px;color:#9bb6c8;
  text-transform:uppercase;letter-spacing:.16em;font-weight:500;margin-top:8px;
}

/* ── HERO TRACKING CARD ── */
.heroTrackCard{position:relative;z-index:2;background:rgba(8,20,34,.78);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,.11);border-radius:28px;padding:30px;color:white}
.heroTrackCardHdr{font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.45);margin-bottom:16px}
.heroTrackSearch{margin-bottom:24px}
.heroTrackSearch input{width:100%;height:52px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:14px;color:white;padding:0 18px;font-size:.93rem;outline:none;transition:border-color .2s}
.heroTrackSearch input::placeholder{color:rgba(255,255,255,.32)}
.heroTrackSearch input:focus{border-color:var(--orange);background:rgba(255,255,255,.11)}

/* Timeline */
.htlWrap{display:flex;flex-direction:column;gap:0;margin-bottom:22px}
.htlItem{display:flex;align-items:flex-start;gap:14px}
.htlLeft{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:16px}
.htlDot{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:4px}
.htlOrange{background:var(--orange);box-shadow:0 0 14px rgba(255,122,26,.55)}
.htlGreen{background:var(--green);box-shadow:0 0 12px rgba(139,197,63,.45)}
.htlBlue{background:var(--cyan);box-shadow:0 0 12px rgba(36,199,236,.45)}
.htlLine{width:2px;flex:1;min-height:28px;background:rgba(255,255,255,.1);margin:4px 0}
.htlInfo{padding-bottom:20px}
.htlLabel{display:block;font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.42)}
.htlVal{display:block;font-size:.97rem;font-weight:800;color:white;margin-top:3px}
.htlItem:last-child .htlInfo{padding-bottom:0}
.heroRastrearBtn{
  width:100%;height:50px;background:transparent;border:1px solid rgba(255,255,255,.18);
  border-radius:14px;color:white;font-weight:800;cursor:pointer;
  letter-spacing:.08em;font-size:.82rem;transition:all .25s;
  text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:6px;
  position:relative;z-index:2;overflow:hidden;
}
.heroRastrearBtn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(36,199,236,.12),transparent);
  transform:translateX(-100%);transition:transform .6s var(--ease);
}
.heroRastrearBtn:hover{background:rgba(36,199,236,.08);border-color:rgba(36,199,236,.4);box-shadow:0 0 20px rgba(36,199,236,.12)}
.heroRastrearBtn:hover::before{transform:translateX(100%)}

/* ══════════════════════════════════════════
   PREMIUM TRACKING — VISUAL UPGRADE
══════════════════════════════════════════ */

/* Card base */
.heroTrackCard{overflow:hidden}

/* HUD grid */
.htcHudGrid{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(36,199,236,.032) 1px,transparent 1px),
    linear-gradient(90deg,rgba(36,199,236,.032) 1px,transparent 1px);
  background-size:30px 30px;
  mask-image:radial-gradient(ellipse 75% 65% at 80% 20%,black,transparent);
  -webkit-mask-image:radial-gradient(ellipse 75% 65% at 80% 20%,black,transparent);
}

/* Scan line */
.htcScanLine{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(36,199,236,.5),transparent);
  animation:htcScan 4.5s ease-in-out infinite;z-index:1;pointer-events:none;
}
@keyframes htcScan{
  0%  {top:2%;opacity:0}8%{opacity:.85}92%{opacity:.3}100%{top:98%;opacity:0}
}

/* Radar corner */
.htcRadarWrap{
  position:absolute;bottom:-72px;right:-72px;
  width:220px;height:220px;pointer-events:none;z-index:0;
}
.htcRadarRing{
  position:absolute;top:50%;left:50%;border-radius:50%;
  border:1px solid rgba(36,199,236,.22);
  animation:htcRingPulse 3.8s ease-out infinite;
  transform:translate(-50%,-50%) scale(0);
}
.htcRr1{width:56px;height:56px}
.htcRr2{width:108px;height:108px;animation-delay:.95s}
.htcRr3{width:162px;height:162px;animation-delay:1.9s}
@keyframes htcRingPulse{
  0%  {transform:translate(-50%,-50%) scale(.15);opacity:.9}
  100%{transform:translate(-50%,-50%) scale(1);opacity:0}
}
.htcRadarSweep{
  position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg at 50% 50%,transparent 78%,rgba(36,199,236,.2) 100%);
  animation:htcRadarRotate 3.2s linear infinite;
}
@keyframes htcRadarRotate{to{transform:rotate(360deg)}}
.htcRadarCore{
  position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:rgba(36,199,236,.75);box-shadow:0 0 14px rgba(36,199,236,.9);
}

/* Header upgrades */
.heroTrackCardHdr{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;position:relative;z-index:2;
}
.htcHdrLeft{display:flex;align-items:center;gap:8px}
.htcLivePing{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
  background:#22c55e;animation:htcLivePing 2s ease-in-out infinite;
}
@keyframes htcLivePing{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}
  50%    {box-shadow:0 0 0 7px rgba(34,197,94,0)}
}
.htcSysTag{
  font-family:'JetBrains Mono',monospace;font-size:.55rem;font-weight:700;
  letter-spacing:.14em;color:rgba(36,199,236,.45);
  border:1px solid rgba(36,199,236,.18);padding:3px 8px;border-radius:6px;
  animation:htcSysTagBlink 3.2s ease-in-out infinite;
}
@keyframes htcSysTagBlink{0%,100%{opacity:1}50%{opacity:.4}}

/* Premium input */
.heroTrackSearch{position:relative;z-index:2}
.htcInputWrap{position:relative;display:flex;align-items:center}
.htcInput{
  width:100%;height:52px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11);
  border-radius:14px;color:white;padding:0 18px;
  font-size:.85rem;outline:none;
  font-family:'JetBrains Mono',monospace;letter-spacing:.04em;
  transition:border-color .3s,background .3s,box-shadow .3s;
  animation:htcInputBreathe 5s ease-in-out infinite;
}
@keyframes htcInputBreathe{
  0%,100%{box-shadow:0 0 0 0 rgba(36,199,236,.0)}
  50%    {box-shadow:0 0 14px rgba(36,199,236,.07)}
}
.htcInput::placeholder{
  color:rgba(255,255,255,.28);font-family:'Sora',sans-serif;
  letter-spacing:0;font-size:.87rem;
}
.htcInput:focus{
  border-color:rgba(36,199,236,.55);background:rgba(255,255,255,.10);
  box-shadow:0 0 0 3px rgba(36,199,236,.1),0 0 24px rgba(36,199,236,.08);
  animation:none;
}

/* Timeline z-index fix */
.htlWrap{position:relative;z-index:2}

/* ── LOADING STATE ── */
.htlLoadWrap{
  display:flex;flex-direction:column;align-items:center;
  padding:10px 0 4px;gap:10px;
}
.htlLoadRadarWrap{position:relative;width:88px;height:88px;flex-shrink:0}
.htlLoadRing{
  position:absolute;top:50%;left:50%;border-radius:50%;
  border:1.5px solid rgba(36,199,236,.28);
  animation:htlLRing 1.8s ease-out infinite;
}
.htlLRing1{width:26px;height:26px}
.htlLRing2{width:52px;height:52px;animation-delay:.45s}
.htlLRing3{width:78px;height:78px;animation-delay:.9s}
@keyframes htlLRing{
  0%  {transform:translate(-50%,-50%) scale(.5);opacity:.9}
  100%{transform:translate(-50%,-50%) scale(1.05);opacity:0}
}
.htlLoadSweep{
  position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,transparent 75%,rgba(36,199,236,.38) 100%);
  animation:htlLoadRotate 1.4s linear infinite;
}
@keyframes htlLoadRotate{to{transform:rotate(360deg)}}
.htlLoadCenter{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:28px;height:28px;border-radius:50%;
  background:rgba(36,199,236,.1);border:1px solid rgba(36,199,236,.35);
  display:flex;align-items:center;justify-content:center;
}
.htlLoadCode{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;
  font-weight:700;letter-spacing:.1em;color:rgba(36,199,236,.7);
}
.htlLoadMsg{
  font-size:.78rem;color:rgba(255,255,255,.5);text-align:center;
  transition:opacity .28s;
}
.htlLoadDots{display:flex;gap:5px}
.htlLoadDots span{
  width:5px;height:5px;border-radius:50%;background:rgba(36,199,236,.55);
  animation:htlDotBounce 1.2s ease-in-out infinite;
}
.htlLoadDots span:nth-child(2){animation-delay:.2s}
.htlLoadDots span:nth-child(3){animation-delay:.4s}
@keyframes htlDotBounce{
  0%,100%{transform:scale(.6);opacity:.3}
  50%    {transform:scale(1);opacity:1}
}

/* ── RESULT REVEAL ── */
@keyframes htlReveal{
  from{opacity:0;transform:translateY(9px)}
  to  {opacity:1;transform:translateY(0)}
}
.htl-reveal{opacity:0;animation:htlReveal .5s var(--ease-out) forwards}

/* ── CURRENT STATE CARD ── */
.htlCurrentCard{
  border-radius:16px;padding:13px 15px;margin-bottom:14px;
  position:relative;overflow:hidden;
}
.htlCurrentCard::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% -10%,var(--glow,#24c7ec) 0%,transparent 65%);
  opacity:.08;
}
.htlCurrentTop{display:flex;align-items:center;justify-content:space-between;gap:8px}
.htlCurrentLeft{display:flex;align-items:center;gap:9px}
.htlCurrentIcon{font-size:1.05rem;line-height:1}
.htlCurrentLabel{font-size:.9rem;font-weight:800;color:white;line-height:1.2}
.htlLiveBadge{
  font-size:.56rem;font-weight:900;letter-spacing:.1em;white-space:nowrap;
  color:#4ade80;background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.28);padding:3px 8px;border-radius:99px;
  animation:htlLiveBlink 2.2s ease-in-out infinite;flex-shrink:0;
}
@keyframes htlLiveBlink{0%,100%{opacity:1}50%{opacity:.55}}
.htlCurrentCode{
  font-family:'JetBrains Mono',monospace;font-size:.63rem;
  color:rgba(255,255,255,.3);margin-top:6px;letter-spacing:.06em;
}

/* ── EXTRA INFO LINES ── */
.htlExtraLine{
  display:flex;align-items:center;gap:8px;
  font-size:.72rem;color:rgba(255,255,255,.4);margin-bottom:10px;
}
.htlExtraIcon{font-size:.88rem;line-height:1}
.htlPlaneIcon{display:inline-block;animation:htlPlaneFloat 2.5s ease-in-out infinite}
@keyframes htlPlaneFloat{
  0%,100%{transform:translateX(0) translateY(0)}
  30%    {transform:translateX(4px) translateY(-2px)}
  70%    {transform:translateX(-2px) translateY(1px)}
}

/* ── TIMELINE DOT STATES ── */
.htlDotPulse{animation:htlDotPulseAnim 1.8s ease-in-out infinite}
@keyframes htlDotPulseAnim{
  0%,100%{transform:scale(1);opacity:1}
  50%    {transform:scale(1.5);opacity:.75}
}

/* ── EVENTS ── */
.htlEventsWrap{
  margin-top:12px;padding-top:11px;
  border-top:1px solid rgba(255,255,255,.07);
}
.htlEventsTitle{
  font-size:.6rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.28);margin-bottom:8px;
}
.htlEvRow{display:flex;gap:8px;margin-bottom:8px;align-items:flex-start}
.htlEvDot{
  width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.22);
  flex-shrink:0;margin-top:5px;
}
.htlEvDesc{font-size:.74rem;color:rgba(255,255,255,.62);line-height:1.4}
.htlEvDate{font-size:.61rem;color:rgba(255,255,255,.28);margin-top:2px}

/* ── WA LINK ── */
.htlWaLink{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:14px;padding:10px 0;border-radius:12px;
  background:rgba(34,197,94,.09);border:1px solid rgba(34,197,94,.22);
  color:#4ade80;font-size:.76rem;font-weight:700;
  text-decoration:none;letter-spacing:.04em;
  transition:background .2s,transform .2s;
}
.htlWaLink:hover{background:rgba(34,197,94,.18);transform:translateY(-1px)}

/* ── SERVICES STRIP ── */
.servicesStrip{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:linear-gradient(180deg,#060d1a 0%,#080f1e 100%);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:28px 24px;
  gap:18px;
}
.svcCard{
  padding:30px 26px;
  background:rgba(10,20,40,0.4);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;
  transition:transform .35s cubic-bezier(.22,.61,.36,1),
             box-shadow .35s cubic-bezier(.22,.61,.36,1),
             border-color .35s;
  position:relative;overflow:hidden;
}
.svcCard::before{
  content:"";position:absolute;inset:0;border-radius:20px;opacity:0;
  transition:opacity .35s;
  background:radial-gradient(ellipse 90% 70% at 50% -10%,rgba(28,141,214,.14),transparent 70%);
}
.svcCard:hover{
  transform:translateY(-8px);
  border-color:rgba(28,141,214,.35);
  box-shadow:0 16px 48px rgba(28,141,214,.18), 0 4px 16px rgba(0,0,0,.4);
}
.svcCard:hover::before{opacity:1}
.svcIcon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
  background:rgba(28,141,214,.12);
  border:1px solid rgba(28,141,214,.22);
  color:rgba(28,141,214,.9);
  transition:background .35s, box-shadow .35s;
}
.svcCard:hover .svcIcon{
  background:rgba(28,141,214,.2);
  box-shadow:0 0 24px rgba(28,141,214,.3);
}
.svcCard h4{
  font-size:.76rem;font-weight:900;letter-spacing:.1em;
  margin:0 0 10px;color:#ddeeff;text-transform:uppercase;
}
.svcCard p{font-size:.87rem;color:rgba(255,255,255,.42);line-height:1.65;margin:0}

/* ── STATS STRIP ── */
.statsStrip{display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(135deg,#050f1c,#0a2236)}
.statItem{text-align:center;padding:52px 24px;border-right:1px solid rgba(255,255,255,.07)}
.statItem:last-child{border-right:none}
.statItem b{display:block;font-size:clamp(2.4rem,4vw,3.8rem);font-weight:900;color:var(--orange);line-height:1;margin-bottom:10px;letter-spacing:-.02em}
.statItem span{font-size:.72rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* ── COTIZADOR SECTION ── */
.cotizSection{
  padding:100px 3%;
  background:#f4f8fb;
}
.cotizWrap{max-width:1600px;margin:0 auto}
.cotizHeader{text-align:center;margin-bottom:56px}
.cotizHeader h2{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(2.4rem,5vw,4.8rem);line-height:.95;letter-spacing:-.02em;
  margin:18px 0 14px;color:var(--ink);
}
.cotizHeader h2 em{font-style:italic;color:var(--cyan-deep)}
.cotizHeader p{color:var(--muted);font-size:1rem;line-height:1.65;max-width:560px;margin:0 auto}

/* ── COTIZADOR LAYOUT ── */
.calculator{background:radial-gradient(ellipse at 15% 25%,rgba(36,199,236,.07),transparent 50%),radial-gradient(ellipse at 85% 75%,rgba(139,197,63,.07),transparent 50%),linear-gradient(160deg,#eef8ff,#f5fbf5,#f8f5ff)}
.quoteLayout3{display:grid;grid-template-columns:1fr 1.4fr 1.4fr;gap:28px;align-items:stretch}
.panel{border-radius:26px;padding:28px;position:relative;overflow:hidden}
.productsPanel{
  background:#fff;
  border:1px solid #deeaf4;
  box-shadow:0 8px 40px rgba(12,68,105,.08);
  padding:36px;
}
.invoicePanel{
  background:#fff;
  border:1px solid #deeaf4;
  box-shadow:0 8px 40px rgba(12,68,105,.08);
  padding:36px;
  display:flex;flex-direction:column;
}
.calcVisual{background:linear-gradient(160deg,#061421 0%,#0d2b42 60%,#0a3a2a 100%)!important;border-radius:26px!important;padding:30px!important;box-shadow:0 40px 80px rgba(6,20,33,.28)!important;border:none!important;display:flex;flex-direction:column;min-height:520px;height:100%}
.calcVisual::before{display:none!important}
.calcVisual .pill{align-self:flex-start;margin-bottom:8px}
.calcVisualTitle{font-size:clamp(1.4rem,2vw,1.8rem);line-height:1.15;margin:0 0 10px;letter-spacing:-.04em;color:white}
.calcVisualDesc{color:#88bdd8;font-size:.88rem;line-height:1.65;margin:0}
.calcImgWrap{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 0}
.calcImgWrap img{width:100%;max-width:420px;filter:drop-shadow(0 28px 56px rgba(36,199,236,.42));animation:floatBox 6s ease-in-out infinite}
.calcVisualStats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.calcVisualStats div{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px;text-align:center}
.calcVisualStats b{display:block;font-size:1.2rem;color:#24c7ec;font-weight:900}
.calcVisualStats span{font-size:.72rem;color:#7aabcc;text-transform:uppercase;letter-spacing:.07em}
@keyframes floatBox{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-7px) rotate(1deg)}}

.panelHeader{margin-bottom:24px}
.panelHeader h3{font-family:'Instrument Serif',serif;font-weight:400;font-size:2rem;margin:0;letter-spacing:-.02em;color:var(--ink)}
.panelHeader p{color:var(--muted);margin-top:6px;font-size:.95rem}
.productRow{display:grid;grid-template-columns:1.6fr .7fr .7fr auto;gap:12px;margin:12px 0;padding:18px;border-radius:20px;background:white;border:1px solid #e4eff8;box-shadow:0 2px 12px rgba(28,141,214,.06);transition:all .2s}
.productRow:hover{box-shadow:0 8px 28px rgba(28,141,214,.13);border-color:#c2dff0}
.productRow input{height:56px;border:1px solid #daeef8;border-radius:14px;padding:0 16px;font-size:1rem;background:white;outline:none;transition:all .2s;width:100%}
.productRow input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(36,199,236,.12)}
.removeBtn{width:50px;height:56px;border:0;border-radius:14px;background:#fff0f0;color:#d43f48;font-weight:900;cursor:pointer;font-size:1.2rem;transition:all .2s;flex-shrink:0}
.removeBtn:hover{background:#ffd6d8;transform:scale(1.08)}
.addBtn{width:100%;height:58px;border:0;border-radius:18px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:white;font-weight:900;margin-top:16px;cursor:pointer;font-size:1rem;letter-spacing:.04em;transition:all .2s;box-shadow:0 10px 28px rgba(28,141,214,.22)}
.addBtn:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(28,141,214,.32)}
.typeBox{padding:20px 22px;border-radius:20px;background:white;border:1px solid #daeef8;box-shadow:0 2px 10px rgba(28,141,214,.06);margin:16px 0}
.typeBox label{font-weight:900;font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}
.typeBox select{width:100%;height:56px;border-radius:14px;border:1px solid #cfe8f4;margin-top:10px;padding:0 16px;background:white;font-size:1rem;outline:none;cursor:pointer;transition:border-color .2s}
.typeBox select:focus{border-color:var(--cyan)}

/* ── VOLUMETRIC ── */
.volRow{
  grid-column:1/-1;
  display:flex;align-items:center;gap:12px;
  padding-top:12px;margin-top:4px;
  border-top:1px dashed #d8eef8;
  flex-wrap:wrap;
}
.volLabel{
  font-size:.72rem;font-weight:800;color:var(--muted);
  text-transform:uppercase;letter-spacing:.07em;
  white-space:nowrap;flex-shrink:0;
}
.volFields{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:1}
.pdim{
  width:110px!important;height:46px!important;
  font-size:.88rem!important;border-radius:12px!important;
  padding:0 12px!important;
}
.volResult{
  font-size:.8rem;
  padding:6px 14px;
  background:#f0f7ff;
  border-radius:10px;
  border:1px solid #d0e8f8;
  color:var(--muted);
  white-space:nowrap;
}
.volWinner{font-weight:800;padding:2px 8px;border-radius:6px;font-size:.75rem}
.volWinnerVol{color:#ff7a1a;background:#fff3e8}
.volWinnerReal{color:#1c8dd6;background:#e8f4ff}

.invoicePanel{display:flex;flex-direction:column}
.invoiceTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px;padding-bottom:16px;border-bottom:2px solid #eef5fb}
.invoiceLabel{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;font-weight:900;margin:0 0 4px}
.invoiceTitle{font-size:1.5rem;margin:0;letter-spacing:-.03em;font-weight:900}
.invoiceBadge{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--cyan));color:white;font-weight:900;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 20px rgba(28,141,214,.3)}
.summaryGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:16px 0}
.metric{padding:16px 18px;border-radius:18px;background:white;border:1px solid #e4eff8;box-shadow:0 2px 10px rgba(28,141,214,.06);position:relative;overflow:hidden}
.metric::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--cyan),var(--blue))}
.metric span{display:block;color:var(--muted);font-weight:800;font-size:.75rem;text-transform:uppercase;letter-spacing:.07em}
.metric b{font-size:1.2rem;color:var(--text);margin-top:3px;display:block;font-weight:900}
.formulaBox{padding:16px 18px;border-radius:18px;background:white;border:1px solid #daeef8;box-shadow:0 2px 10px rgba(28,141,214,.06);margin:12px 0}
.formulaBox h4{margin:0 0 5px;color:var(--blue);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:900}
.formulaBox p{margin:0;color:#2a4a5e;line-height:1.6;font-size:.9rem}
.invoiceBreakdown{border:1px solid #e4eff8;border-radius:20px;overflow:hidden;margin:14px 0 18px;flex:1}
.invoiceLine{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid #eef5fb;transition:background .15s}
.invoiceLine:hover{background:#f8fcff}
.invoiceLine span{color:var(--muted);font-size:.85rem;font-weight:800}
.invoiceLine b{font-size:1rem;color:var(--text);font-weight:900}
.invoiceTotal{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:linear-gradient(135deg,#061421,#0d2b42)}
.invoiceTotal span{color:#7fdaef;text-transform:uppercase;font-weight:900;font-size:.75rem;letter-spacing:.12em}
.invoiceTotal strong{font-size:clamp(1.6rem,2.5vw,2.2rem);background:linear-gradient(135deg,#24c7ec,#8bc53f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:56px;padding:0 24px;border-radius:16px;text-decoration:none;font-weight:900;border:0;cursor:pointer;font-size:.95rem}
.primary{background:linear-gradient(135deg,var(--orange),var(--red));color:white;box-shadow:0 16px 40px rgba(238,93,98,.25)}
.primary:hover{transform:translateY(-2px);box-shadow:0 22px 48px rgba(238,93,98,.35)}
.full{width:100%}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:99px;
  background:rgba(36,199,236,.12);border:1px solid rgba(36,199,236,.32);
  color:#c1f5ff;text-transform:uppercase;letter-spacing:.18em;font-size:11.5px;font-weight:600;
}
.pill .dot{
  width:7px;height:7px;border-radius:50%;background:var(--cyan);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(36,199,236,.6);animation:ping 1.6s infinite;
}
@keyframes ping{
  0%{box-shadow:0 0 0 0 rgba(36,199,236,.6)}
  70%{box-shadow:0 0 0 9px rgba(36,199,236,0)}
  100%{box-shadow:0 0 0 0 rgba(36,199,236,0)}
}
.pill.dark{
  background:rgba(28,141,214,.10);border-color:rgba(28,141,214,.25);color:var(--cyan-deep);
}
.pill.dark .dot{background:var(--cyan-deep);animation:none;box-shadow:0 0 0 3px rgba(28,141,214,.18)}

/* ── MARQUEE ── */
.marquee{
  background:var(--ink);color:#fff;
  padding:20px 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.marquee-track{
  display:flex;
  width:max-content;
  animation:marqueeScroll 55s linear infinite;
  will-change:transform;
}
.marquee-track span{
  display:inline-flex;align-items:center;
  gap:56px;
  padding-right:56px;
  flex-shrink:0;
  white-space:nowrap;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:30px;
  letter-spacing:-.01em;color:#fff;
}
.marquee-track .dot{
  width:7px;height:7px;border-radius:50%;background:var(--coral);flex-shrink:0;display:inline-block;
}
/* continuo — no se pausa al hover */
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ── SECTION BASE ── */
.section{padding:100px 5%}
.sectionTitle{text-align:center;max-width:780px;margin:0 auto 52px}
.sectionTitle h2{font-family:'Instrument Serif',serif;font-weight:400;font-size:clamp(2.2rem,5vw,4.4rem);line-height:.94;letter-spacing:-.03em;margin:16px 0}
.sectionTitle p{font-size:1.05rem;line-height:1.65;color:var(--muted)}

/* ── TARIFAS ── */
.tariffs{
  padding:80px 5%;
  position:relative;
  isolation:isolate;
  background:
    linear-gradient(180deg,rgba(4,11,21,.55) 0%,rgba(4,11,21,.42) 100%),
    url('assets/fondo3.png') center/cover no-repeat fixed;
}
.tariffs .sectionTitle{text-align:center;margin-bottom:52px}
.tariffs .sectionTitle h2{color:#fff;font-family:'Instrument Serif',serif;font-weight:400}
.tariffs .sectionTitle h2 em{font-style:italic;color:var(--cyan)}
.tariffs .sectionTitle p{color:#7a9bb5}
.tariffs .pill.dark{background:rgba(36,199,236,.12);border-color:rgba(36,199,236,.28);color:#c1f5ff}
.tariffs .pill.dark .dot{background:var(--cyan)}

/* Tarjeta única */
.tarifBigCard{
  max-width:1200px;margin:0 auto;
  background:rgba(5,13,28,.55);
  border:1px solid rgba(255,255,255,.12);
  border-radius:32px;
  overflow:hidden;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

/* Cabecera */
.tarifCardHead{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 36px;
  background:rgba(28,141,214,.12);
  border-bottom:1px solid rgba(255,255,255,.09);
  gap:20px;
}
.tarifCardHeadLeft{display:flex;align-items:center;gap:18px}
.tarifCardBadge{
  width:52px;height:52px;border-radius:16px;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:grid;place-items:center;font-size:1.4rem;flex-shrink:0;
  box-shadow:0 8px 24px rgba(36,199,236,.35);
}
.tarifCardTitle{font-family:'Instrument Serif',serif;font-size:1.5rem;color:#fff;letter-spacing:-.01em}
.tarifCardSub{font-size:.75rem;color:#6a9ab8;margin-top:3px;letter-spacing:.04em}
.tarifCardRoute{display:flex;align-items:center;gap:10px}
.tarifRouteDot{
  font-family:'JetBrains Mono',monospace;font-size:.78rem;font-weight:700;
  color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  padding:6px 12px;border-radius:8px;letter-spacing:.1em;
}
.tarifRouteDotEnd{background:rgba(36,199,236,.18);border-color:rgba(36,199,236,.4);color:var(--cyan)}
.tarifRouteLine{flex:1;min-width:60px;height:1px;background:rgba(255,255,255,.15);position:relative}
.tarifRouteLine i{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px rgba(36,199,236,.7);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.6)}}

/* Columnas header */
.tarifCols{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1.2fr;
  padding:10px 36px;
  background:rgba(255,255,255,.03);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.tarifCols span{
  font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:#4a7a98;
}

/* Filas */
.tarifRow{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1.2fr;
  align-items:center;
  padding:11px 36px;
  border-bottom:1px solid rgba(255,255,255,.05);
  transition:background .2s, transform .2s;
  cursor:default;position:relative;
}
.tarifRow:last-child{border-bottom:none}
.tarifRow::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--cyan),var(--blue));
  opacity:0;
  transition:opacity .25s, width .35s cubic-bezier(.16,1,.3,1);
}
.tarifRow::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(36,199,236,.07) 0%,transparent 70%);
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
}
.tarifRow:hover{background:rgba(255,255,255,.03)}
.tarifRow:hover::before{opacity:1;width:3px}
.tarifRow:hover::after{opacity:1}
.tarifRow > div,.tarifRow > span{
  font-size:.88rem;color:#8ab0c8;font-weight:500;
  transition:color .25s ease;
}
.tarifRow:hover > div,.tarifRow:hover > span{color:#daeef8}

/* Columna de rango */
.tr-range b{display:block;color:#fff;font-size:.9rem;font-weight:700;font-family:'Sora',sans-serif;letter-spacing:-.01em}
.tr-range small{font-size:.68rem;color:#4a7a98;font-weight:500;margin-top:1px;display:block;letter-spacing:.04em}

/* Tarifa / kg */
.tr-rate{font-family:'JetBrains Mono',monospace;font-size:.95rem;color:var(--cyan)!important;font-weight:700}
.tr-rate em{font-style:normal;font-size:.75rem;color:#4a7a98;margin-left:2px}
.tr-fixed{color:var(--orange)!important}

/* Nac */
.tr-nac{color:#7ab8d0!important;font-size:.82rem}

/* Fila destacada */
.tarifRowFeatured{
  background:linear-gradient(90deg,rgba(36,199,236,.10),rgba(139,197,63,.06),transparent)!important;
  border-color:rgba(36,199,236,.18)!important;
}
.tarifRowFeatured .tr-range b{color:var(--cyan)}
.tarifRowFeatured .tr-range small{color:var(--green);font-weight:700}
.tarifRowFeatured::before{width:4px!important;background:linear-gradient(180deg,var(--cyan),var(--green))!important}

/* Fila tipo mínimo fijo */
.tarifFlat .tr-range b{color:#ffd580}
.tarifFlat .tr-rate{color:var(--orange)!important}

/* Pie */
.tarifCardFoot{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 36px;
  background:rgba(255,255,255,.03);
  border-top:1px solid rgba(255,255,255,.08);
}
.tarifCardFoot span{font-size:.8rem;color:#4a7a98}

/* ── CASILLA MIAMI ── */
.address{background:linear-gradient(90deg,rgba(6,20,33,.94),rgba(6,20,33,.6)),url('assets/fondo2.jpg') center/cover fixed;color:white}
.addressContent{display:grid;grid-template-columns:1fr .9fr;gap:28px}
.addressContent h2{font-size:clamp(2.2rem,5vw,4.4rem);line-height:.94;letter-spacing:-.055em;margin:18px 0}
.addressCard,.requirements{border-radius:28px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(16px);padding:28px}
.addressCard p,.requirements p{font-size:1.05rem;color:#eef8ff;margin:8px 0}
.requirements h3{font-size:1.8rem;margin-top:0}

/* ── CONTACTO ── */
.contactSection{
  background:
    linear-gradient(135deg,rgba(4,11,21,.96) 0%,rgba(8,22,42,.92) 100%),
    url('assets/fondo2.jpg') center/cover no-repeat fixed;
  padding:100px 5%;
  position:relative;
  isolation:isolate;
}
.contactInner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.contactCTA .pill{margin-bottom:24px}
.contactCTA h2{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(2.8rem,5vw,5rem);line-height:.95;letter-spacing:-.02em;
  color:#fff;margin:0 0 20px;
}
.contactCTA h2 em{font-style:italic;color:var(--cyan)}
.contactCTA p{font-size:1.05rem;color:#7a9bb5;line-height:1.7;margin:0 0 36px;max-width:440px}
.contactBtns{display:flex;flex-wrap:wrap;gap:14px}
.contactWaBtn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:99px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;font-weight:700;font-size:.95rem;
  box-shadow:0 12px 30px rgba(37,211,102,.35),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform var(--t),box-shadow var(--t);text-decoration:none;
}
.contactWaBtn:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(37,211,102,.45)}
.contactMapBtn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 24px;border-radius:99px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;font-weight:600;font-size:.92rem;
  backdrop-filter:blur(12px);
  transition:background var(--t),transform var(--t);text-decoration:none;
}
.contactMapBtn:hover{background:rgba(255,255,255,.15);transform:translateY(-2px)}

/* Info cards */
.contactCards{display:flex;flex-direction:column;gap:16px}
.contactCard{
  display:flex;align-items:flex-start;gap:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:20px;padding:22px 24px;
  backdrop-filter:blur(12px);
  transition:background var(--t),border-color var(--t),transform var(--t);
}
.contactCard:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.16);transform:translateX(6px)}
.contactCardIcon{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:rgba(28,141,214,.2);border:1px solid rgba(28,141,214,.3);
  display:grid;place-items:center;color:var(--cyan-deep);
}
.contactCardIconGreen{background:rgba(37,211,102,.15);border-color:rgba(37,211,102,.3);color:#25d366}
.contactCardIconCyan{background:rgba(36,199,236,.15);border-color:rgba(36,199,236,.3);color:var(--cyan)}
.contactCardIconOrange{background:rgba(255,122,26,.15);border-color:rgba(255,122,26,.3);color:var(--orange)}
.contactCard h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);margin:0 0 6px}
.contactCard p{font-size:.92rem;color:#ccdde8;line-height:1.6;margin:0}

/* ── FOOTER ── */
.footer{background:#02080f;border-top:1px solid rgba(255,255,255,.06)}
.footerTop{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.2fr 2fr;gap:64px;
  padding:64px 5% 48px;
}
.footerBrand img{height:52px;filter:brightness(1.1) drop-shadow(0 4px 16px rgba(36,199,236,.2));margin-bottom:18px}
.footerBrand p{font-size:.9rem;color:#4a6a82;line-height:1.7;max-width:260px;margin:0}
.footerLinks{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footerCol h5{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#4a6a82;margin:0 0 18px}
.footerCol a{
  display:block;font-size:.88rem;color:#6a8ea6;
  margin-bottom:10px;text-decoration:none;
  transition:color var(--t);
}
.footerCol a:hover{color:#c1eaf8}
.footerBottom{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 5%;
  border-top:1px solid rgba(255,255,255,.05);
}
.footerBottom p{font-size:.78rem;color:#2e4a5e;margin:0}

/* ── NAV DERECHA + HAMBURGUESA ── */
.navRight{display:flex;align-items:center;gap:10px}
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:40px;border-radius:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  cursor:pointer;padding:8px;transition:background var(--t);
}
.hamburger:hover{background:rgba(255,255,255,.15)}
.hamburger span{
  display:block;width:100%;height:2px;border-radius:2px;
  background:#fff;transition:transform .3s,opacity .3s;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Menú móvil desplegable */
.mobileMenu{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(4,10,22,.97);backdrop-filter:blur(20px);
  z-index:79;flex-direction:column;justify-content:center;align-items:center;
  gap:8px;padding:100px 5% 40px;
  opacity:0;transform:translateY(-12px);
  transition:opacity .3s,transform .3s;
}
.mobileMenu.open{display:flex;opacity:1;transform:translateY(0)}
.mobileMenu a{
  font-family:'Instrument Serif',serif;font-size:clamp(2rem,7vw,2.8rem);
  color:rgba(255,255,255,.7);text-decoration:none;
  padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07);width:100%;text-align:center;
  transition:color .2s;
}
.mobileMenu a:hover{color:#fff}
.mobileMenuWa{
  margin-top:16px!important;border:none!important;
  display:inline-flex!important;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,#25d366,#128c7e)!important;
  color:#fff!important;border-radius:99px!important;
  padding:14px 32px!important;font-family:'Sora',sans-serif!important;
  font-size:1rem!important;font-weight:700!important;width:auto!important;
  box-shadow:0 12px 30px rgba(37,211,102,.3);
}

/* ── GLASS BUTTON ── */
.glass{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:white;backdrop-filter:blur(14px)}

/* ══════════════════════════════════════════
   RESPONSIVE — TABLET (≤ 1024px)
══════════════════════════════════════════ */
@media(max-width:1024px){

  /* Nav */
  .nav{top:10px;padding:8px 10px 8px 18px}
  .navlinks{display:none}
  .hamburger{display:flex}
  .brand img{height:42px}

  /* Hero */
  .hero{grid-template-columns:1fr;padding:120px 6% 60px;gap:36px}
  .heroTrackCard{max-width:540px}

  /* Servicios */
  .servicesStrip{grid-template-columns:1fr 1fr;padding:20px 16px;gap:14px}
  .svcCard{border-bottom:none}

  /* Stats */
  .statsStrip{grid-template-columns:1fr 1fr}
  .statItem{border-bottom:1px solid rgba(255,255,255,.07)}

  /* Cotizador */
  .cotizSection{padding:80px 4%}
  .quoteLayout3{grid-template-columns:1fr;gap:20px}
  .calcVisual{min-height:auto!important;height:auto!important}

  /* Tarifas */
  .tarifCols{display:none}
  .tarifRow{grid-template-columns:1fr 1fr;gap:6px;padding:14px 20px}
  .tarifRow > div:nth-child(n+3){display:none}
  .tarifCardHead{flex-direction:column;align-items:flex-start;gap:12px}

  /* Casilla */
  .addressContent{grid-template-columns:1fr}

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

  /* Footer */
  .footerTop{grid-template-columns:1fr;gap:40px}
  .footerLinks{grid-template-columns:repeat(3,1fr)}
}

/* ══════════════════════════════════════════
   RESPONSIVE — MÓVIL (≤ 640px)
══════════════════════════════════════════ */
@media(max-width:640px){

  /* Nav — compacto */
  .nav{
    top:8px;width:calc(100% - 24px);
    padding:8px 8px 8px 16px;
    border-radius:50px;
  }
  .navlinks{display:none}
  .brand img{height:36px}
  .navbtn{padding:10px 14px;font-size:12px;gap:6px}
  .navbtn svg{width:16px;height:16px}

  /* Hero */
  .hero{
    grid-template-columns:1fr;
    padding:100px 5% 50px;
    gap:32px;
    min-height:auto;
  }
  h1{font-size:clamp(2.6rem,10vw,3.8rem);margin:18px 0 16px}
  .hero p.lead{font-size:.95rem}
  .actions{flex-direction:column;align-items:flex-start;gap:12px}
  .actions .btn,.actions .contactWaBtn{width:100%;justify-content:center}
  .play-link{margin-left:0}
  .heroStats{grid-template-columns:repeat(3,1fr);gap:8px;padding-top:24px}
  .heroStats b{font-size:1.5rem}

  /* Tracking card — se apila */
  .heroTrackCard{padding:22px 18px;border-radius:20px}

  /* Orbs reducidos */
  .orb.o1{width:280px;height:280px}
  .orb.o2{width:200px;height:200px}
  .orb.o3{display:none}

  /* Marquee */
  .marquee-track span{font-size:22px;gap:36px;padding-right:36px}
  .marquee{padding:14px 0}

  /* Servicios */
  .servicesStrip{grid-template-columns:1fr}
  .svcCard{padding:22px 18px}

  /* Stats */
  .statsStrip{grid-template-columns:1fr 1fr}
  .statItem{padding:32px 16px}
  .statItem b{font-size:2rem}

  /* Cotizador */
  .cotizSection{padding:60px 4%}
  .cotizHeader{margin-bottom:36px}
  .cotizHeader h2{font-size:clamp(2rem,8vw,3rem)}
  .quoteLayout3{grid-template-columns:1fr;gap:16px}
  .calcVisual{min-height:auto!important;height:auto!important;padding:22px!important}
  .productsPanel,.invoicePanel{padding:20px 16px}
  .productRow{grid-template-columns:1fr 1fr;gap:8px}
  .productRow .pname{grid-column:1/-1}
  .volRow{flex-direction:column;align-items:flex-start}
  .volFields{flex-wrap:wrap}
  .pdim{width:90px!important}
  .summaryGrid{grid-template-columns:1fr 1fr}

  /* Tarifas */
  .tariffs{padding:50px 3%}
  .tarifBigCard{border-radius:16px}
  .tarifCardHead{flex-direction:column;align-items:flex-start;gap:8px;padding:14px 14px}
  .tarifCardTitle{font-size:1.1rem}
  .tarifCardSub{font-size:.65rem}
  .tarifCardBadge{width:38px;height:38px;font-size:1rem}
  .tarifCardRoute{display:none}
  /* Columnas visibles en móvil: rango · tarifa · handling */
  .tarifCols{
    display:grid;
    grid-template-columns:1.6fr .8fr .7fr .7fr;
    padding:7px 14px;
  }
  .tarifCols span{font-size:.58rem;letter-spacing:.06em}
  .tarifCols span:nth-child(n+5){display:none}
  .tarifRow{
    display:grid;
    grid-template-columns:1.6fr .8fr .7fr .7fr;
    gap:0;
    padding:6px 14px;
    border-bottom:1px solid rgba(255,255,255,.04);
  }
  .tarifRow > div:nth-child(n+5){display:none}
  .tarifRow > div{font-size:.75rem;line-height:1.2}
  .tr-range b{font-size:.75rem!important;letter-spacing:-.01em}
  .tr-range small{font-size:.6rem!important;margin-top:0}
  .tr-rate{font-size:.75rem!important}
  .tarifRowFeatured::before{width:3px!important}
  .tarifCardFoot{flex-direction:column;align-items:stretch;gap:10px;padding:12px 14px}
  .tarifCardFoot .btn{width:100%;justify-content:center;min-height:40px;font-size:.82rem}

  /* Casilla */
  .address{background-attachment:scroll}
  .addressContent{grid-template-columns:1fr;gap:20px}
  .addressContent h2{font-size:clamp(1.8rem,7vw,2.6rem)}
  .addressCard,.requirements{padding:20px}

  /* Contacto */
  .contactSection{padding:60px 5%;background-attachment:scroll}
  .contactInner{grid-template-columns:1fr;gap:36px}
  .contactCTA h2{font-size:clamp(2.2rem,8vw,3.2rem)}
  .contactBtns{flex-direction:column}
  .contactWaBtn,.contactMapBtn{width:100%;justify-content:center}
  .contactCard{padding:16px 18px}

  /* Footer */
  .footerTop{grid-template-columns:1fr;gap:32px;padding:48px 5% 32px}
  .footerLinks{grid-template-columns:1fr 1fr;gap:24px}
  .footerBrand img{height:44px}
  .footerBottom{flex-direction:column;text-align:center;gap:8px;padding:16px 5%}

  /* Section base */
  .section{padding:60px 5%}
  .sectionTitle{margin-bottom:36px}
}

/* ══════════════════════════════════════════
   RESPONSIVE — MÓVIL PEQUEÑO (≤ 390px)
══════════════════════════════════════════ */
@media(max-width:390px){
  h1{font-size:2.4rem}
  .heroStats{grid-template-columns:repeat(3,1fr)}
  .heroStats b{font-size:1.3rem}
  .statsStrip{grid-template-columns:1fr 1fr}
  .footerLinks{grid-template-columns:1fr}
  .quoteLayout3{gap:12px}
  .navbtn span{display:none}
  /* Tarifas ultra compacto */
  .tarifRow{padding:5px 10px}
  .tarifRow > div{font-size:.68rem}
  .tr-range b{font-size:.68rem!important}
  .tr-range small{display:none}
  .tarifCols span{font-size:.54rem}
  .tarifCols{padding:5px 10px}
}
