:root{
	--bg:#000000; /* negro profundo */
	--card:#ffffff;
	--primary:#D10013; /* botones */
	--muted:#9ca3af;
	--success:#2d3f21; /* separador verde */
	--danger:#b91c1c;
	--text:#ffffff; /* texto principal blanco */
	--card-text:#0b0b0b; /* texto en tarjetas blancas */
	--max-width:1100px;
}
*{box-sizing:border-box}

/* Tipografía Shentox W04 Semibold - añade los archivos WOFF/WOFF2 en public/fonts/ */
@font-face{
  font-family: 'Shentox W04';
  src: url('/public/fonts/ShentoxW04-Semibold.woff2') format('woff2'),
	   url('/public/fonts/ShentoxW04-Semibold.woff') format('woff');
  font-weight:600;
  font-style:normal;
  font-display:swap;
}

body{font-family: Inter, 'Segoe UI', Helvetica, Arial, sans-serif;margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;}

/* Headings use the supplied Shentox semibold font (upload font files to public/fonts/) */
h1,h2,h3,h4,h5,h6{font-family:'Shentox W04', Inter, 'Segoe UI', Helvetica, Arial, sans-serif;color:var(--text);font-weight:600;margin:0}
.wrap{max-width:var(--max-width);margin:0 auto;padding:18px}

/* Header */

.brand a{color:var(--text);text-decoration:none;font-weight:600;font-size:20px}
.nav-toggle{display:none;background:transparent;border:0;color:var(--text);font-size:22px;padding:8px;cursor:pointer}
.main-nav{display:flex;gap:12px;align-items:center}
.main-nav a{color:var(--text);text-decoration:none;padding:8px;border-radius:6px;font-size:15px}
.main-nav a:hover{background:rgba(255,255,255,0.08)}
.admin-link{background:rgba(255,255,255,0.08);padding:6px 8px;border-radius:6px}

/* Active nav link */
.main-nav a.active{background:rgba(255,255,255,0.12);font-weight:600}

/* Skip link for accessibility */
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:12px;top:12px;background:#fff;padding:8px;border-radius:8px;color:var(--primary);z-index:2000}

/* Flash messages */
.flash{max-width:var(--max-width);margin:12px auto 0;padding:12px;border-radius:8px;box-shadow:0 2px 6px rgba(16,24,40,0.04);text-align:left}
.flash-success{background:#ecfdf5;border-left:4px solid var(--success);color:#064e3b}
.flash-error{background:#fff1f2;border-left:4px solid var(--danger);color:#7f1d1d}
.flash.hide{opacity:0;transform:translateY(-6px);transition:all .3s ease}

/* Main content */
main.wrap{background:transparent;padding:22px}
		.courses-grid{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);padding:16px;border-radius:10px;box-shadow:0 6px 18px rgba(15,23,42,0.04);margin-bottom:16px;color:var(--card-text)}

/* Forms */
.form-group{margin:10px 0}
		.courses-grid{grid-template-columns:1fr}
input[type="text"],input[type="email"],input[type="password"],input[type="date"],input[type="time"],textarea,select{width:100%;max-width:520px;padding:10px;border:1px solid #e6edf3;border-radius:8px;background:#fff}
.btn{display:inline-block;padding:10px 14px;background:var(--primary);color:#fff;border-radius:8px;border:0;cursor:pointer;text-decoration:none}
.btn.secondary{background:#f3f4f6;color:#111;border:1px solid #e6edf3}
.errors{background:#fff1f2;border-left:4px solid var(--danger);padding:10px;border-radius:8px;margin:8px 0}
.success{background:#ecfdf5;border-left:4px solid var(--success);padding:10px;border-radius:8px;margin:8px 0}
	.courses-section{background:var(--bg);padding:40px 0 80px}
	.courses-section .wrap{position:relative}
	.courses-grid{margin-top:-60px}
	.course-card{padding:22px;box-shadow:0 18px 36px rgba(0,0,0,0.6);color:var(--card-text)}
	.course-card .circle{width:120px;height:120px;margin:-70px auto 12px;box-shadow:0 6px 14px rgba(0,0,0,0.22)}
	.btn.red, .btn.red:visited{background:var(--primary);color:#fff;padding:12px 18px;border-radius:6px;border:0;display:inline-block;font-weight:700;text-transform:uppercase}
	.practice-img{height:260px}
	.practice-desc{background:#f9fafb;padding:22px;border-radius:8px;color:#0b0b0b}
	.gallery-item{height:140px}
	.map-wrap iframe{height:420px}
	.contact-form input,.contact-form textarea{padding:12px}
	.contact-form .btn{padding:12px 18px;background:var(--primary);}

/* Tables */
table{width:100%;border-collapse:collapse}
table th,table td{padding:10px;border-bottom:1px solid #eef2f6;text-align:left}

/* Calendar grid */
.calendar{margin-top:12px}
.cal-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal-row{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}
.cal-day{background:var(--card);padding:10px;border-radius:8px;min-height:90px;border:1px solid #eef2f6}
.cal-day.empty{background:transparent;border:0}
.cal-day .date{font-weight:600;margin-bottom:6px}
.event{background:#eef6ff;padding:6px;border-radius:6px;margin-bottom:6px;color:#0b3d91;font-size:13px}

/* Slot-specific styles inside calendar */
.event.slot{background:#fff8e6;padding:6px;border-radius:6px;margin-bottom:6px;color:#92400e;font-size:13px}
.event.slot.available{background:#ecfdf5;border-left:4px solid var(--success);color:#064e3b}
.event.slot.full{background:#fff1f2;border-left:4px solid var(--danger);color:#7f1d1d}

/* Compact slot badges inside calendar cells */
.slots-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.slot-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;font-size:12px;border:1px solid #e6edf3;background:#fff;color:inherit;cursor:pointer}
.slot-badge .slot-count{font-size:11px;color:var(--muted);margin-left:6px}
.slot-badge.available{background:#ecfdf5;border-left:4px solid var(--success);color:#064e3b}
.slot-badge.full{background:#fff1f2;border-left:4px solid var(--danger);color:#7f1d1d}
.slot-badge[disabled]{opacity:0.65;cursor:not-allowed}

/* Modal for booking */
.modal{display:none;position:fixed;inset:0;background:rgba(2,6,23,0.5);align-items:center;justify-content:center;z-index:1200}
.modal .modal-content{background:var(--card);padding:18px;border-radius:10px;box-shadow:0 10px 30px rgba(2,6,23,0.12);min-width:280px;max-width:520px;position:relative}
.modal .modal-close{position:absolute;right:10px;top:8px;border:0;background:transparent;font-size:20px;cursor:pointer}

/* Misc */
.subscriptions{list-style:none;padding-left:0}
.subscriptions li{margin:8px 0}
footer.site-footer{background:#7B0303;padding:14px 0;margin-top:24px;border-top:1px solid rgba(255,255,255,0.04);color:var(--text)}

/* Responsive */
@media (max-width:800px){
	.nav-toggle{display:block}
	.main-nav{display:none;flex-direction:column;background:linear-gradient(180deg,rgba(0,0,0,0.02),transparent);position:absolute;left:12px;right:12px;top:62px;padding:12px;border-radius:8px}
	.main-nav.open{display:flex}
	.wrap{padding:12px}
}

/* Responsive calendar: stack days in single column on small screens */
@media (max-width:700px){
	.cal-headers{display:none}
	.cal-row{grid-template-columns:repeat(1,1fr)}
	.cal-day{min-height:80px}
	.slots-wrap{gap:6px}
	.slot-badge{font-size:13px;padding:6px}
	.calendar-controls{display:flex;flex-wrap:wrap;gap:6px}
}

/* Admin panel layout */
.admin-layout{display:flex;gap:20px;align-items:flex-start;margin-top:12px}
.admin-menu{width:220px;min-width:160px;display:flex;flex-direction:column;gap:6px}
.admin-menu a{display:block;padding:8px 12px;border-radius:8px;background:transparent;color:var(--muted);text-decoration:none;border:1px solid transparent}
.admin-menu a.active{background:var(--card);color:var(--primary);font-weight:600;border-color:#e6edf3;box-shadow:0 4px 14px rgba(15,23,42,0.04)}
.admin-content{flex:1}

@media (max-width:900px){
  .admin-layout{flex-direction:column}
  .admin-menu{flex-direction:row;overflow:auto;width:auto}
  .admin-menu a{white-space:nowrap}
}

/* Homepage specific styles */
.hero{
	position:relative;
	min-height:480px;
	display:flex;
	align-items:center;
	overflow:hidden;
	color:#fff;
	/* break out of .wrap and flush against navbar */
	width:100vw;
	margin-left:calc(50% - 50vw);
	margin-right:calc(50% - 50vw);
	margin-top:-22px;
}
.hero img.hero-bg{
	position:absolute;
	inset:0;
	width:100%;
	height:100%;
	object-fit:cover;
	object-position:center top;
	z-index:0;
}
.hero::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0.28);z-index:1}
.hero-inner{
	position:relative;
	z-index:2;
	display:flex;
	align-items:center;
	justify-content:flex-end;
	width:100%;
	max-width:var(--max-width);
	margin:0 auto;
	padding:0 18px;
}
.hero-title{font-size:46px;margin:0 0 8px;text-transform:uppercase;letter-spacing:3px;font-weight:600;text-align:right}

/* Franja verde debajo del hero: full viewport width y altura reducida */
.hero-stripe{
	height:67.5px;
	background:var(--success);
	width:100vw;
	margin-left:calc(50% - 50vw);
	margin-right:calc(50% - 50vw);
	display:block;
}

.section-title{text-align:center;font-size:24px;margin:10px 0;text-transform:uppercase;letter-spacing:2px}

.courses-section{background:var(--bg);padding:40px 0 30px}
.courses-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:70px}
	.course-card{background:var(--card);padding:18px 18px 18px;padding-top:75px;border-radius:8px;text-align:center;position:relative;box-shadow:0 10px 20px rgba(2,6,23,0.18);color:var(--card-text)}

	/* Círculo flotante que desborda por encima de la card */
	.course-card .course-thumb{
		width:110px;height:110px;
		border-radius:50%;
		background:#c5c5c5;
		position:absolute;
		top:-55px;
		left:50%;
		transform:translateX(-50%);
		overflow:hidden;
		border:4px solid #fff;
		box-shadow:0 6px 16px rgba(0,0,0,0.22);
	}
	.course-card .course-thumb img{width:100%;height:100%;object-fit:cover;display:block}

	.course-card h3{margin:8px 0;font-size:15px;text-transform:uppercase;color:var(--card-text)}
	.course-card p{color:var(--muted);font-size:14px}
.btn.red, .btn.red:visited{background:#c01b1b}

.practice-inner{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.practice-img{background:url('public/images/practice.svg') center/cover no-repeat;height:220px;border-radius:8px}
.practice-desc{background:#f9fafb;padding:18px;border-radius:8px;color:#0b0b0b}
.practice-desc h3{color:#0b0b0b}

/* ── Galería marquee de dos filas ── */
.gallery-section{
	overflow:hidden;
	padding:20px 0 10px;
	/* breakout igual que el hero: ocupa todo el viewport */
	width:100vw;
	margin-left:calc(50% - 50vw);
	margin-right:calc(50% - 50vw);
}

.gallery-track{
	width:100%;
	overflow:hidden;
	margin-bottom:10px;
}

@keyframes marquee-left{
	0%  { transform:translateX(0) }
	100%{ transform:translateX(var(--marquee-end, -50%)) }
}
@keyframes marquee-right{
	0%  { transform:translateX(var(--marquee-end, -50%)) }
	100%{ transform:translateX(0) }
}

.gallery-reel{
	display:flex;
	gap:10px;
	width:max-content;
	animation:marquee-left 28s linear infinite;
}
.gallery-track--reverse .gallery-reel{
	animation-name:marquee-right;
	animation-duration:22s;
}

/* Pausa al pasar el mouse */
.gallery-track:hover .gallery-reel{ animation-play-state:paused }

.gallery-item{
	background:#3a3a3a;
	border-radius:4px;
	height:180px;
	width:280px;
	flex-shrink:0;
	object-fit:cover;  /* funciona cuando el elemento es <img> */
	display:block;
}

/* legacy grid (no se usa en home pero evita romper otras vistas) */
.gallery-grid{display:flex;flex-wrap:wrap;gap:10px}

/* === Sección combinada Mapa + Contacto === */
.contact-map-section{background:#111;color:#fff;padding:28px 0}
.contact-map-inner{
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:40px;
	align-items:start;
}
.contact-map-col{}

.map-wrap iframe{width:100%;height:360px;border:0;border-radius:4px;display:block}

.contact-form .form-group{margin-bottom:12px;position:relative}
.contact-form input,.contact-form textarea{width:100%;padding:10px 14px;border-radius:0;border:none;border-bottom:1px solid #444;background:#1c1c1c;font-size:14px;color:#fff}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#888}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-helper{font-size:11px;color:#777;text-align:right;margin-top:4px;font-style:italic}
.contact-form .btn{display:block;width:100%;margin:14px 0 0;background:var(--primary);padding:14px;text-align:center;border-radius:0;font-size:15px;letter-spacing:1px;border:none;cursor:pointer}
/* WhatsApp FAB */
.whatsapp-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:1100;box-shadow:0 4px 14px rgba(0,0,0,0.3);text-decoration:none}
.whatsapp-fab svg{width:30px;height:30px;fill:#fff}

.dark-section{background:#000;color:#fff;padding:14px 0}
.dark-section .section-title{color:#fff}

@media (max-width:1000px){
	.courses-grid{grid-template-columns:repeat(2,1fr)}
	.hero-title{font-size:36px}
	.hero{min-height:360px}
}

@media (max-width:700px){
	.courses-grid{grid-template-columns:1fr}
	.practice-inner{grid-template-columns:1fr}
	.hero-title{font-size:22px}
	.hero{min-height:280px}
	.contact-map-inner{grid-template-columns:1fr;gap:28px}
	.map-wrap iframe{height:260px}
}

/* Small tweaks for very small devices */
@media (max-width:420px){
	.wrap{padding:10px}
	.hero{min-height:200px}
	.hero-title{font-size:18px}
	.course-card .course-thumb{width:80px;height:80px;top:-40px}
	.course-card{padding-top:55px}
	.contact-form .btn{width:100%}
}
