/* ===== Doho — diseño oscuro moderno ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --azul:#3b82f6;
  --azul-claro:#60a5fa;
  --azul-osc:#1e3a8a;
  --azul-deep:#0f1d52;
  --rojo:#ef4444;
  --rojo-osc:#dc2626;
  --dorado:#fbbf24;

  /* Tema oscuro */
  --bg-base:#06080f;
  --bg-1:#0a0e1c;
  --bg-2:#111726;
  --bg-3:#172033;
  --surface:#0f1525;
  --surface-2:#141b2e;
  --surface-3:#1a2340;
  --border:rgba(255,255,255,.07);
  --border-hover:rgba(59,130,246,.3);

  --text:#e2e8f0;
  --text-soft:#94a3b8;
  --text-mute:#64748b;

  --gris:#94a3b8;
  --gris-50:#1a2340;
  --gris-100:#141b2e;
  --gris-claro:#1f2940;
  --gc:#1f2940;

  --shadow-sm:0 1px 2px rgba(0,0,0,.4), 0 1px 3px rgba(0,0,0,.5);
  --shadow:0 4px 6px -1px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.5);
  --shadow-lg:0 10px 30px -5px rgba(0,0,0,.6), 0 20px 60px -10px rgba(59,130,246,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--text);
  background:var(--bg-base);
  background-image:
    radial-gradient(ellipse 1200px 600px at 80% 0%, rgba(59,130,246,.08) 0%, transparent 60%),
    radial-gradient(ellipse 800px 600px at 0% 50%, rgba(220,38,38,.06) 0%, transparent 50%),
    linear-gradient(180deg, var(--bg-base) 0%, var(--bg-1) 100%);
  background-attachment:fixed;
  line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--azul-claro);text-decoration:none;transition:color .15s}
a:hover{color:#93c5fd}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(10,14,28,.78);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--border);
}
.site-header .wrap{max-width:1240px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.brand img{width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:0 0 0 2px var(--azul),0 4px 16px rgba(59,130,246,.4)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px}
.brand-sub{font-size:11px;color:var(--text-mute);font-weight:600;letter-spacing:.8px;text-transform:uppercase}
.site-nav{margin-left:auto;display:flex;gap:2px;flex-wrap:nowrap;align-items:center}
.site-nav a{padding:8px 12px;color:var(--text);font-weight:600;font-size:13.5px;border-radius:8px;transition:.18s;white-space:nowrap}
.site-nav a:hover{background:rgba(59,130,246,.12);color:var(--azul-claro);text-decoration:none}
.site-nav a.cta{background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%);color:#fff;padding:9px 18px;margin-left:8px;box-shadow:0 4px 14px rgba(220,38,38,.4)}
.site-nav a.cta:hover{background:linear-gradient(135deg,#ef4444 0%,#b91c1c 100%);transform:translateY(-1px);color:#fff}
@media(max-width:1180px){.site-nav{gap:0}.site-nav a{padding:7px 9px;font-size:13px}}
.menu-btn{display:none;background:transparent;border:none;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:space-around;padding:8px}
.menu-btn span{display:block;height:3px;background:#fff;border-radius:2px}

/* HERO */
.hero{
  position:relative;
  background:
    radial-gradient(ellipse at 80% 30%, rgba(220,38,38,.25) 0%, transparent 55%),
    radial-gradient(ellipse at 20% 70%, rgba(59,130,246,.3) 0%, transparent 55%),
    linear-gradient(135deg, #06080f 0%, #0a0e1c 50%, #111726 100%);
  color:#fff;padding:130px 22px 150px;overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'><circle cx='20' cy='20' r='1' fill='rgba(255,255,255,0.06)'/></svg>");opacity:.6;pointer-events:none}
.hero .wrap{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center;position:relative;z-index:1}
.hero-text h1{
  font-size:60px;line-height:1.05;font-weight:900;letter-spacing:-1.5px;margin-bottom:18px;
  background:linear-gradient(135deg,#fff 30%,#dbeafe 70%,#93c5fd 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-text h1 .accent{
  display:inline-block;
  background:linear-gradient(135deg,#fff 0%,#fbbf24 60%,#f59e0b 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  border-bottom:5px solid var(--rojo);padding-bottom:6px;
}
.hero-text .lema{font-size:19px;color:#cbd5e1;font-weight:400;margin-bottom:34px;max-width:560px;line-height:1.5}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:14px 28px;border-radius:10px;font-weight:700;font-size:15px;text-decoration:none;transition:all .2s cubic-bezier(.34,1.56,.64,1);border:none;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,#ef4444 0%,#991b1b 100%);color:#fff;box-shadow:0 8px 24px rgba(220,38,38,.5)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(220,38,38,.65);color:#fff}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.3)}
.hero-logo{position:relative}
.hero-logo::before{content:"";position:absolute;inset:-40px;background:radial-gradient(circle,rgba(220,38,38,.5) 0%,transparent 70%);filter:blur(50px);z-index:0;animation:pulse 4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
.hero-logo img{position:relative;width:300px;height:300px;border-radius:50%;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 8px rgba(220,38,38,.3),0 0 0 16px rgba(255,255,255,.04);z-index:1}

/* SECTIONS */
section{padding:90px 22px;position:relative}
section .wrap{max-width:1240px;margin:0 auto}
.section-title{font-size:42px;font-weight:900;color:#fff;margin-bottom:10px;letter-spacing:-1px;line-height:1.1}
.section-sub{color:var(--text-soft);font-size:17px;margin-bottom:54px;max-width:680px}

/* ACTIVIDADES */
.act-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.act-card{
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  border-radius:18px;padding:32px 28px;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--border);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  display:flex;flex-direction:column;gap:10px;text-decoration:none;color:inherit;
  position:relative;overflow:hidden;
}
.act-card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--azul) 0%,var(--azul-claro) 100%)}
.act-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 100% 0%,rgba(59,130,246,.08),transparent 50%);opacity:0;transition:.3s;pointer-events:none}
.act-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);text-decoration:none;border-color:var(--border-hover)}
.act-card:hover::after{opacity:1}
.act-card h3{color:#fff;font-size:22px;font-weight:800;letter-spacing:-.3px;position:relative}
.act-card p{color:var(--text-soft);font-size:14.5px;line-height:1.55;position:relative}

/* HORARIOS */
.horarios-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.dia-card{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);border-radius:14px;padding:22px;box-shadow:var(--shadow-sm);border-left:5px solid var(--azul);border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:.2s}
.dia-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--border-hover)}
.dia-card h4{color:#fff;margin-bottom:12px;font-size:15px;text-transform:uppercase;letter-spacing:.8px;font-weight:800}
.dia-card .bloque{padding:9px 0;border-bottom:1px dashed var(--border);font-size:14px;color:var(--text-soft)}
.dia-card .bloque:last-child{border-bottom:none}
.dia-card .bloque strong{color:#fff;font-weight:700}

.tarifas-card{background:linear-gradient(135deg,var(--azul-osc) 0%,var(--azul-deep) 60%,#000 100%);color:#fff;border-radius:18px;padding:36px;margin-top:36px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;border:1px solid rgba(59,130,246,.2)}
.tarifas-card::before{content:"";position:absolute;top:-50%;right:-30%;width:500px;height:500px;background:radial-gradient(circle,rgba(220,38,38,.4),transparent 70%);filter:blur(60px)}
.tarifas-card h3{margin-bottom:22px;font-size:22px;letter-spacing:-.3px;position:relative}
.tarifas-card .tarifa-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:15.5px;position:relative}
.tarifas-card .tarifa-row:last-child{border-bottom:none}
.tarifas-card .precio{font-weight:800;color:var(--dorado);font-size:17px}

/* STAFF */
.staff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px}
.staff-card{text-align:center;padding:24px 18px;background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);border-radius:16px;box-shadow:var(--shadow-sm);transition:.3s;border:1px solid var(--border)}
.staff-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-hover)}
.staff-card .foto{width:170px;height:170px;border-radius:50%;background:var(--surface-2);margin:0 auto 16px;object-fit:cover;box-shadow:0 0 0 4px var(--surface),0 0 0 8px var(--azul),0 12px 30px rgba(0,0,0,.5)}
.staff-card h3{color:#fff;font-size:18px;font-weight:800;letter-spacing:-.2px}
.staff-card .rol{color:var(--rojo);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-weight:700}
.staff-card p{font-size:14px;color:var(--text-soft);line-height:1.55}

/* NOTICIAS */
.noticia-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.noticia{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;border:1px solid var(--border)}
.noticia:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-hover)}
.noticia .img{height:200px;background:linear-gradient(135deg,var(--azul) 0%,var(--azul-osc) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:48px}
.noticia .body{padding:22px}
.noticia .fecha{font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.8px;font-weight:700}
.noticia h3{color:#fff;font-size:18px;margin:8px 0 10px;font-weight:800;line-height:1.3}
.noticia p{color:var(--text-soft);font-size:14.5px;line-height:1.55}

/* CONTACTO */
.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.contacto-info p{padding:16px 0;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border);font-size:16px;color:var(--text-soft)}
.contacto-info p strong{color:#fff;min-width:100px;font-weight:700}
.redes{display:flex;gap:14px;margin-top:24px}
.redes a{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--azul) 0%,var(--azul-osc) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;transition:.25s;box-shadow:0 4px 14px rgba(59,130,246,.3)}
.redes a:hover{background:linear-gradient(135deg,var(--rojo) 0%,var(--rojo-osc) 100%);transform:scale(1.08) rotate(-3deg);color:#fff;text-decoration:none;box-shadow:0 6px 20px rgba(220,38,38,.5)}

/* FOOTER */
.site-footer{background:linear-gradient(180deg,var(--bg-1) 0%,#000 100%);color:#cbd5e1;padding:80px 22px 40px;margin-top:100px;position:relative;border-top:1px solid var(--border)}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--azul),var(--rojo),transparent)}
.site-footer .wrap{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:50px}
.site-footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px;font-weight:800}
.site-footer a{color:#94a3b8;display:block;padding:6px 0;font-size:14.5px;transition:.15s}
.site-footer a:hover{color:#fff;padding-left:6px}
.site-footer p{color:var(--text-soft)}
.site-footer .copyright{max-width:1240px;margin:50px auto 0;padding-top:24px;border-top:1px solid var(--border);font-size:12.5px;color:#64748b;text-align:center;letter-spacing:.5px}

/* CITA */
.cita{background:radial-gradient(ellipse at 30% 30%, rgba(59,130,246,.25), transparent 60%),linear-gradient(135deg,#06080f 0%,#0a0e1c 100%);color:#fff;padding:100px 22px;text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cita blockquote{max-width:820px;margin:0 auto;font-size:26px;font-style:italic;line-height:1.5;font-weight:300;position:relative;color:#e2e8f0}
.cita blockquote::before{content:'"';font-size:120px;color:var(--rojo);line-height:0;display:block;margin-bottom:34px;opacity:.8}
.cita cite{display:block;margin-top:24px;font-size:13px;color:#94a3b8;font-style:normal;letter-spacing:2px;text-transform:uppercase;font-weight:600}

/* TABLAS (oscuro) */
table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}
th{background:var(--surface-2);font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-mute);font-weight:700}
tr:hover td{background:var(--surface-2)}

/* MOBILE */
@media (max-width:960px){
  .site-header .wrap{flex-wrap:wrap;gap:12px;padding:12px 18px}
  .menu-btn{display:flex}
  .site-nav{display:none;flex-basis:100%;flex-direction:column;align-items:stretch;border-top:1px solid var(--border);padding-top:10px;margin-top:10px}
  .site-nav.open{display:flex}
  .site-nav a{padding:13px 14px;width:100%;font-size:15px;border-radius:10px}
  .site-nav a.cta{margin-left:0;text-align:center}
  .hero{padding:90px 22px 110px}
  .hero .wrap{grid-template-columns:1fr;text-align:center;gap:40px}
  .hero-text h1{font-size:42px;line-height:1.1}
  .hero-text .lema{margin:0 auto 26px;font-size:16px}
  .hero-cta{justify-content:center;flex-direction:column}
  .hero-cta .btn{width:100%}
  .hero-logo img{width:220px;height:220px;margin:0 auto}
  section{padding:60px 18px}
  .section-title{font-size:30px}
  .section-sub{font-size:15.5px;margin-bottom:36px}
  .contacto-grid{grid-template-columns:1fr;gap:28px}
  .site-footer{padding:60px 18px 32px}
  .site-footer .wrap{grid-template-columns:1fr;gap:34px;text-align:center}
  .site-footer .redes,.contacto-info .redes{justify-content:center}
  .cita{padding:70px 18px}
  .cita blockquote{font-size:19px}
  .cita blockquote::before{font-size:80px;margin-bottom:18px}
  .brand img{width:42px;height:42px}
  table{font-size:13px}
  table th,table td{padding:8px 10px}
}
@media (max-width:480px){
  .hero-text h1{font-size:32px}
  .hero-logo img{width:180px;height:180px}
  .section-title{font-size:26px}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero-text>*{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) backwards}
.hero-text h1{animation-delay:.1s}
.hero-text .lema{animation-delay:.25s}
.hero-text .hero-cta{animation-delay:.4s}
.hero-logo{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .3s backwards}
