:root{
  --ink:#26120d;
  --muted:#6f5a4c;
  --paper:#fff8ed;
  --paper-2:#f4e6d1;
  --sand:#c9b08b;
  --gold:#d8a03c;
  --red:#b93428;
  --blood:#6f1813;
  --brown:#35170f;
  --smoke:#1b1715;
  --line:rgba(62,31,20,.18);
  --shadow:0 20px 70px rgba(23,12,8,.18);
  --radius:18px;
  --sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif:Georgia, "Times New Roman", serif;
}
*{box-sizing:border-box}
html{scroll-behavior:auto}
body{margin:0;color:var(--ink);font-family:var(--sans);line-height:1.58;background:#f7f1e7;min-height:100vh}
body:before{content:"";position:fixed;inset:0;z-index:-3;background:radial-gradient(circle at 20% 0%, rgba(185,52,40,.18), transparent 28rem),radial-gradient(circle at 88% 8%, rgba(216,160,60,.22), transparent 24rem),linear-gradient(180deg,#d3b995 0,#efe4d2 18rem,#faf8f3 35rem)}
.page-bg{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.55;background:linear-gradient(115deg,rgba(255,255,255,.35),rgba(255,255,255,0) 30%),repeating-linear-gradient(45deg,rgba(75,38,25,.045) 0 1px,transparent 1px 14px)}
a{color:inherit}.skip{position:absolute;left:-999px}.skip:focus{left:1rem;top:1rem;z-index:20;background:#fff;padding:.7rem 1rem;border-radius:10px}
.topbar{position:sticky;top:0;z-index:10;background:rgba(42,22,14,.9);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,226,183,.22);box-shadow:0 6px 24px rgba(0,0,0,.18)}
.topbar-inner{max-width:1460px;margin:0 auto;padding:1rem 1.2rem;display:grid;grid-template-columns:220px 1fr minmax(420px,560px);gap:1.1rem;align-items:center}
.download{display:inline-flex;flex-direction:column;gap:.05rem;padding:.75rem 1rem;text-decoration:none;color:#fff;background:linear-gradient(135deg,#3b170f,#1b0a06);border:1px solid rgba(255,232,183,.23);border-radius:11px;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.download span{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#e6cfa7}.download strong{font-size:.95rem}
.brand{text-align:center;color:#fff;line-height:1.15}.brand small{display:block;text-transform:uppercase;letter-spacing:.18em;color:#d8a03c;font-weight:800;font-size:.68rem}.brand b{display:block;font:700 1.28rem var(--serif);letter-spacing:.01em}.brand em{display:block;font-style:normal;color:#d9c4ab;font-size:.78rem;margin-top:.18rem}
.controls{display:grid;gap:.55rem}.mode-toggle{display:grid;grid-template-columns:1fr 1fr;background:#e9ddcb;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:.28rem;box-shadow:inset 0 2px 10px rgba(0,0,0,.08)}
.mode-toggle button{border:0;border-radius:9px;background:transparent;padding:.68rem 1rem;font-weight:900;letter-spacing:.01em;color:#573b2b;cursor:pointer}.mode-toggle button[aria-pressed="true"]{color:#fff;background:linear-gradient(135deg,var(--blood),var(--brown));box-shadow:0 4px 14px rgba(49,18,11,.28)}
.search-wrap{display:block}.search{width:100%;border:1px solid rgba(61,30,18,.22);border-radius:11px;padding:.86rem 1rem .86rem 2.7rem;font-size:.95rem;background:#fff8ee url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%236f5a4c' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E") no-repeat .9rem center;color:var(--ink);outline:none}.search:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(216,160,60,.24)}
.shell{max-width:1460px;margin:1.5rem auto 4rem;padding:0 1.2rem;display:grid;grid-template-columns:300px minmax(0,1fr);gap:1.3rem}.sidebar{position:relative}.toc{position:sticky;top:7.3rem;max-height:calc(100vh - 8.5rem);overflow:auto;background:rgba(255,249,239,.92);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}.toc h2{font:700 1.45rem var(--serif);margin:.15rem 0 .9rem}.nav-group{padding:.8rem 0;border-top:1px solid var(--line)}.nav-group:first-of-type{border-top:0}.nav-group h3{margin:0 0 .45rem;color:var(--blood);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em}.nav-group a{display:block;text-decoration:none;color:#4e3a31;padding:.42rem .6rem;border-radius:9px;font-size:.88rem;line-height:1.25}.nav-group a:hover,.nav-group a.active{background:linear-gradient(90deg,rgba(216,160,60,.28),rgba(216,160,60,.08));color:#25110c}.nav-group a.active{font-weight:800;border-left:4px solid var(--red)}body[data-mode="rules"] .nav-group a[data-mode="tactics"],body[data-mode="tactics"] .nav-group a[data-mode="rules"]{display:none}
.main{min-width:0}.hero,.mode-intro,.rule-section,.results-bar{background:rgba(255,250,242,.94);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.hero{position:relative;overflow:hidden;padding:2rem;margin-bottom:1rem;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:end;background:linear-gradient(135deg,rgba(255,250,242,.98),rgba(246,230,206,.94))}.hero:after{content:"";position:absolute;right:-70px;top:-85px;width:290px;height:290px;border-radius:50%;background:radial-gradient(circle,rgba(185,52,40,.2),transparent 62%)}.eyebrow{margin:0 0 .35rem;text-transform:uppercase;letter-spacing:.16em;color:var(--blood);font-size:.72rem;font-weight:900}.hero h1,.mode-intro h1{position:relative;margin:0;font:800 clamp(2.6rem,6vw,5.2rem)/.9 var(--serif);letter-spacing:-.04em;color:#2a120b}.hero p{font-size:1.08rem;max-width:760px}.hero-actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-end}.hero-actions a{position:relative;text-decoration:none;border-radius:999px;padding:.76rem 1rem;background:#fff;border:1px solid var(--line);font-weight:850;color:#32170f}.hero-actions a:first-child{background:linear-gradient(135deg,var(--blood),var(--brown));color:#fff;border-color:transparent}.mode-intro{display:none;padding:2rem;margin-bottom:1rem;background:linear-gradient(135deg,#fff8ed,#f3dfc0)}body[data-mode="tactics"] .hero{display:none}body[data-mode="tactics"] .mode-intro{display:block}
.results-bar{padding:.75rem 1rem;margin-bottom:1rem;font-weight:800;color:#4b2b20}.content{display:grid;gap:1rem}.rule-section{scroll-margin-top:8.5rem;overflow:hidden}.rule-head{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:start;padding:1.3rem 1.45rem .8rem;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.45),rgba(255,255,255,0))}.rule-head span{grid-column:1/-1;color:var(--blood);text-transform:uppercase;letter-spacing:.14em;font-weight:900;font-size:.68rem}.rule-head h2{margin:0;font:760 clamp(1.75rem,3vw,2.55rem)/1 var(--serif);letter-spacing:-.02em}.copy-link{text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:.45rem .72rem;font-size:.78rem;color:var(--muted);background:#fff}.prose{padding:1.25rem 1.45rem 1.5rem;max-width:980px}.prose h3{margin:1.35rem 0 .3rem;font:700 1.25rem var(--serif);color:#35170f}.prose p{margin:.72rem 0}.lede{font-size:1.08rem;color:#513a30}.rule-line{padding-left:1rem;border-left:3px solid rgba(185,52,40,.28);background:rgba(216,160,60,.09);border-radius:0 10px 10px 0;padding:.55rem .8rem}.learn-path,.tactic-grid,.cards-grid{display:grid;gap:1rem}.learn-path{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:1rem}.learn-path div,.tactic-grid article,.mini-card{background:#fffaf1;border:1px solid var(--line);border-radius:15px;padding:1rem}.learn-path b{display:grid;place-items:center;width:2rem;height:2rem;border-radius:999px;background:linear-gradient(135deg,var(--blood),var(--red));color:#fff}.learn-path span{display:block;font-weight:900;margin:.55rem 0 .15rem}.steps{background:#fffaf1;border:1px solid var(--line);border-radius:15px;padding:1rem 1rem 1rem 2.2rem}.steps li{margin:.35rem 0}.steps a{font-weight:800;color:var(--blood)}.tactic-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1rem}.tactic-grid b{font:700 1.15rem var(--serif)}.card-tools{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.48rem .7rem;font-weight:800;color:#4d392f;cursor:pointer}.chip.is-active{background:linear-gradient(135deg,var(--blood),var(--brown));color:#fff;border-color:transparent}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));align-items:start}.ability-card,.mini-card{background:#fffaf1;border:1px solid var(--line);border-radius:16px;padding:1rem;box-shadow:0 8px 28px rgba(40,18,10,.07)}.ability-card h3,.mini-card h3{margin:.25rem 0 .2rem;font:760 1.28rem var(--serif)}.ability-top{display:flex;justify-content:space-between;align-items:center}.num{font-weight:950;color:var(--blood)}.color{font-size:1.3rem}.type{font-size:.82rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.05em}.hidden-by-search{display:none!important}body[data-mode="rules"] [data-mode="tactics"],body[data-mode="tactics"] [data-mode="rules"]{display:none}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.back-top{position:fixed;right:1rem;bottom:1rem;text-decoration:none;background:linear-gradient(135deg,var(--blood),var(--brown));color:#fff;border-radius:999px;padding:.7rem .85rem;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.25)}
@media (max-width:1100px){.topbar-inner{grid-template-columns:1fr;gap:.8rem}.brand{text-align:left}.shell{grid-template-columns:1fr}.toc{position:relative;top:0;max-height:340px}.learn-path{grid-template-columns:repeat(2,minmax(0,1fr))}.tactic-grid{grid-template-columns:1fr}.hero{grid-template-columns:1fr}.hero-actions{justify-content:flex-start}.rule-section{scroll-margin-top:1rem}}
@media (max-width:640px){.topbar-inner,.shell{padding-left:.75rem;padding-right:.75rem}.mode-toggle button{padding:.62rem .5rem}.hero,.mode-intro{padding:1.2rem}.rule-head,.prose{padding-left:1rem;padding-right:1rem}.learn-path{grid-template-columns:1fr}.cards-grid{grid-template-columns:1fr}.download{width:100%}}
@media print{.topbar,.sidebar,.back-top,.copy-link,.hero-actions,.search-wrap{display:none!important}.shell{display:block;margin:0}.rule-section{box-shadow:none;border:1px solid #ddd;break-inside:avoid}body [data-mode]{display:block!important}}


/* Rev20 audit fixes: mode-specific index, preview search, and readability */
.nav-group[hidden], .toc a[hidden]{display:none!important}
.card-nav-group{max-height:32rem;overflow:auto;padding-right:.25rem}
.card-nav-group .sub{font-size:.8rem;padding-left:1rem;color:#5d4a40}
.controls{position:relative}
.search-results{position:absolute;left:0;right:0;top:100%;margin-top:.55rem;z-index:25;background:#fffaf1;border:1px solid rgba(62,31,20,.22);border-radius:14px;box-shadow:0 22px 70px rgba(23,12,8,.28);max-height:min(66vh,620px);overflow:auto;padding:.45rem}
.search-result{display:grid;gap:.14rem;text-decoration:none;padding:.72rem .8rem;border-radius:12px;border-bottom:1px solid rgba(62,31,20,.08)}
.search-result:hover,.search-result:focus{background:linear-gradient(90deg,rgba(216,160,60,.22),rgba(185,52,40,.08));outline:none}
.search-result strong{font:760 1rem var(--serif);color:#25110c}
.search-result small{color:#5d4a40;line-height:1.35}
.search-meta{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;font-weight:950;color:var(--blood)}
.search-result mark{background:rgba(216,160,60,.38);color:#24120c;border-radius:3px;padding:0 .08rem}
.search-more,.empty-search{padding:.8rem;color:#5d4a40}.empty-search{display:grid;gap:.15rem}.empty-search b{color:#2a120b}
.search-hit{animation:searchPulse 2.4s ease;border-color:rgba(185,52,40,.55)!important;box-shadow:0 0 0 4px rgba(185,52,40,.13), var(--shadow)!important}
@keyframes searchPulse{0%,100%{transform:none}30%{transform:translateY(-2px)}}
.hidden-by-filter{display:none!important}
.prose p{max-width:78ch}.prose p + p{margin-top:.55rem}
.prose > p:not(.lede):nth-of-type(odd){border-left:2px solid rgba(216,160,60,.18);padding-left:.75rem}
.ability-card{scroll-margin-top:8.5rem}
.ability-card.search-hit{outline:0}
body[data-mode="rules"] .mode-intro{display:none!important}
body[data-mode="tactics"] .hero{display:none!important}
body[data-mode="tactics"] .mode-intro{display:block!important}
@media (max-width:1100px){.search-results{position:fixed;left:.75rem;right:.75rem;top:auto;max-height:60vh}.card-nav-group{max-height:18rem}}
body[data-mode="rules"] .nav-group[data-nav-mode="tactics"],
body[data-mode="tactics"] .nav-group[data-nav-mode="rules"]{display:none!important}
body[data-mode="tactics"] .nav-group[data-generated-card-index="true"]{display:none!important}


/* Rev20 v2: clearer onboarding and lightweight instructional illustrations */
.learn-path--compact p{margin-top:.35rem}
.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-top:1rem}
.rule-figure{margin:1rem 0;padding:1rem;background:linear-gradient(180deg,#fffefb,#faf1e1);border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 28px rgba(40,18,10,.08)}
.rule-figure img{display:block;max-width:100%;height:auto;margin:0 auto;border-radius:12px;border:1px solid rgba(62,31,20,.08)}
.rule-figure figcaption{margin-top:.65rem;font-size:.9rem;color:#5b4538}
.rule-figure--compact{max-width:620px}
.rule-figure--wide{max-width:980px}
.figure-grid{display:grid;gap:.9rem}
.figure-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.figure-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.figure-grid figure{margin:0}
.figure-grid figcaption{font-size:.85rem;line-height:1.35}
.rule-line a{font-weight:800;color:var(--blood);text-decoration:none}
.rule-line a:hover{text-decoration:underline}
@media (max-width:1100px){.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.figure-grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.summary-grid,.figure-grid--2,.figure-grid--3{grid-template-columns:1fr}}

/* Rev22 readability pass: scannable unit/stat sections */
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin:1rem 0 1.2rem}
.stat-card,.unit-card{background:#fffaf1;border:1px solid var(--line);border-radius:16px;padding:1rem;box-shadow:0 8px 28px rgba(40,18,10,.07)}
.stat-card span{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:950;color:var(--blood);margin-bottom:.25rem}
.stat-card strong{display:block;font:760 1.35rem var(--serif);color:#2a120b;margin-bottom:.2rem}
.stat-card p,.unit-card p{margin:.25rem 0 0;color:#4f3a31;line-height:1.45}
.unit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:1rem 0 1.2rem}
.unit-card h4{margin:0 0 .25rem;font:760 1.15rem var(--serif);color:#2a120b}
.clean-list{display:grid;gap:.45rem;margin:.8rem 0 1.1rem;padding:0;list-style:none}
.clean-list li{position:relative;padding:.55rem .75rem .55rem 2rem;border:1px solid rgba(62,31,20,.12);border-radius:12px;background:rgba(255,250,242,.82)}
.clean-list li:before{content:"";position:absolute;left:.75rem;top:1.05rem;width:.45rem;height:.45rem;border-radius:50%;background:linear-gradient(135deg,var(--blood),var(--red))}
.prose > p:not(.lede):nth-of-type(odd){border-left:0;padding-left:0}
@media (max-width:900px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.stat-grid{grid-template-columns:1fr}}

/* Rev23 mobile iframe pass: compact header, collapsible index, safer small-screen flow */
.toc-toggle{display:none;width:100%;border:1px solid rgba(62,31,20,.18);border-radius:14px;background:linear-gradient(135deg,#fffaf1,#f0dfc7);color:#2a120b;font-weight:950;padding:.85rem 1rem;text-align:left;box-shadow:0 10px 30px rgba(23,12,8,.12);cursor:pointer}
.toc-toggle span{display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.toc-toggle span:after{content:"+";display:grid;place-items:center;width:1.35rem;height:1.35rem;border-radius:999px;background:rgba(111,24,19,.12);color:var(--blood);font-size:1.05rem;line-height:1}
.sidebar.is-open .toc-toggle span:after{content:"-"}
img,svg,video,canvas{max-width:100%;height:auto}
.prose,.rule-head,.ability-card,.mini-card,.stat-card,.unit-card{overflow-wrap:anywhere}
@media (max-width:820px){
  body{font-size:16px;line-height:1.55;background:#faf7f0}
  body:before{background:linear-gradient(180deg,#e5d2b7 0,#f8f1e7 18rem,#faf8f3 40rem)}
  .topbar{position:relative;top:auto;z-index:20}
  .topbar-inner{padding:.7rem .8rem;gap:.65rem;grid-template-columns:1fr}
  .brand{order:1;text-align:left}.brand small,.brand em{display:none}.brand b{font-size:1.05rem;line-height:1.1}
  .controls{order:2;gap:.45rem}.mode-toggle{border-radius:11px}.mode-toggle button{min-height:44px;padding:.58rem .5rem;font-size:.9rem;line-height:1.1}
  .search{min-height:46px;padding:.76rem .9rem .76rem 2.55rem;font-size:16px;border-radius:12px}
  .download{order:3;width:auto;min-height:42px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.4rem;padding:.58rem .75rem;border-radius:12px}.download span{font-size:.62rem}.download strong{font-size:.86rem}
  .shell{margin:.75rem auto 3.25rem;padding:0 .75rem;gap:.75rem;grid-template-columns:1fr}
  .sidebar{position:sticky;top:.4rem;z-index:15}.toc-toggle{display:block}
  .toc{display:none;margin-top:.5rem;position:relative;top:auto;max-height:min(64vh,430px);padding:.75rem;border-radius:14px;box-shadow:0 16px 42px rgba(23,12,8,.22)}
  .sidebar.is-open .toc{display:block}.toc h2{font-size:1.18rem;margin:.1rem 0 .45rem}.nav-group{padding:.55rem 0}.nav-group a{min-height:38px;padding:.5rem .6rem;font-size:.92rem}
  .hero,.mode-intro,.rule-section,.results-bar{border-radius:14px;box-shadow:0 12px 36px rgba(23,12,8,.13)}
  .hero,.mode-intro{padding:1rem;margin-bottom:.75rem}.hero h1,.mode-intro h1{font-size:clamp(2rem,11vw,3.05rem);line-height:.96;letter-spacing:-.035em}.hero p,.lede{font-size:1rem}.hero-actions{display:grid;grid-template-columns:1fr;gap:.5rem}.hero-actions a{text-align:center;padding:.72rem .85rem}
  .content{gap:.75rem}.rule-section{scroll-margin-top:1rem}.rule-head{grid-template-columns:1fr;gap:.4rem;padding:1rem .95rem .7rem}.rule-head h2{font-size:clamp(1.45rem,7vw,2.05rem);line-height:1.05}.copy-link{justify-self:start;min-height:38px;display:inline-flex;align-items:center}
  .prose{padding:1rem .95rem 1.1rem;max-width:none}.prose p{max-width:none}.prose h3{font-size:1.14rem;line-height:1.15}.steps{padding:.9rem .9rem .9rem 1.75rem}.clean-list li{padding:.62rem .7rem .62rem 1.7rem}.clean-list li:before{left:.65rem;top:1.06rem}
  .summary-grid,.learn-path,.figure-grid--2,.figure-grid--3,.tactic-grid,.stat-grid,.unit-grid,.cards-grid{grid-template-columns:1fr!important;gap:.75rem}
  .ability-card,.mini-card,.stat-card,.unit-card,.rule-figure{border-radius:14px;padding:.85rem}.ability-top{gap:.65rem}.type{font-size:.75rem}
  .card-tools{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.chip{min-height:40px;padding:.5rem .55rem;font-size:.86rem}
  .search-results{position:fixed;left:.6rem;right:.6rem;top:auto;bottom:.7rem;max-height:min(55vh,420px);z-index:50;border-radius:16px;padding:.35rem;box-shadow:0 24px 80px rgba(23,12,8,.35)}
  .search-result{padding:.75rem;border-radius:12px}.search-result small{font-size:.86rem}.results-bar{padding:.65rem .8rem;font-size:.92rem}
  .back-top{right:.75rem;bottom:.75rem;padding:.58rem .72rem;font-size:.85rem}
}
@media (max-width:390px){
  .topbar-inner,.shell{padding-left:.55rem;padding-right:.55rem}.mode-toggle button{font-size:.82rem}.brand b{font-size:.98rem}.download span{display:none}.hero,.mode-intro,.prose,.rule-head{padding-left:.8rem;padding-right:.8rem}.card-tools{grid-template-columns:1fr}.search-results{left:.45rem;right:.45rem;bottom:.55rem}
}
@media (max-width:820px){
  .brand{display:none}
  .topbar-inner{padding-top:.55rem;padding-bottom:.55rem;gap:.5rem}
  .download{min-height:38px;padding:.5rem .7rem}.search{min-height:44px}.mode-toggle button{min-height:42px}
}

/* Rev24 source-of-truth rules pass */
.rule-table{overflow:auto;margin:1rem 0;border:1px solid var(--line);border-radius:14px;background:#fffaf1;box-shadow:0 8px 24px rgba(40,18,10,.06)}
.rule-table table{width:100%;border-collapse:collapse;min-width:620px}
.rule-table th,.rule-table td{padding:.78rem .9rem;border-bottom:1px solid rgba(62,31,20,.12);text-align:left;vertical-align:top}
.rule-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--blood);background:rgba(216,160,60,.15);font-weight:950}
.rule-table tr:last-child td{border-bottom:0}
.advanced-ruling{margin-top:.8rem;border:1px solid rgba(185,52,40,.18);border-radius:12px;background:rgba(216,160,60,.09);padding:.65rem .75rem}
.advanced-ruling summary{cursor:pointer;font-weight:950;color:var(--blood)}
.advanced-ruling p{margin:.55rem 0 0;line-height:1.45;color:#4e372d}


/* Storybook polish: closer to the friendly original rulebook flow while preserving current rules */
.hero--storybook{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(260px,.75fr);gap:1.2rem;align-items:center;position:relative;overflow:hidden}
.hero--storybook:after{content:"";position:absolute;inset:auto -4rem -6rem auto;width:20rem;height:20rem;border-radius:50%;background:radial-gradient(circle,rgba(216,160,60,.23),rgba(185,52,40,0) 68%);pointer-events:none}
.hero-copy{position:relative;z-index:1}.hero-visual{position:relative;z-index:1;display:grid;gap:.8rem;align-self:stretch;align-content:center}
.hero-card-preview{margin:0;background:linear-gradient(160deg,rgba(21,12,10,.92),rgba(67,29,24,.84));border:1px solid rgba(255,221,156,.45);box-shadow:0 18px 54px rgba(23,12,8,.24);border-radius:22px;padding:1rem;transform:rotate(1deg)}
.hero-card-preview img{display:block;width:min(100%,310px);margin:auto;border-radius:12px;border:3px solid rgba(20,10,8,.75);background:#050505}
.hero-card-preview figcaption{margin-top:.7rem;color:#f9e8bf;font-weight:800;text-align:center;font-size:.92rem;line-height:1.35}
.quick-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.35rem}.quick-actions span{display:grid;place-items:center;text-align:center;min-height:2.35rem;border-radius:999px;background:linear-gradient(135deg,#fff8e9,#ead1a8);border:1px solid rgba(67,29,24,.22);font-size:.74rem;font-weight:950;color:#34170e;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 8px 20px rgba(23,12,8,.11)}
.lore-callout{position:relative;margin:0 0 1rem;padding:1.05rem 1.1rem 1rem 1.25rem;border-radius:18px;border:1px solid rgba(88,43,29,.2);background:linear-gradient(135deg,rgba(40,18,13,.94),rgba(92,34,28,.88));box-shadow:0 14px 42px rgba(23,12,8,.18);color:#fff3d7;overflow:hidden}.lore-callout:before{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:linear-gradient(180deg,var(--gold),var(--blood))}.lore-callout:after{content:"";position:absolute;right:-4rem;bottom:-5rem;width:14rem;height:14rem;border-radius:50%;background:radial-gradient(circle,rgba(216,160,60,.22),transparent 66%)}.lore-callout p{position:relative;margin:.35rem 0 0;max-width:82ch;color:#fff3d7}.lore-kicker{position:relative;display:inline-flex;align-items:center;gap:.35rem;font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;font-weight:1000;color:#ffd98c}.lore-kicker:before{content:"";width:.58rem;height:.58rem;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(216,160,60,.16)}
.play-flow{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.75rem;margin:1rem 0 1.15rem}.play-flow article{background:#fffaf1;border:1px solid var(--line);border-radius:16px;padding:.65rem;box-shadow:0 10px 26px rgba(40,18,10,.08);display:grid;grid-template-rows:auto auto 1fr;gap:.35rem;min-height:100%}.play-flow img{width:100%;aspect-ratio:1.5/1;object-fit:cover;border-radius:10px;border:1px solid rgba(62,31,20,.1);background:#f2e1c9}.play-flow strong{font:800 1rem var(--serif);color:#2a120b;line-height:1.1}.play-flow span{font-size:.83rem;line-height:1.35;color:#5a4338}
.setup-ribbon{display:flex;flex-wrap:wrap;gap:.5rem;margin:.9rem 0 1rem}.setup-ribbon span{display:inline-flex;align-items:center;gap:.45rem;background:linear-gradient(135deg,#fffaf1,#f1dfbf);border:1px solid rgba(62,31,20,.14);border-radius:999px;padding:.45rem .7rem;font-weight:850;color:#2a120b;box-shadow:0 8px 20px rgba(40,18,10,.06)}.setup-ribbon b{display:grid;place-items:center;width:1.4rem;height:1.4rem;border-radius:999px;background:var(--blood);color:#fff7e8;font-size:.82rem}.framed-card img{background:#080808;padding:.25rem;box-shadow:inset 0 0 0 1px rgba(255,222,170,.25)}.action-reminder{background:linear-gradient(90deg,rgba(216,160,60,.16),rgba(255,250,242,.5));border-radius:12px;padding:.65rem .75rem}.ability-colors img{max-height:260px;object-fit:contain;background:#080808}
@media (max-width:1050px){.hero--storybook{grid-template-columns:1fr}.hero-visual{max-width:640px}.play-flow{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:720px){.quick-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.play-flow{grid-template-columns:1fr 1fr}.lore-callout{border-radius:14px;padding:.95rem 1rem .95rem 1.05rem}.setup-ribbon span{width:100%}}
@media (max-width:480px){.play-flow{grid-template-columns:1fr}.hero-card-preview{transform:none}.quick-actions{grid-template-columns:1fr 1fr}.quick-actions span:last-child{grid-column:1/-1}}

/* Lore treatment: story wall plus simple gameplay block */
.lore-callout--epic{
  margin:0;
  padding:clamp(1.1rem,2.4vw,1.7rem);
  border:1px solid rgba(255,217,140,.22);
  border-radius:18px;
  color:#fff3d7;
  background:
    radial-gradient(circle at 84% 18%,rgba(216,160,60,.13),transparent 34%),
    linear-gradient(135deg,rgba(34,14,13,.97),rgba(91,36,26,.94));
  box-shadow:0 14px 38px rgba(23,12,8,.16);
}
.lore-callout--epic:before{
  width:6px;
  background:linear-gradient(180deg,#ffd98c,var(--gold),var(--blood));
}
.lore-callout--epic:after{
  display:none;
}
.lore-callout--epic .lore-kicker{
  margin-bottom:.65rem;
  color:#ffd98c;
}
.lore-story-text{
  max-width:78ch;
}
.lore-story-text p{
  margin:.7rem 0 0;
  max-width:78ch;
  color:#fff3d7;
  font-size:clamp(1rem,1.08vw,1.08rem);
  line-height:1.68;
  text-wrap:pretty;
}
.lore-story-text p:first-of-type::first-letter{
  float:left;
  margin:.08em .12em 0 0;
  color:#ffd98c;
  font-family:var(--serif);
  font-size:4.1rem;
  line-height:.72;
  text-shadow:0 3px 14px rgba(0,0,0,.22);
}
.lore-gameplay-block{
  max-width:78ch;
  margin:1.15rem 0 0;
  padding:1rem 1.1rem;
  border-left:5px solid var(--gold);
  border-radius:10px;
  background:rgba(255,252,245,.96);
  color:#3a2119;
  box-shadow:0 8px 22px rgba(23,12,8,.12);
}
.lore-gameplay-block p{
  margin:0;
  max-width:74ch;
  color:#3a2119;
  font-size:clamp(.98rem,1.02vw,1.05rem);
  line-height:1.6;
  text-wrap:pretty;
}
.lore-gameplay-block p+p{
  margin-top:.75rem;
  padding-top:.75rem;
  border-top:1px solid rgba(111,58,38,.16);
}
@media (max-width:720px){
  .lore-callout--epic{padding:1rem;border-radius:14px}
  .lore-story-text p{line-height:1.56}
  .lore-gameplay-block{padding:.9rem .95rem}
}


/* Clean information layout: remove noisy card styling from basic rule content while keeping Ability Cards as cards */
.summary-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  margin:1rem 0 1.15rem;
  max-width:78ch;
  border-top:1px solid rgba(62,31,20,.14);
  border-bottom:1px solid rgba(62,31,20,.14);
}
.summary-grid .mini-card{
  display:grid;
  grid-template-columns:minmax(8rem,13rem) 1fr;
  gap:1rem;
  align-items:start;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:.82rem 0;
  border-bottom:1px solid rgba(62,31,20,.1);
}
.summary-grid .mini-card:last-child{border-bottom:0}
.summary-grid .mini-card h3{
  margin:0;
  font:760 1.05rem/1.2 var(--serif);
  color:#2a120b;
}
.summary-grid .mini-card p{margin:0;line-height:1.55;color:#4e382e}

.play-flow{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:.9rem;
  margin:1.15rem 0 1.25rem;
  padding:.95rem 0;
  border-top:1px solid rgba(62,31,20,.14);
  border-bottom:1px solid rgba(62,31,20,.14);
}
.play-flow article{
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:0;
  min-height:0;
  display:grid;
  gap:.42rem;
  align-content:start;
}
.play-flow img{
  width:100%;
  aspect-ratio:1.55/1;
  object-fit:cover;
  border-radius:8px;
  border:1px solid rgba(62,31,20,.12);
  background:#f2e1c9;
}
.play-flow strong{font:800 .98rem/1.1 var(--serif);color:#2a120b}
.play-flow span{font-size:.84rem;line-height:1.35;color:#684d40}

.setup-ribbon{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:.7rem;
  margin:1rem 0 1.35rem;
  padding:.85rem 0;
  border-top:1px solid rgba(62,31,20,.14);
  border-bottom:1px solid rgba(62,31,20,.14);
}
.setup-ribbon span{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:start;
  gap:.5rem;
  background:transparent;
  border:0;
  border-radius:0;
  padding:0;
  box-shadow:none;
  color:#3d281f;
  font-weight:850;
  line-height:1.3;
}
.setup-ribbon b{
  display:inline-grid;
  place-items:center;
  width:1.55rem;
  height:1.55rem;
  border-radius:50%;
  background:#3a2119;
  color:#fff8e7;
  font-size:.78rem;
  box-shadow:none;
}

.stat-card,.unit-card{
  background:transparent;
  border:0;
  border-left:3px solid rgba(128,44,33,.28);
  border-radius:0;
  box-shadow:none;
  padding:.25rem 0 .3rem .85rem;
}
.stat-card span{margin-bottom:.15rem}
.stat-card strong,.unit-card h4{margin:0 0 .15rem;color:#2a120b}
.stat-card p,.unit-card p{line-height:1.48;color:#4f3a31}
.stat-grid,.unit-grid{gap:1.15rem 1.35rem}

.rule-figure{
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:0;
}
.rule-figure img{
  border-radius:10px;
  border:1px solid rgba(62,31,20,.12);
  box-shadow:0 8px 22px rgba(40,18,10,.08);
}
.rule-figure figcaption{
  padding:0 .15rem;
  color:#5b4538;
}

.warriors-grid .mini-card{
  background:transparent;
  border:0;
  border-left:3px solid rgba(128,44,33,.24);
  border-radius:0;
  box-shadow:none;
  padding:.15rem 0 .2rem .85rem;
}
.warriors-grid .mini-card h3{font-size:1.12rem;margin:0 0 .15rem}
.warriors-grid .mini-card p{margin:0;color:#4f3a31;line-height:1.45}

@media (max-width:1050px){
  .play-flow,.setup-ribbon{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:720px){
  .summary-grid .mini-card{grid-template-columns:1fr;gap:.2rem}
  .play-flow,.setup-ribbon{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .play-flow,.setup-ribbon{grid-template-columns:1fr}
}

/* Plain text pass: remove remaining card/box treatments from basic information */
.clean-list{
  display:block;
  list-style:disc;
  margin:.55rem 0 1.15rem 1.25rem;
  padding:0;
  max-width:78ch;
}
.clean-list li{
  position:static;
  padding:.18rem 0 .28rem 0;
  margin:0 0 .16rem 0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  line-height:1.55;
}
.clean-list li:before{content:none!important;display:none!important}
.steps{
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:.25rem 0 .25rem 1.45rem;
}
.steps li{margin:.3rem 0;line-height:1.5}
.rule-line{
  background:transparent;
  border-radius:0;
  border-left:3px solid rgba(128,44,33,.32);
  padding:.25rem 0 .3rem .75rem;
}
/* Keep the Ability Card index visually distinct; strip basic rule cards only */
.prose .mini-card:not(.ability-card),
.prose .stat-card,
.prose .unit-card{
  background:transparent;
  border-top:0;
  border-right:0;
  border-bottom:0;
  border-radius:0;
  box-shadow:none;
}
@media (max-width:640px){
  .clean-list{margin-left:1.1rem}.clean-list li{padding:.16rem 0 .24rem 0}
}

/* Separate gameplay text from the lore panel */
.gameplay-premise-section{
  margin-top:.9rem;
}
.gameplay-premise-copy{
  max-width:78ch;
}
.gameplay-premise-copy p{
  margin:0;
  color:#3a2119;
  font-size:clamp(1rem,1.05vw,1.06rem);
  line-height:1.62;
  text-wrap:pretty;
}
.gameplay-premise-copy p+p{
  margin-top:1rem;
  padding-top:.9rem;
  border-top:1px solid rgba(111,58,38,.16);
}

/* Clear Warrior type separation without turning the content into cards */
.prose h3#keeper,
.prose h3#minions,
.prose h3#guardian{
  margin:2.45rem 0 .65rem;
  padding-top:1.05rem;
  border-top:2px solid rgba(128,44,33,.26);
  font:760 clamp(1.65rem,2.5vw,2.15rem)/1.05 var(--serif);
  letter-spacing:-.015em;
  color:#2a120b;
}
.prose h3#keeper:first-of-type{margin-top:2rem}
.prose h3#keeper::before,
.prose h3#minions::before,
.prose h3#guardian::before{
  content:"Warrior Type";
  display:block;
  margin-bottom:.22rem;
  font:900 .64rem/1 var(--sans);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--blood);
}
.minion-reminder{margin-top:1.1rem;margin-bottom:1.45rem}
