:root{
  --red:#e01822;
  --red-dark:#9e1118;
  --black:#050506;
  --panel:#101014;
  --panel-soft:#16161c;
  --border:#2d2d35;
  --text:#f4f4f4;
  --muted:#b6b8c0;
  --shadow:0 30px 90px rgba(0,0,0,.42);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#060607;color:var(--text);font-family:Arial,Helvetica,sans-serif;overflow-x:hidden}
a{color:inherit}
button{font:inherit}

.loader{position:fixed;inset:0;background:#050506;z-index:9999;display:grid;place-items:center;animation:loaderFade .8s ease 1s forwards}
.loader img{width:min(340px,70vw);mix-blend-mode:screen;animation:logoPulse 1s ease}
@keyframes loaderFade{to{opacity:0;visibility:hidden}}
@keyframes logoPulse{from{opacity:0;transform:scale(.92);filter:blur(10px)}to{opacity:1;transform:scale(1);filter:blur(0)}}

.hero{min-height:920px;background:linear-gradient(90deg,rgba(0,0,0,.92),rgba(0,0,0,.42)),url("../images/hero-master.jpg");background-size:cover;background-position:center;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:54px 54px;mask-image:linear-gradient(to bottom,black,transparent 88%)}
.hero::after{content:"";position:absolute;width:820px;height:820px;right:-370px;bottom:-370px;border-radius:50%;border:95px solid rgba(224,24,34,.12);box-shadow:inset 0 0 90px rgba(224,24,34,.1)}

.nav{width:min(1240px,calc(100% - 42px));margin:0 auto;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:18px;z-index:20;background:rgba(8,8,10,.48);border:1px solid rgba(255,255,255,.1);border-radius:16px;backdrop-filter:blur(18px);box-shadow:0 18px 55px rgba(0,0,0,.22);transition:.25s ease}
.nav.scrolled{background:rgba(8,8,10,.9);border-color:rgba(224,24,34,.38)}
.brand img{width:205px;max-height:84px;object-fit:contain;display:block;mix-blend-mode:screen;filter:drop-shadow(0 14px 35px rgba(224,24,34,.28))}
.nav-links{display:flex;gap:24px;align-items:center;font-weight:900}
.nav-links a{text-decoration:none;text-transform:uppercase;font-size:.8rem;letter-spacing:.8px;opacity:.92;position:relative}
.nav-links a::after{content:"";position:absolute;height:2px;width:0;left:0;bottom:-8px;background:var(--red);transition:.2s ease}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after{width:100%}
.nav-cta{text-decoration:none;text-transform:uppercase;font-weight:900;letter-spacing:.6px;background:linear-gradient(135deg,var(--red),var(--red-dark));padding:14px 24px;border-radius:8px;box-shadow:0 16px 36px rgba(224,24,34,.28)}
.menu-toggle{display:none;background:transparent;border:0;color:#fff;font-size:2rem;cursor:pointer}

.hero-inner{width:min(1240px,calc(100% - 42px));margin:0 auto;padding:155px 0 145px;display:grid;grid-template-columns:1fr 390px;gap:60px;align-items:center;position:relative;z-index:2}
.hero-copy{max-width:760px}
.eyebrow{color:var(--red);text-transform:uppercase;letter-spacing:2.3px;font-size:.78rem;font-weight:900}
h1,h2,h3{text-transform:uppercase}
h1{font-size:clamp(3.6rem,7.4vw,6.9rem);line-height:.86;letter-spacing:-2px;margin:12px 0 24px}
h1 span{color:var(--red)}
.hero-copy p,.section-heading p,.experience-copy p,.booking-copy p,.proof-bar p,.course-content p,.process-grid p,.hero-panel p,.footer p,.integration-box p{color:var(--muted);line-height:1.7;font-size:1.04rem}
.hero-copy p{color:rgba(255,255,255,.85);font-size:1.18rem}
.button-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:15px 25px;border-radius:8px;border:0;cursor:pointer;text-decoration:none;text-transform:uppercase;font-weight:900;letter-spacing:.6px;transition:.2s ease}
.btn-primary{background:linear-gradient(135deg,var(--red),var(--red-dark));color:white;box-shadow:0 18px 38px rgba(224,24,34,.3)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.25);color:white}
.full{width:100%;grid-column:1/-1}

.hero-panel{padding:28px;border-radius:20px;background:linear-gradient(145deg,rgba(255,255,255,.11),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(18px);box-shadow:var(--shadow);border-top:3px solid var(--red)}
.hero-panel .micro{color:rgba(255,255,255,.58);text-transform:uppercase;letter-spacing:1.8px;font-size:.75rem;font-weight:900;margin:0 0 10px}
.hero-panel h2{margin:0 0 14px;font-size:1.65rem}
.panel-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:22px 0}
.panel-stats span{padding:10px;background:rgba(224,24,34,.12);border:1px solid rgba(224,24,34,.24);color:white;font-size:.78rem;text-align:center;border-radius:8px;font-weight:900}
.hero-panel a,.course-content a{color:var(--red);font-weight:900;text-transform:uppercase;text-decoration:none}

.proof-bar{width:min(1240px,calc(100% - 42px));margin:-80px auto 0;display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(135deg,rgba(17,17,22,.96),rgba(8,8,10,.97));border:1px solid var(--border);border-top:3px solid var(--red);box-shadow:var(--shadow);position:relative;z-index:3;border-radius:16px;overflow:hidden}
.proof-bar article{padding:30px;border-right:1px solid var(--border)}
.proof-bar article:last-child{border-right:0}
.proof-bar span{color:var(--red);font-weight:900}
.proof-bar strong{display:block;margin:10px 0 7px;text-transform:uppercase}

.section{width:min(1240px,calc(100% - 42px));margin:0 auto;padding:105px 0}
.section-heading{max-width:780px;margin-bottom:44px}
.section-heading.center{text-align:center;margin-left:auto;margin-right:auto}
.section-heading h2,.experience-copy h2,.booking-copy h2,.final-overlay h2{font-size:clamp(2.45rem,4.2vw,3.9rem);line-height:.95;letter-spacing:-1px;margin:10px 0 20px}

.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.course-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 22px 55px rgba(0,0,0,.28);transition:.25s ease;position:relative}
.course-card:hover{transform:translateY(-8px);border-color:rgba(224,24,34,.72);box-shadow:var(--shadow)}
.course-card.featured{border-color:rgba(224,24,34,.42)}
.course-image{height:300px;position:relative;overflow:hidden}
.course-image img{width:100%;height:100%;object-fit:cover;display:block;transition:.4s ease}
.course-card:hover .course-image img{transform:scale(1.05)}
.course-image span{position:absolute;left:22px;bottom:22px;color:white;background:rgba(224,24,34,.86);padding:10px 14px;border-radius:999px;font-size:.76rem;font-weight:900;text-transform:uppercase;letter-spacing:1px}
.course-content{padding:30px}
.course-content h3{font-size:1.45rem;margin:0 0 14px}
.meta{margin:24px 0;display:grid;gap:8px;color:white}

.experience-section{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;background:#08080a;border-block:1px solid var(--border)}
.experience-image img{width:100%;height:640px;object-fit:cover;display:block}
.experience-copy{padding:60px max(42px,calc((100vw - 1240px)/2))}
.check-list{margin-top:28px;display:grid;gap:12px}
.check-list p{margin:0;color:white;font-weight:900}

.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:14px}
.gallery-item{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#111;padding:0;cursor:pointer;position:relative}
.gallery-item.large{grid-column:span 2;grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:.35s ease}
.gallery-item:hover img{transform:scale(1.06);filter:brightness(1.1)}
.gallery-item::after{content:"View";position:absolute;right:14px;bottom:14px;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.16);padding:8px 12px;border-radius:999px;color:white;font-size:.75rem;font-weight:900;text-transform:uppercase;opacity:0;transition:.2s ease}
.gallery-item:hover::after{opacity:1}

.process-section{padding:105px max(21px,calc((100% - 1240px)/2));background:radial-gradient(circle at 18% 20%,rgba(224,24,34,.12),transparent 28%),linear-gradient(135deg,#101014,#08080a);border-block:1px solid var(--border)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.process-grid article{padding:28px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.035)}
.process-grid span{color:var(--red);font-weight:900}

.booking-section{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.integration-box{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:22px;margin:24px 0}
code{background:rgba(255,255,255,.08);padding:3px 6px;border-radius:4px}
.form-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:30px;display:grid;grid-template-columns:1fr 1fr;gap:18px;box-shadow:var(--shadow)}
.form-card h3{grid-column:1/-1;margin:0 0 8px}
label{display:grid;gap:8px;color:white;font-weight:900}
input,select,textarea{width:100%;padding:14px;border:1px solid #33343a;background:#070708;color:white;border-radius:8px;font:inherit}
textarea{min-height:140px;resize:vertical}
.form-message{grid-column:1/-1;color:#ff5b63;font-weight:900}

.final-cta{min-height:520px;background:linear-gradient(90deg,rgba(0,0,0,.82),rgba(0,0,0,.45)),url("../images/footer-range.jpg");background-size:cover;background-position:center;display:grid;place-items:center;text-align:center}
.final-overlay{width:min(900px,calc(100% - 42px));padding:55px;border-radius:22px;background:rgba(8,8,10,.55);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(14px)}
.footer{display:grid;grid-template-columns:1fr .65fr 1fr;gap:36px;padding:60px max(21px,calc((100% - 1240px)/2));background:var(--black);border-top:3px solid var(--red)}
.footer img{width:280px;max-width:100%;mix-blend-mode:screen}
.footer a{display:block;color:var(--muted);text-decoration:none;margin:8px 0}
.footer a:hover{color:var(--red)}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:999;display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:94vw;max-height:88vh;border:1px solid rgba(255,255,255,.16);box-shadow:var(--shadow)}
.lightbox-close{position:absolute;top:24px;right:24px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);color:white;font-size:2rem;cursor:pointer}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

@media(max-width:980px){
  .menu-toggle{display:block}
  .nav-cta{display:none}
  .brand img{width:170px}
  .nav{top:10px;width:min(100% - 22px,1240px)}
  .nav-links{display:none;position:absolute;top:92px;left:0;right:0;padding:20px;background:#08080a;border:1px solid var(--border);border-radius:14px}
  .nav-links.open{display:grid;gap:16px}
  .hero-inner,.proof-bar,.course-grid,.experience-section,.booking-section,.process-grid,.footer{grid-template-columns:1fr}
  .hero-inner{padding-top:95px}
  .proof-bar{margin-top:0}
  .proof-bar article{border-right:0;border-bottom:1px solid var(--border)}
  .experience-image img{height:360px}
  .form-card{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:260px}
  .gallery-item.large{grid-column:span 1;grid-row:span 1}
  h1{font-size:clamp(3.1rem,13vw,5.2rem)}
}


/* ---------- Milestone 2 Pages ---------- */
.page-hero {
  min-height: 540px;
  background: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/hero-master.jpg");
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, black, transparent 88%);
}

.page-title {
  width: min(1240px, calc(100% - 42px));
  margin: 0 auto;
  padding: 105px 0 120px;
  position: relative;
  z-index: 2;
}

.page-title h1 {
  font-size: clamp(3.3rem, 7vw, 6.4rem);
  line-height: .86;
  letter-spacing: -2px;
  margin: 12px 0 24px;
}

.page-title p {
  color: rgba(255,255,255,.85);
  line-height: 1.7;
  max-width: 760px;
}

.classes-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/handgun-course.jpg"); }
.handgun-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/handgun-course.jpg"); }
.rifle-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/rifle-course.jpg"); }
.defensive-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/defensive-course.jpg"); }
.instructors-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/lead-instructor-portrait.jpg"); }
.booking-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/booking.jpg"); }
.gallery-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/wide-range-architecture.jpg"); }
.faq-hero, .legal-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/equipment-flatlay.jpg"); }
.contact-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/academy-lifestyle.jpg"); }

.course-detail {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 48px;
  align-items: center;
}

.detail-copy h2,
.map-placeholder h2,
.narrow h2 {
  font-size: clamp(2.35rem, 4vw, 3.7rem);
  line-height: .95;
  letter-spacing: -1px;
  margin: 10px 0 20px;
}

.detail-copy p,
.info-card p,
.info-card li,
.map-placeholder p,
.narrow p {
  color: var(--muted);
  line-height: 1.7;
}

.feature-img {
  width: 100%;
  border-radius: 18px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.cards-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 26px;
}

.cards-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.info-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px;
  box-shadow: 0 20px 50px rgba(0,0,0,.22);
}

.info-card ul {
  padding-left: 20px;
}

.info-card li {
  margin: 10px 0;
}

.full-gallery {
  grid-template-columns: repeat(4, 1fr);
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}

details {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 24px;
}

summary {
  cursor: pointer;
  color: white;
  font-weight: 900;
  text-transform: uppercase;
}

.calendar-shell-page {
  padding-top: 40px;
}

.month-calendar {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.month-calendar > div {
  padding: 16px;
  text-align: center;
  background: #050506;
  font-weight: 900;
  text-transform: uppercase;
}

.month-calendar > span {
  min-height: 110px;
  padding: 12px;
  border-top: 1px solid var(--border);
  border-right: 1px solid var(--border);
  color: var(--muted);
}

.month-calendar .event {
  background: rgba(224,24,34,.18);
  color: white;
  font-weight: 900;
}

.contact-logo {
  width: 300px;
  max-width: 100%;
  mix-blend-mode: screen;
  margin-bottom: 20px;
}

.map-placeholder {
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    radial-gradient(circle at 20% 50%, rgba(224,24,34,.16), transparent 30%),
    linear-gradient(135deg, #111116, #08080a);
  padding: 60px;
}

.narrow {
  max-width: 860px;
}

@media(max-width:980px) {
  .course-detail,
  .cards-2,
  .cards-3,
  .faq-grid,
  .full-gallery {
    grid-template-columns: 1fr;
  }

  .month-calendar > span {
    min-height: 78px;
    font-size: .75rem;
  }
}


/* ---------- Milestone 3 Production Polish ---------- */
.mobile-sticky-book {
  display: none;
}

.booking-flow-section {
  padding-top: 100px;
}

.booking-steps {
  width: min(900px, 100%);
  margin: 0 auto 34px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.booking-step {
  border: 0;
  color: var(--muted);
  background: transparent;
  padding: 20px;
  cursor: pointer;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .5px;
  border-right: 1px solid var(--border);
}

.booking-step:last-child {
  border-right: 0;
}

.booking-step span {
  color: var(--red);
  margin-right: 8px;
}

.booking-step.is-active {
  color: white;
  background: rgba(224,24,34,.16);
}

.booking-panel {
  display: none;
}

.booking-panel.is-active {
  display: block;
}

.booking-course-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.booking-course-card {
  text-align: left;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  color: white;
  cursor: pointer;
  box-shadow: 0 20px 55px rgba(0,0,0,.26);
  transition: .22s ease;
}

.booking-course-card:hover,
.booking-course-card.selected {
  transform: translateY(-5px);
  border-color: rgba(224,24,34,.72);
  box-shadow: var(--shadow);
}

.booking-course-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.booking-course-card span,
.payment-card .eyebrow {
  color: var(--red);
  display: block;
  margin: 22px 22px 8px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.booking-course-card h3,
.booking-course-card p {
  margin-left: 22px;
  margin-right: 22px;
}

.booking-course-card p {
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 24px;
}

.center-row {
  justify-content: center;
}

.calendly-shell {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 28px;
  box-shadow: var(--shadow);
}

.calendly-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 26px;
}

.calendly-placeholder {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 26px;
  align-items: stretch;
}

.fake-calendar {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: #08080a;
}

.fake-calendar > div {
  padding: 14px;
  text-align: center;
  background: #050506;
  color: white;
  font-weight: 900;
}

.fake-calendar > span {
  min-height: 82px;
  padding: 12px;
  border-top: 1px solid var(--border);
  border-right: 1px solid var(--border);
  color: var(--muted);
}

.fake-calendar .hot {
  background: rgba(224,24,34,.2);
  color: white;
  font-weight: 900;
}

.calendly-instructions {
  border: 1px solid rgba(224,24,34,.32);
  border-radius: 16px;
  padding: 24px;
  background:
    radial-gradient(circle at 20% 20%, rgba(224,24,34,.14), transparent 35%),
    #101014;
}

.payment-grid,
.welcome-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 26px;
}

.payment-card,
.student-next-card,
.welcome-card,
.student-checklist {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 30px;
  box-shadow: var(--shadow);
}

.student-next-card {
  margin-top: 26px;
  text-align: center;
}

.student-checklist ul {
  padding-left: 20px;
  color: var(--muted);
  line-height: 1.8;
}

.resources-hero {
  background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/equipment-flatlay.jpg");
}

.student-hero {
  background-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.46)), url("../images/student-success.jpg");
}

/* Larger mobile tap targets */
@media(max-width:980px) {
  .booking-steps,
  .booking-course-grid,
  .calendly-placeholder,
  .payment-grid,
  .welcome-grid {
    grid-template-columns: 1fr;
  }

  .booking-step {
    border-right: 0;
    border-bottom: 1px solid var(--border);
  }

  .fake-calendar > span {
    min-height: 58px;
    font-size: .75rem;
  }

  .mobile-sticky-book {
    display: flex;
    position: fixed;
    left: 16px;
    right: 16px;
    bottom: 16px;
    z-index: 60;
    justify-content: center;
    align-items: center;
    min-height: 54px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--red), var(--red-dark));
    color: white;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 900;
    box-shadow: 0 18px 42px rgba(0,0,0,.45);
  }

  body {
    padding-bottom: 78px;
  }
}


/* ---------- Version 3.0 Signature polish ---------- */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 18%, rgba(224,24,34,.08), transparent 28%),
    radial-gradient(circle at 88% 70%, rgba(224,24,34,.055), transparent 30%);
  z-index: -1;
}

.hero,
.page-hero {
  background-attachment: fixed;
}

.course-card,
.booking-course-card,
.info-card,
.payment-card,
.welcome-card,
.student-checklist {
  backdrop-filter: blur(8px);
}

.btn-primary {
  position: relative;
  overflow: hidden;
}

.btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent, rgba(255,255,255,.22), transparent);
  transform: translateX(-120%);
  transition: .5s ease;
}

.btn-primary:hover::after {
  transform: translateX(120%);
}

.gallery-item img,
.course-image img,
.booking-course-card img,
.feature-img,
.experience-image img {
  image-rendering: auto;
}

@media(max-width:980px) {
  .hero,
  .page-hero {
    background-attachment: scroll;
  }
}
