/* ============================================================
   Kaya Bülent Ataman – Personal Training & Workshops Arnstadt
   Shared Design 1 Stylesheet (dark / fighter / animated)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Roboto',sans-serif;background:#0a0a0a;color:#d8d8d8;line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.04em}
h1{font-size:clamp(2.4rem,5.5vw,5rem);font-weight:700;line-height:1.08}
h2{font-size:clamp(1.8rem,3.8vw,3rem);font-weight:600;line-height:1.15}
h3{font-size:clamp(1rem,1.8vw,1.4rem);font-weight:500}
p{line-height:1.75}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

:root{
    --red:#e63946;
    --red-d:#c41230;
    --bg:#0a0a0a;
    --bg2:#111;
    --bg3:#181818;
    --bg4:#1e1e1e;
    --bdr:#272727;
    --text:#d8d8d8;
    --muted:#777;
}

/* ── BILINGUAL ── */
[data-lang="de"] .en, html[data-lang="de"] .en{display:none!important}
[data-lang="en"] .de, html[data-lang="en"] .de{display:none!important}
.lang-switcher{display:flex;align-items:center;gap:6px}
.lang-btn{background:none;border:1px solid #333;color:#666;font-family:'Roboto',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;padding:5px 10px;cursor:pointer;transition:all .25s}
.lang-btn.active,.lang-btn:hover{border-color:var(--red);color:var(--red)}
.lang-sep{color:#333;font-size:.7rem}

/* ── HEADER / NAV ── */
header{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;background:rgba(10,10,10,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--bdr);transition:box-shadow .3s,border-color .3s}
header.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.6);border-bottom-color:rgba(230,57,70,.3)}
.logo{font-family:'Oswald',sans-serif;font-size:1.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff}
.logo em{color:var(--red);font-style:normal}
nav ul{list-style:none;display:flex;gap:24px;align-items:center}
nav a{font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:#aaa;transition:color .25s;position:relative}
nav a:not(.nav-cta)::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
nav a:not(.nav-cta):hover::after,nav a.active:not(.nav-cta)::after{transform:scaleX(1)}
nav a:hover{color:var(--red)}
nav a.active{color:#fff}
.nav-cta{background:var(--red)!important;color:#fff!important;padding:8px 20px;border-radius:2px;transition:background .25s,box-shadow .25s,transform .25s!important}
.nav-cta:hover{background:var(--red-d)!important;box-shadow:0 8px 24px rgba(230,57,70,.4);transform:translateY(-2px)}
.header-right{display:flex;align-items:center;gap:20px}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:#fff;display:block;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-nav{display:none;position:fixed;top:68px;left:0;right:0;background:#111;border-bottom:2px solid var(--red);z-index:499;flex-direction:column;padding:8px 0;animation:slideDown .35s ease both}
.mob-nav.open{display:flex}
.mob-nav a{padding:14px 5%;font-family:'Oswald',sans-serif;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:#bbb;border-bottom:1px solid var(--bdr);transition:color .2s,background .2s}
.mob-nav a:hover,.mob-nav a.active{color:var(--red);background:rgba(230,57,70,.05)}
.mob-lang{display:flex;gap:10px;padding:14px 5%}

/* ── FLOATING BOOK CTA (always visible) ── */
.book-fab{position:fixed;bottom:24px;right:24px;background:var(--red);color:#fff;padding:14px 24px;border-radius:100px;font-family:'Oswald',sans-serif;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;z-index:9999;box-shadow:0 8px 28px rgba(230,57,70,.4);transition:all .3s;display:inline-flex;align-items:center;gap:8px;animation:fabPulse 2.6s ease-in-out infinite}
.book-fab:hover{background:var(--red-d);transform:translateY(-3px) scale(1.04);box-shadow:0 14px 36px rgba(230,57,70,.55)}
.book-fab::before{content:'';display:inline-block;width:8px;height:8px;background:#fff;border-radius:50%;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:fabDot 1.6s ease-out infinite}

/* ── PAGE HERO (smaller, inside pages) ── */
.page-hero{position:relative;padding:140px 5% 70px;background:linear-gradient(120deg,#0a0a0a 0%,#141414 60%,#220505 100%);overflow:hidden;border-bottom:1px solid var(--bdr)}
.page-hero::after{content:'';position:absolute;left:-120px;bottom:-120px;width:380px;height:380px;background:radial-gradient(circle,rgba(230,57,70,.18),transparent 70%);pointer-events:none;animation:floatGlow 9s ease-in-out infinite alternate}
.page-hero .inner{position:relative;z-index:1}
.page-hero .breadcrumb{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#555;margin-bottom:18px}
.page-hero .breadcrumb a{color:#888;transition:color .2s}
.page-hero .breadcrumb a:hover{color:var(--red)}
.page-hero h1{color:#fff;margin-bottom:14px}
.page-hero h1 em{color:var(--red);font-style:normal}
.page-hero .lead{color:#aaa;max-width:600px;font-size:1.02rem;line-height:1.75}

/* ── HOMEPAGE HERO ── */
#home-hero{min-height:100vh;display:flex;align-items:center;position:relative;padding-top:68px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:linear-gradient(105deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.6) 55%,rgba(100,0,10,.25) 100%),url('images/training_1.png');background-size:cover;background-position:center 30%;animation:bgZoom 18s ease-in-out infinite alternate}
.hero-content{position:relative;z-index:1;max-width:1160px;margin:0 auto;padding:80px 5%;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:6px 16px;margin-bottom:26px;animation:fadeUp .8s .1s both}
.hero-tag::before{content:'';width:16px;height:2px;background:rgba(255,255,255,.6)}
.hero-title{color:#fff;margin-bottom:20px;animation:fadeUp .8s .25s both}
.hero-title em{color:var(--red);font-style:normal;display:block}
.hero-sub{font-size:1rem;color:#bbb;max-width:520px;margin-bottom:42px;font-weight:300;animation:fadeUp .8s .4s both}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .8s .55s both}
.btn-red{display:inline-block;background:var(--red);color:#fff;padding:15px 38px;font-family:'Oswald',sans-serif;font-size:.9rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;border:2px solid var(--red);transition:all .3s;cursor:pointer}
.btn-red:hover{background:var(--red-d);border-color:var(--red-d);transform:translateY(-2px);box-shadow:0 10px 30px rgba(230,57,70,.4)}
.btn-ghost{display:inline-block;background:transparent;color:#fff;padding:13px 36px;font-family:'Oswald',sans-serif;font-size:.9rem;text-transform:uppercase;letter-spacing:.12em;font-weight:500;border:2px solid rgba(255,255,255,.4);transition:all .3s;cursor:pointer}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}
.hero-stats{display:flex;gap:44px;margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap;animation:fadeUp .8s .7s both}
.stat-num{font-family:'Oswald',sans-serif;font-size:2.6rem;font-weight:700;color:var(--red);line-height:1}
.stat-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:#888;margin-top:4px}

.trust-bar{background:var(--bg3);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);padding:22px 5%}
.trust-inner{max-width:1160px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.trust-item{display:flex;align-items:center;gap:9px}
.trust-dot{width:7px;height:7px;background:var(--red);flex-shrink:0;animation:pulseDot 2s ease-in-out infinite}
.trust-item span{font-family:'Oswald',sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:#aaa}

/* ── SECTIONS ── */
section{padding:90px 5%}
.inner{max-width:1160px;margin:0 auto}
.s-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:var(--red);font-family:'Roboto',sans-serif;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.s-label::after{content:'';flex:1;max-width:36px;height:1px;background:var(--red)}
.s-title{color:#fff;margin-bottom:16px}
.s-title em{color:var(--red);font-style:normal}
.s-sub{max-width:580px;color:var(--muted);margin-bottom:50px;font-size:.93rem}

/* ── REVEAL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.reveal-stagger>*{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal-stagger.in>*{opacity:1;transform:none}
.reveal-stagger.in>*:nth-child(1){transition-delay:.05s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.12s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.19s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.26s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.33s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.4s}

/* ── TRAINING / SERVICES ── */
.training-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:var(--bdr)}
.t-card{background:var(--bg3);padding:38px 30px;position:relative;overflow:hidden;transition:background .3s,transform .3s}
.t-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--red);transition:width .4s ease}
.t-card:hover{background:#202020;transform:translateY(-4px)}
.t-card:hover::after{width:100%}
.t-icon{font-size:2.2rem;margin-bottom:20px;display:block;line-height:1;transition:transform .35s ease}
.t-card:hover .t-icon{transform:scale(1.15) rotate(-4deg)}
.t-card h3{color:#fff;margin-bottom:12px;font-size:1.25rem}
.t-card p{font-size:.86rem;color:var(--muted)}
.t-badge{position:absolute;top:14px;left:30px;display:inline-block;background:var(--red);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;margin-bottom:0}
.t-link{display:inline-block;margin-top:18px;font-family:'Oswald',sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--red);border-bottom:1px solid transparent;transition:border-color .25s}
.t-link:hover{border-color:var(--red)}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:5fr 6fr;gap:70px;align-items:center}
.about-img-wrap{position:relative}
.about-img-wrap img{width:100%;height:540px;object-fit:cover;object-position:top;filter:grayscale(10%) contrast(1.05);transition:filter .5s ease}
.about-img-wrap:hover img{filter:grayscale(0%) contrast(1.1)}
.about-badge{position:absolute;right:-16px;bottom:-16px;background:var(--red);padding:22px 26px;text-align:center;min-width:100px;animation:floatY 4s ease-in-out infinite}
.badge-n{font-family:'Oswald',sans-serif;font-size:2.4rem;font-weight:700;color:#fff;line-height:1}
.badge-t{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.75);margin-top:4px}
.about-feats{margin-top:32px}
.af{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--bdr);transition:padding-left .25s}
.af:first-child{border-top:1px solid var(--bdr)}
.af:hover{padding-left:8px}
.af-icon{width:44px;height:44px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;transition:transform .3s}
.af:hover .af-icon{transform:rotate(-6deg) scale(1.05)}
.af-text h4{color:#fff;font-size:.9rem;margin-bottom:3px;text-transform:uppercase;letter-spacing:.06em}
.af-text p{font-size:.82rem;color:var(--muted)}

/* ── CV / LEBENSLAUF ── */
.cv-profile{background:var(--bg3);border:1px solid var(--bdr);padding:40px;display:flex;gap:40px;align-items:center;margin-bottom:60px;border-left:4px solid var(--red)}
.cv-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;object-position:top;border:3px solid var(--red);flex-shrink:0}
.cv-profile-info h3{color:#fff;font-size:1.8rem;margin-bottom:4px}
.cv-profile-info .cv-title{color:var(--red);font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;font-family:'Roboto',sans-serif;font-weight:700;margin-bottom:14px}
.cv-quick{display:flex;gap:28px;flex-wrap:wrap;margin-bottom:18px}
.cv-qi{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:6px}
.cv-qi strong{color:#ccc}
.cv-tags{display:flex;gap:8px;flex-wrap:wrap}
.cv-tag{background:rgba(230,57,70,.12);color:var(--red);border:1px solid rgba(230,57,70,.3);font-size:.68rem;font-family:'Roboto',sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px}
.cv-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px}
.cv-section-h{color:#fff;font-size:1rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:28px;padding-bottom:12px;border-bottom:1px solid var(--bdr)}

.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:4px;top:0;bottom:0;width:1px;background:var(--bdr)}
.tl-item{position:relative;padding-bottom:32px;transition:transform .3s}
.tl-item:hover{transform:translateX(4px)}
.tl-dot{position:absolute;left:-24px;top:4px;width:10px;height:10px;background:var(--red);flex-shrink:0;transition:transform .3s,box-shadow .3s}
.tl-item:hover .tl-dot{transform:scale(1.4);box-shadow:0 0 0 6px rgba(230,57,70,.18)}
.tl-year{font-family:'Oswald',sans-serif;font-size:.72rem;color:var(--red);text-transform:uppercase;letter-spacing:.14em;margin-bottom:4px}
.tl-title{font-family:'Roboto',sans-serif;font-size:.92rem;font-weight:700;color:#fff;margin-bottom:4px}
.tl-sub{font-size:.8rem;color:var(--muted)}

.skill-item{margin-bottom:16px}
.skill-header{display:flex;justify-content:space-between;margin-bottom:6px}
.skill-name{font-size:.82rem;font-weight:500;color:#ccc}
.skill-pct{font-size:.78rem;color:var(--red);font-weight:700}
.skill-bar{height:3px;background:var(--bdr)}
.skill-fill{height:100%;background:var(--red);transition:width 1.2s cubic-bezier(.25,.46,.45,.94)}
.certs-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.cert-card{background:var(--bg3);border:1px solid var(--bdr);padding:14px 16px;border-left:2px solid var(--red);transition:transform .25s,border-left-width .25s}
.cert-card:hover{transform:translateY(-2px);border-left-width:5px}
.cert-card h5{font-family:'Oswald',sans-serif;font-size:.82rem;color:#fff;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.cert-card span{font-size:.72rem;color:var(--muted)}

.fight-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr)}
.fs-item{background:var(--bg3);padding:24px 18px;text-align:center;transition:background .3s}
.fs-item:hover{background:#202020}
.fs-num{font-family:'Oswald',sans-serif;font-size:2.2rem;font-weight:700;color:var(--red);line-height:1}
.fs-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#888;margin-top:6px}

/* ── WORKSHOPS ── */
.ws-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:24px}
.ws-card{background:var(--bg3);border:1px solid var(--bdr);overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease,border-color .3s,box-shadow .35s}
.ws-card:hover{transform:translateY(-6px);border-color:rgba(230,57,70,.45);box-shadow:0 24px 50px rgba(0,0,0,.55)}
.ws-image{height:180px;background:linear-gradient(135deg,#1a1a1a,#330a0d);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:3.4rem}
.ws-image img{width:100%;height:100%;object-fit:cover;object-position:center}
.ws-image::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(230,57,70,.25),transparent 60%);opacity:0;transition:opacity .4s}
.ws-card:hover .ws-image::after{opacity:1}
.ws-tag{position:absolute;top:14px;left:14px;background:var(--red);color:#fff;font-family:'Oswald',sans-serif;font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;padding:4px 10px;z-index:1}
.ws-body{padding:26px 26px 28px;flex:1;display:flex;flex-direction:column}
.ws-body h3{color:#fff;margin-bottom:12px;font-size:1.15rem}
.ws-body p{font-size:.86rem;color:var(--muted);margin-bottom:18px}
.ws-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:22px;font-size:.74rem;color:#999;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em}
.ws-meta span{display:inline-flex;align-items:center;gap:5px}
.ws-meta strong{color:var(--red)}
.ws-cta{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:12px}
.ws-price{font-family:'Oswald',sans-serif;font-size:1.6rem;color:#fff;font-weight:700}
.ws-price small{font-size:.7rem;color:var(--muted);font-weight:400;display:block;margin-top:-3px;letter-spacing:.1em;text-transform:uppercase}
.ws-btn{background:var(--red);color:#fff;padding:11px 22px;font-family:'Oswald',sans-serif;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border:none;cursor:pointer;transition:background .25s,transform .25s;display:inline-flex;align-items:center;gap:8px}
.ws-btn:hover{background:var(--red-d);transform:translateX(3px)}

/* ── BOOKING ── */
#buchen{background:var(--bg)}
.booking-wrap{max-width:860px;margin:0 auto}
.steps{display:flex;align-items:center;margin-bottom:44px}
.step{display:flex;align-items:center;gap:10px}
.step-num{width:36px;height:36px;border:2px solid var(--bdr);color:var(--muted);font-family:'Oswald',sans-serif;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.step.active .step-num{border-color:var(--red);background:var(--red);color:#fff;box-shadow:0 0 0 6px rgba(230,57,70,.18)}
.step.done .step-num{border-color:var(--red);color:var(--red)}
.step-label{font-family:'Roboto',sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);transition:color .3s}
.step.active .step-label{color:#fff}
.step-line{flex:1;height:1px;background:var(--bdr);margin:0 14px;max-width:80px;position:relative;overflow:hidden}
.step-line::after{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--red);transition:width .5s ease}
.step-line.done::after{width:100%}
.booking-step{display:none;animation:fadeUp .5s ease both}
.booking-step.active{display:block}

.service-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}
.service-card{background:var(--bg3);border:2px solid var(--bdr);padding:28px 22px;cursor:pointer;transition:all .3s;text-align:center}
.service-card:hover,.service-card.selected{border-color:var(--red);background:#1a0a0a;transform:translateY(-3px)}
.service-card .s-icon{font-size:2rem;margin-bottom:12px;display:block}
.service-card h4{font-family:'Oswald',sans-serif;font-size:1rem;text-transform:uppercase;color:#fff;margin-bottom:8px}
.service-card p{font-size:.78rem;color:var(--muted)}
.service-card .s-price{font-family:'Oswald',sans-serif;font-size:1.3rem;font-weight:700;color:var(--red);margin-top:12px}

.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cal-nav{background:none;border:1px solid var(--bdr);color:var(--muted);padding:6px 14px;cursor:pointer;font-family:'Oswald',sans-serif;font-size:.8rem;text-transform:uppercase;transition:all .25s}
.cal-nav:hover{border-color:var(--red);color:var(--red)}
.cal-month{font-family:'Oswald',sans-serif;font-size:1.1rem;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:28px}
.cal-day-header{text-align:center;font-family:'Oswald',sans-serif;font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#555;padding:6px 0}
.cal-day{text-align:center;padding:10px 6px;font-size:.88rem;color:var(--muted);border:1px solid transparent;cursor:pointer;transition:all .25s}
.cal-day.available{color:#ccc;border-color:var(--bdr)}
.cal-day.available:hover{border-color:var(--red);color:#fff;transform:scale(1.05)}
.cal-day.selected{background:var(--red);color:#fff;border-color:var(--red)}
.cal-day.disabled{color:#333;cursor:default}
.cal-day.empty{border:none;cursor:default}

.time-slots{margin-bottom:28px}
.time-slots h4{font-family:'Oswald',sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:14px}
.slots-grid{display:flex;gap:10px;flex-wrap:wrap}
.slot{padding:9px 16px;border:1px solid var(--bdr);color:var(--muted);font-size:.82rem;cursor:pointer;transition:all .25s}
.slot.available{color:#ccc}
.slot.available:hover{border-color:var(--red);color:var(--red)}
.slot.selected{background:var(--red);border-color:var(--red);color:#fff}
.slot.booked{background:#181818;color:#333;cursor:not-allowed;text-decoration:line-through}

.form-group{margin-bottom:18px}
.form-group label{display:block;font-family:'Oswald',sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:#888;margin-bottom:7px}
.form-group input,.form-group textarea,.form-group select{width:100%;background:var(--bg3);border:1px solid var(--bdr);color:#d8d8d8;padding:12px 15px;font-family:'Roboto',sans-serif;font-size:.88rem;outline:none;transition:border-color .3s,box-shadow .3s;-webkit-appearance:none;font-family:'Roboto',sans-serif}
.form-group input[type="checkbox"]{width:16px;height:16px;min-width:16px;min-height:16px;padding:0;margin:0 6px 0 0;background:transparent;border:1px solid var(--bdr);cursor:pointer;flex-shrink:0;vertical-align:middle;-webkit-appearance:checkbox;appearance:checkbox;accent-color:var(--red)}
.form-group input[type="checkbox"]:focus{outline:2px solid var(--red);outline-offset:2px}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(230,57,70,.12)}
.form-group textarea{height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.booking-summary{background:var(--bg3);border-left:3px solid var(--red);padding:20px 24px;margin-bottom:24px;display:flex;gap:30px;flex-wrap:wrap}
.bs-item{flex:1;min-width:140px}
.bs-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#888;margin-bottom:3px}
.bs-value{font-family:'Oswald',sans-serif;font-size:.95rem;color:#fff}
.booking-nav{display:flex;gap:12px;justify-content:space-between;align-items:center;margin-top:24px}
.btn-next{background:var(--red);color:#fff;padding:13px 32px;font-family:'Oswald',sans-serif;font-size:.88rem;text-transform:uppercase;letter-spacing:.12em;border:none;cursor:pointer;transition:all .3s}
.btn-next:hover{background:var(--red-d);transform:translateX(3px)}
.btn-next:disabled{background:#333;color:#555;cursor:not-allowed;transform:none}
.btn-back-step{background:none;border:1px solid var(--bdr);color:var(--muted);padding:11px 28px;font-family:'Oswald',sans-serif;font-size:.88rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .25s}
.btn-back-step:hover{border-color:#fff;color:#fff}
.booking-confirm{text-align:center;padding:60px 20px;animation:fadeUp .6s ease both}
.confirm-icon{font-size:3.5rem;margin-bottom:20px;animation:popIn .55s cubic-bezier(.34,1.56,.64,1) both}
.booking-confirm h3{color:#fff;font-size:1.8rem;margin-bottom:12px}
.booking-confirm p{color:var(--muted);max-width:400px;margin:0 auto 30px;font-size:.9rem}

/* ── KURSE / SCHEDULE ── */
.sched-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.sched-card{background:var(--bg2);border:1px solid var(--bdr);padding:28px 24px;transition:border-color .3s,transform .3s}
.sched-card:hover{border-color:var(--red);transform:translateY(-4px)}
.sched-day{font-family:'Oswald',sans-serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.sched-time{font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;color:#fff;line-height:1;margin-bottom:10px}
.sched-course{font-size:.95rem;color:#ccc;font-weight:500;margin-bottom:10px}
.sched-badge{display:inline-block;font-size:.68rem;background:rgba(230,57,70,.1);color:var(--red);border:1px solid rgba(230,57,70,.3);padding:2px 9px;text-transform:uppercase;letter-spacing:.1em}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.p-card{background:var(--bg3);border:1px solid var(--bdr);padding:42px 34px;position:relative;transition:transform .35s,box-shadow .35s}
.p-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,0,0,.5)}
.p-card.featured{border-color:var(--red)}
.feat-pill{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-family:'Oswald',sans-serif;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;padding:4px 18px}
.p-name{font-family:'Oswald',sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin-bottom:16px}
.p-price{font-family:'Oswald',sans-serif;font-size:3.5rem;font-weight:700;color:#fff;line-height:1;display:flex;align-items:flex-start;gap:3px}
.p-price sup{font-size:1.3rem;padding-top:8px}
.p-period{font-size:.8rem;color:#888;margin:8px 0 26px}
.p-list{list-style:none;margin-bottom:32px}
.p-list li{padding:10px 0;border-bottom:1px solid var(--bdr);font-size:.86rem;color:#aaa;display:flex;align-items:center;gap:9px}
.p-list li::before{content:'✓';color:var(--red);font-weight:700;flex-shrink:0}
.btn-block{display:block;width:100%;text-align:center;padding:13px;font-family:'Oswald',sans-serif;font-size:.88rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;border:2px solid var(--bdr);color:#aaa;transition:all .3s;background:transparent}
.btn-block:hover{border-color:var(--red);color:var(--red)}
.btn-block.filled{background:var(--red);border-color:var(--red);color:#fff}
.btn-block.filled:hover{background:var(--red-d);border-color:var(--red-d);box-shadow:0 10px 28px rgba(230,57,70,.4)}

/* ── BENEFITS ── */
.ben-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:36px}
.ben-item{text-align:center;padding:18px 8px;transition:transform .3s}
.ben-item:hover{transform:translateY(-4px)}
.ben-n{font-family:'Oswald',sans-serif;font-size:3rem;font-weight:700;color:rgba(230,57,70,.16);line-height:1;margin-bottom:14px;transition:color .3s}
.ben-item:hover .ben-n{color:rgba(230,57,70,.4)}
.ben-item h3{color:#fff;font-size:.9rem;margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}
.ben-item p{font-size:.82rem;color:var(--muted)}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.testi-card{background:var(--bg2);padding:32px 28px;border-left:3px solid var(--red);transition:transform .3s,border-left-width .3s}
.testi-card:hover{transform:translateY(-4px);border-left-width:6px}
.testi-stars{color:var(--red);font-size:.85rem;letter-spacing:3px;margin-bottom:16px}
.testi-text{font-size:.88rem;color:#aaa;line-height:1.8;font-style:italic;margin-bottom:24px}
.testi-author{display:flex;align-items:center;gap:12px}
.t-avatar{width:40px;height:40px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700;color:#fff;font-size:.95rem;flex-shrink:0}
.t-name{font-family:'Oswald',sans-serif;font-size:.9rem;text-transform:uppercase;color:#fff}
.t-since{font-size:.72rem;color:#555;margin-top:2px}

/* ── FAQ ── */
.faq-wrap{max-width:740px}
.faq-item{border-bottom:1px solid var(--bdr)}
.faq-q{width:100%;background:none;border:none;color:#ddd;font-family:'Oswald',sans-serif;font-size:.98rem;text-transform:uppercase;letter-spacing:.04em;padding:20px 0;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;transition:color .25s}
.faq-q:hover{color:var(--red)}
.faq-plus{font-size:1.5rem;color:var(--red);flex-shrink:0;line-height:1;transition:transform .3s}
.faq-item.open .faq-plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 0 20px;font-size:.88rem;color:var(--muted)}
.faq-item.open .faq-a{max-height:320px}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:70px;align-items:start}
.c-info p{font-size:.88rem;color:var(--muted);margin-bottom:32px}
.c-detail{display:flex;gap:12px;margin-bottom:20px;transition:transform .25s}
.c-detail:hover{transform:translateX(4px)}
.c-icon{font-size:1rem;color:var(--red);flex-shrink:0;margin-top:2px}
.c-text{font-size:.85rem;color:#888}
.c-text strong{display:block;color:#ccc;margin-bottom:2px;font-weight:500}
.submit-btn{width:100%;background:var(--red);color:#fff;padding:14px;font-family:'Oswald',sans-serif;font-size:.92rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;border:none;cursor:pointer;transition:all .3s}
.submit-btn:hover{background:var(--red-d);box-shadow:0 10px 28px rgba(230,57,70,.4);transform:translateY(-2px)}

/* ── CTA STRIP ── */
.cta-strip{background:linear-gradient(120deg,#1a0408 0%,#330912 100%);border-top:1px solid rgba(230,57,70,.25);border-bottom:1px solid rgba(230,57,70,.25);padding:70px 5%;text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;left:-100px;top:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(230,57,70,.25),transparent 70%);animation:floatGlow 7s ease-in-out infinite alternate}
.cta-strip::after{content:'';position:absolute;right:-100px;bottom:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(230,57,70,.2),transparent 70%);animation:floatGlow 7s ease-in-out 1s infinite alternate-reverse}
.cta-strip .inner{position:relative;z-index:1}
.cta-strip h2{color:#fff;margin-bottom:14px}
.cta-strip p{color:#bbb;max-width:540px;margin:0 auto 28px}

/* ── FOOTER ── */
footer{background:#060606;border-top:1px solid var(--bdr);padding:58px 5% 28px}
.footer-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.f-logo{font-family:'Oswald',sans-serif;font-size:1.2rem;font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:12px}
.f-logo em{color:var(--red);font-style:normal}
.f-desc{font-size:.8rem;color:#666;line-height:1.75}
.f-col h4{font-family:'Oswald',sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;color:#888;margin-bottom:16px}
.f-links{list-style:none}
.f-links li{margin-bottom:9px}
.f-links a{font-size:.8rem;color:#666;transition:color .25s}
.f-links a:hover{color:var(--red)}
.footer-bottom{max-width:1160px;margin:0 auto;border-top:1px solid var(--bdr);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.76rem;color:#555}
.legal-links{display:flex;gap:20px}
.legal-links a{font-size:.76rem;color:#555;transition:color .25s}
.legal-links a:hover{color:var(--red)}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes popIn{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.1)}100%{transform:scale(1)}}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.65}}
@keyframes fabPulse{0%,100%{box-shadow:0 8px 28px rgba(230,57,70,.4)}50%{box-shadow:0 8px 36px rgba(230,57,70,.65)}}
@keyframes fabDot{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}100%{box-shadow:0 0 0 12px rgba(255,255,255,0)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes floatGlow{from{transform:translate(0,0)}to{transform:translate(60px,-40px)}}
@keyframes bgZoom{from{transform:scale(1)}to{transform:scale(1.08)}}

@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
    .reveal,.reveal-stagger>*{opacity:1;transform:none}
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
    .about-grid{grid-template-columns:1fr;gap:50px}
    .about-img-wrap img{height:400px}
    .about-badge{right:0;bottom:0}
    .contact-grid{grid-template-columns:1fr;gap:44px}
    .footer-grid{grid-template-columns:1fr 1fr}
    .cv-grid{grid-template-columns:1fr}
    .fight-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    nav ul{display:none}
    .hamburger{display:flex}
    .header-right nav{display:none}
    section{padding:60px 4%}
    .page-hero{padding:110px 4% 50px}
    #home-hero .hero-content{padding:60px 5%}
    .footer-grid{grid-template-columns:1fr;gap:28px}
    .form-row{grid-template-columns:1fr}
    .book-fab{bottom:14px;right:14px;font-size:.74rem;padding:11px 17px}
    .service-cards{grid-template-columns:1fr}
    .cv-profile{flex-direction:column;text-align:center}
    .cv-quick{justify-content:center}
    .cv-tags{justify-content:center}
    .steps .step-label{display:none}
    .step-line{max-width:30px}
}
@media(max-width:480px){
    .hero-btns{flex-direction:column}
    .btn-red,.btn-ghost{text-align:center;width:100%}
    .pricing-grid{grid-template-columns:1fr}
    .testi-grid{grid-template-columns:1fr}
    .ben-grid{grid-template-columns:1fr 1fr}
    .certs-grid{grid-template-columns:1fr}
    .fight-stats{grid-template-columns:repeat(2,1fr)}
    .hero-stats{gap:24px}
    .stat-num{font-size:2rem}
}
