/* =========================================================
   BAUSEN - Cookie Policy (inspirado en aiacoweb.netlify.app/servicio)
   Paleta:
   - Morning cloud  #DCE2EF
   - Silver lake    #5B75B6
   - Azul real      #003DA5
   - Azul marino    #182389
   Tipografías:
   - Body: Inter
   - Secundaria: Source Sans 3
   - Display: Momo Trust (si está disponible)
========================================================= */

@font-face{
  font-family:"Momo Trust";
  src:url("/fonts/momo-trust.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }

:root{
  --bg:#DCE2EF;
  --surface:rgba(255,255,255,.76);
  --surface2:rgba(255,255,255,.62);
  --border:rgba(24,35,137,.16);
  --text:#0B1633;
  --text-soft:rgba(11,22,51,.78);

  --slb:#5B75B6;
  --real:#003DA5;
  --navy:#182389;

  --radius:14px;
  --shadow:0 18px 55px rgba(24,35,137,.14);
  --shadow2:0 10px 26px rgba(24,35,137,.10);
  --t:220ms ease;
}

body{
  font-family:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1100px 520px at 20% 10%, rgba(0,61,165,.12), transparent 55%),
    radial-gradient(900px 520px at 85% 0%, rgba(91,117,182,.18), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.72;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

a{ color:var(--real); text-decoration:none; text-underline-offset:3px; transition:var(--t); }
a:hover{ color:var(--navy); text-decoration:underline; }

/* Hidden robusto */
[hidden]{ display:none !important; }

/* NAV */
.nav-container{
  position:sticky; top:0; z-index:1000;
  background:rgba(220,226,239,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
  box-shadow:0 10px 30px rgba(24,35,137,.08);
}
.nav-content{
  max-width:1150px; margin:0 auto; padding:14px 18px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.logo{ display:flex; align-items:center; gap:10px; color:var(--text); }
.logo-icon{
  width:44px; height:44px; border-radius:16px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(0,61,165,.10), rgba(91,117,182,.22));
  border:1px solid rgba(24,35,137,.18);
  box-shadow:var(--shadow2);
  color:var(--navy);
}
.logo-text{
  font-family:"Momo Trust","Inter",sans-serif;
  letter-spacing:-0.08em; /* interletrado aprox -91 */
  font-size:1.2rem;
}
.nav-links{
  display:flex; align-items:center; gap:10px;
  font-family:"Source Sans 3","Inter",sans-serif;
}
.nav-links a{
  padding:10px 12px; border-radius:12px;
  color:rgba(11,22,51,.84);
  border:1px solid transparent;
}
.nav-links a:hover{
  background:rgba(255,255,255,.58);
  border-color:rgba(24,35,137,.14);
  text-decoration:none;
  transform:translateY(-1px);
}
.theme-toggle{ display:none !important; } /* modo claro fijo */

/* HERO */
.header{ max-width:1150px; margin:0 auto; padding:44px 18px 18px; }
.header-content{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
  padding:28px 26px;
  box-shadow:var(--shadow2);
  position:relative;
  overflow:hidden;
}
.header-content::before{
  content:"";
  position:absolute; inset:-30%;
  background:
    radial-gradient(closest-side, rgba(0,61,165,.18), transparent 62%),
    radial-gradient(closest-side, rgba(91,117,182,.22), transparent 62%);
  transform:translate(18%, -12%);
  pointer-events:none;
}
.badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:999px;
  border:1px solid rgba(24,35,137,.14);
  background:rgba(255,255,255,.60);
  position:relative;
}
.badge i{ color:var(--navy); }
.badge span{
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.82);
  font-weight:700;
  letter-spacing:-0.01em;
}
.header h1{
  margin-top:14px;
  font-family:"Momo Trust","Inter",sans-serif;
  letter-spacing:-0.08em;
  font-size:clamp(2rem, 3.5vw, 3rem);
  line-height:1.06;
  position:relative;
  background:linear-gradient(135deg, var(--navy), var(--real));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.header p{
  margin-top:12px; max-width:70ch;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:var(--text-soft);
  position:relative;
}
.header-buttons{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top:18px; position:relative;
}

/* BUTTONS */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 14px; border-radius:14px;
  border:1px solid transparent;
  font-family:"Source Sans 3","Inter",sans-serif;
  font-weight:700;
  cursor:pointer;
  transition:var(--t);
  user-select:none;
  text-decoration:none !important;
}
.btn-primary{
  background:linear-gradient(135deg, var(--real), var(--navy));
  color:#fff;
  box-shadow:0 14px 34px rgba(0,61,165,.20);
  border-color:rgba(255,255,255,.22);
}
.btn-primary:hover{ transform:translateY(-1px); filter:brightness(1.03); }
.btn-secondary{
  background:rgba(255,255,255,.62);
  border-color:rgba(24,35,137,.16);
  color:rgba(11,22,51,.90);
}
.btn-secondary:hover{ transform:translateY(-1px); box-shadow:var(--shadow2); }
.btn-ghost{
  background:transparent;
  border-color:rgba(24,35,137,.16);
  color:rgba(11,22,51,.86);
}
.btn-ghost:hover{ background:rgba(255,255,255,.55); }

/* MAIN */
.main{ max-width:1150px; margin:0 auto; padding:18px 18px 60px; }
.quick-nav{
  margin-top:14px;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:24px;
  padding:18px 18px 16px;
  box-shadow:var(--shadow2);
}
.quick-nav-header h2{
  font-family:"Momo Trust","Inter",sans-serif;
  letter-spacing:-0.06em;
  display:flex; align-items:center; gap:10px;
  font-size:1.35rem;
  color:rgba(11,22,51,.92);
}
.quick-nav-header p{
  margin-top:6px;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.72);
}
.quick-nav-buttons{ margin-top:12px; display:flex; flex-wrap:wrap; gap:10px; }
.quick-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:14px;
  border:1px solid rgba(24,35,137,.14);
  background:rgba(255,255,255,.60);
  color:rgba(11,22,51,.86);
  font-family:"Source Sans 3","Inter",sans-serif;
  font-weight:700;
  transition:var(--t);
  text-decoration:none !important;
}
.quick-btn:hover{ transform:translateY(-1px); box-shadow:var(--shadow2); }
.quick-btn.active{
  background:linear-gradient(135deg, rgba(0,61,165,.14), rgba(91,117,182,.16));
  border-color:rgba(0,61,165,.24);
}
.quick-nav-footer{
  margin-top:12px;
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; flex-wrap:wrap;
  border-top:1px solid rgba(24,35,137,.12);
  padding-top:12px;
}
.link-like{
  background:none; border:none; color:var(--real);
  font-family:"Source Sans 3","Inter",sans-serif;
  font-weight:800;
  cursor:pointer;
  padding:8px 10px;
  border-radius:12px;
}
.link-like:hover{ background:rgba(255,255,255,.55); color:var(--navy); }
.version{
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.70);
  display:inline-flex; gap:10px; align-items:center;
}

/* CONTENT */
.content-wrapper{ margin-top:16px; display:grid; gap:14px; }
.content-section{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
  padding:22px 22px 20px;
  box-shadow:var(--shadow2);
}
.section-number{
  position:absolute; top:18px; right:18px;
  width:40px; height:40px;
  border-radius:14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(0,61,165,.14), rgba(91,117,182,.18));
  border:1px solid rgba(24,35,137,.18);
  font-family:"Inter",sans-serif;
  font-weight:900;
  color:rgba(11,22,51,.84);
}
.content-section h2{
  font-family:"Momo Trust","Inter",sans-serif;
  letter-spacing:-0.06em;
  display:flex; gap:10px; align-items:center;
  font-size:1.55rem;
  color:rgba(11,22,51,.92);
}
.content-section p{
  margin-top:10px;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:var(--text-soft);
  max-width:78ch;
}

.info-box{
  margin-top:14px;
  display:flex; gap:12px;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(0,61,165,.10), rgba(91,117,182,.14));
  border:1px solid rgba(24,35,137,.16);
}
.info-box i{ color:var(--navy); font-size:22px; margin-top:2px; }
.info-box h3{ font-family:"Inter",sans-serif; letter-spacing:-0.01em; }
.info-box p{ margin-top:4px; }

.cards-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
}
.card{
  background:rgba(255,255,255,.62);
  border:1px solid rgba(24,35,137,.14);
  border-radius:18px;
  padding:14px;
  transition:var(--t);
}
.card:hover{ transform:translateY(-2px); box-shadow:var(--shadow2); }
.card-icon{
  width:50px; height:50px;
  border-radius:18px;
  display:grid; place-items:center;
  background:rgba(220,226,239,.60);
  border:1px solid rgba(24,35,137,.14);
  color:var(--navy);
}
.card h3{ margin-top:10px; font-family:"Inter",sans-serif; letter-spacing:-0.01em; }
.card p{ margin-top:6px; }
.pill{
  display:inline-flex; gap:8px; align-items:center;
  margin-top:10px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(24,35,137,.14);
  background:rgba(255,255,255,.58);
  font-family:"Source Sans 3","Inter",sans-serif;
  font-weight:800;
  color:rgba(11,22,51,.78);
}
.pill-on{
  border-color:rgba(0,61,165,.20);
  background:linear-gradient(135deg, rgba(0,61,165,.12), rgba(91,117,182,.14));
}

.steps{ margin-top:12px; display:grid; gap:10px; }
.step{
  display:flex; gap:12px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(24,35,137,.14);
}
.step-num{
  width:40px; height:40px;
  border-radius:16px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--real), var(--navy));
  color:#fff; font-weight:900;
  flex:0 0 auto;
}
.step h3{ font-family:"Inter",sans-serif; letter-spacing:-0.01em; }
.step p{ margin-top:4px; }

.note{
  margin-top:12px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(24,35,137,.14);
  background:rgba(220,226,239,.55);
  display:flex; gap:10px; align-items:flex-start;
}
.note i{ color:var(--navy); margin-top:2px; }
.note p{ margin-top:0; }

.table-wrap{
  margin-top:12px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(24,35,137,.14);
  background:rgba(255,255,255,.62);
}
.table{ width:100%; border-collapse:collapse; font-family:"Source Sans 3","Inter",sans-serif; }
.table th, .table td{ padding:12px; text-align:left; border-bottom:1px solid rgba(24,35,137,.12); }
.table th{ background:rgba(220,226,239,.60); color:rgba(11,22,51,.90); font-weight:900; }
.table td{ color:rgba(11,22,51,.78); }

/* PREFS */
.prefs{ margin-top:14px; display:grid; gap:10px; }
.pref-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(24,35,137,.14);
}
.pref-left h3{ font-family:"Inter",sans-serif; letter-spacing:-0.01em; }
.pref-left p{ margin-top:4px; }
.badge-on{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 10px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(0,61,165,.12), rgba(91,117,182,.14));
  border:1px solid rgba(0,61,165,.20);
  font-family:"Source Sans 3","Inter",sans-serif;
  font-weight:900;
  color:rgba(11,22,51,.82);
}
.switch{ position:relative; width:54px; height:32px; display:inline-block; }
.switch input{ opacity:0; width:0; height:0; }
.slider{
  position:absolute; inset:0;
  cursor:pointer;
  background:rgba(11,22,51,.18);
  border:1px solid rgba(24,35,137,.20);
  transition:var(--t);
  border-radius:999px;
}
.slider::before{
  content:"";
  position:absolute;
  height:24px; width:24px;
  left:4px; top:3px;
  background:#fff;
  border-radius:999px;
  transition:var(--t);
  box-shadow:0 10px 20px rgba(24,35,137,.14);
}
.switch input:checked + .slider{ background:linear-gradient(135deg, var(--real), var(--navy)); }
.switch input:checked + .slider::before{ transform:translateX(22px); }
.prefs-actions{
  display:flex; flex-wrap:wrap; gap:10px;
  align-items:center; margin-top:6px;
}
.prefs-status{
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.78);
  font-weight:800;
}

/* CALLOUT + CONTACT */
.callout{
  margin-top:12px;
  padding:14px;
  border-radius:18px;
  background:rgba(0,61,165,.10);
  border:1px solid rgba(0,61,165,.18);
  display:flex; gap:12px;
}
.callout i{ color:var(--real); font-size:20px; margin-top:2px; }
.callout h3{ font-family:"Inter",sans-serif; letter-spacing:-0.01em; }
.callout p{ margin-top:4px; }

.contact-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
}
.contact-card{
  background:rgba(255,255,255,.62);
  border:1px solid rgba(24,35,137,.14);
  border-radius:18px;
  padding:14px;
}
.contact-card h3{
  font-family:"Inter",sans-serif;
  letter-spacing:-0.01em;
  display:flex; gap:10px; align-items:center;
}
.contact-card p{ margin-top:6px; }
.acceptance{
  margin-top:14px;
  display:flex; justify-content:space-between; align-items:center;
  gap:12px; flex-wrap:wrap;
  border-top:1px solid rgba(24,35,137,.12);
  padding-top:12px;
}
.acceptance p{
  margin-top:0;
  max-width:70ch;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.74);
}

/* FOOTER */
.footer{
  margin-top:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(24,35,137,.14);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow2);
}
.footer-content{
  padding:18px;
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:16px;
}
.footer-brand{ display:flex; gap:12px; align-items:flex-start; }
.footer-logo{
  width:46px; height:46px;
  border-radius:18px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(0,61,165,.10), rgba(91,117,182,.22));
  border:1px solid rgba(24,35,137,.16);
  color:var(--navy);
}
.footer-brand h3{
  font-family:"Momo Trust","Inter",sans-serif;
  letter-spacing:-0.08em;
}
.footer-brand p{
  margin-top:4px;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.72);
}
.footer-columns{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
}
.footer-col h4{
  font-family:"Inter",sans-serif;
  letter-spacing:-0.01em;
  color:rgba(11,22,51,.90);
}
.footer-col a{
  display:block;
  margin-top:8px;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.76);
  text-decoration:none;
}
.footer-col a:hover{ color:var(--navy); text-decoration:underline; }
.footer-meta{
  display:flex; gap:10px; align-items:center;
  margin-top:8px;
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.76);
}
.footer-bottom{
  padding:12px 18px;
  border-top:1px solid rgba(24,35,137,.12);
  font-family:"Source Sans 3","Inter",sans-serif;
  color:rgba(11,22,51,.70);
  text-align:center;
}

/* TO TOP */
.to-top{
  position:fixed; right:18px; bottom:18px;
  width:52px; height:52px;
  border-radius:18px;
  border:1px solid rgba(24,35,137,.20);
  background:linear-gradient(135deg, var(--real), var(--navy));
  color:#fff;
  box-shadow:var(--shadow);
  cursor:pointer;
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:var(--t);
}
.to-top.visible{ opacity:1; transform:translateY(0); pointer-events:auto; }
.to-top:hover{ filter:brightness(1.05); transform:translateY(-2px); }

/* RESPONSIVE */
@media (max-width: 980px){
  .cards-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-content{ grid-template-columns:1fr; }
  .footer-columns{ grid-template-columns:1fr; }
}
@media (max-width: 760px){
  .nav-links{ display:none; }
  .header-content{ padding:22px 18px; }
  .content-section{ padding:20px 18px; }
  .cards-grid{ grid-template-columns:1fr; }
  .section-number{ width:38px; height:38px; border-radius:14px; }
}
