/* ============================================================================
   Ironside Adventure Hub — shared styles (public + admin)
   Theme colours are injected at runtime from content.theme via CSS variables.
   ============================================================================ */
:root{
  --bg-dark:#0c1810; --forest:#163a24; --forest-soft:#26543a;
  --mint:#cfe7d5; --mint-dim:#a7c4ad;
  --gold:#c9a24a; --gold-bright:#e6c879;
  --moonlit:#6f9ec4; --moonlit-deep:#13324a;
  --cream:#f4f1e8; --cream-soft:#fbf8f0;
  --ink:#13332f; --ink-soft:#3f5b54;
  --ember:#d8763a;
  --button:#d8763a; --button-2:#b85f28; --button-text:#ffffff;
  --heading:#cfe7d5;
  --maxw:780px; --radius:18px; --notch:18px;
  color-scheme:light;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;font-family:'Manrope',system-ui,sans-serif;color:var(--mint);font-size:17px;line-height:1.7;background:var(--bg-dark);min-height:100vh;}
.serif{font-family:'Cormorant Garamond',serif;} .display{font-family:'Cinzel',serif;}
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:radial-gradient(120% 70% at 50% -5%, rgba(111,158,196,.18), transparent 55%),radial-gradient(140% 80% at 50% 115%, rgba(38,84,58,.55), transparent 55%);}
.mote{position:absolute;width:5px;height:5px;border-radius:50%;background:radial-gradient(circle,var(--gold-bright),transparent 70%);opacity:0;animation:rise linear infinite;}
@keyframes rise{0%{transform:translateY(20px) scale(.6);opacity:0}15%{opacity:.7}85%{opacity:.5}100%{transform:translateY(-110vh) scale(1.1);opacity:0}}
.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 16px 90px;}

/* notched frame shape (chamfered top-right + bottom-left, Ironside style) */
.notch{position:relative;background:var(--gold);
  clip-path:polygon(0 0, calc(100% - var(--notch)) 0, 100% var(--notch), 100% 100%, var(--notch) 100%, 0 calc(100% - var(--notch)));}
.notch::after{content:"";position:absolute;inset:1.6px;z-index:0;background:var(--cream);
  clip-path:polygon(0 0, calc(100% - (var(--notch) - 1.6px)) 0, 100% calc(var(--notch) - 1.6px), 100% 100%, calc(var(--notch) - 1.6px) 100%, 0 calc(100% - (var(--notch) - 1.6px)));}
.notch>*{position:relative;z-index:1;}

/* surfaces */
.panel-dark{position:relative;background:linear-gradient(180deg, rgba(22,58,36,.92), rgba(10,22,14,.96));border:1px solid rgba(201,162,74,.30);border-radius:var(--radius);box-shadow:0 16px 40px rgba(0,0,0,.45), inset 0 0 70px rgba(38,84,58,.25);color:var(--mint);}
.panel-cream{position:relative;background:linear-gradient(180deg,var(--cream-soft),var(--cream));border:1px solid rgba(19,51,47,.14);border-radius:var(--radius);box-shadow:0 14px 34px rgba(0,0,0,.30);color:var(--ink);}
.panel-cream a{color:var(--forest);}
.orn{display:block;margin:0 auto;color:var(--gold);opacity:.9;}
.rule{display:flex;align-items:center;gap:14px;justify-content:center;margin:0 auto 6px;max-width:300px;color:var(--gold);}
.rule::before,.rule::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold),transparent);}

/* hero */
header.hero{padding-top:30px;}
.hero-art{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(201,162,74,.4);box-shadow:0 18px 50px rgba(0,0,0,.5);}
.hero-art svg,.hero-art img{display:block;width:100%;height:auto;}
.hero-plate{margin-top:-26px;padding:50px 24px 30px;text-align:center;}
.eyebrow{font-family:'Cinzel',serif;letter-spacing:.36em;text-transform:uppercase;font-size:11px;color:var(--gold);margin:0 0 14px;}
.story-title{font-family:'Cinzel',serif;font-weight:700;line-height:1.02;margin:0;font-size:clamp(38px,11vw,72px);color:var(--heading);text-shadow:0 2px 20px rgba(0,0,0,.5);}
.story-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(19px,5vw,26px);color:var(--mint-dim);margin:16px auto 0;max-width:30ch;}
.story-intro{font-size:16px;margin:18px auto 0;max-width:48ch;color:var(--mint);}
.release-badge{display:inline-flex;align-items:center;gap:9px;margin-top:24px;font-family:'Cinzel',serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(180deg,var(--forest-soft),var(--forest));color:var(--mint);padding:10px 20px;border-radius:999px;border:1px solid var(--gold);box-shadow:0 5px 16px rgba(0,0,0,.4);}
.release-sub{display:block;margin-top:11px;font-size:14px;color:var(--mint-dim);font-style:italic;font-family:'Cormorant Garamond',serif;}

.section{margin-top:34px;}
.section-eyebrow{font-family:'Cinzel',serif;letter-spacing:.32em;text-transform:uppercase;font-size:11px;color:var(--gold-bright);text-align:center;margin:46px 0 6px;}
.section-title{font-family:'Cinzel',serif;font-weight:600;text-align:center;font-size:clamp(26px,7vw,38px);color:var(--heading);margin:0 0 20px;text-shadow:0 2px 14px rgba(0,0,0,.5);}

.recap{padding:28px 24px;text-align:center;}
.recap .label{font-family:'Cinzel',serif;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ember);margin-bottom:10px;}
.recap p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(19px,5vw,24px);line-height:1.5;margin:0;color:var(--ink);}

/* chapters — notched containers */
.chapters{display:flex;flex-direction:column;gap:16px;}
.chapter{--notch:20px;}
.chapter-head{width:100%;border:0;cursor:pointer;text-align:left;background:transparent;display:flex;align-items:center;gap:15px;padding:19px 22px;font:inherit;color:var(--ink);}
.chapter-head:focus-visible{outline:3px solid var(--moonlit);outline-offset:-3px;}
.ch-mark{flex:0 0 auto;width:46px;height:46px;display:grid;place-items:center;overflow:hidden;
  font-family:'Cinzel',serif;font-weight:700;font-size:17px;color:var(--bg-dark);
  background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold));
  box-shadow:0 3px 9px rgba(0,0,0,.35),inset 0 1px 2px rgba(255,255,255,.6);
  clip-path:polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));}
.ch-mark img{width:100%;height:100%;object-fit:cover;display:block;}
.ch-mark.icon{background:var(--cream);border:1px solid var(--gold);}
.ch-meta{flex:1 1 auto;min-width:0;}
.ch-title{font-family:'Cinzel',serif;font-weight:600;font-size:clamp(17px,4.4vw,22px);line-height:1.2;color:var(--forest);}
.ch-status{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-top:4px;font-weight:600;}
.ch-status.latest{color:var(--ember);} .ch-status.scheduled{color:var(--moonlit-deep);}
.ch-toggle{flex:0 0 auto;color:var(--gold);transition:transform .35s ease;display:grid;place-items:center;}
.ch-toggle svg{display:block;}
.chapter[data-open="true"] .ch-toggle{transform:rotate(180deg);}
.chapter.locked .chapter-head{cursor:not-allowed;}
.chapter.locked .ch-mark{background:linear-gradient(180deg,#9fb0a3,#74897c);color:#fff;}
.chapter.locked .ch-title{color:var(--ink-soft);}
.ch-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .42s ease;}
.chapter[data-open="true"] .ch-body{grid-template-rows:1fr;}
.ch-body-inner{overflow:hidden;}
.ch-content{padding:2px 24px 28px;}
.ch-art{border-radius:13px;overflow:hidden;border:1px solid rgba(19,51,47,.2);margin:6px 0 18px;box-shadow:0 8px 22px rgba(0,0,0,.18);}
.ch-art svg,.ch-art img{display:block;width:100%;height:auto;}
.ch-story p{margin:0 0 14px;font-size:17px;}
.ch-story .dropcap::first-letter{font-family:'Cinzel',serif;float:left;font-size:60px;line-height:.78;padding:6px 10px 0 0;color:var(--ember);}
.countdown{display:inline-block;margin-top:6px;font-family:'Cinzel',serif;font-size:13px;letter-spacing:.1em;color:var(--moonlit-deep);}

/* interactive */
.module{margin:20px 0;padding:18px;border-radius:13px;background:linear-gradient(180deg,rgba(19,50,74,.08),rgba(19,50,74,.03));border:1px solid rgba(111,158,196,.4);}
.module-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--moonlit-deep);margin-bottom:10px;}
.module-prompt{font-family:'Cormorant Garamond',serif;font-size:21px;font-style:italic;margin:0 0 14px;color:var(--ink);}
.field-row{display:flex;gap:10px;flex-wrap:wrap;}
.module input[type=text]{flex:1 1 180px;min-width:0;padding:12px 14px;border-radius:10px;font:inherit;border:1px solid rgba(19,51,47,.3);background:#fff;color:var(--ink);}
.module input[type=text]:focus{outline:2px solid var(--moonlit);}
.btn{font-family:'Cinzel',serif;font-weight:600;font-size:13px;letter-spacing:.06em;cursor:pointer;border:0;border-radius:10px;padding:13px 22px;color:var(--button-text);background:linear-gradient(180deg,var(--button),var(--button-2));box-shadow:0 4px 13px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.25);transition:transform .12s,filter .12s;}
.btn:hover{filter:brightness(1.07);} .btn:active{transform:translateY(1px);}
.btn.secondary{background:linear-gradient(180deg,var(--moonlit),var(--moonlit-deep));color:#fff;}
.btn.gold{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:var(--bg-dark);}
.btn.ghost{background:transparent;border:1px solid var(--gold);color:var(--gold);box-shadow:none;}
.btn-cta{display:inline-block;text-decoration:none;margin-top:6px;}
.options{display:flex;flex-direction:column;gap:10px;}
.opt{text-align:left;width:100%;padding:13px 16px;border-radius:10px;font:inherit;cursor:pointer;border:1px solid rgba(19,51,47,.25);background:#fff;color:var(--ink);transition:.15s;}
.opt:hover{border-color:var(--moonlit);}
.opt.correct{background:rgba(38,84,58,.16);border-color:var(--forest-soft);}
.opt.wrong{background:rgba(200,70,40,.13);border-color:#b5482e;}
.runes{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:6px 0 14px;}
.rune{width:58px;height:58px;border-radius:12px;display:grid;place-items:center;cursor:pointer;font-family:'Cinzel',serif;font-size:26px;color:var(--moonlit-deep);background:radial-gradient(circle at 40% 30%,#fff,#e7e0cf);border:1px solid rgba(19,51,47,.3);transition:.18s;user-select:none;}
.rune:hover{transform:translateY(-2px);}
.rune.lit{background:radial-gradient(circle at 40% 30%,var(--gold-bright),var(--ember));color:#fff;box-shadow:0 0 18px rgba(216,118,58,.8);border-color:var(--gold);}
.feedback{margin-top:12px;font-style:italic;font-size:16px;min-height:1.2em;font-family:'Cormorant Garamond',serif;}
.feedback.ok{color:var(--forest);font-weight:600;} .feedback.no{color:#b5482e;}
.code-vault{margin:18px 0;padding:18px;border-radius:13px;text-align:center;background:radial-gradient(120% 120% at 50% 0%,rgba(201,162,74,.16),rgba(201,162,74,.04));border:1px dashed var(--gold);}
.code-vault .vault-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.code-locked{font-style:italic;color:var(--ink-soft);font-family:'Cormorant Garamond',serif;}
.code-reveal{display:none;} .code-vault.unlocked .code-reveal{display:block;animation:fadein .5s ease;}
.code-vault.unlocked .code-locked{display:none;}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.secret-code{font-family:'Cinzel',serif;font-weight:700;font-size:clamp(22px,7vw,32px);letter-spacing:.14em;color:var(--forest);margin:6px 0;background:linear-gradient(180deg,#fff,transparent);display:inline-block;padding:4px 16px;border-radius:8px;}
.copy-note{font-size:13px;color:var(--ink-soft);}
.reward{margin-top:18px;padding:16px 18px;border-radius:13px;display:flex;gap:12px;align-items:flex-start;background:linear-gradient(180deg,rgba(38,84,58,.16),rgba(38,84,58,.06));border:1px solid rgba(38,84,58,.4);}
.reward .gift{font-size:26px;line-height:1;} .reward .r-title{font-family:'Cinzel',serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);}

/* giveaway */
.giveaway{padding:0;overflow:hidden;}
.giveaway .g-top{padding:30px 22px 6px;text-align:center;}
.g-kicker{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--mint-dim);margin:0 auto 16px;max-width:40ch;}
.g-logo{font-family:'Cinzel',serif;font-weight:700;letter-spacing:.04em;font-size:clamp(34px,10vw,60px);color:var(--gold-bright);line-height:1;text-shadow:0 2px 18px rgba(0,0,0,.5);}
.g-logo small{display:block;font-size:14px;letter-spacing:.4em;color:var(--gold);margin-top:8px;}
.g-arch{margin:22px auto 0;max-width:78%;border:1px solid rgba(201,162,74,.5);border-radius:200px 200px 16px 16px;overflow:hidden;box-shadow:0 14px 40px rgba(0,0,0,.5);}
.g-arch svg,.g-arch img{display:block;width:100%;height:auto;}
.g-body{padding:22px;text-align:center;}
.g-desc{margin:0 auto 16px;max-width:48ch;color:var(--mint);}
.rewards-list{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:9px;}
.rewards-list li{display:flex;gap:10px;align-items:center;justify-content:center;color:var(--mint);}
.rewards-list .tick{color:var(--gold);}
.g-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,6vw,30px);color:var(--mint);margin:8px 0 2px;}

/* faq */
.faq-item{border-bottom:1px solid rgba(19,51,47,.16);}
.faq-item:last-child{border-bottom:0;}
.faq-q{width:100%;background:transparent;border:0;cursor:pointer;font:inherit;text-align:left;display:flex;justify-content:space-between;gap:12px;align-items:center;padding:17px 20px;color:var(--forest);}
.faq-q .qt{font-family:'Cinzel',serif;font-weight:600;font-size:15px;}
.faq-q .qi{color:var(--gold);transition:transform .3s;display:grid;place-items:center;}
.faq-item[data-open="true"] .qi{transform:rotate(180deg);}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease;}
.faq-item[data-open="true"] .faq-a{grid-template-rows:1fr;}
.faq-a-inner{overflow:hidden;} .faq-a p{margin:0;padding:0 20px 18px;color:var(--ink);}

/* archive */
.archive{padding:26px 22px;}
.arch-block{margin-bottom:20px;} .arch-block:last-child{margin-bottom:0;}
.arch-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ember);margin-bottom:10px;}
.arch-card{display:flex;gap:14px;align-items:center;padding:14px 16px;border-radius:13px;margin-bottom:10px;background:linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,.15));border:1px solid rgba(19,51,47,.18);}
.arch-card.current{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,74,.3) inset;}
.arch-card .seal{flex:0 0 auto;width:40px;height:40px;border-radius:9px;display:grid;place-items:center;font-size:19px;background:radial-gradient(circle at 40% 30%,var(--forest-soft),var(--forest));color:var(--gold-bright);}
.arch-card .a-name{font-family:'Cinzel',serif;font-weight:600;color:var(--forest);font-size:15px;}
.arch-card .a-blurb{font-size:14px;color:var(--ink-soft);font-style:italic;font-family:'Cormorant Garamond',serif;}
.arch-card .a-tag{margin-left:auto;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:var(--forest);color:var(--mint);white-space:nowrap;}
.arch-card.coming .seal{background:linear-gradient(180deg,#9fb0a3,#74897c);color:#fff;} .arch-card.coming .a-tag{background:#74897c;}

footer{text-align:center;padding:42px 16px 0;color:var(--mint-dim);font-size:13px;position:relative;z-index:1;}
footer .crest{font-family:'Cinzel',serif;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);font-size:14px;margin-bottom:6px;}

@media(min-width:760px){ body{font-size:18px;} .hero-plate{padding:60px 44px 34px;} .ch-content{padding:4px 38px 32px;} }
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

/* ===== Minstrel V1 additions ===== */
/* chapters: rounded rectangles (override the notched look) */
.chapter.chapter-round{--notch:0px;clip-path:none;background:transparent;border-radius:18px;}
.chapter.chapter-round::after{display:none;}
.chapter.chapter-round{background:linear-gradient(180deg,var(--cream-soft),var(--cream));border:1px solid rgba(19,51,47,.16);box-shadow:0 12px 30px rgba(0,0,0,.28);overflow:hidden;}
/* width helpers */
.section.w-wide{max-width:none;}
.w-full{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:100vw;}
/* social chips spacing handled inline */
/* editor-only states (never present on the public page) */
.editable-block{position:relative;cursor:pointer;}
.editable-block:hover{outline:2px dashed var(--moonlit);outline-offset:3px;}
.editable-block.selected{outline:3px solid var(--ember);outline-offset:3px;}
.blk-hidden{opacity:.45;}
.blk-hidden::before{content:"Hidden";position:absolute;top:6px;left:6px;z-index:5;background:#74897c;color:#fff;font:600 10px/1 'Manrope',sans-serif;letter-spacing:.08em;text-transform:uppercase;padding:4px 7px;border-radius:6px;}
