/* The Carousel Method — Mobile-first styles */
:root{
  --navy:#0B1C36;
  --gold:#CFAE54;
  --gold-dk:#B99640;
  --text:#2E2E2E;
  --muted:#F8F8F8;
  --white:#FFFFFF;
  --radius:6px;
  --shadow:0 6px 24px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Open Sans","Segoe UI",system-ui,-apple-system,Arial,sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.container{max-width:1200px;margin:0 auto;padding:0 20px}
.container.narrow{max-width:720px}

.site-header{
  position:sticky;top:0;z-index:40;
  background:var(--white);
  border-bottom:1px solid #ececec;
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;min-height:56px;
}
.brand{color:var(--navy);font-weight:800;text-decoration:none}

.section{padding:32px 0}
.section--muted{background:var(--muted)}
.hero{
  background:var(--navy);color:#fff;padding:40px 0 24px;
}
.hero .container{display:grid;gap:20px;align-items:center}
.hero__copy h1{
  font-family:"Montserrat",sans-serif;font-weight:800;
  font-size:32px;line-height:1.2;margin:0 0 8px;color:#fff;
}
.subhead{color:var(--gold);font-size:18px;margin:0 0 16px}
.hero .trust{color:rgba(255,255,255,.85);font-size:13px;margin-top:8px}
.hero__media img{display:block;width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow)}

h2{
  font-family:"Montserrat",sans-serif;font-weight:700;
  color:var(--navy);font-size:26px;margin:0 0 8px;
}
h2.accent{color:var(--gold)}
.lead{color:var(--navy);font-weight:600}

.list{padding-left:18px;margin:12px 0}
.list li{margin:6px 0}

.img{display:block;width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow);margin:12px 0}

.steps{display:grid;gap:16px;margin:12px 0}
.step h3{font-family:"Montserrat",sans-serif;font-size:18px;margin:0 0 4px;color:var(--navy)}
.proof{font-size:14px;color:rgba(11,28,54,.8);margin-top:8px}

.before-after{display:grid;gap:8px;margin:8px 0 12px}

.offer{display:grid;gap:16px}
.card{
  border:1px solid #ececec;border-radius:12px;padding:16px;background:#fff;box-shadow:var(--shadow);
}
.card h3{margin:0 0 6px;color:var(--navy);font-family:"Montserrat",sans-serif}
.card .price{margin:10px 0 14px}
.price .now{font-weight:800;font-family:"Montserrat",sans-serif;font-size:32px;color:var(--navy);margin-right:8px}
.price .rrp{color:#777;text-decoration:line-through}

.countdown{
  display:flex;align-items:center;gap:8px;margin:14px 0 6px;
}
.cd-label{font-weight:600;color:var(--navy)}
.cd-timer{font-family:"Montserrat",sans-serif;font-weight:700}

.policy{background:var(--navy);color:#fff}
.policy h2{color:#fff}
.policy .policy-text{opacity:.9}

.final-cta .sub{font-family:"Montserrat",sans-serif;color:var(--gold);font-size:18px;margin-top:4px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 20px;border-radius:var(--radius);text-decoration:none;cursor:pointer;
  font-family:"Montserrat",sans-serif;font-weight:700;font-size:18px;line-height:1;
  transition:.15s ease-in-out; border:1px solid transparent;
}
.btn--primary{background:var(--gold);color:#fff}
.btn--primary:hover{background:var(--gold-dk)}
.btn--ghost{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn--ghost:hover{background:rgba(207,174,84,.08)}

/* Make header row flex with a little space between brand and nav */
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;min-height:56px;
  gap:12px; /* new */
}

/* Nav as a flex row with gaps instead of margins */
.nav{
  display:flex;
  gap:10px;
}

/* Equal widths for both buttons */
.nav .btn{
  flex:1 1 0;         /* share space equally */
  text-align:center;
  padding:14px 20px;  /* keep your button padding */
  box-sizing:border-box;
}

@media (max-width: 768px) {
  /* This rule forces the header items to wrap, stacking the brand and the nav. */
  .site-header .container {
    flex-wrap: wrap; 
    align-items: flex-start;
  }
  /* This forces the brand and nav to take up the full width, wrapping them onto new lines. */
  .brand, .nav {
    flex: 1 1 100%; 
  }
  /* The nav container becomes a column, so buttons stack with a gap. */
  .nav {
    flex-direction: column; 
    padding-top: 10px; 
    gap: 10px; 
  }
  /* This makes both buttons the same width and fills the entire nav container. */
  .nav .btn {
    width: 100%;
    margin-bottom: 0;
  }
}
  
/* Optional: on wider screens, cap nav width so buttons don’t stretch too wide */
@media (min-width: 1024px){
  .nav{ width:360px; } /* adjust to taste */
}

.site-footer{padding:24px 0;border-top:1px solid #ececec}
.site-footer .small{font-size:13px;color:#777;margin:6px 0 0}

.micro-cta{font-size:14px;color:var(--navy);margin-top:8px}

/* Modal */
.modal{
  position:fixed;inset:0;display:none;place-items:center;
  background:rgba(0,0,0,.5);z-index:100;
}
.modal[aria-hidden="false"]{display:grid}
.modal__dialog{
  width:min(92vw,560px);background:#fff;border-radius:14px;padding:20px;box-shadow:var(--shadow)
}
.modal__close{
  position:absolute;right:14px;top:10px;border:0;background:transparent;
  font-size:28px;cursor:pointer;color:#333
}
.form{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
.form input[type="email"]{
  padding:12px 12px;border:1px solid #ddd;border-radius:8px;font-size:16px
}
.tiny{font-size:12px;color:#666;margin-top:8px}
.visually-hidden{position:absolute !important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden}

/* Responsive: simple desktop enhancements */
@media (min-width: 768px){
  .hero .container{grid-template-columns:1.2fr .8fr}
  .offer{grid-template-columns:1fr 1fr}
}