/* BBE Buddy — site chrome (buttons, nav, sections, footer) */

.wrap{ max-width:1240px; margin:0 auto; padding:0 44px; }
.wrap-n{ max-width:1000px; margin:0 auto; padding:0 44px; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:700; font-size:16px; padding:14px 24px; border-radius:100px; text-decoration:none; border:0; cursor:pointer; transition:transform .15s, background .2s, color .2s, box-shadow .2s; }
.btn .arr{ transition:transform .2s; }
.btn:hover .arr{ transform:translateX(3px); }
.btn-gold{ background:var(--gold); color:var(--ink); }
.btn-gold:hover{ transform:translateY(-2px); background:#fff; }
.btn-white{ background:#fff; color:var(--ink); }
.btn-white:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -16px rgba(0,0,0,.4); }
.btn-line-w{ background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px color-mix(in srgb,#fff 40%,transparent); }
.btn-line-w:hover{ box-shadow:inset 0 0 0 1.5px #fff; }
.btn-ink{ background:var(--ink); color:#fff; }
.btn-ink:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -16px rgba(28,43,39,.6); }
.btn-teal{ background:var(--teal); color:#fff; }
.btn-teal:hover{ transform:translateY(-2px); background:var(--teal-d); }
.btn-line{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--ink) 24%,transparent); }
.btn-line:hover{ box-shadow:inset 0 0 0 1.5px var(--ink); }
.btn-sm{ padding:10px 18px; font-size:15px; }

/* ---------- header / nav ---------- */
header.nav{ position:sticky; top:0; z-index:60; transition:background .25s, box-shadow .25s; }
header.nav.on-color{ position:absolute; top:0; left:0; right:0; }
.nav-in{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:28px; }
.brand-lock{ display:flex; align-items:center; gap:13px; text-decoration:none; }
.nav .logo{ height:42px; width:auto; }
.brand-lock .prod{ font-family:var(--font-display); font-weight:800; font-size:14px; letter-spacing:.04em; padding:5px 11px; border-radius:8px; line-height:1; }
.nav ul{ display:flex; gap:30px; list-style:none; margin:0; padding:0; font-weight:600; font-size:15.5px; align-items:center; }
.nav ul a{ text-decoration:none; transition:color .2s; }
.nav-cta{ display:flex; align-items:center; gap:16px; }
.nav-cta .signin{ font-family:var(--font-display); font-weight:700; font-size:15px; text-decoration:none; transition:color .2s; }

/* light header (default, on paper) */
header.nav{ background:color-mix(in srgb,var(--paper) 90%,transparent); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
header.nav .prod{ background:var(--teal); color:#fff; }
header.nav ul a{ color:var(--ink-2); }
header.nav ul a:hover, header.nav ul a.active{ color:var(--teal); }
header.nav .signin{ color:var(--ink); }
header.nav .signin:hover{ color:var(--teal); }

/* header sitting on a colour hero */
header.nav.on-color{ background:transparent; backdrop-filter:none; border-bottom:0; }
header.nav.on-color .prod{ background:color-mix(in srgb,#fff 16%,transparent); color:#fff; }
header.nav.on-color ul a{ color:color-mix(in srgb,#fff 82%,transparent); }
header.nav.on-color ul a:hover, header.nav.on-color ul a.active{ color:#fff; }
header.nav.on-color .signin{ color:#fff; }

/* ---------- section base ---------- */
section.band{ padding:104px 0; }
.kicker{ font-family:var(--font-display); font-weight:800; font-size:14px; text-transform:uppercase; letter-spacing:.16em; display:inline-flex; align-items:center; gap:10px; color:var(--teal); }
.kicker::before{ content:""; width:26px; height:3px; background:var(--coral); border-radius:2px; }
.sec-head{ max-width:760px; }
.sec-head h2{ font-size:clamp(34px,4.4vw,58px); font-weight:900; letter-spacing:-0.03em; margin:18px 0 0; }
.sec-head p{ font-size:20px; color:var(--ink-2); margin:18px 0 0; }

/* color stripe */
.stripe{ display:flex; height:14px; }
.stripe i{ flex:1; display:block; }

/* generic page hero (inner pages) */
.page-hero{ background:var(--teal); color:#fff; padding:150px 0 0; position:relative; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; right:-120px; top:-120px; width:420px; height:420px; border-radius:50%; background:color-mix(in srgb,#fff 8%,transparent); }
.page-hero .eyebrow{ font-size:14px; color:var(--gold); display:inline-flex; align-items:center; gap:10px; text-transform:uppercase; letter-spacing:.14em; font-weight:700; }
.page-hero .eyebrow::before{ content:""; width:30px; height:3px; background:var(--gold); border-radius:2px; }
.page-hero h1{ font-size:clamp(42px,5.6vw,80px); font-weight:900; letter-spacing:-0.035em; margin:22px 0 0; max-width:17ch; }
.page-hero h1 .o{ color:var(--gold); }
.page-hero p.lead{ font-size:21px; color:color-mix(in srgb,#fff 86%,transparent); max-width:52ch; margin:22px 0 0; padding-bottom:64px; }

/* ---------- footer ---------- */
footer.site{ background:var(--paper-2); border-top:1px solid var(--line); padding:64px 0 40px; }
.foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
footer.site .logo{ height:46px; margin-bottom:16px; }
footer.site p.tag{ color:var(--ink-2); font-size:15px; max-width:34ch; }
footer.site h5{ font-family:var(--font-display); font-size:13px; text-transform:uppercase; letter-spacing:.12em; margin:0 0 16px; }
footer.site ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
footer.site ul a{ text-decoration:none; color:var(--ink-2); font-size:15px; }
footer.site ul a:hover{ color:var(--teal); }
.foot-bot{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:54px; padding-top:24px; border-top:1px solid var(--line); font-size:13px; color:var(--ink-2); }
.foot-bot .compliance{ display:inline-flex; align-items:center; gap:8px; }
.foot-bot .dot-eu{ width:8px; height:8px; border-radius:50%; background:var(--mint); }

@media (max-width:980px){
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .nav ul{ display:none; }
  .nav-in{ height:72px; }
}
@media (max-width:560px){ .foot-grid{ grid-template-columns:1fr; } .wrap,.wrap-n{ padding:0 24px; } }
