:root{
  --primary:#8e2a8c;
  --secondary:#7ac70c;
  --dark:#111827;
  --muted:#6b7280;
}

html{scroll-behavior:smooth;}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #111;
}
a{color: var(--primary);}
a:hover{color:#6f1f6d;}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:1rem; top:1rem; width:auto; height:auto; padding:.75rem 1rem;
  background:#fff; border:2px solid var(--primary); z-index:2000; border-radius:999px;
}

.navbar-custom{background:rgba(255,255,255,.92); backdrop-filter:saturate(150%) blur(10px);}
.navbar-custom .nav-link{color:#222;font-weight:600;}
.navbar-custom .nav-link:hover{color:var(--primary);}
.navbar-custom .nav-link.active{color:var(--primary);}

.hero{
  min-height:100vh;
  background:
    linear-gradient(135deg, rgba(0,0,0,.4), rgba(0,0,0,.4)),
    url("../images/fondo.jpg") center / cover no-repeat;
  color:white;
  padding-top:110px;
  position:relative;
  overflow:hidden;
}
.hero:after{
  content:"";
  position:absolute;
  inset:-40%;
  background: conic-gradient(from 90deg, rgba(255,255,255,.22), transparent, rgba(255,255,255,.12));
  animation: spin 14s linear infinite;
  opacity:.35;
}
@keyframes spin{to{transform:rotate(360deg);}}

.hero > .container{position:relative; z-index:1;}
.hero-logo{max-width:300px; filter: drop-shadow(0 10px 25px rgba(0,0,0,.25));}
.section-padding{padding:96px 0;}
.section-title{letter-spacing:-0.02em;}
.kicker{color:rgba(255,255,255,.85);}

.card{border:0; border-radius:1.25rem;}
.rounded-4{border-radius:1.5rem!important;}

.results-list{max-width:720px;margin:auto;font-size:1.05rem;}
.results-list li{margin:.55rem 0; color:#111;}
.badge-soft{
  display:inline-flex; align-items:center; gap:.4rem;
  background: rgba(142,42,140,.10); color: var(--primary);
  border:1px solid rgba(142,42,140,.18);
  padding:.35rem .65rem; border-radius:999px; font-weight:600;
}

.social-icons a{color:var(--primary);font-size:1.6rem;margin:0 10px;}
.social-icons a:hover{transform:translateY(-2px);}

.footer{background:var(--dark); color:#fff; padding:44px 0;}
.footer a{color:#d1d5db; text-decoration:none; margin:0 .4rem;}
.footer a:hover{color:#fff;}

.fade-in{opacity:0;transform:translateY(18px);transition:all .8s ease;}
.fade-in.show{opacity:1;transform:none;}

.cookie-banner{
  position:fixed; left:0; right:0; bottom:0;
  z-index:2000;
  background:#fff; border-top:1px solid rgba(0,0,0,.12);
  box-shadow:0 -12px 30px rgba(0,0,0,.12);
}
.cookie-banner .btn{border-radius:999px;}
.cookie-pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.4rem .75rem; border-radius:999px;
  background: #f3f4f6; color:#111; font-weight:600;
}