﻿@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800&family=Manrope:wght@400;500;700;800&display=swap');

:root{
  --bg:#f2f6f5;
  --panel:#ffffff;
  --panel-strong:#0f1f2e;
  --text:#13212d;
  --muted:#5a6977;
  --line:#d7e2ea;
  --primary:#007a64;
  --primary-strong:#005746;
  --accent:#ff6b2c;
  --shadow:0 20px 45px rgba(12,33,46,.14);
  --radius-xl:26px;
  --radius-lg:18px;
  --radius-md:12px;
  --shell-width:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope", "Segoe UI", Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 10% -5%, rgba(0,122,100,.18), transparent 28%),
    radial-gradient(circle at 96% 0%, rgba(255,107,44,.14), transparent 24%),
    linear-gradient(180deg,#f8fcfb 0%,#f2f6f5 56%,#e8efed 100%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.site-shell{width:min(100%,var(--shell-width));margin:0 auto;padding:30px 20px 64px}

.site-header{
  position:sticky;
  top:0;
  z-index:30;
  backdrop-filter:blur(12px);
  background:rgba(247,251,250,.9);
  border-bottom:1px solid rgba(19,33,45,.08);
}
.site-header-inner{width:min(100%,var(--shell-width));margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand-lockup{display:flex;align-items:center;gap:14px;min-width:0}
.brand-lockup img{width:50px;height:50px;border-radius:14px;box-shadow:0 12px 26px rgba(10,35,49,.22)}
.brand-copy{min-width:0}
.brand-name{font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:1.9rem;font-weight:800;letter-spacing:.04em;line-height:1;text-transform:uppercase}
.brand-tagline{color:var(--muted);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.nav-toggle{display:none;border:none;background:var(--panel);color:var(--text);border-radius:12px;padding:10px 14px;box-shadow:var(--shadow)}
.nav-links{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.nav-links a{font-weight:700;color:#334556}
.nav-links a:hover{color:var(--primary)}

.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;margin-top:20px}
.hero-card,.panel,.article-card,.feature-card,.legal-card,.article-body,.detail-sidebar-card{
  background:var(--panel);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  border:1px solid rgba(19,33,45,.08);
}
.hero-card{
  position:relative;
  overflow:hidden;
  padding:34px;
  color:#f5fbff;
  background:linear-gradient(145deg,#0e2432 0%,#0b5a5f 58%,#0a8269 100%);
}
.hero-card::before{
  content:"";
  position:absolute;
  width:280px;
  height:280px;
  right:-95px;
  top:-90px;
  border-radius:999px;
  background:rgba(255,107,44,.25);
}
.hero-card::after{
  content:"";
  position:absolute;
  width:230px;
  height:230px;
  left:-76px;
  bottom:-120px;
  border-radius:999px;
  background:rgba(150,235,227,.25);
}
.hero-kicker,.section-kicker,.article-kicker,.mini-kicker{
  font-family:"Barlow Condensed", "Arial Narrow", sans-serif;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.hero-kicker{font-size:.95rem;color:rgba(236,246,252,.85)}
.hero-title{position:relative;z-index:1;margin:14px 0 16px;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:clamp(2.5rem,5vw,4.3rem);line-height:.92;max-width:12ch;text-transform:uppercase}
.hero-copy{position:relative;z-index:1;max-width:56ch;color:rgba(244,250,255,.9);font-size:1.03rem;line-height:1.7}
.hero-actions{position:relative;z-index:1;margin-top:22px;display:flex;gap:12px;flex-wrap:wrap}
.button,.button-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 20px;border-radius:999px;font-weight:800}
.button{background:#fff;color:#0f2530}
.button-secondary{border:1px solid rgba(255,255,255,.35);color:#f8fdff}

.hero-aside{display:grid;gap:18px}
.score-strip{padding:22px;background:linear-gradient(180deg,#ffffff 0%,#edf4f2 100%)}
.score-strip h2,.section-title,.article-section h2,.detail-sidebar-card h2,.legal-card h1{margin:0;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;letter-spacing:.04em;text-transform:uppercase}
.score-grid{margin-top:16px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.score-box{padding:16px;border-radius:var(--radius-md);background:linear-gradient(140deg,#102838 0%,#0e4454 100%);color:#fff}
.score-value{font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:2.3rem;line-height:1}
.score-label{margin-top:8px;font-size:.88rem;color:rgba(243,250,255,.75)}
.insight-panel{padding:20px;background:linear-gradient(140deg,#ffffff 0%,#edf6f8 100%)}
.insight-panel h3{margin:0 0 8px;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:1.5rem;text-transform:uppercase;letter-spacing:.03em}
.insight-panel p{margin:0;color:var(--muted)}

.section{margin-top:30px}
.section-heading{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:16px}
.section-kicker{color:var(--accent);font-size:.92rem}
.section-title{font-size:clamp(2rem,4vw,3.2rem)}
.section-subtitle{color:var(--muted);max-width:56ch}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature-card{overflow:hidden}
.feature-card img{aspect-ratio:16/10;object-fit:cover}
.feature-content{padding:20px}
.mini-kicker{color:var(--accent);font-size:.82rem}
.feature-title,.article-title-link,.related-card-title{margin:10px 0 8px;font-weight:800;line-height:1.15}
.feature-title{font-size:1.3rem}
.meta-row{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}

.category-blocks{display:grid;gap:20px}
.category-block{padding:22px;position:relative;overflow:hidden}
.category-block::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg,var(--accent) 0%,var(--primary) 100%)}
.category-title-row{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;margin-bottom:14px}
.category-title{margin:0;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:2.05rem;text-transform:uppercase;letter-spacing:.03em}

.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.article-card{overflow:hidden}
.article-card img,.related-card img{aspect-ratio:16/10;object-fit:cover}
.article-card-body,.related-card-body{padding:18px}
.article-kicker{font-size:.82rem;color:var(--primary);font-weight:700}
.article-title-link{font-size:1.15rem}
.article-summary,.legal-card p,.article-section p,.article-intro,.related-card-summary,.detail-sidebar-card p,.detail-sidebar-card li,.footer-copy{color:var(--muted)}

.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;margin-top:24px}
.article-body{overflow:hidden}
.article-hero{padding:32px;background:linear-gradient(130deg,#ffffff 0%,#ebf5f2 100%);border-bottom:1px solid var(--line)}
.article-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(0,122,100,.13);color:var(--primary);font-weight:800}
.article-hero h1{margin:14px 0 12px;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:clamp(2.1rem,4.4vw,3.8rem);line-height:.95;text-transform:uppercase;letter-spacing:.02em}
.article-lead-image{border-radius:20px;overflow:hidden;margin-top:22px;border:1px solid rgba(19,33,45,.1)}
.article-content{padding:28px 32px 34px}
.article-intro{font-size:1.06rem;line-height:1.74}
.insight-box,.detail-sidebar-card{padding:20px}
.insight-box{margin:22px 0;border-radius:var(--radius-lg);background:linear-gradient(140deg,#0f2435 0%,#10465b 100%);color:#f7fcff}
.insight-box h2{margin-bottom:12px;font-size:1.72rem}
.insight-box ul,.detail-sidebar-card ul{margin:0;padding-left:18px}
.article-section + .article-section{margin-top:22px}
.article-section h2{margin-bottom:10px;font-size:1.74rem}
.article-section p{margin:0 0 12px;font-size:1rem;line-height:1.75}

.detail-sidebar{display:grid;gap:18px;align-self:start;position:sticky;top:94px}
.related-grid{display:grid;gap:14px}
.related-card{border-radius:18px;overflow:hidden;border:1px solid rgba(19,33,45,.09);background:#fff}
.related-card-title{font-size:1rem}

.legal-wrap{max-width:920px;margin:24px auto 0}
.legal-card{padding:30px}
.legal-card h1{font-size:clamp(2.1rem,3.5vw,3.2rem);margin-bottom:12px}
.legal-card h2{margin:18px 0 8px;font-family:"Barlow Condensed", "Arial Narrow", sans-serif;font-size:1.35rem;text-transform:uppercase;letter-spacing:.04em}
.legal-card p{margin:0 0 12px;font-size:1.03rem;line-height:1.75}
.legal-card ul{margin:0 0 12px;padding-left:18px;color:var(--muted)}

.footer{margin-top:36px;padding-top:18px;border-top:1px solid rgba(19,33,45,.12);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center}
.footer-nav{display:flex;gap:14px;flex-wrap:wrap}
.footer-nav a{color:var(--muted);font-weight:800}
.footer-nav a:hover{color:var(--primary)}

.site-tactic .section-heading{align-items:flex-start;flex-direction:column}
.site-tactic .brand-name{letter-spacing:.06em}

@media (max-width:1100px){
  .feature-grid,.article-grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:980px){
  .hero,.detail-layout,.feature-grid,.article-grid{grid-template-columns:1fr}
  .detail-sidebar{position:static}
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;
    left:20px;
    right:20px;
    top:calc(100% + 10px);
    padding:16px;
    border-radius:18px;
    background:#ffffff;
    box-shadow:var(--shadow);
    display:none;
    flex-direction:column;
    align-items:flex-start;
  }
  .nav-links.is-open{display:flex}
}

@media (max-width:640px){
  .site-shell,.site-header-inner{padding-left:14px;padding-right:14px}
  .hero-card,.article-hero,.article-content,.category-block,.legal-card{padding:22px}
  .score-grid{grid-template-columns:1fr}
  .brand-name{font-size:1.5rem}
  .brand-tagline{font-size:.84rem}
}

.tbh-ad-block{
  margin:22px auto;
  max-width:390px;
  padding:10px 10px 14px;
  border-radius:14px;
  border:1px dashed #b7c8db;
  background:#f3f9ff;
  text-align:center;
}
.tbh-ad-label{
  display:block;
  margin-bottom:8px;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#5f6f84;
}
.tbh-ad-slot{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:250px;
  min-height:250px;
  margin:0 auto;
}
.tbh-ad-slot-anchor{min-width:300px;min-height:50px}
.tbh-ad-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:inherit;
  border:1px dashed #9fb2cb;
  background:#edf4fc;
  color:#4a5c75;
  font-size:13px;
  font-weight:700;
}
.tbh-hidden{display:none !important}

.tbh-top-anchor-wrap,.tbh-bottom-anchor-wrap{
  position:fixed;
  left:0;
  right:0;
  z-index:1200;
  display:flex;
  justify-content:center;
  pointer-events:none;
}
.tbh-top-anchor-wrap{top:0}
.tbh-bottom-anchor-wrap{bottom:0}
.tbh-top-anchor-wrap .tbh-ad-block,.tbh-bottom-anchor-wrap .tbh-ad-block{
  margin:0;
  border-radius:0;
  border:1px solid #b7c8db;
  background:rgba(243,249,255,.97);
  pointer-events:auto;
}
.tbh-top-anchor-wrap .tbh-ad-slot,.tbh-bottom-anchor-wrap .tbh-ad-slot{min-height:50px}
body.tbh-has-top-anchor{padding-top:86px}
body.tbh-has-bottom-anchor{padding-bottom:86px}
body.tbh-has-top-anchor .site-header{top:86px}

.tbh-interstitial{
  position:fixed;
  inset:0;
  z-index:1400;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(9,17,29,.76);
}
.tbh-interstitial.is-visible{display:flex}
.tbh-interstitial-card{position:relative;width:min(96vw,420px)}
.tbh-interstitial-close{
  position:absolute;
  top:-12px;
  right:-12px;
  width:34px;
  height:34px;
  border:0;
  border-radius:999px;
  background:#0f1f2e;
  color:#fff;
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
.tbh-ad-block-interstitial{
  margin:0;
  max-width:none;
  padding:12px;
  border-radius:16px;
  border:1px solid #cfddec;
  background:#fff;
}
.tbh-ad-block-interstitial .tbh-ad-slot{min-width:250px;min-height:250px}

@media (max-width:640px){
  body.tbh-has-top-anchor{padding-top:76px}
  body.tbh-has-bottom-anchor{padding-bottom:76px}
  body.tbh-has-top-anchor .site-header{top:76px}
  .tbh-top-anchor-wrap .tbh-ad-block,.tbh-bottom-anchor-wrap .tbh-ad-block{padding-left:6px;padding-right:6px}
}
