/* ==========================================
   BADGER HOMEPAGE — UPDATED FULL VERSION
   ========================================== */

/* --------------------------
   SHARED
   -------------------------- */


@media (max-width: 1120px){
  .site-footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 860px){
  .site-footer-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .site-footer-container{
    width:min(100% - 24px, 1180px);
  }

  .site-footer{
    padding:64px 0 22px;
  }
}

body.home-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.home-page *{
  box-sizing:border-box;
}

.home-page a{
  text-decoration:none;
}

.home-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.home-page .bh-container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.home-page .bh-main{
  display:block;
}

.home-page .bh-cta-nav{
  min-width:160px;
}

/* --------------------------
   Header
   -------------------------- */

/* --------------------------
   Header
   -------------------------- */

.home-page .bh-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.home-page .bh-header-inner{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.home-page .bh-brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.home-page .bh-brand-mark{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
  flex:0 0 42px;
}

.home-page .bh-brand-word{
  font-size:inherit;
  font-weight:inherit;
  letter-spacing:inherit;
  line-height:1;
}

.home-page .bh-nav{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.home-page .bh-nav a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

/* --------------------------
   Buttons
   -------------------------- */

.home-page .bh-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
}

.home-page .bh-btn:hover{
  transform:translateY(-1px);
}

.home-page .bh-btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.home-page .bh-btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.home-page .bh-btn-white{
  background:#ffffff;
  color:var(--bh-secondary-dark);
  border-color:#ffffff;
}

.home-page .bh-btn-ghost{
  background:rgba(255,255,255,0.10);
  color:#ffffff;
  border-color:rgba(255,255,255,0.24);
}

/* --------------------------
   Shared labels / titles
   -------------------------- */

.home-page .bh-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.home-page .bh-kicker-light{
  background:rgba(255,255,255,0.14);
  color:#ffffff;
}

.home-page .bh-section-head{
  margin-bottom:28px;
}

.home-page .bh-section-head-center{
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
}

.home-page .bh-section-title{
  margin:18px 0 0;
  font-size:clamp(30px, 3.8vw, 50px);
  line-height:1.04;
  letter-spacing:-0.04em;
  font-weight:800;
  color:var(--bh-text);
}

.home-page .bh-section-title-light{
  color:#ffffff;
}

/* --------------------------
   Hero
   -------------------------- */

.home-page .bh-hero{
  padding:46px 0 56px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.12), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.16), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.home-page .bh-hero-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.home-page .bh-hero-copy{
  max-width:860px;
  text-align:center;
}

.home-page .bh-hero-title{
  margin:18px 0 16px;
  font-size:clamp(34px, 5.4vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-secondary-dark);
  max-width:900px;
}

.home-page .bh-hero-sub{
  max-width:760px;
  margin:0 auto;
  font-size:1.05rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.home-page .bh-hero-actions{
  margin-top:48px;
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}

.home-page .bh-hero-stage{
  position:relative;
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  margin-top:72px;
  padding:38px 32px 20px;
  min-height:930px;
  border-radius:0;
  overflow:hidden;
  background:
    radial-gradient(circle at 22% 20%, rgba(255,255,255,0.16), transparent 24%),
    radial-gradient(circle at 78% 26%, rgba(255,255,255,0.12), transparent 22%),
    linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  box-shadow:none;
}

.home-page .bh-hero-stage::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-70px;
  transform:translateX(-50%);
  width:min(760px, 86%);
  height:180px;
  border-radius:999px 999px 0 0;
  background:rgba(255,255,255,0.14);
  filter:blur(0.5px);
}

.home-page .bh-float{
  position:absolute;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  color:#fff;
  border:1px solid rgba(255,255,255,0.18);
  font-size:0.84rem;
  font-weight:700;
  backdrop-filter:blur(8px);
  z-index:2;
  box-shadow:0 8px 20px rgba(16,20,28,0.08);
  text-align:center;
}

.home-page .bh-float-1{ top:50px; left:50px; }
.home-page .bh-float-2{ top:70px; right:200px; }
.home-page .bh-float-3{ bottom:200px; left:150px; }
.home-page .bh-float-4{ bottom:134px; right:120px; }
.home-page .bh-float-5{ top:220px; left:120px; }
.home-page .bh-float-6{ top:254px; right:84px; }
.home-page .bh-float-7{ top:560px; left:180px; }
.home-page .bh-float-8{ top:650px; right:136px; }
.home-page .bh-float-9{ top:400px; left:80px; }
.home-page .bh-float-10{ top:430px; right:200px; }

.home-page .bh-demo-frame{
  position:relative;
  z-index:3;
  display:flex;
  justify-content:center;
  padding-top:24px;
}

.home-page .bh-demo-phone{
  width:min(430px, 100%);
  padding:14px;
  border-radius:34px;
  background:linear-gradient(180deg, #212632, #373d48);
  box-shadow:0 22px 50px rgba(16,20,28,0.28);
}

.home-page .bh-demo-notch{
  width:34%;
  height:18px;
  margin:0 auto 12px;
  border-radius:0 0 14px 14px;
  background:#12161f;
}

.home-page .bh-demo-screen{
  background:#ffffff;
  border-radius:24px;
  overflow:hidden;
}

.home-page .bh-demo-top{
  display:flex;
  align-items:center;
  gap:12px;
  padding:18px;
  background:var(--bh-secondary);
  color:#ffffff;
  border-radius:0 0 24px 24px;
}

.home-page .bh-demo-avatar{
  width:44px;
  height:44px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,0.18);
  font-weight:800;
}

.home-page .bh-demo-name{
  font-size:1rem;
  font-weight:700;
}

.home-page .bh-demo-tier{
  font-size:0.82rem;
  font-weight:600;
  opacity:0.95;
}

.home-page .bh-demo-ribbon{
  margin:18px;
  padding:14px 16px;
  border-radius:22px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
  display:flex;
  gap:10px;
  align-items:center;
}

.home-page .bh-demo-ribbon-dot{
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--bh-primary);
}

.home-page .bh-demo-ribbon-label{
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--bh-secondary-dark);
}

.home-page .bh-demo-ribbon-copy{
  font-size:0.92rem;
  font-weight:600;
  color:var(--bh-text);
  margin-top:2px;
}

.home-page .bh-demo-task{
  margin:0 18px;
  border-radius:24px;
  overflow:hidden;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.home-page .bh-demo-task-visual{
  min-height:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--bh-primary);
}

.home-page .bh-demo-task-icon{
  width:96px;
  height:96px;
  border-radius:22px;
  display:grid;
  place-items:center;
  font-size:2rem;
  background:rgba(197,251,198,0.14);
  color:#ffffff;
}

.home-page .bh-demo-task-body{
  padding:18px;
}

.home-page .bh-demo-token{
  font-size:0.74rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--bh-primary);
  margin-bottom:8px;
}

.home-page .bh-demo-task-body h3{
  margin:0 0 10px;
  font-size:1.14rem;
  line-height:1.25;
  color:var(--bh-text);
}

.home-page .bh-demo-task-body p{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.6;
}

.home-page .bh-demo-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:14px;
}

.home-page .bh-demo-meta span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:var(--bh-border-soft);
  border:1px solid var(--bh-border);
  color:var(--bh-text-secondary);
  font-size:0.8rem;
  font-weight:600;
}

.home-page .bh-demo-btn{
  width:100%;
  min-height:48px;
  margin-top:16px;
  border:0;
  border-radius:16px;
  background:var(--bh-primary);
  color:#ffffff;
  font-size:0.95rem;
  font-weight:700;
}

.home-page .bh-demo-checkin{
  margin:18px;
  padding:18px;
  border-radius:24px;
  background:var(--bh-secondary);
  color:#ffffff;
}

.home-page .bh-demo-checkin-label{
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.home-page .bh-demo-checkin p{
  margin:0 0 14px;
  color:rgba(255,255,255,0.94);
  line-height:1.6;
}

.home-page .bh-demo-checkin-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 18px;
  border-radius:999px;
  background:#ffffff;
  color:var(--bh-ink);
  font-size:0.9rem;
  font-weight:700;
}

/* --------------------------
   Benefits
   -------------------------- */

.home-page .bh-benefits{
  padding:96px 0;
}

.home-page .bh-benefit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.home-page .bh-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:24px;
  box-shadow:var(--bh-shadow-soft);
}

.home-page .bh-benefit-card{
  padding:30px 30px 34px;
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.home-page .bh-icon-box{
  width:320px;
  height:400px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:rgba(161,242,199,0.24);
  color:var(--bh-primary);
  font-size:1.35rem;
  font-weight:800;
  margin-bottom:22px;
}

.home-page .bh-benefit-card h3{
  margin:0 0 14px;
  font-size:1.12rem;
  line-height:1.25;
  color:var(--bh-text);
}

.home-page .bh-benefit-card p{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.72;
}

/* --------------------------
   How it works — loop
   -------------------------- */

.home-page .bh-how{
  padding:96px 0;
}

.home-page .bh-loop-shell{
  display:grid;
  grid-template-columns:minmax(260px, 1fr) 460px minmax(260px, 1fr);
  gap:26px;
  align-items:center;
  margin-top:16px;
}

.home-page .bh-loop-diagram{
  position:relative;
  width:460px;
  height:460px;
  margin:0 auto;
}

.home-page .bh-loop-ring{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:
    conic-gradient(
      from 243deg,
      var(--bh-secondary-dark) 0deg 114deg,
      #ffffff 114deg 120deg,
      var(--bh-secondary) 120deg 234deg,
      #ffffff 234deg 240deg,
      #b7eab8 240deg 354deg,
      #ffffff 354deg 360deg
    );
  box-shadow:var(--bh-shadow-soft);
}

.home-page .bh-loop-ring::after{
  content:"";
  position:absolute;
  inset:74px;
  border-radius:50%;
  background:#ffffff;
  box-shadow:inset 0 0 0 18px rgba(143,147,255,0.10);
}

.home-page .bh-loop-core{
  position:absolute;
  inset:136px;
  border-radius:50%;
  background:linear-gradient(180deg, rgba(143,147,255,0.18), rgba(143,147,255,0.10));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  z-index:2;
}

.home-page .bh-loop-core-step{
  font-size:0.9rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--bh-secondary-dark);
}

.home-page .bh-loop-core-title{
  margin-top:8px;
  max-width:130px;
  font-size:1.12rem;
  line-height:1.2;
  font-weight:700;
  color:var(--bh-text);
}

.home-page .bh-loop-node{
  position:absolute;
  width:54px;
  height:54px;
  border-radius:27px;
  display:grid;
  place-items:center;
  background:#ffffff;
  color:var(--bh-secondary-dark);
  box-shadow:var(--bh-shadow-soft);
  font-size:1rem;
  font-weight:800;
  z-index:3;
  transform:translate(-50%, -50%);
}

.home-page .bh-loop-node-1{
  top:34.5%;
  left:11%;
}

.home-page .bh-loop-node-2{
  top:34.5%;
  left:89%;
}

.home-page .bh-loop-node-3{
  top:92%;
  left:50%;
}

.home-page .bh-loop-card{
  padding:28px;
  border:none;
  box-shadow:var(--bh-shadow-soft);
}

.home-page .bh-loop-card-1{
  align-self:start;
  margin-top:58px;
  justify-self:end;
}

.home-page .bh-loop-card-2{
  align-self:start;
  margin-top:58px;
  justify-self:start;
}

.home-page .bh-loop-card-3{
  grid-column:2 / 3;
  max-width:420px;
  margin:8px auto 0;
}

.home-page .bh-loop-card-num{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(143,147,255,0.14);
  color:var(--bh-secondary-dark);
  font-size:1rem;
  font-weight:800;
  margin-bottom:16px;
}

.home-page .bh-loop-card h3{
  margin:0 0 12px;
  font-size:1.12rem;
  line-height:1.28;
  color:var(--bh-text);
}

.home-page .bh-loop-card p{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.72;
}

/* --------------------------
   Get section
   -------------------------- */

.home-page .bh-get{
  padding:200px 0;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
}

.home-page .bh-get-panel{
  max-width:1120px;
  margin:0 auto;
  text-align:center;
}

.home-page .bh-get-copy{
  max-width:760px;
  margin:18px auto 0;
  font-size:1.02rem;
  line-height:1.75;
  color:rgba(255,255,255,0.94);
}

.home-page .bh-get-cta-row{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:36px;
}

.home-page .bh-get-primary,
.home-page .bh-get-business{
  min-width:220px;
  min-height:56px;
  font-size:1rem;
}

.home-page .bh-get-qr-placeholder{
  width:min(220px, 100%);
  min-height:220px;
  margin:28px auto 0;
  border-radius:28px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.22);
  color:rgba(255,255,255,0.86);
  font-size:0.95rem;
  font-weight:700;
  letter-spacing:0.02em;
}

@media (max-width: 640px){
  .home-page .bh-get-cta-row{
    flex-direction:column;
    align-items:stretch;
    width:100%;
  }

  .home-page .bh-get-primary,
  .home-page .bh-get-business{
    width:100%;
  }

  .home-page .bh-get-qr-placeholder{
    min-height:180px;
    border-radius:24px;
  }
}

/* removed plan strip */
.home-page .bh-plan-strip{
  display:none;
}

/* --------------------------
   About / pledge
   -------------------------- */

.home-page .bh-about{
  padding:96px 0 82px;
}

.home-page .bh-about-copy{
  max-width:860px;
  margin:18px auto 0;
  text-align:center;
  color:var(--bh-text-secondary);
  line-height:1.8;
  font-size:1.02rem;
}

.home-page .bh-about-copy-secondary{
  margin-top:18px;
  max-width:900px;
}

.home-page .bh-about-pledge-bar{
  width:min(400px, 100%);
  min-height:600px;
  margin:34px auto 0;
  border-radius:28px;
  background:linear-gradient(
    180deg,
    rgba(143,147,255,0.10),
    rgba(143,147,255,0.06)
  );
  border:1px solid rgba(143,147,255,0.18);
  box-shadow:var(--bh-shadow-soft);
}

/* --------------------------
   Footer
   -------------------------- */

.home-page .bh-footer{
  background:#004d43;
  color:#ffffff;
  padding:72px 0 24px;
}

.home-page .bh-footer-grid{
  display:grid;
  grid-template-columns:1.2fr repeat(3, 0.8fr);
  gap:28px;
  align-items:start;
}

.home-page .bh-footer-logo{
  font-size:2rem;
  font-weight:900;
  letter-spacing:0.08em;
  margin-bottom:14px;
}

.home-page .bh-footer-brand p{
  max-width:320px;
  color:rgba(255,255,255,0.74);
  line-height:1.7;
  margin:0;
}

.home-page .bh-footer-title{
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.52);
  margin-bottom:14px;
}

.home-page .bh-footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.home-page .bh-footer-col a{
  color:#ffffff;
  opacity:0.9;
  font-weight:500;
}

.home-page .bh-footer-bottom{
  margin-top:36px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.14);
}

.home-page .bh-footer-bottom p{
  margin:0;
  color:rgba(255,255,255,0.62);
  font-size:0.92rem;
}

/* --------------------------
   Responsive
   -------------------------- */

@media (max-width: 1120px){
  .home-page .bh-footer-grid{
    grid-template-columns:1fr 1fr;
  }

  .home-page .bh-loop-shell{
    grid-template-columns:1fr;
    gap:22px;
  }

  .home-page .bh-loop-card-1,
  .home-page .bh-loop-card-2,
  .home-page .bh-loop-card-3{
    grid-column:auto;
    max-width:none;
    margin:0;
    justify-self:stretch;
  }
}

@media (max-width: 860px){
  .home-page .bh-header-inner{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .home-page .bh-nav{
    flex-wrap:wrap;
    gap:16px;
  }

  .home-page .bh-hero{
    padding:36px 0 56px;
  }

  .home-page .bh-hero-stage{
    min-height:auto;
    padding:24px 16px 16px;
    display:flex;
    flex-direction:column;
    align-items:center;
    margin-top:56px;
  }

  .home-page .bh-float{
    display:inline-flex;
    position:static;
    margin:0 8px 10px 0;
  }

  .home-page .bh-demo-frame{
    width:100%;
    order:2;
  }

  .home-page .bh-benefit-grid,
  .home-page .bh-footer-grid{
    grid-template-columns:1fr;
  }

  .home-page .bh-benefit-card{
    min-height:320px;
  }

  .home-page .bh-loop-diagram{
    width:360px;
    height:360px;
  }

  .home-page .bh-loop-ring::after{
    inset:58px;
  }

  .home-page .bh-loop-core{
    inset:110px;
  }
}

@media (max-width: 640px){
  .home-page .bh-container{
    width:min(100% - 24px, 1180px);
  }

  .home-page .bh-hero-title{
    font-size:clamp(32px, 10vw, 44px);
  }

  .home-page .bh-section-title{
    font-size:clamp(30px, 11vw, 42px);
  }

  .home-page .bh-hero-actions{
    flex-direction:column;
    align-items:stretch;
    width:100%;
  }

  .home-page .bh-hero-actions .bh-btn{
    width:100%;
  }

  .home-page .bh-demo-phone{
    padding:10px;
  }

  .home-page .bh-benefits,
  .home-page .bh-how,
  .home-page .bh-get,
  .home-page .bh-about{
    padding:72px 0;
  }

  .home-page .bh-loop-diagram{
    width:300px;
    height:300px;
  }

  .home-page .bh-loop-ring::after{
    inset:50px;
  }

  .home-page .bh-loop-core{
    inset:94px;
  }

  .home-page .bh-loop-core-title{
    font-size:0.98rem;
  }

  .home-page .bh-loop-node{
    width:46px;
    height:46px;
  }

  .home-page .bh-about-pledge-bar{
    min-height:96px;
    border-radius:22px;
    margin-top:26px;
  }
}

/* ==========================================
   BADGER BLOG PAGE
   Add below homepage styles
   ========================================== */

body.blog-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.blog-page *{
  box-sizing:border-box;
}

.blog-page a{
  text-decoration:none;
}

.blog-page button{
  font:inherit;
}

.blog-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.blog-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.blog-page .section{
  padding:88px 0;
}

.blog-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.blog-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.blog-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* --------------------------
   Header
   -------------------------- */

.blog-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.blog-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.blog-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.blog-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.blog-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.blog-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.blog-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.blog-page .btn:hover{
  transform:translateY(-1px);
}

.blog-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.blog-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.blog-page .cta-nav{
  min-width:160px;
}

/* --------------------------
   Hero
   -------------------------- */

.blog-page .blog-hero{
  padding:46px 0 0;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.blog-page .blog-header{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.blog-page .blog-header-center{
  justify-content:center;
  text-align:center;
}

.blog-page .blog-main-title{
  max-width:900px;
  color:var(--bh-secondary-dark);
}

/* --------------------------
   Tabs
   -------------------------- */

.blog-page .blog-tabs-wrap{
  margin-top:48px;
  padding-bottom:6px;
}

.blog-page .blog-tabs{
  display:flex;
  gap:12px;
  overflow-x:auto;
  padding:4px 2px 8px;
  scrollbar-width:none;
}

.blog-page .blog-tabs::-webkit-scrollbar{
  display:none;
}

.blog-page .blog-tab{
  flex:0 0 auto;
  min-height:46px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid rgba(143,147,255,0.16);
  background:#ffffff;
  color:var(--bh-text);
  box-shadow:0 6px 14px rgba(17,24,39,0.05);  font-size:0.92rem;
  font-weight:700;
  cursor:pointer;
  transition:transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.blog-page .blog-tab:hover{
  transform:translateY(-1px);
}

.blog-page .blog-tab.is-active{
  background:linear-gradient(135deg, rgba(150,79,247,0.12), rgba(143,147,255,0.18));
  color:var(--bh-secondary-dark);
  border-color:rgba(143,147,255,0.28);
}

/* --------------------------
   Panels
   -------------------------- */

.blog-page .blog-panels{
  padding:34px 0 96px;
}

.blog-page .blog-panel{
  display:none;
}

.blog-page .blog-panel.is-active{
  display:block;
}

.blog-page .blog-panel-header{
  max-width:760px;
  margin:0 0 28px;
}

.blog-page .blog-panel-header .h3{
  margin-bottom:12px;
}

/* --------------------------
   Cards
   -------------------------- */

.blog-page .blog-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
  padding:28px;
  display:flex;
  flex-direction:column;
  min-height:280px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.blog-page .blog-card:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 48px rgba(17,24,39,0.10);
  border-color:rgba(143,147,255,0.22);
}

.blog-page .blog-card-wide{
  min-height:320px;
}

.blog-page .blog-card-tall{
  min-height:420px;
}

.blog-page .blog-card-tag{
  display:inline-flex;
  align-self:flex-start;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.blog-page .blog-card-title{
  margin:0 0 14px;
  font-size:1.4rem;
  line-height:1.2;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.blog-page .blog-card-excerpt{
  margin:0;
  color:var(--bh-text-secondary);
}

.blog-page .blog-card-meta{
  margin-top:auto;
  padding-top:18px;
  font-size:0.92rem;
  font-weight:700;
  color:var(--bh-primary);
}

/* --------------------------
   Grid layouts
   -------------------------- */

.blog-page .blog-grid{
  display:grid;
  gap:20px;
}

.blog-page .blog-grid-2x2{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.blog-page .blog-grid-3{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.blog-page .blog-grid-mix{
  grid-template-columns:1.15fr 1fr 1fr;
  align-items:stretch;
}

/* --------------------------
   Stacked wide cards
   -------------------------- */

.blog-page .blog-stack{
  display:grid;
  gap:20px;
}

/* --------------------------
   Carousel
   -------------------------- */

.blog-page .blog-carousel{
  position:relative;
  display:grid;
  grid-template-columns:56px minmax(0, 1fr) 56px;
  gap:16px;
  align-items:center;
}

.blog-page .blog-carousel-btn{
  width:56px;
  height:56px;
  border-radius:18px;
  border:1px solid rgba(143,147,255,0.18);
  background:#ffffff;
  color:var(--bh-secondary-dark);
  box-shadow:var(--bh-shadow-soft);
  font-size:2rem;
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background-color .18s ease;
}

.blog-page .blog-carousel-btn:hover{
  transform:translateY(-1px);
  border-color:rgba(143,147,255,0.32);
}

.blog-page .blog-carousel-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(360px, 1fr);
  gap:20px;
  overflow-x:auto;
  scroll-behavior:smooth;
  scrollbar-width:none;
  padding:4px 2px;
}

.blog-page .blog-carousel-track::-webkit-scrollbar{
  display:none;
}

.blog-page .blog-carousel-track .blog-card-wide{
  opacity:0.72;
  transform:scale(0.985);
  transition:opacity .2s ease, transform .2s ease, box-shadow .2s ease;
}

.blog-page .blog-carousel-track .blog-card-wide.is-active{
  opacity:1;
  transform:scale(1);
}

/* --------------------------
   Cookie banner
   -------------------------- */

.blog-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.blog-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.blog-page .cookie-banner-text{
  max-width:760px;
}

.blog-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.blog-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.blog-page .cookie-btn{
  min-width:150px;
}

/* --------------------------
   Responsive
   -------------------------- */

@media (max-width: 1120px){
  .blog-page .blog-grid-3{
    grid-template-columns:1fr 1fr;
  }

  .blog-page .blog-grid-mix{
    grid-template-columns:1fr 1fr;
  }

  .blog-page .blog-grid-mix .blog-card-tall{
    grid-row:auto;
    min-height:320px;
  }

  .blog-page .blog-carousel-track{
    grid-auto-columns:minmax(320px, 1fr);
  }
}

@media (max-width: 860px){
  .blog-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .blog-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .blog-page .blog-hero{
    padding-top:36px;
  }

  .blog-page .blog-grid-2x2,
  .blog-page .blog-grid-3,
  .blog-page .blog-grid-mix{
    grid-template-columns:1fr;
  }

  .blog-page .blog-card,
  .blog-page .blog-card-wide,
  .blog-page .blog-card-tall{
    min-height:auto;
  }

  .blog-page .blog-carousel{
    grid-template-columns:1fr;
    gap:12px;
  }

  .blog-page .blog-carousel-btn{
    display:none;
  }

  .blog-page .blog-carousel-track{
    grid-auto-columns:88%;
    padding-bottom:4px;
  }

  .blog-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .blog-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .blog-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .blog-page .container{
    width:min(100% - 24px, 1180px);
  }

  .blog-page .section{
    padding:72px 0;
  }

  .blog-page .blog-panels{
    padding:28px 0 72px;
  }

  .blog-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .blog-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .blog-page .blog-card{
    padding:22px;
    border-radius:24px;
  }

  .blog-page .blog-card-title{
    font-size:1.2rem;
  }

  .blog-page .blog-carousel-track{
    grid-auto-columns:92%;
    gap:16px;
  }

  .blog-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .blog-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER ABOUT PAGE
   Add below blog page styles
   ========================================== */

body.about-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.about-page *{
  box-sizing:border-box;
}

.about-page a{
  text-decoration:none;
}

.about-page button{
  font:inherit;
}

.about-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.about-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.about-page .section{
  padding:88px 0;
}

.about-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.about-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.about-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* --------------------------
   Header
   -------------------------- */

.about-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.about-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.about-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.about-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.about-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.about-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.about-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.about-page .btn:hover{
  transform:translateY(-1px);
}

.about-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.about-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.about-page .cta-nav{
  min-width:160px;
}

/* --------------------------
   Hero
   -------------------------- */

.about-page .about-hero{
  padding:46px 0 0;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.about-page .about-header{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.about-page .about-header-center{
  justify-content:center;
  text-align:center;
  flex-direction:column;
}

.about-page .about-main-title{
  max-width:900px;
  color:var(--bh-secondary-dark);  
}

.about-page .about-intro{
  max-width:760px;
  margin:18px auto 0;
}

/* --------------------------
   Tabs
   -------------------------- */

.about-page .about-tabs-wrap{
  margin-top:48px;
  padding-bottom:6px;
}

.about-page .about-tabs{
  display:flex;
  gap:12px;
  overflow-x:auto;
  padding:4px 2px 8px;
  scrollbar-width:none;
}

.about-page .about-tabs::-webkit-scrollbar{
  display:none;
}

.about-page .about-tab{
  flex:0 0 auto;
  min-height:46px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid rgba(143,147,255,0.16);
  background:#ffffff;
  color:var(--bh-text);
  box-shadow:0 6px 14px rgba(17,24,39,0.05);
  font-size:0.92rem;
  font-weight:700;
  cursor:pointer;
  transition:transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.about-page .about-tab:hover{
  transform:translateY(-1px);
}

.about-page .about-tab.is-active{
  background:linear-gradient(135deg, rgba(150,79,247,0.12), rgba(143,147,255,0.18));
  color:var(--bh-secondary-dark);
  border-color:rgba(143,147,255,0.28);
}

/* --------------------------
   Panels
   -------------------------- */

.about-page .about-panels{
  padding:34px 0 96px;
}

.about-page .about-panel{
  display:none;
}

.about-page .about-panel.is-active{
  display:block;
}

.about-page .about-layout{
  display:grid;
  grid-template-columns:minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap:24px;
  align-items:stretch;
}

.about-page .about-layout-single{
  grid-template-columns:1fr;
}

.about-page .about-layout-contact{
  grid-template-columns:minmax(0, 1fr) minmax(320px, 420px);
}

.about-page .about-copy{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
  padding:32px;
}

.about-page .about-copy-wide{
  max-width:none;
}

.about-page .about-copy .h3{
  margin-bottom:14px;
}

.about-page .about-copy .p2 + .p2{
  margin-top:14px;
}

.about-page .about-list{
  margin:18px 0 18px 0;
  padding-left:20px;
  display:grid;
  gap:12px;
  color:var(--bh-text-secondary);
}

.about-page .about-list li{
  padding-left:4px;
  line-height:1.75;
}

.about-page .about-link{
  color:var(--bh-primary);
  font-weight:700;
}

.about-page .about-illustration{
  display:flex;
}

.about-page .about-illustration-card{
  position:relative;
  overflow:hidden;
  width:100%;
  min-height:100%;
  border-radius:32px;
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.18), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(255,255,255,0.16), transparent 22%),
    linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  border:1px solid rgba(143,147,255,0.20);
  box-shadow:var(--bh-shadow-strong);
  color:#ffffff;
}

.about-page .about-illustration-card-secondary{
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.18), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(255,255,255,0.16), transparent 22%),
    linear-gradient(135deg, #7f86ff, #964ff7);
}

.about-page .about-illustration-card-founder{
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.18), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(255,255,255,0.16), transparent 22%),
    linear-gradient(135deg, #004d43, #2d8f7f);
}

.about-page .about-illustration-card::before{
  content:"";
  position:absolute;
  width:240px;
  height:240px;
  right:-60px;
  top:-60px;
  border-radius:50%;
  background:rgba(255,255,255,0.10);
}

.about-page .about-illustration-card::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  left:-50px;
  bottom:-50px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
}

.about-page .about-illustration-kicker{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-self:flex-start;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.16);
  color:#ffffff;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:18px;
  align-items:center;
}

.about-page .about-illustration-title{
  position:relative;
  z-index:1;
  margin:0 0 14px;
  font-size:clamp(28px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:#ffffff;
  max-width:420px;
}

.about-page .about-illustration-copy{
  position:relative;
  z-index:1;
  max-width:420px;
  color:rgba(255,255,255,0.92);
}

/* --------------------------
   Accessibility feature cards
   -------------------------- */

.about-page .about-feature-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  margin:26px 0;
}

.about-page .about-feature-card{
  background:#F8FAFC;
  border:1px solid var(--bh-border-soft);
  border-radius:22px;
  padding:22px;
  box-shadow:none;
}

.about-page .about-feature-title{
  margin:0 0 10px;
  font-size:1.02rem;
  line-height:1.25;
  font-weight:800;
  color:var(--bh-text);
}

/* --------------------------
   Contact card
   -------------------------- */

.about-page .about-contact-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.about-page .about-contact-kicker{
  display:inline-flex;
  align-self:flex-start;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  align-items:center;
  margin-bottom:18px;
}

.about-page .about-contact-title{
  margin:0 0 14px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
  word-break:break-word;
}

.about-page .about-contact-card .p2 + .p2{
  margin-top:12px;
}

.about-page .about-contact-btn{
  margin-top:22px;
  width:100%;
}

/* --------------------------
   Cookie banner
   -------------------------- */

.about-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.about-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.about-page .cookie-banner-text{
  max-width:760px;
}

.about-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.about-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.about-page .cookie-btn{
  min-width:150px;
}

/* --------------------------
   Responsive
   -------------------------- */

@media (max-width: 1120px){
  .about-page .about-layout,
  .about-page .about-layout-contact{
    grid-template-columns:1fr;
  }

  .about-page .about-feature-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 860px){
  .about-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .about-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .about-page .about-hero{
    padding-top:36px;
  }

  .about-page .about-copy,
  .about-page .about-contact-card{
    padding:26px;
  }

  .about-page .about-illustration-card{
    min-height:320px;
  }

  .about-page .about-feature-grid{
    grid-template-columns:1fr;
  }

  .about-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .about-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .about-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .about-page .container{
    width:min(100% - 24px, 1180px);
  }

  .about-page .section{
    padding:72px 0;
  }

  .about-page .about-panels{
    padding:28px 0 72px;
  }

  .about-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .about-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .about-page .about-tabs-wrap{
    margin-top:38px;
  }

  .about-page .about-copy,
  .about-page .about-contact-card{
    border-radius:24px;
    padding:22px;
  }

  .about-page .about-illustration-card{
    min-height:280px;
    border-radius:24px;
    padding:22px;
  }

  .about-page .about-contact-title{
    font-size:1.45rem;
  }

  .about-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .about-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER GET STARTED PAGE
   Add below about page styles
   ========================================== */

body.get-started-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.get-started-page .auth-grid.auth-grid-single{
  width:100%;
  max-width:700px;
  margin:48px auto 0;
  display:grid;
  grid-template-columns:1fr;
  justify-items:center;
}

.get-started-page .auth-grid.auth-grid-single .auth-card-signup{
  width:100%;
  max-width:760px;
}

.get-started-page *{
  box-sizing:border-box;
}

.get-started-page a{
  text-decoration:none;
}

.get-started-page button,
.get-started-page input{
  font:inherit;
}

.get-started-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.get-started-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.get-started-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-page .h3{
  margin:0;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* --------------------------
   Header
   -------------------------- */

.get-started-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.get-started-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.get-started-page .nav-simple{
  grid-template-columns:auto;
  justify-content:center;
}

.get-started-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.get-started-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

/* --------------------------
   Buttons
   -------------------------- */

.get-started-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.get-started-page .btn:hover{
  transform:translateY(-1px);
}

.get-started-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.get-started-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

/* --------------------------
   Hero / shell
   -------------------------- */

.get-started-page .auth-hero{
  padding:52px 0 96px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.get-started-page .auth-shell{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.get-started-page .auth-header{
  max-width:760px;
  text-align:center;
}

.get-started-page .auth-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin:0;
}

.get-started-page .auth-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.get-started-page .auth-sub{
  max-width:720px;
  margin:18px auto 0;
}

.get-started-page .auth-sub-detail{
  max-width:660px;
  margin:14px auto 0;
  font-size:0.96rem;
}

/* --------------------------
   Grid
   -------------------------- */

.get-started-page .auth-grid{
  width:100%;
  max-width:1040px;
  margin-top:48px;
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap:24px;
  align-items:start;
}

/* --------------------------
   Cards
   -------------------------- */

.get-started-page .auth-card,
.get-started-page .auth-side-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
}

.get-started-page .auth-card-signup{
  padding:32px;
}

.get-started-page .auth-card-header{
  margin-bottom:22px;
}

.get-started-page .auth-card-sub{
  margin-top:10px;
}

.get-started-page .auth-link-inline{
  color:var(--bh-primary);
  font-weight:700;
}

/* --------------------------
   Form
   -------------------------- */

.get-started-page .auth-form{
  display:grid;
  gap:12px;
}

.get-started-page .auth-label{
  font-weight:700;
  color:var(--bh-text);
  margin-top:4px;
}

.get-started-page .field{
  width:100%;
  min-height:54px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  color:var(--bh-text);
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.get-started-page .field::placeholder{
  color:#9CA3AF;
}

.get-started-page .field:focus{
  border-color:rgba(143,147,255,0.44);
  box-shadow:0 0 0 4px rgba(143,147,255,0.10);
}

.get-started-page .auth-password-note{
  margin-top:-2px;
  font-size:0.92rem;
}

.get-started-page .auth-checkbox{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-top:4px;
}

.get-started-page .auth-checkbox input{
  width:18px;
  height:18px;
  margin-top:4px;
  accent-color:var(--bh-primary);
}

.get-started-page .auth-checkbox span{
  color:var(--bh-text-secondary);
  line-height:1.7;
}

.get-started-page .auth-checkbox a{
  color:var(--bh-primary);
  font-weight:700;
}

.get-started-page .auth-primary-cta{
  width:100%;
  margin-top:8px;
  min-height:56px;
  font-size:1rem;
}

/* --------------------------
   Side info card
   -------------------------- */

.get-started-page .auth-side-card{
  padding:32px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(143,147,255,0.12), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(161,242,199,0.16), transparent 22%),
    #ffffff;
}

.get-started-page .auth-side-kicker{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.get-started-page .auth-side-title{
  margin:0 0 20px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.1;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-page .auth-side-points{
  display:grid;
  gap:16px;
}

.get-started-page .auth-side-point{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:12px;
  align-items:start;
}

.get-started-page .auth-side-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--bh-primary);
  margin-top:10px;
}

.get-started-page .auth-side-note{
  margin-top:24px;
  padding:18px;
  border-radius:20px;
  background:#F8FAFC;
  border:1px solid var(--bh-border-soft);
}

/* --------------------------
   Cookie banner
   -------------------------- */

.get-started-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.get-started-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.get-started-page .cookie-banner-text{
  max-width:760px;
}

.get-started-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.get-started-page .cookie-btn{
  min-width:150px;
}

/* --------------------------
   Responsive
   -------------------------- */

@media (max-width: 1120px){
  .get-started-page .auth-grid{
    grid-template-columns:1fr;
    max-width:760px;
  }
}

@media (max-width: 860px){
  .get-started-page .auth-hero{
    padding:40px 0 80px;
  }

  .get-started-page .auth-card-signup,
  .get-started-page .auth-side-card{
    padding:26px;
  }

  .get-started-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .get-started-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .get-started-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .get-started-page .container{
    width:min(100% - 24px, 1180px);
  }

  .get-started-page .auth-title{
    font-size:clamp(32px, 10vw, 44px);
  }

  .get-started-page .auth-card-signup,
  .get-started-page .auth-side-card{
    padding:22px;
    border-radius:24px;
  }

  .get-started-page .field{
    min-height:52px;
    border-radius:14px;
  }

  .get-started-page .auth-primary-cta{
    min-height:54px;
  }

  .get-started-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .get-started-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

.site-footer{
  background:#004d43;
  color:#ffffff;
  padding:72px 0 24px;
}

.site-footer-container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.site-footer-grid{
  display:grid;
  grid-template-columns:1.2fr repeat(3, 0.8fr);
  gap:28px;
  align-items:start;
}

.site-footer-logo{
  font-size:2rem;
  font-weight:900;
  letter-spacing:0.08em;
  margin-bottom:14px;
}

.site-footer-brand p{
  max-width:320px;
  color:rgba(255,255,255,0.74);
  line-height:1.7;
  margin:0;
}

.site-footer-title{
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.52);
  margin-bottom:14px;
}

.site-footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.site-footer-col a{
  color:#ffffff;
  opacity:0.9;
  font-weight:500;
  text-decoration:none;
}

.site-footer-bottom{
  margin-top:36px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.14);
}

.site-footer-bottom p{
  margin:0;
  color:rgba(255,255,255,0.62);
  font-size:0.92rem;
}

/* ==========================================
   BADGER FAQS PAGE
   Lighter, closer to home page
   ========================================== */

body.faqs-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.faqs-page *{
  box-sizing:border-box;
}

.faqs-page a{
  text-decoration:none;
}

.faqs-page button{
  font:inherit;
}

.faqs-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.faqs-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.faqs-page .section{
  padding:88px 0;
}

.faqs-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.faqs-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.faqs-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.faqs-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.faqs-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.faqs-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.faqs-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.faqs-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.faqs-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.faqs-page .btn:hover{
  transform:translateY(-1px);
}

.faqs-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.faqs-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.faqs-page .cta-nav{
  min-width:160px;
}

/* Hero */

.faqs-page .faq-hero{
  padding:46px 0 0;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.faqs-page .faq-header{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.faqs-page .faq-header-center{
  justify-content:center;
  text-align:center;
  flex-direction:column;
}

.faqs-page .faq-main-title{
  max-width:900px;
  color:var(--bh-secondary-dark);  
}

.faqs-page .faq-intro{
  max-width:760px;
  margin:18px auto 0;
}

/* FAQ body */

.faqs-page .faq-panels{
  padding:48px 0 96px;
}

.faqs-page .faq-narrow{
  max-width:860px;
}

.faqs-page .faq-list{
  display:grid;
  gap:14px;
}

.faqs-page .faq-item{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:24px;
  box-shadow:var(--bh-shadow-soft);
  overflow:hidden;
}

.faqs-page .faq-question{
  list-style:none;
  cursor:pointer;
  position:relative;
  padding:24px 68px 24px 24px;
  font-size:1.06rem;
  line-height:1.45;
  font-weight:800;
  color:var(--bh-text);
}

.faqs-page .faq-question::-webkit-details-marker{
  display:none;
}

.faqs-page .faq-question::after{
  content:"+";
  position:absolute;
  right:24px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:1.2rem;
  font-weight:700;
}

.faqs-page .faq-item[open] .faq-question::after{
  content:"–";
}

.faqs-page .faq-answer{
  padding:0 24px 24px;
}

.faqs-page .faq-answer .p2{
  max-width:900px;
}

.faqs-page .faq-link{
  color:var(--bh-primary);
  font-weight:700;
}

/* Contact section — simplified */

.faqs-page .faq-contact-simple{
  margin-top:42px;
  text-align:center;
}

.faqs-page .faq-contact-title{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.faqs-page .faq-contact-text{
  max-width:620px;
  margin:16px auto 0;
}

.faqs-page .faq-contact-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px;
}

/* Cookie banner */

.faqs-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.faqs-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.faqs-page .cookie-banner-text{
  max-width:760px;
}

.faqs-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.faqs-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.faqs-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 860px){
  .faqs-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .faqs-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .faqs-page .faq-hero{
    padding-top:36px;
  }

  .faqs-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .faqs-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .faqs-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .faqs-page .container{
    width:min(100% - 24px, 1180px);
  }

  .faqs-page .section{
    padding:72px 0;
  }

  .faqs-page .faq-panels{
    padding:28px 0 72px;
  }

  .faqs-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .faqs-page .faq-item{
    border-radius:24px;
  }

  .faqs-page .faq-question{
    padding:20px 60px 20px 20px;
    font-size:1rem;
  }

  .faqs-page .faq-answer{
    padding:0 20px 20px;
  }

  .faqs-page .faq-contact-actions{
    width:100%;
    flex-direction:column;
    align-items:stretch;
  }

  .faqs-page .faq-contact-actions .btn{
    width:100%;
  }

  .faqs-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .faqs-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER CRISIS PAGE
   ========================================== */

body.crisis-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.crisis-page *{
  box-sizing:border-box;
}

.crisis-page a{
  text-decoration:none;
}

.crisis-page button,
.crisis-page select{
  font:inherit;
}

.crisis-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.crisis-page .container,
.crisis-page .bh-container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.crisis-page .section{
  padding:88px 0;
}

.crisis-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.crisis-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.crisis-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.crisis-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.crisis-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.crisis-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.crisis-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.crisis-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.crisis-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.crisis-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.crisis-page .btn:hover{
  transform:translateY(-1px);
}

.crisis-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.crisis-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.crisis-page .cta-nav{
  min-width:160px;
}

/* Hero */

.crisis-page .crisis-hero{
  padding:92px 0 88px;
  text-align:center;
  background:
    radial-gradient(circle at 22% 20%, rgba(255,255,255,0.16), transparent 24%),
    radial-gradient(circle at 78% 26%, rgba(255,255,255,0.12), transparent 22%),
    linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
}

.crisis-page .crisis-header{
  display:flex;
  align-items:center;
  justify-content:center;
}

.crisis-page .crisis-header-center{
  text-align:center;
  flex-direction:column;
}

.crisis-page .crisis-hero-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 18px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  color:#ffffff;
  border:1px solid rgba(255,255,255,0.18);
  font-size:0.8rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.crisis-page .crisis-main-title{
  max-width:980px;
  margin:22px auto 0;
  color:#ffffff;
  font-size:clamp(38px, 5.2vw, 72px);
}

.crisis-page .crisis-intro{
  max-width:860px;
  margin:22px auto 0;
  color:rgba(255,255,255,0.94);
  font-size:1.05rem;
  line-height:1.8;
}

/* Country picker */

.crisis-page .crisis-country-picker{
  padding:42px 0 24px;
}

.crisis-page .crisis-picker-wrap{
  max-width:760px;
  margin:0 auto;
}

.crisis-page .crisis-picker-label{
  display:block;
  margin-bottom:12px;
  color:var(--bh-text);
  font-size:1rem;
  font-weight:700;
}

.crisis-page .crisis-country-select{
  display:block;
  width:100%;
  min-height:64px;
  padding:0 20px;
  border-radius:22px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  color:var(--bh-text);
  font-size:1.02rem;
  font-weight:700;
  box-shadow:var(--bh-shadow-soft);
  appearance:auto;
  outline:none;
}

.crisis-page .crisis-country-select:focus{
  border-color:rgba(143,147,255,0.45);
  box-shadow:0 0 0 4px rgba(143,147,255,0.10);
}

/* Country result */

.crisis-page .crisis-country-result{
  padding:12px 0 56px;
}

.crisis-page .crisis-country-card{
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
}

.crisis-page .crisis-country-region{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:20px;
}

.crisis-page .crisis-country-title{
  margin:0 0 26px;
  font-size:clamp(34px, 4vw, 56px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
  display:flex;
  align-items:baseline;
  gap:14px;
  flex-wrap:wrap;
}

.crisis-page .crisis-country-code{
  font-size:0.58em;
  font-weight:800;
  letter-spacing:-0.02em;
  opacity:0.98;
}

.crisis-page .crisis-country-name{
  font-size:1em;
}

.crisis-page .crisis-country-block{
  margin-top:18px;
  padding:24px 26px;
  border-radius:28px;
  background:#f8f9fc;
  border:1px solid var(--bh-border-soft);
}

.crisis-page .crisis-country-block-label{
  margin-bottom:12px;
  color:var(--bh-secondary-dark);
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.crisis-page .crisis-country-block-value{
  font-size:1.18rem;
  font-weight:800;
  color:var(--bh-text);
}

.crisis-page .crisis-country-lines{
  display:grid;
  gap:14px;
}

.crisis-page .crisis-line-item{
  padding:18px 20px;
  border-radius:20px;
  background:#ffffff;
  border:1px solid var(--bh-border);
}

.crisis-page .crisis-line-name{
  font-size:1rem;
  font-weight:800;
  color:var(--bh-text);
}

.crisis-page .crisis-line-number{
  margin-top:6px;
  font-size:1.02rem;
  font-weight:700;
  color:var(--bh-primary);
  word-break:break-word;
}

.crisis-page .crisis-line-desc{
  margin-top:6px;
  font-size:0.94rem;
  line-height:1.6;
  color:var(--bh-text-secondary);
}

.crisis-page .crisis-line-empty{
  font-size:0.96rem;
  line-height:1.7;
  color:var(--bh-text-secondary);
}

/* Support directory */

.crisis-page .crisis-support-directory{
  padding:12px 0 96px;
}

.crisis-page .crisis-support-directory-inner{
  max-width:760px;
  margin:0 auto;
  text-align:center;
}

.crisis-page .crisis-support-directory-title{
  margin:0;
}

.crisis-page .crisis-support-directory-copy{
  margin:16px auto 0;
  max-width:620px;
}

.crisis-page .crisis-support-links{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:28px;
}

.crisis-page .crisis-support-link{
  display:block;
  padding:22px 24px;
  border-radius:24px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  box-shadow:var(--bh-shadow-soft);
  text-align:left;
  color:var(--bh-text);
  font-size:1rem;
  font-weight:800;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.crisis-page .crisis-support-link:hover{
  transform:translateY(-2px);
  border-color:rgba(143,147,255,0.28);
  box-shadow:0 24px 48px rgba(17,24,39,0.10);
}

/* Footer */

.crisis-page .bh-footer{
  background:#004d43;
  color:#ffffff;
  padding:72px 0 24px;
}

.crisis-page .bh-footer-grid{
  display:grid;
  grid-template-columns:1.2fr repeat(3, 0.8fr);
  gap:28px;
  align-items:start;
}

.crisis-page .bh-footer-logo{
  font-size:2rem;
  font-weight:900;
  letter-spacing:0.08em;
  margin-bottom:14px;
}

.crisis-page .bh-footer-brand p{
  max-width:320px;
  color:rgba(255,255,255,0.74);
  line-height:1.7;
  margin:0;
}

.crisis-page .bh-footer-title{
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.52);
  margin-bottom:14px;
}

.crisis-page .bh-footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.crisis-page .bh-footer-col a{
  color:#ffffff;
  opacity:0.9;
  font-weight:500;
}

.crisis-page .bh-footer-bottom{
  margin-top:36px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.14);
}

.crisis-page .bh-footer-bottom p{
  margin:0;
  color:rgba(255,255,255,0.62);
  font-size:0.92rem;
}

/* Cookie banner */

.crisis-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.crisis-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.crisis-page .cookie-banner-text{
  max-width:760px;
}

.crisis-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.crisis-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.crisis-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .crisis-page .bh-footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 860px){
  .crisis-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .crisis-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .crisis-page .crisis-hero{
    padding:72px 0 68px;
  }

  .crisis-page .crisis-country-card{
    padding:0;
  }

  .crisis-page .bh-footer-grid{
    grid-template-columns:1fr;
  }

  .crisis-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .crisis-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .crisis-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .crisis-page .container,
  .crisis-page .bh-container{
    width:min(100% - 24px, 1180px);
  }

  .crisis-page .section{
    padding:72px 0;
  }

  .crisis-page .crisis-hero{
    padding:56px 0 54px;
  }

  .crisis-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .crisis-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .crisis-page .crisis-main-title{
    font-size:clamp(32px, 10vw, 46px);
  }

  .crisis-page .crisis-intro{
    font-size:0.98rem;
    line-height:1.75;
  }

  .crisis-page .crisis-country-select{
    min-height:58px;
    border-radius:18px;
    font-size:0.98rem;
  }

  .crisis-page .crisis-country-block{
    padding:18px;
    border-radius:20px;
  }

  .crisis-page .crisis-country-title{
    font-size:clamp(30px, 9vw, 42px);
  }

  .crisis-page .crisis-line-item{
    padding:16px;
    border-radius:18px;
  }

  .crisis-page .crisis-support-link{
    padding:18px;
    border-radius:20px;
  }

  .crisis-page .bh-footer{
    padding:64px 0 22px;
  }

  .crisis-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .crisis-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER PRIVACY PAGE
   ========================================== */

body.privacy-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.privacy-page *{
  box-sizing:border-box;
}

.privacy-page a{
  text-decoration:none;
}

.privacy-page button{
  font:inherit;
}

.privacy-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.privacy-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.privacy-page .section{
  padding:88px 0;
}

.privacy-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.privacy-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.privacy-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.privacy-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.privacy-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.privacy-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.privacy-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.privacy-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.privacy-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.privacy-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.privacy-page .btn:hover{
  transform:translateY(-1px);
}

.privacy-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.privacy-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.privacy-page .cta-nav{
  min-width:160px;
}

/* Hero */

.privacy-page .privacy-hero{
  padding:52px 0 18px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.privacy-page .privacy-hero-inner{
  max-width:860px;
  margin:0 auto;
}

.privacy-page .privacy-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.privacy-page .privacy-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.privacy-page .privacy-updated{
  margin:18px 0 0;
  font-size:1rem;
  line-height:1.6;
  font-style:italic;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.privacy-page .privacy-intro{
  margin-top:22px;
  max-width:860px;
}

.privacy-page .privacy-intro-secondary{
  margin-top:12px;
}

/* Body */

.privacy-page .privacy-body{
  padding:14px 0 96px;
}

.privacy-page .privacy-article{
  max-width:860px;
  margin:0 auto;
}

.privacy-page .privacy-at-a-glance{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-bottom:40px;
}

.privacy-page .privacy-glance-card{
  padding:22px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.privacy-page .privacy-glance-label{
  margin-bottom:10px;
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.privacy-page .privacy-section{
  padding:32px 0;
}

.privacy-page .privacy-section + .privacy-section{
  border-top:1px solid var(--bh-border);
}

.privacy-page .privacy-section-title{
  margin-bottom:14px;
  font-size:clamp(24px, 2.6vw, 32px);
}

.privacy-page .privacy-section .p2 + .p2{
  margin-top:14px;
}

.privacy-page .privacy-list{
  margin:16px 0 0;
  padding-left:22px;
  display:grid;
  gap:12px;
  color:var(--bh-text-secondary);
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
}

.privacy-page .privacy-list li{
  padding-left:4px;
}

.privacy-page .privacy-link{
  color:var(--bh-primary);
  font-weight:700;
}

.privacy-page .privacy-note{
  margin:18px 0;
  padding:18px 20px;
  border-radius:20px;
  background:rgba(143,147,255,0.08);
  border:1px solid rgba(143,147,255,0.16);
}

.privacy-page .privacy-section-contact{
  padding-bottom:0;
}

.privacy-page .privacy-contact-card{
  margin-top:18px;
  padding:22px 24px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.privacy-page .privacy-contact-label{
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.privacy-page .privacy-contact-link{
  display:inline-block;
  color:var(--bh-primary);
  font-size:1.08rem;
  font-weight:800;
  word-break:break-word;
}

/* Cookie banner */

.privacy-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.privacy-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.privacy-page .cookie-banner-text{
  max-width:760px;
}

.privacy-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.privacy-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.privacy-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .privacy-page .privacy-at-a-glance{
    grid-template-columns:1fr;
  }
}

@media (max-width: 860px){
  .privacy-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .privacy-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .privacy-page .privacy-hero{
    padding:42px 0 12px;
  }

  .privacy-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .privacy-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .privacy-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .privacy-page .container{
    width:min(100% - 24px, 1180px);
  }

  .privacy-page .section{
    padding:72px 0;
  }

  .privacy-page .privacy-body{
    padding:6px 0 72px;
  }

  .privacy-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .privacy-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .privacy-page .privacy-glance-card,
  .privacy-page .privacy-contact-card{
    padding:18px;
    border-radius:20px;
  }

  .privacy-page .privacy-section{
    padding:26px 0;
  }

  .privacy-page .privacy-list{
    padding-left:20px;
  }

  .privacy-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .privacy-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER TERMS PAGE
   ========================================== */

body.terms-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.terms-page *{
  box-sizing:border-box;
}

.terms-page a{
  text-decoration:none;
}

.terms-page button{
  font:inherit;
}

.terms-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.terms-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.terms-page .section{
  padding:88px 0;
}

.terms-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.terms-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.terms-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.terms-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.terms-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.terms-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.terms-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.terms-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.terms-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.terms-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.terms-page .btn:hover{
  transform:translateY(-1px);
}

.terms-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.terms-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.terms-page .cta-nav{
  min-width:160px;
}

/* Hero */

.terms-page .terms-hero{
  padding:52px 0 18px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.terms-page .terms-hero-inner{
  max-width:860px;
  margin:0 auto;
}

.terms-page .terms-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.terms-page .terms-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.terms-page .terms-updated{
  margin:18px 0 0;
  font-size:1rem;
  line-height:1.6;
  font-style:italic;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.terms-page .terms-intro{
  margin-top:22px;
  max-width:860px;
}

/* Body */

.terms-page .terms-body{
  padding:14px 0 96px;
}

.terms-page .terms-article{
  max-width:860px;
  margin:0 auto;
}

.terms-page .terms-at-a-glance{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-bottom:40px;
}

.terms-page .terms-glance-card{
  padding:22px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.terms-page .terms-glance-label{
  margin-bottom:10px;
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.terms-page .terms-section{
  padding:32px 0;
}

.terms-page .terms-section + .terms-section{
  border-top:1px solid var(--bh-border);
}

.terms-page .terms-section-title{
  margin-bottom:14px;
  font-size:clamp(24px, 2.6vw, 32px);
}

.terms-page .terms-section .p2 + .p2{
  margin-top:14px;
}

.terms-page .terms-list{
  margin:16px 0 0;
  padding-left:22px;
  display:grid;
  gap:12px;
  color:var(--bh-text-secondary);
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
}

.terms-page .terms-list li{
  padding-left:4px;
}

.terms-page .terms-link{
  color:var(--bh-primary);
  font-weight:700;
}

.terms-page .terms-note{
  margin:18px 0;
  padding:18px 20px;
  border-radius:20px;
  background:rgba(143,147,255,0.08);
  border:1px solid rgba(143,147,255,0.16);
}

.terms-page .terms-section-contact{
  padding-bottom:0;
}

.terms-page .terms-contact-card{
  margin-top:18px;
  padding:22px 24px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.terms-page .terms-contact-label{
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.terms-page .terms-contact-link{
  display:inline-block;
  color:var(--bh-primary);
  font-size:1.08rem;
  font-weight:800;
  word-break:break-word;
}

/* Cookie banner */

.terms-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.terms-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.terms-page .cookie-banner-text{
  max-width:760px;
}

.terms-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.terms-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.terms-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .terms-page .terms-at-a-glance{
    grid-template-columns:1fr;
  }
}

@media (max-width: 860px){
  .terms-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .terms-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .terms-page .terms-hero{
    padding:42px 0 12px;
  }

  .terms-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .terms-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .terms-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .terms-page .container{
    width:min(100% - 24px, 1180px);
  }

  .terms-page .section{
    padding:72px 0;
  }

  .terms-page .terms-body{
    padding:6px 0 72px;
  }

  .terms-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .terms-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .terms-page .terms-glance-card,
  .terms-page .terms-contact-card{
    padding:18px;
    border-radius:20px;
  }

  .terms-page .terms-section{
    padding:26px 0;
  }

  .terms-page .terms-list{
    padding-left:20px;
  }

  .terms-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .terms-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER COMMUNITY PAGE
   ========================================== */

body.community-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.community-page *{
  box-sizing:border-box;
}

.community-page a{
  text-decoration:none;
}

.community-page button{
  font:inherit;
}

.community-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.community-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.community-page .section{
  padding:88px 0;
}

.community-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.community-page .h3{
  margin:0;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.community-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.community-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.community-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.community-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.community-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.community-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.community-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.community-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.community-page .btn:hover{
  transform:translateY(-1px);
}

.community-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.community-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.community-page .cta-nav{
  min-width:160px;
}

/* Hero */

.community-page .community-hero{
  padding:52px 0 18px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.community-page .community-hero-inner{
  max-width:860px;
  margin:0 auto;
}

.community-page .community-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.community-page .community-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.community-page .community-updated{
  margin:18px 0 0;
  font-size:1rem;
  line-height:1.6;
  font-style:italic;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.community-page .community-intro{
  margin-top:22px;
  max-width:860px;
}

/* Body */

.community-page .community-body{
  padding:14px 0 96px;
}

.community-page .community-article{
  max-width:860px;
  margin:0 auto;
}

.community-page .community-at-a-glance{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-bottom:40px;
}

.community-page .community-glance-card{
  padding:22px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.community-page .community-glance-label{
  margin-bottom:10px;
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.community-page .community-section{
  padding:32px 0;
}

.community-page .community-section + .community-section{
  border-top:1px solid var(--bh-border);
}

.community-page .community-section-title{
  margin-bottom:14px;
  font-size:clamp(24px, 2.6vw, 32px);
}

.community-page .community-section .p2 + .p2{
  margin-top:14px;
}

.community-page .community-list{
  margin:16px 0 0;
  padding-left:22px;
  display:grid;
  gap:12px;
  color:var(--bh-text-secondary);
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
}

.community-page .community-list li{
  padding-left:4px;
}

.community-page .community-note{
  margin:18px 0 0;
  padding:18px 20px;
  border-radius:20px;
  background:rgba(143,147,255,0.08);
  border:1px solid rgba(143,147,255,0.16);
}

.community-page .community-contact-card{
  margin-top:18px;
  padding:22px 24px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.community-page .community-contact-label{
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.community-page .community-contact-link{
  display:inline-block;
  color:var(--bh-primary);
  font-size:1.08rem;
  font-weight:800;
  word-break:break-word;
}

.community-page .community-section-last{
  padding-bottom:0;
}

/* Cookie banner */

.community-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.community-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.community-page .cookie-banner-text{
  max-width:760px;
}

.community-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.community-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.community-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .community-page .community-at-a-glance{
    grid-template-columns:1fr;
  }
}

@media (max-width: 860px){
  .community-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .community-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .community-page .community-hero{
    padding:42px 0 12px;
  }

  .community-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .community-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .community-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .community-page .container{
    width:min(100% - 24px, 1180px);
  }

  .community-page .section{
    padding:72px 0;
  }

  .community-page .community-body{
    padding:6px 0 72px;
  }

  .community-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .community-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .community-page .community-glance-card,
  .community-page .community-contact-card{
    padding:18px;
    border-radius:20px;
  }

  .community-page .community-section{
    padding:26px 0;
  }

  .community-page .community-list{
    padding-left:20px;
  }

  .community-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .community-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER BUSINESS PAGE
   ========================================== */

body.business-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.business-page *{
  box-sizing:border-box;
}

.business-page a{
  text-decoration:none;
}

.business-page button{
  font:inherit;
}

.business-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.business-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.business-page .section{
  padding:96px 0;
}

.business-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.business-page .h3{
  margin:0;
  font-size:clamp(24px, 2.8vw, 34px);
  line-height:1.12;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.business-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.8;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.business-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.business-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.business-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.business-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.business-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.business-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.business-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.business-page .btn:hover{
  transform:translateY(-1px);
}

.business-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.business-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.business-page .btn-light{
  background:#ffffff;
  color:var(--bh-secondary-dark);
  border-color:#ffffff;
}

.business-page .cta-nav{
  min-width:160px;
}

/* Shared section heading */

.business-page .biz-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.business-page .biz-section-head{
  max-width:760px;
  margin-bottom:30px;
}

.business-page .biz-section-head .h2{
  margin-top:18px;
}

.business-page .biz-section-head .p2{
  margin-top:16px;
}

.business-page .biz-section-head-center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

/* Hero */

.business-page .biz-hero{
  padding:56px 0 84px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.business-page .biz-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap:28px;
  align-items:center;
}

.business-page .biz-hero-title{
  margin-top:18px;
  font-size:clamp(38px, 5.4vw, 68px);
  line-height:1.01;
  letter-spacing:-0.05em;
  max-width:760px;
  color:var(--bh-secondary-dark);
}

.business-page .biz-hero-sub{
  margin-top:18px;
  max-width:760px;
}

.business-page .biz-hero-actions{
  margin-top:32px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.business-page .biz-client-login-row{
  margin-top:28px;
}

.business-page .biz-client-login-link{
  color:var(--bh-secondary-dark);
  font-size:0.94rem;
  font-weight:700;
}

.business-page .biz-hero-stage{
  min-height:560px;
  border-radius:36px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
  overflow:hidden;
}

.business-page .biz-hero-image-placeholder{
  width:100%;
  height:100%;
  min-height:560px;
  background:
    linear-gradient(180deg, #f8f9fc 0%, #eef2f7 100%);
}

/* Benefits */

.business-page .biz-benefit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}

.business-page .biz-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:24px;
  box-shadow:var(--bh-shadow-soft);
}

.business-page .biz-benefit-card{
  padding:30px;
  min-height:310px;
}

.business-page .biz-card-icon{
  width:320px;
  height:320px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:1.05rem;
  font-weight:800;
  margin-bottom:18px;
}

.business-page .biz-benefit-card h3{
  margin:0 0 14px;
  font-size:1.12rem;
  line-height:1.28;
  color:var(--bh-text);
}

.business-page .biz-benefit-card p{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.75;
}

/* How it works */

.business-page .biz-how{
  background:#fcfcff;
}

.business-page .biz-how-grid{
  display:grid;
  grid-template-columns:minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap:26px;
  align-items:start;
}

.business-page .biz-how-copy .h2{
  margin-top:18px;
}

.business-page .biz-how-copy .p2{
  margin-top:16px;
}

.business-page .biz-steps{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:16px;
}

.business-page .biz-step{
  display:grid;
  grid-template-columns:60px 1fr;
  gap:16px;
  padding:22px;
  border-radius:24px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.business-page .biz-step-number{
  width:60px;
  height:60px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:rgba(143,147,255,0.14);
  color:var(--bh-secondary-dark);
  font-size:1.08rem;
  font-weight:800;
}

.business-page .biz-step-title{
  margin-bottom:10px;
  font-size:1.08rem;
}

/* Demo CTA */

.business-page .biz-demo{
  padding-top:84px;
}

.business-page .biz-demo-card{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding:180px 0;
  border-radius:0;
  display:block;
  background:
    radial-gradient(circle at 22% 20%, rgba(255,255,255,0.16), transparent 24%),
    radial-gradient(circle at 78% 26%, rgba(255,255,255,0.12), transparent 22%),
    linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  box-shadow:none;
}

@media (max-width: 860px){
  .business-page .biz-demo-card{
    padding:90px 0;
  }
}

@media (max-width: 640px){
  .business-page .biz-demo-card{
    padding:72px 0;
  }
}

.business-page .biz-demo-inner{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
  padding:0 40px;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:20px;
}

.business-page .biz-demo-copy{
  max-width:860px;
}

.business-page .biz-demo-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  color:#ffffff;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.business-page .biz-demo-title{
  margin-top:18px;
  color:#ffffff;
  max-width:900px;
}

.business-page .biz-demo-sub{
  margin-top:14px;
  max-width:760px;
  color:rgba(255,255,255,0.92);
}

.business-page .biz-demo-pills{
  margin-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.business-page .biz-demo-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.20);
  color:#ffffff;
  font-size:0.84rem;
  font-weight:700;
  backdrop-filter:blur(8px);
}

.business-page .biz-demo-actions{
  flex:0 0 auto;
  padding-top:76px;
}

/* FAQ */

.business-page .biz-faq{
  padding-top:48px;
}

.business-page .biz-faq-list{
  max-width:860px;
  margin:0 auto;
  display:grid;
  gap:14px;
}

.business-page .biz-faq-item{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:24px;
  box-shadow:var(--bh-shadow-soft);
  overflow:hidden;
}

.business-page .biz-faq-question{
  list-style:none;
  cursor:pointer;
  position:relative;
  padding:24px 68px 24px 24px;
  font-size:1.02rem;
  line-height:1.45;
  font-weight:800;
  color:var(--bh-text);
}

.business-page .biz-faq-question::-webkit-details-marker{
  display:none;
}

.business-page .biz-faq-question::after{
  content:"+";
  position:absolute;
  right:24px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:1.2rem;
  font-weight:700;
}

.business-page .biz-faq-item[open] .biz-faq-question::after{
  content:"–";
}

.business-page .biz-faq-answer{
  padding:0 24px 24px;
}

.business-page .biz-faq-answer p{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.75;
}

/* Cookie banner */

.business-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.business-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.business-page .cookie-banner-text{
  max-width:760px;
}

.business-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.business-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.business-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .business-page .biz-benefit-grid,
  .business-page .biz-how-grid,
  .business-page .biz-hero-grid{
    grid-template-columns:1fr;
  }

  .business-page .biz-hero-stage{
    min-height:420px;
  }

  .business-page .biz-hero-image-placeholder{
    min-height:420px;
  }
}

@media (max-width: 860px){
  .business-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .business-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .business-page .biz-hero{
    padding:40px 0 72px;
  }

  .business-page .biz-demo-card{
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding:110px 0;
    border-radius:0;
    display:block;
    background:
      radial-gradient(circle at 22% 20%, rgba(255,255,255,0.16), transparent 24%),
      radial-gradient(circle at 78% 26%, rgba(255,255,255,0.12), transparent 22%),
      linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
    box-shadow:none;
  }

  .business-page .biz-demo-actions{
    padding-top:0;
  }

  .business-page .biz-benefit-grid{
    grid-template-columns:1fr;
  }

  .business-page .biz-step{
    grid-template-columns:52px 1fr;
  }

  .business-page .biz-step-number{
    width:52px;
    height:52px;
    border-radius:18px;
  }

  .business-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .business-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .business-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .business-page .container{
    width:min(100% - 24px, 1180px);
  }

  .business-page .section{
    padding:72px 0;
  }

  .business-page .h2{
    font-size:clamp(32px, 10vw, 44px);
  }

  .business-page .h3{
    font-size:clamp(24px, 8vw, 32px);
  }

  .business-page .biz-hero-title{
    font-size:clamp(34px, 11vw, 46px);
  }

  .business-page .biz-hero-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .business-page .biz-hero-actions .btn{
    width:100%;
  }

  .business-page .biz-hero-stage,
  .business-page .biz-hero-image-placeholder{
    min-height:280px;
    border-radius:28px;
  }

  .business-page .biz-benefit-card{
    padding:24px;
    min-height:auto;
  }

  .business-page .biz-step{
    padding:18px;
    border-radius:20px;
  }

  .business-page .biz-demo-card{
    padding:28px 22px;
    border-radius:28px;
  }

  .business-page .biz-faq-question{
    padding:20px 60px 20px 20px;
    font-size:0.98rem;
  }

  .business-page .biz-faq-answer{
    padding:0 20px 20px;
  }

  .business-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .business-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER ADMIN PORTAL — REDESIGNED
   ========================================== */

body.admin-page{
  margin:0;
  background:
    radial-gradient(circle at 8% 8%, rgba(143,147,255,0.10), transparent 26%),
    radial-gradient(circle at 92% 10%, rgba(161,242,199,0.10), transparent 24%),
    linear-gradient(180deg, #f7f8fc 0%, #f4f6fb 100%);
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E6EAF2;
  --bh-border-soft:#F0F3F8;
  --bh-surface:#ffffff;
  --bh-soft:#F7F8FC;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 26px 60px rgba(17,24,39,0.12);
}

.admin-page *{
  box-sizing:border-box;
}

.admin-page a{
  text-decoration:none;
}

.admin-page button,
.admin-page input{
  font:inherit;
}

.admin-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.admin-page .admin-shell{
  width:min(1400px, calc(100% - 40px));
  margin:0 auto;
}

/* Header */

.admin-page .admin-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(230,234,242,0.95);
}

.admin-page .admin-header-inner{
  min-height:92px;
  display:grid;
  grid-template-columns:auto minmax(280px, 1fr) auto;
  align-items:center;
  gap:18px;
}

.admin-page .admin-header-left{
  display:flex;
  align-items:center;
  gap:14px;
}

.admin-page .admin-sidebar-toggle{
  width:48px;
  height:48px;
  border:none;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#ffffff;
  color:var(--bh-text);
  box-shadow:var(--bh-shadow-soft);
  cursor:pointer;
}

.admin-page .admin-brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:var(--bh-text);
}

.admin-page .admin-brand-mark{
  width:52px;
  height:52px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1.1rem;
  font-weight:900;
  box-shadow:0 16px 36px rgba(143,147,255,0.32);
}

.admin-page .admin-brand-word{
  font-size:1.22rem;
  font-weight:800;
  letter-spacing:0.02em;
}

.admin-page .admin-top-search{
  display:flex;
  justify-content:center;
}

.admin-page .admin-search-input{
  width:min(100%, 420px);
  min-height:52px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid var(--bh-border);
  background:rgba(255,255,255,0.88);
  color:var(--bh-text);
  box-shadow:var(--bh-shadow-soft);
  outline:none;
}

.admin-page .admin-search-input::placeholder{
  color:#9AA2B1;
}

.admin-page .admin-search-input:focus{
  border-color:rgba(143,147,255,0.42);
  box-shadow:0 0 0 4px rgba(143,147,255,0.10);
}

.admin-page .admin-header-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.admin-page .admin-header-btn{
  min-height:50px;
  padding:0 18px;
  border:1px solid var(--bh-border);
  border-radius:18px;
  background:rgba(255,255,255,0.88);
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:700;
  box-shadow:var(--bh-shadow-soft);
  cursor:pointer;
}

.admin-page .admin-user-chip{
  min-height:56px;
  padding:0 14px;
  border-radius:20px;
  display:flex;
  align-items:center;
  gap:12px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.admin-page .admin-user-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#ffffff;
  font-weight:800;
}

.admin-page .admin-user-copy{
  display:flex;
  flex-direction:column;
  line-height:1.15;
}

.admin-page .admin-user-name{
  font-size:0.95rem;
  font-weight:800;
  color:var(--bh-text);
}

.admin-page .admin-user-role{
  margin-top:4px;
  font-size:0.76rem;
  font-weight:700;
  color:var(--bh-text-secondary);
}

/* Main layout */

.admin-page .admin-main{
  padding:28px 0 40px;
}

.admin-page .admin-layout{
  display:grid;
  grid-template-columns:300px minmax(0, 1fr);
  gap:24px;
  align-items:start;
}

/* Sidebar */

.admin-page .admin-sidebar{
  position:sticky;
  top:120px;
  padding:18px;
  border-radius:30px;
  background:rgba(255,255,255,0.82);
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-strong);
  backdrop-filter:blur(14px);
}

.admin-page .admin-sidebar-top{
  margin-bottom:18px;
}

.admin-page .admin-sidebar-org{
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg, #faf8ff 0%, #f4f6fb 100%);
  border:1px solid rgba(143,147,255,0.14);
}

.admin-page .admin-sidebar-org-kicker{
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.admin-page .admin-sidebar-org h2{
  margin:0 0 8px;
  font-size:1.32rem;
  line-height:1.2;
  color:var(--bh-text);
}

.admin-page .admin-sidebar-org p{
  margin:0;
  font-size:0.92rem;
  line-height:1.65;
  color:var(--bh-text-secondary);
}

.admin-page .admin-nav{
  display:grid;
  gap:10px;
}

.admin-page .admin-nav-link{
  min-height:56px;
  padding:0 16px;
  border-radius:18px;
  display:flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:0.96rem;
  font-weight:700;
  transition:background-color .18s ease, color .18s ease, transform .18s ease;
}

.admin-page .admin-nav-link:hover{
  transform:translateY(-1px);
  background:#ffffff;
}

.admin-page .admin-nav-link.is-active{
  background:linear-gradient(135deg, rgba(150,79,247,0.14), rgba(143,147,255,0.18));
  color:var(--bh-secondary-dark);
}

.admin-page .admin-nav-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#ffffff;
  border:1px solid var(--bh-border);
  font-size:0.86rem;
  font-weight:800;
  flex:0 0 34px;
}

.admin-page .admin-sidebar-footer{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid var(--bh-border-soft);
}

.admin-page .admin-sidebar-manage{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  width:100%;
  padding:0 16px;
  border-radius:16px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  color:var(--bh-primary);
  font-size:0.92rem;
  font-weight:800;
  box-shadow:var(--bh-shadow-soft);
}

/* Collapsed state */

.admin-page.is-collapsed .admin-layout{
  grid-template-columns:92px minmax(0, 1fr);
}

.admin-page.is-collapsed .admin-sidebar{
  padding:14px;
}

.admin-page.is-collapsed .admin-sidebar-top,
.admin-page.is-collapsed .admin-sidebar-footer{
  display:none;
}

.admin-page.is-collapsed .admin-nav-link{
  justify-content:center;
  padding:0;
}

.admin-page.is-collapsed .admin-nav-label{
  display:none;
}

/* Content */

.admin-page .admin-content{
  display:grid;
  gap:24px;
}

.admin-page .admin-hero{
  padding:34px 36px;
  border-radius:34px;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:22px;
  align-items:center;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.14), transparent 24%),
    radial-gradient(circle at 84% 22%, rgba(255,255,255,0.12), transparent 24%),
    linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#ffffff;
  box-shadow:0 32px 70px rgba(143,147,255,0.28);
}

.admin-page .admin-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.18);
  color:#ffffff;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.admin-page .admin-page-title{
  margin:18px 0 0;
  font-size:clamp(38px, 4.6vw, 64px);
  line-height:0.98;
  letter-spacing:-0.05em;
  font-weight:900;
  color:#ffffff;
  max-width:760px;
}

.admin-page .admin-page-sub{
  margin:16px 0 0;
  max-width:760px;
  font-size:1.04rem;
  line-height:1.75;
  color:rgba(255,255,255,0.94);
}

.admin-page .admin-hero-meta{
  margin-top:22px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.admin-page .admin-hero-meta span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.18);
  color:#ffffff;
  font-size:0.84rem;
  font-weight:700;
}

.admin-page .admin-hero-actions{
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:stretch;
}

.admin-page .admin-btn{
  min-height:56px;
  padding:0 22px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.98rem;
  font-weight:800;
  cursor:pointer;
}

.admin-page .admin-btn-primary{
  background:#ffffff;
  color:var(--bh-secondary-dark);
  box-shadow:0 16px 32px rgba(17,24,39,0.12);
}

.admin-page .admin-btn-secondary{
  background:rgba(255,255,255,0.12);
  color:#ffffff;
  border-color:rgba(255,255,255,0.24);
}

/* Metric cards */

.admin-page .admin-metrics-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
}

.admin-page .admin-metric-card{
  position:relative;
  overflow:hidden;
  padding:26px 28px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-strong);
}

.admin-page .admin-metric-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:5px;
  background:linear-gradient(90deg, var(--bh-secondary-dark), var(--bh-secondary));
}

.admin-page .admin-metric-label{
  color:var(--bh-text-secondary);
  font-size:0.9rem;
  font-weight:700;
}

.admin-page .admin-metric-value{
  margin-top:14px;
  font-size:3rem;
  line-height:0.95;
  font-weight:900;
  color:var(--bh-text);
  letter-spacing:-0.04em;
}

.admin-page .admin-metric-meta{
  margin-top:14px;
  color:var(--bh-primary);
  font-size:0.98rem;
  font-weight:800;
}

/* General cards */

.admin-page .admin-grid{
  display:grid;
  gap:24px;
}

.admin-page .admin-grid-primary{
  grid-template-columns:1.28fr 0.92fr;
}

.admin-page .admin-grid-secondary{
  grid-template-columns:1.06fr 0.86fr 0.78fr;
}

.admin-page .admin-stack{
  display:grid;
  gap:24px;
}

.admin-page .admin-card{
  position:relative;
  overflow:hidden;
  padding:28px;
  border-radius:30px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-strong);
}

.admin-page .admin-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(90deg, rgba(150,79,247,0.20), rgba(143,147,255,0.04));
}

.admin-page .admin-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:22px;
}

.admin-page .admin-card-kicker{
  color:var(--bh-secondary-dark);
  font-size:0.78rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.admin-page .admin-card-title{
  margin:0;
  font-size:1.24rem;
  line-height:1.2;
  color:var(--bh-text);
}

.admin-page .admin-inline-btn{
  min-height:46px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  color:var(--bh-text);
  font-size:0.9rem;
  font-weight:800;
  box-shadow:var(--bh-shadow-soft);
  cursor:pointer;
}

/* Cohort cards */

.admin-page .admin-cohort-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.admin-page .admin-cohort-card{
  padding:20px;
  border-radius:22px;
  background:linear-gradient(180deg, #fafbff 0%, #f6f8fd 100%);
  border:1px solid var(--bh-border);
}

.admin-page .admin-cohort-card strong{
  display:block;
  color:var(--bh-text);
  font-size:1.02rem;
  line-height:1.35;
}

.admin-page .admin-cohort-card span{
  display:block;
  margin-top:8px;
  color:var(--bh-text-secondary);
  font-size:0.92rem;
  line-height:1.55;
  font-weight:600;
}

/* Quick actions */

.admin-page .admin-action-stack{
  display:grid;
  gap:14px;
}

.admin-page .admin-action-btn{
  min-height:58px;
  padding:0 18px;
  border:none;
  border-radius:18px;
  background:linear-gradient(180deg, #fafbff 0%, #f5f7fc 100%);
  border:1px solid var(--bh-border);
  color:var(--bh-text);
  text-align:left;
  font-size:0.95rem;
  font-weight:800;
  box-shadow:var(--bh-shadow-soft);
  cursor:pointer;
}

/* Lists */

.admin-page .admin-list{
  display:grid;
  gap:16px;
}

.admin-page .admin-list-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding-bottom:16px;
  border-bottom:1px solid var(--bh-border-soft);
}

.admin-page .admin-list-row:last-child{
  padding-bottom:0;
  border-bottom:none;
}

.admin-page .admin-list-row strong{
  display:block;
  color:var(--bh-text);
  font-size:0.98rem;
  line-height:1.35;
}

.admin-page .admin-list-row p{
  margin:7px 0 0;
  color:var(--bh-text-secondary);
  font-size:0.9rem;
  line-height:1.6;
}

.admin-page .admin-list-row span{
  color:var(--bh-text-secondary);
  font-size:0.82rem;
  font-weight:800;
  white-space:nowrap;
}

/* Alerts */

.admin-page .admin-alert-stack{
  display:grid;
  gap:14px;
}

.admin-page .admin-alert-item{
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg, #fafbff 0%, #f7f9fd 100%);
  border:1px solid var(--bh-border);
}

.admin-page .admin-alert-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}

.admin-page .admin-alert-top strong{
  color:var(--bh-text);
  font-size:0.96rem;
  line-height:1.35;
}

.admin-page .admin-alert-item p{
  margin:10px 0 0;
  color:var(--bh-text-secondary);
  font-size:0.9rem;
  line-height:1.6;
}

.admin-page .admin-alert-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(150,79,247,0.14);
  color:var(--bh-secondary-dark);
  font-size:0.74rem;
  font-weight:800;
  letter-spacing:0.04em;
  text-transform:uppercase;
  white-space:nowrap;
}

.admin-page .admin-alert-badge-soft{
  background:rgba(0,77,67,0.10);
  color:var(--bh-primary);
}

/* Trends */

.admin-page .admin-trend-stack{
  display:grid;
  gap:14px;
}

.admin-page .admin-trend-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(180deg, #fafbff 0%, #f7f9fd 100%);
  border:1px solid var(--bh-border);
}

.admin-page .admin-trend-row span{
  color:var(--bh-text-secondary);
  font-size:0.92rem;
  line-height:1.5;
}

.admin-page .admin-trend-row strong{
  color:var(--bh-text);
  font-size:0.94rem;
  font-weight:800;
}

/* Details */

.admin-page .admin-detail-stack{
  display:grid;
  gap:14px;
}

.admin-page .admin-detail-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(180deg, #fafbff 0%, #f7f9fd 100%);
  border:1px solid var(--bh-border);
}

.admin-page .admin-detail-row span{
  color:var(--bh-text-secondary);
  font-size:0.92rem;
}

.admin-page .admin-detail-row strong{
  color:var(--bh-text);
  font-size:0.94rem;
  font-weight:800;
}

/* Links */

.admin-page .admin-header-link,
.admin-page .admin-inline-link{
  text-decoration:none;
}

/* Responsive */

@media (max-width: 1260px){
  .admin-page .admin-layout{
    grid-template-columns:1fr;
  }

  .admin-page.is-collapsed .admin-layout{
    grid-template-columns:1fr;
  }

  .admin-page .admin-sidebar{
    position:static;
  }

  .admin-page .admin-metrics-grid{
    grid-template-columns:1fr 1fr;
  }

  .admin-page .admin-grid-primary,
  .admin-page .admin-grid-secondary{
    grid-template-columns:1fr;
  }
}

@media (max-width: 980px){
  .admin-page .admin-header-inner{
    grid-template-columns:1fr;
    gap:14px;
    padding:16px 0;
  }

  .admin-page .admin-top-search{
    width:100%;
  }

  .admin-page .admin-search-input{
    width:100%;
  }

  .admin-page .admin-header-actions{
    width:100%;
    justify-content:flex-start;
  }

  .admin-page .admin-hero{
    grid-template-columns:1fr;
  }

  .admin-page .admin-hero-actions{
    flex-direction:row;
    flex-wrap:wrap;
  }

  .admin-page .admin-cohort-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .admin-page .admin-shell{
    width:min(100% - 24px, 1400px);
  }

  .admin-page .admin-main{
    padding:18px 0 28px;
  }

  .admin-page .admin-metrics-grid{
    grid-template-columns:1fr;
  }

  .admin-page .admin-card,
  .admin-page .admin-metric-card,
  .admin-page .admin-sidebar{
    padding:20px;
    border-radius:24px;
  }

  .admin-page .admin-hero{
    padding:24px;
    border-radius:28px;
  }

  .admin-page .admin-page-title{
    font-size:clamp(34px, 12vw, 46px);
  }

  .admin-page .admin-header-actions{
    gap:8px;
  }

  .admin-page .admin-header-btn{
    min-height:46px;
    padding:0 14px;
  }

  .admin-page .admin-user-chip{
    width:100%;
    justify-content:flex-start;
  }

  .admin-page .admin-hero-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .admin-page .admin-btn{
    width:100%;
  }
}

/* ==========================================
   BADGER BUSINESS ACCESS PAGE
   ========================================== */

body.get-started-business-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.get-started-business-page *{
  box-sizing:border-box;
}

.get-started-business-page a{
  text-decoration:none;
}

.get-started-business-page button,
.get-started-business-page input,
.get-started-business-page textarea,
.get-started-business-page select{
  font:inherit;
}

.get-started-business-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.get-started-business-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.get-started-business-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-business-page .h3{
  margin:0;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-business-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

/* Header */

.get-started-business-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.get-started-business-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.get-started-business-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.get-started-business-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  letter-spacing:0;
}

.get-started-business-page .menu{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
}

.get-started-business-page .menu a{
  color:var(--bh-text);
  font-size:0.95rem;
  font-weight:600;
}

.get-started-business-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.get-started-business-page .btn:hover{
  transform:translateY(-1px);
}

.get-started-business-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.get-started-business-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.get-started-business-page .cta-nav{
  min-width:160px;
}

/* Hero / shell */

.get-started-business-page .biz-auth-hero{
  padding:56px 0 96px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.get-started-business-page .biz-auth-shell{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.get-started-business-page .biz-auth-header{
  max-width:820px;
  text-align:center;
}

.get-started-business-page .biz-auth-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin:0;
}

.get-started-business-page .biz-auth-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.get-started-business-page .biz-auth-sub{
  max-width:760px;
  margin:18px auto 0;
}

.get-started-business-page .biz-auth-sub-detail{
  max-width:700px;
  margin:14px auto 0;
  font-size:0.96rem;
}

/* Grid */

.get-started-business-page .biz-auth-grid{
  width:100%;
  margin-top:48px;
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap:24px;
  align-items:start;
}

.get-started-business-page .biz-auth-right-col{
  display:grid;
  gap:24px;
}

/* Cards */

.get-started-business-page .biz-auth-card,
.get-started-business-page .biz-auth-side-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
}

.get-started-business-page .biz-auth-card{
  padding:32px;
}

.get-started-business-page .biz-auth-side-card{
  padding:32px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(143,147,255,0.12), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(161,242,199,0.16), transparent 22%),
    #ffffff;
}

.get-started-business-page .biz-auth-card-header{
  margin-bottom:22px;
}

.get-started-business-page .biz-auth-card-sub{
  margin-top:10px;
}

/* Form */

.get-started-business-page .biz-auth-form{
  display:grid;
  gap:12px;
}

.get-started-business-page .biz-auth-label{
  font-weight:700;
  color:var(--bh-text);
  margin-top:4px;
}

.get-started-business-page .field{
  width:100%;
  min-height:54px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  color:var(--bh-text);
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.get-started-business-page .field::placeholder{
  color:#9CA3AF;
}

.get-started-business-page .field:focus{
  border-color:rgba(143,147,255,0.44);
  box-shadow:0 0 0 4px rgba(143,147,255,0.10);
}

.get-started-business-page .field-select{
  appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, #6B7280 50%),
    linear-gradient(135deg, #6B7280 50%, transparent 50%);
  background-position:
    calc(100% - 24px) calc(50% - 3px),
    calc(100% - 18px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:48px;
}

.get-started-business-page .field-textarea{
  min-height:140px;
  padding:16px;
  resize:vertical;
}

.get-started-business-page .biz-auth-checkbox{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-top:6px;
}

.get-started-business-page .biz-auth-checkbox input{
  width:18px;
  height:18px;
  margin-top:4px;
  accent-color:var(--bh-primary);
}

.get-started-business-page .biz-auth-checkbox span{
  color:var(--bh-text-secondary);
  line-height:1.7;
}

.get-started-business-page .biz-auth-checkbox a{
  color:var(--bh-primary);
  font-weight:700;
}

.get-started-business-page .biz-auth-primary-cta{
  width:100%;
  margin-top:8px;
  min-height:56px;
  font-size:1rem;
}

/* Status */

.get-started-business-page .biz-auth-status{
  margin-bottom:18px;
  padding:14px 16px;
  border-radius:16px;
  font-size:0.95rem;
  line-height:1.6;
  font-weight:700;
}

.get-started-business-page .biz-auth-status.is-success{
  background:rgba(0,77,67,0.08);
  border:1px solid rgba(0,77,67,0.14);
  color:var(--bh-primary);
}

.get-started-business-page .biz-auth-status.is-error{
  background:rgba(185,28,28,0.08);
  border:1px solid rgba(185,28,28,0.14);
  color:#991B1B;
}

/* Side card */

.get-started-business-page .biz-auth-side-kicker{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.get-started-business-page .biz-auth-side-title{
  margin:0 0 20px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.1;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-business-page .biz-auth-side-points{
  display:grid;
  gap:16px;
}

.get-started-business-page .biz-auth-side-point{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:12px;
  align-items:start;
}

.get-started-business-page .biz-auth-side-point strong{
  display:block;
  color:var(--bh-text);
  margin-bottom:4px;
  font-size:1rem;
}

.get-started-business-page .biz-auth-side-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--bh-primary);
  margin-top:10px;
}

.get-started-business-page .biz-auth-side-note{
  margin-top:24px;
  padding:18px;
  border-radius:20px;
  background:#F8FAFC;
  border:1px solid var(--bh-border-soft);
}

.get-started-business-page .biz-auth-side-note strong{
  display:block;
  margin-bottom:8px;
  color:var(--bh-text);
}

/* Cookie banner */

.get-started-business-page .cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:100;
}

.get-started-business-page .cookie-banner-inner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px;
  border-radius:28px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:0 24px 60px rgba(17,24,39,0.16);
}

.get-started-business-page .cookie-banner-text{
  max-width:760px;
}

.get-started-business-page .cookie-title{
  margin:0 0 10px;
  font-size:1.2rem;
  line-height:1.2;
  font-weight:800;
  color:var(--bh-text);
}

.get-started-business-page .cookie-banner-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.get-started-business-page .cookie-btn{
  min-width:150px;
}

/* Responsive */

@media (max-width: 1120px){
  .get-started-business-page .biz-auth-grid{
    grid-template-columns:1fr;
    max-width:820px;
    margin-left:auto;
    margin-right:auto;
  }
}

@media (max-width: 860px){
  .get-started-business-page .nav{
    grid-template-columns:1fr;
    justify-items:center;
    padding:16px 0;
  }

  .get-started-business-page .menu{
    flex-wrap:wrap;
    gap:16px;
  }

  .get-started-business-page .biz-auth-hero{
    padding:40px 0 80px;
  }

  .get-started-business-page .biz-auth-card,
  .get-started-business-page .biz-auth-side-card{
    padding:26px;
  }

  .get-started-business-page .cookie-banner-inner{
    flex-direction:column;
    align-items:stretch;
  }

  .get-started-business-page .cookie-banner-actions{
    justify-content:stretch;
  }

  .get-started-business-page .cookie-banner-actions .btn{
    flex:1 1 180px;
  }
}

@media (max-width: 640px){
  .get-started-business-page .container{
    width:min(100% - 24px, 1180px);
  }

  .get-started-business-page .biz-auth-title{
    font-size:clamp(32px, 10vw, 44px);
  }

  .get-started-business-page .biz-auth-card,
  .get-started-business-page .biz-auth-side-card{
    padding:22px;
    border-radius:24px;
  }

  .get-started-business-page .field{
    min-height:52px;
    border-radius:14px;
  }

  .get-started-business-page .field-textarea{
    min-height:128px;
  }

  .get-started-business-page .biz-auth-primary-cta{
    min-height:54px;
  }

  .get-started-business-page .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .get-started-business-page .cookie-banner-inner{
    padding:18px;
    border-radius:24px;
  }
}

/* ==========================================
   BADGER GET STARTED PAGE — APP LINKS
   ========================================== */

.get-started-page .auth-app-row{
  display:flex;
  justify-content:flex-start;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.get-started-page .auth-app-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--bh-border);
  background:#F8FAFC;
  color:var(--bh-text);
  font-size:0.9rem;
  font-weight:700;
}

.get-started-page .auth-next-note{
  margin-top:2px;
  font-size:0.92rem;
}

@media (max-width: 640px){
  .get-started-page .auth-app-row{
    flex-direction:column;
    align-items:stretch;
  }

  .get-started-page .auth-app-link{
    width:100%;
  }
}

/* ==========================================
   BADGER CHOOSE PLAN PAGE
   ========================================== */

body.choose-plan-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.choose-plan-page *{
  box-sizing:border-box;
}

.choose-plan-page a{
  text-decoration:none;
}

.choose-plan-page button{
  font:inherit;
}

.choose-plan-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.choose-plan-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.choose-plan-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.choose-plan-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.choose-plan-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.choose-plan-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto;
  justify-content:center;
  align-items:center;
}

.choose-plan-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.choose-plan-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
}

.choose-plan-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.choose-plan-page .btn:hover{
  transform:translateY(-1px);
}

.choose-plan-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.choose-plan-page .btn-secondary{
  background:var(--bh-soft);
  color:var(--bh-text);
  border-color:var(--bh-border);
}

.choose-plan-page .plan-hero{
  padding:52px 0 96px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.choose-plan-page .plan-shell{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.choose-plan-page .plan-header{
  max-width:800px;
  text-align:center;
}

.choose-plan-page .plan-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin:0;
}

.choose-plan-page .plan-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.choose-plan-page .plan-sub{
  max-width:760px;
  margin:18px auto 0;
}

.choose-plan-page .plan-account-pill{
  margin-top:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
  color:var(--bh-text);
  font-size:0.92rem;
  font-weight:700;
  gap: 8px
}

.choose-plan-page .plan-account-email{
  display:inline-block;
  margin-left:8px;
}

.choose-plan-page .billing-toggle{
  margin-top:36px;
  display:inline-flex;
  gap:8px;
  padding:8px;
  border-radius:18px;
  background:#ffffff;
  border:1px solid var(--bh-border);
  box-shadow:var(--bh-shadow-soft);
}

.choose-plan-page .billing-toggle-btn{
  min-height:46px;
  padding:0 16px;
  border:none;
  border-radius:14px;
  background:transparent;
  color:var(--bh-text);
  font-size:0.94rem;
  font-weight:800;
  cursor:pointer;
}

.choose-plan-page .billing-toggle-btn span{
  font-size:0.78rem;
  opacity:0.8;
  margin-left:4px;
}

.choose-plan-page .billing-toggle-btn.is-active{
  background:linear-gradient(135deg, rgba(150,79,247,0.12), rgba(143,147,255,0.18));
  color:var(--bh-secondary-dark);
}

.choose-plan-page .plan-grid{
  width:100%;
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
  align-items:stretch;
}

.choose-plan-page .plan-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
  padding:28px;
  display:flex;
  flex-direction:column;
}

.choose-plan-page .plan-card.is-featured{
  border-color:rgba(143,147,255,0.34);
  box-shadow:0 26px 60px rgba(143,147,255,0.14);
}

.choose-plan-page .plan-card-top{
  margin-bottom:18px;
}

.choose-plan-page .plan-card-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:16px;
}

.choose-plan-page .plan-card-title{
  margin:0 0 10px;
  font-size:1.5rem;
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.choose-plan-page .plan-card-copy{
  margin:0;
  color:var(--bh-text-secondary);
  line-height:1.7;
}

.choose-plan-page .plan-price-wrap{
  margin:6px 0 20px;
}

.choose-plan-page .plan-price{
  font-size:2.4rem;
  line-height:1;
  letter-spacing:-0.05em;
  font-weight:900;
  color:var(--bh-text);
}

.choose-plan-page .plan-price-note{
  margin-top:8px;
  color:var(--bh-text-secondary);
  font-size:0.92rem;
  font-weight:700;
}

.choose-plan-page .plan-list{
  margin-bottom:10px;
  padding-left:20px;
  display:grid;
  gap:12px;
  color:var(--bh-text-secondary);
  line-height:1.65;
  font-size:0.96rem;
}

.choose-plan-page .plan-cta{
  width:100%;
  margin-top:auto;
  min-height:56px;
}

.choose-plan-page .plan-footnote{
  max-width:760px;
  margin:24px auto 0;
  text-align:center;
}

@media (max-width: 1120px){
  .choose-plan-page .plan-grid{
    grid-template-columns:1fr;
    max-width:760px;
  }
}

@media (max-width: 640px){
  .choose-plan-page .container{
    width:min(100% - 24px, 1180px);
  }

  .choose-plan-page .plan-title{
    font-size:clamp(32px, 10vw, 44px);
  }

  .choose-plan-page .plan-card{
    padding:22px;
    border-radius:24px;
  }

  .choose-plan-page .billing-toggle{
    width:100%;
    flex-direction:column;
  }

  .choose-plan-page .billing-toggle-btn{
    width:100%;
  }
}

/* ==========================================
   BADGER PAYMENT PAGE
   ========================================== */

body.payment-page{
  margin:0;
  background:#ffffff;
  color:#111827;
  font-family:"Montserrat", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  --bh-primary:#004d43;
  --bh-primary-soft:#c5fbc6;
  --bh-secondary:#8f93ff;
  --bh-secondary-dark:#964ff7;
  --bh-tertiary:#a1f2c7;
  --bh-soft:#E9ECF2;
  --bh-text:#111827;
  --bh-text-secondary:#6B7280;
  --bh-border:#E5E7EB;
  --bh-border-soft:#F3F4F6;
  --bh-surface:#ffffff;
  --bh-ink:#2D2D31;
  --bh-shadow-soft:0 18px 40px rgba(17,24,39,0.08);
  --bh-shadow-strong:0 30px 80px rgba(17,24,39,0.16);
}

.payment-page *{
  box-sizing:border-box;
}

.payment-page a{
  text-decoration:none;
}

.payment-page button,
.payment-page input,
.payment-page select{
  font:inherit;
}

.payment-page .visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.payment-page .container{
  width:min(1180px, calc(100% - 40px));
  margin:0 auto;
}

.payment-page .h2{
  margin:0;
  font-size:clamp(34px, 5vw, 60px);
  line-height:1.02;
  letter-spacing:-0.045em;
  font-weight:800;
  color:var(--bh-text);
}

.payment-page .p2{
  margin:0;
  font-size:1rem;
  line-height:1.75;
  font-weight:500;
  color:var(--bh-text-secondary);
}

.payment-page .site{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,0.85);
}

.payment-page .nav{
  min-height:86px;
  display:grid;
  grid-template-columns:auto;
  justify-content:center;
  align-items:center;
}

.payment-page .brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--bh-text);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:0.08em;
}

.payment-page .brand::before{
  content:"B";
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--bh-secondary-dark), var(--bh-secondary));
  color:#fff;
  font-size:1rem;
  font-weight:900;
}

.payment-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid transparent;
  font-size:0.95rem;
  font-weight:700;
  transition:transform .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease;
  cursor:pointer;
}

.payment-page .btn:hover{
  transform:translateY(-1px);
}

.payment-page .btn-primary{
  background:var(--bh-primary);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,77,67,0.15);
}

.payment-page .payment-hero{
  padding:52px 0 96px;
  background:
    radial-gradient(circle at 10% 15%, rgba(143,147,255,0.10), transparent 24%),
    radial-gradient(circle at 90% 18%, rgba(161,242,199,0.14), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fcfcff 100%);
}

.payment-page .payment-shell{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.payment-page .payment-header{
  max-width:780px;
  text-align:center;
}

.payment-page .payment-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(143,147,255,0.12);
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin:0;
}

.payment-page .payment-title{
  margin-top:18px;
  color:var(--bh-secondary-dark);
}

.payment-page .payment-sub{
  max-width:720px;
  margin:18px auto 0;
}

.payment-page .payment-grid{
  width:100%;
  margin-top:36px;
  display:grid;
  grid-template-columns:minmax(320px, 0.85fr) minmax(0, 1.15fr);
  gap:24px;
  align-items:start;
}

.payment-page .payment-card{
  background:#ffffff;
  border:1px solid var(--bh-border);
  border-radius:28px;
  box-shadow:var(--bh-shadow-soft);
  padding:32px;
}

.payment-page .payment-card-kicker{
  color:var(--bh-secondary-dark);
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.payment-page .payment-card-title{
  margin:0 0 16px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:800;
  color:var(--bh-text);
}

.payment-page .payment-summary-stack{
  display:grid;
  gap:14px;
}

.payment-page .payment-summary-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  border-radius:18px;
  background:#F8FAFC;
  border:1px solid var(--bh-border-soft);
}

.payment-page .payment-summary-row span{
  color:var(--bh-text-secondary);
  font-size:0.94rem;
}

.payment-page .payment-summary-row strong{
  color:var(--bh-text);
  font-size:0.96rem;
  font-weight:800;
}

.payment-page .payment-note{
  margin-top:20px;
  padding:18px;
  border-radius:20px;
  background:rgba(143,147,255,0.08);
  border:1px solid rgba(143,147,255,0.14);
  color:var(--bh-text-secondary);
  line-height:1.7;
}

.payment-page .payment-back-link{
  display:inline-block;
  margin-top:20px;
  color:var(--bh-primary);
  font-weight:800;
}

.payment-page .payment-form-copy{
  margin-bottom:18px;
}

.payment-page .payment-form{
  display:grid;
  gap:12px;
}

.payment-page .payment-label{
  font-weight:700;
  color:var(--bh-text);
  margin-top:4px;
}

.payment-page .field{
  width:100%;
  min-height:54px;
  padding:0 16px;
  border-radius:16px;
  border:1px solid var(--bh-border);
  background:#ffffff;
  color:var(--bh-text);
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.payment-page .field:focus{
  border-color:rgba(143,147,255,0.44);
  box-shadow:0 0 0 4px rgba(143,147,255,0.10);
}

.payment-page .payment-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.payment-page .payment-checkbox{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-top:4px;
}

.payment-page .payment-checkbox input{
  width:18px;
  height:18px;
  margin-top:4px;
  accent-color:var(--bh-primary);
}

.payment-page .payment-checkbox span{
  color:var(--bh-text-secondary);
  line-height:1.7;
}

.payment-page .payment-checkbox a{
  color:var(--bh-primary);
  font-weight:700;
}

.payment-page .payment-primary-cta{
  width:100%;
  margin-top:8px;
  min-height:56px;
  font-size:1rem;
}

.payment-page .payment-secure-note{
  margin:0;
  color:var(--bh-text-secondary);
  font-size:0.92rem;
  line-height:1.6;
}

.payment-page .payment-app-links{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:20px;
}

.payment-page .payment-app-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--bh-border);
  background:#F8FAFC;
  color:var(--bh-text);
  font-size:0.9rem;
  font-weight:700;
}

@media (max-width: 1120px){
  .payment-page .payment-grid{
    grid-template-columns:1fr;
    max-width:820px;
    margin-left:auto;
    margin-right:auto;
  }
}

@media (max-width: 640px){
  .payment-page .container{
    width:min(100% - 24px, 1180px);
  }

  .payment-page .payment-title{
    font-size:clamp(32px, 10vw, 44px);
  }

  .payment-page .payment-card{
    padding:22px;
    border-radius:24px;
  }

  .payment-page .payment-row{
    display:grid;
    grid-template-columns:minmax(0, 1.02fr) minmax(320px, 0.98fr);
    gap:24px;
    align-items:start;
    margin-top:48px;
  }

  .payment-page .payment-col{
    display:grid;
    gap:24px;
  }

  .payment-page .payment-card{
    background:#ffffff;
    border:1px solid var(--bh-border);
    border-radius:28px;
    box-shadow:var(--bh-shadow-soft);
    padding:32px;
  }

  .payment-page .payment-card-header{
    margin-bottom:22px;
  }

  .payment-page .payment-card-kicker{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    padding:0 14px;
    border-radius:999px;
    background:rgba(143,147,255,0.12);
    color:var(--bh-secondary-dark);
    font-size:0.76rem;
    font-weight:800;
    letter-spacing:0.08em;
    text-transform:uppercase;
    margin-bottom:14px;
  }

  .payment-page .payment-card-title{
    margin:0;
    font-size:clamp(24px, 3vw, 34px);
    line-height:1.08;
    letter-spacing:-0.03em;
    font-weight:800;
    color:var(--bh-text);
  }

  .payment-page .payment-card-sub{
    margin-top:12px;
    color:var(--bh-text-secondary);
  }

  .payment-page .payment-plan-chip{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    padding:0 16px;
    border-radius:999px;
    background:rgba(0,77,67,0.08);
    color:var(--bh-primary);
    font-size:0.82rem;
    font-weight:800;
    letter-spacing:0.04em;
    text-transform:uppercase;
  }

  .payment-page .payment-plan-selected{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
    padding:20px;
    border-radius:22px;
    background:linear-gradient(180deg, #fafbff 0%, #f7f9fd 100%);
    border:1px solid var(--bh-border);
    margin-top:18px;
  }

  .payment-page .payment-plan-name{
    margin:0;
    font-size:1.08rem;
    font-weight:800;
    color:var(--bh-text);
  }

  .payment-page .payment-plan-copy{
    margin:8px 0 0;
    color:var(--bh-text-secondary);
    line-height:1.7;
    font-size:0.95rem;
  }

  .payment-page .payment-plan-price{
    text-align:right;
    flex:0 0 auto;
  }

  .payment-page .payment-plan-price strong{
    display:block;
    font-size:1.4rem;
    line-height:1;
    letter-spacing:-0.03em;
    color:var(--bh-text);
  }

  .payment-page .payment-plan-price span{
    display:block;
    margin-top:6px;
    color:var(--bh-text-secondary);
    font-size:0.88rem;
    font-weight:700;
  }

  .payment-page .payment-form{
    display:grid;
    gap:14px;
    margin-top:8px;
  }

  .payment-page .payment-label{
    display:block;
    margin:0 0 8px;
    font-weight:700;
    color:var(--bh-text);
  }

  .payment-page .payment-field,
  .payment-page .payment-select{
    width:100%;
    min-height:54px;
    padding:0 16px;
    border-radius:16px;
    border:1px solid var(--bh-border);
    background:#ffffff;
    color:var(--bh-text);
    outline:none;
    transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
  }

  .payment-page .payment-field::placeholder{
    color:#9CA3AF;
  }

  .payment-page .payment-field:focus,
  .payment-page .payment-select:focus{
    border-color:rgba(143,147,255,0.44);
    box-shadow:0 0 0 4px rgba(143,147,255,0.10);
  }

  .payment-page .payment-field-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
  }

  .payment-page .payment-card-box{
    min-height:58px;
    padding:16px 18px;
    border-radius:18px;
    border:1px dashed rgba(143,147,255,0.28);
    background:#fafbff;
    color:var(--bh-text-secondary);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    font-size:0.95rem;
    line-height:1.5;
  }

  .payment-page .payment-card-icons{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
  }

  .payment-page .payment-card-icon{
    min-width:44px;
    min-height:30px;
    padding:0 10px;
    border-radius:10px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:#ffffff;
    border:1px solid var(--bh-border);
    color:var(--bh-text);
    font-size:0.8rem;
    font-weight:800;
  }

  .payment-page .payment-checkbox{
    display:flex;
    align-items:flex-start;
    gap:12px;
    margin-top:4px;
  }

  .payment-page .payment-checkbox input{
    width:18px;
    height:18px;
    margin-top:4px;
    accent-color:var(--bh-primary);
  }

  .payment-page .payment-checkbox span{
    color:var(--bh-text-secondary);
    line-height:1.7;
  }

  .payment-page .payment-checkbox a{
    color:var(--bh-primary);
    font-weight:700;
  }

  .payment-page .payment-submit{
    width:100%;
    min-height:56px;
    margin-top:8px;
    border:none;
    border-radius:18px;
    background:var(--bh-primary);
    color:#ffffff;
    font-size:1rem;
    font-weight:800;
    box-shadow:0 10px 24px rgba(0,77,67,0.15);
    cursor:pointer;
    transition:transform .18s ease, opacity .18s ease;
  }

  .payment-page .payment-submit:hover{
    transform:translateY(-1px);
  }

  .payment-page .payment-note{
    margin-top:12px;
    font-size:0.9rem;
    line-height:1.7;
    color:var(--bh-text-secondary);
  }

  .payment-page .payment-note-strong{
    color:var(--bh-text);
    font-weight:700;
  }

  .payment-page .payment-summary-card{
    position:sticky;
    top:110px;
  }

  .payment-page .payment-summary-list{
    display:grid;
    gap:14px;
    margin-top:8px;
  }

  .payment-page .payment-summary-row{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:14px;
    padding-bottom:14px;
    border-bottom:1px solid var(--bh-border-soft);
    color:var(--bh-text-secondary);
    font-size:0.96rem;
    line-height:1.6;
  }

  .payment-page .payment-summary-row:last-child{
    border-bottom:none;
    padding-bottom:0;
  }

  .payment-page .payment-summary-row strong{
    color:var(--bh-text);
    font-weight:800;
  }

  .payment-page .payment-summary-total{
    margin-top:18px;
    padding:18px 20px;
    border-radius:20px;
    background:linear-gradient(180deg, #fafbff 0%, #f7f9fd 100%);
    border:1px solid var(--bh-border);
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
  }

  .payment-page .payment-summary-total-label{
    color:var(--bh-text);
    font-size:1rem;
    font-weight:800;
  }

  .payment-page .payment-summary-total-price{
    color:var(--bh-text);
    font-size:1.55rem;
    line-height:1;
    letter-spacing:-0.03em;
    font-weight:900;
  }

  .payment-page .payment-summary-caption{
    margin-top:12px;
    color:var(--bh-text-secondary);
    font-size:0.9rem;
    line-height:1.7;
  }

  .payment-page .payment-summary-points{
    margin-top:20px;
    display:grid;
    gap:12px;
  }

  .payment-page .payment-summary-point{
    display:grid;
    grid-template-columns:18px 1fr;
    gap:12px;
    align-items:start;
  }

  .payment-page .payment-summary-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    background:var(--bh-primary);
    margin-top:10px;
  }

  .payment-page .payment-summary-point strong{
    display:block;
    margin-bottom:4px;
    color:var(--bh-text);
    font-size:0.98rem;
  }

  .payment-page .payment-summary-point p{
    margin:0;
    color:var(--bh-text-secondary);
    line-height:1.65;
    font-size:0.92rem;
  }

  .payment-page .payment-back-link{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-top:18px;
    color:var(--bh-primary);
    font-size:0.94rem;
    font-weight:800;
  }

  .payment-page .payment-status{
    margin-bottom:18px;
    padding:14px 16px;
    border-radius:16px;
    font-size:0.95rem;
    line-height:1.6;
    font-weight:700;
  }

  .payment-page .payment-status.is-success{
    background:rgba(0,77,67,0.08);
    border:1px solid rgba(0,77,67,0.14);
    color:var(--bh-primary);
  }

  .payment-page .payment-status.is-error{
    background:rgba(185,28,28,0.08);
    border:1px solid rgba(185,28,28,0.14);
    color:#991B1B;
  }

  .payment-page .payment-status.is-info{
    background:rgba(143,147,255,0.10);
    border:1px solid rgba(143,147,255,0.18);
    color:var(--bh-secondary-dark);
  }

  @media (max-width: 1120px){
    .payment-page .payment-row{
      grid-template-columns:1fr;
      max-width:820px;
      margin-left:auto;
      margin-right:auto;
    }

    .payment-page .payment-summary-card{
      position:static;
    }
  }

  @media (max-width: 860px){
    .payment-page .payment-card{
      padding:26px;
      border-radius:24px;
    }

    .payment-page .payment-field-row{
      grid-template-columns:1fr;
    }

    .payment-page .payment-plan-selected{
      flex-direction:column;
      align-items:flex-start;
    }

    .payment-page .payment-plan-price{
      text-align:left;
    }
  }

  @media (max-width: 640px){
    .payment-page .payment-card{
      padding:22px;
      border-radius:22px;
    }

    .payment-page .payment-field,
    .payment-page .payment-select{
      min-height:52px;
      border-radius:14px;
    }

    .payment-page .payment-submit{
      min-height:54px;
    }

    .payment-page .payment-summary-total{
      padding:16px 18px;
      border-radius:18px;
    }

    .payment-page .payment-summary-total-price{
      font-size:1.35rem;
    }
  }
  }
  /* ==========================================
    BADGER WAITLIST PAGE
    Add below get-started-page styles
    ========================================== */

  .waitlist-page .waitlist-status{
    width:100%;
    margin:0 0 18px;
    padding:14px 16px;
    border-radius:16px;
    font-size:0.95rem;
    line-height:1.6;
    font-weight:700;
  }

  .waitlist-page .waitlist-status.is-success{
    background:rgba(0,77,67,0.08);
    border:1px solid rgba(0,77,67,0.14);
    color:#004d43;
  }

  .waitlist-page .waitlist-status.is-error{
    background:rgba(185,28,28,0.08);
    border:1px solid rgba(185,28,28,0.14);
    color:#991B1B;
  }

  .waitlist-page .waitlist-note{
    margin-top:6px;
    font-size:0.92rem;
    line-height:1.65;
    color:#6B7280;
  }

  .waitlist-page .waitlist-note a{
    color:#004d43;
    font-weight:700;
    text-decoration:none;
  }  

/* ==========================================
   BADGER RESPONSIVE OVERRIDE FIX
   PASTE AT THE VERY END OF styles.css
   ========================================== */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

img,
svg,
video,
canvas {
  max-width: 100%;
  height: auto;
}

/* stop horizontal overflow on key page shells */
body.home-page,
body.blog-page,
body.about-page,
body.faqs-page,
body.crisis-page,
body.privacy-page,
body.terms-page,
body.community-page,
body.business-page,
body.get-started-page,
body.get-started-business-page,
body.choose-plan-page,
body.payment-page,
body.waitlist-page,
body.admin-page {
  overflow-x: hidden;
}

/* safer width handling */
.home-page .bh-container,
.blog-page .container,
.about-page .container,
.faqs-page .container,
.crisis-page .container,
.crisis-page .bh-container,
.privacy-page .container,
.terms-page .container,
.community-page .container,
.business-page .container,
.get-started-page .container,
.get-started-business-page .container,
.choose-plan-page .container,
.payment-page .container,
.site-footer-container {
  max-width: 1180px;
  width: min(1180px, calc(100% - 40px));
  margin-left: auto;
  margin-right: auto;
}

/* cards and boxes should never force overflow */
.home-page .bh-card,
.home-page .bh-benefit-card,
.home-page .bh-loop-card,
.home-page .bh-demo-phone,
.home-page .bh-demo-screen,
.home-page .bh-demo-task,
.home-page .bh-demo-checkin,
.business-page .biz-card,
.business-page .biz-benefit-card,
.blog-page .blog-card,
.about-page .about-copy,
.about-page .about-contact-card,
.get-started-page .auth-card,
.get-started-page .auth-side-card,
.get-started-business-page .biz-auth-card,
.get-started-business-page .biz-auth-side-card,
.choose-plan-page .plan-card,
.payment-page .payment-card,
.site-footer-grid,
.home-page .bh-footer-grid,
.crisis-page .bh-footer-grid {
  min-width: 0;
  max-width: 100%;
}

/* ==========================================
   SMALLER LAPTOP / TABLET
   ========================================== */
@media (max-width: 1024px) {
  /* ------------------------------------------
     HEADER: show only logo + Badger
     ------------------------------------------ */

  .home-page .bh-header-inner,
  .blog-page .nav,
  .about-page .nav,
  .faqs-page .nav,
  .crisis-page .nav,
  .privacy-page .nav,
  .terms-page .nav,
  .community-page .nav,
  .business-page .nav,
  .get-started-page .nav,
  .get-started-business-page .nav {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    align-items: center !important;
    gap: 0 !important;
    min-height: auto !important;
    padding: 18px 0 !important;
  }

  .home-page .bh-nav,
  .home-page .bh-cta-nav,
  .blog-page .menu,
  .blog-page .cta-nav,
  .about-page .menu,
  .about-page .cta-nav,
  .faqs-page .menu,
  .faqs-page .cta-nav,
  .crisis-page .menu,
  .crisis-page .cta-nav,
  .privacy-page .menu,
  .privacy-page .cta-nav,
  .terms-page .menu,
  .terms-page .cta-nav,
  .community-page .menu,
  .community-page .cta-nav,
  .business-page .menu,
  .business-page .cta-nav,
  .get-started-business-page .menu,
  .get-started-business-page .cta-nav {
    display: none !important;
  }

  .home-page .bh-brand,
  .blog-page .brand,
  .about-page .brand,
  .faqs-page .brand,
  .crisis-page .brand,
  .privacy-page .brand,
  .terms-page .brand,
  .community-page .brand,
  .business-page .brand,
  .get-started-page .brand,
  .get-started-business-page .brand,
  .choose-plan-page .brand,
  .payment-page .brand {
    justify-content: center;
    text-align: center;
  }

  /* ------------------------------------------
     HOMEPAGE HERO
     ------------------------------------------ */

  .home-page .bh-hero {
    padding: 34px 0 48px;
  }

  .home-page .bh-hero-title {
    font-size: clamp(34px, 7vw, 54px);
  }

  .home-page .bh-hero-sub {
    max-width: 760px;
    font-size: 1rem;
    line-height: 1.65;
  }

  .home-page .bh-hero-actions {
    margin-top: 36px;
  }

  /* make purple section contained on narrower screens */
  .home-page .bh-hero-stage {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-top: 44px !important;
    min-height: auto !important;
    padding: 28px 18px 22px !important;
    border-radius: 32px !important;
    overflow: hidden !important;
  }

  .home-page .bh-hero-stage::after {
    display: none !important;
  }

  /* remove all floating pills on smaller laptop/tablet */
  .home-page .bh-float {
    display: none !important;
  }

  .home-page .bh-demo-frame {
    width: 100%;
    padding-top: 0;
  }

  .home-page .bh-demo-phone {
    width: min(390px, 100%);
    margin: 0 auto;
  }

  /* ------------------------------------------
     HOMEPAGE BENEFITS
     ------------------------------------------ */

  .home-page .bh-benefit-grid {
    grid-template-columns: 1fr !important;
    gap: 18px;
  }

  .home-page .bh-benefit-card {
    min-height: auto !important;
    padding: 24px;
  }

  .home-page .bh-icon-box {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    aspect-ratio: 16 / 9;
    margin-bottom: 18px;
  }

  /* ------------------------------------------
     HOMEPAGE HOW IT WORKS
     ------------------------------------------ */

  .home-page .bh-loop-shell {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    overflow: hidden;
  }

  .home-page .bh-loop-diagram {
    width: min(360px, 100%) !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    margin: 0 auto;
  }

  .home-page .bh-loop-card,
  .home-page .bh-loop-card-1,
  .home-page .bh-loop-card-2,
  .home-page .bh-loop-card-3 {
    grid-column: auto !important;
    align-self: auto !important;
    justify-self: stretch !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 24px;
  }

  .home-page .bh-loop-ring::after {
    inset: 58px;
  }

  .home-page .bh-loop-core {
    inset: 110px;
  }

  /* ------------------------------------------
     HOMEPAGE GET / ABOUT
     ------------------------------------------ */

  .home-page .bh-benefits,
  .home-page .bh-how,
  .home-page .bh-get,
  .home-page .bh-about {
    padding: 76px 0;
  }

  .home-page .bh-get-cta-row {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }

  .home-page .bh-get-primary,
  .home-page .bh-get-business {
    width: 100%;
    min-width: 0 !important;
  }

  .home-page .bh-about-pledge-bar {
    width: 100%;
    min-height: 180px;
    border-radius: 24px;
  }

  /* ------------------------------------------
     FOOTERS
     ------------------------------------------ */

  .home-page .bh-footer-grid,
  .crisis-page .bh-footer-grid,
  .site-footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 26px !important;
  }

  .home-page .bh-footer-brand,
  .crisis-page .bh-footer-brand,
  .site-footer-brand {
    grid-column: 1 / -1;
  }

  .home-page .bh-footer-col,
  .crisis-page .bh-footer-col,
  .site-footer-col {
    min-width: 0;
  }

  .home-page .bh-footer-col a,
  .crisis-page .bh-footer-col a,
  .site-footer-col a {
    white-space: normal;
    word-break: break-word;
  }

  /* ------------------------------------------
     BUSINESS PAGE specific overflow fixes
     ------------------------------------------ */

  .business-page .biz-benefit-grid,
  .business-page .biz-how-grid,
  .business-page .biz-hero-grid {
    grid-template-columns: 1fr !important;
  }

  .business-page .biz-card-icon {
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    aspect-ratio: 16 / 9;
  }

  .business-page .biz-demo-inner {
    width: min(1180px, calc(100% - 40px));
    padding: 0;
    flex-direction: column;
    align-items: stretch;
  }

  .business-page .biz-demo-actions {
    padding-top: 0;
  }
}

/* ==========================================
   PHONE
   ========================================== */
@media (max-width: 700px) {
  .home-page .bh-container,
  .blog-page .container,
  .about-page .container,
  .faqs-page .container,
  .crisis-page .container,
  .crisis-page .bh-container,
  .privacy-page .container,
  .terms-page .container,
  .community-page .container,
  .business-page .container,
  .get-started-page .container,
  .get-started-business-page .container,
  .choose-plan-page .container,
  .payment-page .container,
  .site-footer-container {
    width: min(100% - 24px, 1180px);
  }

  .home-page .bh-header-inner,
  .blog-page .nav,
  .about-page .nav,
  .faqs-page .nav,
  .crisis-page .nav,
  .privacy-page .nav,
  .terms-page .nav,
  .community-page .nav,
  .business-page .nav,
  .get-started-page .nav,
  .get-started-business-page .nav,
  .choose-plan-page .nav,
  .payment-page .nav {
    padding: 16px 0 !important;
  }

  .home-page .bh-brand,
  .blog-page .brand,
  .about-page .brand,
  .faqs-page .brand,
  .crisis-page .brand,
  .privacy-page .brand,
  .terms-page .brand,
  .community-page .brand,
  .business-page .brand,
  .get-started-page .brand,
  .get-started-business-page .brand,
  .choose-plan-page .brand,
  .payment-page .brand {
    gap: 12px;
    font-size: 1rem;
  }

  .home-page .bh-brand-mark,
  .blog-page .brand::before,
  .about-page .brand::before,
  .faqs-page .brand::before,
  .crisis-page .brand::before,
  .privacy-page .brand::before,
  .terms-page .brand::before,
  .community-page .brand::before,
  .business-page .brand::before,
  .get-started-page .brand::before,
  .get-started-business-page .brand::before,
  .choose-plan-page .brand::before,
  .payment-page .brand::before {
    width: 42px;
    height: 42px;
  }

  .home-page .bh-hero-title {
    font-size: clamp(32px, 10vw, 44px);
  }

  .home-page .bh-section-title {
    font-size: clamp(30px, 10vw, 40px);
  }

  .home-page .bh-hero-actions {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    gap: 10px;
  }

  .home-page .bh-hero-actions .bh-btn {
    width: 100%;
  }

  .home-page .bh-hero-stage {
    margin-top: 36px !important;
    padding: 18px 12px 14px !important;
    border-radius: 28px !important;
  }

  .home-page .bh-demo-phone {
    width: min(340px, 100%);
    padding: 10px;
  }

  .home-page .bh-demo-top,
  .home-page .bh-demo-ribbon,
  .home-page .bh-demo-task,
  .home-page .bh-demo-checkin {
    margin-left: 14px;
    margin-right: 14px;
  }

  .home-page .bh-demo-task-body,
  .home-page .bh-demo-checkin {
    padding: 16px;
  }

  .home-page .bh-demo-task-visual {
    min-height: 126px;
  }

  .home-page .bh-demo-task-icon {
    width: 82px;
    height: 82px;
  }

  .home-page .bh-benefits,
  .home-page .bh-how,
  .home-page .bh-get,
  .home-page .bh-about,
  .business-page .section,
  .blog-page .section,
  .about-page .section,
  .faqs-page .section,
  .crisis-page .section,
  .privacy-page .section,
  .terms-page .section,
  .community-page .section {
    padding-top: 72px;
    padding-bottom: 72px;
  }

  .home-page .bh-loop-diagram {
    width: min(300px, 100%) !important;
  }

  .home-page .bh-loop-ring::after {
    inset: 50px;
  }

  .home-page .bh-loop-core {
    inset: 94px;
  }

  .home-page .bh-loop-node {
    width: 46px;
    height: 46px;
  }

  .home-page .bh-footer,
  .crisis-page .bh-footer,
  .site-footer {
    padding: 56px 0 22px;
  }

  .home-page .bh-footer-grid,
  .crisis-page .bh-footer-grid,
  .site-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
}

/* ==========================================
   VERY SMALL PHONES
   ========================================== */
@media (max-width: 480px) {
  .home-page .bh-demo-phone {
    width: 100%;
  }

  .home-page .bh-demo-top,
  .home-page .bh-demo-ribbon,
  .home-page .bh-demo-task,
  .home-page .bh-demo-checkin {
    margin-left: 12px;
    margin-right: 12px;
  }

  .home-page .bh-loop-diagram {
    width: min(280px, 100%) !important;
  }
}
/* ==========================================
   EARLIER TABLET / HALF-LAPTOP FIX
   ========================================== */

@media (max-width: 800px) {
  /* header: logo + Badger only */
  .home-page .bh-header-inner,
  .blog-page .nav,
  .about-page .nav,
  .faqs-page .nav,
  .crisis-page .nav,
  .privacy-page .nav,
  .terms-page .nav,
  .community-page .nav,
  .business-page .nav,
  .get-started-page .nav,
  .get-started-business-page .nav {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    align-items: center !important;
    gap: 0 !important;
    padding: 18px 0 !important;
    min-height: auto !important;
  }

  .home-page .bh-nav,
  .home-page .bh-cta-nav,
  .blog-page .menu,
  .blog-page .cta-nav,
  .about-page .menu,
  .about-page .cta-nav,
  .faqs-page .menu,
  .faqs-page .cta-nav,
  .crisis-page .menu,
  .crisis-page .cta-nav,
  .privacy-page .menu,
  .privacy-page .cta-nav,
  .terms-page .menu,
  .terms-page .cta-nav,
  .community-page .menu,
  .community-page .cta-nav,
  .business-page .menu,
  .business-page .cta-nav,
  .get-started-business-page .menu,
  .get-started-business-page .cta-nav {
    display: none !important;
  }

  /* homepage purple pills: hide earlier */
  .home-page .bh-float {
    display: none !important;
  }

  /* keep hero stage tidy */
  .home-page .bh-hero-stage {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-top: 44px !important;
    min-height: auto !important;
    padding: 28px 18px 22px !important;
    border-radius: 32px !important;
    overflow: hidden !important;
  }

  .home-page .bh-hero-stage::after {
    display: none !important;
  }

  .home-page .bh-demo-frame {
    width: 100%;
    padding-top: 0;
  }

  .home-page .bh-demo-phone {
    width: min(390px, 100%);
    margin: 0 auto;
  }

  /* footer: stop awkward long-line layout sooner */
  .home-page .bh-footer-grid,
  .crisis-page .bh-footer-grid,
  .site-footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 26px !important;
  }

  .home-page .bh-footer-brand,
  .crisis-page .bh-footer-brand,
  .site-footer-brand {
    grid-column: 1 / -1;
  }
}
/* ==========================================
   HOMEPAGE HERO FLOAT FIX — MID DESKTOP
   scattered, straight, and safely inside viewport
   ========================================== */
@media (min-width: 1025px) and (max-width: 1450px) {
  .home-page .bh-hero-stage{
    min-height: 880px !important;
    padding: 34px 24px 20px !important;
  }

  .home-page .bh-demo-phone{
    width: min(390px, 100%) !important;
  }

  .home-page .bh-float{
    min-height: auto;
    padding: 10px 16px;
    font-size: 0.8rem;
    line-height: 1.25;
    white-space: normal;
    text-align: center;
    max-width: 230px;
    transform: none !important;
  }

  /* left side */
  .home-page .bh-float-1{
    top: 44px !important;
    left: max(20px, calc(50% - 610px)) !important;
    right: auto !important;
    max-width: 250px;
  }

  .home-page .bh-float-5{
    top: 250px !important;
    left: max(28px, calc(50% - 560px)) !important;
    right: auto !important;
    max-width: 210px;
  }

  .home-page .bh-float-9{
    top: 510px !important;
    left: max(18px, calc(50% - 640px)) !important;
    right: auto !important;
    max-width: 210px;
  }

  .home-page .bh-float-7{
    top: 740px !important;
    left: max(34px, calc(50% - 545px)) !important;
    right: auto !important;
    max-width: 230px;
  }

  /* right side */
  .home-page .bh-float-2{
    top: 82px !important;
    right: max(18px, calc(50% - 585px)) !important;
    left: auto !important;
    max-width: 210px;
  }

  .home-page .bh-float-6{
    top: 350px !important;
    right: max(30px, calc(50% - 545px)) !important;
    left: auto !important;
    max-width: 250px;
  }

  .home-page .bh-float-10{
    top: 600px !important;
    right: max(18px, calc(50% - 635px)) !important;
    left: auto !important;
    max-width: 230px;
  }

  .home-page .bh-float-8{
    top: 820px !important;
    right: max(34px, calc(50% - 520px)) !important;
    left: auto !important;
    max-width: 190px;
  }

  /* keep these hidden in this range */
  .home-page .bh-float-3,
  .home-page .bh-float-4{
    display: none !important;
  }
}

/* slightly narrower desktop: reduce size a bit more so nothing clips */
@media (min-width: 1025px) and (max-width: 1180px) {
  .home-page .bh-float{
    font-size: 0.76rem;
    padding: 9px 14px;
    max-width: 200px;
  }

  .home-page .bh-float-1{ top: 42px !important; }
  .home-page .bh-float-5{ top: 238px !important; }
  .home-page .bh-float-9{ top: 490px !important; }
  .home-page .bh-float-7{ top: 710px !important; }

  .home-page .bh-float-2{ top: 78px !important; }
  .home-page .bh-float-6{ top: 332px !important; }
  .home-page .bh-float-10{ top: 575px !important; }
  .home-page .bh-float-8{ top: 790px !important; }
}
/* ==========================================
   HOMEPAGE BENEFITS — keep 3 across,
   then jump straight to centred 1-column
   ========================================== */

.home-page .bh-benefit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  align-items:stretch;
}

.home-page .bh-benefit-grid > *{
  min-width:0;
}

.home-page .bh-benefit-card{
  height:100%;
  min-height:360px;
  display:flex;
  flex-direction:column;
}

.home-page .bh-icon-box{
  width:100%;
  max-width:none;
  height:auto;
  aspect-ratio:4 / 5;
  margin-bottom:22px;
}

/* as soon as 3 columns stop fitting nicely,
   go straight to 1 centred column */
@media (max-width: 1210px){
  .home-page .bh-benefit-grid{
    grid-template-columns:1fr !important;
    max-width:460px;
    margin:0 auto;
  }

  .home-page .bh-benefit-card{
    width:100%;
    min-height:360px;
  }
}

@media (max-width: 640px){
  .home-page .bh-benefit-grid{
    max-width:420px;
  }

  .home-page .bh-benefit-card{
    padding:24px;
  }
}
/* ==========================================
   HOMEPAGE HOW IT WORKS — keep chart first,
   then stack 1 / 2 / 3 underneath
   ========================================== */
@media (max-width: 1180px) {
  .home-page .bh-loop-shell {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 20px !important;
  }

  .home-page .bh-loop-diagram {
    order: 1;
    width: min(420px, 100%) !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    margin: 0 auto !important;
    flex: 0 0 auto;
  }

  .home-page .bh-loop-card-1,
  .home-page .bh-loop-card-2,
  .home-page .bh-loop-card-3 {
    order: unset;
    width: min(760px, 100%) !important;
    max-width: 760px !important;
    margin: 0 auto !important;
    justify-self: auto !important;
    align-self: stretch !important;
  }

  .home-page .bh-loop-card-1 { order: 2 !important; }
  .home-page .bh-loop-card-2 { order: 3 !important; }
  .home-page .bh-loop-card-3 { order: 4 !important; }

  .home-page .bh-loop-card,
  .home-page .bh-loop-card-1,
  .home-page .bh-loop-card-2,
  .home-page .bh-loop-card-3 {
    padding: 24px !important;
  }
}
/* ==========================================
   HOMEPAGE "BUILT TO MOVE YOU" IMAGE BOX
   keep original proportion at all sizes
   ========================================== */

.home-page .bh-about-pledge-bar{
  width:min(400px, 100%) !important;
  max-width:400px !important;
  aspect-ratio:2 / 3 !important;   /* matches 400 x 600 */
  min-height:0 !important;
  height:auto !important;
  margin:34px auto 0 !important;
}

@media (max-width: 1024px){
  .home-page .bh-about-pledge-bar{
    width:min(360px, 100%) !important;
    border-radius:24px !important;
  }
}

@media (max-width: 640px){
  .home-page .bh-about-pledge-bar{
    width:min(280px, 100%) !important;
    margin-top:26px !important;
    border-radius:22px !important;
  }
}
/* ==========================================
   ABOUT PAGE — keep purple card above text
   when stacked into 1 column
   ========================================== */

@media (max-width: 1120px){
  .about-page .about-layout > .about-illustration{
    order: 1;
  }

  .about-page .about-layout > .about-copy{
    order: 2;
  }
}
/* ==========================================
   BUSINESS PAGE — benefit cards responsive fix
   keeps image box proportional and jumps
   from 3 columns straight to 1 column
   ========================================== */

/* desktop */
.business-page .biz-benefit-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  align-items:stretch;
}

.business-page .biz-card,
.business-page .biz-benefit-card{
  width:100%;
  min-width:0;
}

.business-page .biz-benefit-card{
  min-height:auto !important;
  display:flex;
  flex-direction:column;
}

.business-page .biz-card-icon{
  width:100% !important;
  max-width:none !important;
  height:auto !important;
  aspect-ratio:1 / 1;   /* keeps same proportion as desktop square box */
  margin-bottom:18px;
  flex:0 0 auto;
}

/* once 3-across gets too tight, go straight to 1 column */
@media (max-width: 1180px){
  .business-page .biz-benefit-grid{
    grid-template-columns:1fr !important;
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
  }

  .business-page .biz-card-icon{
    width:100% !important;
    aspect-ratio:1 / 1;
  }
}

/* mobile tidy-up */
@media (max-width: 640px){
  .business-page .biz-benefit-card{
    padding:24px;
  }

  .business-page .biz-benefit-grid{
    max-width:none;
  }
}
@media (max-width: 640px){
  .privacy-page .privacy-article,
  .terms-page .terms-article,
  .community-page .community-article{
    padding-left: 6px;
    padding-right: 6px;
  }

  .privacy-page .privacy-section,
  .terms-page .terms-section,
  .community-page .community-section{
    padding-left: 0;
    padding-right: 0;
  }

  .privacy-page .p2,
  .terms-page .p2,
  .community-page .p2{
    line-height: 1.8;
  }
}