:root{
  --primary:#8a2be2;       /* Purple (neón suave) */
  --accent:#00e5ff;        /* Cyan */
  --hot:#ff2d95;           /* Magenta */
  --dark:#070a16;          /* Noche */
  --text:#0f172a;
  --muted:#5b6475;
  --bg:#060818;            /* Fondo oscuro */
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.14);
  --shadow:0 18px 40px rgba(0,0,0,.45);
  --radius:20px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: rgba(255,255,255,.92);
  background: radial-gradient(1000px 600px at 12% 10%, rgba(138,43,226,.25), transparent 60%),
              radial-gradient(900px 520px at 88% 12%, rgba(0,229,255,.20), transparent 55%),
              radial-gradient(900px 600px at 50% 92%, rgba(255,45,149,.18), transparent 55%),
              linear-gradient(180deg, #050615 0%, #070a16 60%, #060818 100%);
  line-height:1.55;
}
a{color:inherit}
code{color:rgba(255,255,255,.9); background:rgba(255,255,255,.08); padding:2px 6px; border-radius:10px}
.container{width:min(1120px, calc(100% - 32px)); margin:0 auto}

/* Ambient overlay (grain) */
body:before{
  content:"";
  position:fixed; inset:0;
  background-image:url("../img/grain.svg");
  mix-blend-mode: overlay;
  opacity:.22;
  pointer-events:none;
  z-index:-1;
}

.topbar{
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
  font-size: 13px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.topbar-inner{
  display:flex; gap:12px; justify-content:space-between; align-items:center;
  padding:8px 0;
}
.topbar-link{color:rgba(255,255,255,.9); text-decoration:none}
.topbar-link:hover{text-decoration:underline}

.site-header{
  position: sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: rgba(6,8,24,.65);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.nav-wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}

.brand-mark{
  position: relative;   /* <- CLAVE */
  display: inline-block;
  width: 66px;
  height: 47px;
  background-image: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2Flogo_mrvallaspapales.png?alt=media&token=fbd04485-be93-473b-858a-9534a3c684f9");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.brand-mark:after{
  content:"";
  position:absolute; inset:2px;
  border-radius:12px;
  pointer-events:none;  
}
.brand-name{font-weight:950; letter-spacing:.2px}

.nav{display:flex; gap:18px; align-items:center}
.nav a{text-decoration:none; font-weight:800; opacity:.88}
.nav a:hover{opacity:1}
.nav-cta{margin-left:8px}

.nav-toggle{
  display:none;
  width:46px; height:40px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  border-radius: 14px;
  cursor:pointer;
}
.nav-toggle span{display:block; height:2px; background:rgba(255,255,255,.92); margin:7px 10px; opacity:.9}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px;
  border-radius: 999px;
  font-weight:950;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
  gap:10px;
}
.btn-sm{padding:10px 14px; font-size:14px}
.btn-primary{
  color:#0b1028;
  background: linear-gradient(90deg, var(--accent), rgba(0,229,255,.75));
  box-shadow: 0 18px 38px rgba(0,229,255,.18);
}
.btn-primary:hover{filter: brightness(1.03)}
.btn-outline{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
}
.btn-outline:hover{background: rgba(255,255,255,.09)}

.hero{padding: 56px 0 18px}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
  align-items:stretch;
}
.hero-card{
  border:1px solid rgba(255,255,255,.14);
  border-radius: calc(var(--radius) + 10px);
  background: radial-gradient(900px 380px at 20% 20%, rgba(138,43,226,.20), transparent 55%),
              radial-gradient(700px 330px at 85% 25%, rgba(0,229,255,.16), transparent 55%),
              linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}
.hero-card:before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(circle at 18% 20%, rgba(255,45,149,.20), transparent 45%),
              radial-gradient(circle at 86% 18%, rgba(0,229,255,.24), transparent 45%);
  opacity:.9;
  pointer-events:none;
}
.hero-content{padding: 28px; position:relative}
.kicker{display:inline-flex; gap:8px; align-items:center; font-weight:950; color: rgba(255,255,255,.92); font-size:13px}
.kicker i{width:10px;height:10px;border-radius:50%;background:var(--hot);display:inline-block; box-shadow:0 0 0 6px rgba(255,45,149,.12)}
h1{margin:12px 0 10px; font-size: clamp(28px, 3.3vw, 46px); line-height:1.06}
.lead{margin:0; color: rgba(255,255,255,.78); font-size: 16px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}
.hero-stats{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin-top:20px}
.stat{
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  padding: 12px;
}
.stat b{display:block; font-size: 18px}
.stat span{color: rgba(255,255,255,.70); font-size: 13px}

.hero-side{
  border:1px solid rgba(255,255,255,.14);
  border-radius: calc(var(--radius) + 10px);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.hero-side .img{
  height: 240px;
  position: relative;

  background-image:
    var(--hero-img, url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FLogoFin.png?alt=media&token=7dc27e53-4f73-41f8-b3eb-98549b64320c")),
    radial-gradient(800px 300px at 15% 25%, rgba(0, 229, 255, .25), transparent 55%),
    radial-gradient(700px 260px at 80% 30%, rgba(255, 45, 149, .22), transparent 55%),
    linear-gradient(135deg, rgba(138, 43, 226, .55), rgba(7, 10, 22, 1));

  background-size: cover, auto, auto, auto;
  background-position: center, center, center, center;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;

  border-radius: 14px;
  overflow: hidden;
}
.hero-side .img:before{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.24) 1px, transparent 1px);
  background-size: 18px 18px;
  opacity:.20;
}
.hero-side .box{padding:18px}
.hero-side h3{margin:0 0 6px}
.hero-side p{margin:0; color: rgba(255,255,255,.74)}
.hero-side ul{margin: 12px 0 0; padding-left: 18px; color: rgba(255,255,255,.74)}
.hero-side li{margin:6px 0}

.section{padding: 44px 0}
.section h2{margin:0 0 10px; font-size: 28px}
.section p{margin:0 0 16px; color: rgba(255,255,255,.72)}

.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card .card-body{padding:16px}
.card h3{margin:0 0 6px}
.card p{margin:0; color: rgba(255,255,255,.72)}
.card .card-top{
  height: 160px;
  position:relative;
}
.card .card-top:after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(circle at 25% 30%, rgba(255,255,255,.12), transparent 55%);
}
.pills{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}
.pill{font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background: rgba(0,0,0,.18)}

.page-title{padding: 28px 0 0}
.breadcrumb{color: rgba(255,255,255,.70); font-size: 13px}
.page-title h1{margin:6px 0 0; font-size: 34px}

.gallery-filters{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
  margin: 18px 0 22px;
}
.btn-filter{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  font-weight:950;
}
.btn-filter.is-active{
  border-color: rgba(0,229,255,.65);
  box-shadow: 0 0 0 3px rgba(0,229,255,.16);
}
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.g-item{grid-column: span 3}
.g-item a{display:block; text-decoration:none}
.g-thumb{
  width:100%;
  height:190px;
  object-fit:cover;
  display:block;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,.06);
}
.g-cap{padding:10px 6px 0; color: rgba(255,255,255,.72); font-size: 13px}

.form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-weight:950; font-size: 13px}
.field input, .field textarea, .field select{
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.92);
  outline:none;
}
.field input::placeholder, .field textarea::placeholder{color: rgba(255,255,255,.55)}
.field textarea{min-height: 120px; resize: vertical}
.form-actions{grid-column: 1/-1; display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.note{color: rgba(255,255,255,.68); font-size: 13px}

.site-footer{
  margin-top: 44px;
  border-top: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
}
.footer-grid{display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:14px; padding: 26px 0}
.footer-list{list-style:none; padding:0; margin:0}
.footer-list li{margin:8px 0}
.footer-list a{text-decoration:none; opacity:.9}
.footer-list a:hover{text-decoration:underline}
.footer-badges{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}
.badge{font-size:12px; padding:6px 10px; border-radius:999px; background: rgba(0,229,255,.12); border:1px solid rgba(0,229,255,.22)}
.footer-bottom{display:flex; justify-content:space-between; gap:12px; padding: 14px 0; border-top: 1px solid rgba(255,255,255,.12)}
.muted{color: rgba(255,255,255,.72)}

.whatsapp{
  position:fixed; right:16px; bottom:16px; z-index:9999;
  background: linear-gradient(90deg, #25D366, #22c55e);
  color:#06210f; padding:12px 14px; border-radius:999px;
  font-weight:950; text-decoration:none; box-shadow: 0 18px 30px rgba(0,0,0,.35);
  display:flex; align-items:center; gap:10px;
}
.wa-dot{width:10px;height:10px;border-radius:50%; background: rgba(255,255,255,.92)}

@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr}
  .grid-3{grid-template-columns: 1fr 1fr}
  .g-item{grid-column: span 6}
  .footer-grid{grid-template-columns: 1fr 1fr}
}
@media (max-width: 620px){
  .topbar-inner{flex-direction:column; align-items:flex-start}
  .nav{display:none; position:absolute; left:0; right:0; top: 106px; background: rgba(6,8,24,.95); border-bottom:1px solid rgba(255,255,255,.12); padding: 12px 16px; flex-direction:column; align-items:flex-start}
  .nav.is-open{display:flex}
  .nav-toggle{display:inline-block}
  .grid-3{grid-template-columns: 1fr}
  .g-item{grid-column: span 12}
  .form{grid-template-columns: 1fr}
  .footer-bottom{flex-direction:column}
}

/* ---- Cotización (WhatsApp) - formulario profesional en blanco ---- */
.quote-card{
  background: #ffffff !important;
  color: #0f172a;
  border-color: rgba(15,23,42,.14) !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.25);
}
.quote-card h1, .quote-card h2, .quote-card h3, .quote-card p, .quote-card label{
  color:#0f172a;
}
.quote-card .muted{ color: rgba(15,23,42,.72) !important; }
.quote-card .field input,
.quote-card .field textarea,
.quote-card .field select{
  background: #ffffff;
  color: #0f172a;
  border: 1px solid rgba(15,23,42,.16);
}
.quote-card .field input::placeholder,
.quote-card .field textarea::placeholder{
  color: rgba(15,23,42,.45);
}
.quote-card .btn-outline{
  background: transparent;
  border-color: rgba(15,23,42,.18);
  color: #0f172a;
}
.quote-card .btn-outline:hover{
  background: rgba(15,23,42,.04);
}
.quote-card .note{
  color: rgba(15,23,42,.66);
}

/* ---- Luces de evento (fondo animado) ---- */
#eventLights{
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  opacity: .78;
  filter: blur(0.2px);
}


/* ---- Botones claros para Catálogo ---- */
.catalogo-page .btn-primary,
.catalogo-page .card .btn-primary{
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,.25) !important;
  box-shadow: 0 12px 24px rgba(0,0,0,.25);
}
.catalogo-page .btn-primary:hover,
.catalogo-page .card .btn-primary:hover{
  background: #f1f5f9 !important;
}


/* ---- Botones claros globales (alto contraste) ---- */
.btn-primary{
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,.25) !important;
  box-shadow: 0 14px 28px rgba(0,0,0,.30);
}
.btn-primary:hover{
  background: #f1f5f9 !important;
}

/* ---- Galería: filtros más legibles ---- */
.btn-filter{
  background: rgba(255,255,255,.92) !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,.22) !important;
  box-shadow: 0 10px 20px rgba(0,0,0,.25);
}
.btn-filter:hover{
  background: #ffffff !important;
}
.btn-filter.is-active{
  background: linear-gradient(90deg, rgba(0,229,255,.95), rgba(0,229,255,.70)) !important;
  color: #0b1028 !important;
  border-color: rgba(0,229,255,.75) !important;
  box-shadow: 0 0 0 3px rgba(0,229,255,.22), 0 14px 28px rgba(0,0,0,.30);
}

/* ---- Contacto: mostrar cotización al inicio ---- */
.contacto-page .page-title{ padding-top: 14px; }
.contacto-page .quote-card{ margin-top: 16px; }


/* === Card image tops (pro) =============================================== */
.card-top{
  position: relative;
  height: 180px;
  border-radius: 14px 14px 0 0;
  background-image: var(--card-img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}
.card-top::after{
  content:"";
  position:absolute;
  inset:0;
}
@media (max-width: 768px){
  .card-top{ height: 140px; }
}

/* If a card has no body radius, keep the same top rounding */
.card{
  overflow: hidden;
}


.card-top{ 
  background-image: var(--card-img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
/* === Card-top image classes (auto) ===================================== */
.cardimg-arriendo{ --card-img: url("/assets/img/servicios/arriendo.svg"); }
.cardimg-arriendo-estufas{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FEstufas.png?alt=media&token=2d3c310e-ae45-4acc-b6c8-1fe2888dedc8"); }
.cardimg-servicio2{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FSERVICIO_MONTAJE_18.jpeg?alt=media&token=44ff8aef-8249-43f7-83b3-bb0d72d6c4eb"); }
.cardimg-servicio1{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PAPALES_8.jpeg?alt=media&token=899aaa69-e94c-430e-8c20-ee727067db8b"); }
.cardimg-servicio3{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_FREE_10.jpeg?alt=media&token=f4c5803e-6a1a-45ae-9da0-77c8033a8faa"); }
.cardimg-equipo-montaje{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FSERVICIO_MONTAJE_30.jpeg?alt=media&token=4bbecb2b-4eb1-4dd8-a11f-0657d94c8585"); }
.cardimg-malla-acma{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FACMA2.jpeg?alt=media&token=56e8bcf4-d991-4215-94cf-12c70f07c771"); }
.cardimg-vallas-papales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PAPALES_4.jpeg?alt=media&token=da517047-3b3c-4f09-ae7e-649525ef1641"); }
.cardimg-mini-valla-peatonal{ --card-img: url("/assets/img/catalogo/mini-valla-peatonal.svg"); }
.cardimg-montaje{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FSERVICIO_MONTAJE_30.jpeg?alt=media&token=4bbecb2b-4eb1-4dd8-a11f-0657d94c8585"); }
.cardimg-vallas-mini-peatonales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_MINI_PEATONAL_4.jpeg?alt=media&token=6650ea0d-989c-4512-9fb8-f34a102c5060"); }
.cardimg-tipo_1{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PAPALES_2.jpeg?alt=media&token=5d7d26da-9e4f-413e-848d-711895a2203d"); }
.cardimg-tipo_2{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PEATONALES_XXL_6.jpeg?alt=media&token=95fe76df-5f02-4f9e-8961-3946c3afc693"); }
.cardimg-tipo_3{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_FREE_9.jpeg?alt=media&token=040e1129-099d-47eb-a7f9-692871625d76"); }
.cardimg-vallas-peatonales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PEATONALES_9.jpeg?alt=media&token=b0760b5d-941d-4767-8375-563f993ed28c"); }
.cardimg-venta{ --card-img: url("/assets/img/servicios/venta.svg"); }
.cardimg-mallas-acma{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FACMA8.jpeg?alt=media&token=0554b1f9-4fc5-439d-8e25-cbb2253cc4f8"); }
.cardimg-freestanding-contencion{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_FREE_9.jpeg?alt=media&token=040e1129-099d-47eb-a7f9-692871625d76"); }
.cardimg-mini-papales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_MINI_PAPALES_5.jpeg?alt=media&token=ef6fcbfd-5cee-4921-815c-fc07c307fc38"); }
.cardimg-mini-peatonales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_MINI_PEATONAL_2.jpeg?alt=media&token=70efb5bb-75b7-431f-be86-9cdf37e229dd"); }
.cardimg-papales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PAPALES_7.jpeg?alt=media&token=1af550e2-2a2a-48f0-867e-c96081a326e1"); }
.cardimg-peatonal-blanca-xxl{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PEATONALES_XXL_6.jpeg?alt=media&token=95fe76df-5f02-4f9e-8961-3946c3afc693"); }
.cardimg-peatonales{ --card-img: url("https://firebasestorage.googleapis.com/v0/b/micelio-893ec.firebasestorage.app/o/MRVALLAS%2FVALLAS_PEATONALES_3.jpeg?alt=media&token=6ff2c5de-9707-46f5-82b6-fbad075b8510"); }