:root{
  --black:#0a0a0a;
  --white:#ffffff;
  --accent:#d7372f;
  --gray:#1a1a1a;
  --line:#000;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--white);
  color:var(--black);
  font-family:"Manrope",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.45;
}
a{color:inherit;text-decoration:none}
img,svg{display:block}

/* ===== Header bar ===== */
.bar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 20px;
  background:var(--black);color:var(--white);
  border-bottom:4px solid var(--accent);
}
.wordmark{
  font-family:"Oswald",sans-serif;font-weight:700;
  font-size:24px;letter-spacing:.14em;color:var(--white);
}
.bar-actions{display:flex;align-items:center;gap:14px}
.phone{font-weight:800;font-size:15px;letter-spacing:.02em;white-space:nowrap}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:"Oswald",sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
  padding:11px 18px;font-size:14px;
  border:2px solid var(--black);
  transition:transform .12s ease,background .15s ease,color .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-max{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-max:hover{background:#b82a23;border-color:#b82a23}
.btn-ghost{background:transparent;color:var(--black);border-color:var(--black)}
.btn-ghost:hover{background:var(--black);color:var(--white)}
.bar .btn{padding:9px 14px;font-size:13px}
.bar .btn-ghost{border-color:var(--white);color:var(--white)}
.bar .btn-ghost:hover{background:var(--white);color:var(--black)}
.btn-lg{padding:18px 28px;font-size:17px}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  padding:72px 20px 64px;background:var(--black);
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url(assets/img/generated/hero-training.webp) center/cover no-repeat;
  filter:grayscale(1) contrast(1.2);opacity:.24;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,var(--black) 0%,rgba(10,10,10,.65) 45%,rgba(10,10,10,.25) 100%);
}
.hero-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto}
.hero h1{color:var(--white)}
.hero .hero-sub{color:rgba(255,255,255,.82)}
.hero .tag{background:var(--white);color:var(--black)}
.hero .btn-ghost{background:transparent;color:var(--white);border-color:var(--white)}
.hero .btn-ghost:hover{background:var(--white);color:var(--black)}
.tag{
  display:inline-block;font-family:"Oswald",sans-serif;font-weight:600;
  font-size:13px;letter-spacing:.18em;
  background:var(--black);color:var(--white);padding:6px 12px;margin-bottom:24px;
}
.hero h1{
  font-family:"Oswald",sans-serif;font-weight:700;
  font-size:clamp(56px,15vw,160px);line-height:.92;
  letter-spacing:-.01em;text-transform:uppercase;
}
.hero h1 br+*{}
.hero h1{position:relative}
.hero-sub{
  max-width:620px;margin:24px 0 32px;
  font-size:clamp(16px,2.4vw,20px);font-weight:600;color:var(--gray);
}
.cta-row{display:flex;flex-wrap:wrap;gap:14px}

/* ===== Section labels ===== */
.sec-label{
  font-family:"Oswald",sans-serif;font-weight:700;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:20px;
}

/* ===== Directions ===== */
.dirs{
  border-top:5px solid var(--black);
  padding:48px 20px;max-width:1100px;margin:0 auto;
}
.dir-list{list-style:none}
.dir-list li{
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:"num name" "num desc";
  column-gap:24px;align-items:baseline;
  padding:24px 0;border-bottom:2px solid var(--black);
}
.dir-list li:first-child{border-top:2px solid var(--black)}
.num{
  grid-area:num;align-self:center;
  font-family:"Oswald",sans-serif;font-weight:700;
  font-size:clamp(40px,7vw,72px);line-height:1;color:var(--accent);
}
.dir-name{
  grid-area:name;
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  font-size:clamp(22px,4vw,38px);line-height:1.05;letter-spacing:.01em;
}
.dir-desc{grid-area:desc;font-weight:600;color:var(--gray);font-size:16px;margin-top:6px}

/* ===== Income ===== */
.income{background:var(--black);color:var(--white)}
.income p{
  max-width:1100px;margin:0 auto;padding:48px 20px;
  font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;
  font-size:clamp(20px,3.6vw,34px);line-height:1.25;letter-spacing:.01em;
}
.income b{color:var(--accent);font-weight:700}

/* ===== Cities ===== */
.cities{padding:48px 20px;max-width:1100px;margin:0 auto;border-bottom:5px solid var(--black)}
.cities-line{
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  font-size:clamp(18px,3vw,30px);line-height:1.3;letter-spacing:.01em;
}

/* ===== Contact ===== */
.contact{padding:64px 20px 72px;max-width:1100px;margin:0 auto;text-align:center}
.contact h2{
  font-family:"Oswald",sans-serif;font-weight:700;text-transform:uppercase;
  font-size:clamp(44px,11vw,120px);line-height:.95;letter-spacing:-.01em;
}
.contact-sub{margin:18px auto 30px;max-width:520px;font-weight:600;color:var(--gray);font-size:17px}
.contact .cta-row{justify-content:center}

/* ===== Footer ===== */
.foot{
  background:var(--black);color:var(--white);
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 22px;
  padding:24px 20px;font-size:14px;font-weight:600;
  border-top:4px solid var(--accent);
}
.foot a:hover{color:var(--accent)}

/* ===== Sticky mobile CTA ===== */
.sticky-cta{
  display:none;
  position:fixed;left:14px;right:14px;bottom:14px;z-index:60;
  align-items:center;justify-content:center;gap:9px;
  background:var(--accent);color:var(--white);
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;font-size:16px;
  padding:15px;border:2px solid var(--black);
  box-shadow:0 6px 24px rgba(0,0,0,.35);
}

/* ===== Responsive ===== */
@media (max-width:640px){
  .phone{display:none}
  .bar{padding:12px 14px}
  .wordmark{font-size:20px}
  .dir-list li{grid-template-columns:auto 1fr;column-gap:16px}
  .cta-row .btn-lg{flex:1 1 100%;justify-content:center}
  .sticky-cta{display:flex}
  main{padding-bottom:72px}
}
