
:root{
    --bg:#17191e;
    --bg-soft:#1d2026;
    --bg-deep:#111317;
    --panel:#1a1d22;
    --text:#ffffff;
    --muted:#c9c9c9;
    --muted-2:#9fa4ad;
    --line:rgba(255,255,255,0.08);
    --brand:#ef544e;
    --cream:#fff1cc;
    --radius:22px;
    --shadow:0 18px 50px rgba(0,0,0,0.28);
}
*,
*::before,
*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    background:var(--bg);
    color:var(--text);
    font-family:Arial, Helvetica, sans-serif;
    line-height:1.5;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
.container{width:min(1180px, calc(100% - 48px));margin:0 auto}
.narrow{max-width:820px}
.center-text{text-align:center}
.eyebrow{
    margin:0 0 10px;
    color:var(--brand);
    font-size:14px;
    font-weight:700;
    letter-spacing:.18em;
    text-transform:uppercase;
}
h1,h2,h3{margin:0;line-height:1.1}
h1{font-size:clamp(38px,5vw,64px);margin-bottom:18px}
h2{font-size:clamp(30px,4vw,48px)}
h3{font-size:clamp(28px,3vw,40px)}
.lead{margin:0 auto;color:var(--muted);font-size:19px;max-width:760px}
.section{padding:96px 0}
.section-dark{background:var(--bg-soft)}
.section-head{
    display:flex;
    justify-content:space-between;
    align-items:end;
    gap:28px;
    margin-bottom:34px;
}
.section-copy{max-width:560px;color:var(--muted);margin:0}

.font_8 {
    font: var(--font_8);
    color: rgb(172, 171, 171);
    letter-spacing: 0em;
    font-family: open sans, sans-serif;
}
.wien-rich-text__text{
    font-size: 22px;
    letter-spacing: normal;
    
    line-height: 1.5em;
}

/* Header */
.site-header{
    position:sticky;top:0;z-index:1000;
    background:rgba(23,25,30,.96);
    border-bottom:1px solid rgba(255,255,255,.03);
    backdrop-filter:blur(8px);
}
.nav-shell{min-height:84px;display:flex;align-items:center;gap:18px}
.brand{
    width:64px;height:64px;flex:0 0 64px;
    display:inline-flex;align-items:center;justify-content:center;
    background:var(--brand);color:var(--cream);font-size:19px;font-weight:500;
}
.main-nav{flex:1}
.main-nav ul{
    list-style:none;margin:0;padding:0;
    display:flex;flex-wrap:wrap;align-items:center;gap:8px;
}
.main-nav a{
    display:inline-block;padding:10px 12px;
    color:#dfdfdf;font-size:17px;line-height:1;white-space:nowrap;
    transition:color .2s ease;
}
.main-nav a:hover{color:var(--brand)}
.menu-toggle{
    display:none;width:46px;height:46px;margin-left:auto;
    border:1px solid rgba(255,255,255,.12);border-radius:10px;
    background:transparent;padding:0;cursor:pointer;
}
.menu-toggle span{display:block;width:22px;height:2px;background:#fff;margin:5px auto}

/* Hero */
.hero-section{position:relative;width:100%;overflow:hidden;background:var(--bg-deep)}
.hero-media{position:relative;width:100%;min-height:620px;overflow:hidden}
.hero-image-layer{
    position:absolute;top:0;left:50%;
    width:100vw;height:100%;
    transform:translateX(-50%);
    background:url("assets/hero-bg.avif") center center / cover no-repeat;
}
.hero-dark-overlay{
    position:absolute;inset:0;
    background:
        linear-gradient(rgba(12,14,18,.56), rgba(12,14,18,.66)),
        radial-gradient(circle at center, rgba(0,0,0,.04), rgba(0,0,0,.26));
}
.hero-logo-card{
    position:absolute;inset:0;z-index:2;
    display:flex;align-items:center;justify-content:center;padding:34px;
}
.hero-logo-card img{
    width:min(520px,52vw);height:auto;
    filter:drop-shadow(0 18px 40px rgba(0,0,0,.35));
}
.scroll-down{
    position:absolute;left:50%;bottom:150px;transform:translateX(-50%);
    width:60px;height:60px;border:3px solid var(--brand);border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    z-index:5;background:var(--bg);box-shadow:var(--shadow);
}
.scroll-down span{
    width:14px;height:14px;border-right:3px solid var(--brand);border-bottom:3px solid var(--brand);
    transform:rotate(45deg);margin-top:-7px;
}

.intro-section{padding-top:340px}

/* Training large offer blocks */
.training-head{margin-bottom:24px}
.training-stack{display:grid;gap:28px}
.training-feature{
    display:grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
    gap:0;
    border:1px solid var(--line);
    border-radius:30px;
    margin-bottom: 59px;
    overflow:hidden;
    background:var(--panel);
    box-shadow:var(--shadow);
}
.training-feature.reverse{
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
}
.training-feature.reverse .training-feature__media{order:2}
.training-feature.reverse .training-feature__content{order:1}
.training-feature__media{
    min-height:480px;
    background:#121418;
    position:relative;
}
.training-feature__media img{
    width:100%;height:100%;
}
.training-feature__content{
    padding:38px 36px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    background:
        linear-gradient(180deg, rgba(255,255,255,.015), rgba(0,0,0,.04));
}
.training-title-img{
    width:min(360px, 100%);
    max-height:84px;
    object-fit:contain;
    object-position:left center;
    margin-bottom:44px;
}
.training-feature__content h3{
    margin-bottom:14px;
}
.training-feature__content p{
    color:var(--muted);
    margin:0 0 14px;
    font-size:18px;
}
.training-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:10px;
}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.pricing-card{
    position:relative;border:1px solid var(--line);border-radius:var(--radius);
    background:#1b1e24;padding:28px;box-shadow:var(--shadow);
}
.pricing-card.featured{
    border-color:rgba(239,84,78,.45);
    background:linear-gradient(180deg, rgba(239,84,78,.09), rgba(255,255,255,.02));
}
.pricing-badge{
    position:absolute;top:16px;right:16px;background:var(--brand);color:#fff;
    padding:7px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;
}
.pricing-label{margin:0 0 10px;color:var(--brand);font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.price{margin-top:24px;font-size:56px;font-weight:700;line-height:1}
.price-note{margin:6px 0 18px;color:var(--muted-2)}
.pricing-card ul{padding-left:18px;margin:0 0 24px;color:var(--muted)}
.pricing-card li + li{margin-top:8px}

/* Buttons */
.btn{
    display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;
    border-radius:12px;border:1px solid transparent;font-weight:700;
    transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--brand);color:#fff}
.btn-outline{border-color:rgba(255,255,255,.15);color:#fff;background:transparent}
.btn-full{width:100%}

/* Schedule */
.schedule-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.schedule-card{
    padding:26px;border-radius:var(--radius);background:#1a1d22;border:1px solid var(--line);box-shadow:var(--shadow);
}
.schedule-card h3{margin-bottom:16px}
.schedule-card ul{margin:0;padding:0;list-style:none}
.schedule-card li{
    display:flex;gap:14px;padding:12px 0;border-top:1px solid rgba(255,255,255,.06);color:var(--muted);
}
.schedule-card li:first-child{border-top:0;padding-top:0}
.schedule-card span{min-width:58px;color:#fff;font-weight:700}

/* Trainers */
.trainers-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.trainer-card{
    border-radius:var(--radius);overflow:hidden;background:#15181d;border:1px solid var(--line);box-shadow:var(--shadow);
}
.trainer-card img{width:100%;aspect-ratio:4/4.4;object-fit:cover}
.trainer-card__content{padding:20px}
.trainer-card__content p{margin:8px 0 0;color:var(--muted)}

/* News */
.news-banner{
    display:grid;grid-template-columns:1.1fr 1fr;gap:24px;align-items:stretch;
    background:#1a1d22;border-radius:28px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);
}
.news-banner__image img{width:100%;height:100%;object-fit:cover}
.news-banner__content{padding:34px;display:flex;flex-direction:column;justify-content:center}
.news-banner__content p:not(.eyebrow){color:var(--muted)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact-copy p:not(.eyebrow){color:var(--muted)}
.contact-list{display:grid;gap:14px;margin-top:26px}
.contact-list div{
    display:flex;flex-direction:column;gap:4px;padding:16px 18px;border-radius:16px;
    background:#1a1d22;border:1px solid var(--line);
}
.contact-list span{color:var(--muted)}
.contact-form{
    padding:24px;border-radius:24px;background:#1a1d22;border:1px solid var(--line);box-shadow:var(--shadow);
}
.form-row{display:grid;gap:8px;margin-bottom:16px}
.form-row label{font-weight:700}
.form-row input,.form-row textarea{
    width:100%;border:1px solid rgba(255,255,255,.09);background:#111317;color:#fff;
    border-radius:14px;padding:14px 16px;outline:none;
}
.form-row input::placeholder,.form-row textarea::placeholder{color:#858b95}

/* Footer */
.site-footer{
    padding:30px 0 48px;border-top:1px solid rgba(255,255,255,.04);background:#14161a;
}
.footer-shell{display:flex;justify-content:space-between;gap:24px;align-items:center}
.footer-shell p{margin:8px 0 0;color:var(--muted-2)}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{color:#d8d8d8}

/* Reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

@media (max-width:1080px){
    .trainers-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .news-banner,.contact-grid{grid-template-columns:1fr}
}
@media (max-width:980px){
    .menu-toggle{display:block}
    .main-nav{
        position:absolute;top:100%;left:0;right:0;display:none;background:rgba(23,25,30,.99);
        border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);padding:12px 24px 18px;
    }
    .main-nav.is-open{display:block}
    .main-nav ul{flex-direction:column;align-items:flex-start;gap:4px}
    .main-nav a{width:100%;padding:12px 0}
    .training-feature,
    .training-feature.reverse{
        grid-template-columns:1fr;
    }
    .training-feature.reverse .training-feature__media,
    .training-feature.reverse .training-feature__content{
        order:initial;
    }
    .training-feature__media{min-height:340px}
    .pricing-grid,.schedule-grid{grid-template-columns:1fr}
    .footer-shell,.section-head{flex-direction:column;align-items:flex-start}
    .hero-media{min-height:560px}
    .hero-logo-card img{width:min(420px,74vw)}
}
@media (max-width:680px){
    .container{width:min(100% - 24px,1180px)}
    .section{padding:72px 0}
    .nav-shell{min-height:74px}
    .brand{width:52px;height:52px;flex-basis:52px;font-size:16px}
    .hero-media{min-height:420px}
    .hero-logo-card{padding:20px}
    .hero-logo-card img{width:min(300px,80vw)}
    .scroll-down{width:50px;height:50px;bottom:-24px}
    .trainers-grid{grid-template-columns:1fr}
    .training-feature__content{padding:26px 20px}
    .training-feature__media{min-height:250px}
    .training-feature__content p{font-size:16px}
    .training-title-img{max-height:64px}
    .contact-form{padding:18px}
    .news-banner__content{padding:22px}
}
