/*
Theme Name: Victoria Teens Foundation
Theme URI: https://victoriateens.org.uk
Author: Victoria Teens Foundation
Author URI: https://victoriateens.org.uk
Description: Custom one-page charity theme for Victoria Teens Foundation — healing, learning, and digital empowerment for young survivors of sexual abuse. Built around a "rising horizon" visual signature: deep indigo night transitioning into warm daylight, mirroring the recovery journey across the site's four pillars (Heal, Learn, Empower, Speak).
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.6
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vtf
Tags: one-page, charity, non-profit, custom-colors, custom-menu, footer-widgets, translation-ready
*/

/* ==========================================================================
   This stylesheet is enqueued in its entirety via functions.php. Design
   tokens and section styles below are unchanged from the original VTF site
   design — only WordPress-specific additions (widgets, alignment classes,
   default post/page content, screen-reader text, admin bar offset) have
   been appended at the end.
   ========================================================================== */

  :root{
    --navy:#1B1F3B; --navy-deep:#11142B; --navy-soft:#2A2F55;
    --amber:#E8A33D; --amber-deep:#C97F1E; --amber-pale:#F8E3BC;
    --teal:#3FA7A0; --teal-deep:#2C7E78;
    --paper:#FBF7F1; --paper-dim:#F1EADC; --line:#E4DCCB;
    --ink:#23232B; --ink-soft:#5B5B66; --ink-faint:#86869A;
    --care:#C1502E; --care-bg:#FBEAE3;
    --white:#FFFFFF;
    --radius:20px; --radius-sm:12px;
    --shadow:0 24px 60px -24px rgba(17,20,43,0.35);
    --shadow-sm:0 10px 30px -14px rgba(17,20,43,0.25);
    --maxw:1180px;
    --font-display:'Fraunces', Georgia, serif;
    --font-body:'Inter', -apple-system, sans-serif;
    --font-mono:'IBM Plex Mono', 'Courier New', monospace;
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0; font-family:var(--font-body); color:var(--ink);
    background:var(--paper); line-height:1.6; -webkit-font-smoothing:antialiased;
  }
  img,svg{display:block; max-width:100%;}
  a{color:inherit;}
  h1,h2,h3{font-family:var(--font-display); margin:0; color:var(--navy); font-weight:600;}
  p{margin:0;}
  ul{margin:0; padding:0;}
  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
  .eyebrow{
    font-family:var(--font-mono); font-size:12.5px; letter-spacing:.12em; text-transform:uppercase;
    color:var(--amber-deep); display:flex; align-items:center; gap:10px; margin-bottom:14px; font-weight:500;
  }
  .eyebrow::before{content:""; width:22px; height:1.5px; background:var(--amber-deep); display:inline-block;}
  .eyebrow.on-dark{color:var(--amber);}
  .eyebrow.on-dark::before{background:var(--amber);}
  .btn{
    display:inline-flex; align-items:center; gap:8px; font-family:var(--font-body); font-weight:700;
    font-size:15px; padding:14px 26px; border-radius:999px; border:1.5px solid transparent;
    cursor:pointer; text-decoration:none; transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
    white-space:nowrap;
  }
  .btn:active{transform:translateY(1px);}
  .btn-amber{background:var(--amber); color:var(--navy-deep);}
  .btn-amber:hover{background:#F0AE52; box-shadow:0 14px 30px -10px rgba(232,163,61,.6);}
  .btn-ghost-dark{background:transparent; color:var(--white); border-color:rgba(255,255,255,.4);}
  .btn-ghost-dark:hover{border-color:var(--white); background:rgba(255,255,255,.08);}
  .btn-ghost-light{background:transparent; color:var(--navy); border-color:var(--navy);}
  .btn-ghost-light:hover{background:var(--navy); color:var(--white);}
  .btn-navy{background:var(--navy); color:var(--white);}
  .btn-navy:hover{background:var(--navy-soft);}
  .btn-sm{padding:9px 16px; font-size:13.5px;}
  .icon{width:22px; height:22px; flex-shrink:0;}
  .btn:focus-visible, a:focus-visible, button:focus-visible{outline:2.5px solid var(--teal); outline-offset:2px;}

  /* ---------- QUICK EXIT ---------- */
  .quick-exit{
    position:fixed; top:14px; right:18px; z-index:200;
    background:rgba(17,20,43,.92); color:#EDEFF5; border:1px solid rgba(255,255,255,.18);
    font-family:var(--font-body); font-size:13px; font-weight:600; letter-spacing:.01em;
    padding:9px 14px 9px 12px; border-radius:999px; display:flex; align-items:center; gap:6px;
    cursor:pointer; box-shadow:0 8px 24px -8px rgba(0,0,0,.45);
  }
  .quick-exit:hover{background:var(--care);}
  .quick-exit .icon{width:15px; height:15px;}
  @media (max-width: 880px){
    .quick-exit{top:auto; bottom:18px; right:16px; box-shadow:0 10px 26px -8px rgba(0,0,0,.55);}
  }

  /* ---------- NAV ---------- */
  header.site{
    position:sticky; top:0; z-index:100; background:rgba(27,31,59,.88);
    backdrop-filter:blur(10px); border-bottom:1px solid rgba(255,255,255,.08);
  }
  .nav-row{display:flex; align-items:center; justify-content:space-between; padding:14px 28px; gap:18px; max-width:var(--maxw); margin:0 auto;}
  .brand{display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0;}
  .brand-mark{width:34px; height:34px;}
  .brand-word{font-family:var(--font-display); color:var(--white); font-size:17px; font-weight:600; line-height:1.1;}
  .brand-word span{display:block; font-family:var(--font-mono); font-size:9.5px; letter-spacing:.16em; color:var(--amber); font-weight:500; margin-top:1px;}
  nav.links{display:flex; align-items:center; gap:26px; font-size:14.5px; font-weight:500;}
  nav.links ul{display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0;}
  nav.links li{list-style:none; margin:0; padding:0;}
  nav.links a{color:#D9DCE8; text-decoration:none; transition:color .15s;}
  nav.links a:hover{color:var(--white);}
  nav.links li > a{display:block;}
  nav.links .sub-menu{display:none;}
  .nav-cta{display:flex; align-items:center; gap:10px; flex-shrink:0;}
  .nav-toggle{display:none; background:none; border:none; color:var(--white); cursor:pointer; padding:6px;}
  .nav-toggle .icon{width:24px; height:24px;}
  .mobile-panel{display:none;}

  @media (max-width: 880px){
    nav.links{display:none;}
    .nav-toggle{display:block;}
    .mobile-panel.open{
      display:flex; flex-direction:column; gap:2px; padding:8px 28px 18px;
      background:rgba(27,31,59,.97);
    }
    .mobile-panel a{color:#D9DCE8; text-decoration:none; padding:10px 0; font-size:15px; border-top:1px solid rgba(255,255,255,.08); display:block;}
    .mobile-panel ul{list-style:none; margin:0; padding:0;}
    .mobile-panel li{list-style:none; margin:0; padding:0;}
    .mobile-panel .sub-menu{display:none;}
    .brand-word{font-size:15px;}
  }

  /* ---------- HERO ---------- */
  .hero{
    position:relative; background:radial-gradient(120% 100% at 18% 0%, #262C54 0%, var(--navy) 46%, var(--navy-deep) 100%);
    color:var(--white); overflow:hidden; padding-bottom:120px;
  }
  .hero-grid{
    max-width:var(--maxw); margin:0 auto; padding:84px 28px 40px; position:relative; z-index:2;
    display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center;
  }
  .hero h1{
    color:var(--white); font-size:clamp(36px,5.4vw,60px); line-height:1.06; letter-spacing:-.01em; font-weight:600;
  }
  .hero h1 em{color:var(--amber); font-style:normal; font-weight:600;}
  .hero p.lead{
    margin-top:22px; font-size:18px; color:#C9CDE2; max-width:480px; line-height:1.65;
  }
  .hero .cta-row{display:flex; gap:14px; margin-top:34px; flex-wrap:wrap;}
  .trust-row{
    margin-top:40px; display:flex; gap:24px; flex-wrap:wrap; font-family:var(--font-mono);
    font-size:11.5px; letter-spacing:.06em; color:#9DA3C2; text-transform:uppercase;
  }
  .trust-row span{display:flex; align-items:center; gap:7px;}
  .trust-row .dot{width:5px; height:5px; border-radius:50%; background:var(--amber); display:inline-block;}

  .hero-art{position:relative; height:340px;}
  .hero-art svg{position:absolute; inset:0; width:100%; height:100%;}
  .sun-glow{
    position:absolute; border-radius:50%; background:radial-gradient(circle, rgba(232,163,61,.55), transparent 70%);
    width:340px; height:340px; right:-40px; top:30px; filter:blur(6px);
    animation:pulseGlow 7s ease-in-out infinite;
  }
  @keyframes pulseGlow{ 0%,100%{opacity:.55;} 50%{opacity:.85;} }
  @media (prefers-reduced-motion: reduce){ .sun-glow{animation:none;} }

  .horizon-edge{position:absolute; left:0; right:0; bottom:-2px; height:170px; z-index:1; pointer-events:none;}
  .horizon-edge svg{width:100%; height:100%; display:block;}

  @media (max-width: 880px){
    .hero-grid{grid-template-columns:1fr; padding-top:54px;}
    .hero-art{height:220px; order:-1;}
  }

  /* ---------- SECTION SCAFFOLDING ---------- */
  section{padding:96px 0;}
  .section-paper{background:var(--paper);}
  .section-dim{background:var(--paper-dim);}
  .head-block{max-width:640px; margin-bottom:48px;}
  .head-block h2{font-size:clamp(28px,3.4vw,40px); line-height:1.15;}
  .head-block p{margin-top:16px; font-size:17px; color:var(--ink-soft); line-height:1.65;}
  .reveal{opacity:1; transform:none;}
  .has-js .reveal{opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease;}
  .has-js .reveal.is-visible{opacity:1; transform:none;}
  @media (prefers-reduced-motion: reduce){
    .has-js .reveal{opacity:1; transform:none; transition:none;}
  }

  /* ---------- STATS BAND ---------- */
  .stats-band{background:var(--paper); border-bottom:1px solid var(--line);}
  .stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:0;}
  .stat{padding:38px 26px; border-left:1px solid var(--line);}
  .stat:first-child{border-left:none;}
  .stat .num{font-family:var(--font-mono); font-size:30px; color:var(--navy); font-weight:500;}
  .stat .lbl{margin-top:8px; font-size:13.5px; color:var(--ink-soft); line-height:1.5;}
  @media (max-width: 880px){
    .stats-grid{grid-template-columns:1fr 1fr;}
    .stat:nth-child(3){border-left:none;}
    .stat{border-bottom:1px solid var(--line);}
  }

  /* ---------- ABOUT ---------- */
  .about-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;}
  .quote-card{
    background:var(--navy); color:var(--white); border-radius:var(--radius); padding:38px 36px;
    box-shadow:var(--shadow); position:relative; overflow:hidden;
  }
  .quote-card::after{
    content:""; position:absolute; right:-30px; bottom:-50px; width:160px; height:160px; border-radius:50%;
    background:radial-gradient(circle, rgba(232,163,61,.35), transparent 70%);
  }
  .quote-card p{
    font-family:var(--font-display); font-size:23px; line-height:1.5; font-style:italic; font-weight:500; position:relative; z-index:1;
  }
  .quote-card .sig{margin-top:18px; font-family:var(--font-mono); font-size:11.5px; color:var(--amber); letter-spacing:.06em; text-transform:uppercase; position:relative; z-index:1;}
  .mini-belief{display:flex; gap:14px; padding:18px 0; border-top:1px solid var(--line);}
  .mini-belief:first-of-type{border-top:none; padding-top:0;}
  .mini-belief .num{font-family:var(--font-mono); color:var(--amber-deep); font-weight:500; font-size:14px; padding-top:2px;}
  .mini-belief h3{font-size:16.5px; font-weight:700; color:var(--navy); margin-bottom:5px; font-family:var(--font-body);}
  .mini-belief p{font-size:14.5px; color:var(--ink-soft); line-height:1.55;}

  @media (max-width: 880px){ .about-grid{grid-template-columns:1fr; gap:36px;} }

  /* ---------- SUPPORT ---------- */
  .support{background:var(--navy-deep); color:var(--white);}
  .support .head-block h2{color:var(--white);}
  .support .head-block p{color:#C9CDE2;}
  .support-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
  .s-card{
    background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius);
    padding:30px 26px; transition:background .2s, transform .2s;
  }
  .s-card:hover{background:rgba(255,255,255,.09); transform:translateY(-3px);}
  .s-card .icon-wrap{width:46px; height:46px; border-radius:12px; background:var(--amber); display:flex; align-items:center; justify-content:center; margin-bottom:18px;}
  .s-card .icon-wrap .icon{color:var(--navy-deep); width:24px; height:24px;}
  .s-card h3{color:var(--white); font-size:18px; margin-bottom:8px; font-family:var(--font-body);}
  .s-card p{color:#BFC3DC; font-size:14.5px; line-height:1.6;}
  .s-card a.tap{display:inline-flex; margin-top:14px; color:var(--amber); font-weight:700; font-size:14px; text-decoration:none; align-items:center; gap:6px;}

  .emergency{
    margin-top:36px; background:var(--care-bg); border:1px solid #E8C3B3; border-radius:var(--radius-sm);
    padding:22px 26px; display:flex; gap:16px; align-items:flex-start;
  }
  .emergency .icon{color:var(--care); width:24px; height:24px; flex-shrink:0; margin-top:2px;}
  .emergency p{color:#7A3A26; font-size:14.5px; line-height:1.65;}
  .emergency strong{color:#5C2A1A;}

  @media (max-width: 880px){ .support-cards{grid-template-columns:1fr;} }

  /* ---------- PILLARS ---------- */
  .pillars-rail{position:relative; max-width:840px; margin:0 auto;}
  .pillar-item{
    display:grid; grid-template-columns:64px 1fr; gap:26px; position:relative; padding-bottom:56px;
  }
  .pillar-item:last-child{padding-bottom:0;}
  .rail-col{position:relative; display:flex; flex-direction:column; align-items:center;}
  .rail-line{position:absolute; top:54px; bottom:-2px; width:2px; background:var(--line); left:50%; transform:translateX(-50%);}
  .pillar-item:last-child .rail-line{display:none;}
  .node{
    width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-family:var(--font-mono); font-weight:500; font-size:14px; color:var(--white); z-index:1;
    box-shadow:0 8px 22px -8px rgba(17,20,43,.45);
  }
  .pillar-body{
    background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px 30px;
    box-shadow:var(--shadow-sm);
  }
  .pillar-body .ptag{font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:6px;}
  .pillar-body h3{font-size:21px; margin-bottom:10px;}
  .pillar-body p{color:var(--ink-soft); font-size:15px; line-height:1.65;}
  .pillar-body .modelled{margin-top:14px; font-size:12.5px; color:var(--ink-faint); font-style:italic;}

  @media (max-width: 600px){
    .pillar-item{grid-template-columns:46px 1fr; gap:16px;}
    .node{width:42px; height:42px; font-size:12px;}
    .rail-line{top:44px;}
    .pillar-body{padding:22px 20px;}
  }

  /* ---------- SAFEGUARDING ---------- */
  .safe-grid{display:grid; grid-template-columns:1fr 1fr; gap:6px 28px;}
  .safe-item{display:flex; gap:16px; padding:20px 0; align-items:flex-start; border-top:1px solid var(--line);}
  .safe-item:nth-child(1), .safe-item:nth-child(2){border-top:none;}
  .safe-item .icon-wrap{
    width:42px; height:42px; border-radius:11px; background:var(--paper); border:1px solid var(--line);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
  }
  .safe-item .icon-wrap .icon{width:21px; height:21px; color:var(--teal-deep);}
  .safe-item h3{font-size:16px; margin-bottom:5px; font-family:var(--font-body);}
  .safe-item p{font-size:14px; color:var(--ink-soft); line-height:1.55;}
  @media (max-width: 700px){
    .safe-grid{grid-template-columns:1fr;}
    .safe-item:nth-child(2){border-top:1px solid var(--line);}
  }

  /* ---------- MANIFESTO STRIP ---------- */
  .manifesto{background:var(--navy); color:var(--white); position:relative; overflow:hidden;}
  .manifesto::before{
    content:""; position:absolute; top:-120px; left:50%; transform:translateX(-50%); width:680px; height:680px;
    border-radius:50%; background:radial-gradient(circle, rgba(232,163,61,.18), transparent 68%);
  }
  .manifesto-inner{position:relative; z-index:1; text-align:center; max-width:760px; margin:0 auto;}
  .manifesto .eyebrow{justify-content:center;}
  .manifesto h2{color:var(--white); font-size:clamp(26px,3.2vw,36px);}
  .belief-track{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:48px; text-align:left;}
  .belief-card{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-sm); padding:22px 20px;}
  .belief-card .num{font-family:var(--font-mono); color:var(--amber); font-size:13px;}
  .belief-card p{margin-top:10px; font-size:14.5px; color:#D9DCE8; line-height:1.55;}
  .manifesto .closing{margin-top:44px; font-family:var(--font-display); font-style:italic; font-size:20px; color:var(--amber-pale);}
  @media (max-width: 880px){ .belief-track{grid-template-columns:1fr 1fr;} }
  @media (max-width: 560px){ .belief-track{grid-template-columns:1fr;} }

  /* ---------- GET INVOLVED ---------- */
  .involve-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
  .involve-card{
    background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:32px 28px;
    box-shadow:var(--shadow-sm); display:flex; flex-direction:column; height:100%;
  }
  .involve-card .icon-wrap{
    width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:20px;
  }
  .involve-card:nth-child(1) .icon-wrap{background:var(--amber-pale);}
  .involve-card:nth-child(1) .icon-wrap .icon{color:var(--amber-deep);}
  .involve-card:nth-child(2) .icon-wrap{background:#DCEEEC;}
  .involve-card:nth-child(2) .icon-wrap .icon{color:var(--teal-deep);}
  .involve-card:nth-child(3) .icon-wrap{background:#E3E5F0;}
  .involve-card:nth-child(3) .icon-wrap .icon{color:var(--navy);}
  .involve-card h3{font-size:19px; margin-bottom:10px;}
  .involve-card p{font-size:14.5px; color:var(--ink-soft); line-height:1.6; flex-grow:1;}
  .involve-card .btn{margin-top:20px; align-self:flex-start;}
  @media (max-width: 880px){ .involve-grid{grid-template-columns:1fr;} }

  /* ---------- FOOTER ---------- */
  footer.site{background:var(--navy-deep); color:#A9ADC4; padding:64px 0 28px;}
  .foot-top{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1);}
  .foot-brand .brand-word{color:var(--white);}
  .foot-brand p{margin-top:16px; font-size:13.5px; line-height:1.7; max-width:280px; color:#9398B3;}
  .foot-col h4{font-family:var(--font-mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:#777EA0; margin-bottom:16px; font-weight:500;}
  .foot-col a{display:block; font-size:14px; color:#C7CBDF; text-decoration:none; padding:6px 0;}
  .foot-col a:hover{color:var(--white);}
  .foot-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:24px; flex-wrap:wrap; gap:14px; font-size:12.5px; color:#6F7593;}
  .status-pill{
    display:inline-flex; align-items:center; gap:7px; background:rgba(232,163,61,.12); border:1px solid rgba(232,163,61,.35);
    color:var(--amber); padding:6px 13px; border-radius:999px; font-family:var(--font-mono); font-size:11px; letter-spacing:.04em;
  }
  .status-pill .dot{width:6px; height:6px; border-radius:50%; background:var(--amber);}
  @media (max-width: 880px){
    .foot-top{grid-template-columns:1fr 1fr; gap:30px;}
    .foot-brand{grid-column:1 / -1;}
  }
  @media (max-width: 560px){
    .foot-top{grid-template-columns:1fr;}
  }

/* ==========================================================================
   WordPress-specific additions
   ========================================================================== */

/* Screen-reader text (WordPress core requirement for accessibility) */
.screen-reader-text{
  border:0; clip:rect(1px,1px,1px,1px); clip-path:inset(50%); height:1px;
  margin:-1px; overflow:hidden; padding:0; position:absolute!important; width:1px;
  word-wrap:normal!important;
}
.skip-link{
  position:absolute; left:-9999px; top:1px; z-index:999999;
  background:var(--navy); color:var(--white); padding:12px 18px; border-radius:0 0 8px 0;
  font-family:var(--font-body); font-weight:600; text-decoration:none;
}
.skip-link:focus{left:0;}

/* Push fixed/sticky elements down when the WP admin bar is showing */
.admin-bar header.site{top:32px;}
@media screen and (max-width:600px){
  .admin-bar header.site{top:46px;}
}
.admin-bar .quick-exit{top:46px;}
@media screen and (max-width:600px){
  .admin-bar .quick-exit{top:auto;}
}

/* Footer widget areas — styled to match the existing .foot-col look so
   anything added via Appearance → Widgets sits naturally in the design */
.foot-col .widget{margin-bottom:0;}
.foot-col .widget-title{
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
  color:#777EA0; margin:0 0 16px; font-weight:500;
}
.foot-col ul{list-style:none; margin:0; padding:0;}
.foot-col ul li{padding:0;}
.foot-col select, .foot-col input[type="text"]{
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
  color:#C7CBDF; padding:8px 10px; border-radius:8px; font-family:var(--font-body); font-size:13px;
}

/* Generic page/post content (used by page.php, single.php, index.php loop) */
.page-hero{
  background:var(--navy); color:var(--white); padding:74px 0 64px; position:relative; overflow:hidden;
}
.page-hero::after{
  content:""; position:absolute; right:-60px; top:-60px; width:280px; height:280px; border-radius:50%;
  background:radial-gradient(circle, rgba(232,163,61,.25), transparent 70%);
}
.page-hero .wrap{position:relative; z-index:1;}
.page-hero h1{color:var(--white); font-size:clamp(30px,4.4vw,46px);}
.page-hero .meta{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--amber); margin-top:14px;
}

.entry-content{max-width:760px; margin:0 auto; padding:64px 28px; font-size:16.5px; color:var(--ink-soft); line-height:1.75;}
.entry-content h2{margin-top:42px; margin-bottom:14px; font-size:26px; color:var(--navy);}
.entry-content h3{margin-top:30px; margin-bottom:10px; font-size:20px; color:var(--navy);}
.entry-content p{margin-bottom:18px;}
.entry-content ul, .entry-content ol{margin:0 0 18px; padding-left:22px;}
.entry-content li{margin-bottom:8px;}
.entry-content a{color:var(--amber-deep); text-decoration:underline; text-decoration-color:var(--line);}
.entry-content blockquote{
  border-left:3px solid var(--amber); margin:24px 0; padding:4px 22px; font-style:italic; color:var(--navy);
  font-family:var(--font-display); font-size:19px;
}
.entry-content img{border-radius:var(--radius-sm); margin:18px 0;}
.entry-content .alignleft{float:left; margin:0 22px 14px 0;}
.entry-content .alignright{float:right; margin:0 0 14px 22px;}
.entry-content .aligncenter{display:block; margin:18px auto;}
.entry-content .wp-caption-text{font-size:13px; color:var(--ink-faint); margin-top:6px;}

/* Blog index / archive cards (index.php, archive.php) */
.post-list{max-width:760px; margin:0 auto; padding:64px 28px; display:flex; flex-direction:column; gap:28px;}
.post-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px 30px;
  box-shadow:var(--shadow-sm);
}
.post-card .post-meta{font-family:var(--font-mono); font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:8px;}
.post-card h2{font-size:23px; margin-bottom:10px;}
.post-card h2 a{color:var(--navy); text-decoration:none;}
.post-card h2 a:hover{color:var(--amber-deep);}
.post-card p{color:var(--ink-soft); font-size:15.5px; line-height:1.65;}
.post-card .read-more{display:inline-flex; margin-top:14px; color:var(--amber-deep); font-weight:700; font-size:14px; text-decoration:none;}
.pagination{display:flex; gap:10px; justify-content:center; padding:0 28px 64px;}
.pagination a, .pagination span{
  padding:9px 16px; border-radius:999px; border:1px solid var(--line); font-size:14px; color:var(--navy); text-decoration:none;
}
.pagination .current{background:var(--navy); color:var(--white); border-color:var(--navy);}

.no-results{max-width:600px; margin:0 auto; padding:90px 28px; text-align:center;}
.no-results h2{margin-bottom:14px;}
.no-results p{color:var(--ink-soft); margin-bottom:24px;}

.comment-respond{max-width:760px; margin:0 auto 64px; padding:0 28px;}
.comment-respond input, .comment-respond textarea{
  width:100%; border:1px solid var(--line); border-radius:var(--radius-sm); padding:12px 14px;
  font-family:var(--font-body); font-size:15px; margin-bottom:14px; background:var(--paper);
}
.comment-respond label{display:block; font-size:13.5px; color:var(--ink-soft); margin-bottom:6px;}
