/*
Theme Name: Mai Karon Muay Thai
Theme URI: https://maikaron.com
Author: Mai Karon Muay Thai
Author URI: https://maikaron.com
Description: Custom dark theme for Mai Karon Muay Thai - Karon Beach, Phuket. Fully responsive. Ships with the Home and Online Coaching templates; drop in more page templates to extend it.
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: maikaron
*/


  :root{
    --bg:#0b0b0d;--bg2:#141417;--card:#161619;--ink:#fff;--muted:rgba(255,255,255,.62);--faint:rgba(255,255,255,.42);
    --line:rgba(255,255,255,.12);--line-s:rgba(255,255,255,.07);--nav-sc:rgba(11,11,13,.82);
    --red:#ed1c24;--red-d:#c4141b;--grad:linear-gradient(180deg,#ed1c24,#c4141b);
    --glow:0 13px 36px -14px rgba(237,28,36,.5);
    --fd:"Archivo",ui-sans-serif,system-ui,sans-serif;--fb:"Inter",ui-sans-serif,system-ui,sans-serif;--max:1240px;
    --logo:url('assets/img/logo.png');--img-class:url('assets/img/img-class.jpg');--img-gym:url('assets/img/img-gym.jpg');--img-stadium:url('assets/img/img-stadium.jpg');--img-ring:url('assets/img/img-ring.jpg');--img-beach:url('assets/img/img-beach.jpg');
  }
  html{background:#0b0b0d}
  *{box-sizing:border-box}html{scroll-behavior:smooth}
  body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--fb);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}
  h1,h2,h3{font-family:var(--fd);font-weight:800;text-transform:uppercase;line-height:.94;letter-spacing:-.01em;margin:0;overflow-wrap:break-word}
  p{margin:0}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
  .wrap{max-width:var(--max);margin-inline:auto;padding-inline:clamp(18px,5vw,48px)}
  section{scroll-margin-top:74px}.pad{padding-block:clamp(58px,9vw,116px)}
  .pad:not(.alt):not(.final){background:var(--bg)}
  .alt{background:var(--bg2)}
  .grad-t{color:var(--red)}
  .eyebrow{font-family:var(--fb);font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin:0 0 16px}
  .h-xl{font-size:clamp(2.6rem,8vw,5.8rem)}.h-lg{font-size:clamp(1.95rem,5vw,3.7rem)}
  .sub{font-size:clamp(1.04rem,2.1vw,1.26rem);max-width:56ch;color:var(--muted)}

  .btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;gap:10px;font-family:var(--fb);font-weight:700;font-size:.92rem;letter-spacing:.02em;text-transform:uppercase;padding:15px 28px;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:transform .25s,box-shadow .25s,background .25s,color .25s,border-color .25s}
  .btn svg{width:16px;height:16px;transition:transform .25s}
  .btn-grad{background:var(--grad);color:#fff;box-shadow:var(--glow)}
  .btn-grad:hover{transform:translateY(-3px);box-shadow:0 18px 44px -14px rgba(237,28,36,.66)}.btn-grad:hover svg{transform:translateX(4px)}
  .btn-out{background:transparent;color:var(--ink);border-color:var(--line)}
  .btn-out:hover{border-color:var(--red);color:var(--red);transform:translateY(-3px)}

  /* NAV */
  .nav{position:sticky;top:0;z-index:60;border-bottom:1px solid transparent;transition:background .35s,border-color .35s}
  .nav.sc{background:var(--nav-sc);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-color:var(--line)}
  .nav-in{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:11px}
  .brand-logo{display:block;height:62px;aspect-ratio:700/580;background:var(--logo) left center/contain no-repeat;flex:none}
  .nav-links{display:none;gap:28px}
  .nav-links a{font-weight:600;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:.2s}
  .nav.sc .nav-links a{color:var(--muted)}.nav .nav-links a:hover{color:var(--red)}
  .nav-item{position:relative;display:flex;align-items:center}
  .nav-dd-t{display:inline-flex;align-items:center;gap:5px}
  .nav-dd-t svg{width:11px;height:11px;opacity:.65;transition:transform .25s}
  .nav-item:hover .nav-dd-t svg,.nav-item:focus-within .nav-dd-t svg{transform:rotate(180deg)}
  .nav-dd{position:absolute;top:100%;left:50%;transform:translate(-50%,10px);min-width:214px;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:8px;display:flex;flex-direction:column;gap:1px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;box-shadow:0 16px 38px rgba(0,0,0,.5);z-index:70}
  .nav-item:hover .nav-dd,.nav-item:focus-within .nav-dd{opacity:1;visibility:visible;transform:translate(-50%,7px)}
  .nav-links .nav-dd a{padding:9px 13px;border-radius:7px;font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.82);white-space:nowrap;transition:.15s}
  .nav-links .nav-dd a:hover{background:rgba(255,255,255,.06);color:var(--red)}
  
  
  
  .nav-right{display:flex;align-items:center;gap:10px}
  .nav-right .btn{padding:10px 18px;font-size:.76rem}
  .burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;align-items:center;background:none;border:0;cursor:pointer;padding:0}
  .burger span{display:block;width:24px;height:2px;background:#fff;transition:.3s}
  .nav.sc .burger span{background:var(--ink)}
  @media(min-width:920px){.nav-links{display:flex;align-items:center}.burger{display:none}}
  @media(max-width:560px){.brand-logo{height:54px}.nav-right .btn{padding:9px 14px;font-size:.72rem}}

  /* MOBILE MENU */
  .mobile-menu{position:fixed;inset:0;z-index:80;background:rgba(8,8,10,.985);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:0;padding:90px 24px 46px;overflow-y:auto;transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .35s ease,opacity .35s ease}
  .mobile-menu.open{transform:none;opacity:1;pointer-events:auto}
  
  .mobile-menu .btn{margin-top:24px;color:#fff}
  .mm-links{display:flex;flex-direction:column;align-items:center;width:100%;max-width:520px}.mm-links a{font-family:var(--fd);font-weight:700;font-size:clamp(1.18rem,4.7vw,1.42rem);text-transform:uppercase;letter-spacing:.02em;color:#fff;padding:11px 8px;line-height:1.12;transition:color .15s ease}.mm-links a:hover,.mm-links a:active{color:var(--red)}.mm-close{position:absolute;top:18px;right:18px;width:46px;height:46px;background:none;border:0;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer}

  /* HERO SLIDER */
  .hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:#08080a}
  .slides{position:absolute;inset:0;z-index:0}
  .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.04);transition:opacity 1.2s ease,transform 6s ease}
  .slide.on{opacity:1;transform:scale(1)}
  .slide-1{background-image:var(--img-class)}.slide-2{background-image:var(--img-beach)}.slide-3{background-image:var(--img-stadium)}
  .hero-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,8,10,.5),rgba(8,8,10,.62) 46%,rgba(8,8,10,.96))}
  .hero-in{position:relative;z-index:3;width:100%;padding-block:clamp(52px,7vw,94px)}
  .hero .eyebrow{color:#fff;opacity:.85}
  .hero h1{margin-top:8px;max-width:14ch;color:#fff}
  .hero .sub{margin:22px 0 0;color:rgba(255,255,255,.85)}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:34px 0 0}
  .hero-cta-sub{display:flex;flex-wrap:wrap;gap:12px}
  .hero-cta-sub .btn{flex:0 1 auto;justify-content:center;white-space:nowrap}
  @media(max-width:620px){
    .hero-cta>.btn-grad{flex:0 1 70%;justify-content:center}
    .hero-cta-sub{flex:1 1 100%}
    .hero-cta-sub .btn{font-size:.74rem;letter-spacing:.012em;padding:13px 9px}
  }
  .hero .btn-out{color:#fff;border-color:rgba(255,255,255,.4)}.hero .btn-out:hover{border-color:#fff;color:#fff}
  .rate{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;margin:28px 0 0;font-weight:600;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.8)}
  .stars{display:inline-flex;gap:2px;color:var(--red)}.stars svg{width:15px;height:15px}
  .dots{position:absolute;left:0;right:0;bottom:20px;z-index:4;display:flex;gap:8px;justify-content:center}
  .dots button{width:32px;height:4px;border:0;border-radius:2px;background:rgba(255,255,255,.34);cursor:pointer;padding:0;transition:.3s}
  .dots button.on{background:var(--red);width:46px}

  /* MARQUEE (flat) */
  .marq{background:var(--red);overflow:hidden;padding-block:14px;position:relative;z-index:5}
  .marq-t{display:flex;width:max-content;white-space:nowrap;animation:scroll 28s linear infinite}
  .marq-t span{font-family:var(--fd);font-weight:800;font-size:clamp(1rem,2.2vw,1.5rem);text-transform:uppercase;letter-spacing:.04em;padding:0 24px;color:#fff}
  .marq-t span::after{content:"\2022";margin-left:24px;opacity:.5}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* OFFER TILES */
  .tiles{display:grid;gap:16px;grid-template-columns:1fr;margin-top:36px}
  @media(min-width:620px){.tiles{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:1000px){.tiles{grid-template-columns:repeat(4,1fr)}}
  .tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:clamp(26px,3.4vw,34px);display:flex;flex-direction:column;gap:10px;transition:transform .35s,border-color .35s;position:relative;overflow:hidden}
  .tile:hover{transform:translateY(-5px);border-color:rgba(237,28,36,.42)}
  .tile>*{position:relative;z-index:1}
  .tile::after{content:"";position:absolute;inset:0;z-index:0;border-radius:inherit;opacity:0;transition:opacity .4s ease;background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(237,28,36,.16),transparent 62%);pointer-events:none}
  .tile:hover::after{opacity:1}
  .tile .k{font-family:var(--fd);font-weight:900;font-size:1.1rem;color:var(--red)}
  .tile h3{font-size:clamp(1.35rem,3vw,1.75rem)}
  .tile p{color:var(--muted);font-size:.96rem;flex:1}
  .tlink{font-family:var(--fb);font-weight:700;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;color:var(--ink)}
  .tlink svg{width:15px;height:15px;transition:transform .25s}.tile:hover .tlink svg{transform:translateX(4px)}.tile:hover .tlink{color:var(--red)}

  /* STATEMENT + STATS */
  .state h2{max-width:18ch}.state .sub{margin-top:22px}
  .fears{display:grid;grid-template-columns:1fr;margin-top:38px;border-top:1px solid var(--line)}
  @media(min-width:760px){.fears{grid-template-columns:repeat(2,1fr)}}
  .fear{padding:24px 0;display:flex;gap:16px;align-items:flex-start;border-bottom:1px solid var(--line)}
  @media(min-width:760px){.fear{padding:26px 30px;border-right:1px solid var(--line)}.fear:nth-child(2n){border-right:0}}
  .fear .x{flex:none;font-family:var(--fd);font-weight:900;font-size:1.3rem;color:var(--red);line-height:1}
  .fear p{color:var(--muted);font-size:.98rem}
  .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:42px}
  @media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
  .stat{background:var(--card);padding:28px 22px;text-align:center}
  .stat .v{font-family:var(--fd);font-weight:900;font-size:clamp(2rem,5vw,3rem);line-height:1;color:var(--red)}
  .stat .l{font-size:.76rem;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-top:7px}

  /* HOW */
  .proc{display:grid;grid-template-columns:1fr;margin-top:34px;border-top:1px solid var(--line)}
  .pstep{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;padding:30px 0;border-bottom:1px solid var(--line)}
  @media(min-width:760px){.pstep{grid-template-columns:140px 1fr;gap:36px}}
  .pstep .n{font-family:var(--fd);font-weight:900;font-size:clamp(2.6rem,7vw,4.2rem);line-height:.85;color:var(--red)}
  .pstep h3{font-size:clamp(1.3rem,3vw,1.9rem);margin-bottom:8px}
  .pstep p{color:var(--muted);max-width:62ch}

  /* PRICING */
  .plans{display:grid;gap:20px;grid-template-columns:1fr;margin-top:36px;align-items:stretch}
  .plan-single{max-width:560px;margin:36px auto 0}
  @media(min-width:840px){.plans{grid-template-columns:1fr 1fr}}
  .plan{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:clamp(26px,4vw,40px);display:flex;flex-direction:column;transition:transform .35s,border-color .35s}
  .plan:hover{transform:translateY(-4px);border-color:rgba(237,28,36,.4)}
  .plan.feat{border:0;background:linear-gradient(160deg,rgba(237,28,36,.13),rgba(237,28,36,.03)),var(--card);box-shadow:0 30px 60px -34px rgba(237,28,36,.5);position:relative;overflow:hidden}
  .plan.feat::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:var(--red)}
  .badge{font-family:var(--fb);font-weight:700;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;background:var(--red);color:#fff;padding:5px 12px;border-radius:4px;align-self:flex-start;margin-bottom:18px}
  .pname{font-family:var(--fd);font-weight:800;font-size:clamp(1.6rem,3.6vw,2.1rem);line-height:.98}
  .pfor{font-size:.93rem;color:var(--muted);margin-top:10px;min-height:42px}
  .pcost{display:flex;align-items:baseline;gap:9px;margin:18px 0 2px}
  .amt{font-family:var(--fd);font-weight:900;font-size:clamp(2.2rem,5.5vw,3.1rem);line-height:1}
  .amt-sm{font-size:clamp(1.2rem,2.4vw,1.5rem);line-height:1.18;letter-spacing:0}
  .palt{font-size:.86rem;color:var(--faint);margin-bottom:22px}
  .chk{margin:0;padding:0;flex:1;margin-bottom:24px}
  .chk li{list-style:none;display:flex;gap:12px;align-items:flex-start;padding:9px 0;font-size:.96rem;border-top:1px solid var(--line-s)}
  .chk li:first-child{border-top:0}.chk b{font-weight:700}
  .chk .ic{flex:none;width:19px;height:19px;color:var(--red);margin-top:2px}
  .plan .btn{width:100%;justify-content:center}
  .online{margin-top:24px;display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:14px;padding:28px;background:var(--card)}
  .online h3{font-family:var(--fd);font-weight:800;font-size:1.45rem}
  .online p{color:var(--muted);font-size:.93rem;max-width:46ch;margin-top:6px}
  .online .price{font-family:var(--fd);font-weight:900;font-size:1.55rem;margin-bottom:12px;color:var(--red)}

  /* GALLERY */
  .gal{display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:36px}
  @media(min-width:760px){.gal{grid-template-columns:repeat(4,1fr)}}
  .g{position:relative;aspect-ratio:4/5;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
  .g i{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
  .g:hover i{transform:scale(1.06)}
  .g::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.4))}
  .g1 i{background-image:var(--img-class)}.g2 i{background-image:var(--img-gym)}.g3 i{background-image:var(--img-stadium)}.g4 i{background-image:var(--img-ring)}

  /* TESTIMONIALS */
  .tg{display:grid;gap:18px;grid-template-columns:1fr;margin-top:36px}
  @media(min-width:760px){.tg{grid-template-columns:repeat(3,1fr)}}
  .quote{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:15px;transition:transform .35s,border-color .35s}
  .quote:hover{transform:translateY(-4px);border-color:rgba(237,28,36,.4)}
  .quote .txt{font-size:1rem;line-height:1.55}
  .quote .who{margin-top:auto;font-family:var(--fd);font-weight:800;font-size:1.05rem}
  .quote .who span{font-family:var(--fb);font-weight:400;font-size:.82rem;color:var(--faint);text-transform:none}
  .rev-cta{display:flex;justify-content:center;margin-top:32px}

  /* FAQ */
  .faq{margin-top:34px;border-top:1px solid var(--line)}
  .qa{border-bottom:1px solid var(--line)}
  .qa button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 0;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--fd);font-weight:700;font-size:clamp(1.1rem,2.4vw,1.45rem);text-transform:uppercase;color:var(--ink)}
  .qa .sign{flex:none;width:26px;height:26px;display:grid;place-items:center;font-family:var(--fb);font-weight:700;font-size:1.5rem;color:var(--red);transition:transform .3s}.qa.open .sign{transform:rotate(45deg)}
  .qa .ans{max-height:0;overflow:hidden;transition:max-height .4s ease}.qa .ans p{padding:0 0 24px;color:var(--muted);font-size:1rem;max-width:70ch}

  /* FINAL */
  .final{background:var(--grad);position:relative;overflow:hidden}
  .final::after{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 80% 0,rgba(255,255,255,.16),transparent 60%)}
  .final .wrap{position:relative;z-index:1;text-align:center}
  .final h2{font-size:clamp(2.4rem,7vw,5.4rem);max-width:16ch;margin-inline:auto;color:#fff}
  .final .sub{margin:22px auto 0;color:rgba(255,255,255,.92);max-width:48ch}
  .final .btn-final{background:#0b0b0d;color:#fff;margin-top:32px;border-color:#0b0b0d}
  .final .btn-final:hover{transform:translateY(-3px);background:#000}
  .final .contact{margin-top:24px;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.85)}.final .contact a{color:#fff;text-decoration:underline;text-underline-offset:4px}

  /* FOOTER */
  footer{background:#08080a;border-top:1px solid rgba(255,255,255,.1);color:#fff}
  .foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;padding-block:32px 0}
  
  .foot-links{display:flex;flex-wrap:wrap;gap:20px;font-weight:600;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.62)}.foot-links a:hover{color:var(--red)}
  .cr{color:rgba(255,255,255,.4);font-size:.8rem;letter-spacing:.03em}.foot-sub{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px 20px;padding-block:18px 32px;margin-top:18px;border-top:1px solid rgba(255,255,255,.1)}.foot-social{display:flex;gap:10px;align-items:center;margin-right:3mm}.soc{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#fff;transition:transform .25s,box-shadow .25s}.soc:hover{transform:translateY(-3px);box-shadow:0 8px 20px -6px rgba(0,0,0,.55)}.soc svg{width:20px;height:20px}.soc-fb{background:#1877F2}.soc-ig{background:radial-gradient(circle at 28% 100%,#FED576 0%,#F47133 22%,#BC3081 55%,#4E5DD4 88%)}.soc-yt{background:#FF0000}

  .js [data-r]{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1)}[data-r].in{opacity:1;transform:none}
  :focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:4px}
  @media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}.js [data-r]{opacity:1;transform:none}.marq-t{animation:none}.slide{transform:none}}
  /* motion layer */
  html.lenis,html.lenis body{height:auto}
  .lenis.lenis-smooth{scroll-behavior:auto!important}
  .lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
  .lenis.lenis-stopped{overflow:hidden}
  .lenis.lenis-smooth iframe{pointer-events:none}
  .progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:90;pointer-events:none}
  .progress i{display:block;height:100%;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--red);transition:transform .12s linear}


/* ---- grid3 : Online Coaching "why" section (1 / 2 / 3 columns) ---- */
.grid3{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:680px){.grid3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.grid3{grid-template-columns:repeat(3,1fr)}}


/* ===================== SUBPAGE COMPONENTS (phead / pcard / cards / callout / prose) ===================== */
h1,h2,h3{font-family:var(--fd);font-weight:800;text-transform:uppercase;line-height:.96;letter-spacing:-.01em;margin:0;overflow-wrap:break-word}
.pad{padding-block:clamp(54px,8vw,104px);background:var(--bg)}
.eyebrow{font-family:var(--fb);font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin:0 0 14px}
.sub{font-size:clamp(1.02rem,2vw,1.22rem);max-width:60ch;color:var(--muted)}
.btn-out:hover svg{transform:translateX(4px)}
.phead{position:relative;background:#08080a;overflow:hidden}
.phead .bg{position:absolute;inset:0;background:var(--img-hero) center/cover;opacity:.5;transform:scale(1.03)}
.phead .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,10,.5),rgba(8,8,10,.82) 58%,var(--bg))}
.phead .wrap{position:relative;z-index:2;padding-block:clamp(112px,16vw,184px) clamp(40px,6vw,72px)}
.phead .eyebrow{color:#fff;opacity:.85}
.phead h1{color:#fff;font-size:clamp(2.4rem,7.4vw,4.8rem);max-width:15ch}
.phead .sub{color:rgba(255,255,255,.86);margin-top:18px}
.rate{display:inline-flex;align-items:center;gap:10px;margin-top:26px;font-weight:600;font-size:.84rem;letter-spacing:.03em;text-transform:uppercase;color:rgba(255,255,255,.92)}
.rate .stars{display:inline-flex;gap:2px;color:#ffb400}
.rate .stars svg{width:17px;height:17px}
.sec-h{margin-bottom:34px;max-width:70ch}
.sec-h h2{font-size:clamp(1.85rem,4.6vw,3rem)}
.sec-h .note{color:var(--muted);margin-top:13px;font-size:.99rem}
.cards{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:600px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.cards{grid-template-columns:repeat(3,1fr)}}
.cards.two{max-width:780px;margin-inline:auto;grid-template-columns:1fr}
@media(min-width:620px){.cards.two{grid-template-columns:repeat(2,1fr)}}
#camps .cards{max-width:1000px;margin-inline:auto}
@media(min-width:1000px){#camps .cards{grid-template-columns:repeat(2,1fr)}}
.pcard{position:relative;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:clamp(22px,3vw,30px);display:flex;flex-direction:column;transition:transform .35s,border-color .35s;overflow:hidden}
.pcard:hover{transform:translateY(-5px);border-color:rgba(237,28,36,.42)}
.pcard.feat{border:0;background:linear-gradient(160deg,rgba(237,28,36,.13),rgba(237,28,36,.03)),var(--card);box-shadow:0 30px 60px -34px rgba(237,28,36,.5)}
.pcard.feat::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:var(--red)}
.pcard .nm{font-family:var(--fd);font-weight:800;font-size:clamp(1.28rem,2.6vw,1.6rem);line-height:1}
.prw{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin:10px 0 2px}
.pr{font-family:var(--fd);font-weight:900;font-size:clamp(1.9rem,4.4vw,2.5rem);line-height:1;color:var(--red)}
.pr.txt{font-size:clamp(1.2rem,2.7vw,1.5rem);line-height:1.18}
.was{font-family:var(--fd);font-weight:700;font-size:1.05rem;color:var(--faint);text-decoration:line-through}
.un{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:600}
.usd{font-size:.82rem;color:var(--muted);font-weight:600;letter-spacing:.02em;margin-top:4px}
.pcard .mt{font-size:.85rem;color:var(--muted);margin:2px 0 0}
.pcard ul{list-style:none;margin:16px 0 20px;padding:0;display:flex;flex-direction:column;gap:9px;flex:1}
.pcard li{display:flex;gap:10px;font-size:.92rem;align-items:flex-start;color:var(--ink)}
.pcard li .ic{flex:none;width:18px;height:18px;color:var(--red);margin-top:3px}
.pcard li .ic svg{width:100%;height:100%}
.rent{font-weight:700;color:var(--ink)}
.amt-hl{color:var(--red);font-weight:800}
.pcard .btn{width:100%;justify-content:center;margin-top:auto}
.pop{position:absolute;top:16px;right:16px;font-family:var(--fb);font-weight:700;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;background:var(--red);color:#fff;padding:4px 10px;border-radius:4px}
.pcard.feat .pop{top:18px}
.sched-wrap{margin-top:40px}
.sched-h{font-family:var(--fd);font-weight:800;text-transform:uppercase;font-size:1.15rem;margin-bottom:14px}
.sched{border-collapse:collapse;width:100%;max-width:620px;font-size:.94rem}
.sched th,.sched td{border:1px solid var(--line);padding:13px 16px;text-align:left}
.sched th{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--card);color:var(--ink)}
.sched td{color:var(--muted)}
.sched tbody td:first-child{color:var(--ink);font-weight:600}
.slots{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.slot{font-family:var(--fd);font-weight:700;font-size:.92rem;letter-spacing:.02em;padding:9px 15px;border:1px solid var(--line);border-radius:8px;background:var(--card);color:var(--ink)}
.slot-note{color:var(--muted);font-size:.9rem;margin-top:14px}
.slot-note b{color:var(--red)}
.callout{border:1px solid var(--line);border-radius:16px;padding:clamp(26px,4vw,40px);background:var(--card);display:flex;flex-wrap:wrap;gap:22px;align-items:center;justify-content:space-between}
.callout .ct{flex:1 1 360px}
.callout h3{font-family:var(--fd);font-weight:800;font-size:clamp(1.4rem,3vw,1.9rem);text-transform:uppercase}
.callout p{color:var(--muted);margin-top:8px;max-width:62ch}
.fine{color:var(--faint);font-size:.82rem;max-width:90ch;margin-top:30px;line-height:1.7}
.final h2{font-size:clamp(2.2rem,6.4vw,4.6rem);max-width:18ch;margin-inline:auto;color:#fff}
.final .sub{margin:20px auto 0;color:rgba(255,255,255,.92);max-width:46ch}
.final .btn-final{background:#0b0b0d;color:#fff;margin-top:30px;border-color:#0b0b0d}
.final .contact{margin-top:22px;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.85)}
.cr{font-size:.74rem;color:rgba(255,255,255,.5);letter-spacing:.04em}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}.js [data-r]{opacity:1;transform:none}.phead .bg{transform:none}}
#main .cards:not(.two){max-width:1100px;margin-inline:auto}
@media(min-width:1000px){#main .cards:not(.two){grid-template-columns:repeat(2,1fr)}}
.reqs{margin-top:44px;max-width:840px}
.reqs h3{font-family:var(--fd);font-weight:800;text-transform:uppercase;font-size:1.2rem;margin-bottom:18px}
.reqs ul{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.reqs li{display:flex;gap:13px;align-items:flex-start;font-size:.99rem;color:var(--ink);line-height:1.55}
.reqs li .ic{flex:none;width:21px;height:21px;color:var(--red);margin-top:3px}
.reqs li .ic svg{width:100%;height:100%}
.reqs li b{font-weight:700}
.reqs .note{color:var(--faint);font-size:.86rem;margin-top:22px;line-height:1.7;max-width:90ch}
.foot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;align-items:center;padding-block:32px}
.foot .brand-logo{height:84px}

/* ---- per-page hero backgrounds (scoped by body class pg-{slug}) ---- */
.pg-private-training{--img-hero:url('assets/img/hero-private-training.jpg')}
.pg-group-training{--img-hero:url('assets/img/hero-group-training.jpg')}
.pg-beach-training{--img-hero:url('assets/img/hero-beach-training.jpg')}
.pg-dtv{--img-hero:url('assets/img/hero-dtv.jpg')}
.pg-daily-training{--img-hero:url('assets/img/hero-group-training.jpg')}
.pg-camps{--img-hero:url('assets/img/hero-camps.jpg')}
.pg-fight-preparation{--img-hero:url('assets/img/hero-dtv.jpg')}
.pg-trainingoffer{--img-hero:url('assets/img/hero-group-training.jpg')}

/* text/utility pages: plain hero, no photo */
.pg-news{--img-hero:none}
.pg-contact{--img-hero:none}
.pg-gym-rules{--img-hero:none}
.pg-privacy-policy{--img-hero:none}
.pg-refund_returns{--img-hero:none}


/* ===================== Contact page (redesigned) ===================== */
.chead{padding-block:clamp(84px,11vw,132px) clamp(18px,3vw,34px)}
.chead .ceyebrow{color:var(--red);font-family:var(--fd);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 12px}
.chead h1{color:var(--ink);font-family:var(--fd);font-weight:800;font-size:clamp(2.4rem,7vw,4.4rem);line-height:1.02;letter-spacing:-.01em}
.chead .csub{color:var(--muted);font-size:clamp(1rem,1.35vw,1.12rem);line-height:1.6;max-width:56ch;margin-top:16px}
.contact-sec{padding-bottom:clamp(64px,9vw,112px)}
.cgrid{display:grid;grid-template-columns:1.05fr 1fr;gap:22px;align-items:stretch}
.ccard{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:clamp(24px,3.2vw,40px)}
.ccard .ctitle{color:var(--ink);font-family:var(--fd);font-weight:800;font-size:clamp(1.35rem,2.4vw,1.8rem);margin:0 0 24px}
.crows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px}
.crows li{display:flex;gap:15px;align-items:flex-start}
.cic{flex:0 0 auto;width:44px;height:44px;border-radius:13px;background:var(--bg2);border:1px solid var(--line);display:grid;place-items:center;color:var(--red)}
.cic svg{width:21px;height:21px}
.clabel{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin:0 0 5px;font-weight:600}
.cval{margin:0;color:var(--ink);font-size:1.03rem;line-height:1.5}
.cval a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);transition:color .2s,border-color .2s}
.cval a:hover{color:var(--red);border-color:var(--red)}
.cwa-btn{margin-top:28px;display:flex;width:100%;justify-content:center}
.cmap{position:relative;min-height:360px;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--bg2)}
.cmap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:820px){.cgrid{grid-template-columns:1fr}.cmap{min-height:300px}}
/* BLOG */
.blog{background:var(--bg);padding-block:clamp(40px,6vw,72px) clamp(64px,9vw,104px)}.bgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}.bcard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .2s ease,border-color .2s ease}.bcard:hover{transform:translateY(-4px);border-color:rgba(237,28,36,.5)}.bcard-media{display:block;aspect-ratio:16/10;overflow:hidden;background:#0e0e11}.bcard-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.bcard:hover .bcard-media img{transform:scale(1.04)}.bcard-ph{display:block;width:100%;height:100%;background:linear-gradient(135deg,#17171a,#0d0d10)}.bcard-body{display:flex;flex-direction:column;gap:9px;padding:20px 22px 24px;flex:1}.bcard-meta{font-family:var(--fb);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin:0}.bcard-title{font-family:var(--fd);font-weight:700;font-size:1.2rem;line-height:1.22;margin:0}.bcard-title a{color:#fff;transition:color .15s ease}.bcard-title a:hover{color:var(--red)}.bcard-excerpt{font-family:var(--fb);font-size:.94rem;line-height:1.55;color:var(--muted);margin:0;flex:1}.bcard-link{font-family:var(--fb);font-weight:600;font-size:.86rem;color:#fff;display:inline-flex;align-items:center;gap:6px;margin-top:6px}.bcard-link svg{width:16px;height:16px;transition:transform .15s ease}.bcard-link:hover{color:var(--red)}.bcard-link:hover svg{transform:translateX(3px)}.blog-state{color:var(--muted);font-size:1.05rem;text-align:center;padding:48px 0}.blog-more-wrap{display:flex;justify-content:center;gap:14px;margin-top:clamp(32px,5vw,48px);flex-wrap:wrap}
/* SINGLE POST */
.post-head h1{font-size:clamp(2rem,5.4vw,3.4rem);max-width:20ch}.post-single{padding-block:clamp(40px,6vw,72px) clamp(56px,8vw,96px)}.post-body{max-width:760px;margin-inline:auto;font-family:var(--fb);font-size:1.06rem;line-height:1.75;color:rgba(255,255,255,.84)}.post-body>*:first-child{margin-top:0}.post-body p{margin:0 0 1.2em}.post-body h2{font-family:var(--fd);font-weight:700;font-size:clamp(1.5rem,3.4vw,2rem);line-height:1.2;color:#fff;margin:1.8em 0 .6em}.post-body h3{font-family:var(--fd);font-weight:700;font-size:clamp(1.25rem,2.6vw,1.5rem);color:#fff;margin:1.5em 0 .5em}.post-body h4{font-family:var(--fd);font-weight:700;font-size:1.15rem;color:#fff;margin:1.4em 0 .4em}.post-body a{color:var(--red);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.post-body a:hover{color:#fff}.post-body ul,.post-body ol{margin:0 0 1.2em;padding-left:1.3em}.post-body li{margin:0 0 .5em}.post-body li::marker{color:var(--red)}.post-body img{max-width:100%;height:auto;border-radius:12px;margin:1.5em 0;display:block}.post-body figure{margin:1.5em 0}.post-body figcaption{font-size:.86rem;color:var(--muted);text-align:center;margin-top:8px}.post-body blockquote{margin:1.6em 0;padding:4px 0 4px 22px;border-left:3px solid var(--red);color:#fff;font-size:1.12rem}.post-body blockquote p:last-child{margin-bottom:0}.post-body strong,.post-body b{color:#fff}.post-body hr{border:0;border-top:1px solid var(--line);margin:2em 0}.post-body code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--card);padding:2px 6px;border-radius:5px;font-size:.92em}.post-body pre{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:16px 18px;overflow-x:auto;margin:1.5em 0}.post-body pre code{background:none;padding:0}.post-nav{max-width:760px;margin:clamp(44px,6vw,68px) auto 0;display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;padding-top:30px;border-top:1px solid var(--line)}.post-nav-link{display:flex;flex-direction:column;gap:4px;min-width:0}.post-nav-link.next{text-align:right;align-items:flex-end}.post-nav-link span{font-family:var(--fb);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red)}.post-nav-link em{font-family:var(--fd);font-weight:600;font-size:.96rem;font-style:normal;color:#fff;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-nav-link:hover em{color:var(--red)}.post-nav-all{white-space:nowrap}@media(max-width:600px){.post-nav{grid-template-columns:1fr;justify-items:center;text-align:center}.post-nav-link.next{text-align:center;align-items:center}.post-nav-all{order:-1}}
.post-body h2,.post-body h3,.post-body h4{text-transform:none;letter-spacing:-.01em}

/* WOOCOMMERCE / SHOP */
.shop{padding-block:clamp(108px,15vw,156px) clamp(56px,8vw,96px)}
.woocommerce .woocommerce-products-header__title,.woocommerce h1.page-title,.shop .page-title{font-family:var(--fd);font-weight:800;font-size:clamp(2.4rem,7vw,4rem);text-transform:uppercase;color:#fff;line-height:1;margin:0 0 10px}
.woocommerce .woocommerce-result-count{color:var(--muted);font-family:var(--fb);font-size:.9rem;margin:0 0 22px}
.woocommerce .woocommerce-ordering{margin:0 0 26px}
.woocommerce .woocommerce-ordering select,.woocommerce select.orderby{background:var(--card);color:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 14px;font-family:var(--fb);font-size:.9rem;cursor:pointer}
.woocommerce ul.products,.woocommerce-page ul.products{display:grid !important;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px;margin:0 !important;padding:0 !important;list-style:none}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none !important;content:"" !important}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{position:relative;width:auto !important;margin:0 !important;padding:0 !important;float:none !important;display:flex !important;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .2s ease,border-color .2s ease}
.woocommerce ul.products li.product:hover{transform:translateY(-4px);border-color:rgba(237,28,36,.5)}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,.woocommerce ul.products li.product a.woocommerce-loop-product__link{display:flex;flex-direction:column}
.woocommerce ul.products li.product img{width:100%;aspect-ratio:1/1;height:auto;object-fit:cover;margin:0 !important;border-radius:0;display:block}
.woocommerce ul.products li.product .onsale,.woocommerce span.onsale{position:absolute;top:10px;left:10px;right:auto;background:var(--grad);color:#fff;border:0;border-radius:999px;min-height:0;min-width:0;font-family:var(--fb);font-weight:700;font-size:.7rem;letter-spacing:.04em;padding:5px 11px;margin:0;line-height:1}
.woocommerce ul.products li.product .woocommerce-loop-product__title,.woocommerce ul.products li.product h2.woocommerce-loop-product__title,.woocommerce ul.products li.product h3{font-family:var(--fd) !important;font-weight:700 !important;font-size:1rem !important;line-height:1.25 !important;color:#fff !important;text-transform:none !important;padding:16px 16px 0 !important;margin:0 !important}
.woocommerce ul.products li.product .star-rating{margin:8px 16px 0;font-size:.8em;color:var(--red)}
.woocommerce ul.products li.product .price{color:#fff !important;font-family:var(--fb) !important;font-weight:700 !important;font-size:1.06rem !important;padding:8px 16px 0 !important;margin:0 !important}
.woocommerce ul.products li.product .price del{color:var(--muted);font-weight:400;opacity:.65;margin-right:6px}
.woocommerce ul.products li.product .price ins{text-decoration:none;color:var(--red)}
.woocommerce ul.products li.product .button,.woocommerce ul.products li.product a.added_to_cart{margin:16px !important;margin-top:auto !important;display:block !important;text-align:center;background:var(--grad) !important;color:#fff !important;border:0 !important;border-radius:9px !important;padding:12px 14px !important;font-family:var(--fd) !important;font-weight:700 !important;font-size:.82rem !important;letter-spacing:.04em;text-transform:uppercase !important;line-height:1.2 !important;cursor:pointer;transition:filter .15s ease,transform .15s ease}
.woocommerce ul.products li.product .button:hover{filter:brightness(1.1);transform:translateY(-2px);color:#fff !important}
.woocommerce ul.products li.product a.added_to_cart{margin-top:8px !important;background:transparent !important;border:1px solid var(--line) !important}
.woocommerce ul.products li.product .compare,.woocommerce ul.products li.product .button.compare,.woocommerce ul.products li.product .yith-wcwl-add-to-wishlist{display:block !important;text-align:center;font-family:var(--fb) !important;font-size:.78rem !important;font-weight:500 !important;color:var(--muted) !important;background:transparent !important;border:0 !important;padding:0 16px 16px !important;margin:0 !important;text-transform:none !important;letter-spacing:0 !important}
.woocommerce ul.products li.product .compare:hover{color:var(--red) !important}
.woocommerce nav.woocommerce-pagination{margin-top:clamp(32px,5vw,48px)}
.woocommerce nav.woocommerce-pagination ul{border:0;display:flex;justify-content:center;gap:8px}
.woocommerce nav.woocommerce-pagination ul li{border:0;margin:0;overflow:visible}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{background:var(--card);border:1px solid var(--line);border-radius:8px;color:#fff;padding:10px 14px;min-width:44px;font-family:var(--fb)}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--grad);border-color:transparent;color:#fff}
.woocommerce nav.woocommerce-pagination ul li a:hover{border-color:var(--red);color:var(--red)}
/* single product */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.woocommerce div.product div.images img{border-radius:14px}
.woocommerce div.product .product_title{font-family:var(--fd);font-weight:800;font-size:clamp(1.8rem,4vw,2.6rem);text-transform:none;color:#fff;line-height:1.1;margin:0 0 14px}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:#fff;font-family:var(--fb);font-weight:700;font-size:1.5rem;margin:0 0 18px}
.woocommerce div.product .woocommerce-product-details__short-description{color:var(--muted);line-height:1.65;margin-bottom:22px}
.woocommerce .quantity .qty{background:var(--card);border:1px solid var(--line);color:#fff;border-radius:9px;padding:11px 10px;width:84px;font-family:var(--fb)}
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce div.product form.cart .button{background:var(--grad) !important;color:#fff !important;border:0 !important;border-radius:9px !important;padding:13px 24px !important;font-family:var(--fd) !important;font-weight:700 !important;text-transform:uppercase !important;letter-spacing:.04em;font-size:.9rem !important;cursor:pointer;transition:filter .15s ease,transform .15s ease}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce div.product form.cart .button:hover{filter:brightness(1.1);transform:translateY(-2px);color:#fff !important}
.woocommerce div.product .woocommerce-tabs ul.tabs{border:0;padding:0;margin:0 0 18px}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:var(--card);border:1px solid var(--line);border-radius:8px;margin:0 8px 0 0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{color:#fff}
.woocommerce div.product .woocommerce-tabs .panel{color:var(--muted);line-height:1.7}
.woocommerce table.shop_table{border-color:var(--line);color:rgba(255,255,255,.85)}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{border-color:var(--line)}
.woocommerce-message,.woocommerce-info,.woocommerce-error{background:var(--card);border-top-color:var(--red);color:rgba(255,255,255,.9)}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{background:var(--card);border:1px solid var(--line);color:#fff;border-radius:9px;padding:11px 12px}
@media(max-width:780px){.woocommerce div.product{grid-template-columns:1fr}}
