/* ===== Variables y tema ===== */
:root{
  --header-h: 72px;
  --container-max: 1200px;
  --bg:#0a0a0f;
  --txt:#e9e9f0;
  --muted:#b7b7c9;
  --primary:#7c3aed; /* morado acento */
  --primary-2:#a78bfa;
  --card:#12121a;
  --border:#232336;
  --success:#22c55e;
  --danger:#ef4444;
  --radius:16px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;
  background:radial-gradient(1200px 800px at 20% -10%, #121223 0%, transparent 60%), var(--bg);
  color:var(--txt);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
}

#starfield{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:-1;
}

/* ===== Layout ===== */
.container{width:min(1120px, 92%); margin-inline:auto}
.section{padding:96px 0}
.hero{padding:140px 0 120px}
.title{font-size: clamp(2rem, 3.8vw, 4rem); line-height:1.1; margin:0 0 12px}
.lead{color:var(--muted); font-size:clamp(1rem,1.2vw,1.2rem); max-width:680px}

/* ===== Header / Nav ===== */
.site-header{position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(8px)}
.nav{
  max-width: var(--container-max);
  margin: 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 4%; border-bottom:1px solid rgba(255,255,255,.04);
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.15));
}
.brand{color:#fff; text-decoration:none; font-weight:700}
.hamburger{display:none; background:none; border:0; color:#fff; font-size:1.5rem; cursor:pointer}
.nav-menu{display:flex; gap:24px; list-style:none; margin:0; padding:0}
.nav-menu a{color:var(--muted); text-decoration:none; padding:8px 10px; border-radius:10px}
.nav-menu a.active, .nav-menu a:hover{color:#fff; background:rgba(255,255,255,.06)}

/* ===== UI ===== */
.btn{display:inline-block; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:600; border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-2)); color:#fff}
.btn-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.18)}
.btn-outline{background:transparent; color:#fff; border:1px solid var(--border)}
.btn:hover{transform:translateY(-1px); box-shadow:0 6px 18px rgba(0,0,0,.25)}
.link{color:var(--primary-2); text-decoration:none}
.link:hover{text-decoration:underline}
.h2{font-size:clamp(1.6rem,2.6vw,2.4rem); margin:0 0 8px}

.grid{display:grid; gap:24px}
.cards{grid-template-columns:repeat(auto-fit, minmax(240px,1fr))}
.portfolio{grid-template-columns:repeat(auto-fit, minmax(260px,1fr))}
.pricing{grid-template-columns:repeat(auto-fit, minmax(260px,1fr))}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01) 60%), var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;
}
.card-icon{font-size:1.6rem; margin-bottom:6px}
.price .price-amount{font-size:1.4rem}
.recommended{position:relative; outline:2px solid var(--primary)}
.badge{position:absolute; top:12px; right:12px; background:var(--primary); color:#fff; padding:4px 10px; border-radius:999px; font-size:.75rem}

.filters{display:flex; gap:10px; margin-bottom:18px; flex-wrap:wrap}
.chip{padding:8px 12px; border-radius:999px; border:1px solid var(--border); background:#0f0f18; color:#fff; cursor:pointer}
.chip.active, .chip:hover{background:var(--primary); border-color:transparent}




.form-grid{grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:16px}
.form input, .form textarea{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--border);
  background:#0f0f18; color:#fff
}
.checkbox{display:flex; align-items:center; gap:10px}
.status{min-height:1.4rem; color:var(--muted); margin-top:8px}

.scroll-down{margin-top:24px; background:transparent; border:1px solid rgba(255,255,255,.2); color:#fff; padding:10px 14px; border-radius:999px; cursor:pointer}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.72);
}
.lightbox img{ width:auto; height:auto; max-width:92vw; max-height:82vh; border-radius:12px; border:1px solid var(--border, rgba(255,255,255,.15)); object-fit:contain; }
.lightbox-caption{color:#fff; margin-top:10px; text-align:center}
.lightbox-close{position:absolute; top:16px; right:16px; background:#161625; border:1px solid var(--border); color:#fff; padding:8px 10px; border-radius:10px}

/* Back to top */
.back-to-top{
  position:fixed; right:18px; bottom:18px; display:none;
  background:#161625; color:#fff; border:1px solid var(--border);
  border-radius:12px; padding:10px 12px; cursor:pointer;
}

/* Footer */
.footer{border-top:1px solid rgba(255,255,255,.06); padding:30px 0; color:var(--muted); background:rgba(0,0,0,.2)}

/* Reveal on scroll */
.reveal{opacity:0; transform:translateY(12px); transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1; transform:none}

/* Responsive nav */
@media (max-width: 920px){
  .hamburger{display:block}
  .nav-menu{
    position:fixed; inset:60px 0 auto 0; background:rgba(10,10,16,.96);
    padding:18px; flex-direction:column; gap:12px; transform:translateY(-12px); opacity:0;
    pointer-events:none; transition:opacity .2s ease, transform .2s ease;
  }
  .nav-menu.open{transform:none; opacity:1; pointer-events:auto}
}



/* === 👇 Inyección de Responsividad (auto-fit / minmax, mobile-first) === */
:root{
  --header-h: 72px;
  --container-max: 1200px; --container-max: 1200px; }
*{ box-sizing: border-box }
html, body{ min-height: 100%; }
img{ max-width: 100%; height: auto; display: block; }

.container, .wrap, .inner, .content{
  max-width: var(--container-max);
  width: min(92vw, var(--container-max));
  margin-inline: auto;
}

/* Grids fluidas por defecto */
[class*="grid"], .grid{
  display: grid;
  gap: clamp(12px, 2.8vw, 24px);
}

/* Fallbacks si hay grillas de 3 columnas fijas */
.grid-3, .cards, .pricing, .folio, .portfolio, .services{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

/* Tablas de precios: ajuste */
.pricing .card, .pricing .price-card{ min-width: 0; display:flex; flex-direction:column; }

/* Navbar pegajoso seguro en móviles */
header, .site-header{
  position: sticky; top: 0;
  z-index: 1000;
  backdrop-filter: blur(6px);
}

/* Menú hamburguesa accesible */
.nav-toggle{ display: none; background: none; border: 0; }
@media (max-width: 640px){
  .nav-toggle{ display: inline-flex; align-items:center; justify-content:center; padding: 8px; }
  nav ul, .menu{ display: none; position: absolute; right: 5%; left: 5%; top: calc(100% + 8px);
    background: rgba(15,16,32,.96); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 10px; }
  nav ul.open, .menu.open{ display: flex; flex-direction: column; gap: 10px; }
}

/* Secciones con padding fluido */
section{ padding-block: clamp(56px, 8vw, 112px); }

/* Tipografías fluidas */
h1{ font-size: clamp(1.9rem, 3.6vw, 3.2rem); line-height: 1.15; }
h2{ font-size: clamp(1.4rem, 2.4vw, 2rem); }
p, li, a, label, input, textarea{ font-size: clamp(.96rem, 1.1vw, 1rem); }

/* Evitar scroll horizontal por overflow en elementos */
.row, .card, .tile, .panel{ min-width: 0; }


/* ====== MERGE Pricing (Ref) ====== */


/* === Pricing rules from reference: sitio-precios-starfield/assets/css/styles.css === */
/* =========
   Variables (ajusta aquí la paleta para igualar tu referente)
   Colores de ejemplo (oscuro con acentos morados): 
   Reemplaza por los HEX exactos del sitio de referencia cuando los confirmes.
========== */
:root{
  --header-h: 72px;
  --container-max: 1200px;
  --bg:#0a0a0f;
  --bg-elev: #121225;
  --text:#f3f4f6;
  --muted: #a6a6c9;
  --primary:#7c3aed;
  --primary-600: #6633ff;
  --accent:#a78bfa;
  --card: #14142a;
  --border: #262649;
  --success: #22c55e;
  --danger: #ef4444;
  --shadow: 0 10px 25px rgba(0,0,0,.45);
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
}

/* Starfield canvas behind content */
#starfield{
  position: fixed;
  inset: 0;
  z-index: -1;
  background: radial-gradient(1200px 800px at 70% 20%, rgba(124,77,255,.18), transparent 60%),
              radial-gradient(800px 600px at 20% 80%, rgba(0,229,255,.12), transparent 60%),
              #05050b;
}

/* Header / Nav */
.site-header{
  position: sticky;
  top:0;
  z-index:10;
  backdrop-filter: blur(8px);
  background: linear-gradient(to bottom, rgba(11,11,20,.8), rgba(11,11,20,.4));
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.container{ width:min(1100px, 92%); margin-inline:auto; }
.nav{
  max-width: var(--container-max);
  margin: 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding: .9rem 0;
}
.brand{
  font-weight: 800; letter-spacing:.3px; text-decoration:none; color:var(--text);
}
.nav-menu{
  display:flex; gap:1rem; list-style:none; margin:0; padding:0;
}
.nav-menu a{
  color:var(--muted); text-decoration:none; padding:.4rem .7rem; border-radius:.6rem;
  transition: transform .2s ease, background .2s ease, color .2s ease;
}
.nav-menu a:hover, .nav-menu a.active{ color:var(--text); background: rgba(124,77,255,.14); }

.nav-toggle{ display:none; background:none; border:0; }
.nav-toggle .bar{ display:block; width:22px; height:2px; background:var(--text); margin:5px 0; }

/* Hero */
.hero{ padding: 5.5rem 0 3rem; text-align:center; }
.hero h1{ font-size: clamp(2rem, 4vw, 3rem); margin:0 0 .6rem; }
.hero .accent{ color: var(--accent); }
.lead{ color:var(--muted); margin:.2rem auto 1.4rem; max-width: 60ch; }

.hero-cta{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

.btn{
  display:inline-block; border:1px solid var(--border); padding:.75rem 1rem; border-radius:.9rem;
  text-decoration:none; color:var(--text); transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  will-change: transform;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-primary{ background: linear-gradient(180deg, var(--primary), var(--primary-600)); border-color: transparent; }
.btn-ghost{ background: transparent; }

/* Features */
.features{ padding: 2rem 0 1rem; }
.feature-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1rem; padding:0; margin:1rem 0 0; list-style:none;
}
.card{
  background: var(--card); border: 1px solid var(--border); border-radius: 1rem; padding:1rem;
  box-shadow: var(--shadow);
}

/* Pricing */
.pricing{ padding: 3rem 0; }
.pricing-head{ text-align:center; margin-bottom: 1rem; }
.pricing .sub{ color:var(--muted); }

.toggle-row{
  display:flex; gap:.5rem; justify-content:center; margin:1rem 0 2rem;
}
.toggle{
  background: var(--card); color:var(--text); border:1px solid var(--border);
  padding:.55rem .9rem; border-radius:.7rem; cursor:pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.toggle:hover{ transform: translateY(-1px); }
.toggle.active{ background: rgba(124,77,255,.2); border-color: rgba(124,77,255,.4); }
.badge{ background: rgba(124,77,255,.18); border:1px solid rgba(124,77,255,.4); color: var(--text); padding:.2rem .5rem; border-radius:999px; font-size:.8rem; }
.badge.ahorra{ background: rgba(34,197,94,.18); border-color: rgba(34,197,94,.5); }

.pricing-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem;
}
.price-card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 1.1rem; padding:1.1rem; position:relative; overflow:hidden;
}
.price-card .card-head h3{ margin:.4rem 0 .4rem; font-size: 2rem; }
.price-card .price{ font-weight: 800; letter-spacing:.3px; }
.price-card .features-list{ list-style:none; padding:0; margin:1rem 0; color:var(--text); }
.price-card .features-list li{ margin:.35rem 0; color: var(--muted); }
.price-card .btn{ width:100%; text-align:center; }

.price-card.featured{
  border-color: rgba(124,77,255,.6);
  box-shadow: 0 0 0 2px rgba(124,77,255,.18), var(--shadow);
  transform: translateY(-2px);
}
.ribbon{
  position:absolute; top:12px; right:-30px; transform: rotate(45deg);
  background: linear-gradient(90deg, var(--accent), var(--primary));
  color:#05050b; font-weight:700; font-size:.8rem; padding:.3rem 2.4rem;
}

/* Contact */
.contact{ padding: 2rem 0 4rem; }
.contact-form{
  background: var(--card); border: 1px solid var(--border); border-radius: 1rem;
  padding:1rem; max-width: 640px; margin: 0 auto;
  display:grid; gap:.8rem;
}
.contact-form label{ display:grid; gap:.3rem; color: var(--muted); }
.contact-form input, .contact-form textarea{
  width:100%; background:#0f0f1e; color:var(--text);
  border:1px solid var(--border); border-radius:.6rem; padding:.7rem .8rem;
}

/* Footer */
.site-footer{ padding: 1.2rem 0; border-top: 1px solid rgba(255,255,255,.06); background: rgba(0,0,0,.2); }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.footer-inner .socials{ list-style:none; display:flex; gap:.8rem; padding:0; margin:0; }
.footer-inner a{ color:var(--muted); text-decoration:none; }
.footer-inner a:hover{ color:var(--text); }

/* Responsive */
@media (max-width: 1024px){
  .feature-grid{ grid-template-columns: repeat(2,1fr); }
  .pricing-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px){
  .nav-toggle{ display:block; }
  .nav-menu{ display:none; position:absolute; right:4%; top:52px; background: var(--bg-elev); padding:.6rem; border:1px solid var(--border); border-radius:.8rem; }
  .nav-menu.open{ display:flex; flex-direction:column; }
  .feature-grid{ grid-template-columns: 1fr; }
  .pricing-grid{ grid-template-columns: 1fr; }
  .hero{ padding-top: 4.5rem; }
}

/* Motion reduction */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}



/* === Branding Studio 11 (morado) + mejoras Planes === */
.price-card.featured{
  border-color: color-mix(in oklab, var(--primary) 55%, #ffffff 0%);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--primary) 30%, transparent 70%) inset, var(--shadow);
}
.price-card.featured h3{ color: var(--primary); }

.price-card .deal{
  display:inline-block; margin-top:.2rem; font-weight:700; font-size:.85rem;
  color: var(--accent); background: rgba(167,139,250,.14);
  border:1px solid rgba(167,139,250,.35); padding:.25rem .5rem; border-radius:999px;
}

/* Tooltip */
.tip{ position:relative; cursor:help; border-bottom:1px dotted rgba(255,255,255,.35) }
.tip[data-tooltip]:hover::after{
  content: attr(data-tooltip);
  position:absolute; bottom: 125%; left: 50%; transform: translateX(-50%);
  background:#1a1a2a; color:#fff; padding:.45rem .6rem; border-radius:8px;
  border:1px solid rgba(255,255,255,.08); white-space:nowrap; font-size:.8rem; z-index:10;
  box-shadow: var(--shadow);
}
.tip[data-tooltip]:hover::before{
  content:""; position:absolute; bottom: 115%; left:50%; transform:translateX(-50%);
  border:6px solid transparent; border-top-color:#1a1a2a;
}

/* Currency controls */
.pricing-controls{ display:flex; align-items:center; justify-content:center; gap:.5rem; margin:.8rem 0 1.2rem }
.currency-btn{
  background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:999px; padding:.45rem .9rem; font-weight:700; cursor:pointer;
}
.currency-btn.active{ background: linear-gradient(135deg, var(--primary), #6d28d9); border-color: transparent; }
.price .code{ font-size:.55em; opacity:.8; margin-left:.25rem }


/* Billing controls (Mensual / Anual) */
.billing-controls{ display:flex; align-items:center; justify-content:center; gap:.5rem; margin:-.2rem 0 1.2rem }
.billing-btn{
  background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:999px; padding:.45rem .9rem; font-weight:700; cursor:pointer;
}
.billing-btn.active{ background: linear-gradient(135deg, var(--primary), #6d28d9); border-color: transparent; }
.price .period{ margin-left:.25rem; opacity:.8; font-size:.6em }
.price .strike{ text-decoration: line-through; opacity:.6; font-size:.7em; margin-left:.4rem }


/* Unified controls row */
.controls-row{
  display:flex; align-items:center; justify-content:center;
  gap:.8rem; flex-wrap:wrap; margin:.4rem 0 1.2rem;
}
.controls-row .pricing-controls, .controls-row .billing-controls{
  display:flex; gap:.5rem;
}


/* === Estilo de "Planes y Precios" como imagen adjunta === */
.pricing{ gap: clamp(16px, 2.4vw, 24px); }
.price-card{
  position: relative;
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 24px);
  background: linear-gradient(180deg, rgba(20,20,36,.9), rgba(12,12,24,.95));
  border: 1px solid rgba(167,139,250,.18);
  box-shadow: 0 8px 28px rgba(0,0,0,.35);
}
.price-card:hover{ transform: translateY(-2px); transition: transform .18s ease; }

.price-card .plan-pill{
  display:inline-block; font-weight:700; font-size:.8rem; letter-spacing:.2px;
  color:#c7b8ff; background: rgba(124,58,237,.15);
  border:1px solid rgba(124,58,237,.45);
  border-radius: 999px; padding:.25rem .6rem; margin-bottom:.4rem;
}

.price-card .price{ font-size: clamp(2rem, 4vw, 2.6rem); font-weight: 800; }
.price-card .price .period{ opacity:.85; font-weight:700; }
.price-card p{ color: var(--muted); margin-top:.2rem; margin-bottom:.6rem; }

.price-card .features{ list-style:none; padding:0; margin:.2rem 0 1rem; display:grid; gap:.45rem; }
.price-card .features li{
  position: relative; padding-left: 1.35rem;
}
.price-card .features li::before{
  content: '✔'; position:absolute; left:0; top:0; line-height:1;
  opacity:.8; color:#a78bfa; font-weight:900;
}

.price-card .btn{ width: 100%; border-radius: 16px; padding: .9rem 1rem; margin-top:.6rem; }
.price-card .btn.primary{ background: linear-gradient(180deg, #8b5cf6, #6d28d9); }

.price-card.featured{
  background: linear-gradient(180deg, rgba(18,18,36,1), rgba(10,10,20,1));
  border-color: rgba(124,58,237,.55);
  box-shadow: 0 0 0 2px rgba(124,58,237,.25) inset, 0 16px 60px rgba(124,58,237,.15);
}

/* Diagonal ribbon Popular */
.price-card .ribbon{
  position:absolute; top:12px; right:-34px; transform: rotate(45deg);
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  color:#0b0b12; font-weight:800; font-size:.8rem;
  padding:.25rem 2.1rem; border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

/* Controles segmentados (más pill) */
.controls-row .currency-btn, .controls-row .billing-btn{
  border-radius: 12px; padding:.5rem 1rem; font-weight:700;
  border:1px solid rgba(167,139,250,.25);
  background: rgba(255,255,255,.03);
}
.controls-row .currency-btn.active, .controls-row .billing-btn.active{
  background: linear-gradient(180deg, #8b5cf6, #6d28d9); border-color: transparent;
  box-shadow: 0 6px 22px rgba(109,40,217,.35);
}

.pricing-note{
  color: var(--muted);
  margin-top: .8rem;
}


/* === Corrección estilo Planes y Precios (pixel closer) === */
.section#planes .section-title, #planes .section-title{ text-align:center; }
#planes .section-sub{ text-align:center; color:var(--muted); margin-top:.25rem; margin-bottom:1rem; }

.controls-row{
  display:flex; align-items:center; justify-content:center; gap:.8rem; flex-wrap:wrap;
  margin:.6rem 0 1.4rem;
}
.controls-row .currency-btn, .controls-row .billing-btn{
  border-radius: 14px; padding:.55rem 1.05rem; font-weight:700;
  border:1px solid rgba(167,139,250,.22);
  background: rgba(255,255,255,.03);
}
.controls-row .billing-btn[data-bill="Y"]{
  position:relative;
}
.controls-row .billing-btn[data-bill="Y"]::after{
  content:"Ahorra 20%";
  position:absolute; top:-10px; right:-10px;
  background: linear-gradient(135deg, #34d399, #22c55e);
  color:#04120a; font-weight:800; font-size:.7rem; padding:.15rem .5rem;
  border-radius:999px; box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.controls-row .currency-btn.active, .controls-row .billing-btn.active{
  background: linear-gradient(180deg, #8b5cf6, #6d28d9); border-color: transparent;
  box-shadow: 0 6px 22px rgba(109,40,217,.35);
}

.pricing{
  display:grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap: clamp(18px, 2.4vw, 28px);
}
.price-card{
  position:relative; background: linear-gradient(180deg, rgba(20,20,36,.95), rgba(12,12,24,.98));
  border:1px solid rgba(124,58,237,.22);
  border-radius: 22px; padding: clamp(18px, 2.4vw, 26px);
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
  transition: transform .18s ease, box-shadow .18s ease;
}
.price-card:hover{ transform: translateY(-2px); box-shadow: 0 18px 60px rgba(0,0,0,.45); }

.price-card .plan-pill{
  display:inline-block; font-weight:800; font-size:.8rem;
  color:#d7ccff; background: rgba(124,58,237,.16);
  border:1px solid rgba(124,58,237,.45);
  border-radius: 999px; padding:.28rem .62rem; margin-bottom:.5rem;
}
.price-card h3{ margin:.2rem 0 .4rem }

.price-card .price{
  font-size: clamp(2.1rem, 4.2vw, 2.8rem); font-weight: 900; letter-spacing:.2px;
}
.price-card .price .period{ opacity:.9; font-weight:800 }
.price-card .price .code{ display:none } /* oculta MXN/USD al lado del precio */

.price-card p{ color: var(--muted); margin:.25rem 0 .7rem }

.price-card .features{ list-style:none; padding:0; margin:.2rem 0 1rem; display:grid; gap:.5rem }
.price-card .features li{ position:relative; padding-left: 1.35rem }
.price-card .features li::before{
  content:'✔'; position:absolute; left:0; top:0; line-height:1;
  color:#a78bfa; font-weight:900; opacity:.9;
}

.price-card .btn{ width:100%; border-radius: 16px; padding:.95rem 1rem; margin-top:.6rem }
.price-card .btn.primary{ background: linear-gradient(180deg, #8b5cf6, #6d28d9); }

.price-card.featured{
  background: linear-gradient(180deg, rgba(18,18,36,1), rgba(10,10,20,1));
  border-color: rgba(124,58,237,.55);
  box-shadow: 0 0 0 2px rgba(124,58,237,.25) inset, 0 22px 70px rgba(124,58,237,.18);
}
.price-card .ribbon{
  position:absolute; top:12px; right:-34px; transform: rotate(45deg);
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  color:#0b0b12; font-weight:800; font-size:.8rem;
  padding:.28rem 2.1rem; border-radius: 6px; box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

.pricing-note{ color: var(--muted); margin-top:.9rem; text-align:center }



/* Fixes: pricing featured and switch */
.price-card{ position: relative; }
.price-card .badge{ position:absolute; top:12px; right:12px; font-size:.75rem; background:linear-gradient(135deg, var(--primary), var(--primary-2)); color:#fff; padding:.25rem .5rem; border-radius:.5rem; }
.switch{ position:relative; width:46px; height:26px; display:inline-block; }
.switch input{ opacity:0; width:0; height:0; }
.switch .slider{ position:absolute; cursor:pointer; inset:0; background:rgba(255,255,255,.12); border:1px solid var(--border); border-radius:999px; transition: .2s; }
.switch .slider:before{ content:""; position:absolute; height:18px; width:18px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.2s; }
.switch input:checked + .slider{ background:linear-gradient(135deg, var(--primary), var(--primary-2)); }
.switch input:checked + .slider:before{ transform: translateX(20px); }
@media (max-width:640px){
  .pricing-grid{ grid-template-columns: 1fr; }
}



/* Mobile nav button fix */
.hamburger{ display:none; background:none; border:0; color:var(--text); font-size:1.3rem; }
@media (max-width: 640px){
  .hamburger{ display:inline-flex; align-items:center; justify-content:center; padding:8px; }
}

canvas#starfield{ position:fixed; inset:0; z-index:-1; }


/* === Desktop fixed header + safe anchor offset === */
@media (min-width: 1024px){
  .site-header{ position: fixed; top: 0; left: 0; right: 0; z-index: 1000; }
  body{ padding-top: var(--header-h); }
}

/* Ensure section anchors aren't covered by the fixed header */
main section[id]{ scroll-margin-top: calc(var(--header-h) + 12px); }


/* === Appended from css_styles.css === */
/* ===== Variables y tema ===== */
:root{
  --header-h: 72px;
  --container-max: 1200px;
  --bg:#0a0a0f;
  --txt:#e9e9f0;
  --muted:#b7b7c9;
  --primary:#7c3aed; /* morado acento */
  --primary-2:#a78bfa;
  --card:#12121a;
  --border:#232336;
  --success:#22c55e;
  --danger:#ef4444;
  --radius:16px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;
  background:radial-gradient(1200px 800px at 20% -10%, #121223 0%, transparent 60%), var(--bg);
  color:var(--txt);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
}

#starfield{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:-1;
}

/* ===== Layout ===== */
.container{width:min(1120px, 92%); margin-inline:auto}
.section{padding:96px 0}
.hero{padding:140px 0 120px}
.title{font-size: clamp(2rem, 3.8vw, 4rem); line-height:1.1; margin:0 0 12px}
.lead{color:var(--muted); font-size:clamp(1rem,1.2vw,1.2rem); max-width:680px}

/* ===== Header / Nav ===== */
.site-header{position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(8px)}
.nav{
  max-width: var(--container-max);
  margin: 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 4%; border-bottom:1px solid rgba(255,255,255,.04);
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.15));
}
.brand{color:#fff; text-decoration:none; font-weight:700}
.hamburger{display:none; background:none; border:0; color:#fff; font-size:1.5rem; cursor:pointer}
.nav-menu{display:flex; gap:24px; list-style:none; margin:0; padding:0}
.nav-menu a{color:var(--muted); text-decoration:none; padding:8px 10px; border-radius:10px}
.nav-menu a.active, .nav-menu a:hover{color:#fff; background:rgba(255,255,255,.06)}

/* ===== UI ===== */
.btn{display:inline-block; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:600; border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-2)); color:#fff}
.btn-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.18)}
.btn-outline{background:transparent; color:#fff; border:1px solid var(--border)}
.btn:hover{transform:translateY(-1px); box-shadow:0 6px 18px rgba(0,0,0,.25)}
.link{color:var(--primary-2); text-decoration:none}
.link:hover{text-decoration:underline}
.h2{font-size:clamp(1.6rem,2.6vw,2.4rem); margin:0 0 8px}

.grid{display:grid; gap:24px}
.cards{grid-template-columns:repeat(auto-fit, minmax(240px,1fr))}
.portfolio{grid-template-columns:repeat(auto-fit, minmax(260px,1fr))}
.pricing{grid-template-columns:repeat(auto-fit, minmax(260px,1fr))}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01) 60%), var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;
}
.card-icon{font-size:1.6rem; margin-bottom:6px}
.price .price-amount{font-size:1.4rem}
.recommended{position:relative; outline:2px solid var(--primary)}
.badge{position:absolute; top:12px; right:12px; background:var(--primary); color:#fff; padding:4px 10px; border-radius:999px; font-size:.75rem}

.filters{display:flex; gap:10px; margin-bottom:18px; flex-wrap:wrap}
.chip{padding:8px 12px; border-radius:999px; border:1px solid var(--border); background:#0f0f18; color:#fff; cursor:pointer}
.chip.active, .chip:hover{background:var(--primary); border-color:transparent}




.form-grid{grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:16px}
.form input, .form textarea{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--border);
  background:#0f0f18; color:#fff
}
.checkbox{display:flex; align-items:center; gap:10px}
.status{min-height:1.4rem; color:var(--muted); margin-top:8px}

.scroll-down{margin-top:24px; background:transparent; border:1px solid rgba(255,255,255,.2); color:#fff; padding:10px 14px; border-radius:999px; cursor:pointer}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.72);
}
.lightbox img{ width:auto; height:auto; max-width:92vw; max-height:82vh; border-radius:12px; border:1px solid var(--border, rgba(255,255,255,.15)); object-fit:contain; }
.lightbox-caption{color:#fff; margin-top:10px; text-align:center}
.lightbox-close{position:absolute; top:16px; right:16px; background:#161625; border:1px solid var(--border); color:#fff; padding:8px 10px; border-radius:10px}

/* Back to top */
.back-to-top{
  position:fixed; right:18px; bottom:18px; display:none;
  background:#161625; color:#fff; border:1px solid var(--border);
  border-radius:12px; padding:10px 12px; cursor:pointer;
}

/* Footer */
.footer{border-top:1px solid rgba(255,255,255,.06); padding:30px 0; color:var(--muted); background:rgba(0,0,0,.2)}

/* Reveal on scroll */
.reveal{opacity:0; transform:translateY(12px); transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1; transform:none}

/* Responsive nav */
@media (max-width: 920px){
  .hamburger{display:block}
  .nav-menu{
    position:fixed; inset:60px 0 auto 0; background:rgba(10,10,16,.96);
    padding:18px; flex-direction:column; gap:12px; transform:translateY(-12px); opacity:0;
    pointer-events:none; transition:opacity .2s ease, transform .2s ease;
  }
  .nav-menu.open{transform:none; opacity:1; pointer-events:auto}
}



/* === 👇 Inyección de Responsividad (auto-fit / minmax, mobile-first) === */
:root{
  --header-h: 72px;
  --container-max: 1200px; --container-max: 1200px; }
*{ box-sizing: border-box }
html, body{ min-height: 100%; }
img{ max-width: 100%; height: auto; display: block; }

.container, .wrap, .inner, .content{
  max-width: var(--container-max);
  width: min(92vw, var(--container-max));
  margin-inline: auto;
}

/* Grids fluidas por defecto */
[class*="grid"], .grid{
  display: grid;
  gap: clamp(12px, 2.8vw, 24px);
}

/* Fallbacks si hay grillas de 3 columnas fijas */
.grid-3, .cards, .pricing, .folio, .portfolio, .services{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

/* Tablas de precios: ajuste */
.pricing .card, .pricing .price-card{ min-width: 0; display:flex; flex-direction:column; }

/* Navbar pegajoso seguro en móviles */
header, .site-header{
  position: sticky; top: 0;
  z-index: 1000;
  backdrop-filter: blur(6px);
}

/* Menú hamburguesa accesible */
.nav-toggle{ display: none; background: none; border: 0; }
@media (max-width: 640px){
  .nav-toggle{ display: inline-flex; align-items:center; justify-content:center; padding: 8px; }
  nav ul, .menu{ display: none; position: absolute; right: 5%; left: 5%; top: calc(100% + 8px);
    background: rgba(15,16,32,.96); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 10px; }
  nav ul.open, .menu.open{ display: flex; flex-direction: column; gap: 10px; }
}

/* Secciones con padding fluido */
section{ padding-block: clamp(56px, 8vw, 112px); }

/* Tipografías fluidas */
h1{ font-size: clamp(1.9rem, 3.6vw, 3.2rem); line-height: 1.15; }
h2{ font-size: clamp(1.4rem, 2.4vw, 2rem); }
p, li, a, label, input, textarea{ font-size: clamp(.96rem, 1.1vw, 1rem); }

/* Evitar scroll horizontal por overflow en elementos */
.row, .card, .tile, .panel{ min-width: 0; }


/* ====== MERGE Pricing (Ref) ====== */


/* === Pricing rules from reference: sitio-precios-starfield/assets/css/styles.css === */
/* =========
   Variables (ajusta aquí la paleta para igualar tu referente)
   Colores de ejemplo (oscuro con acentos morados): 
   Reemplaza por los HEX exactos del sitio de referencia cuando los confirmes.
========== */
:root{
  --header-h: 72px;
  --container-max: 1200px;
  --bg:#0a0a0f;
  --bg-elev: #121225;
  --text:#f3f4f6;
  --muted: #a6a6c9;
  --primary:#7c3aed;
  --primary-600: #6633ff;
  --accent:#a78bfa;
  --card: #14142a;
  --border: #262649;
  --success: #22c55e;
  --danger: #ef4444;
  --shadow: 0 10px 25px rgba(0,0,0,.45);
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
}

/* Starfield canvas behind content */
#starfield{
  position: fixed;
  inset: 0;
  z-index: -1;
  background: radial-gradient(1200px 800px at 70% 20%, rgba(124,77,255,.18), transparent 60%),
              radial-gradient(800px 600px at 20% 80%, rgba(0,229,255,.12), transparent 60%),
              #05050b;
}

/* Header / Nav */
.site-header{
  position: sticky;
  top:0;
  z-index:10;
  backdrop-filter: blur(8px);
  background: linear-gradient(to bottom, rgba(11,11,20,.8), rgba(11,11,20,.4));
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.container{ width:min(1100px, 92%); margin-inline:auto; }
.nav{
  max-width: var(--container-max);
  margin: 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding: .9rem 0;
}
.brand{
  font-weight: 800; letter-spacing:.3px; text-decoration:none; color:var(--text);
}
.nav-menu{
  display:flex; gap:1rem; list-style:none; margin:0; padding:0;
}
.nav-menu a{
  color:var(--muted); text-decoration:none; padding:.4rem .7rem; border-radius:.6rem;
  transition: transform .2s ease, background .2s ease, color .2s ease;
}
.nav-menu a:hover, .nav-menu a.active{ color:var(--text); background: rgba(124,77,255,.14); }

.nav-toggle{ display:none; background:none; border:0; }
.nav-toggle .bar{ display:block; width:22px; height:2px; background:var(--text); margin:5px 0; }

/* Hero */
.hero{ padding: 5.5rem 0 3rem; text-align:center; }
.hero h1{ font-size: clamp(2rem, 4vw, 3rem); margin:0 0 .6rem; }
.hero .accent{ color: var(--accent); }
.lead{ color:var(--muted); margin:.2rem auto 1.4rem; max-width: 60ch; }

.hero-cta{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

.btn{
  display:inline-block; border:1px solid var(--border); padding:.75rem 1rem; border-radius:.9rem;
  text-decoration:none; color:var(--text); transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  will-change: transform;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-primary{ background: linear-gradient(180deg, var(--primary), var(--primary-600)); border-color: transparent; }
.btn-ghost{ background: transparent; }

/* Features */
.features{ padding: 2rem 0 1rem; }
.feature-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1rem; padding:0; margin:1rem 0 0; list-style:none;
}
.card{
  background: var(--card); border: 1px solid var(--border); border-radius: 1rem; padding:1rem;
  box-shadow: var(--shadow);
}

/* Pricing */
.pricing{ padding: 3rem 0; }
.pricing-head{ text-align:center; margin-bottom: 1rem; }
.pricing .sub{ color:var(--muted); }

.toggle-row{
  display:flex; gap:.5rem; justify-content:center; margin:1rem 0 2rem;
}
.toggle{
  background: var(--card); color:var(--text); border:1px solid var(--border);
  padding:.55rem .9rem; border-radius:.7rem; cursor:pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.toggle:hover{ transform: translateY(-1px); }
.toggle.active{ background: rgba(124,77,255,.2); border-color: rgba(124,77,255,.4); }
.badge{ background: rgba(124,77,255,.18); border:1px solid rgba(124,77,255,.4); color: var(--text); padding:.2rem .5rem; border-radius:999px; font-size:.8rem; }
.badge.ahorra{ background: rgba(34,197,94,.18); border-color: rgba(34,197,94,.5); }

.pricing-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem;
}
.price-card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 1.1rem; padding:1.1rem; position:relative; overflow:hidden;
}
.price-card .card-head h3{ margin:.4rem 0 .4rem; font-size: 2rem; }
.price-card .price{ font-weight: 800; letter-spacing:.3px; }
.price-card .features-list{ list-style:none; padding:0; margin:1rem 0; color:var(--text); }
.price-card .features-list li{ margin:.35rem 0; color: var(--muted); }
.price-card .btn{ width:100%; text-align:center; }

.price-card.featured{
  border-color: rgba(124,77,255,.6);
  box-shadow: 0 0 0 2px rgba(124,77,255,.18), var(--shadow);
  transform: translateY(-2px);
}
.ribbon{
  position:absolute; top:12px; right:-30px; transform: rotate(45deg);
  background: linear-gradient(90deg, var(--accent), var(--primary));
  color:#05050b; font-weight:700; font-size:.8rem; padding:.3rem 2.4rem;
}

/* Contact */
.contact{ padding: 2rem 0 4rem; }
.contact-form{
  background: var(--card); border: 1px solid var(--border); border-radius: 1rem;
  padding:1rem; max-width: 640px; margin: 0 auto;
  display:grid; gap:.8rem;
}
.contact-form label{ display:grid; gap:.3rem; color: var(--muted); }
.contact-form input, .contact-form textarea{
  width:100%; background:#0f0f1e; color:var(--text);
  border:1px solid var(--border); border-radius:.6rem; padding:.7rem .8rem;
}

/* Footer */
.site-footer{ padding: 1.2rem 0; border-top: 1px solid rgba(255,255,255,.06); background: rgba(0,0,0,.2); }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.footer-inner .socials{ list-style:none; display:flex; gap:.8rem; padding:0; margin:0; }
.footer-inner a{ color:var(--muted); text-decoration:none; }
.footer-inner a:hover{ color:var(--text); }

/* Responsive */
@media (max-width: 1024px){
  .feature-grid{ grid-template-columns: repeat(2,1fr); }
  .pricing-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px){
  .nav-toggle{ display:block; }
  .nav-menu{ display:none; position:absolute; right:4%; top:52px; background: var(--bg-elev); padding:.6rem; border:1px solid var(--border); border-radius:.8rem; }
  .nav-menu.open{ display:flex; flex-direction:column; }
  .feature-grid{ grid-template-columns: 1fr; }
  .pricing-grid{ grid-template-columns: 1fr; }
  .hero{ padding-top: 4.5rem; }
}

/* Motion reduction */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}



/* === Branding Studio 11 (morado) + mejoras Planes === */
.price-card.featured{
  border-color: color-mix(in oklab, var(--primary) 55%, #ffffff 0%);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--primary) 30%, transparent 70%) inset, var(--shadow);
}
.price-card.featured h3{ color: var(--primary); }

.price-card .deal{
  display:inline-block; margin-top:.2rem; font-weight:700; font-size:.85rem;
  color: var(--accent); background: rgba(167,139,250,.14);
  border:1px solid rgba(167,139,250,.35); padding:.25rem .5rem; border-radius:999px;
}

/* Tooltip */
.tip{ position:relative; cursor:help; border-bottom:1px dotted rgba(255,255,255,.35) }
.tip[data-tooltip]:hover::after{
  content: attr(data-tooltip);
  position:absolute; bottom: 125%; left: 50%; transform: translateX(-50%);
  background:#1a1a2a; color:#fff; padding:.45rem .6rem; border-radius:8px;
  border:1px solid rgba(255,255,255,.08); white-space:nowrap; font-size:.8rem; z-index:10;
  box-shadow: var(--shadow);
}
.tip[data-tooltip]:hover::before{
  content:""; position:absolute; bottom: 115%; left:50%; transform:translateX(-50%);
  border:6px solid transparent; border-top-color:#1a1a2a;
}

/* Currency controls */
.pricing-controls{ display:flex; align-items:center; justify-content:center; gap:.5rem; margin:.8rem 0 1.2rem }
.currency-btn{
  background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:999px; padding:.45rem .9rem; font-weight:700; cursor:pointer;
}
.currency-btn.active{ background: linear-gradient(135deg, var(--primary), #6d28d9); border-color: transparent; }
.price .code{ font-size:.55em; opacity:.8; margin-left:.25rem }


/* Billing controls (Mensual / Anual) */
.billing-controls{ display:flex; align-items:center; justify-content:center; gap:.5rem; margin:-.2rem 0 1.2rem }
.billing-btn{
  background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:999px; padding:.45rem .9rem; font-weight:700; cursor:pointer;
}
.billing-btn.active{ background: linear-gradient(135deg, var(--primary), #6d28d9); border-color: transparent; }
.price .period{ margin-left:.25rem; opacity:.8; font-size:.6em }
.price .strike{ text-decoration: line-through; opacity:.6; font-size:.7em; margin-left:.4rem }


/* Unified controls row */
.controls-row{
  display:flex; align-items:center; justify-content:center;
  gap:.8rem; flex-wrap:wrap; margin:.4rem 0 1.2rem;
}
.controls-row .pricing-controls, .controls-row .billing-controls{
  display:flex; gap:.5rem;
}


/* === Estilo de "Planes y Precios" como imagen adjunta === */
.pricing{ gap: clamp(16px, 2.4vw, 24px); }
.price-card{
  position: relative;
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 24px);
  background: linear-gradient(180deg, rgba(20,20,36,.9), rgba(12,12,24,.95));
  border: 1px solid rgba(167,139,250,.18);
  box-shadow: 0 8px 28px rgba(0,0,0,.35);
}
.price-card:hover{ transform: translateY(-2px); transition: transform .18s ease; }

.price-card .plan-pill{
  display:inline-block; font-weight:700; font-size:.8rem; letter-spacing:.2px;
  color:#c7b8ff; background: rgba(124,58,237,.15);
  border:1px solid rgba(124,58,237,.45);
  border-radius: 999px; padding:.25rem .6rem; margin-bottom:.4rem;
}

.price-card .price{ font-size: clamp(2rem, 4vw, 2.6rem); font-weight: 800; }
.price-card .price .period{ opacity:.85; font-weight:700; }
.price-card p{ color: var(--muted); margin-top:.2rem; margin-bottom:.6rem; }

.price-card .features{ list-style:none; padding:0; margin:.2rem 0 1rem; display:grid; gap:.45rem; }
.price-card .features li{
  position: relative; padding-left: 1.35rem;
}
.price-card .features li::before{
  content: '✔'; position:absolute; left:0; top:0; line-height:1;
  opacity:.8; color:#a78bfa; font-weight:900;
}

.price-card .btn{ width: 100%; border-radius: 16px; padding: .9rem 1rem; margin-top:.6rem; }
.price-card .btn.primary{ background: linear-gradient(180deg, #8b5cf6, #6d28d9); }

.price-card.featured{
  background: linear-gradient(180deg, rgba(18,18,36,1), rgba(10,10,20,1));
  border-color: rgba(124,58,237,.55);
  box-shadow: 0 0 0 2px rgba(124,58,237,.25) inset, 0 16px 60px rgba(124,58,237,.15);
}

/* Diagonal ribbon Popular */
.price-card .ribbon{
  position:absolute; top:12px; right:-34px; transform: rotate(45deg);
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  color:#0b0b12; font-weight:800; font-size:.8rem;
  padding:.25rem 2.1rem; border-radius: 6px;
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

/* Controles segmentados (más pill) */
.controls-row .currency-btn, .controls-row .billing-btn{
  border-radius: 12px; padding:.5rem 1rem; font-weight:700;
  border:1px solid rgba(167,139,250,.25);
  background: rgba(255,255,255,.03);
}
.controls-row .currency-btn.active, .controls-row .billing-btn.active{
  background: linear-gradient(180deg, #8b5cf6, #6d28d9); border-color: transparent;
  box-shadow: 0 6px 22px rgba(109,40,217,.35);
}

.pricing-note{
  color: var(--muted);
  margin-top: .8rem;
}


/* === Corrección estilo Planes y Precios (pixel closer) === */
.section#planes .section-title, #planes .section-title{ text-align:center; }
#planes .section-sub{ text-align:center; color:var(--muted); margin-top:.25rem; margin-bottom:1rem; }

.controls-row{
  display:flex; align-items:center; justify-content:center; gap:.8rem; flex-wrap:wrap;
  margin:.6rem 0 1.4rem;
}
.controls-row .currency-btn, .controls-row .billing-btn{
  border-radius: 14px; padding:.55rem 1.05rem; font-weight:700;
  border:1px solid rgba(167,139,250,.22);
  background: rgba(255,255,255,.03);
}
.controls-row .billing-btn[data-bill="Y"]{
  position:relative;
}
.controls-row .billing-btn[data-bill="Y"]::after{
  content:"Ahorra 20%";
  position:absolute; top:-10px; right:-10px;
  background: linear-gradient(135deg, #34d399, #22c55e);
  color:#04120a; font-weight:800; font-size:.7rem; padding:.15rem .5rem;
  border-radius:999px; box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.controls-row .currency-btn.active, .controls-row .billing-btn.active{
  background: linear-gradient(180deg, #8b5cf6, #6d28d9); border-color: transparent;
  box-shadow: 0 6px 22px rgba(109,40,217,.35);
}

.pricing{
  display:grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap: clamp(18px, 2.4vw, 28px);
}
.price-card{
  position:relative; background: linear-gradient(180deg, rgba(20,20,36,.95), rgba(12,12,24,.98));
  border:1px solid rgba(124,58,237,.22);
  border-radius: 22px; padding: clamp(18px, 2.4vw, 26px);
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
  transition: transform .18s ease, box-shadow .18s ease;
}
.price-card:hover{ transform: translateY(-2px); box-shadow: 0 18px 60px rgba(0,0,0,.45); }

.price-card .plan-pill{
  display:inline-block; font-weight:800; font-size:.8rem;
  color:#d7ccff; background: rgba(124,58,237,.16);
  border:1px solid rgba(124,58,237,.45);
  border-radius: 999px; padding:.28rem .62rem; margin-bottom:.5rem;
}
.price-card h3{ margin:.2rem 0 .4rem }

.price-card .price{
  font-size: clamp(2.1rem, 4.2vw, 2.8rem); font-weight: 900; letter-spacing:.2px;
}
.price-card .price .period{ opacity:.9; font-weight:800 }
.price-card .price .code{ display:none } /* oculta MXN/USD al lado del precio */

.price-card p{ color: var(--muted); margin:.25rem 0 .7rem }

.price-card .features{ list-style:none; padding:0; margin:.2rem 0 1rem; display:grid; gap:.5rem }
.price-card .features li{ position:relative; padding-left: 1.35rem }
.price-card .features li::before{
  content:'✔'; position:absolute; left:0; top:0; line-height:1;
  color:#a78bfa; font-weight:900; opacity:.9;
}

.price-card .btn{ width:100%; border-radius: 16px; padding:.95rem 1rem; margin-top:.6rem }
.price-card .btn.primary{ background: linear-gradient(180deg, #8b5cf6, #6d28d9); }

.price-card.featured{
  background: linear-gradient(180deg, rgba(18,18,36,1), rgba(10,10,20,1));
  border-color: rgba(124,58,237,.55);
  box-shadow: 0 0 0 2px rgba(124,58,237,.25) inset, 0 22px 70px rgba(124,58,237,.18);
}
.price-card .ribbon{
  position:absolute; top:12px; right:-34px; transform: rotate(45deg);
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  color:#0b0b12; font-weight:800; font-size:.8rem;
  padding:.28rem 2.1rem; border-radius: 6px; box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

.pricing-note{ color: var(--muted); margin-top:.9rem; text-align:center }



/* Fixes: pricing featured and switch */
.price-card{ position: relative; }
.price-card .badge{ position:absolute; top:12px; right:12px; font-size:.75rem; background:linear-gradient(135deg, var(--primary), var(--primary-2)); color:#fff; padding:.25rem .5rem; border-radius:.5rem; }
.switch{ position:relative; width:46px; height:26px; display:inline-block; }
.switch input{ opacity:0; width:0; height:0; }
.switch .slider{ position:absolute; cursor:pointer; inset:0; background:rgba(255,255,255,.12); border:1px solid var(--border); border-radius:999px; transition: .2s; }
.switch .slider:before{ content:""; position:absolute; height:18px; width:18px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.2s; }
.switch input:checked + .slider{ background:linear-gradient(135deg, var(--primary), var(--primary-2)); }
.switch input:checked + .slider:before{ transform: translateX(20px); }
@media (max-width:640px){
  .pricing-grid{ grid-template-columns: 1fr; }
}



/* Mobile nav button fix */
.hamburger{ display:none; background:none; border:0; color:var(--text); font-size:1.3rem; }
@media (max-width: 640px){
  .hamburger{ display:inline-flex; align-items:center; justify-content:center; padding:8px; }
}

canvas#starfield{ position:fixed; inset:0; z-index:-1; }


/* === Desktop fixed header + safe anchor offset === */
@media (min-width: 1024px){
  .site-header{ position: fixed; top: 0; left: 0; right: 0; z-index: 1000; }
  body{ padding-top: var(--header-h); }
}

/* Ensure section anchors aren't covered by the fixed header */
main section[id]{ scroll-margin-top: calc(var(--header-h) + 12px); }


/* Ensure anchors are not hidden behind fixed header */
html{ scroll-padding-top: var(--header-h); }

.nav{ padding:16px 5.5%; }

/* Hero badge spacing and style */
.hero .badge{
  position: relative;
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  background: rgba(124,58,237,.18);
  border: 1px solid rgba(124,58,237,.35);
  margin: clamp(8px, 2.5vw, 18px) 0 10px;

  margin-bottom: 24px;
}
.hero .badge .dot{
  width:8px; height:8px; border-radius:999px; background:#7c3aed;
  box-shadow: 0 0 0 3px rgba(124,58,237,.15);
}

/* Force header fixed on all viewports */
.site-header{ position:fixed !important; top:0; left:0; right:0; z-index:1000; }
body{ padding-top: var(--header-h); }

/* Section titles centered and uppercase */
.section h2, .h2, .hero .title{
  text-align:center;
  text-transform:uppercase;
}

/* Gradient text effect for titles */
.section h2, .h2, .hero .title{
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

/* Floating WhatsApp button */
.whatsapp-float{
  position: fixed;
  right: 18px; bottom: 18px;
  z-index: 1100;
  width: 54px; height: 54px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  background: #25D366; 
  color: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.15);
  transition: transform .15s ease, filter .2s ease;
}
.whatsapp-float:hover{ transform: translateY(-2px); filter: brightness(1.05); }
.whatsapp-float svg{ display:block; }

/* Move back-to-top up so it doesn't overlap WA button */
.back-to-top{ bottom: 86px; }

@media (max-width: 640px){
  
}


/* === Clientes (logo wall) ========================= */
.logo-wall{
  width: 100%;
  margin-top: 24px;
}
.clientes-grid{
  display: grid;
  gap: 24px;
  align-items: center;
  grid-template-columns: repeat(4, minmax(0, 1fr)); /* Desktop: 4 */
}
.cliente{
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  border-radius: 16px;
  background: transparent; /* contenedor transparente */
}
.cliente img{
  max-width: 100%;
  max-height: 72px; /* altura controlada para uniformidad */
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: .85;
  transition: filter .2s ease, opacity .2s ease, transform .2s ease;
}
.cliente img:hover{
  filter: grayscale(0%);
  opacity: 1;
  transform: scale(1.02);
}

/* Tablet */
@media (max-width: 1024px){
  .clientes-grid{ grid-template-columns: repeat(2, 1fr); }
  .cliente img{ max-height: 64px; }
}

/* Móvil */
@media (max-width: 640px){
  .clientes-grid{ grid-template-columns: 1fr; }
  .cliente{ padding: 12px; }
  .cliente img{ max-height: 56px; }
}
/* === /Clientes ==================================== */


/* === FIXES: Portfolio & Filters (2025-09-30) === */
.grid.portfolio, .portfolio.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}
.portfolio-item {
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01) 60%), #0f0f18;
  border: 1px solid var(--border, rgba(255,255,255,.12));
  border-radius: 14px;
  padding: 12px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.portfolio-item:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.25); }
.portfolio-item h3 { font-size: 1rem; margin: 10px 8px 4px; color: #fff; }

/* Responsive filter chips: horizontal scroll on mobile */
@media (max-width: 640px){
  .filters{ flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
  .chip{ white-space: nowrap; }
}

/* Lightbox close button style fallback */
.lightbox{ position: fixed; inset: 0; display: grid; place-items: center; background: rgba(0,0,0,.72); z-index: 9999; padding: 20px; }
.lightbox img{ width:auto; height:auto; max-width:92vw; max-height:82vh; border-radius:12px; border:1px solid var(--border, rgba(255,255,255,.15)); object-fit:contain; }
.lightbox-close{
  position: absolute; top: 16px; right: 16px; background: rgba(0,0,0,.5);
  border: 1px solid var(--border, rgba(255,255,255,.25)); color: #fff; padding: 8px 10px; border-radius: 10px; cursor: pointer;
}
.lightbox-caption{ color:#fff; margin-top:10px; text-align:center; max-width: 90vw; }


/* === Social links in footer (responsive) === */
.social-links{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:center;
  margin-top:14px;
  flex-wrap:wrap;
}
.social-links a{
  color:#fff;
  font-size:1.5rem;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px; height:40px;
  border-radius:999px;
  border:1px solid var(--border, rgba(255,255,255,.18));
  background:rgba(255,255,255,.04);
  transition:transform .2s ease, background .2s ease, color .2s ease;
}
.social-links a:hover{
  transform:translateY(-2px);
  background:var(--primary, #7c3aed);
  color:#fff;
}
@media (max-width: 640px){
  .social-links{ gap:12px; }
  .social-links a{ width:36px; height:36px; font-size:1.25rem; }
}


/* === Footer layout & sleek social icons === */
.footer .footer-inner{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.footer .footer-inner p{
  margin:0;
  color:var(--muted);
}
.footer .social-links{
  display:flex; gap:12px; align-items:center;
}
.footer .social-links a{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border, rgba(255,255,255,.18));
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
.footer .social-links a:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg, var(--primary, #7c3aed), var(--primary-2, #a78bfa));
  border-color:transparent;
}
.footer .social-links .icon{
  display:inline-flex;
  width:20px; height:20px;
  color:#fff;
}
.footer .social-links svg{
  width:100%; height:100%;
}

/* Responsive tweaks */
@media (max-width: 640px){
  .footer .footer-inner{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:10px;
  }
  .footer .social-links a{ width:36px; height:36px; border-radius:10px; }
  .footer .social-links .icon{ width:18px; height:18px; }
}



/* === Slider logos transparente === */
.logo-slider {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 20px 0;
  background: transparent;
}
.logo-track {
  display: flex;
  width: calc(200%);
  animation: scrollLogos 25s linear infinite;
}
.logo {
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 40px;
}
.logo img {
  max-height: 70px;
  width: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: 0.9;
  transition: filter .3s, opacity .3s;
}
.logo img:hover {
  filter: grayscale(0%);
  opacity: 1;
}
@keyframes scrollLogos {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


/* === Tarjeta de contacto (glass transparente) === */
.contact-card {
  margin: 30px auto;
  padding: 22px;
  border-radius: 16px;
  max-width: 640px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  text-align: center;
}
.contact-card__title {
  font-weight: 600;
  margin-bottom: 16px;
  font-size: 1.1rem;
  color: #fff;
}
.contact-quick {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}
.contact-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  text-decoration: none;
  transition: transform .2s, background .2s, border-color .2s;
}
.contact-chip svg { width: 18px; height: 18px; }
.contact-chip:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.28);
}
.contact-chip--wa {
  background: rgba(37,211,102,0.15);
  border-color: rgba(37,211,102,0.35);
}
.contact-chip--wa:hover {
  background: rgba(37,211,102,0.22);
  border-color: rgba(37,211,102,0.55);
}
@media (max-width:640px){
  .contact-card { margin: 22px auto; padding: 18px; }
}



/* Íconos de contacto mantienen el glow verde */
.contact-row svg {
  color: #25D366;
  stroke: currentColor;
  fill: none;
  transition: color 0.3s ease-in-out, filter 0.3s ease-in-out;
}

.contact-row:hover svg {
  color: #25D366;
  filter: brightness(1.2) drop-shadow(0 0 6px rgba(37, 211, 102, 0.8));
}



/* Responsive ajustes para móviles */
@media (max-width: 640px) {
  

  
}


/* i-Studio11: Unificar botón "Asesoría Gratuita" con estilo de contacto directo (chip + glow) */
@keyframes pulse-glow {
  0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.6); }
  70% { box-shadow: 0 0 0 10px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}
.btn-asesoria,
.btn-asesoria:visited {
  background: rgba(37,211,102,0.15);
  border: 1px solid rgba(37,211,102,0.35);
  color: #25D366 !important;
  border-radius: 14px;
  padding: 12px 22px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  animation: pulse-glow 2s infinite;
  transition: transform .25s ease, background-color .25s ease, border-color .25s ease, color .25s ease;
}
.btn-asesoria:hover,
.btn-asesoria:focus {
  background: rgba(37,211,102,0.22);
  border-color: rgba(37,211,102,0.55);
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 0 12px rgba(37, 211, 102, 0.8);
  animation: none;
}
.btn-asesoria svg {
  color: #25D366;
  stroke: currentColor;
  transition: color 0.3s ease-in-out, filter 0.3s ease-in-out;
}
.btn-asesoria:hover svg {
  color: #ffffff;
  filter: drop-shadow(0 0 6px rgba(37, 211, 102, 0.8));
}
@media (max-width: 640px){
  .btn-asesoria { padding: 10px 16px; font-size: .9rem; }
  .btn-asesoria:hover, .btn-asesoria:focus { transform: translateY(-1px); }
}


/* i-Studio11: Estilo unificado para CTAs (chip verde) */
@keyframes pulse-glow { 0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.6); } 70% { box-shadow: 0 0 0 10px rgba(37, 211, 102, 0); } 100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); } }
.btn-cta, .btn-cta:visited {
  background: rgba(37,211,102,0.15);
  border: 1px solid rgba(37,211,102,0.35);
  color: #25D366 !important;
  border-radius: 14px;
  padding: 12px 22px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  animation: pulse-glow 2s infinite;
  transition: transform .25s ease, background-color .25s ease, border-color .25s ease, color .25s ease;
}
.btn-cta:hover, .btn-cta:focus {
  background: rgba(37,211,102,0.22);
  border-color: rgba(37,211,102,0.55);
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 0 12px rgba(37, 211, 102, 0.8);
  animation: none;
}
.btn-cta svg {
  color: #25D366;
  stroke: currentColor;
  transition: color 0.3s ease-in-out, filter 0.3s ease-in-out;
}
.btn-cta:hover svg {
  color: #ffffff;
  filter: drop-shadow(0 0 6px rgba(37, 211, 102, 0.8));
}
@media (max-width: 640px){
  .btn-cta { padding: 10px 16px; font-size: .9rem; }
  .btn-cta:hover, .btn-cta:focus { transform: translateY(-1px); }
}
