  /* Self-hosted fonts.
     Files live in /assets/fonts/ in the repo. Loaded with font-display:swap so text
     shows in the fallback font immediately and swaps to the webfont once it arrives.
     Self-hosting eliminates third-party requests (no Google Fonts, no IP exposure)
     so these load for all users regardless of cookie consent. */
  @font-face{font-family:'Playfair Display';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/playfair-400.woff2') format('woff2')}
  @font-face{font-family:'Playfair Display';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/playfair-400-italic.woff2') format('woff2')}
  @font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/playfair-600.woff2') format('woff2')}
  @font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/playfair-700.woff2') format('woff2')}
  @font-face{font-family:'Source Sans 3';font-style:normal;font-weight:300;font-display:swap;src:url('/assets/fonts/sourcesans3-300.woff2') format('woff2')}
  @font-face{font-family:'Source Sans 3';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/sourcesans3-400.woff2') format('woff2')}
  @font-face{font-family:'Source Sans 3';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/sourcesans3-500.woff2') format('woff2')}
  @font-face{font-family:'Source Sans 3';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/sourcesans3-600.woff2') format('woff2')}

  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --gd:#085041;--gm:#0F6E56;--gl:#1D9E75;--gp:#E1F5EE;
    --gold:#BA7517;--goldp:#FAEEDA;
    --td:#1a1a1a;--tm:#444;--muted:#777;
    --border:#e0e0d8;--bg:#fafaf7;--white:#fff;--red:#A32D2D;
    --serif:'Playfair Display',Georgia,serif;--sans:'Source Sans 3',system-ui,sans-serif;
    --sh:0 2px 12px rgba(0,0,0,.07);--shl:0 8px 32px rgba(0,0,0,.12)
  }
  body{font-family:var(--sans);background:var(--bg);color:var(--td);line-height:1.6}
  .topbar{background:var(--gd);color:#9FE1CB;font-size:12px;padding:6px 0;text-align:center;letter-spacing:.04em}
  nav{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--sh)}
  .nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;height:64px;gap:10px}
  .brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
  .brand-icon{width:36px;height:36px;background:var(--gm);border-radius:8px;display:flex;align-items:center;justify-content:center}
  .brand-icon svg{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round}
  .brand-name{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--gd)}
  .brand-name span{color:var(--gl)}
  .nav-links{display:flex;gap:4px;margin-left:8px}
  .nav-link{font-size:14px;font-weight:500;padding:8px 13px;border-radius:6px;cursor:pointer;color:var(--tm);border:none;background:none;transition:all .18s;white-space:nowrap}
  .nav-link:hover{background:var(--gp);color:var(--gm)}
  .nav-link.active{background:var(--gm);color:#fff}
  .nav-spacer{flex:1}
  .nav-search-wrap{position:relative;width:240px;flex-shrink:0}
  .nav-search-input{width:100%;font-family:var(--sans);font-size:13px;padding:8px 12px 8px 32px;border:1.5px solid var(--border);border-radius:20px;outline:none;background:var(--bg);transition:border .15s}
  .nav-search-input:focus{border-color:var(--gm)}
  .nav-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none}
  .nav-search-icon svg{width:14px;height:14px;stroke:var(--muted);fill:none;stroke-width:2;stroke-linecap:round}
  .nav-actions{display:flex;gap:8px;flex-shrink:0}
  .btn{font-family:var(--sans);font-size:13px;font-weight:600;padding:8px 16px;border-radius:6px;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}
  .btn-primary{background:var(--gm);color:#fff}
  .btn-primary:hover{background:var(--gd)}
  .btn-outline{background:transparent;border:1.5px solid var(--gm);color:var(--gm)}
  .btn-outline:hover{background:var(--gp)}
  .btn-danger{background:var(--red);color:#fff;font-size:12px;padding:6px 12px}
  .btn-danger:hover{opacity:.85}
  .btn-sm{font-size:12px;padding:6px 12px}
  .btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);font-size:12px;padding:5px 13px}
  .btn-ghost:hover{background:rgba(255,255,255,.22)}
  .hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;margin-left:auto}
  .hamburger span{display:block;width:22px;height:2px;background:var(--td);border-radius:2px}
  .page{display:none}.page.active{display:block}

  /* ADMIN BAR */
  .admin-bar{background:var(--gd);padding:0;overflow:hidden;transition:all .2s;display:none}
  .admin-bar.visible{display:block}
  .admin-bar-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;flex-wrap:wrap}
  .admin-bar-label{color:#9FE1CB;font-size:12px;font-weight:600;letter-spacing:.05em;display:flex;align-items:center;gap:6px}
  .status-dot{width:7px;height:7px;border-radius:50%;background:#1D9E75;flex-shrink:0;display:inline-block;transition:background .3s}
  .status-dot.warn{background:#EF9F27}
  .status-dot.err{background:#E24B4A}
  .admin-toggle{font-size:12px;font-weight:600;padding:5px 14px;border-radius:5px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.1);color:#fff;cursor:pointer;font-family:var(--sans);transition:background .15s}
  .admin-toggle:hover{background:rgba(255,255,255,.2)}
  .manage-btn{display:none}
  .admin-mode .manage-btn{display:inline-flex}

  /* GITHUB SETTINGS PANEL */
  .gh-panel{background:#063d31;border-top:1px solid rgba(255,255,255,.08);padding:20px 24px;display:none}
  .gh-panel.open{display:block}
  .gh-panel-title{font-size:13px;font-weight:700;color:#9FE1CB;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
  .gh-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:14px}
  .gh-field label{display:block;font-size:11px;font-weight:600;color:rgba(159,225,203,.7);margin-bottom:5px;letter-spacing:.05em;text-transform:uppercase}
  .gh-input{width:100%;font-family:var(--sans);font-size:13px;padding:8px 11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff;outline:none;transition:border .15s}
  .gh-input:focus{border-color:#1D9E75}
  .gh-input::placeholder{color:rgba(255,255,255,.3)}
  .gh-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .gh-status{font-size:12px;color:#9FE1CB;opacity:.75;display:flex;align-items:center;gap:6px}
  .publish-btn{background:#1D9E75;color:#fff;border:none;font-family:var(--sans);font-size:13px;font-weight:700;padding:9px 20px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:background .15s}
  .publish-btn:hover{background:#0F6E56}
  .publish-btn:disabled{opacity:.5;cursor:not-allowed}
  .spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
  @keyframes spin{to{transform:rotate(360deg)}}
  .gh-note{font-size:11px;color:rgba(159,225,203,.55);margin-top:10px;line-height:1.6}
  .gh-note a{color:#9FE1CB}

  /* ADS */
  /* Ad slots — work as visible placeholders before approval, invisible containers after */
  .ad-slot{background:#f0f0eb;border:1.5px dashed #ccc;border-radius:8px;text-align:center;margin:20px 0;font-size:12px;color:#999;letter-spacing:.06em;font-weight:600;text-transform:uppercase;overflow:hidden;position:relative}
  .ad-slot .ad-placeholder{padding:18px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;height:100%}
  .ad-slot.leaderboard{min-height:90px}
  .ad-slot.rectangle{min-height:250px}
  .ad-slot.wide{min-height:120px}
  .ad-slot .adsbygoogle{display:block;width:100%}
  /* When real ad is loaded, hide placeholder and dashed border */
  body.ads-loaded .ad-slot{background:transparent;border:none}
  body.ads-loaded .ad-slot .ad-placeholder{display:none}
  /* Hide all ad slots when ADSENSE_CONFIG.showAdSlots is false */
  body.ads-hidden .ad-slot{display:none}

  /* Legacy placeholder styles (kept for backward compat, can be removed once all slots converted) */
  .ad-banner{background:#f0f0eb;border:1.5px dashed #ccc;border-radius:8px;text-align:center;padding:18px;margin:20px 0;font-size:12px;color:#999;letter-spacing:.06em;font-weight:600;text-transform:uppercase}
  .ad-banner.leaderboard{height:90px;display:flex;align-items:center;justify-content:center}
  .ad-banner.rectangle{height:250px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px}
  .ad-banner.wide{height:120px;display:flex;align-items:center;justify-content:center}

  /* HERO */
  .hero{background:linear-gradient(135deg,var(--gd) 0%,var(--gm) 60%,var(--gl) 100%);color:#fff;padding:48px 24px;text-align:center;position:relative;overflow:hidden}
  .hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='1.5' fill='rgba(255,255,255,0.06)'/%3E%3C/svg%3E") repeat}
  .hero-inner{max-width:680px;margin:0 auto;position:relative}
  .hero-tag{display:inline-block;background:rgba(255,255,255,.15);color:#9FE1CB;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:12px;border:1px solid rgba(255,255,255,.2)}
  .hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,42px);font-weight:700;line-height:1.2;margin-bottom:10px}
  .hero p{font-size:15px;opacity:.82;max-width:520px;margin:0 auto 18px;line-height:1.6}
  .hero-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
  .btn-hero{font-family:var(--sans);font-size:13px;font-weight:600;padding:10px 20px;border-radius:8px;cursor:pointer;border:none;transition:all .2s}
  .btn-hero-p{background:#fff;color:var(--gd)}.btn-hero-p:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.2)}
  .btn-hero-o{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}.btn-hero-o:hover{background:rgba(255,255,255,.1)}

  /* LAYOUT */
  .container{max-width:1200px;margin:0 auto;padding:0 24px}
  .content-grid{display:grid;grid-template-columns:1fr 300px;gap:40px;padding:48px 0}
  .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;padding-bottom:12px;border-bottom:2px solid var(--gm);flex-wrap:wrap;gap:10px}
  .section-title{font-family:var(--serif);font-size:22px;font-weight:600}
  .section-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gm)}
  .filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:24px;padding:12px 16px;background:var(--white);border:1px solid var(--border);border-radius:10px}
  .filter-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;margin-right:4px}
  .filter-pill{font-size:12px;font-weight:500;padding:5px 14px;border-radius:20px;border:1px solid var(--border);color:var(--tm);cursor:pointer;background:none;font-family:var(--sans);transition:all .15s}
  .filter-pill:hover{background:var(--gp);border-color:var(--gm);color:var(--gm)}
  .filter-pill.active{background:var(--gm);color:#fff;border-color:var(--gm)}

  /* CARDS */
  .article-card{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:box-shadow .2s,transform .2s;cursor:pointer;display:flex;flex-direction:column;text-decoration:none;color:inherit}
  .article-card:hover{box-shadow:var(--shl);transform:translateY(-3px)}
  .card-img{width:100%;height:200px;object-fit:cover;display:block;flex-shrink:0}
  .card-img-ph{width:100%;height:200px;background:linear-gradient(135deg,var(--gp),#d4ede5);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .card-body{padding:20px;flex:1;display:flex;flex-direction:column}
  .article-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
  .article-tag{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:20px;background:var(--gp);color:var(--gd)}
  .article-date{font-size:12px;color:var(--muted)}
  .card-body h3{font-family:var(--serif);font-size:18px;font-weight:600;line-height:1.3;margin-bottom:8px;color:var(--td)}
  .card-body p{font-size:14px;color:var(--tm);line-height:1.6;flex:1}
  .topic-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
  .ttag{font-size:10px;font-weight:600;padding:3px 9px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .12s}
  .ttag:hover{border-color:var(--gm);color:var(--gm);background:var(--gp)}
  .article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
  mark{background:#fff3b0;border-radius:2px;padding:0 2px}

  .feat-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:20px;background:var(--goldp);color:var(--gold);border:1px solid #F0C488;margin-bottom:8px}
  .btn-feature{font-size:12px;font-weight:600;padding:6px 12px;border-radius:6px;background:var(--goldp);color:var(--gold);border:1px solid #F0C488;cursor:pointer;font-family:var(--sans);transition:all .15s}
  .btn-feature:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
  .btn-feature.is-featured{background:var(--gold);color:#fff;border-color:var(--gold);cursor:default}
  .article-card.featured{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}

  /* FEATURED */
  .featured-card{display:grid;grid-template-columns:1fr 1fr;background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:32px;transition:box-shadow .2s;cursor:pointer;text-decoration:none;color:inherit}
  .featured-card:hover{box-shadow:var(--shl)}
  .feat-img{width:100%;height:100%;min-height:280px;object-fit:cover;display:block}
  .feat-img-ph{width:100%;min-height:280px;background:linear-gradient(135deg,var(--gp),#b8e0d4);display:flex;align-items:center;justify-content:center}
  .feat-body{padding:36px 32px;display:flex;flex-direction:column;justify-content:center}
  .feat-body .article-tag{margin-bottom:14px;display:inline-block}
  .feat-body h2{font-family:var(--serif);font-size:26px;font-weight:700;line-height:1.25;margin-bottom:14px;color:var(--td)}
  .feat-body p{font-size:15px;color:var(--tm);line-height:1.7;margin-bottom:20px}
  .read-more{font-size:13px;font-weight:600;color:var(--gm);background:none;border:none;cursor:pointer;padding:0;font-family:var(--sans);display:inline-flex;align-items:center;gap:4px}
  .read-more:hover{color:var(--gd)}.read-more::after{content:'→'}

  /* PAGINATION */
  .pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:36px;padding-top:24px;border-top:1px solid var(--border);flex-wrap:wrap}
  .pg-btn{font-family:var(--sans);font-size:13px;font-weight:600;width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border);background:var(--white);color:var(--tm);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
  .pg-btn:hover:not(:disabled){border-color:var(--gm);color:var(--gm)}
  .pg-btn.active{background:var(--gm);color:#fff;border-color:var(--gm)}
  .pg-btn:disabled{opacity:.3;cursor:not-allowed}
  .pg-info{font-size:12px;color:var(--muted);padding:0 6px}

  /* SIDEBAR */
  .sidebar{display:flex;flex-direction:column;gap:28px}
  .sidebar-widget{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:20px}
  .widget-title{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gd);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
  .trending-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;color:inherit}
  .trending-item:last-child{border-bottom:none;padding-bottom:0}
  .trend-num{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--gp);line-height:1;min-width:28px}
  .trend-text{font-size:13px;font-weight:500;color:var(--td);line-height:1.4}
  .trending-item:hover .trend-text{color:var(--gm)}
  .cat-pills{display:flex;flex-wrap:wrap;gap:8px}
  .cat-pill{font-size:12px;font-weight:500;padding:6px 14px;border-radius:20px;border:1px solid var(--border);color:var(--tm);cursor:pointer;background:none;font-family:var(--sans);transition:all .15s}
  .cat-pill:hover{background:var(--gm);color:#fff;border-color:var(--gm)}
  /* Editorial Standards snapshot (homepage sidebar widget) */
  .standards-snapshot{list-style:none;padding:0;margin:0 0 16px 0;display:grid;gap:10px}
  .standards-snapshot li{position:relative;padding:0 0 0 24px;font-size:13px;color:var(--tm);line-height:1.5}
  .standards-snapshot li::before{content:'';position:absolute;left:0;top:3px;width:14px;height:14px;background:var(--gp);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F6E56' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:9px;background-repeat:no-repeat;background-position:center}
  .standards-snapshot-link{display:block;font-size:12px;color:var(--gm);font-weight:600;text-decoration:none;cursor:pointer;padding-top:10px;border-top:1px solid var(--border);transition:color .15s}
  .standards-snapshot-link:hover{color:var(--gd)}

  /* ARTICLE DETAIL */
  .article-detail{max-width:760px;margin:48px auto;padding:0 24px}
  .detail-img{width:100%;height:400px;object-fit:cover;border-radius:12px;margin-bottom:32px;display:block}
  .detail-img-ph{width:100%;height:400px;background:linear-gradient(135deg,var(--gp),#c5e8dc);border-radius:12px;margin-bottom:32px;display:flex;align-items:center;justify-content:center}
  .article-detail h1{font-family:var(--serif);font-size:clamp(26px,4vw,38px);font-weight:700;line-height:1.2;margin-bottom:16px}
  .detail-meta{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:13px;margin-bottom:28px;flex-wrap:wrap}
  /* Byline link → editorial policy. Uses brand green, underlined on hover only,
     so it reads as a link without dominating the muted meta-line typography. */
  .detail-meta .byline-link{color:var(--gd);font-weight:500;text-decoration:none;cursor:pointer;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
  .detail-meta .byline-link:hover,
  .detail-meta .byline-link:focus-visible{color:var(--gm);border-bottom-color:var(--gm);outline:none}
  /* Summary deck — sits between the article title and byline. Editorial italic-serif treatment.
     Mirrors the convention used by NYT / The Atlantic / BBC for their article subheadings. */
  .detail-deck{font-family:var(--serif);font-size:19px;line-height:1.55;color:var(--tm);font-style:italic;margin:0 0 18px;padding:0;font-weight:400}
  @media (max-width:560px){.detail-deck{font-size:17px;line-height:1.5;margin-bottom:14px}}
  .detail-body{font-size:17px;line-height:1.8;color:var(--td)}
  .detail-body p{margin-bottom:20px}
  .detail-body h2{font-family:var(--serif);font-size:24px;font-weight:600;margin:36px 0 16px}
  .detail-body h3{font-family:var(--serif);font-size:20px;font-weight:600;margin:28px 0 12px}
  .back-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--gm);background:none;border:none;cursor:pointer;padding:0;margin-bottom:24px;font-family:var(--sans)}
  .back-btn::before{content:'←'}.back-btn:hover{color:var(--gd)}
  .article-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}

  /* SEARCH */
  .search-hero{background:var(--gd);padding:48px 24px}
  .search-inner{max-width:680px;margin:0 auto}
  .search-inner h2{font-family:var(--serif);font-size:28px;color:#fff;margin-bottom:6px}
  .search-qlbl{font-size:14px;color:#9FE1CB;margin-bottom:18px}
  .search-bar-lg{display:flex;gap:10px}
  .search-bar-lg input{flex:1;font-family:var(--sans);font-size:15px;padding:12px 16px;border:none;border-radius:8px;outline:none}
  .search-bar-lg button{background:var(--gl);color:#fff;border:none;border-radius:8px;padding:12px 20px;font-family:var(--sans);font-size:14px;font-weight:600;cursor:pointer}
  .search-bar-lg button:hover{background:var(--gm)}
  .search-count{font-size:13px;color:var(--muted);margin-bottom:24px}

  /* COOKIE BANNER */
  .cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,.18);padding:22px 24px;z-index:9999;font-family:var(--sans);display:none}
  .cookie-banner.visible{display:block;animation:slideUp .3s ease-out}
  @keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
  .cookie-banner h3{font-family:var(--serif);font-size:18px;color:var(--gd);margin-bottom:8px}
  .cookie-banner p{font-size:13px;color:var(--tm);line-height:1.6;margin-bottom:14px}
  .cookie-banner p a{color:var(--gm);text-decoration:underline;cursor:pointer}
  .cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
  .cookie-btn{font-family:var(--sans);font-size:13px;font-weight:600;padding:9px 18px;border-radius:7px;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}
  .cookie-btn-primary{background:var(--gm);color:#fff}
  .cookie-btn-primary:hover{background:var(--gd)}
  .cookie-btn-secondary{background:#fff;color:var(--tm);border:1px solid var(--border)}
  .cookie-btn-secondary:hover{background:#f5f5ef;border-color:var(--gm);color:var(--gm)}
  .cookie-details{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:none;font-size:12px;color:var(--tm);line-height:1.7}
  .cookie-details.open{display:block}
  .cookie-details ul{margin-left:18px;margin-top:6px}
  .cookie-details strong{color:var(--td)}

  /* PRIVACY PAGE */
  .privacy-hero{background:var(--gd);color:#fff;padding:48px 24px;text-align:center}
  .privacy-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,42px);margin-bottom:10px}
  .privacy-hero p{font-size:15px;opacity:.82;max-width:540px;margin:0 auto}
  .privacy-content{max-width:780px;margin:0 auto;padding:40px 24px 64px}
  .privacy-content h2{font-family:var(--serif);font-size:22px;color:var(--gd);margin:32px 0 12px;padding-top:16px;border-top:1px solid var(--border)}
  .privacy-content h2:first-child{border-top:none;padding-top:0;margin-top:0}
  .privacy-content h3{font-size:15px;font-weight:600;color:var(--td);margin:20px 0 8px}
  .privacy-content p{font-size:15px;color:var(--tm);line-height:1.75;margin-bottom:14px}
  .privacy-content ul{margin:10px 0 16px 22px;font-size:15px;color:var(--tm);line-height:1.85}
  .privacy-content li{margin-bottom:6px}
  .privacy-content code{background:#f0f0eb;padding:1px 6px;border-radius:4px;font-size:13px;color:#c0392b}
  .privacy-content a{color:var(--gm);text-decoration:underline}
  .privacy-meta{font-size:13px;color:var(--muted);font-style:italic;margin-top:8px;display:block}
  .privacy-callout{background:var(--gp);border-left:4px solid var(--gm);padding:14px 18px;border-radius:6px;margin:18px 0;font-size:14px;color:var(--gd);line-height:1.7}
  .privacy-callout strong{font-weight:700}
  .about-hero{background:var(--gd);color:#fff;padding:80px 24px;text-align:center}
  .about-hero h1{font-family:var(--serif);font-size:42px;font-weight:700;margin-bottom:16px}
  .about-hero p{font-size:17px;opacity:.82;max-width:580px;margin:0 auto;line-height:1.7}
  .about-content{max-width:860px;margin:0 auto;padding:60px 24px}
  .about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin:48px 0}
  .about-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:28px 24px;text-align:center}
  .about-icon{width:52px;height:52px;background:var(--gp);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
  .about-card h3{font-family:var(--serif);font-size:18px;font-weight:600;margin-bottom:8px}
  .about-card p{font-size:14px;color:var(--tm);line-height:1.6}

  /* Prominent medical disclaimer callout */
  .disclaimer-callout{background:var(--goldp);border:1px solid #F0C488;border-left:5px solid var(--gold);border-radius:12px;padding:32px 36px;margin:48px 0;display:flex;gap:20px;align-items:flex-start}
  .disclaimer-callout .disclaimer-icon{flex-shrink:0;width:48px;height:48px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid #F0C488}
  .disclaimer-callout .disclaimer-icon svg{width:24px;height:24px;stroke:var(--gold)}
  .disclaimer-callout h2{font-family:var(--serif);font-size:22px;font-weight:700;color:#5C3A0B;margin-bottom:10px}
  .disclaimer-callout p{font-size:15px;line-height:1.7;color:#633806;margin-bottom:10px}
  .disclaimer-callout p:last-child{margin-bottom:0}
  .disclaimer-callout strong{color:#3D2406}
  @media (max-width:560px){.disclaimer-callout{flex-direction:column;padding:24px;gap:14px}.disclaimer-callout .disclaimer-icon{margin:0}}

  /* Editorial standards section */
  .editorial-section{margin:48px 0}
  .editorial-section h2{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--gd);margin-bottom:16px}
  .editorial-section p{font-size:15px;color:var(--tm);line-height:1.8;margin-bottom:14px}
  .editorial-section .standards-list{list-style:none;padding:0;margin:18px 0;display:grid;gap:12px}
  .editorial-section .standards-list li{position:relative;padding:0 0 0 32px;font-size:14px;color:var(--tm);line-height:1.7}
  .editorial-section .standards-list li::before{content:'';position:absolute;left:0;top:6px;width:18px;height:18px;background:var(--gp);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F6E56' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:11px;background-repeat:no-repeat;background-position:center}

  /* FAQ section */
  .faq-section{margin:48px 0}
  .faq-section h2{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--gd);margin-bottom:24px}
  .faq-item{border-bottom:1px solid var(--border)}
  .faq-item:first-child{border-top:1px solid var(--border)}
  .faq-q{width:100%;background:transparent;border:none;padding:18px 0;text-align:left;cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;color:var(--td);display:flex;align-items:center;justify-content:space-between;gap:14px;transition:color .15s}
  .faq-q:hover{color:var(--gm)}
  .faq-q .faq-toggle{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--gp);color:var(--gm);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;line-height:1;transition:transform .2s}
  .faq-item.open .faq-q .faq-toggle{transform:rotate(45deg)}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease,padding .25s ease}
  .faq-item.open .faq-a{max-height:500px;padding:0 0 18px 0}
  .faq-a p{font-size:14px;color:var(--tm);line-height:1.75}

  /* MODAL */
  .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:999;display:none;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto}
  .modal-overlay.open{display:flex}
  .modal{background:var(--white);border-radius:14px;width:100%;max-width:700px;box-shadow:var(--shl)}
  .modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--border)}
  .modal-title{font-family:var(--serif);font-size:20px;font-weight:600}
  .modal-close{width:32px;height:32px;border:none;background:none;font-size:20px;cursor:pointer;color:var(--muted);border-radius:6px;display:flex;align-items:center;justify-content:center}
  .modal-close:hover{background:#f5f5f0}
  .modal-body{padding:24px 28px;max-height:calc(100vh - 180px);overflow-y:auto}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .form-group{margin-bottom:16px}
  .form-label{display:block;font-size:13px;font-weight:600;color:var(--tm);margin-bottom:6px}
  .form-input{width:100%;font-family:var(--sans);font-size:14px;padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;outline:none;background:var(--white);color:var(--td);transition:border .15s}
  .form-input:focus{border-color:var(--gm)}
  textarea.form-input{resize:vertical;min-height:110px;line-height:1.6}
  select.form-input{cursor:pointer}
  .form-hint{font-size:11px;color:var(--muted);margin-top:4px}

  /* Reference rows (admin form) */
  .ref-row{display:grid;grid-template-columns:1fr 2fr auto;gap:8px;align-items:start;margin-bottom:6px}
  .ref-row input{font-family:inherit;font-size:13px;padding:8px 10px;border:1.5px solid var(--border);border-radius:7px;outline:none;transition:border .15s;width:100%}
  .ref-row input:focus{border-color:var(--gm)}
  .ref-row input.invalid{border-color:var(--red);background:#FEF6F6}
  .ref-row .ref-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:6px 8px;border-radius:6px;transition:all .15s}
  .ref-row .ref-del:hover{background:#FCEBEB;color:var(--red)}
  @media (max-width:560px){.ref-row{grid-template-columns:1fr auto;grid-auto-rows:auto}.ref-row .ref-url{grid-column:1/-1}}

  /* Further Reading card (reader view) */
  .further-reading{margin-top:48px;padding-top:24px;border-top:2px solid var(--gp)}
  .further-reading-heading{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--gd);margin-bottom:16px;display:flex;align-items:center;gap:8px}
  .further-reading-heading svg{width:18px;height:18px}
  .ref-item{display:block;background:#fafaf7;border:1px solid var(--border);border-radius:8px;padding:14px 16px;margin-bottom:10px;text-decoration:none;color:inherit;transition:all .15s}
  .ref-item:hover{background:#f3f3ee;border-color:var(--gm);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.04)}
  .ref-item .ref-title{font-size:14px;font-weight:600;color:var(--td);line-height:1.45;margin-bottom:4px}
  .ref-item .ref-domain{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}
  .ref-item .ref-domain svg{width:11px;height:11px}
  .modal-footer{padding:16px 28px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}

  /* TAGS */
  .tags-wrap{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;border:1.5px solid var(--border);border-radius:8px;min-height:44px;align-items:center;cursor:text;transition:border .15s}
  .tags-wrap:focus-within{border-color:var(--gm)}
  .tag-chip{display:flex;align-items:center;gap:4px;background:var(--gp);color:var(--gd);font-size:12px;font-weight:600;padding:3px 8px 3px 10px;border-radius:12px}
  .tag-rm{background:none;border:none;cursor:pointer;color:var(--gm);font-size:15px;line-height:1;padding:0 2px}
  .tag-rm:hover{color:var(--red)}
  .tag-field{border:none;outline:none;font-family:var(--sans);font-size:13px;min-width:100px;flex:1;background:transparent}

  /* IMAGE UPLOAD */
  .img-zone{border:2px dashed var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}
  .img-zone:hover{border-color:var(--gl)}
  .img-zone.has-img{border-style:solid;border-color:var(--gm)}
  .img-zone-inner{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}
  .img-zone-inner span{font-size:13px;color:var(--muted);font-weight:500;text-align:center}
  .img-zone-inner small{font-size:11px;color:var(--muted)}
  .img-preview-img{width:100%;height:200px;object-fit:cover;display:block;cursor:pointer}
  .img-zone-actions{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg);border-top:1px solid var(--border);flex-wrap:wrap}
  .img-zone-name{font-size:12px;color:var(--muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
  .img-rm-btn{font-size:11px;color:var(--red);background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:600}
  .or-div{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:11px;color:var(--muted)}
  .or-div::before,.or-div::after{content:'';flex:1;height:1px;background:var(--border)}
  .url-row{display:flex;gap:8px;padding:0 14px 14px}
  .url-row input{flex:1;font-family:var(--sans);font-size:13px;padding:8px 12px;border:1.5px solid var(--border);border-radius:6px;outline:none;min-width:0}
  .url-row input:focus{border-color:var(--gm)}
  .url-row button{font-family:var(--sans);font-size:12px;font-weight:600;padding:8px 14px;background:var(--gp);color:var(--gd);border:none;border-radius:6px;cursor:pointer;white-space:nowrap}
  .url-row button:hover{background:var(--gm);color:#fff}

  /* TOAST */
  .toast{position:fixed;bottom:24px;right:24px;background:var(--gd);color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s;box-shadow:var(--shl);max-width:340px}
  .toast.show{transform:translateY(0);opacity:1}

  /* LOADING SCREEN */
  .loading-screen{position:fixed;inset:0;background:var(--white);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:9998}
  .loading-screen.hidden{display:none}
  .loading-logo{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--gd)}
  .loading-logo span{color:var(--gl)}
  .loading-bar{width:200px;height:3px;background:var(--gp);border-radius:2px;overflow:hidden}
  .loading-bar-inner{height:100%;background:var(--gm);border-radius:2px;animation:loadbar 1.2s ease-in-out infinite}
  @keyframes loadbar{0%{width:0;margin-left:0}50%{width:60%;margin-left:20%}100%{width:0;margin-left:100%}}
  .loading-text{font-size:13px;color:var(--muted)}

  .empty-state{text-align:center;padding:60px 24px;grid-column:1/-1}
  .empty-state svg{width:56px;height:56px;stroke:var(--border);margin-bottom:16px}
  .empty-state h3{font-family:var(--serif);font-size:20px;color:var(--muted);margin-bottom:8px}
  .empty-state p{font-size:14px;color:var(--muted);margin-bottom:20px}

  footer{background:var(--gd);color:#9FE1CB;padding:48px 24px 24px;margin-top:80px}
  .footer-inner{max-width:1200px;margin:0 auto}
  .footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
  .footer-brand-name{font-family:var(--serif);color:#fff;font-size:24px;display:block;margin-bottom:12px}
  .footer-brand p{font-size:13px;line-height:1.7;opacity:.7;max-width:260px}
  .footer-col h4{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:14px}
  .footer-col a{display:block;font-size:13px;color:#9FE1CB;opacity:.7;margin-bottom:8px;text-decoration:none;cursor:pointer;transition:opacity .15s}
  .footer-col a:hover{opacity:1}
  .footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
  .footer-bottom p{font-size:12px;opacity:.5}

  @media(max-width:960px){.content-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.featured-card{grid-template-columns:1fr}.feat-img,.feat-img-ph{min-height:200px;height:200px}.nav-search-wrap{width:160px}}
  @media(max-width:700px){.nav-links{display:none;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:12px 16px;gap:2px;box-shadow:var(--sh);z-index:99}.nav-links.open{display:flex}.nav-search-wrap{display:none}.hamburger{display:flex}.nav-actions .btn-outline{display:none}.footer-grid{grid-template-columns:1fr}.hero{padding:36px 16px}.form-row{grid-template-columns:1fr}.gh-fields{grid-template-columns:1fr}}
  @media(max-width:480px){.article-grid{grid-template-columns:1fr}}

  /* Discovery banner — shown at the top of the home/discovery view when the user
     landed on an unknown URL. Soft, informational tone, not alarming. */
  .discovery-banner{background:var(--gp);border:1px solid #BFE5D7;border-radius:10px;margin:0 0 24px 0;padding:14px 18px}
  .discovery-banner-inner{display:flex;align-items:center;gap:14px}
  .discovery-banner-icon{flex-shrink:0;width:32px;height:32px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid #BFE5D7}
  .discovery-banner-icon svg{width:16px;height:16px;stroke:var(--gd)}
  .discovery-banner-text{display:flex;flex-direction:column;gap:2px}
  .discovery-banner-text strong{font-size:14px;color:var(--gd);font-weight:600}
  .discovery-banner-text span{font-size:13px;color:var(--tm)}
  @media (max-width:560px){.discovery-banner{padding:12px 14px}.discovery-banner-inner{gap:10px}.discovery-banner-text strong{font-size:13px}.discovery-banner-text span{font-size:12px}}
