
:root{
  --black:#050505;
  --black2:#0c0c0b;
  --graphite:#151515;
  --white:#f5f5f0;
  --muted:#b9b6ad;
  --gold:#c5a34b;
  --gold2:#f2c400;
  --line:rgba(255,255,255,.12);
  --lineGold:rgba(197,163,75,.34);
  --max:1180px;
  --radius:18px;
  --shadow:0 28px 90px rgba(0,0,0,.42);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:92px}
body{margin:0;background:var(--black);color:var(--white);font-family:Inter,Arial,Helvetica,sans-serif;overflow-x:hidden;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}img{max-width:100%}button,input,select{font:inherit}.container{width:min(var(--max),calc(100% - 44px));margin:auto}
h1,h2,h3,p{margin-top:0}h1,h2,h3{font-family:Inter,Arial,Helvetica,sans-serif;font-weight:950;letter-spacing:-.04em}h1{font-size:clamp(46px,5.6vw,86px);line-height:.98;margin:0 0 16px}h2{font-size:clamp(34px,4vw,58px);line-height:1.02;margin:0}h3{font-size:clamp(22px,2.1vw,34px);line-height:1.05;margin:0 0 12px}p{font-size:16px;line-height:1.65;color:var(--muted)}
.skip-link{position:absolute;left:-999px;top:10px;background:var(--gold2);color:#060606;padding:10px 14px;border-radius:10px;z-index:999;font-weight:950}.skip-link:focus{left:10px}
.kicker{display:inline-flex;align-items:center;gap:12px;color:var(--gold2);font-size:12px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;margin:0 0 16px}.kicker::before{content:"";width:30px;height:1px;background:var(--gold2)}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 22px;border-radius:4px;border:1px solid var(--gold);background:var(--gold);color:#070707;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:.18s ease}.btn:hover{transform:translateY(-2px);filter:brightness(1.08)}.btn.dark{background:#101010;border-color:#242424;color:#fff}.btn.outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.25)}.btn:focus-visible,.tab-btn:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--gold2);outline-offset:3px}
.header{position:fixed;top:0;left:0;right:0;z-index:90;background:#030303;border-bottom:1px solid rgba(255,255,255,.08)}.nav{min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;align-items:center;gap:0}.brand img{width:56px;height:56px;display:block;object-fit:contain;filter:drop-shadow(0 0 20px rgba(197,163,75,.20))}.menu{display:flex;align-items:center;gap:24px;font-size:12px;font-weight:850;text-transform:uppercase;letter-spacing:.03em}.menu a{color:#efefef;opacity:.9}.menu a.active,.menu a:hover{color:var(--gold2);opacity:1}.mobile-toggle{display:none}
.hero{position:relative;min-height:100vh;padding-top:84px;display:flex;align-items:center;overflow:hidden}.hero-bg{position:absolute;inset:84px 8px 0 8px;overflow:hidden}.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(.58) contrast(1.08) saturate(.85)}.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.87) 0%,rgba(0,0,0,.68) 38%,rgba(0,0,0,.18) 72%,rgba(0,0,0,.62) 100%)}.hero-content{position:relative;z-index:2;width:100%;padding:110px 0 76px}.hero-copy{max-width:620px}.hero-sub{font-size:clamp(24px,2.6vw,40px);line-height:1.08;color:#fff;margin-bottom:18px}.hero-line{width:min(520px,100%);height:3px;background:#fff;margin:12px 0 22px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:54px;max-width:1120px}.fact{background:rgba(0,0,0,.58);border:1px solid rgba(197,163,75,.22);padding:14px 14px;border-radius:12px;display:flex;align-items:center;gap:12px;min-height:88px}.fact-icon{display:grid;place-items:center;flex:0 0 38px;width:38px;height:38px;border-radius:10px;background:rgba(242,196,0,.10);border:1px solid rgba(242,196,0,.20);color:var(--gold2)}.fact-icon svg,.qa-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.fact-copy{display:grid;gap:4px}.fact strong{display:block;color:#fff;font-size:13px;font-weight:900;line-height:1.25;letter-spacing:.01em;text-transform:uppercase}.fact span{display:block;margin:0;font-size:11px;font-weight:780;text-transform:uppercase;letter-spacing:.08em;color:#d5d0c5}
.page-hero{padding:148px 0 70px;background:linear-gradient(120deg,rgba(0,0,0,.92),rgba(0,0,0,.68)),var(--hero-image);background-size:cover;background-position:center;border-bottom:1px solid rgba(255,255,255,.08)}.page-hero .lead{max-width:650px;font-size:20px;color:#eee;font-weight:650}.breadcrumb{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold2);font-weight:950;margin-bottom:20px}
section{padding:82px 0}.section-head{display:grid;grid-template-columns:1fr minmax(280px,440px);gap:32px;align-items:end;margin-bottom:34px}.section-head p{margin:0}.dark-band{background:#080808;border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.card,.panel,.newsletter-card,.contact-card,.faq-item,.schedule-card,.mini-card{background:#101010;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card{overflow:hidden}.card-img{height:260px;background:#050505;display:grid;place-items:center;padding:8px;border-bottom:1px solid rgba(255,255,255,.08)}.card-img img{width:100%;height:100%;object-fit:contain}.card-body,.panel,.mini-card,.schedule-card,.contact-card{padding:24px}.card-body p,.mini-card p{font-size:14px}.card-link{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center;background:var(--gold);color:#080808;border-radius:4px;font-size:12px;font-weight:950;text-transform:uppercase}
.feature-panel{padding:38px;background:#f4f0df;color:#111;border-radius:var(--radius)}.feature-panel p{color:#4a443d}.feature-list{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:24px}.feature-item{background:#111;color:#fff;border-left:4px solid var(--gold2);padding:16px;font-size:13px;font-weight:950;text-transform:uppercase}.media-panel{background:#101010;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:grid;place-items:center;padding:8px}.media-panel img{width:100%;height:100%;object-fit:contain;max-height:620px}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.tab-btn{padding:12px 16px;border-radius:4px;border:1px solid rgba(255,255,255,.16);background:#101010;color:#fff;font-size:12px;font-weight:950;text-transform:uppercase;cursor:pointer}.tab-btn.active{background:var(--gold);border-color:var(--gold);color:#080808}.schedule-panel{display:none}.schedule-panel.active{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.schedule-card h3{color:var(--gold2)}.schedule-card p{margin:0;color:#e5e2d8}
.form-grid{display:grid;gap:12px}.form-grid.two{grid-template-columns:1fr 1fr}.field{display:grid;gap:6px}.field span{font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;color:#d9d5c8}.field input,.field select{width:100%;min-height:50px;padding:0 14px;border-radius:4px;border:1px solid rgba(255,255,255,.16);background:#050505;color:#fff;font-size:14px;font-weight:750;outline:none}.result{margin-top:15px;padding:16px;border-radius:10px;background:rgba(242,196,0,.10);border:1px solid rgba(242,196,0,.24);font-size:15px;line-height:1.6;color:#f0eadc}
.scrub-section{padding:0;background:#050505}.scrub-wrap{height:155vh;position:relative}.scrub-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center}#scrubCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}.scrub-shade{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.18) 65%,rgba(0,0,0,.58))}.scrub-copy{position:relative;z-index:3;max-width:520px}.scrub-copy p{color:#ddd}
.gallery-grid{columns:3 280px;column-gap:16px}.gallery-card{break-inside:avoid;margin:0 0 16px;background:#0f0f0f;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);cursor:pointer}.gallery-card img{width:100%;height:auto;display:block}.gallery-info{padding:16px 18px}.gallery-info p{font-size:13px;margin:0}
.newsletter-card{display:grid;grid-template-columns:1fr .9fr;gap:24px;align-items:center;padding:34px;background:#f4f0df;color:#111}.newsletter-card p{color:#4c463f}.newsletter-form{display:grid;gap:12px}.newsletter-form input{width:100%;min-height:52px;padding:0 16px;border-radius:4px;border:1px solid rgba(0,0,0,.16);background:#fff;color:#111;font-size:14px;font-weight:800;outline:none}.newsletter-form small{color:#4c463f;line-height:1.45}.faq-grid{display:grid;gap:12px}.faq-item{padding:18px 20px;box-shadow:none}.faq-question{display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer}.faq-question h3{font-size:22px;margin:0}.faq-answer{display:none;padding-top:12px;font-size:15px;line-height:1.6;color:#d8d1c2}.faq-item.open .faq-answer{display:block}.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.contact-card{box-shadow:none}.contact-card h3{color:var(--gold2);font-size:27px}.contact-card p,.contact-card a{font-size:14px;font-weight:800;line-height:1.55;color:#e5dfd1}.map-frame{margin-top:18px;border:1px solid var(--line);border-radius:14px;overflow:hidden;min-height:360px;background:#0a0a0a;box-shadow:var(--shadow)}.map-frame iframe{width:100%;height:360px;border:0;display:block;filter:grayscale(.9) invert(.88) contrast(.82)}
footer{padding:44px 0 54px;background:#030303;border-top:1px solid rgba(255,255,255,.08)}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px}footer img{width:58px;height:58px;object-fit:contain;margin-bottom:12px}footer p,footer a{font-size:14px;line-height:1.7;color:#cfc8b8}.policy-links{display:grid;gap:8px}.quick-actions{position:fixed;right:14px;bottom:14px;z-index:95;display:grid;gap:8px}.quick-actions a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:999px;background:rgba(5,5,5,.92);border:1px solid rgba(197,163,75,.24);box-shadow:0 14px 34px rgba(0,0,0,.42);font-size:11px;font-weight:900;text-transform:uppercase;color:#fff;letter-spacing:.04em}.qa-icon{display:grid;place-items:center;flex:0 0 24px;width:24px;height:24px;border-radius:999px;background:rgba(242,196,0,.10);border:1px solid rgba(242,196,0,.22);color:var(--gold2)}.qa-label{display:block}.lightbox{position:fixed;inset:0;z-index:130;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.88);padding:22px}.lightbox.open{display:flex}.lightbox img{max-width:min(1100px,94vw);max-height:88vh;border-radius:14px;border:1px solid var(--lineGold)}.lightbox button{position:absolute;top:20px;right:20px}
@media(max-width:1120px){.hero-copy{margin-left:0}.grid-4,.contact-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.newsletter-card{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}}
@media(max-width:860px){html{scroll-padding-top:74px}body{padding-bottom:80px}.container{width:min(var(--max),calc(100% - 24px))}.nav{min-height:66px}.brand img{width:44px;height:44px}.mobile-toggle{display:inline-flex;min-height:40px;align-items:center;padding:0 13px;background:transparent;border:1px solid rgba(255,255,255,.24);border-radius:4px;color:#fff;font-size:12px;font-weight:950;text-transform:uppercase}.menu{position:fixed;top:66px;left:12px;right:12px;display:none;flex-direction:column;align-items:stretch;max-height:calc(100svh - 88px);overflow:auto;padding:14px;background:#050505;border:1px solid rgba(197,163,75,.28);border-radius:10px;box-shadow:0 24px 80px rgba(0,0,0,.65)}.menu.open{display:flex}.menu a{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.08)}.menu .btn{margin-top:8px}.hero{min-height:auto;padding-top:66px}.hero-bg{inset:66px 0 0 0}.hero-bg::after{background:linear-gradient(90deg,rgba(0,0,0,.90),rgba(0,0,0,.58)),linear-gradient(0deg,rgba(0,0,0,.36),transparent)}.hero-content{padding:100px 0 38px}h1{font-size:clamp(42px,13vw,70px)}h2{font-size:clamp(34px,10vw,54px)}.hero-sub{font-size:24px}.hero-line{height:2px}.hero-actions{display:grid;grid-template-columns:1fr;max-width:360px}.hero-actions .btn{width:100%}.hero-facts{grid-template-columns:1fr;gap:8px;margin-top:28px;max-width:420px}.fact{padding:12px 14px;display:flex;align-items:center;gap:12px;min-height:0}.page-hero{padding:108px 0 48px}section{padding:54px 0}.section-head{grid-template-columns:1fr;gap:12px;margin-bottom:22px}.grid-3,.grid-4,.contact-grid,.form-grid.two,.schedule-panel.active{grid-template-columns:1fr}.card-img{height:auto}.card-img img{height:auto;max-height:430px}.feature-panel,.panel,.newsletter-card{padding:22px}.feature-list{grid-template-columns:1fr}.media-panel img{height:auto;max-height:520px}.tabs{display:flex;overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;flex:0 0 auto}.scrub-wrap{height:145vh}.scrub-sticky{height:100svh;min-height:620px}.scrub-shade{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48))}.gallery-grid{columns:1}.map-frame,.map-frame iframe{height:290px;min-height:290px}.quick-actions{left:10px;right:10px;bottom:10px;grid-template-columns:repeat(3,1fr);gap:8px}.quick-actions a{justify-content:center;flex-direction:column;gap:4px;padding:8px 6px;font-size:10px;line-height:1.1;border-radius:14px}.qa-icon{width:24px;height:24px;flex-basis:24px}.qa-label{display:block}footer{padding-bottom:106px}}
@media(max-width:420px){.container{width:min(var(--max),calc(100% - 20px))}h1{font-size:clamp(40px,14vw,62px)}}


/* --- M4RTIAL update: logo clean, icon-only callouts, photo-adaptive discipline cards --- */
.brand{gap:0!important;background:transparent!important;border:0!important;box-shadow:none!important}
.brand img{width:58px!important;height:58px!important;display:block!important;object-fit:contain!important;background:transparent!important;border:0!important;box-shadow:none!important;mix-blend-mode:normal!important;filter:drop-shadow(0 0 18px rgba(197,163,75,.18))!important}
.brand span{display:none!important}

.hero-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:52px;max-width:1120px}
.fact{background:rgba(0,0,0,.55);border:1px solid rgba(197,163,75,.20);padding:12px 13px;border-radius:12px;display:flex;align-items:center;gap:11px;min-height:78px}
.fact-icon{display:grid;place-items:center;flex:0 0 34px;width:34px;height:34px;border-radius:10px;background:rgba(242,196,0,.09);border:1px solid rgba(242,196,0,.19);color:var(--gold2)}
.fact-icon svg,.qa-icon svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}
.fact-copy{display:grid;gap:3px;min-width:0}
.fact strong{display:block;color:#fff;font-size:12px;font-weight:900;line-height:1.22;letter-spacing:.01em;text-transform:uppercase}
.fact span{display:block;margin:0;font-size:10px;font-weight:780;text-transform:uppercase;letter-spacing:.08em;color:#d5d0c5}

.quick-actions{position:fixed;right:14px;bottom:14px;z-index:95;display:grid;gap:8px!important}
.quick-actions a{width:44px;height:44px;padding:0!important;display:grid!important;place-items:center!important;border-radius:999px!important;background:rgba(5,5,5,.92)!important;border:1px solid rgba(197,163,75,.26)!important;box-shadow:0 14px 34px rgba(0,0,0,.42)!important;color:#fff!important}
.quick-actions .qa-label{display:none!important}
.qa-icon{display:grid;place-items:center;width:24px!important;height:24px!important;border-radius:999px;background:rgba(242,196,0,.10);border:1px solid rgba(242,196,0,.22);color:var(--gold2)}

/* Disciplina / area cards: image block and text block are separated; no overlay, no forced crop */
.card{display:flex;flex-direction:column;overflow:hidden}
.card-img{height:auto!important;min-height:0!important;padding:0!important;background:#050505;display:block;border-bottom:1px solid rgba(255,255,255,.08)}
.card-img img{width:100%!important;height:auto!important;max-height:none!important;object-fit:contain!important;display:block!important;background:#050505}
.card-body{position:relative;z-index:2;background:#101010;padding:22px 22px 24px!important}
.card-body p{min-height:auto!important;margin-bottom:16px}
.grid-4 .card{align-self:start}

@media(max-width:860px){
  body{padding-bottom:0!important}
  .brand img{width:46px!important;height:46px!important}
  .hero-facts{grid-template-columns:1fr;gap:8px;margin-top:28px;max-width:420px}
  .fact{padding:10px 12px;min-height:62px}
  .fact-icon{width:32px;height:32px;flex-basis:32px}
  .quick-actions{right:12px!important;left:auto!important;bottom:12px!important;grid-template-columns:1fr!important;gap:7px!important}
  .quick-actions a{width:42px!important;height:42px!important;padding:0!important;border-radius:999px!important}
  .card-img img{max-height:none!important}
}
@media(max-width:420px){
  .brand img{width:44px!important;height:44px!important}
}


/* =====================================================================
   M4RTIAL v3 — tema blanco global + reserva en landing + tarifas activas
   ===================================================================== */
body:not(.landing-light){background:#ffffff!important;color:#111111!important;padding-bottom:0!important}
body:not(.landing-light)::before{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(180deg,#ffffff 0%,#fbfaf6 54%,#ffffff 100%)}
body:not(.landing-light) .header{background:rgba(255,255,255,.94)!important;border-bottom:1px solid rgba(16,16,16,.08)!important;backdrop-filter:blur(18px)}
body:not(.landing-light) .nav{min-height:76px}
body:not(.landing-light) .brand img{width:54px!important;height:54px!important;background:transparent!important;border:0!important;box-shadow:none!important;filter:drop-shadow(0 8px 18px rgba(130,95,20,.16))!important}
body:not(.landing-light) .menu a{color:#151515!important;opacity:.78}
body:not(.landing-light) .menu a.active,body:not(.landing-light) .menu a:hover{color:#9d7600!important;opacity:1}
body:not(.landing-light) .menu .btn, body:not(.landing-light) .btn{background:#111!important;border-color:#111!important;color:#fff!important;border-radius:999px}
body:not(.landing-light) .btn.outline{background:#fff!important;color:#111!important;border-color:rgba(16,16,16,.18)!important}
body:not(.landing-light) .mobile-toggle{color:#111!important;border-color:rgba(0,0,0,.18)!important;background:#fff!important}
body:not(.landing-light) main,body:not(.landing-light) section,body:not(.landing-light) .dark-band,body:not(.landing-light) .scrub-section,body:not(.landing-light) footer{background:#fff!important;color:#111!important;border-color:rgba(16,16,16,.08)!important}
body:not(.landing-light) .page-hero{padding:132px 0 58px!important;background:#fff!important;border-bottom:1px solid rgba(16,16,16,.08)!important;color:#111!important}
body:not(.landing-light) h1,body:not(.landing-light) h2,body:not(.landing-light) h3{color:#111!important}
body:not(.landing-light) p,body:not(.landing-light) .page-hero .lead,body:not(.landing-light) .section-head p{color:#625e55!important}
body:not(.landing-light) .breadcrumb,body:not(.landing-light) .kicker{color:#9d7600!important}
body:not(.landing-light) .kicker::before{background:#c5a34b!important}
body:not(.landing-light) .card,body:not(.landing-light) .panel,body:not(.landing-light) .newsletter-card,body:not(.landing-light) .contact-card,body:not(.landing-light) .faq-item,body:not(.landing-light) .schedule-card,body:not(.landing-light) .mini-card,body:not(.landing-light) .media-panel,body:not(.landing-light) .legal-box{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.08)!important;box-shadow:0 18px 55px rgba(23,20,12,.08)!important;border-radius:24px!important}
body:not(.landing-light) .card-body{background:#fff!important;color:#111!important}
body:not(.landing-light) .card-img,body:not(.landing-light) .media-panel{background:#f5f1e7!important;border-color:rgba(16,16,16,.07)!important}
body:not(.landing-light) .card-img img{background:#0b0b0a!important}
body:not(.landing-light) .feature-panel{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.08)!important;box-shadow:0 18px 55px rgba(23,20,12,.08)!important}
body:not(.landing-light) .feature-panel p{color:#625e55!important}
body:not(.landing-light) .feature-item{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.08)!important;border-left:4px solid #c5a34b!important;border-radius:14px!important}
body:not(.landing-light) .tab-btn{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.12)!important;border-radius:999px!important}
body:not(.landing-light) .tab-btn.active{background:#111!important;border-color:#111!important;color:#fff!important}
body:not(.landing-light) .schedule-card h3,body:not(.landing-light) .contact-card h3{color:#111!important}
body:not(.landing-light) .schedule-card p,body:not(.landing-light) .contact-card p,body:not(.landing-light) .contact-card a{color:#4b453e!important}
body:not(.landing-light) .field span{color:#514d46!important}
body:not(.landing-light) .field input,body:not(.landing-light) .field select{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.12)!important;border-radius:14px!important}
body:not(.landing-light) .result{background:#fff9df!important;border:1px solid rgba(197,163,75,.24)!important;color:#4d4639!important}
body:not(.landing-light) .newsletter-card p,body:not(.landing-light) .newsletter-form small{color:#625e55!important}
body:not(.landing-light) .newsletter-form input{background:#fff!important;color:#111!important;border:1px solid rgba(16,16,16,.12)!important;border-radius:999px!important}
body:not(.landing-light) .faq-answer{color:#625e55!important}
body:not(.landing-light) .map-frame{background:#fff!important;border:1px solid rgba(16,16,16,.08)!important;box-shadow:0 18px 55px rgba(23,20,12,.08)!important}
body:not(.landing-light) .map-frame iframe{filter:none!important}
body:not(.landing-light) footer p,body:not(.landing-light) footer a{color:#68635a!important}
body:not(.landing-light) .quick-actions a{background:#fff!important;color:#111!important;border-color:rgba(16,16,16,.12)!important;box-shadow:0 14px 34px rgba(23,20,12,.13)!important}
body:not(.landing-light) .qa-icon{background:#fff6cd!important;color:#9d7600!important;border-color:rgba(197,163,75,.22)!important}
.card-link{border-radius:999px!important;background:#111!important;color:#fff!important}

.price-notice{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;padding:28px;border:1px solid rgba(16,16,16,.08);border-radius:28px;background:#fff;box-shadow:0 18px 55px rgba(23,20,12,.08)}
.price-notice h2{font-size:clamp(32px,4vw,54px);margin-bottom:10px;color:#111!important}
.price-notice p{margin:0;color:#625e55!important;max-width:680px}
.price-notice span{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 16px;border-radius:999px;background:#fff6cd;border:1px solid rgba(197,163,75,.24);color:#9d7600;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.price-card{min-height:310px;display:flex;flex-direction:column;justify-content:space-between;padding:24px;border:1px solid rgba(16,16,16,.08);border-radius:26px;background:#fff;box-shadow:0 18px 55px rgba(23,20,12,.08)}
.price-card h3{font-size:24px;line-height:1.05;margin:12px 0 10px;color:#111!important;letter-spacing:-.035em}
.price-card p{font-size:14px;line-height:1.55;color:#625e55!important;margin-bottom:0}
.plan-tag{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#f5f1e7;border:1px solid rgba(16,16,16,.07);font-size:10px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#6d6250}
.price{font-size:42px;line-height:1;font-weight:950;letter-spacing:-.055em;color:#111;margin-top:22px}
.tax-note{font-size:12px!important;text-transform:uppercase;letter-spacing:.08em;font-weight:850;color:#9d7600!important;margin:8px 0 16px!important}
.btn-full{width:100%;min-height:46px}.btn-sm{min-height:44px;padding:0 18px}

@media(max-width:1120px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  body:not(.landing-light) .nav{min-height:66px}
  body:not(.landing-light) .brand img{width:46px!important;height:46px!important}
  body:not(.landing-light) .menu{background:#fff!important;color:#111!important;border-color:rgba(16,16,16,.10)!important;box-shadow:0 24px 80px rgba(23,20,12,.16)!important}
  body:not(.landing-light) .menu a{color:#111!important;border-bottom:1px solid rgba(16,16,16,.07)!important}
  body:not(.landing-light) .page-hero{padding:104px 0 44px!important}
  body:not(.landing-light) section{padding:52px 0!important}
  .price-notice{display:grid;padding:22px}.price-grid{grid-template-columns:1fr}.price-card{min-height:auto}
}


/* =====================================================================
   M4RTIAL v4 — blanco forzado en páginas internas + reserva arriba
   ===================================================================== */
html,
body.theme-white,
body.theme-white main,
body.theme-white section,
body.theme-white .white-band,
body.theme-white .dark-band,
body.theme-white footer{
  background:#ffffff!important;
  color:#111111!important;
}
body.theme-white{
  background:#ffffff!important;
  color:#111111!important;
  padding-bottom:0!important;
}
body.theme-white::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background:#ffffff!important;
}
body.theme-white .header{
  background:rgba(255,255,255,.96)!important;
  border-bottom:1px solid rgba(16,16,16,.08)!important;
  backdrop-filter:blur(18px);
}
body.theme-white .menu a{
  color:#151515!important;
  opacity:.82!important;
}
body.theme-white .menu a.active,
body.theme-white .menu a:hover{
  color:#9d7600!important;
  opacity:1!important;
}
body.theme-white .page-hero{
  background:#ffffff!important;
  color:#111111!important;
  border-bottom:1px solid rgba(16,16,16,.08)!important;
  padding:132px 0 58px!important;
}
body.theme-white .page-hero::before,
body.theme-white .page-hero::after,
body.theme-white .dark-band::before,
body.theme-white .dark-band::after,
body.theme-white .white-band::before,
body.theme-white .white-band::after{
  display:none!important;
  content:none!important;
}
body.theme-white h1,
body.theme-white h2,
body.theme-white h3{
  color:#111111!important;
}
body.theme-white p,
body.theme-white .lead,
body.theme-white .page-hero .lead,
body.theme-white .section-head p,
body.theme-white .faq-answer,
body.theme-white .scrub-copy p{
  color:#625e55!important;
}
body.theme-white .breadcrumb,
body.theme-white .kicker{
  color:#9d7600!important;
}
body.theme-white .kicker::before{
  background:#c5a34b!important;
}
body.theme-white .card,
body.theme-white .panel,
body.theme-white .newsletter-card,
body.theme-white .contact-card,
body.theme-white .faq-item,
body.theme-white .schedule-card,
body.theme-white .mini-card,
body.theme-white .media-panel,
body.theme-white .feature-panel,
body.theme-white .legal-box,
body.theme-white .price-card,
body.theme-white .price-notice{
  background:#ffffff!important;
  color:#111111!important;
  border:1px solid rgba(16,16,16,.08)!important;
  box-shadow:0 18px 55px rgba(23,20,12,.08)!important;
  border-radius:24px!important;
}
body.theme-white .card-body{
  background:#ffffff!important;
  color:#111111!important;
}
body.theme-white .card-img,
body.theme-white .media-panel{
  background:#f5f1e7!important;
  border-color:rgba(16,16,16,.07)!important;
}
body.theme-white .feature-panel p,
body.theme-white .mini-card p,
body.theme-white .contact-card p,
body.theme-white .contact-card a,
body.theme-white .schedule-card p,
body.theme-white footer p,
body.theme-white footer a{
  color:#625e55!important;
}
body.theme-white .feature-item{
  background:#ffffff!important;
  color:#111111!important;
  border:1px solid rgba(16,16,16,.08)!important;
  border-left:4px solid #c5a34b!important;
  border-radius:14px!important;
}
body.theme-white .map-frame{
  background:#ffffff!important;
  border:1px solid rgba(16,16,16,.08)!important;
  box-shadow:0 18px 55px rgba(23,20,12,.08)!important;
}
body.theme-white .map-frame iframe{
  filter:none!important;
}
body.theme-white .btn{
  background:#111111!important;
  border-color:#111111!important;
  color:#ffffff!important;
  border-radius:999px!important;
}
body.theme-white .btn.outline{
  background:#ffffff!important;
  border-color:rgba(16,16,16,.18)!important;
  color:#111111!important;
}
body.theme-white .tab-btn{
  background:#ffffff!important;
  color:#111111!important;
  border:1px solid rgba(16,16,16,.12)!important;
  border-radius:999px!important;
}
body.theme-white .tab-btn.active{
  background:#111111!important;
  color:#ffffff!important;
  border-color:#111111!important;
}
body.theme-white .field span{
  color:#514d46!important;
}
body.theme-white .field input,
body.theme-white .field select{
  background:#ffffff!important;
  color:#111111!important;
  border:1px solid rgba(16,16,16,.12)!important;
  border-radius:14px!important;
}
body.theme-white .result{
  background:#fff9df!important;
  border:1px solid rgba(197,163,75,.24)!important;
  color:#4d4639!important;
}
body.theme-white .quick-actions a{
  background:#ffffff!important;
  color:#111111!important;
  border-color:rgba(16,16,16,.12)!important;
  box-shadow:0 14px 34px rgba(23,20,12,.13)!important;
}
body.theme-white .qa-icon{
  background:#fff6cd!important;
  color:#9d7600!important;
  border-color:rgba(197,163,75,.22)!important;
}
body.theme-white .scrub-section,
body.theme-white .scrub-wrap,
body.theme-white .scrub-sticky,
body.theme-white .scrub-shade{
  background:#ffffff!important;
  color:#111111!important;
}
body.theme-white #scrubCanvas{
  display:none!important;
}
body.landing-light #reserva.reservation-first{
  padding-top:38px!important;
  padding-bottom:58px!important;
  background:#ffffff!important;
  border-top:1px solid rgba(16,16,16,.06)!important;
  border-bottom:1px solid rgba(16,16,16,.06)!important;
}
body.landing-light #reserva.reservation-first .light-section-head{
  margin-bottom:22px!important;
}
body.landing-light #reserva.reservation-first .interactive-panel{
  min-height:100%;
}
@media(max-width:860px){
  body.theme-white .page-hero{padding:104px 0 44px!important;}
  body.theme-white section{padding:52px 0!important;}
}


/* =====================================================================
   M4RTIAL v8 — servicios Corporate / Academy / Kids
   ===================================================================== */
.centered-actions{justify-content:center;margin-top:26px!important;margin-bottom:0!important}
.single-head{grid-template-columns:1fr!important;text-align:left}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
.service-card{padding:26px;border-radius:28px;background:#fff;border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.08);display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-height:310px;color:#111}
.service-card-main{grid-column:span 1}
.service-card h2,.service-card h3{font-size:clamp(25px,2.1vw,34px);line-height:1.02;letter-spacing:-.045em;margin:0;color:#111!important}
.service-card p{margin:0;color:#625e55!important;font-size:15px;line-height:1.62}
.service-card .btn{width:max-content;max-width:100%;min-height:44px}
.service-tag{display:inline-flex;align-items:center;width:max-content;min-height:30px;padding:0 12px;border-radius:999px;background:#fff6cd;border:1px solid rgba(197,163,75,.24);color:#9d7600;font-size:10px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}
.clean-list{display:grid;gap:10px;margin:0;padding:0;list-style:none;color:#625e55;font-size:15px;line-height:1.55}
.clean-list li{position:relative;padding-left:18px}
.clean-list li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;background:#c5a34b}
.split-service{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}
.service-intro{display:flex;flex-direction:column;justify-content:space-between;gap:24px}
.service-intro h2{font-size:clamp(34px,4vw,60px);line-height:.96;letter-spacing:-.055em;margin:0;color:#111!important}
.service-stack{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.highlight-price{display:flex;flex-direction:column;justify-content:space-between;gap:18px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.service-mini-grid .mini-card{min-height:110px;display:grid;place-items:center;text-align:center}
.price-grid-3{grid-template-columns:repeat(3,1fr)}
.small-price{font-size:32px!important;line-height:1.05!important}
.landing-services-grid .service-card{min-height:280px}
.landing-light .service-card .btn.outline, body.theme-white .service-card .btn.outline{background:#fff!important;border-color:rgba(16,16,16,.18)!important;color:#111!important}
@media(max-width:1120px){
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .split-service{grid-template-columns:1fr}
  .price-grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-5{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .light-hero h1{font-size:clamp(38px,11vw,58px)!important;line-height:.96!important}
  .light-section-head h2,.reviews-header h2,.service-intro h2,.price-notice h2{font-size:clamp(30px,8.8vw,44px)!important;line-height:1.02!important}
  body.theme-white h1{font-size:clamp(34px,10vw,52px)!important;line-height:1.02!important}
  body.theme-white h2{font-size:clamp(28px,8.6vw,42px)!important;line-height:1.04!important}
  .service-grid,.service-stack,.price-grid-3,.grid-5{grid-template-columns:1fr!important}
  .service-card{min-height:auto;padding:22px;border-radius:24px}
  .service-card .btn{width:100%}
  .centered-actions{display:grid!important;grid-template-columns:1fr;max-width:360px;margin-left:auto;margin-right:auto}
}


/* =====================================================================
   M4RTIAL v9 — Team próximamente
   ===================================================================== */
.service-card-soon{background:linear-gradient(180deg,#ffffff 0%,#fffaf0 100%)!important;border-color:rgba(197,163,75,.24)!important}
.service-card-soon .service-tag{background:#111!important;border-color:#111!important;color:#fff!important}
.team-hero-soon{background:linear-gradient(180deg,#ffffff 0%,#faf8f1 100%)!important}
.team-soon-panel{background:linear-gradient(180deg,#ffffff 0%,#fffaf0 100%)!important;border-color:rgba(197,163,75,.24)!important}
.team-soon-panel .service-tag{margin-bottom:18px}
.landing-services-grid .service-card-soon{grid-column:span 2}
@media(max-width:1120px){.landing-services-grid .service-card-soon{grid-column:span 2}}
@media(max-width:860px){.landing-services-grid .service-card-soon{grid-column:span 1}.menu a{font-size:12px}}


/* M4RTIAL v10 — ajustes de tarifas y cabecera */
.price-notice.only-note{justify-content:flex-start!important;padding:18px 24px!important}
.price-notice.only-note span{font-size:12px!important}


/* =====================================================================
   M4RTIAL v12 — premium visual system without changing structure
   ===================================================================== */
:root{
  --font-body:"Inter",Arial,Helvetica,sans-serif;
  --font-display:"Sora",Inter,Arial,Helvetica,sans-serif;
  --white:#ffffff;
  --surface:#ffffff;
  --surface-alt:#faf8f3;
  --surface-soft:#f5f1e7;
  --text:#111111;
  --text-soft:#625e55;
  --gold:#b88a24;
  --gold2:#d2aa3a;
  --border-soft:rgba(16,16,16,.08);
  --shadow-soft:0 18px 55px rgba(23,20,12,.08);
  --shadow-hover:0 26px 80px rgba(23,20,12,.12);
}
html{font-size:16px}
body{font-family:var(--font-body)}
h1,h2,h3,.menu,.btn,.card-link,.reviews-google-link,.service-tag,.plan-tag,.light-kicker,.kicker,.breadcrumb,.price,.review-card strong,.review-card h3,.fact strong,.light-fact strong{font-family:var(--font-display)!important}
h1,h2,h3{letter-spacing:-.05em}
p{color:var(--text-soft)}
section{padding:88px 0}
.header{backdrop-filter:blur(16px);box-shadow:0 12px 34px rgba(23,20,12,.06)}
.nav{gap:28px}
.menu{gap:22px}
.menu a{position:relative;padding:10px 0;transition:color .25s ease,opacity .25s ease}
.menu a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold2));transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.menu a:hover::after,.menu a.active::after,.menu a.active-section::after{transform:scaleX(1)}
.menu a.active-section{color:var(--gold2)!important;opacity:1!important}
.brand img{transition:transform .25s ease,filter .25s ease}
.brand:hover img{transform:translateY(-1px) scale(1.03);filter:drop-shadow(0 12px 28px rgba(184,138,36,.25))}
.btn,.reviews-google-link,.card-link{min-height:46px;border-radius:999px!important;font-size:11px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;box-shadow:0 14px 30px rgba(17,17,17,.08);transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease}
.btn:hover,.reviews-google-link:hover,.card-link:hover{transform:translateY(-3px);box-shadow:0 22px 42px rgba(17,17,17,.12)}
.btn.outline:hover,.service-card .btn.outline:hover,.landing-light .service-card .btn.outline:hover,body.theme-white .service-card .btn.outline:hover,body.theme-white .btn.outline:hover{background:#111!important;color:#fff!important;border-color:#111!important}
.section-head h2,.light-section-head h2,.reviews-header h2,.price-notice h2,.light-final-cta h2,.page-hero h1{position:relative;padding-top:16px}
.section-head h2::before,.light-section-head h2::before,.reviews-header h2::before,.price-notice h2::before,.light-final-cta h2::before,.page-hero h1::before{content:"";position:absolute;top:0;left:0;width:54px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold2))}
.centered-actions{gap:14px!important}
.card,.panel,.newsletter-card,.contact-card,.faq-item,.schedule-card,.mini-card,.media-panel,.light-card,.light-panel,.service-card,.review-card,.price-card,.price-notice,.interactive-panel,.light-final-cta,body.theme-white .card,body.theme-white .panel,body.theme-white .newsletter-card,body.theme-white .contact-card,body.theme-white .faq-item,body.theme-white .schedule-card,body.theme-white .mini-card,body.theme-white .media-panel,body.theme-white .feature-panel,body.theme-white .legal-box,body.theme-white .price-card,body.theme-white .price-notice{border:1px solid var(--border-soft)!important;box-shadow:var(--shadow-soft)!important;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease,background .28s ease}
.card:hover,.panel:hover,.newsletter-card:hover,.contact-card:hover,.faq-item:hover,.schedule-card:hover,.mini-card:hover,.light-card:hover,.light-panel:hover,.service-card:hover,.review-card:hover,.price-card:hover,.interactive-panel:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)!important;border-color:rgba(184,138,36,.18)!important}
.service-card,.price-card,.review-card,.interactive-panel{position:relative;overflow:hidden}
.service-card::before,.price-card::before,.review-card::before,.interactive-panel::before,.light-panel::before,.mini-card::before,.contact-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,rgba(184,138,36,.92),rgba(210,170,58,.55),rgba(184,138,36,0));opacity:.9}
.service-tag,.plan-tag{display:inline-flex;align-items:center;gap:8px;min-height:32px;padding:0 12px;border-radius:999px;background:var(--surface-soft);border:1px solid rgba(16,16,16,.07);font-size:10px;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:#6b5a3b}
.service-tag::before,.plan-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(180deg,var(--gold2),var(--gold))}
body.theme-white .field input,body.theme-white .field select,.app-landing-grid .field input,.app-landing-grid .field select,.newsletter-form input{min-height:54px;border-radius:18px!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
body.theme-white .field input:focus,body.theme-white .field select:focus,.app-landing-grid .field input:focus,.app-landing-grid .field select:focus,.newsletter-form input:focus{border-color:rgba(184,138,36,.45)!important;box-shadow:0 0 0 4px rgba(184,138,36,.10)!important}
.result{border-radius:18px}
.review-card{min-height:232px}
.review-stars{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 10px;border-radius:999px;background:#fff6cd;border:1px solid rgba(184,138,36,.18);width:max-content;color:#8f6a15;font-size:12px;letter-spacing:.16em}
.review-card strong{font-size:36px}
.price{font-size:48px}
.footer-grid{align-items:start}
footer{background:linear-gradient(180deg,#fff 0%,#fbfaf6 100%)!important}
footer h3{font-size:24px;margin-bottom:12px}
.policy-links{display:grid;gap:8px}
.quick-actions a{transition:transform .22s ease,box-shadow .22s ease}
.quick-actions a:hover{transform:translateY(-3px);box-shadow:0 18px 36px rgba(23,20,12,.16)!important}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.2,.65,.15,1),transform .65s cubic-bezier(.2,.65,.15,1)}
.reveal.visible{opacity:1;transform:none}

@media(max-width:1120px){
  section{padding:72px 0}
}
@media(max-width:860px){
  html{font-size:15px}
  section{padding:56px 0}
  h1{font-size:clamp(38px,10vw,60px)!important}
  h2,.light-section-head h2,.reviews-header h2,.price-notice h2,.page-hero h1{font-size:clamp(30px,8.5vw,42px)!important;line-height:1!important}
  h3,.service-card h2,.service-card h3,.review-card h3,.price-card h3{font-size:clamp(22px,6vw,28px)!important}
  p,.light-section-head p,.section-head p,.light-hero .lead,.review-card p{font-size:14px!important;line-height:1.6!important}
  .menu a{font-size:11px!important}
  .btn,.reviews-google-link,.card-link{min-height:44px;font-size:10px;padding:0 16px}
  .card,.panel,.newsletter-card,.contact-card,.faq-item,.schedule-card,.mini-card,.light-card,.light-panel,.service-card,.review-card,.price-card,.interactive-panel{border-radius:22px!important}
  .page-hero{padding:104px 0 42px!important}
}


/* =====================================================================
   M4RTIAL v13 — tipografía compacta, corporativa y de impacto
   ===================================================================== */
:root{
  --font-display:"Roboto Condensed",Inter,Arial,Helvetica,sans-serif;
}
h1,h2,h3,.menu,.btn,.card-link,.reviews-google-link,.service-tag,.plan-tag,.light-kicker,.kicker,.breadcrumb,.price,.review-card strong,.review-card h3,.fact strong,.light-fact strong{
  font-family:var(--font-display)!important;
  font-stretch:condensed;
}
h1,h2,h3,.light-hero h1,.light-section-head h2,.reviews-header h2,.price-notice h2,.page-hero h1,.light-final-cta h2{
  letter-spacing:-.022em!important;
  font-weight:900!important;
}
.menu,.btn,.card-link,.reviews-google-link,.service-tag,.plan-tag,.light-kicker,.kicker,.breadcrumb{
  letter-spacing:.075em!important;
  font-weight:800!important;
}
.service-card h2,.service-card h3,.price-card h3,.review-card h3,.mini-card h3,.contact-card h3,.schedule-card h3{
  letter-spacing:-.015em!important;
  font-weight:800!important;
}
.light-hero h1{
  font-size:clamp(52px,6.5vw,92px)!important;
}
.light-section-head h2,.reviews-header h2,.price-notice h2,.page-hero h1{
  font-size:clamp(38px,4.4vw,62px)!important;
}
.price,.review-card strong{
  letter-spacing:-.025em!important;
}
@media(max-width:860px){
  h1,.light-hero h1{font-size:clamp(40px,12vw,62px)!important;letter-spacing:-.018em!important}
  h2,.light-section-head h2,.reviews-header h2,.price-notice h2,.page-hero h1{font-size:clamp(31px,8.4vw,43px)!important;letter-spacing:-.016em!important}
  h3,.service-card h2,.service-card h3,.review-card h3,.price-card h3{font-size:clamp(22px,5.8vw,28px)!important;letter-spacing:-.01em!important}
  .menu,.btn,.card-link,.reviews-google-link,.service-tag,.plan-tag,.light-kicker,.kicker,.breadcrumb{letter-spacing:.065em!important}
}

/* v15 — secuencia visual actualizada con storyboard M4RTIAL de 60 frames */
.landing-scrub-sticky{background:#030303!important}
#scrubCanvas{image-rendering:auto}
.landing-scrub-copy{background:rgba(0,0,0,.18)!important;border-color:rgba(255,255,255,.12)!important}


/* =====================================================================
   M4RTIAL v23 — horarios web + visuales de marca
   ===================================================================== */
.hours-highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:stretch}
.hours-highlight-card{position:relative;overflow:hidden;min-height:250px;padding:26px;border-radius:28px;background:#fff;border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.08);display:flex;flex-direction:column;justify-content:space-between;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}
.hours-highlight-card::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#111 0%,#d2aa3a 60%,rgba(210,170,58,0) 100%)}
.hours-highlight-card:hover{transform:translateY(-6px);box-shadow:0 26px 80px rgba(23,20,12,.12);border-color:rgba(184,138,36,.18)}
.hours-highlight-card span,.schedule-tag{display:inline-flex;align-items:center;width:max-content;min-height:32px;padding:0 12px;border-radius:999px;background:#fff6cd;border:1px solid rgba(197,163,75,.24);color:#8d6a13;font-family:var(--font-display);font-size:10px;font-weight:900;letter-spacing:.11em;text-transform:uppercase}
.hours-highlight-card h3{font-size:clamp(26px,2.4vw,38px);line-height:.94;margin:14px 0 12px;color:#111!important;text-transform:uppercase}
.hours-highlight-card p{font-size:15px;line-height:1.55;color:#625e55!important;margin:0 0 20px}
.hours-highlight-card strong{display:block;font-family:var(--font-display);font-size:24px;line-height:1.05;color:#111;margin-top:8px;text-transform:uppercase}
.hours-board{display:grid;gap:18px}
.hours-board-card{position:relative;overflow:hidden;padding:28px;border-radius:30px;background:#fff;border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.08)}
.hours-board-card::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#111,#d2aa3a,rgba(210,170,58,0))}
.hours-board-card h3{font-size:clamp(30px,3.4vw,54px);line-height:.9;text-transform:uppercase;margin:10px 0 20px;color:#111!important}
.hours-board-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hours-slot{padding:18px;border-radius:20px;background:#faf8f3;border:1px solid rgba(16,16,16,.07)}
.hours-slot small{display:block;font-family:var(--font-display);font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:#8d6a13;margin-bottom:8px}
.hours-slot strong{display:block;font-family:var(--font-display);font-size:28px;line-height:1;color:#111;margin-bottom:8px;text-transform:uppercase}
.hours-slot p{margin:0;font-size:14px;color:#625e55!important;line-height:1.55}
.hours-visuals{overflow:hidden}
.hours-visual-viewport{overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 0 16px;scrollbar-width:thin}
.hours-visual-track{display:flex;gap:18px;width:max-content}
.hours-visual-card{flex:0 0 min(520px,86vw);scroll-snap-align:start;border-radius:26px;overflow:hidden;background:#111;border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.10)}
.hours-visual-card img{display:block;width:100%;height:auto}
.hours-visual-card figcaption{padding:14px 18px;background:#fff;color:#111;font-family:var(--font-display);font-size:12px;font-weight:900;letter-spacing:.10em;text-transform:uppercase}
@media(max-width:980px){.hours-highlight-grid,.hours-board-grid{grid-template-columns:1fr}.hours-highlight-card{min-height:auto}.hours-board-card{padding:22px}.hours-slot strong{font-size:24px}}


/* v24 — Ropa M4RTIAL */
.apparel-highlight{background:#fff!important}
.apparel-hero-card{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;padding:32px;border-radius:32px;background:linear-gradient(135deg,#111 0%,#17130a 58%,#2a2109 100%);border:1px solid rgba(197,163,75,.24);box-shadow:0 26px 80px rgba(23,20,12,.16);color:#fff;position:relative;overflow:hidden}
.apparel-hero-card::after{content:"";position:absolute;right:-90px;top:-120px;width:320px;height:320px;border-radius:50%;background:rgba(242,196,0,.16);filter:blur(8px)}
.apparel-hero-card > *{position:relative;z-index:1}
.apparel-hero-card h3{color:#fff!important;font-size:clamp(32px,4vw,56px);margin:12px 0 10px;line-height:.96}
.apparel-hero-card p{color:#d8d0bd!important;max-width:720px;margin:0;font-size:16px}
.apparel-hero-card .service-tag{background:rgba(242,196,0,.12);border-color:rgba(242,196,0,.24);color:#f2c400}
.apparel-hero-card .btn{background:#f2c400!important;border-color:#f2c400!important;color:#111!important}
.apparel-page-hero{background:#fff!important}
.apparel-intro-card{padding:34px;border-radius:32px;background:linear-gradient(135deg,#fff 0%,#fbfaf6 62%,#fff6cd 100%);border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.08)}
.apparel-intro-card h2{font-size:clamp(36px,4.5vw,64px);line-height:.95;color:#111!important;margin:16px 0 14px}
.apparel-intro-card p{max-width:760px;color:#625e55!important;font-size:16px}
.apparel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.apparel-card{min-height:260px;padding:26px;border-radius:28px;background:#fff;border:1px solid rgba(16,16,16,.08);box-shadow:0 18px 55px rgba(23,20,12,.08);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}
.apparel-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,#b88a24,#f2c400,rgba(242,196,0,0))}
.apparel-card:hover{transform:translateY(-6px);box-shadow:0 26px 80px rgba(23,20,12,.12);border-color:rgba(184,138,36,.18)}
.apparel-card span{display:inline-flex;width:max-content;min-height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#f5f1e7;border:1px solid rgba(16,16,16,.07);color:#6b5a3b;font-family:var(--font-display);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.11em}
.apparel-card h3{font-size:clamp(25px,2.2vw,34px);line-height:1;color:#111!important;margin:18px 0 10px}
.apparel-card p{font-size:14px;color:#625e55!important;margin:0}
.apparel-card strong{display:inline-flex;width:max-content;margin-top:18px;min-height:34px;align-items:center;padding:0 12px;border-radius:999px;background:#111;color:#fff;font-family:var(--font-display);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em}
.apparel-brand-block{display:grid;gap:24px}
.apparel-brand-block h2{color:#111!important;font-size:clamp(36px,4.2vw,60px);line-height:.96}
@media(max-width:980px){.apparel-grid{grid-template-columns:repeat(2,1fr)}.apparel-hero-card{grid-template-columns:1fr}}
@media(max-width:860px){.apparel-grid{grid-template-columns:1fr}.apparel-hero-card,.apparel-intro-card{padding:24px;border-radius:24px}.apparel-hero-card .btn{width:100%}.apparel-card{min-height:auto}}


/* =====================================================================
   M4RTIAL v26 — calendario de disponibilidad en landing
   ===================================================================== */
.calendar-section{
  background:#ffffff!important;
  padding-top:58px!important;
}
.calendar-shell{
  border:1px solid rgba(16,16,16,.08);
  border-radius:30px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfaf6 100%);
  box-shadow:0 24px 75px rgba(23,20,12,.10);
  padding:24px;
  overflow:hidden;
}
.calendar-toolbar{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  margin-bottom:18px;
}
.calendar-toolbar h3{
  color:#111!important;
  margin:0 0 4px;
  font-size:clamp(24px,2.6vw,38px);
  letter-spacing:-.035em;
}
.calendar-toolbar p{
  margin:0;
  color:#625e55!important;
  font-size:14px;
}
.calendar-nav{
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(16,16,16,.10);
  background:#111;
  color:#fff;
  font-size:26px;
  line-height:1;
  font-weight:900;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease;
}
.calendar-nav:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(17,17,17,.16);
}
.calendar-filters{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:14px;
}
.calendar-filter{
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(16,16,16,.10);
  background:#fff;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
}
.calendar-filter.active,
.calendar-filter:hover{
  background:#111;
  color:#fff;
  border-color:#111;
  transform:translateY(-1px);
}
.calendar-legend{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:18px;
  color:#625e55;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.calendar-legend span{
  display:inline-flex;
  align-items:center;
  gap:7px;
}
.dot{
  width:10px;
  height:10px;
  display:inline-block;
  border-radius:50%;
  background:#111;
}
.dot-karate{background:#c5a34b}
.dot-mma{background:#111}
.dot-boxeo{background:#b12b2b}
.dot-tkd{background:#2b5fb1}

.weekly-calendar{
  display:grid;
  grid-template-columns:repeat(6,minmax(160px,1fr));
  gap:12px;
  align-items:stretch;
}
.calendar-day{
  min-height:280px;
  border-radius:24px;
  border:1px solid rgba(16,16,16,.08);
  background:#fff;
  box-shadow:0 14px 36px rgba(23,20,12,.06);
  padding:14px;
}
.calendar-day-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:8px;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid rgba(16,16,16,.07);
}
.calendar-day-name{
  display:block;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:18px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.calendar-day-date{
  display:block;
  margin-top:2px;
  color:#7b756b;
  font-size:12px;
  font-weight:800;
}
.calendar-count{
  min-width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff6cd;
  border:1px solid rgba(197,163,75,.24);
  color:#8f6a15;
  font-size:12px;
  font-weight:950;
}
.calendar-events{
  display:grid;
  gap:9px;
}
.calendar-event{
  display:block;
  width:100%;
  text-align:left;
  border:1px solid rgba(16,16,16,.08);
  border-left:5px solid #111;
  border-radius:16px;
  background:#fff;
  padding:11px 12px;
  cursor:pointer;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
}
.calendar-event:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(23,20,12,.10);
  border-color:rgba(16,16,16,.14);
}
.calendar-event.karate{border-left-color:#c5a34b}
.calendar-event.mma{border-left-color:#111}
.calendar-event.boxeo{border-left-color:#b12b2b}
.calendar-event.tkd{border-left-color:#2b5fb1}
.event-time{
  display:block;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:18px;
  font-weight:900;
  line-height:1;
  margin-bottom:5px;
}
.event-title{
  display:block;
  color:#111;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.event-meta{
  display:block;
  margin-top:4px;
  color:#706a60;
  font-size:12px;
  font-weight:700;
}
.calendar-empty{
  color:#8a8378;
  font-size:13px;
  line-height:1.45;
  background:#faf8f3;
  border:1px dashed rgba(16,16,16,.14);
  border-radius:16px;
  padding:14px;
}
.calendar-note{
  margin-top:16px;
  color:#625e55;
  font-size:13px;
  line-height:1.5;
  font-weight:700;
}
@media(max-width:1120px){
  .weekly-calendar{
    grid-template-columns:repeat(3,1fr);
  }
}
@media(max-width:860px){
  .calendar-shell{
    padding:18px;
    border-radius:26px;
  }
  .calendar-toolbar{
    grid-template-columns:auto 1fr auto;
    gap:10px;
  }
  .calendar-nav{
    width:40px;
    height:40px;
    font-size:22px;
  }
  .calendar-filters{
    flex-wrap:nowrap;
    overflow-x:auto;
    padding-bottom:6px;
    scrollbar-width:none;
  }
  .calendar-filters::-webkit-scrollbar{display:none}
  .calendar-filter{
    flex:0 0 auto;
  }
  .weekly-calendar{
    display:flex;
    overflow-x:auto;
    gap:12px;
    scroll-snap-type:x mandatory;
    padding-bottom:8px;
    scrollbar-width:none;
  }
  .weekly-calendar::-webkit-scrollbar{display:none}
  .calendar-day{
    flex:0 0 84%;
    scroll-snap-align:start;
    min-height:300px;
  }
}
@media(max-width:420px){
  .calendar-day{
    flex-basis:88%;
  }
}



/* =====================================================================
   M4RTIAL v27 — acciones dobles en calendario: WhatsApp + calendario
   ===================================================================== */
.calendar-event{
  cursor:default;
}
.calendar-event:hover{
  transform:none;
}
.calendar-event-main{
  display:block;
  margin-bottom:10px;
}
.calendar-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:7px;
  margin-top:10px;
}
.calendar-action{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.calendar-action.reserve{
  background:#111;
  color:#fff;
  border:1px solid #111;
}
.calendar-action.calendar{
  background:#fff;
  color:#111;
  border:1px solid rgba(16,16,16,.14);
}
.calendar-action:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(23,20,12,.12);
}
.calendar-action.calendar:hover{
  background:#fff6cd;
  border-color:rgba(197,163,75,.28);
  color:#8f6a15;
}
.calendar-help{
  margin-top:8px;
  color:#8a8378;
  font-size:11px;
  line-height:1.4;
  font-weight:700;
}
@media(max-width:860px){
  .calendar-actions{
    grid-template-columns:1fr;
  }
  .calendar-action{
    min-height:38px;
    font-size:10px;
  }
}


/* =====================================================================
   M4RTIAL v31 — encabezado blanco dividido + limpieza redes
   ===================================================================== */
body .header,
body.landing-light .header,
body.landing-light.hero-scrolled .header,
body:not(.landing-light) .header{
  background:#ffffff!important;
  border-bottom:1px solid rgba(16,16,16,.08)!important;
  backdrop-filter:blur(18px)!important;
  box-shadow:0 12px 34px rgba(23,20,12,.06)!important;
}
.nav.nav-split{
  position:relative;
  justify-content:center!important;
}
.nav.nav-split .brand.brand-empty{
  display:none!important;
}
.split-menu{
  width:100%;
  display:grid!important;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:28px;
}
.split-menu .menu-left,
.split-menu .menu-right{
  display:flex;
  align-items:center;
  gap:22px;
}
.split-menu .menu-left{
  justify-content:flex-start;
}
.split-menu .menu-right{
  justify-content:flex-end;
}
body .menu a,
body.landing-light .menu a,
body.landing-light.hero-scrolled .menu a,
body:not(.landing-light) .menu a{
  color:#151515!important;
  opacity:.84!important;
  text-shadow:none!important;
}
body .menu a.active,
body .menu a:hover,
body.landing-light .menu a.active,
body.landing-light .menu a:hover,
body.landing-light.hero-scrolled .menu a.active,
body.landing-light.hero-scrolled .menu a:hover,
body:not(.landing-light) .menu a.active,
body:not(.landing-light) .menu a:hover{
  color:#9d7600!important;
  opacity:1!important;
}
body .mobile-toggle,
body.landing-light .mobile-toggle,
body.landing-light.hero-scrolled .mobile-toggle,
body:not(.landing-light) .mobile-toggle{
  color:#111!important;
  border-color:rgba(0,0,0,.18)!important;
  background:#fff!important;
}
@media(max-width:860px){
  .nav.nav-split{
    justify-content:space-between!important;
  }
  .nav.nav-split::before{
    content:"M4RTIAL";
    font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
    font-size:20px;
    font-weight:900;
    letter-spacing:.04em;
    color:#111;
  }
  .split-menu{
    position:fixed!important;
    top:66px!important;
    left:12px!important;
    right:12px!important;
    width:auto!important;
    display:none!important;
    grid-template-columns:1fr!important;
    gap:0!important;
    padding:14px!important;
    background:#fff!important;
    color:#111!important;
    border:1px solid rgba(16,16,16,.10)!important;
    border-radius:14px!important;
    box-shadow:0 24px 80px rgba(23,20,12,.16)!important;
    max-height:calc(100svh - 88px)!important;
    overflow:auto!important;
  }
  .split-menu.open{
    display:grid!important;
  }
  .split-menu .menu-left,
  .split-menu .menu-right{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    gap:0!important;
  }
  .split-menu .menu-left{
    border-bottom:1px solid rgba(16,16,16,.08);
    margin-bottom:4px;
    padding-bottom:4px;
  }
  .split-menu a{
    color:#111!important;
    text-shadow:none!important;
    padding:13px 10px!important;
    border-bottom:1px solid rgba(16,16,16,.07)!important;
  }
  .split-menu .menu-right a:last-child{
    border-bottom:0!important;
  }
}


/* =====================================================================
   M4RTIAL v32 — encabezado fijo blanco absoluto sobre hero
   ===================================================================== */
html body .header,
html body.landing-light .header,
html body.landing-light.hero-scrolled .header,
html body:not(.landing-light) .header{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  z-index:9999!important;
  background:#ffffff!important;
  background-color:#ffffff!important;
  border-bottom:1px solid rgba(16,16,16,.08)!important;
  backdrop-filter:blur(18px)!important;
  -webkit-backdrop-filter:blur(18px)!important;
  box-shadow:0 12px 34px rgba(23,20,12,.08)!important;
}
html body .header::before,
html body .header::after,
html body.landing-light .header::before,
html body.landing-light .header::after{
  display:none!important;
  content:none!important;
}
html body .nav.nav-split,
html body.landing-light .nav.nav-split{
  min-height:76px!important;
}
html body .split-menu a,
html body.landing-light .split-menu a,
html body.landing-light.hero-scrolled .split-menu a{
  color:#151515!important;
  text-shadow:none!important;
}
html body .split-menu a.active,
html body .split-menu a:hover,
html body.landing-light .split-menu a.active,
html body.landing-light .split-menu a:hover{
  color:#9d7600!important;
}
html body .mobile-toggle,
html body.landing-light .mobile-toggle,
html body.landing-light.hero-scrolled .mobile-toggle{
  color:#111!important;
  border-color:rgba(0,0,0,.18)!important;
  background:#fff!important;
}
html body .landing-photo-hero{
  padding-top:76px!important;
}
html body .landing-photo-hero img{
  max-height:calc(100svh - 76px)!important;
}
@media(max-width:860px){
  html body .nav.nav-split,
  html body.landing-light .nav.nav-split{
    min-height:66px!important;
  }
  html body .header,
  html body.landing-light .header,
  html body.landing-light.hero-scrolled .header{
    background:#ffffff!important;
    background-color:#ffffff!important;
  }
  html body .landing-photo-hero{
    padding-top:66px!important;
  }
  html body .landing-photo-hero img{
    max-height:none!important;
  }
}


/* =====================================================================
   M4RTIAL v33 — menú móvil centrado y sin texto M4RTIAL
   ===================================================================== */
@media(max-width:860px){
  html body .nav.nav-split,
  html body.landing-light .nav.nav-split{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:58px!important;
    position:relative!important;
  }

  html body .nav.nav-split::before,
  html body.landing-light .nav.nav-split::before{
    display:none!important;
    content:none!important;
  }

  html body .mobile-toggle,
  html body.landing-light .mobile-toggle,
  html body.landing-light.hero-scrolled .mobile-toggle{
    position:absolute!important;
    left:50%!important;
    top:50%!important;
    transform:translate(-50%,-50%)!important;
    min-height:32px!important;
    height:32px!important;
    padding:0 11px!important;
    border-radius:999px!important;
    font-size:10px!important;
    line-height:1!important;
    letter-spacing:.08em!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    background:#fff!important;
    color:#111!important;
    border:1px solid rgba(0,0,0,.16)!important;
    box-shadow:0 8px 18px rgba(23,20,12,.08)!important;
  }

  html body .split-menu{
    top:58px!important;
  }

  html body .landing-photo-hero{
    padding-top:58px!important;
  }
}


/* =====================================================================
   M4RTIAL v34 — hero más compacto + carrusel de programas destacados
   ===================================================================== */
.landing-photo-hero{
  min-height:72svh!important;
  padding-top:76px!important;
  padding-bottom:0!important;
}
.landing-photo-hero img{
  width:min(100%,1240px)!important;
  max-height:calc(72svh - 76px)!important;
  object-fit:contain!important;
}
@media(max-width:860px){
  .landing-photo-hero{
    min-height:auto!important;
    padding-top:58px!important;
  }
  .landing-photo-hero img{
    width:100%!important;
    max-height:none!important;
  }
}

.announcements-section{
  background:#fff!important;
  padding-top:52px!important;
  padding-bottom:52px!important;
}
.announcements-shell{
  border:1px solid rgba(16,16,16,.08);
  border-radius:30px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfaf6 100%);
  box-shadow:0 24px 75px rgba(23,20,12,.10);
  padding:24px;
  overflow:hidden;
}
.announcements-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.announcements-head span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  background:#fff6cd;
  border:1px solid rgba(197,163,75,.24);
  color:#8f6a15;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.11em;
}
.announcements-head h2{
  margin:0;
  color:#111!important;
  font-size:clamp(32px,4vw,56px);
  line-height:.95;
  letter-spacing:-.045em;
}
.announcements-carousel{
  position:relative;
  overflow:hidden;
  border-radius:26px;
}
.announcements-track{
  position:relative;
  min-height:330px;
}
.announcement-slide{
  position:absolute;
  inset:0;
  display:grid;
  align-items:stretch;
  opacity:0;
  pointer-events:none;
  transform:translateX(18px);
  transition:opacity .5s ease, transform .5s ease;
  border-radius:26px;
  overflow:hidden;
  color:#fff;
  background:#111;
}
.announcement-slide.active{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0);
}
.announcement-slide::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
}
.announcement-slide:nth-child(1)::before{
  background:
    radial-gradient(circle at 80% 18%,rgba(242,196,0,.26),transparent 36%),
    linear-gradient(135deg,#111 0%,#16110a 48%,#4d3510 100%);
}
.announcement-slide:nth-child(2)::before{
  background:
    radial-gradient(circle at 82% 18%,rgba(177,43,43,.26),transparent 34%),
    linear-gradient(135deg,#111 0%,#151515 46%,#3d1111 100%);
}
.announcement-slide::after{
  content:"M4RTIAL";
  position:absolute;
  right:-20px;
  bottom:-34px;
  z-index:0;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:clamp(92px,12vw,170px);
  font-weight:900;
  line-height:1;
  color:rgba(255,255,255,.055);
  letter-spacing:-.06em;
}
.announcement-content{
  position:relative;
  z-index:1;
  min-height:330px;
  padding:34px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:790px;
}
.announcement-tag{
  width:max-content;
  min-height:32px;
  display:inline-flex;
  align-items:center;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:#f2c400;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.11em;
  margin-bottom:18px;
}
.announcement-content h3{
  color:#fff!important;
  font-size:clamp(34px,5vw,66px);
  line-height:.92;
  letter-spacing:-.045em;
  margin:0 0 16px;
}
.announcement-content p{
  color:rgba(255,255,255,.78)!important;
  font-size:16px;
  line-height:1.55;
  max-width:660px;
  margin:0 0 24px;
}
.announcement-content strong{
  width:max-content;
  min-height:42px;
  display:inline-flex;
  align-items:center;
  padding:0 18px;
  border-radius:999px;
  background:#fff;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.announcements-controls{
  position:absolute;
  z-index:3;
  left:34px;
  bottom:24px;
  display:flex;
  gap:8px;
}
.announcement-dot{
  width:34px;
  height:6px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.28);
  cursor:pointer;
  padding:0;
}
.announcement-dot.active{
  background:#f2c400;
}
.program-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.program-detail-card{
  border:1px solid rgba(16,16,16,.08);
  border-radius:26px;
  background:#fff;
  box-shadow:0 18px 55px rgba(23,20,12,.08);
  padding:26px;
}
.program-detail-card span{
  display:inline-flex;
  min-height:30px;
  align-items:center;
  padding:0 12px;
  border-radius:999px;
  background:#fff6cd;
  color:#8f6a15;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.11em;
  margin-bottom:18px;
}
.program-detail-card h2{
  color:#111!important;
  font-size:clamp(26px,3vw,38px);
  line-height:.98;
  margin-bottom:12px;
}
.program-detail-card p{
  color:#625e55!important;
  margin:0;
}
.program-cta{
  margin-top:18px;
  border-radius:28px;
  background:#111;
  color:#fff;
  padding:34px;
}
.program-cta h2{
  color:#fff!important;
  margin-bottom:10px;
}
.program-cta p{
  color:rgba(255,255,255,.75)!important;
}
@media(max-width:860px){
  .announcements-shell{
    padding:16px;
    border-radius:24px;
  }
  .announcements-head{
    display:grid;
    gap:10px;
  }
  .announcements-track{
    min-height:390px;
  }
  .announcement-content{
    min-height:390px;
    padding:26px 22px 54px;
  }
  .announcement-content h3{
    font-size:clamp(32px,10vw,48px);
  }
  .announcement-content p{
    font-size:14px;
  }
  .announcements-controls{
    left:22px;
    bottom:20px;
  }
  .program-detail-grid{
    grid-template-columns:1fr;
  }
}


/* =====================================================================
   M4RTIAL v35 — hero inicial más reducido + carrusel 4 segundos
   ===================================================================== */
html body .landing-photo-hero{
  min-height:52svh!important;
  height:auto!important;
  padding-top:76px!important;
  padding-bottom:18px!important;
  background:#050505!important;
}
html body .landing-photo-hero img{
  width:min(86%,960px)!important;
  max-width:960px!important;
  height:auto!important;
  max-height:calc(52svh - 76px)!important;
  object-fit:contain!important;
  object-position:center center!important;
  margin:0 auto!important;
}
@media(max-width:1100px){
  html body .landing-photo-hero{
    min-height:48svh!important;
    padding-top:76px!important;
    padding-bottom:14px!important;
  }
  html body .landing-photo-hero img{
    width:82%!important;
    max-height:calc(48svh - 76px)!important;
  }
}
@media(max-width:860px){
  html body .landing-photo-hero{
    min-height:auto!important;
    padding-top:58px!important;
    padding-bottom:12px!important;
  }
  html body .landing-photo-hero img{
    width:72%!important;
    max-width:310px!important;
    height:auto!important;
    max-height:none!important;
  }
}
@media(max-width:420px){
  html body .landing-photo-hero img{
    width:68%!important;
    max-width:270px!important;
  }
}


/* =====================================================================
   M4RTIAL v36 — RGPD / LSSI cookies + páginas legales
   ===================================================================== */
.cookie-banner,
.cookie-panel{
  position:fixed;
  z-index:10050;
  left:16px;
  right:16px;
  bottom:16px;
  display:none;
}
.cookie-banner.open,
.cookie-panel.open{
  display:block;
}
.cookie-box{
  width:min(980px,100%);
  margin:auto;
  border-radius:28px;
  border:1px solid rgba(16,16,16,.10);
  background:#fff;
  color:#111;
  box-shadow:0 28px 90px rgba(23,20,12,.20);
  padding:22px;
}
.cookie-box h2,
.cookie-box h3{
  color:#111!important;
  margin:0 0 10px;
  font-size:clamp(24px,3vw,38px);
  line-height:.98;
}
.cookie-box p{
  color:#625e55!important;
  margin:0 0 16px;
  font-size:14px;
  line-height:1.55;
}
.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.cookie-btn{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:0 16px;
  border:1px solid rgba(16,16,16,.14);
  background:#fff;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  cursor:pointer;
}
.cookie-btn.primary,
.cookie-btn:hover{
  background:#111;
  color:#fff;
  border-color:#111;
}
.cookie-btn.link{
  background:transparent;
  color:#8f6a15;
  border-color:rgba(197,163,75,.24);
}
.cookie-panel{
  top:0;
  bottom:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.42);
  padding:16px;
}
.cookie-panel.open{
  display:flex;
}
.cookie-panel .cookie-box{
  max-height:min(720px,calc(100svh - 32px));
  overflow:auto;
}
.cookie-category{
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  align-items:center;
  padding:16px 0;
  border-top:1px solid rgba(16,16,16,.08);
}
.cookie-category strong{
  display:block;
  color:#111;
  font-size:15px;
  margin-bottom:4px;
}
.cookie-category span{
  display:block;
  color:#625e55;
  font-size:13px;
  line-height:1.45;
}
.cookie-switch{
  position:relative;
  width:52px;
  height:30px;
  display:inline-block;
}
.cookie-switch input{
  opacity:0;
  width:0;
  height:0;
}
.cookie-slider{
  position:absolute;
  cursor:pointer;
  inset:0;
  background:#d8d4ca;
  transition:.2s;
  border-radius:999px;
}
.cookie-slider:before{
  content:"";
  position:absolute;
  width:24px;
  height:24px;
  left:3px;
  top:3px;
  background:#fff;
  transition:.2s;
  border-radius:50%;
  box-shadow:0 4px 10px rgba(0,0,0,.18);
}
.cookie-switch input:checked + .cookie-slider{
  background:#111;
}
.cookie-switch input:checked + .cookie-slider:before{
  transform:translateX(22px);
}
.cookie-switch input:disabled + .cookie-slider{
  background:#8f6a15;
  cursor:not-allowed;
}
.legal-page{
  display:grid;
  gap:16px;
}
.legal-box-pro{
  border:1px solid rgba(16,16,16,.08);
  border-radius:26px;
  background:#fff;
  box-shadow:0 18px 55px rgba(23,20,12,.08);
  padding:26px;
}
.legal-box-pro h2{
  color:#111!important;
  font-size:clamp(26px,3vw,38px);
  line-height:.98;
  margin:0 0 14px;
}
.legal-box-pro p{
  color:#625e55!important;
}
.legal-box-pro a{
  color:#8f6a15;
  font-weight:800;
}
.legal-table{
  display:grid;
  gap:10px;
}
.legal-table div{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:14px;
  padding:14px;
  border-radius:16px;
  background:#faf8f3;
  border:1px solid rgba(16,16,16,.07);
}
.legal-table strong{
  color:#111;
}
.legal-table span{
  color:#625e55;
  line-height:1.5;
}
.legal-list{
  margin:0;
  padding-left:20px;
  color:#625e55;
  line-height:1.7;
}
@media(max-width:860px){
  .cookie-banner,
  .cookie-panel{
    left:10px;
    right:10px;
    bottom:10px;
  }
  .cookie-box{
    padding:18px;
    border-radius:24px;
  }
  .cookie-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .cookie-category{
    grid-template-columns:1fr;
  }
  .legal-table div{
    grid-template-columns:1fr;
  }
  .legal-box-pro{
    padding:20px;
    border-radius:22px;
  }
}


/* =====================================================================
   M4RTIAL v37 — imágenes reales en carrusel de programas destacados
   ===================================================================== */
.announcement-slide{
  grid-template-columns:minmax(0, .95fr) minmax(320px, .75fr)!important;
}
.announcement-content{
  max-width:none!important;
}
.announcement-image{
  position:relative;
  z-index:1;
  min-height:330px;
  overflow:hidden;
}
.announcement-image::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(90deg,rgba(17,17,17,.70),rgba(17,17,17,.18) 48%,rgba(17,17,17,.08));
  pointer-events:none;
}
.announcement-image img{
  width:100%;
  height:100%;
  min-height:330px;
  object-fit:cover;
  object-position:center center;
  display:block;
  filter:saturate(.95) contrast(1.06);
  transform:scale(1.02);
  transition:transform .7s ease;
}
.announcement-slide.active .announcement-image img{
  transform:scale(1);
}
.announcement-slide:nth-child(1) .announcement-image img{
  object-position:48% center;
}
.announcement-slide:nth-child(2) .announcement-image img{
  object-position:center center;
}
@media(max-width:860px){
  .announcement-slide{
    grid-template-columns:1fr!important;
  }
  .announcement-image{
    order:-1;
    min-height:190px;
    max-height:220px;
  }
  .announcement-image::before{
    background:linear-gradient(180deg,rgba(17,17,17,.04),rgba(17,17,17,.55));
  }
  .announcement-image img{
    min-height:190px;
    max-height:220px;
  }
  .announcements-track{
    min-height:570px!important;
  }
  .announcement-content{
    min-height:350px!important;
  }
}


/* v37 — imagen superior en páginas de detalle de programas */
.program-detail-hero-img{
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(16,16,16,.08);
  box-shadow:0 24px 75px rgba(23,20,12,.10);
  margin-bottom:18px;
  background:#111;
}
.program-detail-hero-img img{
  width:100%;
  height:min(52vw,520px);
  object-fit:cover;
  object-position:center center;
  display:block;
}
@media(max-width:860px){
  .program-detail-hero-img{
    border-radius:24px;
  }
  .program-detail-hero-img img{
    height:280px;
  }
}


/* =====================================================================
   M4RTIAL v38 — recomendador integrado con reserva rápida en popout
   ===================================================================== */
.single-recommender-grid{
  display:grid!important;
  grid-template-columns:1fr!important;
}
.recommender-panel{
  max-width:980px;
  margin:0 auto;
  width:100%;
}
.form-grid.three{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.reservation-modal{
  position:fixed;
  inset:0;
  z-index:10020;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.reservation-modal.open{
  display:flex;
}
.reservation-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.52);
  backdrop-filter:blur(8px);
}
.reservation-modal-card{
  position:relative;
  z-index:1;
  width:min(760px,100%);
  max-height:calc(100svh - 36px);
  overflow:auto;
  border-radius:30px;
  background:#fff;
  border:1px solid rgba(16,16,16,.10);
  box-shadow:0 32px 110px rgba(0,0,0,.30);
  padding:30px;
}
.reservation-close{
  position:absolute;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(16,16,16,.10);
  background:#fff;
  color:#111;
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
.reservation-kicker{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  background:#fff6cd;
  border:1px solid rgba(197,163,75,.24);
  color:#8f6a15;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  letter-spacing:.11em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.reservation-modal-card h3{
  color:#111!important;
  font-size:clamp(32px,4vw,54px);
  line-height:.95;
  letter-spacing:-.045em;
  margin:0 42px 10px 0;
}
.reservation-modal-card p{
  color:#625e55!important;
  margin:0 0 18px;
}
.reservation-recommendation{
  display:grid;
  gap:7px;
  padding:18px;
  border-radius:20px;
  background:linear-gradient(135deg,#111 0%,#17120a 100%);
  margin-bottom:18px;
}
.reservation-recommendation strong{
  color:#f2c400;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:30px;
  line-height:1;
  text-transform:uppercase;
}
.reservation-recommendation span{
  color:rgba(255,255,255,.78);
  font-size:14px;
  line-height:1.5;
}
.reservation-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}
body.modal-open{
  overflow:hidden;
}
@media(max-width:860px){
  .form-grid.three{
    grid-template-columns:1fr;
  }
  .reservation-modal{
    padding:10px;
  }
  .reservation-modal-card{
    border-radius:24px;
    padding:22px;
  }
  .reservation-actions{
    display:grid;
    grid-template-columns:1fr;
  }
}


/* =====================================================================
   M4RTIAL v39 — selector de idioma ES / EN / FR / RU
   ===================================================================== */
.language-switcher{
  position:fixed;
  left:16px;
  bottom:92px;
  z-index:10010;
  display:flex;
  align-items:center;
  gap:6px;
  padding:7px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid rgba(16,16,16,.10);
  box-shadow:0 18px 44px rgba(23,20,12,.16);
}
.language-switcher-label{
  padding:0 8px 0 10px;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  white-space:nowrap;
}
.language-switcher button{
  min-width:38px;
  height:32px;
  border:1px solid rgba(16,16,16,.10);
  border-radius:999px;
  background:#fff;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  letter-spacing:.06em;
  cursor:pointer;
  transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
}
.language-switcher button:hover,
.language-switcher button.active{
  background:#111;
  color:#fff;
  border-color:#111;
  transform:translateY(-1px);
}
#google_translate_element,
.goog-te-banner-frame,
.goog-te-balloon-frame,
.skiptranslate iframe{
  display:none!important;
}
body{
  top:0!important;
}
.goog-tooltip,
.goog-tooltip:hover,
.goog-text-highlight{
  display:none!important;
  box-shadow:none!important;
  background:none!important;
}
@media(max-width:860px){
  .language-switcher{
    left:10px;
    right:10px;
    bottom:74px;
    justify-content:center;
    border-radius:22px;
    padding:8px;
  }
  .language-switcher-label{
    display:none;
  }
  .language-switcher button{
    flex:1;
    min-width:0;
    height:34px;
  }
}


/* =====================================================================
   M4RTIAL v40 — limpieza landing + traductor móvil bajo encabezado
   ===================================================================== */
@media(max-width:860px){
  .language-switcher{
    top:64px!important;
    bottom:auto!important;
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    width:auto!important;
    max-width:calc(100vw - 24px)!important;
    justify-content:center!important;
    border-radius:999px!important;
    padding:6px!important;
    box-shadow:0 14px 34px rgba(23,20,12,.14)!important;
  }
  .language-switcher button{
    flex:0 0 auto!important;
    min-width:36px!important;
    width:36px!important;
    height:30px!important;
    font-size:10px!important;
  }
}


/* =====================================================================
   M4RTIAL v41 — estructura minimalista sin títulos de sección
   ===================================================================== */

/* Oculta encabezados de sección repetitivos sin eliminar el contenido funcional */
.light-section-head,
.section-head,
.light-section-head.single-head,
.announcements-head,
.calendar-section .light-section-head,
.reviews-section .light-section-head,
.newsletter-carousel-section .light-section-head,
.hours-highlight-section .light-section-head,
.services-highlight .light-section-head,
.apparel-highlight .light-section-head{
  display:none!important;
}

/* Reduce espacios que dependían del título */
.light-section,
.announcements-section,
.calendar-section,
.reviews-section{
  padding-top:42px!important;
  padding-bottom:42px!important;
}

.reservation-first{
  padding-top:42px!important;
}

/* Mantiene los bloques internos claros y orientados a acción */
.interactive-panel h3,
.calendar-toolbar h3,
.announcement-content h3,
.review-card h3,
.service-card h3,
.price-card h3,
.contact-card h3,
.program-detail-card h2,
.legal-box-pro h2{
  margin-top:0!important;
}

/* Página interior: ocultar migas/títulos grandes cuando la información ya guía la sección */
.page-hero .breadcrumb,
.page-hero h1,
.page-hero .lead{
  display:none!important;
}
.page-hero{
  padding:86px 0 10px!important;
  min-height:auto!important;
}

/* Mantiene una lectura visual limpia sin dejar huecos vacíos */
.page-hero + section{
  padding-top:24px!important;
}

/* El carrusel mantiene contexto con sus etiquetas internas, no necesita título superior */
.announcements-shell{
  margin-top:0!important;
}

/* Ajuste móvil */
@media(max-width:860px){
  .light-section,
  .announcements-section,
  .calendar-section,
  .reviews-section{
    padding-top:30px!important;
    padding-bottom:30px!important;
  }
  .reservation-first{
    padding-top:30px!important;
  }
  .page-hero{
    padding:70px 0 4px!important;
  }
}


/* =====================================================================
   M4RTIAL v42 — carrusel más amplio, precios móvil y Fight Events
   ===================================================================== */

/* Carrusel de programas: más aire en ordenador */
@media(min-width:861px){
  .announcements-section{
    padding-top:54px!important;
    padding-bottom:58px!important;
  }
  .announcements-shell{
    padding:34px!important;
    border-radius:34px!important;
  }
  .announcements-track{
    min-height:430px!important;
  }
  .announcement-slide{
    grid-template-columns:minmax(0,1.08fr) minmax(380px,.92fr)!important;
  }
  .announcement-content{
    min-height:430px!important;
    padding:46px!important;
  }
  .announcement-content h3{
    font-size:clamp(44px,5.2vw,78px)!important;
    line-height:.92!important;
    max-width:760px!important;
  }
  .announcement-content p{
    font-size:17px!important;
    line-height:1.62!important;
    max-width:760px!important;
  }
  .announcement-image,
  .announcement-image img{
    min-height:430px!important;
  }
}

/* Tarifas móvil: más respiración sin alargar demasiado */
@media(max-width:860px){
  .price-grid,
  .plans-grid,
  .pricing-grid{
    gap:16px!important;
  }
  .price-card,
  .plan-card,
  .pricing-card{
    padding:24px!important;
    border-radius:24px!important;
  }
  .price-card h3,
  .plan-card h3,
  .pricing-card h3{
    margin-bottom:10px!important;
    line-height:1.05!important;
  }
  .price-card p,
  .plan-card p,
  .pricing-card p{
    line-height:1.55!important;
  }
  .price,
  .price-card .price{
    margin:14px 0!important;
    line-height:1!important;
  }
  .price-card .btn,
  .plan-card .btn,
  .pricing-card .btn{
    margin-top:12px!important;
  }
}

/* Landing: M4RTIAL Fight Events */
.events-highlight{
  background:#fff!important;
  padding-top:42px!important;
  padding-bottom:42px!important;
}
.events-shell{
  border-radius:32px;
  overflow:hidden;
  background:
    radial-gradient(circle at 86% 14%,rgba(242,196,0,.18),transparent 34%),
    linear-gradient(135deg,#111 0%,#16110a 48%,#050505 100%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 28px 90px rgba(23,20,12,.16);
}
.events-main{
  padding:38px;
  color:#fff;
}
.events-tag{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(242,196,0,.12);
  border:1px solid rgba(242,196,0,.22);
  color:#f2c400;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.11em;
  margin-bottom:18px;
}
.events-main h3{
  color:#fff!important;
  font-size:clamp(38px,5vw,74px);
  line-height:.92;
  letter-spacing:-.045em;
  max-width:820px;
  margin:0 0 16px;
}
.events-main p{
  color:rgba(255,255,255,.76)!important;
  max-width:760px;
  font-size:16px;
  line-height:1.62;
  margin:0 0 24px;
}
.events-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:0 0 24px;
}
.events-grid div{
  border-radius:20px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.10);
  padding:18px;
}
.events-grid strong{
  display:block;
  color:#fff;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:20px;
  line-height:1;
  margin-bottom:8px;
  text-transform:uppercase;
}
.events-grid span{
  display:block;
  color:rgba(255,255,255,.70);
  font-size:13px;
  line-height:1.45;
}
.events-main .btn{
  background:#fff!important;
  color:#111!important;
  border-color:#fff!important;
}

/* Eventos page */
.events-page{
  display:grid;
  gap:18px;
}
.events-hero-card{
  border-radius:32px;
  background:
    radial-gradient(circle at 86% 14%,rgba(242,196,0,.18),transparent 34%),
    linear-gradient(135deg,#111 0%,#16110a 48%,#050505 100%);
  color:#fff;
  padding:40px;
}
.events-hero-card h2{
  color:#fff!important;
  font-size:clamp(44px,6vw,86px);
  line-height:.9;
  margin:0 0 16px;
}
.events-hero-card p{
  color:rgba(255,255,255,.76)!important;
  max-width:850px;
  font-size:17px;
}
.events-page-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.events-page-grid article,
.events-roadmap{
  border:1px solid rgba(16,16,16,.08);
  border-radius:26px;
  background:#fff;
  box-shadow:0 18px 55px rgba(23,20,12,.08);
  padding:24px;
}
.events-page-grid article span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:999px;
  background:#111;
  color:#f2c400;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-weight:900;
  margin-bottom:16px;
}
.events-page-grid h3{
  color:#111!important;
  font-size:28px;
  line-height:1;
  margin-bottom:10px;
}
.events-page-grid p{
  color:#625e55!important;
  line-height:1.55;
}
.events-roadmap{
  display:grid;
  gap:12px;
}
.events-roadmap h2{
  color:#111!important;
  font-size:clamp(32px,4vw,54px);
  line-height:.95;
}
.events-roadmap div{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:16px;
  padding:14px;
  border-radius:16px;
  background:#faf8f3;
  border:1px solid rgba(16,16,16,.07);
}
.events-roadmap strong{
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  text-transform:uppercase;
}
.events-roadmap span{
  color:#625e55;
}
@media(max-width:1000px){
  .events-grid,
  .events-page-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:860px){
  .events-main,
  .events-hero-card{
    padding:26px;
  }
  .events-grid,
  .events-page-grid{
    grid-template-columns:1fr;
  }
  .events-roadmap div{
    grid-template-columns:1fr;
    gap:4px;
  }
}


/* =====================================================================
   M4RTIAL v43 — Fight Events dentro del carrusel principal
   ===================================================================== */
.announcement-slide:nth-child(3)::before{
  background:
    radial-gradient(circle at 78% 18%,rgba(242,196,0,.24),transparent 34%),
    radial-gradient(circle at 88% 82%,rgba(177,43,43,.20),transparent 36%),
    linear-gradient(135deg,#111 0%,#121212 48%,#211506 100%);
}
.announcement-events-bg{
  min-height:430px;
  background:
    linear-gradient(90deg,rgba(17,17,17,.74),rgba(17,17,17,.18) 48%,rgba(17,17,17,.08)),
    radial-gradient(circle at 48% 42%,rgba(242,196,0,.18),transparent 34%),
    linear-gradient(135deg,#101010 0%,#1b1308 50%,#050505 100%);
}
.announcement-events-bg::after{
  content:"FIGHT EVENTS";
  position:absolute;
  right:26px;
  bottom:28px;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:clamp(46px,5vw,82px);
  font-weight:900;
  letter-spacing:-.06em;
  line-height:.85;
  color:rgba(255,255,255,.12);
  text-align:right;
}
.announcement-events-bg::before{
  content:"";
  position:absolute;
  inset:28px;
  border:1px solid rgba(242,196,0,.22);
  border-radius:24px;
  box-shadow:inset 0 0 40px rgba(242,196,0,.06);
}
@media(max-width:860px){
  .announcement-events-bg{
    min-height:190px!important;
    max-height:220px!important;
  }
  .announcement-events-bg::after{
    font-size:42px;
    right:18px;
    bottom:18px;
  }
  .announcement-events-bg::before{
    inset:18px;
    border-radius:18px;
  }
}




/* =====================================================================
   M4RTIAL v45 — Fight Events sin marca de fondo
   ===================================================================== */
.announcement-events-bg::after{
  content:none!important;
}
.announcement-events-logo{
  display:none!important;
}


/* =====================================================================
   M4RTIAL v46 — Fight Events sin imagen en el carrusel
   ===================================================================== */
.announcement-slide-events{
  grid-template-columns:minmax(0,1fr)!important;
}
.announcement-slide-events .announcement-content{
  max-width:none!important;
  min-height:unset!important;
}
.announcement-slide-events .announcement-content p{
  max-width:920px!important;
}
.announcement-slide-events .announcement-content strong{
  margin-top:4px!important;
}
.announcement-slide-events .announcement-image,
.announcement-slide-events .announcement-events-bg{
  display:none!important;
}
@media(min-width:861px){
  .announcement-slide-events .announcement-content{
    padding-right:52px!important;
  }
}


/* =====================================================================
   M4RTIAL v47 — carrusel tipo noticias deslizable
   ===================================================================== */
.news-strip-section{
  background:#fff!important;
  padding-top:46px!important;
  padding-bottom:56px!important;
  overflow:hidden;
}
.news-strip-head{
  display:grid;
  justify-items:center;
  text-align:center;
  gap:8px;
  margin-bottom:28px;
}
.news-strip-head h2{
  color:#123a27!important;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:clamp(38px,5vw,68px);
  line-height:.92;
  letter-spacing:.015em;
  text-transform:uppercase;
  margin:0;
}
.news-strip-head p{
  color:#625e55!important;
  margin:0;
  font-size:15px;
}
.news-strip{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(340px, 420px);
  gap:28px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-padding:calc((100vw - min(1180px, 100vw)) / 2);
  padding:10px max(18px, calc((100vw - 1180px) / 2)) 24px;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.news-strip::-webkit-scrollbar{
  display:none;
}
.news-card{
  scroll-snap-align:center;
  display:flex;
  flex-direction:column;
  min-height:520px;
  background:#fff;
  color:#111;
  border:1px solid rgba(16,16,16,.08);
  box-shadow:0 22px 58px rgba(23,20,12,.10);
  overflow:hidden;
  text-decoration:none;
  transition:transform .22s ease, box-shadow .22s ease;
}
.news-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 78px rgba(23,20,12,.16);
}
.news-card-image{
  height:250px;
  background:#111;
  overflow:hidden;
}
.news-card-image img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
  transition:transform .5s ease;
}
.news-card:hover .news-card-image img{
  transform:scale(1.04);
}
.news-card:nth-child(1) .news-card-image img{
  object-position:48% center;
}
.news-card:nth-child(2) .news-card-image img{
  object-position:center center;
}
.news-card-image-abstract{
  position:relative;
  background:
    radial-gradient(circle at 76% 18%,rgba(242,196,0,.22),transparent 32%),
    radial-gradient(circle at 22% 80%,rgba(177,43,43,.18),transparent 32%),
    linear-gradient(135deg,#080808 0%,#17120a 46%,#050505 100%);
}
.news-card-image-abstract::before{
  content:"";
  position:absolute;
  inset:24px;
  border:1px solid rgba(242,196,0,.18);
}
.news-card-body{
  flex:1;
  padding:28px;
  display:flex;
  flex-direction:column;
}
.news-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:24px;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:18px;
  font-weight:900;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.045em;
}
.news-meta span{
  color:#c4a13c;
}
.news-meta time{
  color:#5f5b54;
  text-align:right;
}
.news-card h3{
  color:#123a27!important;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:clamp(27px,2.4vw,36px);
  line-height:1.08;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin:0 0 18px;
}
.news-card p{
  color:#161616!important;
  font-size:17px;
  line-height:1.72;
  margin:0;
}
@media(min-width:1180px){
  .news-strip{
    grid-auto-columns:420px;
  }
}
@media(max-width:860px){
  .news-strip-section{
    padding-top:34px!important;
    padding-bottom:42px!important;
  }
  .news-strip-head{
    margin-bottom:18px;
  }
  .news-strip-head h2{
    font-size:40px;
  }
  .news-strip-head p{
    display:none;
  }
  .news-strip{
    grid-auto-columns:70vw;
    gap:20px;
    padding-left:15vw;
    padding-right:15vw;
    scroll-padding:15vw;
  }
  .news-card{
    min-height:500px;
  }
  .news-card-image{
    height:230px;
  }
  .news-card-body{
    padding:24px;
  }
  .news-meta{
    font-size:15px;
    margin-bottom:22px;
  }
  .news-card h3{
    font-size:28px;
  }
  .news-card p{
    font-size:16px;
    line-height:1.68;
  }
}
@media(max-width:430px){
  .news-strip{
    grid-auto-columns:72vw;
    padding-left:14vw;
    padding-right:14vw;
    scroll-padding:14vw;
  }
  .news-card{
    min-height:490px;
  }
  .news-card-image{
    height:210px;
  }
  .news-card-body{
    padding:22px;
  }
  .news-card h3{
    font-size:25px;
  }
}


/* =====================================================================
   M4RTIAL v48 — carrusel sin título principal
   ===================================================================== */
.news-strip-head{
  margin-bottom:22px!important;
}
.news-strip-head p{
  display:block!important;
  color:#123a27!important;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:clamp(22px,3vw,38px)!important;
  line-height:1!important;
  font-weight:900!important;
  text-transform:uppercase!important;
  letter-spacing:.02em!important;
}
@media(max-width:860px){
  .news-strip-head{
    margin-bottom:16px!important;
  }
  .news-strip-head p{
    display:block!important;
    font-size:24px!important;
    line-height:1.05!important;
    max-width:320px;
  }
}


/* =====================================================================
   M4RTIAL v49 — carrusel sin cabecera + horarios semanales compactos
   ===================================================================== */
.news-strip-head{
  display:none!important;
}
.news-strip-section{
  padding-top:32px!important;
}

.compact-schedule-section{
  background:#fff!important;
  padding-top:36px!important;
  padding-bottom:44px!important;
}
.compact-schedule-shell{
  border:1px solid rgba(16,16,16,.08);
  border-radius:30px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfaf6 100%);
  box-shadow:0 24px 75px rgba(23,20,12,.10);
  padding:24px;
}
.compact-schedule-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(150px, 1fr));
  gap:10px;
}
.compact-day{
  border:1px solid rgba(16,16,16,.08);
  border-radius:22px;
  background:#fff;
  padding:14px;
  min-height:210px;
}
.compact-day > span{
  display:block;
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:20px;
  font-weight:900;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding-bottom:10px;
  margin-bottom:10px;
  border-bottom:1px solid rgba(16,16,16,.08);
}
.compact-day div{
  display:grid;
  gap:3px;
  padding:8px 0;
  border-bottom:1px solid rgba(16,16,16,.055);
}
.compact-day div:last-child{
  border-bottom:0;
}
.compact-day strong{
  color:#111;
  font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
  font-size:16px;
  line-height:1;
  font-weight:900;
}
.compact-day em{
  color:#6f685f;
  font-size:12px;
  line-height:1.25;
  font-style:normal;
  font-weight:750;
}
.compact-schedule-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}
@media(max-width:1180px){
  .compact-schedule-grid{
    grid-template-columns:repeat(3,1fr);
  }
}
@media(max-width:860px){
  .compact-schedule-section{
    padding-top:28px!important;
    padding-bottom:34px!important;
  }
  .compact-schedule-shell{
    padding:16px;
    border-radius:24px;
  }
  .compact-schedule-grid{
    display:flex;
    overflow-x:auto;
    gap:12px;
    scroll-snap-type:x mandatory;
    padding-bottom:6px;
    scrollbar-width:none;
  }
  .compact-schedule-grid::-webkit-scrollbar{
    display:none;
  }
  .compact-day{
    flex:0 0 74vw;
    min-height:220px;
    scroll-snap-align:start;
  }
  .compact-schedule-actions{
    display:grid;
    grid-template-columns:1fr;
  }
}
@media(max-width:430px){
  .compact-day{
    flex-basis:78vw;
  }
}


/* =====================================================================
   M4RTIAL v50 — idioma móvil izquierda + carrusel texto negro
   ===================================================================== */

/* Carrusel de noticias: texto en negro, no verde oscuro */
.news-strip-head h2,
.news-strip-head p,
.news-card h3{
  color:#111111!important;
}
.news-meta span{
  color:#9d7600!important;
}

/* Selector de idioma móvil pequeño y pegado a la izquierda */
@media(max-width:860px){
  .language-switcher{
    top:64px!important;
    left:10px!important;
    right:auto!important;
    bottom:auto!important;
    transform:none!important;
    width:auto!important;
    max-width:none!important;
    justify-content:flex-start!important;
    padding:5px!important;
    border-radius:999px!important;
    box-shadow:0 10px 24px rgba(23,20,12,.12)!important;
  }

  .language-switcher button{
    flex:0 0 auto!important;
    min-width:28px!important;
    width:28px!important;
    height:26px!important;
    padding:0!important;
    font-size:8px!important;
    letter-spacing:.03em!important;
  }

  .language-switcher-label{
    display:none!important;
  }
}


/* =====================================================================
   M4RTIAL v51 — sin Fight Events + tarifas móviles compactas
   ===================================================================== */

/* Landing: elimina cualquier resto visual del bloque Fight Events */
.news-card-events{
  display:none!important;
}

/* Tarifas móvil: más precios visibles con menos scroll */
@media(max-width:860px){
  .price-notice.only-note{
    padding:12px!important;
    margin-bottom:12px!important;
    border-radius:18px!important;
    box-shadow:0 10px 26px rgba(23,20,12,.06)!important;
  }

  .price-notice.only-note span{
    min-height:28px!important;
    padding:0 10px!important;
    font-size:9px!important;
    letter-spacing:.06em!important;
  }

  .price-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }

  .price-card{
    min-height:auto!important;
    padding:14px!important;
    border-radius:18px!important;
    box-shadow:0 12px 30px rgba(23,20,12,.07)!important;
  }

  .plan-tag{
    min-height:22px!important;
    padding:0 8px!important;
    font-size:7.5px!important;
    letter-spacing:.04em!important;
    line-height:1!important;
    max-width:100%;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .price-card h3{
    font-size:16px!important;
    line-height:1.05!important;
    margin:8px 0 6px!important;
    letter-spacing:-.025em!important;
  }

  .price-card .price-top p{
    display:none!important;
  }

  .price{
    font-size:26px!important;
    line-height:.95!important;
    margin-top:10px!important;
    letter-spacing:-.045em!important;
  }

  .tax-note{
    font-size:8px!important;
    line-height:1!important;
    margin:5px 0 10px!important;
    letter-spacing:.05em!important;
  }

  .price-card .btn,
  .price-card .btn-full{
    min-height:34px!important;
    padding:0 8px!important;
    font-size:8px!important;
    letter-spacing:.04em!important;
    border-radius:999px!important;
  }
}

@media(max-width:380px){
  .price-grid{
    gap:8px!important;
  }

  .price-card{
    padding:12px!important;
  }

  .price-card h3{
    font-size:15px!important;
  }

  .price{
    font-size:24px!important;
  }
}


/* =====================================================================
   M4RTIAL v52 — selector idioma derecha + carrito en encabezado
   ===================================================================== */
.cart-header-link{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:0!important;
  margin-left:4px!important;
  color:#111!important;
  background:#fff!important;
  border:1px solid rgba(16,16,16,.12)!important;
  box-shadow:0 10px 26px rgba(23,20,12,.08)!important;
  opacity:1!important;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease!important;
}
.cart-header-link:hover{
  transform:translateY(-2px)!important;
  border-color:rgba(157,118,0,.38)!important;
  box-shadow:0 16px 34px rgba(23,20,12,.13)!important;
  color:#9d7600!important;
}
.cart-header-link svg{
  width:20px!important;
  height:20px!important;
  display:block!important;
  fill:none!important;
  stroke:currentColor!important;
  stroke-width:2!important;
  stroke-linecap:round!important;
  stroke-linejoin:round!important;
}
.split-menu .menu-right{
  align-items:center!important;
}

/* Móvil: idioma a la derecha y carrito fijo en lado derecho del encabezado */
@media(max-width:860px){
  .language-switcher{
    top:64px!important;
    right:10px!important;
    left:auto!important;
    bottom:auto!important;
    transform:none!important;
    width:auto!important;
    max-width:none!important;
    justify-content:flex-end!important;
    padding:5px!important;
    border-radius:999px!important;
    box-shadow:0 10px 24px rgba(23,20,12,.12)!important;
  }

  .language-switcher button{
    flex:0 0 auto!important;
    min-width:28px!important;
    width:28px!important;
    height:26px!important;
    padding:0!important;
    font-size:8px!important;
    letter-spacing:.03em!important;
  }

  .language-switcher-label{
    display:none!important;
  }

  .nav.nav-split{
    justify-content:center!important;
  }

  .split-menu .cart-header-link{
    position:fixed!important;
    top:13px!important;
    right:14px!important;
    z-index:10001!important;
    width:34px!important;
    height:34px!important;
    min-width:34px!important;
    margin:0!important;
    background:#fff!important;
    color:#111!important;
    border:1px solid rgba(16,16,16,.14)!important;
    box-shadow:0 10px 24px rgba(23,20,12,.10)!important;
  }

  .split-menu .cart-header-link svg{
    width:17px!important;
    height:17px!important;
  }

  .split-menu.open .cart-header-link{
    position:relative!important;
    top:auto!important;
    right:auto!important;
    z-index:auto!important;
    width:100%!important;
    height:42px!important;
    min-width:0!important;
    margin-top:8px!important;
    border-radius:12px!important;
  }

  .split-menu.open .cart-header-link::after{
    content:"Carrito";
    margin-left:8px;
    font-family:var(--font-display, "Roboto Condensed", Inter, Arial, sans-serif);
    font-size:11px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.08em;
  }
}


/* =====================================================================
   M4RTIAL v53 — carrito móvil fuera del menú + menú a la izquierda
   ===================================================================== */
.cart-header-mobile{
  display:none!important;
}

@media(max-width:860px){
  html body .nav.nav-split,
  html body.landing-light .nav.nav-split{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:58px!important;
    position:relative!important;
  }

  html body .mobile-toggle,
  html body.landing-light .mobile-toggle,
  html body.landing-light.hero-scrolled .mobile-toggle{
    position:absolute!important;
    left:14px!important;
    right:auto!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    min-height:32px!important;
    height:32px!important;
    padding:0 11px!important;
    border-radius:999px!important;
    font-size:10px!important;
    line-height:1!important;
    letter-spacing:.08em!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    background:#fff!important;
    color:#111!important;
    border:1px solid rgba(0,0,0,.16)!important;
    box-shadow:0 8px 18px rgba(23,20,12,.08)!important;
  }

  .cart-header-mobile{
    position:absolute!important;
    right:14px!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    z-index:10002!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:34px!important;
    height:34px!important;
    min-width:34px!important;
    border-radius:999px!important;
    background:#fff!important;
    color:#111!important;
    border:1px solid rgba(16,16,16,.14)!important;
    box-shadow:0 10px 24px rgba(23,20,12,.10)!important;
    padding:0!important;
  }

  .cart-header-mobile svg{
    width:17px!important;
    height:17px!important;
    display:block!important;
    fill:none!important;
    stroke:currentColor!important;
    stroke-width:2!important;
    stroke-linecap:round!important;
    stroke-linejoin:round!important;
  }

  .cart-header-mobile:hover{
    color:#9d7600!important;
    border-color:rgba(157,118,0,.34)!important;
  }

  /* El carrito del menú queda oculto en móvil; el acceso visible está en el encabezado */
  .split-menu .cart-header-link,
  .split-menu.open .cart-header-link{
    display:none!important;
  }

  .split-menu{
    top:58px!important;
  }

  html body .landing-photo-hero{
    padding-top:58px!important;
  }
}
