/* ===== BreatheLab shared stylesheet ===== */
:root{
  --ink:#11211f; --ink-soft:#3f5450; --line:#e3e8e6; --bg:#fbfcfb;
  --paper:#ffffff; --brand:#0e8a8f; --brand-dark:#0b3a45; --brand-soft:#e6f4f4;
  --gold:#c98a18; --good:#1f9d6b; --warn:#c2553f;
  --shadow:0 1px 2px rgba(11,58,69,.05), 0 8px 28px rgba(11,58,69,.07);
  --radius:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,-apple-system,system-ui,sans-serif;color:var(--ink);
     background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.serif{font-family:Fraunces,Georgia,serif;font-weight:600;line-height:1.18;letter-spacing:-.01em}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1020px;margin:0 auto;padding:0 22px}
.wrap.narrow{max-width:880px}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(251,252,251,.88);
     backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:62px;
     max-width:1020px;margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:9px;font-family:Fraunces,serif;font-weight:600;
     font-size:21px;color:var(--ink)}
.brand .dot{width:13px;height:13px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.brand .byb{font-family:Inter,sans-serif;font-size:11px;font-weight:500;color:var(--ink-soft);
     letter-spacing:0;margin-left:7px;align-self:center;white-space:nowrap}
@media(max-width:420px){.brand .byb{display:none}}
.nav a.brand:hover{text-decoration:none}
.navlinks{display:flex;gap:24px;font-size:14.5px;font-weight:500}
.navlinks a{color:var(--ink-soft)}
@media(max-width:680px){.navlinks{display:none}}

/* Hero / shared bits */
.crumb{font-size:13px;color:var(--ink-soft);padding:20px 0 0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;
     letter-spacing:.08em;text-transform:uppercase;color:var(--brand);
     background:var(--brand-soft);padding:6px 12px;border-radius:999px}
.hero{padding:40px 0 14px}
h1{font-size:clamp(31px,5vw,50px);margin:16px 0 13px}
.lede{font-size:19px;color:var(--ink-soft);max-width:62ch;margin:0}
.byline{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;margin-top:20px;font-size:13px;color:var(--ink-soft)}
.byline .who{font-weight:600;color:var(--ink)}
.byline .pill{background:var(--paper);border:1px solid var(--line);padding:4px 11px;border-radius:999px}

/* Answer box (AEO snippet bait) */
.answer{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--brand);
     border-radius:var(--radius);padding:22px 24px;margin:26px 0;box-shadow:var(--shadow)}
.answer .tag{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.answer p{margin:0;font-size:16.5px} .answer strong{color:var(--ink)}

section{padding:28px 0}
section h2{font-size:clamp(25px,3.4vw,34px);margin:0 0 6px}
section .sub{color:var(--ink-soft);margin:0 0 22px;max-width:64ch}
p{margin:0 0 14px}

/* Award cards */
.awards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:30px 0}
@media(max-width:820px){.awards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.awards{grid-template-columns:1fr}}
.award{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.award .k{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--gold)}
.award .n{font-family:Fraunces,serif;font-size:19px;margin:7px 0 3px}
.award .s{font-size:13px;color:var(--ink-soft)}
.award .score{font-weight:700;color:var(--brand);font-size:13px;margin-top:9px}

/* Tables */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);box-shadow:var(--shadow);margin:8px 0 18px}
table{border-collapse:collapse;width:100%;min-width:560px;font-size:14.5px}
thead th{text-align:left;background:var(--brand-dark);color:#eafafa;font-weight:600;padding:13px 14px;font-size:13px}
tbody td{padding:13px 14px;border-top:1px solid var(--line);vertical-align:top}
tbody tr:nth-child(even){background:#fafcfb}
td.attr{font-weight:600}
.win-cell{color:var(--good);font-weight:600}
.rank{font-family:Fraunces,serif;font-weight:600;color:var(--brand);font-size:18px}
.prod{font-weight:600;color:var(--ink)}
.prodtype{display:block;font-size:12px;color:var(--ink-soft);font-weight:500}
.scorebadge{display:inline-block;min-width:42px;text-align:center;font-weight:700;color:#fff;border-radius:8px;padding:4px 8px;font-size:14px}
.bestfor{color:var(--ink-soft)} .price{font-weight:600;white-space:nowrap}

/* Pros / cons */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
@media(max-width:640px){.twocol{grid-template-columns:1fr}}
.pc{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px}
.pc h4{margin:0 0 8px;font-size:14px;font-family:Inter;font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.pc.pro h4{color:var(--good)} .pc.con h4{color:var(--warn)}
.pc ul{margin:0;padding-left:18px;font-size:14.5px;color:var(--ink-soft)} .pc li{margin:5px 0}

/* Explainer */
.qa{border-top:1px solid var(--line);padding:24px 0}
.qa:first-of-type{border-top:none}
.qa h3{font-size:21px;margin:0 0 8px}

/* Methodology block */
.method{background:var(--brand-dark);color:#dff0f0;border-radius:var(--radius);padding:30px}
.method h2{color:#fff} .method .sub{color:#a9cdcd}
.method .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:18px}
@media(max-width:700px){.method .grid{grid-template-columns:repeat(2,1fr)}}
.method .m k{display:block;font-size:30px;font-family:Fraunces,serif;color:#fff}
.method .m span{font-size:13px;color:#a9cdcd}

/* FAQ */
details{background:var(--paper);border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
summary{cursor:pointer;padding:16px 18px;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:22px;color:var(--brand);font-weight:400}
details[open] summary::after{content:"\2212"}
details .body{padding:0 18px 18px;color:var(--ink-soft);font-size:15px}

/* Disclaimer + footer */
.disclaimer{font-size:12.5px;color:var(--ink-soft);background:#fff7ee;border:1px solid #f0e0c8;border-radius:12px;padding:14px 16px;margin:22px 0}
footer{border-top:1px solid var(--line);margin-top:40px;padding:30px 0 60px;color:var(--ink-soft);font-size:13.5px}
.footgrid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;max-width:1020px;margin:0 auto;padding:0 22px}
.cta{display:inline-block;background:var(--brand);color:#fff;font-weight:600;padding:11px 20px;border-radius:10px;margin-top:6px}
.cta:hover{text-decoration:none;background:#0b7479}

/* ===== Review-page specific ===== */
/* Verdict cards */
.verdict{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:26px 0}
@media(max-width:560px){.verdict{grid-template-columns:1fr}}
.vcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.vcard.win{border:2px solid var(--brand)}
.vcard .badge{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--gold)}
.vcard h3{margin:8px 0 2px;font-size:23px}
.vcard .score{font-weight:700;color:var(--brand);margin:2px 0 10px}
.vcard p{margin:0;font-size:14.5px;color:var(--ink-soft)}

/* Review scorecard at-a-glance */
.scorecard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px;margin:24px 0}
.scorecard .head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.scorecard .total{font-family:Fraunces,serif;font-size:34px;color:var(--brand)}
.scorecard .total small{font-size:16px;color:var(--ink-soft)}
.bar{display:grid;grid-template-columns:130px 1fr 38px;align-items:center;gap:12px;margin:9px 0;font-size:14px}
.bar .track{height:9px;background:#eef2f1;border-radius:999px;overflow:hidden}
.bar .fill{height:100%;background:var(--brand);border-radius:999px}
.bar .val{text-align:right;font-weight:600;color:var(--ink-soft)}

/* Spec / info table */
.specs{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper);margin:18px 0}
@media(max-width:560px){.specs{grid-template-columns:1fr}}
.specs .row{display:flex;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line);font-size:14px}
.specs .row k{color:var(--ink-soft)} .specs .row b{text-align:right}

/* Photo figures + grid */
.photos{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:10px 0 6px}
@media(max-width:680px){.photos{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.photos{grid-template-columns:1fr}}
figure{margin:0}
figure img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid var(--line);background:#f4f7f6}
/* graceful placeholder when image missing */
figure.slot{position:relative;border:2px dashed #cdd9d7;border-radius:12px;background:#f4f7f6;
     min-height:170px;display:flex;align-items:center;justify-content:center;text-align:center;
     color:#8aa19d;font-size:13px;padding:16px}
figure.slot::before{content:"📷 "attr(data-label)}
figure figcaption{font-size:12.5px;color:var(--ink-soft);margin-top:6px;text-align:center}

/* Editorial note (team fills in) */
.note{background:#fffbe9;border:1px solid #f2e6b8;border-left:4px solid var(--gold);
     border-radius:10px;padding:14px 16px;margin:12px 0;font-size:14px;color:#6b5a1f}
.note b{color:#4d4011}

/* Review section heads with step number */
.rsec{border-top:1px solid var(--line);padding:30px 0}
.rsec .step{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand)}
.rsec h2{margin:6px 0 12px}

/* Product card grid (homepage reviews row) */
.reviewgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(225px,1fr));gap:16px;margin:18px 0}
@media(max-width:520px){.reviewgrid{grid-template-columns:1fr}}
.rcard{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
     padding:20px;box-shadow:var(--shadow);color:inherit}
.rcard:hover{text-decoration:none;transform:translateY(-2px);transition:.15s;border-color:var(--brand)}
.rcard .t{font-family:Fraunces,serif;font-size:20px;margin:2px 0 4px}
.rcard .meta{font-size:13px;color:var(--ink-soft)}
.rcard .sc{display:inline-block;margin-top:10px;font-weight:700;color:#fff;border-radius:8px;padding:3px 9px;font-size:13px}
.rcard .verdict-line{font-size:13.5px;color:var(--ink-soft);margin-top:10px}

/* Guide grid (homepage "by use case") */
.guidegrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:10px;margin:16px 0}
.guidegrid a{display:block;background:var(--paper);border:1px solid var(--line);border-radius:10px;
     padding:13px 15px;font-weight:600;font-size:14.5px;color:var(--ink);box-shadow:var(--shadow)}
.guidegrid a:hover{text-decoration:none;border-color:var(--brand);color:var(--brand);transform:translateY(-1px);transition:.15s}
.guidegrid a span{display:block;font-weight:400;font-size:12.5px;color:var(--ink-soft);margin-top:2px}
.guidegrid .head{grid-column:1/-1;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
     color:var(--ink-soft);margin:8px 0 0;box-shadow:none;border:none;background:none;padding:0}

/* Hero CTA buttons */
.herobtns{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.cta-ghost{display:inline-block;background:var(--paper);color:var(--ink);border:1px solid var(--line);
     font-weight:600;padding:11px 20px;border-radius:10px}
.cta-ghost:hover{text-decoration:none;border-color:var(--brand);color:var(--brand)}

/* Trust stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:28px 0;
     background:var(--brand-dark);border-radius:var(--radius);padding:24px 18px}
@media(max-width:640px){.statband{grid-template-columns:repeat(2,1fr);gap:20px 12px}}
.statband .stat{text-align:center}
.statband .stat k{display:block;font-family:Fraunces,serif;font-size:31px;color:#fff;line-height:1.05}
.statband .stat span{font-size:12.5px;color:#a9cdcd}

/* Trust pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:26px 0}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.pillar .ic{font-size:25px;margin-bottom:8px}
.pillar h3{font-size:16.5px;margin:0 0 6px}
.pillar p{margin:0;font-size:14px;color:var(--ink-soft)}

/* Quote / social-proof strip */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0}
@media(max-width:760px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.quote .stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-bottom:10px}
.quote p{margin:0 0 14px;font-size:15px;color:var(--ink);line-height:1.55}
.quote .src{font-size:12.5px;color:var(--ink-soft);font-weight:600;margin-top:auto}

/* Review-card thumbnail */
.rcard .thumb{width:100%;height:130px;object-fit:cover;border-radius:10px;border:1px solid var(--line);
     background:#f4f7f6;margin-bottom:13px;display:block}

/* Email capture */
.capture{background:var(--brand-soft);border:1px solid #cfe7e7;border-radius:var(--radius);padding:32px 28px;margin:26px 0;text-align:center}
.capture h2{margin:0 0 6px}
.capture .csub{margin:0 auto 18px;max-width:54ch;color:var(--ink-soft)}
.capture form{display:flex;gap:10px;max-width:470px;margin:0 auto;flex-wrap:wrap}
.capture input[type=email]{flex:1;min-width:200px;padding:12px 14px;border:1px solid #b9d7d7;border-radius:10px;font-size:15px;font-family:inherit}
.capture button{border:none;cursor:pointer}
.capture .msg{font-size:14px;margin-top:12px;min-height:1.1em;font-weight:600;color:var(--brand)}
.capture .fine{font-size:12px;color:var(--ink-soft);margin-top:10px}

/* Find-your-fit quiz */
.quiz{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}
.quiz .progress{height:6px;background:#eef2f1;border-radius:999px;overflow:hidden;margin-bottom:18px}
.quiz .progress span{display:block;height:100%;background:var(--brand);width:33%;transition:width .25s}
.quiz .q{display:none}
.quiz .q.active{display:block}
.quiz .qnum{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand)}
.quiz .q h3{font-size:21px;margin:5px 0 14px}
.quiz .opts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(max-width:560px){.quiz .opts{grid-template-columns:1fr}}
.quiz .opt{text-align:left;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 16px;
     font-size:14.5px;font-weight:500;cursor:pointer;font-family:inherit;color:var(--ink);transition:.12s}
.quiz .opt:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-1px)}
.quiz .result{display:none}
.quiz .result.show{display:block}
.quiz .result .rec{display:flex;gap:16px;align-items:center;background:var(--brand-soft);border:1px solid #cfe7e7;
     border-radius:12px;padding:18px 20px;margin-top:6px;flex-wrap:wrap}
.quiz .result .rec .sc{font-weight:700;color:#fff;background:var(--brand);border-radius:8px;padding:4px 10px;font-size:14px}
.quiz .result .rec .body{flex:1;min-width:200px}
.quiz .result .rec .body .t{font-family:Fraunces,serif;font-size:20px}
.quiz .result .rec .body .w{font-size:14px;color:var(--ink-soft);margin:3px 0 0}
.quiz .restart{margin-top:14px;font-size:13.5px;background:none;border:none;color:var(--brand);cursor:pointer;font-family:inherit;font-weight:600}
