/* Styles para Domaxivar - moderno, fondo oscuro, azul vibrante */
:root{
  --bg:#071021; /* fondo oscuro */
  --card:#0b1220;
  --muted:#98a0b3;
  --accent:#0ea5ff; /* azul vibrante */
  --accent-2:#0066ff;
  --glass: rgba(255,255,255,0.03);
  --radius:12px;
  --gap:24px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,Segoe UI,Roboto,system-ui,Arial;
  background:linear-gradient(180deg,var(--bg),#030410 120%);
  color:#e6eef8;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}
.container{max-width:1100px;margin:0 auto;padding:40px 20px}

/* Header */
.site-header{backdrop-filter:blur(6px);position:sticky;top:0;z-index:50;background:linear-gradient(180deg,rgba(7,16,33,0.6),transparent)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700;color:var(--accent);font-size:1.15rem}
.nav{display:flex;gap:18px}
.nav a{color:var(--muted);text-decoration:none;font-weight:600}

/* Buttons */
.btn{display:inline-block;padding:10px 18px;border-radius:10px;text-decoration:none;font-weight:700;border:2px solid transparent}
.btn.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#001528}
.btn.primary.big{padding:18px 34px;font-size:1.05rem}
.btn.outline{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--accent)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid transparent}
.btn.glow{box-shadow:0 6px 20px rgba(14,165,255,0.15),0 0 36px rgba(0,102,255,0.08);transition:transform .16s ease,box-shadow .16s ease}
.btn.glow:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(14,165,255,0.22),0 0 80px rgba(0,102,255,0.12)}

/* Hero */
.hero{padding:80px 0}
.hero-inner{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center}
.hero-copy h1{font-size:2.1rem;margin:0 0 12px;color:#fff}
.lead{color:var(--muted);font-size:1.05rem;margin-bottom:18px}
.hero-ctas{display:flex;gap:14px}

/* Phone mock */
.phone-mock{width:340px;height:640px;border-radius:28px;background:linear-gradient(180deg,#061125 40%,#071326);padding:18px;box-shadow:0 20px 60px rgba(2,6,23,0.6),inset 0 2px 10px rgba(255,255,255,0.02)}
.screen{background:linear-gradient(180deg,#081022,#061026);height:100%;border-radius:12px;overflow:hidden;position:relative}
.map-snapshot{position:absolute;inset:12px;border-radius:8px;background:linear-gradient(180deg,#03203a,#05283f);display:block}

/* Panels */
.panel{padding:64px 0}
.panel.alt{background:linear-gradient(180deg,rgba(255,255,255,0.01),transparent)}
h2{color:#eaf6ff;margin-top:0}
.features{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px}
.features li{background:var(--glass);padding:14px;border-radius:10px}

.cards{display:flex;gap:18px;margin-top:18px}
.card{background:var(--card);padding:18px;border-radius:12px;flex:1}
.muted{color:var(--muted)}

/* Mock map */
.map-wrap{margin-top:18px}
.mock-map{height:360px;border-radius:12px;background:linear-gradient(180deg,#022232,#011822);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,0.03);width:100%}
.marker{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 6px 18px rgba(14,165,255,0.18);transform:translate(-50%,-50%);cursor:pointer;border:2px solid rgba(255,255,255,0.06)}
.marker:after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);width:4px;height:10px;border-radius:2px;background:rgba(14,165,255,0.08)}
.tooltip{position:absolute;background:#02111a;padding:8px 10px;border-radius:8px;color:var(--muted);font-size:0.95rem;border:1px solid rgba(255,255,255,0.03)}

/* CTA */
.cta{padding:64px 0;text-align:center;background:linear-gradient(180deg,rgba(0,102,255,0.06),transparent)}

/* Contact section */
.contact .contact-row{display:flex;gap:28px;align-items:flex-start;margin-top:18px}
.contact-item{flex:1;background:rgba(255,255,255,0.02);padding:18px;border-radius:12px}
.contact .contact-link{display:inline-block;color:var(--accent);font-weight:700;margin-top:6px;text-decoration:none}
.btn.whatsapp{background:linear-gradient(90deg,#25D366,#1DA851);color:#01240b;border-radius:10px;padding:10px 16px;box-shadow:0 8px 30px rgba(37,211,102,0.12);display:inline-block;text-decoration:none}
.btn.whatsapp:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(37,211,102,0.18)}

@media (max-width:900px){
  .contact .contact-row{flex-direction:column}
}

/* Footer */
.site-footer{padding:20px 0;color:var(--muted)}
.footer-inner{display:flex;justify-content:space-between;align-items:center}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(18px);transition:all .7s cubic-bezier(.2,.9,.2,1)}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .phone-mock{width:280px;height:520px;margin:0 auto}
  .cards{flex-direction:column}
  .footer-inner{flex-direction:column;gap:8px}
}

@media (prefers-reduced-motion:reduce){
  .reveal{transition:none}
  .btn{transition:none}
}

/* Assets integration */
.brand{display:flex;align-items:center;gap:12px}
.brand img.logo{width:40px;height:40px;object-fit:contain;border-radius:8px;background:#ffffff;padding:6px;box-shadow:0 6px 18px rgba(0,102,255,0.08);border:1px solid rgba(0,0,0,0.06)}
.phone-img{position:absolute;inset:8px;width:calc(100% - 16px);height:calc(100% - 16px);object-fit:contain;object-position:center;background:linear-gradient(180deg,rgba(2,10,18,0.25),rgba(2,10,18,0.45));border-radius:6px;padding:6px}
.card img{width:100%;height:auto;max-height:200px;object-fit:contain;border-radius:8px;margin-bottom:10px;background:linear-gradient(180deg,rgba(2,6,10,0.18),rgba(255,255,255,0.02));padding:6px}

/* Section images */
.section-img{width:100%;max-height:360px;object-fit:cover;border-radius:12px;margin-bottom:18px;display:block}
.section-img.right{float:right;width:48%;margin-left:20px;margin-bottom:6px}

/* Map background inside mock map */
.real-map{position:absolute;inset:0;z-index:3;height:100%;border-radius:12px}
.leaflet-container{height:100%;width:100%}
.store-label{background:linear-gradient(180deg,#02121a,#03202a);color:#eaf6ff;padding:6px 10px;border-radius:8px;font-weight:700;border:1px solid rgba(255,255,255,0.04);box-shadow:0 8px 18px rgba(0,0,0,0.45)}
.store-label:after{display:none}
.mock-map .map-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;z-index:1;display:block}

/* Panel de depuración pequeño (solo durante desarrollo) */
#map-debug{font-family:Inter,Segoe UI,Roboto,Arial;opacity:0.98}
.mock-map .marker{position:absolute;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px}
.mock-map .marker-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 6px 18px rgba(14,165,255,0.22);border:2px solid rgba(0,0,0,0.25)}
.mock-map .marker-label{background:rgba(2,6,10,0.7);color:#e6eef8;padding:6px 10px;border-radius:12px;font-weight:700;font-size:0.85rem;white-space:nowrap;transform:translateY(-4px)}
.mock-map .tooltip{z-index:3}

@media (max-width:900px){
  .section-img.right{float:none;width:100%;margin:0 auto 14px}
}

/* Newspaper/grid layout for 16:9 images */
.news-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:18px;align-items:start}
.news-item{background:transparent;overflow:visible;display:flex;flex-direction:column}
.news-item.full{grid-column:1/-1}
.news-media{width:100%;flex:0 0 auto;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;overflow:visible;background:transparent}
.news-media > .mock-map{width:100%;height:100%;flex:1 1 auto}
.news-media img{max-width:100%;max-height:100%;display:block;object-fit:contain;background:transparent;border-radius:0}
.news-content{padding:12px 6px;color:var(--muted)}
.news-content h3{color:#eaf6ff;margin:0 0 6px}

@media (min-width:1300px){
  .news-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1200px){
  .news-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .news-grid{grid-template-columns:1fr}
}

/* Fix rápido para asegurar que el mock-map siempre sea visible durante depuración */
.mock-map{min-height:360px !important; height:100% !important}
.mock-map .map-bg{opacity:1 !important; display:block !important; width:100% !important; height:100% !important}
.mock-map .marker{display:flex !important; z-index:9999 !important}
.mock-map .visible-fallback{z-index:9998 !important}
