/* ═══════════════════════════════════════════════════════════
   BLISSINTALE v16 — Warmer, Brighter, Refined
   Cross-platform: Windows · Mac · iOS · Android
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;1,500;1,600;1,700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400;1,9..40,500&display=swap');

/* ── Design Tokens ── */
:root {
  /* Backgrounds — warm white, not grey */
  --bg:#FDFCFA; --bg-alt:#F5F2EE; --bg-card:#FFFFFF; --bg-soft:#F0EEF9;
  /* Text — deeper, richer */
  --ink:#0D0D0D; --ink-soft:#2E2E2E; --muted:#5A5A6A; --muted-light:#8888A0;
  --black:#08080E; --black-mid:#111118;
  /* Brand colours — more vibrant */
  --violet:#6D28D9; --violet-mid:#7C3AED; --violet-bright:#8B5CF6; --violet-soft:#EDE9FE; --violet-dark:#5B21B6;
  --rose:#DB1777; --rose-bright:#F01680; --rose-soft:#FCE7F3;
  --teal:#0D9488; --teal-soft:#CCFBF1;
  --amber:#D97706; --amber-soft:#FEF3C7;
  --sky:#0284C7; --sky-soft:#E0F2FE;
  --emerald:#059669; --emerald-soft:#D1FAE5;
  /* Gradient — more saturated, vivid */
  --grad:linear-gradient(135deg,#6D28D9 0%,#DB1777 100%);
  --grad-vivid:linear-gradient(135deg,#7C3AED 0%,#F01680 100%);
  --grad-soft:linear-gradient(135deg,#EDE9FE 0%,#FCE7F3 100%);
  /* Borders — slightly warmer */
  --border:#E2DDD8; --border-soft:#EAE6E0;
  /* Typography */
  --font-display:'Playfair Display',Georgia,serif;
  --font-ui:'DM Sans',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --max-w:1200px; --radius:12px; --radius-sm:8px; --radius-pill:100px;
}
[data-theme="dark"] {
  --bg:#0A0A0F; --bg-alt:#131318; --bg-card:#1C1C26; --bg-soft:#1E1840;
  --ink:#EDEDF4; --ink-soft:#C8C8D8; --muted:#8888A0; --muted-light:#55556A;
  --border:#28283A; --border-soft:#20202E;
  --violet-soft:#1E1840; --rose-soft:#2A0F1E; --teal-soft:#0A2420;
  --amber-soft:#251A08; --sky-soft:#0A1E2A; --emerald-soft:#0A2018;
  --grad-soft:linear-gradient(135deg,#1E1840 0%,#2A0F1E 100%);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:var(--font-ui);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px;zoom:var(--font-zoom,1)}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}
input,textarea,select{font-family:inherit;-webkit-appearance:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max-w);margin:0 auto;padding:0 48px}
@media(max-width:768px){.container{padding:0 20px}}
@media(max-width:400px){.container{padding:0 16px}}

/* ── Reading Progress ── */
.reading-progress{position:fixed;top:0;left:0;z-index:999;height:3px;width:0%;background:var(--grad-vivid);transition:width 0.1s linear}

/* ══════════════════════════════════
   HEADER
   ══════════════════════════════════ */
.site-header{position:sticky;top:0;z-index:100;background:var(--black);border-bottom:1px solid rgba(255,255,255,0.07)}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 48px;height:64px;display:flex;align-items:center;gap:32px}
.brand{font-family:var(--font-display);font-size:22px;font-weight:700;color:white;letter-spacing:0.01em;flex-shrink:0;line-height:1}
.brand em{font-style:normal;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav{display:flex;align-items:center;gap:24px;margin-left:auto}
/* Nav links — brighter, easier to read */
.nav-link{font-size:13.5px;font-weight:500;color:rgba(255,255,255,0.62);transition:color 0.15s;white-space:nowrap}
.nav-link:hover,.nav-link.active{color:white}
/* Single CTA only — "Tell your story" removed from nav, kept only as .nav-cta */
.nav-cta{font-size:13px;font-weight:600;background:var(--grad-vivid);color:white;padding:8px 20px;border-radius:var(--radius-pill);transition:opacity 0.15s,transform 0.1s;border:none;white-space:nowrap;flex-shrink:0}
.nav-cta:hover{opacity:0.88;transform:translateY(-1px)}
.theme-toggle{background:none;border:1px solid rgba(255,255,255,0.12);padding:6px 10px;font-size:14px;color:rgba(255,255,255,0.5);border-radius:8px;transition:all 0.15s;flex-shrink:0;line-height:1}
.theme-toggle:hover{border-color:var(--violet-bright);color:white}
[data-theme="light"] .icon-sun,[data-theme="dark"] .icon-moon{display:none}
.nav-toggle{display:none;background:none;border:none;flex-direction:column;gap:5px;padding:8px 4px;flex-shrink:0}
.nav-toggle span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,0.6);transition:0.2s;border-radius:1px}
.mobile-nav{display:none}

@media(max-width:900px){
  .header-inner{padding:0 20px;gap:12px}
  .nav-cta{display:none}
  .nav{gap:16px}
  .nav-link{font-size:13px}
}
@media(max-width:768px){
  .nav{display:none}
  .nav-toggle{display:flex}
  .mobile-nav{display:none;position:fixed;inset:64px 0 0 0;background:var(--black);z-index:99;flex-direction:column;padding:20px 24px 32px;gap:0;border-top:1px solid rgba(255,255,255,0.07);overflow-y:auto}
  .mobile-nav.open{display:flex}
  .mobile-nav a{font-size:17px;font-weight:500;color:rgba(255,255,255,0.65);padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.06);transition:color 0.15s;display:block}
  .mobile-nav a:hover{color:white}
  .mobile-cta{margin-top:20px;background:var(--grad-vivid)!important;color:white!important;text-align:center;padding:14px!important;font-weight:600!important;border:none!important;border-radius:var(--radius-pill)!important;border-bottom:none!important}
}

/* ══════════════════════════════════
   BUTTONS
   ══════════════════════════════════ */
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;background:var(--grad-vivid);color:white;padding:12px 28px;border:none;border-radius:var(--radius-pill);transition:opacity 0.15s,transform 0.1s;cursor:pointer;white-space:nowrap;line-height:1.2}
.btn-primary:hover{opacity:0.88;transform:translateY(-1px)}
.btn-primary.large{font-size:15px;padding:14px 36px}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;background:transparent;color:var(--ink);padding:11px 28px;border:1.5px solid var(--border);border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer;white-space:nowrap;line-height:1.2}
.btn-outline:hover{border-color:var(--violet-mid);color:var(--violet-mid)}
.btn-outline-inv{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;background:transparent;color:white;padding:11px 28px;border:1.5px solid rgba(255,255,255,0.28);border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer;line-height:1.2}
.btn-outline-inv:hover{border-color:white;background:rgba(255,255,255,0.08)}
.btn-navy{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;background:var(--violet-dark);color:white;padding:12px 28px;border:none;border-radius:var(--radius-pill);transition:opacity 0.15s;cursor:pointer;line-height:1.2}
.btn-navy:hover{opacity:0.88}
.btn-sm{font-size:12px;font-weight:600;background:none;border:1px solid var(--border);color:var(--muted);padding:7px 16px;border-radius:var(--radius-sm);transition:all 0.15s;cursor:pointer;line-height:1.2}
.btn-sm:hover{border-color:var(--violet-mid);color:var(--violet-mid)}
.btn-report{font-size:12px;font-weight:500;background:none;border:1px solid var(--border);color:var(--muted);padding:7px 16px;border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer;line-height:1.2;display:inline-flex;align-items:center;gap:6px}
.btn-report:hover{border-color:#f87171;color:#f87171;background:rgba(248,113,113,0.05)}

/* ══════════════════════════════════
   HERO
   ══════════════════════════════════ */
.hero{background:var(--black);border-bottom:1px solid rgba(255,255,255,0.07);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 55% 80% at 80% 50%,rgba(109,40,217,0.24) 0%,transparent 65%),radial-gradient(ellipse 40% 60% at 15% 80%,rgba(219,23,119,0.16) 0%,transparent 60%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;position:relative;z-index:1;min-height:520px}
.hero-left{padding:88px 64px 88px 48px;border-right:1px solid rgba(255,255,255,0.07);display:flex;flex-direction:column;justify-content:center}
.hero-right{padding:64px 48px;display:flex;flex-direction:column;justify-content:center;gap:24px}
.hero-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px;display:flex;align-items:center;gap:12px}
.hero-eyebrow::before{content:'';display:inline-block;width:32px;height:1px;background:var(--violet-bright)}
.hero-headline{font-family:var(--font-display);font-size:clamp(40px,5vw,76px);font-weight:700;line-height:1.08;color:white;margin-bottom:12px;letter-spacing:-0.02em}
.hero-headline strong{display:block;font-style:italic;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-tagline{font-family:var(--font-display);font-size:17px;font-style:italic;font-weight:500;color:rgba(255,255,255,0.5);margin-bottom:36px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-search-panel{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius);padding:28px;position:relative}
.hero-search-panel::before{content:'';position:absolute;top:-1px;left:0;right:0;height:2px;background:var(--grad-vivid);border-radius:var(--radius) var(--radius) 0 0}
.hero-search-label{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.38);margin-bottom:12px}
.hero-search-row{display:flex;gap:8px}
.hero-search-input{flex:1;font-size:14px;padding:11px 16px;border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-sm);background:rgba(255,255,255,0.06);color:white;outline:none;transition:border-color 0.15s;min-width:0}
.hero-search-input::placeholder{color:rgba(255,255,255,0.3)}
.hero-search-input:focus{border-color:var(--violet-bright)}
.hero-search-btn{font-size:13px;font-weight:600;background:var(--grad-vivid);color:white;border:none;padding:11px 20px;border-radius:var(--radius-sm);transition:opacity 0.15s;white-space:nowrap;flex-shrink:0}
.hero-search-btn:hover{opacity:0.85}
.hero-stats{opacity:0;transition:opacity 0.4s}
.hero-stats.loaded{opacity:1}
.hero-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px}
.hero-stat{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);padding:20px 12px;border-radius:var(--radius);display:flex;flex-direction:column;gap:4px;align-items:center;text-align:center}
.hero-stat-num{font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-stat-label{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.4)}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;min-height:unset}
  .hero-left{padding:60px 20px 40px;border-right:none;border-bottom:1px solid rgba(255,255,255,0.07)}
  .hero-right{padding:36px 20px 56px}
}

/* ══════════════════════════════════
   STORY OF THE DAY
   ══════════════════════════════════ */
.sotd-section{background:var(--grad-vivid);position:relative;overflow:hidden}
.sotd-section::before{content:'★';position:absolute;right:-10px;top:50%;transform:translateY(-50%);font-size:200px;color:rgba(255,255,255,0.05);pointer-events:none;line-height:1}
.sotd-inner{display:grid;grid-template-columns:180px 1fr;align-items:stretch;min-height:190px}
.sotd-label-col{background:rgba(0,0,0,0.18);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;gap:12px}
.sotd-label-vert{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}
.sotd-star{font-size:24px;color:rgba(255,255,255,0.45)}
.sotd-content{padding:36px 48px;display:flex;flex-direction:column;justify-content:center;gap:10px}
.sotd-theme{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.65)}
.sotd-title{font-family:var(--font-display);font-size:clamp(20px,3vw,34px);font-weight:700;color:white;line-height:1.2}
.sotd-title a{color:inherit}.sotd-title a:hover{text-decoration:underline}
.sotd-snippet{font-size:15px;color:rgba(255,255,255,0.75);line-height:1.6;max-width:580px}
.sotd-meta{font-size:12px;color:rgba(255,255,255,0.5)}
.sotd-read{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:white;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.28);padding:9px 20px;border-radius:var(--radius-pill);transition:all 0.15s;margin-top:6px;align-self:flex-start}
.sotd-read:hover{background:rgba(255,255,255,0.28)}
@media(max-width:700px){.sotd-inner{grid-template-columns:1fr}.sotd-label-col{display:none}.sotd-content{padding:28px 20px}}

/* ══════════════════════════════════
   THEMES GRID
   ══════════════════════════════════ */
.themes-section{background:var(--black);padding:80px 0}
.themes-section .section-title{color:white}
.themes-section .section-head{border-color:rgba(255,255,255,0.08)}
.themes-section .section-label{color:var(--violet-bright)}
.themes-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}
.theme-pill{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.09);border-radius:var(--radius);padding:28px 12px;display:flex;flex-direction:column;align-items:center;gap:12px;text-decoration:none;transition:all 0.2s}
.theme-pill:hover{border-color:rgba(255,255,255,0.22);background:rgba(255,255,255,0.09);transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,0.35)}
.theme-pill-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;transition:transform 0.2s;background:rgba(255,255,255,0.08)}
.theme-pill:hover .theme-pill-icon{transform:scale(1.1)}
.theme-pill[href*="Inspiration"] .theme-pill-icon{background:rgba(124,58,237,0.28)}
.theme-pill[href*="Love"] .theme-pill-icon{background:rgba(240,22,128,0.28)}
.theme-pill[href*="Failure"] .theme-pill-icon{background:rgba(217,119,6,0.28)}
.theme-pill[href*="Success"] .theme-pill-icon{background:rgba(5,150,105,0.28)}
.theme-pill[href*="Confession"] .theme-pill-icon{background:rgba(2,132,199,0.28)}
.theme-pill[href*="Help"] .theme-pill-icon{background:rgba(13,148,136,0.28)}
.theme-pill[href*="Reflections"] .theme-pill-icon{background:rgba(99,102,241,0.28)}
.theme-pill-name{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.72);text-align:center}
.theme-pill:hover .theme-pill-name{color:white}
.theme-pill-count{font-size:10px;color:rgba(255,255,255,0.38)}
@media(max-width:1024px){.themes-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:600px){.themes-grid{grid-template-columns:repeat(2,1fr)}}

/* ══════════════════════════════════
   SECTION HEADS
   ══════════════════════════════════ */
.section-head{display:flex;align-items:baseline;gap:20px;margin-bottom:36px;padding-bottom:18px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.section-label{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--violet-mid)}
.section-title{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);line-height:1.2}
.section-link{font-size:12.5px;font-weight:600;color:var(--violet-mid);margin-left:auto;white-space:nowrap;transition:color 0.15s}
.section-link:hover{text-decoration:underline;color:var(--violet-dark)}

/* ══════════════════════════════════
   STORY CARDS
   ══════════════════════════════════ */
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.story-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:12px;transition:all 0.2s;height:100%}
.story-card:hover{border-color:var(--violet-mid);box-shadow:0 4px 28px rgba(109,40,217,0.12);transform:translateY(-2px)}
.story-theme-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--violet-mid);background:var(--violet-soft);padding:3px 10px;border-radius:var(--radius-pill);align-self:flex-start;transition:all 0.15s}
.story-theme-tag:hover{background:var(--violet-mid);color:white}
.story-card-title{font-family:var(--font-display);font-size:20px;font-weight:700;line-height:1.3;color:var(--ink)}
.story-card-title a{color:inherit;transition:color 0.15s}.story-card-title a:hover{color:var(--violet-mid)}
.story-snippet{font-size:14px;color:var(--muted);line-height:1.65;flex:1}
.story-meta-row{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border-soft);margin-top:auto;gap:8px}
.story-time{font-size:11.5px;color:var(--muted-light)}
.story-read{font-size:12px;font-weight:600;color:var(--violet-mid);transition:color 0.15s;white-space:nowrap}
.story-read:hover{text-decoration:underline}
@media(max-width:900px){.story-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.story-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════
   QUOTES — Wall / Masonry style
   ══════════════════════════════════ */
.quotes-section{padding:80px 0;background:var(--bg-alt)}

/* Homepage quotes: 3-card spotlight row */
.home-quotes-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.home-quotes-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.home-quotes-row{grid-template-columns:1fr}}

/* Full page: masonry-inspired, variable height columns */
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
.quote-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 28px 20px;display:flex;flex-direction:column;gap:14px;transition:all 0.2s;position:relative;overflow:hidden;break-inside:avoid}
.quote-card::before{content:'\201C';position:absolute;top:-14px;left:14px;font-family:var(--font-display);font-size:96px;font-weight:800;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;pointer-events:none;z-index:0;opacity:0.18}
.quote-card:hover{border-color:var(--rose);box-shadow:0 4px 28px rgba(219,23,119,0.1);transform:translateY(-2px)}
.quote-text{font-family:var(--font-display);font-size:17px;font-weight:500;font-style:italic;line-height:1.7;color:var(--ink);position:relative;z-index:1}
.quote-meta-row{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px;border-top:1px solid var(--border-soft)}
.quote-time{font-size:11px;color:var(--muted-light)}
.quote-heart-btn{background:none;border:none;color:var(--muted-light);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:5px;font-size:12px;padding:4px}
.quote-heart-btn:hover,.quote-heart-btn.liked{color:var(--rose)}

/* Homepage "see all" link row */
.quotes-cta-row{display:flex;justify-content:center;gap:12px;margin-top:32px;flex-wrap:wrap}
.quotes-preview-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.quotes-grid{grid-template-columns:repeat(2,1fr)};.quotes-preview-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.quotes-grid{grid-template-columns:1fr}}

/* Quote submit bar */
.quote-submit-bar{background:var(--grad-vivid);padding:64px 0;position:relative;overflow:hidden}
.quote-submit-bar::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 100% at 85% 50%,rgba(255,255,255,0.08) 0%,transparent 60%)}
.quote-submit-inner{max-width:640px;margin:0 auto;padding:0 48px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}
.quote-submit-title{font-family:var(--font-display);font-size:30px;font-weight:700;color:white;font-style:italic;line-height:1.2}
.quote-submit-sub{font-size:14px;color:rgba(255,255,255,0.72);line-height:1.6}
.quote-textarea{width:100%;font-family:var(--font-display);font-size:16px;font-style:italic;padding:16px 20px;border:1px solid rgba(255,255,255,0.22);border-radius:var(--radius);background:rgba(255,255,255,0.12);color:white;outline:none;resize:vertical;min-height:100px;line-height:1.6;transition:border-color 0.15s;-webkit-appearance:none}
.quote-textarea::placeholder{color:rgba(255,255,255,0.45)}
.quote-textarea:focus{border-color:rgba(255,255,255,0.55);background:rgba(255,255,255,0.16)}
.quote-submit-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.quote-char-count{font-size:12px;color:rgba(255,255,255,0.5)}
.quote-submit-btn{font-size:13px;font-weight:600;background:white;color:var(--violet-dark);padding:11px 24px;border:none;border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer}
.quote-submit-btn:hover{background:rgba(255,255,255,0.92);transform:translateY(-1px)}
.quote-status{font-size:13px;color:rgba(255,255,255,0.85);min-height:18px}
@media(max-width:600px){.quote-submit-inner{padding:0 20px}.quote-submit-title{font-size:24px}}

/* ══════════════════════════════════
   FEATURED / SECTIONS
   ══════════════════════════════════ */
.featured-section{padding:80px 0}

/* ══════════════════════════════════
   HOW IT WORKS
   ══════════════════════════════════ */
.how-section{padding:80px 0;background:var(--black)}
.how-section .section-head{border-color:rgba(255,255,255,0.08)}
.how-section .section-title{color:white}
.how-section .section-label{color:var(--violet-bright)}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.how-step{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius);padding:40px 32px;transition:all 0.2s}
.how-step:hover{border-color:rgba(255,255,255,0.16);background:rgba(255,255,255,0.07)}
.step-num{font-family:var(--font-display);font-size:56px;font-weight:800;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:20px;opacity:0.85}
.how-step h3{font-family:var(--font-display);font-size:22px;font-weight:700;color:white;margin-bottom:10px}
.how-step p{font-size:15px;color:rgba(255,255,255,0.58);line-height:1.7}
@media(max-width:700px){.how-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════
   CTA
   ══════════════════════════════════ */
.cta-section{padding:80px 0;background:var(--bg)}
.cta-inner{background:var(--grad-vivid);border-radius:var(--radius);display:flex;align-items:center;justify-content:space-between;gap:40px;padding:56px 64px;position:relative;overflow:hidden}
.cta-inner::after{content:'';position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,0.07);pointer-events:none}
.cta-headline{font-family:var(--font-display);font-size:clamp(24px,4vw,42px);font-style:italic;font-weight:700;color:white;position:relative;z-index:1;line-height:1.2}
.cta-section .btn-primary{background:white;color:var(--violet-dark);flex-shrink:0}
.cta-section .btn-primary:hover{background:rgba(255,255,255,0.93)}
@media(max-width:640px){.cta-inner{flex-direction:column;text-align:center;padding:40px 28px}}

/* ══════════════════════════════════
   FOOTER — brighter, more readable
   ══════════════════════════════════ */
.site-footer{background:#08080E;margin-top:16px}
.footer-brand-col{display:flex;flex-direction:column}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:64px 0 48px;border-bottom:1px solid rgba(255,255,255,0.07)}
.footer-brand{font-family:var(--font-display);font-size:26px;font-weight:700;color:white;margin-bottom:8px;line-height:1.2}
.footer-brand em{font-style:normal;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* Tagline — more visible */
.footer-tagline{font-size:13.5px;color:rgba(255,255,255,0.48);line-height:1.7;margin-bottom:20px}
.footer-links-col{display:flex;flex-direction:column;gap:12px}
/* Column titles — more visible */
.footer-col-title{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.38);margin-bottom:4px}
/* Links — clearly readable */
.footer-links-col a{font-size:13px;color:rgba(255,255,255,0.58);transition:color 0.15s}
.footer-links-col a:hover{color:white}
.footer-bottom{padding:24px 0;display:flex;flex-direction:column;gap:8px}
/* Crisis line — prominent, NHS first */
.footer-crisis{font-size:13px;color:rgba(255,255,255,0.72);line-height:1.8;padding:16px 20px;background:rgba(255,255,255,0.05);border-radius:8px;border-left:3px solid #F43F8A}
.footer-crisis strong{color:white}
.footer-crisis a{color:rgba(255,255,255,0.85);transition:color 0.15s;text-decoration:underline;text-decoration:underline;text-underline-offset:2px}
.footer-crisis a:hover{color:white}
.footer-copy{font-size:11.5px;color:rgba(255,255,255,0.28)}
@media(max-width:960px){.footer-top{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr;gap:28px;padding:48px 0 36px}}

/* ══════════════════════════════════
   LOADING / EMPTY
   ══════════════════════════════════ */
.loading-state{grid-column:1/-1;display:flex;align-items:center;gap:16px;padding:56px 28px;font-size:12.5px;color:var(--muted)}
.loading-bar{width:120px;height:2px;background:var(--border);position:relative;overflow:hidden;flex-shrink:0;border-radius:2px}
.loading-bar::after{content:'';position:absolute;inset:0;background:var(--grad-vivid);animation:load 1.4s ease-in-out infinite;border-radius:2px}
@keyframes load{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.empty-state{grid-column:1/-1;padding:64px 28px;text-align:center}
.empty-state p{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--muted);margin-bottom:24px}

/* ══════════════════════════════════
   PAGE HERO (inner pages)
   ══════════════════════════════════ */
.page-hero{background:var(--black);padding:72px 0 52px;border-bottom:1px solid rgba(255,255,255,0.07);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 50% 80% at 90% 50%,rgba(109,40,217,0.16) 0%,transparent 60%),radial-gradient(ellipse 30% 60% at 10% 80%,rgba(219,23,119,0.1) 0%,transparent 50%)}
.page-hero-inner{position:relative;z-index:1}
.page-title,.page-hero-title{font-family:var(--font-display);font-size:clamp(34px,6vw,62px);font-weight:700;color:white;line-height:1.1;margin-bottom:14px}
.page-sub,.page-hero-sub{font-size:16px;color:rgba(255,255,255,0.52);line-height:1.65;max-width:520px}
.page-hero-label,.section-label-hero{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--violet-bright);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.page-hero-label::before,.section-label-hero::before{content:'';display:inline-block;width:24px;height:1px;background:var(--violet-bright)}
@media(max-width:768px){.page-hero{padding:52px 0 40px}}

/* ══════════════════════════════════
   BROWSE
   ══════════════════════════════════ */
.browse-controls{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:16px 0;position:sticky;top:64px;z-index:50}
.browse-controls-inner{display:flex;align-items:center;gap:8px;flex-wrap:wrap;row-gap:8px;overflow-x:auto;padding-bottom:2px}
.theme-btn{font-size:11.5px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;background:var(--bg-card);color:var(--muted);border:1px solid var(--border);padding:7px 16px;border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer;white-space:nowrap}
.theme-btn:hover{border-color:var(--violet-mid);color:var(--violet-mid)}
.theme-btn.active{background:var(--grad-vivid);color:white;border-color:transparent}
/* Filter bar — theme pills + search + sort in one clean row */
.theme-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:24px 0 0}
.filter-bar{display:flex;align-items:center;gap:10px;padding:16px 0 28px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:200px;max-width:360px}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:16px;pointer-events:none;line-height:1}
.search-input{width:100%;font-size:13.5px;padding:9px 14px 9px 36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--ink);outline:none;transition:border-color 0.15s;box-sizing:border-box}
.search-input:focus{border-color:var(--violet-mid)}
.sort-wrap{flex-shrink:0}
.sort-select{font-size:13px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--ink);outline:none;cursor:pointer;transition:border-color 0.15s}
.sort-select:focus{border-color:var(--violet-mid)}
.btn-filter{font-size:13px;font-weight:600;background:var(--grad-vivid);color:white;border:none;padding:9px 20px;border-radius:var(--radius-sm);cursor:pointer;transition:opacity 0.15s;white-space:nowrap;flex-shrink:0}
.btn-filter:hover{opacity:0.85}
.search-box{display:flex;margin-left:auto}
.search-btn{font-size:12.5px;font-weight:600;background:var(--grad-vivid);color:white;border:none;padding:8px 14px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;transition:opacity 0.15s;white-space:nowrap}
.search-btn:hover{opacity:0.85}
.browse-grid-section{padding:56px 0}
.load-more-row{text-align:center;margin-top:40px}
#load-more{display:none}
@media(max-width:600px){.filter-bar{gap:8px}.search-wrap{max-width:100%;flex:1 1 100%}.sort-wrap{flex:1}.btn-filter{flex-shrink:0}}

/* ══════════════════════════════════
   SHARE PAGE
   ══════════════════════════════════ */
.share-layout{display:grid;grid-template-columns:1fr 360px;gap:56px;padding:72px 0 104px;align-items:start}
.share-form,.share-form-box{display:flex;flex-direction:column;gap:28px}
.form-row-two,.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group,.form-field{display:flex;flex-direction:column;gap:8px}
.form-label{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.form-label-opt{font-size:11px;font-weight:400;letter-spacing:0;text-transform:none;color:var(--muted-light)}
.req{color:var(--rose)}
.form-input,.form-select,.form-textarea{font-size:15px;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--ink);outline:none;width:100%;transition:border-color 0.15s;line-height:1.5;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--violet-mid)}
.form-textarea{resize:vertical;min-height:320px;line-height:1.75}
.form-select{cursor:pointer;appearance:auto;-webkit-appearance:auto}
.char-count{font-size:11.5px;color:var(--muted-light);text-align:right}
.agree-row,.form-agree{display:flex;gap:12px;align-items:flex-start;padding:16px 18px;background:var(--violet-soft);border-left:3px solid var(--violet-mid);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
/* Custom visible checkbox */
.agree-row input[type="checkbox"],.form-agree input[type="checkbox"]{
  flex-shrink:0;margin-top:1px;
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;
  border:2px solid var(--violet-mid);
  border-radius:4px;
  background:var(--bg-card);
  cursor:pointer;
  position:relative;
  transition:background 0.15s,border-color 0.15s;
}
.agree-row input[type="checkbox"]:checked,.form-agree input[type="checkbox"]:checked{
  background:var(--violet-mid);
  border-color:var(--violet-mid);
}
.agree-row input[type="checkbox"]:checked::after,.form-agree input[type="checkbox"]:checked::after{
  content:'';
  position:absolute;
  left:4px;top:1px;
  width:6px;height:10px;
  border:2px solid white;
  border-top:none;border-left:none;
  transform:rotate(45deg);
}
.agree-row input[type="checkbox"]:focus,.form-agree input[type="checkbox"]:focus{
  outline:2px solid var(--violet-mid);outline-offset:2px;
}
.agree-row label,.form-agree label,.checkbox-label{font-size:13.5px;color:var(--ink);line-height:1.5;cursor:pointer}
.agree-row a,.form-agree a{color:var(--violet-mid);text-decoration:underline}
.form-actions{display:flex;flex-direction:column;gap:10px;padding-top:8px}
.share-status{font-size:13.5px;padding:12px 16px;min-height:20px;border-radius:var(--radius-sm);line-height:1.5}
.share-status.ok{color:#166534;background:#f0fdf4;border-left:3px solid #22c55e}
.share-status.err{color:#991b1b;background:#fef2f2;border-left:3px solid #ef4444}
.share-status.pending{color:#92400e;background:#fffbeb;border-left:3px solid #f59e0b}
[data-theme="dark"] .share-status.ok{color:#86efac;background:rgba(134,239,172,0.08);border-left-color:#22c55e}
[data-theme="dark"] .share-status.err{color:#fca5a5;background:rgba(252,165,165,0.08);border-left-color:#ef4444}
[data-theme="dark"] .share-status.pending{color:#fde68a;background:rgba(253,230,138,0.08);border-left-color:#f59e0b}
.share-sidebar,.share-aside{position:sticky;top:80px;display:flex;flex-direction:column;gap:20px}
.sidebar-box,.aside-block{padding:28px;border:1px solid var(--border);border-radius:var(--radius);border-top:3px solid var(--violet-mid);background:var(--bg-card)}
.sidebar-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:16px;color:var(--ink)}
.sidebar-list{display:flex;flex-direction:column;gap:10px;padding:0;list-style:none}
.sidebar-list li{font-size:14px;color:var(--muted);line-height:1.5;padding-left:18px;position:relative}
.sidebar-list li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--violet-mid)}
.aside-note{font-size:13px;color:var(--muted);line-height:1.6;padding:14px;background:var(--bg-soft);border-radius:var(--radius-sm)}
@media(max-width:860px){.share-layout{grid-template-columns:1fr}.share-sidebar,.share-aside{position:static}}
@media(max-width:560px){.form-row-two,.form-row.two-col{grid-template-columns:1fr}}

/* ══════════════════════════════════
   STORY PAGE
   ══════════════════════════════════ */
.story-nav-bar{max-width:780px;margin:0 auto;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
.back-link{font-size:13px;font-weight:500;color:var(--muted);transition:color 0.15s}
.back-link:hover{color:var(--ink)}
.story-top-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.story-layout{max-width:780px;margin:0 auto;padding:64px 48px}
.story-header-section{margin-bottom:40px}
.story-article-theme{font-size:10.5px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--violet-mid);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.story-article-theme::before{content:'';display:inline-block;width:24px;height:1px;background:var(--violet-mid)}
.story-article-title{font-family:var(--font-display);font-size:clamp(28px,5vw,52px);font-weight:700;line-height:1.12;color:var(--ink);margin-bottom:20px;letter-spacing:-0.01em}
.story-article-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12.5px;color:var(--muted)}
.meta-dot{color:var(--border);margin:0 2px}
.reading-time{color:var(--violet-mid);font-weight:600}
.story-divider{width:48px;height:3px;background:var(--grad-vivid);margin:32px 0;border-radius:2px}
.story-pullquote{font-family:var(--font-display);font-size:19px;font-style:italic;font-weight:500;line-height:1.6;color:var(--ink-soft);padding:24px 28px;border-left:3px solid var(--violet-mid);background:var(--violet-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:32px}
[data-theme="dark"] .story-pullquote{background:var(--violet-soft)}
.story-article-body{font-size:17px;line-height:1.9;color:var(--ink-soft);white-space:pre-wrap}
.story-tags{margin-top:48px;padding-top:24px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.tags-label{font-size:10.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-right:4px}
.tag-badge{font-size:11.5px;font-weight:600;color:var(--violet-mid);background:var(--violet-soft);padding:4px 12px;border-radius:var(--radius-pill)}
/* Read aloud — polished */
/* ── Read Aloud Bar ── */
.read-aloud-bar{
  max-width:780px;margin:0 auto;
  padding:0 48px;
  background:linear-gradient(135deg,#0F0B1E 0%,#160A1A 50%,#0A0C1A 100%);
  display:flex;align-items:center;gap:0;
  border-top:1px solid rgba(124,58,237,0.25);
  border-bottom:1px solid rgba(240,22,128,0.15);
  position:relative;overflow:hidden;
  min-height:60px;
}
/* Subtle gradient accent line on top */
.read-aloud-bar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(124,58,237,0.6) 30%,rgba(240,22,128,0.6) 70%,transparent 100%);
}
/* Ambient glow in background */
.read-aloud-bar::after{
  content:'';position:absolute;top:-40px;left:60px;
  width:200px;height:100px;
  background:radial-gradient(ellipse,rgba(124,58,237,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.read-aloud-left{display:flex;align-items:center;gap:10px;padding:16px 0;flex-shrink:0}
.read-aloud-label{font-size:11px;font-weight:700;color:rgba(255,255,255,0.5);letter-spacing:0.18em;text-transform:uppercase;white-space:nowrap}
/* Animated waveform */
.read-aloud-wave{display:flex;align-items:center;gap:2.5px;height:16px}
.read-aloud-wave span{display:block;width:3px;border-radius:2px;background:var(--grad-vivid);opacity:0.5;height:4px;transition:height 0.15s}
.read-aloud-bar.is-playing .read-aloud-wave span{opacity:1}
.read-aloud-bar.is-playing .read-aloud-wave span:nth-child(1){animation:wave 0.9s ease-in-out infinite}
.read-aloud-bar.is-playing .read-aloud-wave span:nth-child(2){animation:wave 0.9s ease-in-out 0.15s infinite}
.read-aloud-bar.is-playing .read-aloud-wave span:nth-child(3){animation:wave 0.9s ease-in-out 0.3s infinite}
.read-aloud-bar.is-playing .read-aloud-wave span:nth-child(4){animation:wave 0.9s ease-in-out 0.1s infinite}
.read-aloud-bar.is-playing .read-aloud-wave span:nth-child(5){animation:wave 0.9s ease-in-out 0.25s infinite}
@keyframes wave{0%,100%{height:3px}50%{height:14px}}
/* Divider */
.read-aloud-divider{width:1px;height:28px;background:rgba(255,255,255,0.08);flex-shrink:0;margin:0 16px}
/* Play/Stop button */
.read-aloud-btn{
  font-size:13px;font-weight:600;
  padding:8px 20px;
  background:var(--grad-vivid);color:white;
  border:none;border-radius:var(--radius-pill);
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  display:inline-flex;align-items:center;gap:6px;
  transition:opacity 0.15s,transform 0.1s;
  box-shadow:0 2px 12px rgba(124,58,237,0.35);
}
.read-aloud-btn:hover{opacity:0.88;transform:translateY(-1px)}
.read-aloud-btn:active{transform:translateY(0)}
.read-aloud-btn.playing{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.8);
  box-shadow:none;
}
.read-aloud-btn.playing:hover{background:rgba(255,255,255,0.13);color:white}
/* Speed group */
.read-aloud-speed-group{display:flex;align-items:center;gap:10px;flex-shrink:0}
.read-aloud-speed-label{font-size:10px;font-weight:700;color:rgba(255,255,255,0.28);letter-spacing:0.16em;text-transform:uppercase;white-space:nowrap}
.read-aloud-speeds{display:flex;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.07);border-radius:var(--radius-pill);padding:3px;gap:1px;flex-shrink:0}
.speed-btn{font-size:11.5px;font-weight:600;padding:4px 11px;border:none;border-radius:var(--radius-pill);background:transparent;color:rgba(255,255,255,0.35);cursor:pointer;transition:all 0.15s;white-space:nowrap;letter-spacing:0.02em}
.speed-btn:hover{color:rgba(255,255,255,0.7)}
.speed-btn.active{background:rgba(255,255,255,0.12);color:white;box-shadow:0 1px 4px rgba(0,0,0,0.3)}
@media(max-width:600px){
  .read-aloud-bar{padding:14px 20px;gap:10px;flex-wrap:wrap;min-height:auto}
  .read-aloud-divider{display:none}
  .read-aloud-speed-group{gap:6px}
}
.reactions-section{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px 0}
.reactions-label{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;text-align:center}
.reactions-row{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.reaction-btn{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;padding:10px 20px;background:var(--bg-card);border:1.5px solid var(--border);color:var(--ink);border-radius:var(--radius-pill);transition:all 0.15s;cursor:pointer}
.reaction-btn:hover{border-color:var(--violet-mid);background:var(--violet-soft)}
.reaction-btn.reacted{border-color:var(--violet-mid);background:var(--violet-soft);color:var(--violet-mid);font-weight:600}
.reaction-btn:disabled{opacity:0.5;cursor:default}
.reaction-feedback{text-align:center;margin-top:14px;font-size:12.5px;color:var(--violet-mid);font-weight:600}
.related-section{max-width:780px;margin:0 auto;padding:32px 48px;border-top:1px solid var(--border)}
.related-title{font-size:10.5px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.related-grid .story-card{padding:16px;margin:0}
.related-grid .story-snippet{display:none}
@media(max-width:600px){.related-grid{grid-template-columns:1fr}.related-grid .story-snippet{display:block}}
.story-bottom-bar{padding:20px 48px;max-width:780px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
.story-end-cta{padding:48px;max-width:780px;margin:0 auto}
.end-cta-inner{background:var(--grad-vivid);border-radius:var(--radius);padding:44px 48px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.end-cta-text{font-family:var(--font-display);font-size:24px;font-style:italic;font-weight:600;color:white;line-height:1.3}
.end-cta-btns{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}
.end-cta-inner .btn-primary{background:white;color:var(--violet-dark)}
.back-to-top{position:fixed;bottom:80px;right:24px;z-index:150;width:42px;height:42px;background:var(--grad-vivid);color:white;border:none;font-size:18px;display:none;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(109,40,217,0.4);border-radius:50%;transition:all 0.15s;cursor:pointer}
.back-to-top:hover{opacity:0.88;transform:translateY(-2px)}
.back-to-top.visible{display:flex}
/* Comments */
.comments-section{max-width:780px;margin:0 auto;padding:40px 48px;border-top:1px solid var(--border)}
.comments-title{font-size:10.5px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.comment-form{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.comment-input{font-size:14px;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--ink);outline:none;resize:vertical;line-height:1.5;transition:border-color 0.15s}
.comment-input:focus{border-color:var(--violet-mid)}
.comment-list{display:flex;flex-direction:column;gap:16px}
.comment-item{padding:16px 20px;background:var(--bg-alt);border-left:2px solid var(--violet-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.comment-item-text{font-size:14px;color:var(--ink);line-height:1.65}
.comment-item-meta{font-size:11px;color:var(--muted-light);margin-top:8px}
.pending-banner{background:var(--amber-soft);border:1px solid var(--amber);border-left:3px solid var(--amber);padding:14px 20px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:14px;color:var(--ink-soft);line-height:1.5}
.pending-banner strong{color:var(--amber)}
@media(max-width:560px){
  .story-nav-bar,.story-layout,.story-bottom-bar,.story-end-cta,.read-aloud-bar,.related-section,.comments-section{padding-left:20px;padding-right:20px}
  .end-cta-inner{flex-direction:column;text-align:center;padding:32px 24px}
}

/* ══════════════════════════════════
   MODAL
   ══════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-box{background:var(--bg-card);padding:40px;max-width:480px;width:100%;border-radius:var(--radius);border-top:3px solid var(--violet-mid)}
.modal-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:8px}
.modal-sub{font-size:14px;color:var(--muted);margin-bottom:24px}
.report-options{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.report-option{display:flex;gap:12px;align-items:center;font-size:14px;color:var(--ink);cursor:pointer;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);transition:all 0.15s}
.report-option:hover{border-color:var(--violet-mid);background:var(--violet-soft)}
/* Custom radio */
.report-option input[type="radio"]{
  flex-shrink:0;
  appearance:none;-webkit-appearance:none;
  width:17px;height:17px;
  border:2px solid var(--border);
  border-radius:50%;
  background:var(--bg-card);
  cursor:pointer;
  position:relative;
  transition:border-color 0.15s;
}
.report-option input[type="radio"]:checked{border-color:var(--violet-mid)}
.report-option input[type="radio"]:checked::after{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:7px;height:7px;
  border-radius:50%;
  background:var(--violet-mid);
}
.report-option:has(input:checked){border-color:var(--violet-mid);background:var(--violet-soft)}
.report-detail{width:100%;font-size:14px;padding:12px 16px;border:1px solid var(--border);background:var(--bg-card);color:var(--ink);resize:vertical;outline:none;margin-bottom:16px;border-radius:var(--radius-sm);transition:border-color 0.15s}
.report-detail:focus{border-color:var(--violet-mid)}
.report-status{font-size:13px;color:var(--violet-mid);margin-bottom:12px;min-height:18px}
.modal-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}

/* ══════════════════════════════════
   ABOUT PAGE
   ══════════════════════════════════ */
.about-quicknav{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:14px 0;font-size:13px;position:sticky;top:64px;z-index:50}
.about-quicknav .container{display:flex;gap:8px;align-items:center;flex-wrap:wrap;row-gap:6px}
.about-quicknav a{color:var(--muted);transition:color 0.15s;padding:2px 0}
.about-quicknav a:hover{color:var(--violet-mid)}
.about-quicknav span{color:var(--border)}
.about-container{padding-top:64px;padding-bottom:96px}
.about-layout{display:grid;grid-template-columns:1fr 300px;gap:64px;align-items:start}
.about-content{display:flex;flex-direction:column}
.about-block{padding-bottom:48px;margin-bottom:48px;border-bottom:1px solid var(--border)}
.about-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.about-block h2{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);margin-bottom:20px;line-height:1.2}
.about-block p{font-size:16px;line-height:1.8;color:var(--ink-soft);margin-bottom:14px}
.about-block p a{color:var(--violet-mid);text-decoration:underline}
.about-callout{display:flex;gap:14px;align-items:flex-start;background:var(--violet-soft);border-left:3px solid var(--violet-mid);padding:18px 20px;margin:24px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.callout-icon{font-size:18px;flex-shrink:0;margin-top:2px}
.about-callout p{color:var(--ink)!important;margin-bottom:0!important;font-size:15px!important}
.guidelines-list{display:flex;flex-direction:column;margin-top:20px}
.guideline{display:flex;gap:24px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--border-soft)}
.guideline:last-child{border-bottom:none}
.g-num{font-family:var(--font-display);font-size:22px;font-weight:700;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-shrink:0;line-height:1;margin-top:2px;min-width:36px}
.guideline strong{font-size:15px;font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
.guideline p{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:0}
.about-aside{position:sticky;top:120px;display:flex;flex-direction:column;gap:16px}
.about-aside-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.about-aside-block .section-label{margin-bottom:14px;display:block}
.theme-list-about{list-style:none;display:flex;flex-direction:column;gap:10px}
.theme-list-about li{font-size:14px;color:var(--muted);display:flex;gap:10px;align-items:center}
.theme-list-about li span{font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--violet-bright);width:24px;flex-shrink:0}
.quicklinks-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.quicklinks-list li a{font-size:14px;color:var(--violet-mid);transition:color 0.15s}
.quicklinks-list li a:hover{text-decoration:underline}
@media(max-width:860px){.about-layout{grid-template-columns:1fr}.about-aside{position:static}}
@media(max-width:768px){.about-container{padding-top:40px;padding-bottom:64px}}

/* ══════════════════════════════════
   LEGAL PAGES
   ══════════════════════════════════ */
.legal-body{padding:64px 0 96px}
.legal-content{max-width:720px}
.legal-updated{display:block;font-size:13px;color:var(--muted);margin-bottom:40px}
.legal-section{margin-bottom:48px}
.legal-section h2,.legal-content h2{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--ink);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.legal-section p,.legal-section li,.legal-content p,.legal-content li{font-size:15.5px;line-height:1.8;color:var(--ink-soft);margin-bottom:12px}
.legal-section ul,.legal-content ul{padding-left:0;list-style:none;margin-bottom:20px}
.legal-section li,.legal-content li{padding-left:22px;position:relative}
.legal-section li::before,.legal-content li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--violet-mid)}
.legal-section strong,.legal-content strong{color:var(--ink);font-weight:600}
.legal-content a{color:var(--violet-mid);text-decoration:underline}
@media(max-width:768px){.legal-body{padding:40px 0 64px}}

/* ══════════════════════════════════
   CONTACT PAGE
   ══════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 380px;gap:56px;padding:64px 0 96px;align-items:start}
.contact-intro{font-size:16px;color:var(--ink-soft);line-height:1.8;margin-bottom:32px}
.contact-methods{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}
.contact-method{display:flex;align-items:center;gap:16px;padding:20px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color 0.15s}
.contact-method:hover{border-color:var(--violet-mid)}
.contact-method-icon{width:44px;height:44px;background:var(--violet-soft);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.contact-method-label{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.contact-method-value{font-size:15px;font-weight:500;color:var(--ink)}
.contact-form-section h2{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:24px}
.contact-sidebar{display:flex;flex-direction:column;gap:16px}
.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.contact-card h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:12px}
.contact-card p{font-size:14px;color:var(--muted);line-height:1.7}
.contact-card a{color:var(--violet-mid)}
@media(max-width:860px){.contact-layout{grid-template-columns:1fr}}
@media(max-width:768px){.contact-layout{padding:40px 0 64px}}

/* ══════════════════════════════════
   ADMIN LOGIN
   ══════════════════════════════════ */
.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--black);padding:20px}
.login-box{border:1px solid rgba(255,255,255,0.08);padding:52px;width:100%;max-width:420px;background:rgba(255,255,255,0.03);border-radius:var(--radius);position:relative;border-top:3px solid transparent}
.login-box::before{content:'';position:absolute;top:-3px;left:0;right:0;height:3px;background:var(--grad-vivid);border-radius:var(--radius) var(--radius) 0 0}
.login-title{font-family:var(--font-display);font-size:36px;font-weight:700;color:white;margin-bottom:6px;line-height:1.2}
.login-title em{font-style:normal;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-sub{font-size:14px;color:rgba(255,255,255,0.38);margin-bottom:36px}
.login-label{display:block;font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.42);margin-bottom:8px}
.login-input{width:100%;font-size:15px;padding:12px 16px;border:1px solid rgba(255,255,255,0.11);border-radius:var(--radius-sm);background:rgba(255,255,255,0.06);color:white;outline:none;margin-bottom:20px;transition:border-color 0.15s;-webkit-appearance:none}
.login-input:focus{border-color:var(--violet-bright)}
.login-error{color:#f87171;font-size:13px;margin-top:12px;min-height:18px}
@media(max-width:480px){.login-box{padding:36px 24px}}

/* ══════════════════════════════════
   ACCESSIBILITY TOOLBAR
   ══════════════════════════════════ */
.a11y-bar{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.a11y-panel{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--violet-mid);padding:18px;width:220px;box-shadow:0 8px 32px rgba(0,0,0,0.15);display:none;border-radius:var(--radius)}
.a11y-panel.open{display:block}
.a11y-panel-title{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.a11y-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.a11y-label{font-size:12px;color:var(--ink)}
.a11y-btn-group{display:flex;gap:4px}
.a11y-btn{font-size:12px;font-weight:600;background:var(--bg-alt);border:1px solid var(--border);color:var(--ink);padding:4px 8px;border-radius:4px;transition:all 0.15s}
.a11y-btn:hover{background:var(--violet-mid);color:white;border-color:var(--violet-mid)}
.a11y-reset{font-size:11px;background:none;border:none;color:var(--muted);text-decoration:underline;cursor:pointer;margin-top:6px}
.a11y-toggle{width:44px;height:44px;background:var(--black);color:var(--violet-bright);border:1px solid rgba(255,255,255,0.09);font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 16px rgba(0,0,0,0.25);border-radius:50%;transition:all 0.15s}
.a11y-toggle:hover{background:var(--grad-vivid);color:white;border-color:transparent}
body.high-contrast{--bg:#fff;--ink:#000;--muted:#222;--border:#000;--bg-card:#fff;--bg-alt:#f0f0f0}
/* Active state for a11y toggle buttons */
.a11y-toggle-btn[data-active="true"]{background:var(--violet-mid);color:white;border-color:var(--violet-mid)}
/* Dyslexia-friendly font */
body.dyslexia-font,body.dyslexia-font p,body.dyslexia-font .story-article-body,body.dyslexia-font .story-snippet{font-family:'Verdana','Trebuchet MS','Arial',sans-serif!important;letter-spacing:0.02em;word-spacing:0.1em}
/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
}
body.reduce-motion *,body.reduce-motion *::before,body.reduce-motion *::after{animation:none!important;animation-duration:0.01ms!important;animation-iteration-count:1!important;transition:none!important;scroll-behavior:auto!important}
/* Line spacing levels */
body.line-spacing-1 p,body.line-spacing-1 .story-article-body,body.line-spacing-1 li{line-height:1.9!important}
body.line-spacing-2 p,body.line-spacing-2 .story-article-body,body.line-spacing-2 li{line-height:2.2!important}
body.line-spacing-3 p,body.line-spacing-3 .story-article-body,body.line-spacing-3 li{line-height:2.6!important}
/* Pre-load (applied to html element to avoid flash) */
html.high-contrast-pre body{--bg:#fff;--ink:#000;--muted:#222;--border:#000;--bg-card:#fff;--bg-alt:#f0f0f0}
html.dyslexia-pre body,html.dyslexia-pre p{font-family:'Verdana','Trebuchet MS','Arial',sans-serif!important}
html.reduce-motion-pre *{animation-duration:0.01ms!important;transition-duration:0.01ms!important}

/* ══════════════════════════════════
   404
   ══════════════════════════════════ */
.notfound-section{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 20px;flex-direction:column}
.notfound-num{font-family:var(--font-display);font-size:clamp(100px,20vw,200px);font-weight:800;background:var(--grad-vivid);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;display:block}
.notfound-title{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--ink);margin-bottom:12px}
.notfound-sub{font-size:16px;color:var(--muted);margin-bottom:32px;max-width:400px}

/* ══════════════════════════════════
   MOBILE — COMPREHENSIVE FIXES
   ══════════════════════════════════ */

/* Prevent any horizontal overflow site-wide */
html, body { overflow-x: hidden; max-width: 100%; }

/* ── Header mobile ── */
@media(max-width:768px) {
  .header-inner { padding: 0 16px; gap: 8px; }
  .brand { font-size: 18px; }
  .nav-cta { display: none; } /* hide in header — shows in mobile nav */
}

/* ── Hero section ── */
@media(max-width:600px) {
  .hero-inner { padding: 56px 0 48px; }
  .hero-headline { font-size: clamp(30px, 8vw, 48px); }
  .hero-tagline { font-size: 14px; }
  .hero-search-panel { padding: 18px; }
  .hero-search-row { flex-direction: column; gap: 8px; }
  .hero-search-btn { width: 100%; text-align: center; }
  .hero-actions { flex-direction: column; gap: 10px; }
  .hero-actions .btn-primary, .hero-actions .btn-outline { width: 100%; text-align: center; justify-content: center; }
  .hero-stats { flex-wrap: wrap; gap: 16px 28px; }
}

/* ── Story of the Day ── */
@media(max-width:600px) {
  .sotd-inner { padding: 24px 16px; }
  .sotd-title { font-size: 20px; }
  .sotd-snippet { font-size: 14px; }
}

/* ── Story cards grid ── */
@media(max-width:480px) {
  .story-card { padding: 18px; }
  .story-card-title { font-size: 16px; }
  .story-snippet { font-size: 13px; }
}

/* ── Browse filter bar ── */
@media(max-width:600px) {
  .theme-filter-row { gap: 6px; padding: 16px 0 0; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
  .theme-btn { font-size: 11px; padding: 6px 12px; flex-shrink: 0; }
  .filter-bar { flex-wrap: wrap; }
  .search-wrap { min-width: 0; flex: 1 1 100%; max-width: 100%; }
  .sort-wrap { flex: 1; }
  .btn-filter { flex-shrink: 0; }
}

/* ── Story page ── */
@media(max-width:600px) {
  .story-nav-bar { padding: 14px 16px; }
  .story-layout { padding: 36px 16px; }
  .story-title { font-size: clamp(22px, 6vw, 32px); }
  .story-article-body { font-size: 15px; }
  .story-bottom-bar { padding: 16px; flex-direction: column; align-items: flex-start; }
  .story-end-cta { padding: 32px 16px; text-align: center; }
  .story-end-cta .btn-primary { width: 100%; justify-content: center; }
  .reactions-section > div { padding: 0 16px; }
  .reactions-row { gap: 8px; justify-content: center; }
  .reaction-btn { font-size: 13px; padding: 10px 14px; }
  .read-aloud-bar { padding: 14px 16px; gap: 10px; min-height: auto; flex-wrap: wrap; }
  .read-aloud-divider { display: none; }
  .read-aloud-speeds { flex-wrap: wrap; }
  .comments-section { padding: 28px 16px; }
  .related-section { padding: 24px 16px; }
  .related-grid { grid-template-columns: 1fr; }
}

/* ── Share page ── */
@media(max-width:600px) {
  .share-layout { padding: 36px 0 64px; gap: 32px; }
  .share-form-section, .share-aside { padding: 0; }
  .form-title { font-size: 24px; }
  .form-input, .form-textarea { font-size: 16px; } /* prevent iOS zoom */
  .share-preview-modal-inner { padding: 24px 16px; }
}

/* ── Quotes page ── */
@media(max-width:600px) {
  .quote-submit-section { padding: 40px 0; }
  .quote-submit-inner { padding: 0 16px; }
  .quote-submit-title { font-size: 22px; }
  .quote-input { font-size: 15px; }
  .quotes-section { padding: 40px 0; }
  .quotes-grid { grid-template-columns: 1fr; }
  .quote-card { padding: 20px; }
}

/* ── About page ── */
@media(max-width:600px) {
  .about-container { padding-top: 28px; padding-bottom: 48px; }
  .about-section { padding: 32px 0; }
  .about-h2 { font-size: 22px; }
  .about-quicknav { display: none; } /* too cramped on mobile */
  .g-item { gap: 12px; }
}

/* ── Legal pages (Terms, Privacy, Accessibility) ── */
@media(max-width:600px) {
  .legal-body { padding: 28px 0 48px; }
  .legal-content h2 { font-size: 18px; }
  .legal-content p, .legal-content li { font-size: 14px; }
}

/* ── Contact page ── */
@media(max-width:600px) {
  .contact-layout { padding: 28px 0 48px; gap: 32px; }
  .contact-methods { gap: 12px; }
  .contact-method { padding: 14px; }
}

/* ── Footer mobile ── */
@media(max-width:560px) {
  .footer-top { padding: 40px 0 28px; }
  .footer-brand-tagline { font-size: 13px; }
  .footer-crisis { font-size: 12px; padding: 12px; }
  .footer-bottom { flex-direction: column; gap: 6px; font-size: 12px; }
  .footer-copy { font-size: 11px; }
}

/* ── Modal ── */
@media(max-width:600px) {
  .modal-box { padding: 24px 18px; margin: 16px; width: calc(100% - 32px); }
  .modal-title { font-size: 18px; }
}

/* ── Accessibility toolbar ── */
@media(max-width:480px) {
  .a11y-panel { right: 12px; bottom: 68px; width: calc(100vw - 24px); max-width: 320px; }
  .a11y-toggle { bottom: 16px; right: 12px; }
}

/* ── Page hero (browse, quotes, etc) ── */
@media(max-width:600px) {
  .page-hero { padding: 40px 0 28px; }
  .page-title { font-size: clamp(26px, 7vw, 40px); }
  .page-sub { font-size: 14px; }
  .section-label { font-size: 9px; }
}

/* ── CTA section ── */
@media(max-width:480px) {
  .cta-inner { padding: 32px 20px; }
  .cta-headline { font-size: 24px; }
  .cta-sub { font-size: 14px; }
}

/* ── How it works ── */
@media(max-width:480px) {
  .how-card { padding: 20px; }
  .how-title { font-size: 15px; }
}
