
:root{
  --bg:#eef5fb;
  --bg-soft:#f7fbff;
  --surface:#ffffff;
  --surface-2:#f3f8fd;
  --ink:#11264a;
  --muted:#5f718d;
  --line:rgba(17,38,74,.10);
  --brand:#1e4da8;
  --brand-2:#2fa15a;
  --brand-3:#15a9c9;
  --shadow:0 18px 44px rgba(15,35,70,.10);
  --shadow-lg:0 24px 60px rgba(15,35,70,.14);
  --radius:26px;
  --radius-sm:18px;
  --container:min(100% - 28px, 1540px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(circle at top left, rgba(30,77,168,.10), transparent 24%),
    radial-gradient(circle at top right, rgba(47,161,90,.08), transparent 20%),
    var(--bg);
  color:var(--ink);
  font:16px/1.6 Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{width:var(--container);margin:0 auto}
.hidden{display:none!important}

.top-strip{
  background:#0d2b66;
  color:#eaf3ff;
  font-size:13px;
}
.top-strip-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  padding:8px 0;
}
.top-social,.top-contact{display:flex;align-items:center;gap:10px;white-space:nowrap;flex-wrap:wrap}
.top-social span,.top-contact span{opacity:.9}
.social-pill,.contact-pill{
  width:26px;height:26px;border-radius:999px;display:grid;place-items:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;font-size:12px;font-weight:800;
}
.top-contact a{opacity:.95}
.ticker-wrap{
  overflow:hidden;
  white-space:nowrap;
}
.ticker{
  display:inline-flex;
  gap:34px;
  animation:ticker 26s linear infinite;
  padding-left:100%;
}
.ticker span{opacity:.9}
@keyframes ticker{to{transform:translateX(-100%)}}

.site-header{
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(17,38,74,.06);
  position:sticky;
  top:0;
  z-index:80;
  box-shadow:0 1px 0 rgba(255,255,255,.7);
}
.header-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  padding:18px 0 14px;
}
.brand{
  display:flex;align-items:center;gap:14px;min-width:0
}
.brand-mark{
  width:68px;height:68px;display:grid;place-items:center;
  border-radius:20px;
  background:linear-gradient(135deg,#dff6ff,#ffffff 45%,#dff0ff);
  border:1px solid rgba(30,77,168,.08);
  box-shadow:var(--shadow);
  overflow:hidden;
  flex:0 0 auto;
}
.brand-mark img{width:100%;height:100%;object-fit:contain;padding:10px}
.brand-copy{min-width:0}
.brand-copy strong{
  display:block;
  font:800 34px/1.05 Georgia,"Times New Roman",serif;
  letter-spacing:-.02em;
  color:#173c8f;
}
.brand-copy strong span{color:var(--brand-2)}
.brand-copy small{
  display:block;margin-top:5px;
  color:#7b879c;font-size:16px;font-style:italic
}

.header-search{
  display:flex;
  justify-content:center;
  align-items:center;
}
.search-form{
  width:min(100%, 540px);
  display:flex;
  align-items:center;
  background:#fff;
  border:1px solid rgba(17,38,74,.12);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(15,35,70,.05);
}
.search-form input{
  border:0;
  outline:none;
  padding:14px 16px;
  width:100%;
  background:transparent;
  color:var(--ink);
}
.search-form button{
  width:58px;height:48px;
  border:0;
  background:linear-gradient(135deg,var(--brand-2),#4fb66f);
  color:#fff;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.header-actions{
  display:flex;align-items:center;gap:12px;justify-content:flex-end;flex-wrap:wrap
}
.header-btn,.primary-btn,.ghost-btn,.secondary-btn,.chip-btn,.menu-toggle,.slider-btn{
  border:1px solid transparent;
  border-radius:14px;
  font-weight:700;
  transition:transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.header-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;background:#fff;color:#18408f;border-color:rgba(24,64,143,.18);
  box-shadow:0 8px 18px rgba(15,35,70,.05);
}
.header-btn:hover,.primary-btn:hover,.secondary-btn:hover,.ghost-btn:hover,.menu-toggle:hover,.slider-btn:hover,.chip-btn:hover{transform:translateY(-1px)}
.header-btn.login{
  background:#fff;
  color:var(--brand-2);
  border-color:rgba(47,161,90,.30);
}
.menu-toggle{
  display:none;
  align-items:center;
  gap:8px;
  background:#fff;
  border-color:rgba(17,38,74,.12);
  padding:12px 14px;
  box-shadow:0 8px 18px rgba(15,35,70,.05);
}

.nav-row{
  border-top:1px solid rgba(17,38,74,.06);
  background:linear-gradient(180deg,#ffffff,#f9fbfe);
}
.nav-inner{
  display:flex;
  align-items:center;
  gap:14px;
  padding:0 0 12px;
}
.site-nav{
  display:flex;
  gap:6px;
  align-items:center;
  flex:1;
  flex-wrap:wrap;
}
.site-nav a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 14px;
  border-radius:999px;
  color:#23385f;
  font-weight:700;
  border:1px solid transparent;
  white-space:nowrap;
}
.site-nav a:hover,.site-nav a.active{
  background:rgba(47,161,90,.08);
  color:var(--brand-2);
  border-color:rgba(47,161,90,.18);
}
.nav-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:#1240a1;
  color:#fff;
  padding:12px 16px;
  border-radius:16px;
  font-weight:800;
  box-shadow:var(--shadow);
  min-width:max-content;
}
.nav-badge small{font-size:12px;opacity:.8}
.nav-badge .speaker{font-size:15px}

.hero-home{padding:20px 0 10px}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:18px;
  align-items:stretch;
}
.hero-copy{
  background:linear-gradient(135deg,#ffffff 0%, #f7fbff 45%, #eef8ff 100%);
  border-radius:34px;
  box-shadow:var(--shadow);
  padding:54px 52px 28px;
  min-height:460px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
  position:relative;
}
.hero-copy::after{
  content:"";
  position:absolute;
  inset:auto -10% -18% auto;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle, rgba(47,161,90,.12), transparent 70%);
  pointer-events:none;
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:800;
  color:var(--brand-2);
}
.kicker::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--brand-2);
  box-shadow:0 0 0 6px rgba(47,161,90,.10);
}
.hero-copy h1{
  margin:16px 0 14px;
  font:800 clamp(3rem, 4.8vw, 5.1rem)/.96 Georgia,"Times New Roman",serif;
  letter-spacing:-.04em;
  color:#163d92;
  max-width:11ch;
}
.hero-copy h1 .accent{color:var(--brand-2)}
.hero-copy p{
  margin:0;
  color:#51637f;
  font-size:18px;
  max-width:34ch;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:26px;
}
.primary-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 22px;
  background:linear-gradient(135deg,var(--brand-2),#52b86b);
  color:#fff;
  box-shadow:0 12px 28px rgba(47,161,90,.22);
}
.secondary-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 22px;
  background:#fff;color:#163d92;border-color:rgba(22,61,146,.16)
}
.hero-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:30px;
}
.metric{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(17,38,74,.08);
  border-radius:18px;
  padding:14px 14px 12px;
  box-shadow:0 12px 30px rgba(15,35,70,.05);
}
.metric strong{display:block;font-size:17px;margin-bottom:4px}
.metric span{color:var(--muted);font-size:13px;line-height:1.4}

.hero-visual{
  border-radius:34px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  position:relative;
  min-height:460px;
  background:linear-gradient(180deg,#ebf7ff 0%,#f5fbff 100%);
}
.hero-slider{
  position:absolute;inset:0;
}
.hero-slide{
  position:absolute;inset:0;
  opacity:0;
  transition:opacity .45s ease;
  background-size:cover;
  background-position:center;
}
.hero-slide.active{opacity:1}
.hero-slide::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(110deg, rgba(10,26,55,.08) 0%, rgba(10,26,55,.12) 34%, rgba(10,26,55,.02) 100%);
}
.hero-slide-content{
  position:absolute;
  inset:auto 30px 26px 30px;
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:22px;
  padding:20px 20px 18px;
  box-shadow:var(--shadow);
  max-width:420px;
}
.hero-slide-content h2,.hero-slide-content h3{
  margin:10px 0 8px;
  font:800 24px/1.08 Georgia,"Times New Roman",serif;
  letter-spacing:-.03em;
  color:#15367d;
}
.hero-slide-content p{margin:0;color:#51637f;font-size:15px}
.hero-slide-content .mini-meta{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;color:#60708d;font-size:13px}
.slider-controls{
  position:absolute;top:18px;right:18px;display:flex;gap:10px;z-index:2
}
.slider-btn{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(255,255,255,.88);
  color:#12386d;
  border-color:rgba(255,255,255,.44);
  box-shadow:0 10px 18px rgba(15,35,70,.08);
  cursor:pointer;
}
.slider-dots{
  position:absolute;
  left:28px;
  bottom:28px;
  display:flex;gap:8px;z-index:3
}
.slider-dot{
  width:10px;height:10px;border-radius:999px;border:0;cursor:pointer;
  background:rgba(22,54,125,.28);
}
.slider-dot.active{background:var(--brand-2)}

.trust-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-top:16px;
}
.trust-card{
  background:#fff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:20px;
  box-shadow:0 10px 22px rgba(15,35,70,.05);
  padding:18px 16px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.trust-icon{
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(47,161,90,.12), rgba(30,77,168,.08));
  color:var(--brand-2);
  font-size:20px;flex:0 0 auto
}
.trust-card h4{margin:0 0 4px;font-size:16px}
.trust-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.45}

.section{
  padding:30px 0;
}
.section-head{
  display:flex;justify-content:space-between;gap:16px;align-items:flex-end;margin-bottom:18px
}
.section-head h2,.footer-title{
  margin:0;
  font:800 clamp(1.6rem, 2.3vw, 2.2rem)/1.1 Georgia,"Times New Roman",serif;
  letter-spacing:-.03em;
  color:#16367d;
}
.section-head p{margin:6px 0 0;color:var(--muted);max-width:72ch}
.section-link{
  color:var(--brand);
  font-weight:800;
  white-space:nowrap
}

.feature-grid{
  display:grid;
  grid-template-columns:1.15fr 1fr .82fr;
  gap:18px;
}
.story-card,.info-card,.list-card,.tool-card,.promo-card,.newsletter-banner,.category-card,.article-card,.toc-card{
  background:#fff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:24px;
  box-shadow:var(--shadow);
}
.story-card{overflow:hidden}
.story-media{
  min-height:220px;
  background-size:cover;
  background-position:center;
}
.story-body{
  padding:18px 18px 20px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:7px 12px;
  background:rgba(47,161,90,.08);
  color:var(--brand-2);
  border:1px solid rgba(47,161,90,.16);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.story-body h3,.list-item h3,.article-copy h2,.article-copy h3{
  margin:12px 0 8px;
  font:800 22px/1.14 Georgia,"Times New Roman",serif;
  letter-spacing:-.03em;
}
.story-body p,.list-item p,.tool-card p,.promo-card p,.newsletter-banner p{margin:0;color:var(--muted)}
.story-meta,.compact-meta,.meta-bar{
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;
  color:#6b7c94;font-size:13px;margin-top:12px
}
.feature-stack{display:grid;gap:18px}
.list-card{padding:18px}
.list-item{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:16px;
  padding:14px 0;
  border-top:1px solid rgba(17,38,74,.08);
  align-items:center;
}
.list-item:first-of-type{border-top:0;padding-top:0}
.list-thumb{
  min-height:120px;
  background-size:cover;
  background-position:center;
  border-radius:18px;
}
.trending-list{
  display:grid;gap:10px;
}
.trending-item{
  display:grid;
  grid-template-columns:88px 1fr;
  gap:12px;
  align-items:center;
  padding:10px 0;
  border-top:1px solid rgba(17,38,74,.08);
}
.trending-item:first-child{border-top:0;padding-top:0}
.trending-item .thumb{
  min-height:70px;
  border-radius:16px;
  background-size:cover;
  background-position:center;
}
.trending-item strong{
  display:block;
  margin-bottom:3px;
  font-size:15px;
  line-height:1.35;
}
.trending-item span{display:block;color:var(--muted);font-size:13px}

.side-stack{
  display:grid;
  gap:18px;
}
.tool-card,.promo-card{padding:20px}
.tool-card h3,.promo-card h3{
  margin:10px 0 10px;
  font:800 24px/1.12 Georgia,"Times New Roman",serif;
  letter-spacing:-.03em;
  color:#16367d;
}
.tip-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.tip{
  display:flex;align-items:center;gap:10px;color:#354a67;font-weight:600;
}
.tip::before{
  content:"✓";
  width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(47,161,90,.12);
  color:var(--brand-2);
  font-size:12px;
  flex:0 0 auto;
}

.categories-section{
  padding-top:4px;
}
.category-grid{
  display:grid;
  grid-template-columns:repeat(8,minmax(0,1fr));
  gap:12px;
}
.category-card{
  padding:18px 12px 16px;
  text-align:center;
}
.category-card .ico{
  width:50px;height:50px;border-radius:18px;margin:0 auto 10px;
  display:grid;place-items:center;
  font-size:22px;
  background:linear-gradient(135deg, rgba(30,77,168,.09), rgba(47,161,90,.10));
}
.category-card strong{display:block;font-size:15px;margin-bottom:4px}
.category-card span{display:block;color:var(--muted);font-size:13px;line-height:1.35}

.newsletter-banner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  padding:22px 24px;
  margin-top:18px;
  background:linear-gradient(135deg,#ffffff,#eef8ff);
}
.newsletter-banner .icon{
  width:74px;height:74px;border-radius:24px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,77,168,.12), rgba(47,161,90,.12));
  font-size:30px;
}
.newsletter-banner h3{
  margin:0 0 6px;
  font:800 24px/1.1 Georgia,"Times New Roman",serif;
  color:#16367d;
}
.newsletter-form{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:min(100%, 420px);
}
.newsletter-form input{
  flex:1;
  min-width:0;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(17,38,74,.12);
  background:#fff;
}

.site-footer{
  margin-top:30px;
  background:linear-gradient(180deg,#0d2b66,#08204c);
  color:#eaf2ff;
}
.footer-top{
  display:grid;
  grid-template-columns:1.2fr .7fr .7fr .8fr;
  gap:24px;
  padding:42px 0 26px;
}
.footer-brand-block p{color:rgba(234,242,255,.82);max-width:32ch}
.footer-brand{
  display:flex;align-items:center;gap:12px;font:800 28px/1 Georgia,"Times New Roman",serif;
}
.footer-brand img{width:58px;height:58px;border-radius:18px;background:#fff;padding:8px}
.site-footer h4{
  margin:0 0 14px;
  font-size:18px
}
.site-footer ul{
  list-style:none;
  padding:0;margin:0;
  display:grid;gap:10px
}
.site-footer a{color:rgba(234,242,255,.88)}
.site-footer p{margin:0;color:rgba(234,242,255,.78);line-height:1.7}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  padding:18px 0 26px;
  border-top:1px solid rgba(255,255,255,.10);
  color:rgba(234,242,255,.75);
  font-size:14px;
}

/* Category and article pages */
.page-hero,.article-hero,.category-hero{
  margin-top:18px;
  background:linear-gradient(135deg,#0f2f6f,#0e3b8b 45%, #0f6f5d 100%);
  color:#fff;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.category-hero{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  min-height:320px;
}
.category-hero .intro,.page-hero .inner{
  padding:40px 42px;
}
.page-hero .inner{max-width:900px}
.category-hero .visual{
  min-height:320px;
  background-size:cover;
  background-position:center;
}
.breadcrumb{
  display:flex;
  gap:10px;
  align-items:center;
  color:rgba(255,255,255,.72);
  font-size:13px;
  flex-wrap:wrap;
}
.breadcrumb a{color:rgba(255,255,255,.92)}
.category-hero h1,.page-hero h1,.article-hero h1{
  margin:14px 0 10px;
  font:800 clamp(2.4rem, 4.8vw, 4.8rem)/.94 Georgia,"Times New Roman",serif;
  letter-spacing:-.04em;
  max-width:12ch;
}
.category-hero p,.page-hero p,.article-hero .summary{
  margin:0;
  max-width:70ch;
  color:rgba(255,255,255,.85);
  font-size:18px;
}
.accent-line{
  width:56px;height:4px;border-radius:999px;
  background:rgba(255,255,255,.7);
  margin:18px 0 0;
}

.content-grid,.article-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:18px;
  align-items:start;
  margin-top:18px;
}
.page-main{display:grid;gap:18px}
.cards-4,.cards-3{
  display:grid;
  gap:18px;
}
.cards-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.featured-dense{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  gap:18px;
}
.article-hero{
  padding:34px 42px;
  margin-bottom:18px;
}
.article-hero .meta-bar{color:rgba(255,255,255,.78);margin-top:16px}
.article-card{
  overflow:hidden;
}
.article-cover{
  min-height:380px;
  background-size:cover;
  background-position:center;
}
.article-body,.article-content{
  padding:20px 22px 24px;
}
.article-content p{
  color:#32445f;
  line-height:1.8;
  margin:0 0 16px;
}
.author-box{
  display:flex;align-items:center;gap:14px;
  background:#f5f9ff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:18px;
  padding:14px 16px;
  margin:20px 0;
}
.author-box .avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg, rgba(30,77,168,.15), rgba(47,161,90,.15));
}
.key-takeaways{
  background:#f8fbff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:20px;
  padding:18px 18px 12px;
  margin:18px 0;
}
.key-takeaways ul{
  margin:12px 0 0 18px;
  color:#32445f;
}
.story-footer{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:18px
}
.tag{
  padding:8px 12px;border-radius:999px;background:#eff6ff;border:1px solid #d7e6ff;color:#1c4a9f;font-weight:700;font-size:13px
}
.related{
  margin-top:18px;
  background:#fff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:18px;
}
.related h3{margin:0 0 14px;font:800 24px/1.1 Georgia,"Times New Roman",serif;color:#16367d}
.sidebar-stack{display:grid;gap:18px}
.toc-card,.mini-card,.side-panel,.newsletter-card{
  background:#fff;
  border:1px solid rgba(17,38,74,.08);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:18px;
}
.toc-card h3,.mini-card h3,.side-panel h3{
  margin:0 0 8px;
  font:800 22px/1.1 Georgia,"Times New Roman",serif;
  color:#16367d;
}
.toc-list{
  display:grid;
  gap:10px;
  margin-top:14px;
  counter-reset:item;
}
.toc-list a{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:11px 12px;
  border-radius:14px;
  background:#f7fbff;
  border:1px solid rgba(17,38,74,.06);
  color:#23406b;
  font-weight:600;
}
.toc-list a span{
  color:var(--muted);
  font-size:13px;
}
.pop-list{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.pop-item{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:12px;
  align-items:center;
}
.pop-item .thumb{
  min-height:66px;
  border-radius:16px;
  background-size:cover;
  background-position:center;
}
.pop-item strong{
  display:block;
  font-size:15px;
  line-height:1.35;
}
.pop-item span{display:block;color:var(--muted);font-size:12px;margin-top:4px}
.newsletter-card{
  background:linear-gradient(135deg,#f8fbff,#eef8ff);
}
.newsletter-card .newsletter-form{min-width:0;width:100%}

.page-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:18px;
  align-items:start;
}

@media (max-width: 1280px){
  .category-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .cards-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .featured-dense,.feature-grid,.article-layout,.content-grid,.page-layout,.category-hero{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr}
  .hero-copy h1{max-width:14ch}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width: 920px){
  .top-strip-inner{grid-template-columns:1fr;justify-items:center;text-align:center}
  .header-inner{grid-template-columns:1fr auto}
  .header-search{grid-column:1/-1;order:3}
  .header-actions{display:none}
  .menu-toggle{display:inline-flex}
  .nav-inner{display:none}
  body.nav-open .nav-inner{display:block}
  .nav-row{position:relative}
  .site-nav{
    display:none;
    position:absolute;
    left:0;right:0;top:100%;
    background:#fff;
    padding:14px;
    box-shadow:var(--shadow);
    border-bottom-left-radius:22px;
    border-bottom-right-radius:22px;
    flex-direction:column;
    align-items:flex-start;
    z-index:90;
  }
  body.nav-open .site-nav{display:flex}
  .hero-copy{padding:34px 24px}
  .hero-copy h1{font-size:3rem}
  .hero-metrics{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr 1fr}
  .category-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .newsletter-banner{grid-template-columns:1fr}
  .newsletter-form{width:100%;min-width:0}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .cards-4,.cards-3{grid-template-columns:1fr}
  .list-item,.content-grid,.page-layout{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .container{width:min(100% - 18px, 100%)}
  .hero-copy h1{font-size:2.6rem}
  .hero-copy p,.category-hero p,.page-hero p,.article-hero .summary{font-size:16px}
  .trust-row{grid-template-columns:1fr}
  .category-grid{grid-template-columns:1fr 1fr}
  .newsletter-form{flex-direction:column;align-items:stretch}
  .search-form{width:100%}
  .header-inner{padding:14px 0 12px}
  .brand-copy strong{font-size:26px}
  .brand-copy small{font-size:14px}
  .category-hero .intro,.page-hero .inner,.article-hero{padding:26px 20px}
  .article-body,.article-content,.story-body,.tool-card,.promo-card,.list-card,.toc-card,.mini-card,.side-panel,.newsletter-card{padding:16px}
}
