/*
Theme Name: LARP-Fit
Theme URI: https://larp-fit.com
Author: LARP-Fit
Description: The official LARP-Fit theme with Dark Fantasy, Light Fantasy, Post-Apocalyptic and Sci-Fi modes.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: larp-fit
*/

/* ══════════════════════════════════════════
   THEME VARIABLES
══════════════════════════════════════════ */
body[data-theme="dark"] {
  --bg-primary:#110e18;--bg-secondary:#1e1a2e;--bg-tertiary:#2a2440;
  --bg-card:#1e1a2e;--bg-nav:#1e1a2e;
  --text-primary:#f5eedd;--text-secondary:#cec3e8;--text-muted:#8a789a;
  --accent:#e0b84e;--accent-light:#f2d06e;--accent-dim:#9a7830;
  --accent2:#a02020;--accent2-bright:#d44030;
  --border:#9a7830;--border-hover:#e0b84e;
  --popup-bg:#1a1228;--popup-border:#e0b84e;
  --font-display:'Cinzel Decorative',serif;
  --font-heading:'Cinzel',serif;--font-body:'IM Fell English',Georgia,serif;
  --header-glow:rgba(122,95,240,0.12);--card-hover-shadow:rgba(139,26,26,0.2);
  --search-bg:#150f1e;--tag-bg:#2a2440;--tag-color:#e0b84e;
  --filter-active-bg:#9a7830;--filter-active-color:#f5eedd;
  --hero-overlay:linear-gradient(180deg,rgba(17,14,24,0) 0%,rgba(17,14,24,0.85) 70%,#110e18 100%);
  --programs-glow:rgba(139,26,26,0.08);
}
body[data-theme="light"] {
  --bg-primary:#faf3e0;--bg-secondary:#f0e2c0;--bg-tertiary:#e8d5a3;
  --bg-card:#fff8ed;--bg-nav:#3d2b0f;
  --text-primary:#2c1a08;--text-secondary:#5c3d1a;--text-muted:#9a7040;
  --accent:#b8620a;--accent-light:#d4820f;--accent-dim:#8a4a08;
  --accent2:#2a6b3a;--accent2-bright:#3d9b55;
  --border:#c9a070;--border-hover:#b8620a;
  --popup-bg:#fff8ed;--popup-border:#b8620a;
  --font-display:'Uncial Antiqua',serif;
  --font-heading:'Cinzel',serif;--font-body:'IM Fell English',Georgia,serif;
  --header-glow:rgba(184,98,10,0.08);--card-hover-shadow:rgba(184,98,10,0.15);
  --search-bg:#fff8ed;--tag-bg:#e8d5a3;--tag-color:#7a3808;
  --filter-active-bg:#b8620a;--filter-active-color:#fff8ed;
  --hero-overlay:linear-gradient(180deg,rgba(250,243,224,0) 0%,rgba(250,243,224,0.85) 70%,#faf3e0 100%);
  --programs-glow:rgba(42,107,58,0.06);
}
body[data-theme="postapoc"] {
  --bg-primary:#0a0f09;--bg-secondary:#111a0e;--bg-tertiary:#182414;
  --bg-card:#111a0e;--bg-nav:#080c07;
  --text-primary:#b8f06a;--text-secondary:#88cc50;--text-muted:#508030;
  --accent:#96e832;--accent-light:#bcf55a;--accent-dim:#4e8818;
  --accent2:#e04010;--accent2-bright:#ff6622;
  --border:#2e5018;--border-hover:#96e832;
  --popup-bg:#0a0f09;--popup-border:#96e832;
  --font-display:'Rajdhani',sans-serif;
  --font-heading:'Rajdhani',sans-serif;--font-body:'Share Tech Mono',monospace;
  --header-glow:rgba(126,207,42,0.12);--card-hover-shadow:rgba(126,207,42,0.18);
  --search-bg:#0a0f09;--tag-bg:#182414;--tag-color:#96e832;
  --filter-active-bg:#4e8818;--filter-active-color:#b8f06a;
  --hero-overlay:linear-gradient(180deg,rgba(10,15,9,0) 0%,rgba(10,15,9,0.85) 70%,#0a0f09 100%);
  --programs-glow:rgba(204,58,10,0.1);
}
body[data-theme="scifi"] {
  --bg-primary:#060c18;--bg-secondary:#0c1630;--bg-tertiary:#101e3e;
  --bg-card:#0c1630;--bg-nav:#060c18;
  --text-primary:#daf2ff;--text-secondary:#90ccee;--text-muted:#4a88aa;
  --accent:#18e8ff;--accent-light:#60f4ff;--accent-dim:#0890aa;
  --accent2:#9040ff;--accent2-bright:#b878ff;
  --border:#0e5080;--border-hover:#18e8ff;
  --popup-bg:#080e20;--popup-border:#18e8ff;
  --font-display:'Rajdhani',sans-serif;
  --font-heading:'Rajdhani',sans-serif;--font-body:'Share Tech Mono',monospace;
  --header-glow:rgba(0,212,255,0.1);--card-hover-shadow:rgba(0,212,255,0.2);
  --search-bg:#060c18;--tag-bg:#101e3e;--tag-color:#18e8ff;
  --filter-active-bg:#0890aa;--filter-active-color:#daf2ff;
  --hero-overlay:linear-gradient(180deg,rgba(6,12,24,0) 0%,rgba(6,12,24,0.85) 70%,#060c18 100%);
  --programs-glow:rgba(123,47,255,0.08);
}

/* ══════════════════════════════════════════
   RESET & BASE
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background-color:var(--bg-primary);color:var(--text-secondary);font-family:var(--font-body);overflow-x:hidden;transition:background-color 0.5s,color 0.5s;}
a{color:var(--accent);text-decoration:none;}
img{max-width:100%;height:auto;}

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.site-header{position:relative;text-align:center;padding:60px 20px 40px;border-bottom:1px solid var(--border);overflow:hidden;transition:all 0.5s;}
.site-header .hazard-stripe{position:absolute;top:0;left:0;right:0;}
.rune-row{font-family:var(--font-heading);font-size:13px;letter-spacing:10px;color:var(--accent-dim);margin:0 0 14px;display:flex;align-items:center;justify-content:center;gap:12px;position:relative;z-index:1;}
.rune-row::before,.rune-row::after{content:'';flex:1;max-width:100px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-dim));}
.rune-row::after{background:linear-gradient(270deg,transparent,var(--accent-dim));}
.site-title{font-family:var(--font-display);font-size:clamp(26px,5vw,52px);color:var(--accent);letter-spacing:3px;line-height:1.2;transition:all 0.5s;position:relative;z-index:1;}
.site-title a{color:inherit;text-decoration:none;}
.site-subtitle{font-family:var(--font-body);font-style:italic;color:var(--text-muted);font-size:15px;margin-top:8px;letter-spacing:2px;position:relative;z-index:1;}
.page-label{font-family:var(--font-heading);font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--accent-dim);margin-top:20px;display:block;position:relative;z-index:1;}

/* Dark Fantasy header */
body[data-theme="dark"] .site-header{background:linear-gradient(180deg,#0a0810 0%,#110e18 40%,#1e1a2e 100%);border-top:3px solid #e0b84e;}
body[data-theme="dark"] .site-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(122,95,240,0.18) 0%,transparent 65%),radial-gradient(ellipse 40% 30% at 50% 100%,rgba(160,32,32,0.1) 0%,transparent 60%);pointer-events:none;}
body[data-theme="dark"] .site-title{text-shadow:0 0 30px rgba(224,184,78,0.4),0 0 80px rgba(122,95,240,0.2);letter-spacing:5px;}
body[data-theme="dark"] .rune-row{font-size:16px;letter-spacing:12px;}

/* Light Fantasy header */
body[data-theme="light"] .site-header{background:linear-gradient(180deg,#fff8ed 0%,#f5e8c8 50%,#f0e2c0 100%);border-top:4px solid #b8620a;border-bottom:2px solid #c9a070;}
body[data-theme="light"] .site-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% -10%,rgba(255,210,100,0.35) 0%,transparent 60%);pointer-events:none;}
body[data-theme="light"] .site-header::after{content:'❧';position:absolute;top:12px;left:50%;transform:translateX(-50%);font-size:22px;color:#c9a070;opacity:0.5;pointer-events:none;}
body[data-theme="light"] .site-title{color:#7a3808;text-shadow:0 2px 12px rgba(184,98,10,0.2),0 0 40px rgba(255,200,80,0.3);letter-spacing:4px;}

/* Post-Apoc header */
body[data-theme="postapoc"] .site-header{background:linear-gradient(180deg,#060908 0%,#0a0f09 50%,#111a0e 100%);border-bottom:1px solid #2e5018;padding-top:22px;}
body[data-theme="postapoc"] .site-header::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(150,232,50,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(150,232,50,0.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;}
body[data-theme="postapoc"] .site-header::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(150,232,50,0.07) 0%,transparent 65%);pointer-events:none;}
body[data-theme="postapoc"] .hazard-stripe{background:repeating-linear-gradient(90deg,#96e832 0px,#96e832 20px,#0a0f09 20px,#0a0f09 40px);height:6px;}
body[data-theme="postapoc"] .site-title{font-weight:700;letter-spacing:8px;text-shadow:0 0 20px rgba(150,232,50,0.7),0 0 60px rgba(150,232,50,0.3);animation:toxicFlicker 6s infinite;}
body[data-theme="postapoc"] .rune-row{letter-spacing:4px;font-size:11px;}
body[data-theme="postapoc"] .site-subtitle{font-style:normal;letter-spacing:3px;font-size:13px;}
@keyframes toxicFlicker{0%,95%,100%{opacity:1;}96%{opacity:0.85;}97%{opacity:1;}98%{opacity:0.7;}99%{opacity:1;}}

/* Sci-Fi header */
body[data-theme="scifi"] .site-header{background:linear-gradient(180deg,#030610 0%,#060c18 40%,#0c1630 100%);border-top:1px solid #0e5080;border-bottom:1px solid #0e5080;}
body[data-theme="scifi"] .site-header::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(24,232,255,0.012) 3px,rgba(24,232,255,0.012) 4px),radial-gradient(ellipse 70% 60% at 50% 0%,rgba(24,232,255,0.1) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 50% 100%,rgba(144,64,255,0.08) 0%,transparent 70%);pointer-events:none;}
body[data-theme="scifi"] .site-header::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(24,232,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(24,232,255,0.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;}
body[data-theme="scifi"] .hazard-stripe{background:linear-gradient(90deg,transparent 0%,#18e8ff 30%,#9040ff 70%,transparent 100%);height:2px;opacity:0.8;}
body[data-theme="scifi"] .site-title{letter-spacing:8px;text-shadow:0 0 20px rgba(24,232,255,0.7),0 0 60px rgba(24,232,255,0.3),0 0 100px rgba(144,64,255,0.2);}
body[data-theme="scifi"] .site-subtitle{font-style:normal;letter-spacing:3px;font-size:13px;}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
.site-nav{display:flex;justify-content:center;align-items:center;gap:28px;padding:14px 20px;background:var(--bg-nav);border-bottom:1px solid var(--border);position:relative;z-index:10;flex-wrap:wrap;transition:background 0.5s;}
.site-nav a{font-family:var(--font-heading);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
body[data-theme="dark"] .site-nav a,body[data-theme="light"] .site-nav a,body[data-theme="postapoc"] .site-nav a,body[data-theme="scifi"] .site-nav a{color:#ffffff;}
.site-nav a:hover,.site-nav a.current-menu-item,.site-nav a.active{color:var(--accent);}
.nav-theme-btn{font-family:var(--font-heading);font-size:11px;letter-spacing:3px;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--accent);padding:6px 14px;cursor:pointer;transition:all 0.2s;margin-left:8px;}
.nav-theme-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary);}
body[data-theme="postapoc"] .site-nav{border-top:3px solid;border-image:repeating-linear-gradient(90deg,#96e832 0px,#96e832 12px,#0a0f09 12px,#0a0f09 24px) 1;}

/* ══════════════════════════════════════════
   THEME SWITCHER MODAL
══════════════════════════════════════════ */
.theme-overlay,.theme-change-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:20px;backdrop-filter:blur(4px);overflow-y:auto;}
.theme-overlay.hidden,.theme-change-overlay.hidden{display:none;}
.theme-popup{background:var(--popup-bg);border:1px solid var(--popup-border);max-width:600px;width:100%;padding:36px 28px 32px;text-align:center;position:relative;animation:popIn 0.35s cubic-bezier(0.34,1.56,0.64,1);margin:auto 0;}
@keyframes popIn{from{opacity:0;transform:scale(0.88) translateY(20px);}to{opacity:1;transform:scale(1) translateY(0);}}
.theme-popup-eyebrow{font-family:var(--font-heading);font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--accent-dim);margin-bottom:12px;}
.theme-popup-title{font-family:var(--font-display);font-size:clamp(18px,3vw,26px);color:var(--accent);margin-bottom:10px;letter-spacing:2px;line-height:1.3;}
.theme-popup-sub{font-family:var(--font-body);font-style:italic;font-size:14px;color:var(--text-muted);margin-bottom:32px;}
.theme-choices{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px;}
.theme-choice-btn{border:none;padding:0;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;background:transparent;display:flex;flex-direction:column;align-items:stretch;text-align:center;position:relative;overflow:hidden;}
.theme-choice-btn:hover{transform:translateY(-4px);}
.tc-inner{display:flex;flex-direction:column;align-items:center;padding:22px 18px 14px;}
.tc-rune{display:block;text-align:center;padding:8px 18px;font-size:10px;letter-spacing:2px;}
.tc-icon{font-size:28px;margin-bottom:10px;display:block;}
.tc-name{display:block;margin-bottom:4px;}
.theme-choice-btn[data-pick="dark"]{background:linear-gradient(160deg,#150f20,#0d0b0e);border:1px solid #9a7830;box-shadow:inset 0 0 30px rgba(122,95,240,0.06);}
.theme-choice-btn[data-pick="dark"]:hover{border-color:#e0b84e;box-shadow:0 8px 32px rgba(224,184,78,0.2);}
.theme-choice-btn[data-pick="dark"] .tc-icon{filter:drop-shadow(0 0 8px rgba(224,184,78,0.5));}
.theme-choice-btn[data-pick="dark"] .tc-name{font-family:'Cinzel Decorative',serif;font-size:11px;color:#e0b84e;letter-spacing:1px;}
.theme-choice-btn[data-pick="dark"] .tc-rune{font-family:'Cinzel',serif;color:#9a7830;border-top:1px solid #2a1f0e;}
.theme-choice-btn[data-pick="light"]{background:linear-gradient(160deg,#fff8ed,#f0e2c0);border:1px solid #c9a070;}
.theme-choice-btn[data-pick="light"]:hover{border-color:#b8620a;box-shadow:0 8px 32px rgba(184,98,10,0.2);}
.theme-choice-btn[data-pick="light"] .tc-name{font-family:'Uncial Antiqua',serif;font-size:13px;color:#b8620a;}
.theme-choice-btn[data-pick="light"] .tc-rune{font-family:'IM Fell English',serif;font-size:13px;color:#b8620a;border-top:1px solid #d4b080;opacity:0.7;}
.theme-choice-btn[data-pick="postapoc"]{background:#0a0f09;border:1px solid #2e5018;}
.theme-choice-btn[data-pick="postapoc"]::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(150,232,50,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(150,232,50,0.03) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;}
.theme-choice-btn[data-pick="postapoc"]:hover{border-color:#96e832;box-shadow:0 8px 32px rgba(150,232,50,0.2);}
.theme-choice-btn[data-pick="postapoc"] .tc-icon{filter:drop-shadow(0 0 6px rgba(150,232,50,0.6));position:relative;}
.theme-choice-btn[data-pick="postapoc"] .tc-name{font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;color:#96e832;letter-spacing:3px;text-transform:uppercase;position:relative;}
.theme-choice-btn[data-pick="postapoc"] .tc-rune{font-family:'Share Tech Mono',monospace;color:#e04010;border-top:1px solid #1e3a10;position:relative;}
.theme-choice-btn[data-pick="scifi"]{background:linear-gradient(160deg,#080f1e,#040810);border:1px solid #0e5080;}
.theme-choice-btn[data-pick="scifi"]::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(24,232,255,0.012) 3px,rgba(24,232,255,0.012) 4px);pointer-events:none;}
.theme-choice-btn[data-pick="scifi"]:hover{border-color:#18e8ff;box-shadow:0 8px 32px rgba(24,232,255,0.25);}
.theme-choice-btn[data-pick="scifi"] .tc-icon{filter:drop-shadow(0 0 8px rgba(24,232,255,0.7));position:relative;}
.theme-choice-btn[data-pick="scifi"] .tc-name{font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;color:#18e8ff;letter-spacing:4px;text-transform:uppercase;position:relative;}
.theme-choice-btn[data-pick="scifi"] .tc-rune{font-family:'Share Tech Mono',monospace;color:#9040ff;border-top:1px solid #0a2840;position:relative;}
.theme-popup-skip{font-family:'Cinzel',serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);background:none;border:none;cursor:pointer;opacity:0.6;transition:opacity 0.2s;}
.theme-popup-skip:hover{opacity:1;}

/* ══════════════════════════════════════════
   SECTION SHARED
══════════════════════════════════════════ */
.section-header{text-align:center;padding:48px 20px 32px;}
.section-label{font-family:var(--font-heading);font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--accent-dim);margin-bottom:10px;display:block;}
.section-title{font-family:var(--font-display);font-size:clamp(18px,3vw,28px);color:var(--accent);letter-spacing:2px;transition:all 0.5s;}
.ornament{display:block;text-align:center;color:var(--accent-dim);font-size:20px;letter-spacing:6px;margin:12px 0 0;opacity:0.7;}
.section-divider{display:flex;align-items:center;justify-content:center;gap:16px;padding:24px 40px;color:var(--accent-dim);}
.section-divider::before,.section-divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--accent-dim) 50%,transparent);}
.section-divider span{font-size:20px;letter-spacing:10px;}

/* ══════════════════════════════════════════
   BLOG CARDS (shared across home + blog)
══════════════════════════════════════════ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;max-width:1200px;margin:0 auto;padding:0 24px;}
.post-card{background:var(--bg-card);border:1px solid var(--border);position:relative;overflow:hidden;cursor:pointer;transition:transform 0.25s,border-color 0.25s,box-shadow 0.25s,background 0.5s;display:flex;flex-direction:column;}
.post-card:hover{transform:translateY(-4px);border-color:var(--border-hover);box-shadow:0 12px 40px var(--card-hover-shadow);}
.post-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity 0.25s;}
.post-card:hover::before{opacity:1;}
body[data-theme="postapoc"] .post-card::after{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);opacity:0;transition:opacity 0.25s;}
body[data-theme="postapoc"] .post-card:hover::after{opacity:1;}
.post-card-image{width:100%;height:180px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0;}
.post-card-image svg{width:50px;height:50px;opacity:0.2;}
.post-tag{position:absolute;bottom:10px;left:12px;font-family:var(--font-heading);font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--bg-primary);background:var(--accent);padding:3px 10px;}
.post-card-body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column;}
.post-date{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;}
.post-title{font-family:var(--font-heading);font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:10px;line-height:1.45;}
.post-excerpt{font-size:13px;color:var(--text-muted);line-height:1.7;font-style:italic;flex:1;}
body[data-theme="postapoc"] .post-excerpt,body[data-theme="scifi"] .post-excerpt{font-style:normal;font-size:12px;}
.post-read-more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-dim);padding-bottom:2px;width:fit-content;transition:color 0.2s,border-color 0.2s;}
.post-read-more:hover{color:var(--accent-light);border-color:var(--accent);}

/* ══════════════════════════════════════════
   HERO FEATURED POST
══════════════════════════════════════════ */
.hero-post{position:relative;min-height:480px;display:flex;align-items:flex-end;background:var(--bg-tertiary);cursor:pointer;transition:filter 0.3s;overflow:hidden;}
.hero-post:hover{filter:brightness(1.06);}
.hero-thumbnail{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.4;}
.hero-overlay{position:absolute;inset:0;background:var(--hero-overlay);}
.hero-content{position:relative;z-index:2;padding:40px 36px;width:100%;max-width:800px;}
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.hero-tag{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--bg-primary);background:var(--accent);padding:3px 12px;}
.hero-featured-label{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent-dim);}
.hero-title{font-family:var(--font-display);font-size:clamp(22px,4vw,38px);color:var(--text-primary);line-height:1.25;margin-bottom:14px;text-shadow:0 2px 20px rgba(0,0,0,0.5);}
.hero-excerpt{font-size:15px;color:var(--text-secondary);line-height:1.7;margin-bottom:20px;max-width:560px;font-style:italic;}
body[data-theme="postapoc"] .hero-excerpt,body[data-theme="scifi"] .hero-excerpt{font-style:normal;font-size:13px;}
.hero-meta{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);}
.hero-read-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);background:transparent;border:1px solid var(--accent);padding:10px 22px;cursor:pointer;transition:all 0.2s;margin-top:18px;text-decoration:none;}
.hero-read-btn:hover{background:var(--accent);color:var(--bg-primary);}
.lf-random-post-wrap{display:flex;justify-content:center;align-items:center;width:100%;padding:8px 0 4px;}

/* ══════════════════════════════════════════
   SEARCH + FILTER BAR
══════════════════════════════════════════ */
.controls-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:20px 24px;display:flex;flex-direction:column;gap:16px;transition:background 0.5s;}
.search-wrap{position:relative;max-width:500px;width:100%;margin:0 auto;}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--accent-dim);font-size:14px;pointer-events:none;font-family:var(--font-heading);}
.search-input{width:100%;padding:10px 16px 10px 40px;background:var(--search-bg);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color 0.2s;}
.search-input::placeholder{color:var(--text-muted);font-style:italic;}
.search-input:focus{border-color:var(--accent);}
.filter-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;}
.filter-bar{text-align:center;max-width:1100px;margin:0 auto;padding:0 24px;}
.filter-btn{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;padding:6px 16px;cursor:pointer;background:transparent;border:1px solid var(--border);color:var(--text-muted);transition:all 0.2s;}
.filter-btn:hover{border-color:var(--accent);color:var(--accent);}
.filter-btn.active{background:var(--filter-active-bg);border-color:var(--accent);color:var(--filter-active-color);}
.results-count{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);margin-bottom:28px;text-align:center;}
.no-results{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--text-muted);font-family:var(--font-heading);font-size:13px;letter-spacing:3px;text-transform:uppercase;}

/* ══════════════════════════════════════════
   SINGLE POST
══════════════════════════════════════════ */
.post-hero-image{width:100%;max-height:420px;object-fit:cover;display:block;}
.post-content-wrap{max-width:780px;margin:0 auto;padding:48px 24px 80px;}
.post-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border);}
.post-header .post-tag{position:static;display:inline-block;margin-bottom:14px;}
.post-header .post-title{font-family:var(--font-display);font-size:clamp(24px,4vw,40px);color:var(--text-primary);line-height:1.25;margin-bottom:12px;}
.post-header .post-meta{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);}
.post-body{font-size:16px;line-height:1.85;color:var(--text-secondary);}
.post-body h2,.post-body h3{font-family:var(--font-heading);color:var(--text-primary);margin:2em 0 0.75em;}
.post-body h2{font-size:clamp(18px,2.5vw,24px);}
.post-body h3{font-size:clamp(15px,2vw,19px);}
.post-body p{margin-bottom:1.4em;}
.post-body ul,.post-body ol{margin:0 0 1.4em 1.5em;}
.post-body li{margin-bottom:0.5em;}
.post-body blockquote{border-left:3px solid var(--accent);padding:16px 20px;margin:1.5em 0;background:var(--bg-secondary);font-style:italic;color:var(--text-primary);}
.post-body img{width:100%;margin:1.5em 0;border:1px solid var(--border);}
.post-body a{color:var(--accent);border-bottom:1px solid var(--accent-dim);}
.post-nav{display:flex;justify-content:space-between;gap:20px;margin-top:48px;padding-top:24px;border-top:1px solid var(--border);}
.post-nav a{font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);padding:10px 0;}

/* ══════════════════════════════════════════
   PROGRAMS PAGE
══════════════════════════════════════════ */
.programs-section{background:var(--bg-secondary);padding-bottom:80px;position:relative;overflow:hidden;transition:background 0.5s;}
.programs-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,var(--programs-glow) 0%,transparent 70%);pointer-events:none;}
.programs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto;padding:0 24px;position:relative;}
.program-card{background:var(--bg-primary);border:1px solid var(--border);padding:32px 28px 36px;position:relative;text-align:center;transition:transform 0.25s,border-color 0.25s,box-shadow 0.25s,background 0.5s;cursor:pointer;}
.program-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent2),transparent);opacity:0;transition:opacity 0.25s;}
.program-card:hover{transform:translateY(-4px);border-color:var(--border-hover);box-shadow:0 12px 40px var(--card-hover-shadow);}
.program-card:hover::after{opacity:1;}
.program-icon{width:64px;height:64px;margin:0 auto 20px;background:var(--bg-secondary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;}
.program-icon svg{width:32px;height:32px;}
.program-tier{font-family:var(--font-heading);font-size:10px;letter-spacing:4px;text-transform:uppercase;margin-bottom:8px;color:var(--text-muted);}
.program-tier.adept{color:var(--accent);}
.program-tier.archmage{color:var(--accent2-bright);}
.program-name{font-family:var(--font-display);font-size:16px;color:var(--text-primary);margin-bottom:12px;line-height:1.35;}
.program-desc{font-size:13.5px;color:var(--text-muted);font-style:italic;line-height:1.7;margin-bottom:24px;}
body[data-theme="postapoc"] .program-desc,body[data-theme="scifi"] .program-desc{font-style:normal;font-size:12.5px;}
.program-price{font-family:var(--font-heading);font-size:22px;color:var(--accent);margin-bottom:4px;}
.program-price-note{font-size:12px;color:var(--text-muted);margin-bottom:20px;}
.program-cta{display:block;width:100%;padding:11px 20px;background:transparent;border:1px solid var(--border);color:var(--accent);font-family:var(--font-heading);font-size:11px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:background 0.2s,border-color 0.2s,color 0.2s;}
.program-cta:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary);}
.program-card.featured-program{border-color:var(--accent);background:var(--bg-tertiary);}

.program-cta.primary{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary);}
.program-cta.primary:hover{background:var(--accent);color:var(--bg-primary);}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.site-footer{background:var(--bg-primary);border-top:1px solid var(--border);text-align:center;padding:32px 20px;font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);transition:background 0.5s;}
.site-footer .footer-rune{font-size:16px;letter-spacing:8px;color:var(--accent-dim);display:block;margin-bottom:12px;opacity:0.6;}

/* ══════════════════════════════════════════
   THEME FLASH
══════════════════════════════════════════ */
.theme-flash{position:fixed;inset:0;background:var(--accent);z-index:2000;pointer-events:none;opacity:0;transition:opacity 0.15s;}
.theme-flash.flash{opacity:0.08;}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:600px){
  .site-header{padding:36px 16px 28px;}
  .rune-row{font-size:10px;letter-spacing:5px;}
  .site-nav{gap:0;padding:0;flex-direction:column;align-items:stretch;}
  .site-nav a{padding:13px 20px;border-bottom:1px solid var(--border);font-size:11px;letter-spacing:2px;display:block;}
  .nav-theme-btn{margin:0;border:none;border-top:1px solid var(--border);padding:13px 20px;text-align:center;font-size:11px;width:100%;}
  body[data-theme="postapoc"] .site-nav{border-top:none;border-left:4px solid;border-image:repeating-linear-gradient(180deg,#96e832 0px,#96e832 12px,#0a0f09 12px,#0a0f09 24px) 1;}
  .theme-popup{padding:28px 18px 24px;}
  .theme-choices{grid-template-columns:1fr;}
  .controls-bar{padding:16px;}
  .hero-post{min-height:360px;}
  .hero-content{padding:24px 20px;}
  .hero-excerpt{display:none;}
  .blog-grid{grid-template-columns:1fr;padding:0 14px;gap:16px;}
  .programs-grid{grid-template-columns:1fr;padding:0 14px;gap:16px;}
  .section-header{padding:32px 16px 20px;}
  .section-divider{padding:16px 20px;}
  .post-content-wrap{padding:32px 16px 60px;}
  .post-nav{flex-direction:column;}
}
@media(min-width:601px) and (max-width:900px){
  .blog-grid{grid-template-columns:repeat(2,1fr);}
  .programs-grid{grid-template-columns:repeat(2,1fr);}
}

/* ══════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════ */
.contact-page { background: var(--bg-primary); padding-bottom: 80px; min-height: 60vh; transition: background 0.5s; }

.contact-wrap {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 40px;
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 24px 0;
}

/* ── Sidebar ── */
.contact-intro-box {
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 28px 24px;
  margin-bottom: 24px;
  position: relative;
}
.contact-intro-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.contact-intro {
  font-family: var(--font-body);
  font-size: 14px;
  font-style: italic;
  color: var(--text-secondary);
  line-height: 1.8;
}
body[data-theme="postapoc"] .contact-intro,
body[data-theme="scifi"] .contact-intro { font-style: normal; font-size: 12.5px; }

.contact-social-box {
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 24px;
}
.contact-social-label {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim);
  margin-bottom: 16px;
}
.contact-social-link {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-heading);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  border: 1px solid var(--border);
  padding: 12px 16px;
  transition: all 0.2s;
}
.contact-social-link:hover {
  border-color: var(--accent);
  background: var(--bg-tertiary);
  color: var(--accent-light);
}
.contact-social-icon {
  width: 20px; height: 20px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contact-social-icon svg { width: 18px; height: 18px; }

/* ── Form ── */
.contact-form-wrap {
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 36px 32px;
  position: relative;
  transition: background 0.5s;
}
.contact-form-wrap::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.form-row { margin-bottom: 22px; }
.form-label {
  display: block;
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim);
  margin-bottom: 8px;
}
.form-input {
  width: 100%;
  padding: 12px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s, background 0.5s;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 0;
}
.form-input:focus { border-color: var(--accent); background: var(--bg-tertiary); }
.form-input::placeholder { color: var(--text-muted); font-style: italic; }
body[data-theme="postapoc"] .form-input::placeholder,
body[data-theme="scifi"] .form-input::placeholder { font-style: normal; }
.form-textarea { resize: vertical; min-height: 150px; line-height: 1.7; }

.form-submit {
  display: block;
  width: 100%;
  padding: 14px 20px;
  background: transparent;
  border: 1px solid var(--accent);
  color: var(--accent);
  font-family: var(--font-heading);
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 8px;
}
.form-submit:hover { background: var(--accent); color: var(--bg-primary); }

/* Success + error states */
.contact-success {
  font-family: var(--font-heading);
  font-size: 13px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  text-align: center;
  padding: 60px 20px;
  border: 1px solid var(--accent-dim);
}
.contact-errors {
  background: var(--bg-secondary);
  border: 1px solid var(--accent2-bright);
  padding: 14px 18px;
  margin-bottom: 24px;
}
.contact-errors p {
  font-family: var(--font-heading);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--accent2-bright);
  margin-bottom: 4px;
}
.contact-errors p:last-child { margin-bottom: 0; }

/* ── Responsive ── */
@media (max-width: 700px) {
  .contact-wrap { grid-template-columns: 1fr; gap: 24px; padding: 24px 14px 0; }
  .contact-form-wrap { padding: 24px 18px; }
}

/* ══════════════════════════════════════════
   PROGRAMS PAGE — PRODUCT SECTIONS
══════════════════════════════════════════ */
.programs-page { background: var(--bg-primary); transition: background 0.5s; }

.product-section { padding: 0 0 20px; }

.product-section-header {
  text-align: center;
  padding: 32px 24px 28px;
  position: relative;
}
.product-section-header::after {
  content: '';
  display: block;
  width: 60px; height: 1px;
  background: var(--accent-dim);
  margin: 14px auto 0;
}
.product-section-title {
  font-family: var(--font-display);
  font-size: clamp(16px, 2.5vw, 24px);
  color: var(--accent);
  letter-spacing: 3px;
  transition: all 0.5s;
}

.product-card-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}

.product-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  transition: border-color 0.25s, background 0.5s;
}
.product-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.product-card:hover { border-color: var(--border-hover); }

/* Preview pane */
.product-preview {
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 280px;
  border-right: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  transition: background 0.5s;
}
.product-preview-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px;
  width: 100%;
  height: 100%;
  color: var(--text-muted);
}
.product-preview-placeholder svg {
  width: 100%;
  max-width: 200px;
  margin-bottom: 16px;
}
.preview-placeholder-text {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim);
  text-align: center;
}

/* Card body */
.product-card-body {
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.product-eyebrow {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim);
  margin-bottom: 10px;
}
.product-name {
  font-family: var(--font-display);
  font-size: clamp(18px, 2.5vw, 26px);
  color: var(--text-primary);
  margin-bottom: 16px;
  line-height: 1.3;
  transition: color 0.5s;
}
.product-desc {
  font-family: var(--font-body);
  font-size: 14px;
  font-style: italic;
  color: var(--text-secondary);
  line-height: 1.8;
  margin-bottom: 24px;
}
body[data-theme="postapoc"] .product-desc,
body[data-theme="scifi"] .product-desc { font-style: normal; font-size: 13px; }

.product-meta { margin-bottom: 20px; }
.product-badge {
  font-family: var(--font-heading);
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 4px 14px;
  border: 1px solid var(--accent-dim);
  color: var(--accent);
}
.product-badge.free { border-color: var(--accent2); color: var(--accent2-bright); }

.product-cta {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-heading);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  background: transparent;
  border: 1px solid var(--accent);
  padding: 12px 24px;
  text-decoration: none;
  transition: all 0.2s;
  align-self: flex-start;
}
.product-cta:hover { background: var(--accent); color: var(--bg-primary); }

.product-coming-soon {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim);
  text-align: center;
  margin-top: 20px;
  opacity: 0.7;
}

/* ── Responsive ── */
@media (max-width: 700px) {
  .product-card { grid-template-columns: 1fr; }
  .product-preview { min-height: 200px; border-right: none; border-bottom: 1px solid var(--border); }
  .product-card-body { padding: 24px 20px; }
  .product-cta { width: 100%; justify-content: center; }
  .product-card-wrap { padding: 0 14px; }
}

/* ══════════════════════════════════════════
   SKILLS SESSION GENERATOR PAGE
══════════════════════════════════════════ */
.skills-gen-page { background: var(--bg-primary); min-height: 60vh; padding-bottom: 80px; transition: background 0.5s; }

.skills-gen-intro {
  max-width: 700px;
  margin: 0 auto 40px;
  padding: 0 24px;
  text-align: center;
}
.skills-gen-desc {
  font-family: var(--font-body);
  font-size: 15px;
  font-style: italic;
  color: var(--text-secondary);
  line-height: 1.8;
}
body[data-theme="postapoc"] .skills-gen-desc,
body[data-theme="scifi"] .skills-gen-desc { font-style: normal; font-size: 13px; }

.skills-gen-content {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 40px;
  position: relative;
  transition: background 0.5s;
}
.skills-gen-content::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

@media (max-width: 600px) {
  .skills-gen-content { padding: 24px 16px; }
}

/* ══════════════════════════════════════════
   HOMEPAGE PRODUCT CARDS
══════════════════════════════════════════ */
.home-products-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 24px;
}
.home-product-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 32px 28px 36px;
  text-align: center;
  position: relative;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s, background 0.5s;
}
.home-product-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.home-product-card:hover {
  transform: translateY(-4px);
  border-color: var(--border-hover);
  box-shadow: 0 12px 40px var(--card-hover-shadow);
}
.home-product-icon {
  width: 64px; height: 64px;
  margin: 0 auto 20px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  transition: background 0.5s;
}
.home-product-icon svg { width: 32px; height: 32px; }
.home-product-eyebrow {
  font-family: var(--font-heading);
  font-size: 10px; letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent-dim); margin-bottom: 8px;
}
.home-product-name {
  font-family: var(--font-display);
  font-size: clamp(14px, 2vw, 18px);
  color: var(--text-primary);
  margin-bottom: 12px; line-height: 1.35;
  transition: color 0.5s;
}
.home-product-desc {
  font-size: 13px; color: var(--text-muted);
  font-style: italic; line-height: 1.7; margin-bottom: 16px;
}
body[data-theme="postapoc"] .home-product-desc,
body[data-theme="scifi"] .home-product-desc { font-style: normal; font-size: 12px; }
.home-product-badge {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 9px; letter-spacing: 3px; text-transform: uppercase;
  padding: 3px 12px;
  border: 1px solid var(--accent2); color: var(--accent2-bright);
}
.programs-see-all {
  font-family: var(--font-heading);
  font-size: 11px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--accent); text-decoration: none;
  border-bottom: 1px solid var(--accent-dim); padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.programs-see-all:hover { color: var(--accent-light); border-color: var(--accent); }

@media (max-width: 600px) {
  .home-products-grid { grid-template-columns: 1fr; padding: 0 14px; }
}

/* ── Product image thumbnails ── */
.home-product-thumb {
  width: 100%;
  height: 180px;
  overflow: hidden;
  margin-bottom: 20px;
  border: 1px solid var(--border);
}
.home-product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s;
}
.home-product-card:hover .home-product-thumb img { transform: scale(1.03); }

.product-preview-image {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
}
.product-preview-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* ══════════════════════════════════════════
   ACCORDION
══════════════════════════════════════════ */
.accordion-wrap {
  max-width: 900px;
  margin: 0 auto 40px;
  padding: 0 24px;
}
.accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 22px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--accent);
  font-family: var(--font-heading);
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  text-align: left;
}
.accordion-trigger:hover { border-color: var(--border-hover); background: var(--bg-tertiary); }
.accordion-trigger[aria-expanded="true"] { border-color: var(--accent); background: var(--bg-tertiary); }
.accordion-icon {
  font-size: 20px;
  font-weight: 300;
  color: var(--accent-dim);
  transition: transform 0.25s;
  flex-shrink: 0;
  margin-left: 16px;
  font-family: var(--font-heading);
}
.accordion-trigger[aria-expanded="true"] .accordion-icon { transform: rotate(45deg); color: var(--accent); }
.accordion-body {
  border: 1px solid var(--accent);
  border-top: none;
  background: var(--bg-card);
  overflow: hidden;
  transition: background 0.5s;
}
.accordion-body[hidden] { display: none; }
.accordion-content { padding: 28px 24px 24px; }
.accordion-intro {
  font-family: var(--font-body);
  font-size: 14px;
  font-style: italic;
  color: var(--text-secondary);
  line-height: 1.8;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
body[data-theme="postapoc"] .accordion-intro,
body[data-theme="scifi"] .accordion-intro { font-style: normal; font-size: 13px; }
.accordion-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.accordion-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  padding: 20px;
  transition: background 0.5s;
}
.accordion-card-title {
  font-family: var(--font-heading);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.accordion-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.accordion-list li {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  padding-left: 14px;
  position: relative;
}
.accordion-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--accent-dim);
  font-size: 11px;
}
.accordion-list li strong {
  color: var(--text-primary);
  font-weight: 600;
}
body[data-theme="postapoc"] .accordion-list li,
body[data-theme="scifi"] .accordion-list li { font-size: 12px; }
.accordion-tags {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.accordion-tags li {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--border);
  padding: 5px 12px;
  background: var(--bg-tertiary);
}
.accordion-note {
  font-family: var(--font-body);
  font-size: 12px;
  font-style: italic;
  color: var(--text-muted);
  line-height: 1.65;
  margin: 0;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
body[data-theme="postapoc"] .accordion-note,
body[data-theme="scifi"] .accordion-note { font-style: normal; }

@media (max-width: 600px) {
  .accordion-wrap { padding: 0 14px; }
  .accordion-grid { grid-template-columns: 1fr; }
  .accordion-content { padding: 20px 16px 18px; }
}

/* Single column accordion grid */
.accordion-grid-single { grid-template-columns: 1fr; }

/* ── Programs page training gallery ── */
.programs-training-gallery { background: var(--bg-primary); transition: background 0.5s; }
.programs-blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (max-width: 600px) {
  .programs-blog-grid { grid-template-columns: 1fr; padding: 0 14px; gap: 16px; }
}

/* ══════════════════════════════════════════
   PROGRAMS PAGE — TRAINING POSTS GALLERY
══════════════════════════════════════════ */
.programs-training-gallery { background: var(--bg-primary); transition: background 0.5s; }
.programs-blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (max-width: 600px) {
  .programs-blog-grid { grid-template-columns: 1fr; padding: 0 14px; gap: 16px; }
}
@media (min-width: 601px) and (max-width: 860px) {
  .programs-blog-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ══════════════════════════════════════════
   NUTRITION PAGE
══════════════════════════════════════════ */
.nutrition-page { padding-bottom: 60px; }

/* ── Training In-Depth page ── */
.product-card-wrap--double { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 900px) { .product-card-wrap--double { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .product-card-wrap--double { grid-template-columns: 1fr; } }
.training-indepth-page { padding-bottom: 80px; min-height: 60vh; }
.training-indepth-content { max-width: 780px; margin: 0 auto; padding: 0 24px; }
.training-indepth-content h3 { font-family: var(--font-heading); font-size: 1.1rem; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin: 2.5rem 0 0.75rem; }
.training-indepth-content p { color: var(--text-secondary); line-height: 1.8; margin-bottom: 1rem; }
.training-indepth-content ul, .training-indepth-content ol { color: var(--text-secondary); line-height: 1.8; margin: 0 0 1rem 1.25rem; }
.training-indepth-content li { margin-bottom: 0.4rem; }
.training-indepth-content .section-divider { margin: 2.5rem 0; }
.tid-equip-heading { font-family: var(--font-heading); font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; color: var(--text-primary); margin: 1.75rem 0 0.5rem; border-left: 2px solid var(--accent); padding-left: 10px; }
.tid-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 1.5rem 0; }
.tid-pillar { background: var(--card-bg); border: 1px solid var(--border); padding: 20px 22px; }
.tid-pillar-title { font-family: var(--font-heading); font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin: 0 0 0.6rem; }
.tid-pillar p { color: var(--text-secondary); font-size: 0.9rem; line-height: 1.7; margin: 0; }
@media (max-width: 600px) { .tid-pillars { grid-template-columns: 1fr; } }
.nutrition-search-wrap { max-width:1100px;margin:0 auto 16px;padding:0 24px; }
.nutrition-search-wrap .search-wrap { position:relative;max-width:500px;margin:0 auto; }
.search-icon { position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--accent-dim);font-size:13px;pointer-events:none; }
.search-input { width:100%;padding:11px 16px 11px 38px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color 0.2s; }
.search-input::placeholder { color:var(--text-muted);font-style:italic; }
.search-input:focus { border-color:var(--accent); }
body[data-theme="postapoc"] .search-input,
body[data-theme="scifi"] .search-input { font-style:normal;font-size:13px; }

.recipe-count-bar { max-width:1100px;margin:0 auto 16px;padding:0 24px;display:flex;align-items:center;justify-content:center; }
.recipe-count { font-family:var(--font-heading);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted); }
.recipe-count span { color:var(--accent); }

.recipes-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto;padding:0 24px; }

.recipe-tag-bar { position:absolute;bottom:10px;left:12px;display:flex;gap:6px;flex-wrap:wrap; }
.recipe-pill { font-family:var(--font-heading);font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:3px 9px; }
.high-pill { background:var(--accent);color:var(--bg-primary); }
.low-pill { background:#2a6b3a;color:#c8f0a8; }
.event-pill { background:#3c3489;color:#cec3e8; }

.high-energy-bg { background:var(--bg-secondary); }
.low-energy-bg  { background:var(--bg-secondary); }
.event-bg       { background:var(--bg-secondary); }

.no-results { grid-column:1/-1;text-align:center;padding:60px 20px 40px;display:none;flex-direction:column;align-items:center;gap:16px; }
.no-results-icon { font-size:20px;color:var(--accent-dim);letter-spacing:8px;opacity:0.5; }
.no-results-title { font-family:var(--font-display);font-size:18px;color:var(--accent); }
.no-results-msg { font-family:var(--font-body);font-size:12px;letter-spacing:1px;color:var(--text-muted);line-height:1.7;max-width:400px; }
.no-results-clear { font-family:var(--font-heading);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);background:none;border:1px solid var(--accent-dim);padding:8px 18px;cursor:pointer;transition:background 0.2s,color 0.2s; }
.no-results-clear:hover { background:var(--accent-dim);color:var(--text-primary); }


@media (max-width:600px) {
  .recipes-grid { grid-template-columns:1fr;padding:0 14px; }
  .nutrition-search-wrap { padding:0 14px; }
}

/* ── YouTube video embed on single posts ── */
.post-video-wrap { max-width: 900px; margin: 0 auto 0; padding: 0; }
.post-video-embed { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.post-video-embed iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* ── Workout gallery pages (battle-drills, skills-gen, body-prep-gen) ── */
.bd-workout-page,
.sg-workout-page,
.bp-workout-page { padding-bottom: 80px; }
.workout-page-intro { max-width: 780px; margin: 0 auto 8px; padding: 0 24px; text-align: center; }
.workout-page-intro .skills-gen-desc { color: var(--text-secondary); line-height: 1.8; }

/* ══════════════════════════════════════════════
   FEATURED POST CARD
══════════════════════════════════════════════ */
.featured-recipe {
  max-width: 1100px;
  margin: 0 auto 40px;
  padding: 0 24px;
}

.featured-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--border);
  background: var(--bg-card);
  overflow: hidden;
  transition: border-color 0.25s, background 0.5s;
  position: relative;
}

.featured-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.featured-img {
  position: relative;
  min-height: 320px;
  background: var(--bg-tertiary);
  overflow: hidden;
}

.featured-img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 320px;
  color: var(--accent-dim);
}

.featured-img-placeholder svg {
  width: 64px;
  height: 64px;
  opacity: 0.15;
}

.featured-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--accent);
  color: var(--bg-primary);
  font-family: var(--font-heading);
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 4px 12px;
  white-space: nowrap;
}

.featured-tag-bar {
  position: absolute;
  bottom: 14px;
  left: 16px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.featured-body {
  padding: 40px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
}

.featured-eyebrow {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}

.featured-title {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.5vw, 1.9rem);
  color: var(--text-primary);
  line-height: 1.25;
  margin: 0;
}

.featured-excerpt {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.75;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.featured-more {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  border: 1px solid var(--accent-dim);
  padding: 8px 20px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  align-self: flex-start;
  margin-top: 6px;
}

.featured-more:hover {
  background: var(--accent);
  color: var(--bg-primary);
  border-color: var(--accent);
}

@media (max-width: 700px) {
  .featured-card {
    grid-template-columns: 1fr;
  }
  .featured-img {
    min-height: 220px;
  }
  .featured-body {
    padding: 28px 24px;
    gap: 12px;
  }
  .featured-recipe {
    padding: 0 14px;
  }
}

/* ══════════════════════════════════════════════
   MATT'S APPS — PRIVATE GENERATOR PAGE
══════════════════════════════════════════════ */
.matts-apps-page { padding-bottom: 80px; min-height: 60vh; }

/* ── Tab bar ── */
.apps-tab-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px;
  max-width: 780px;
  margin: 0 auto 36px;
  padding: 0 24px;
}

/* Make each tab equal width so they sit evenly */
.apps-tab {
  flex: 1 1 auto;
  text-align: center;
  min-width: 140px;
}

/* ── Generator panels ── */
.apps-panels {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 24px;
}

/* Only active panel visible */
.apps-panel { display: none; }
.apps-panel.active { display: block; }

/* Centre the generator widget inside its panel */
.apps-panel > * { margin-left: auto; margin-right: auto; }

/* ── Divider between generator and draft section ── */
.apps-divider {
  max-width: 780px;
  margin: 40px auto 0;
  padding: 0 24px;
  border-top: 1px solid var(--border);
}

/* ── Send to Draft section ── */
.apps-draft-wrap {
  max-width: 780px;
  margin: 0 auto;
  padding: 32px 24px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  text-align: center;
}

.apps-draft-meta {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
}

.apps-meta-label {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--text-muted);
}

.apps-meta-input {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 13px;
  padding: 9px 14px;
  width: 100%;
  transition: border-color 0.2s;
}
.apps-meta-input:focus { outline: none; border-color: var(--accent); }
.apps-meta-input::placeholder { color: var(--text-muted); font-style: italic; }

.apps-draft-btn {
  min-width: 220px;
  justify-content: center;
  text-align: center;
}

.apps-draft-status {
  font-family: var(--font-heading);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  min-height: 20px;
  text-align: center;
}
.apps-draft-status a { color: var(--accent); text-decoration: underline; }
.apps-draft-status--success { color: var(--accent); }
.apps-draft-status--error   { color: #c0392b; }

@media (max-width: 600px) {
  .apps-tab-bar    { padding: 0 14px; gap: 8px; }
  .apps-tab        { min-width: 100%; flex: 1 1 100%; }
  .apps-panels     { padding: 0 14px; }
  .apps-divider    { padding: 0 14px; }
  .apps-draft-wrap { padding: 24px 14px 0; }
}
