/* Reset some basics specifically for hero to match the HTML file environment */
.hero-wrapper-outer {
    --yellow:#F5C200; --yellow-dark:#C99A00;
    --red:#D0200A; --orange:#D04000;
    --cream:#FFFFFF;
    --cream2:#F5F5F5;
    --cream3:#EBEBEB;
    --border-cream:#E0E0E0;
    --text:#1A1410;
    --text-muted:#6B5C4E;
    --text-dim:#9C8878;
    font-family: 'DM Sans', sans-serif;
}

.hero-wrapper-outer * { box-sizing: border-box; }

/* ═══════════════ HERO ═══════════════ */
.hero{
  display:grid;
  grid-template-columns:1fr 280px 200px;
  min-height:550px;
  background:#FFFFFF;
  overflow:hidden;
  position:relative;
}
.hero-left{padding:56px 40px 48px;display:flex;flex-direction:column;justify-content:space-between;text-align: left;}
.hero-star{position:absolute;top:50px;left:355px;font-size:34px;color:#1A1410;opacity:.6;animation:hero-spin 16s linear infinite;pointer-events:none;}
@keyframes hero-spin{to{transform:rotate(360deg);}}
.hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(60px,9vw,112px);line-height:.92;color:#1A1410;letter-spacing:2px;margin: 0;}
.hero h1 .acc{color:#F5C200;}
.with-avs{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:6px;}
.av-stack{display:flex;}
.av{width:40px;height:40px;border-radius:50%;border:2.5px solid #fff;margin-left:-10px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;}
.av:first-child{margin-left:0;}
.av img{width:100%;height:100%;object-fit:cover;}
.av1{background:#5BC4A0;color:#0a2f20;} .av2{background:#F5C200;color:#6a4500;}
.av3{background:#7B82E0;color:#1A1410;} .av4{background:#D0200A;color:#1A1410;}
.hero-bottom{display:flex;align-items:flex-end;gap:32px;margin-top:40px;flex-wrap:wrap;}
.btn-enroll{display:inline-flex;align-items:center;gap:12px;background:#2C1F14;color:#fff;padding:14px 24px;border-radius:8px;font-size:15px;font-weight:700;transition:all .2s;white-space:nowrap;border:none;cursor:pointer;text-decoration: none;}
.btn-enroll:hover{background:#F5C200;color:#1A1410;transform:translateX(3px);}
.btn-arrow{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;flex-shrink:0;}
.hero-tagline{font-size:13px;color:#555555;line-height:1.65;max-width:200px;margin: 0;}

/* center card */
.hero-center{
  background:#FFFFFF;position:relative;
  display:flex;align-items:flex-end;justify-content:center;
  padding:20px 14px 0;
}
.prog-badge{
  position:absolute;top:30px;left:26px;
  background:#fff;border-radius:12px;padding:10px 14px;
  text-align:center;z-index:5;box-shadow:0 4px 20px rgba(0,0,0,.4);
}
.prog-badge .num{font-family:'Bebas Neue',sans-serif;font-size:32px;color:#1A1410;line-height:1;}
.prog-badge .lbl{font-size:9px;color:#666666;text-transform:uppercase;letter-spacing:.1em;font-weight:700;}
.hero-center-card{width:100%;height:100%;border-radius:24px 24px 0 0;overflow:hidden;position:relative;}
.hero-center-img{width:100%;height:100%;min-height:420px;object-fit:cover;object-position:center 20%;display:block;}
.hc-overlay{position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(transparent,rgba(0,0,0,.2));}

/* right panel */
.hero-right{background:#D04000;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
.hr-top{padding:20px 16px;position:relative;z-index:2;}
.hr-name{font-family:'Bebas Neue',sans-serif;font-size:48px;color:#fff;line-height:.88;letter-spacing:2px;}
.hr-role{font-size:10px;color:rgba(255,255,255,.75);margin-top:6px;text-transform:uppercase;letter-spacing:.08em;}
.hr-photo{flex:1;overflow:hidden;}
.hero-right-img{width:100%;height:100%;object-fit:cover;object-position:center 10%;}
.dots-g{position:absolute;bottom:14px;right:12px;display:grid;grid-template-columns:1fr 1fr;gap:6px;z-index:3;}
.dot{width:12px;height:12px;border-radius:50%;}
.dw{background:rgba(255,255,255,.9);} .dy{background:#F5C200;opacity:.8;}

/* ── REVIEW BANNER ── */
.rev-banner {
  background: #F5F5F5;
  border-top: 1px solid #E0E0E0;
  border-bottom: 1px solid #E0E0E0;
  padding: 20px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.rb-text { display: flex; align-items: center; gap: 14px; }
.rb-title { font-size: 15px; font-weight: 600; color: #1A1410; }
.rb-sub { font-size: 13px; color: #555; }
.rb-btn {
  background: #F5C200;
  color: #1A1410;
  padding: 10px 22px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  transition: background .2s;
  white-space: nowrap;
  text-decoration: none;
}
.rb-btn:hover { background: #C99A00; }
.stripe { height: 1px; background: #DADADA; }

/* ══ MOBILE HERO CARDS ══ */
.hero-mobile-cards{
  display:none;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:0 20px 0;
  background:#FFFFFF;
}
.hmc-card{
  position:relative;
  border-radius:20px 20px 0 0;
  overflow:hidden;
  height:280px;
}
.hmc-card img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 15%;
  display:block;
}
.hmc-main{background:#F5F5F5;}
.hmc-badge{
  position:absolute;top:12px;left:12px;z-index:3;
  background:#fff;border-radius:10px;
  padding:8px 12px;text-align:center;
  box-shadow:0 3px 12px rgba(0,0,0,.15);
  display:flex;flex-direction:column;align-items:center;
}
.hmc-num{font-family:'Bebas Neue',sans-serif;font-size:26px;color:#1A1410;line-height:1;}
.hmc-lbl{font-size:8px;color:#888888;text-transform:uppercase;letter-spacing:.1em;font-weight:700;}
.hmc-orange{background:#D04000;}
.hmc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(208,64,0,.55) 0%, transparent 40%);
}
.hmc-label{
  position:absolute;top:14px;left:14px;z-index:3;
}
.hmc-name{
  font-family:'Bebas Neue',sans-serif;font-size:28px;
  color:#fff;line-height:.9;letter-spacing:1.5px;
}
.hmc-role{font-size:9px;color:rgba(255,255,255,.75);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;}

/* ═══════════════ RESPONSIVE ═══════════════ */

@media(max-width:1024px){
  .hero{grid-template-columns:1fr 260px;min-height:460px;}
  .hero-right{display:none;}
  .hero-star{left:320px;}
  .hero h1{font-size:clamp(56px,7.5vw,88px);}
  .bottom-strip{grid-template-columns:200px 1fr 200px;}
  .rev-banner { padding: 16px 28px; }
}

@media(max-width:768px){
  .hero{ display: none; }
  .bottom-strip{ grid-template-columns: 1fr; }
  .rev-banner { padding: 16px 20px; }
  
  /* Brookhurst-style Mobile Hero Slider */
  .hero-mobile-cards {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 75vh;
    width: 100%;
    padding: 0;
    position: relative;
    text-align: center;
    color: #fff;
    margin-bottom: 0;
    overflow: hidden;
    background: #000;
  }
  
  .brook-m-slides {
    position: absolute;
    inset: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
  }
  
  .brook-m-slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 1s ease-in-out;
  }
  
  .brook-m-slide.active {
    opacity: 1;
  }
  
  .brook-m-content {
     width: 100%;
     max-width: 330px;
     margin: 0 auto;
     z-index: 5;
     position: relative;
     padding: 24px 20px 0;
  }
  .brook-m-content::before {
    content: "";
    position: absolute;
    top: 0;
    left: 20px;
    right: 20px;
    height: 1px;
    background: rgba(255,255,255,0.55);
  }
  .brook-m-sub {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 12px;
    font-weight: 500;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5);
  }
  .brook-m-title {
    font-family: 'Playfair Display', serif;
    font-size: 56px;
    line-height: 0.95;
    margin-bottom: 24px;
    letter-spacing: 0;
    font-weight: 400;
    text-transform: none;
    color: #fff;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
  }
  .brook-m-title {
    display: none;
  }
  .brook-m-title::first-line {
    font-family: 'DM Sans', sans-serif;
    font-weight: 200;
    letter-spacing: 0.5px;
  }
  .brook-m-btn {
    display: inline-block;
    background: #F58220;
    color: #fff;
    padding: 14px 32px;
    border-radius: 4px;
    font-weight: 700;
    font-size: 16px;
    text-decoration: none;
    transition: background 0.3s;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
  }
  .brook-m-btn:hover { background: #e07310; color: #fff; }
  
  .brook-m-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 42px;
    color: rgba(255,255,255,0.7);
    padding: 20px;
    z-index: 10;
    cursor: pointer;
    user-select: none;
  }
  .brook-m-arrow-l { left: 0px; }
  .brook-m-arrow-r { right: 0px; }
}

@media(max-width:480px){
  .brook-m-title { font-size: 46px; }
}
