@font-face{font-family:Mr Eaves Small Caps;src:url(/fonts/MrEavesSmallCaps.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Bookinsanity;src:url(/fonts/Bookinsanity.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Bookinsanity;src:url(/fonts/BookinsanityBold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Scaly Sans;src:url(/fonts/ScalySans.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Scaly Sans;src:url(/fonts/ScalySansBold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--surface-base: #0e0703;--surface-elevated: #1d0f05;--surface-parchment: #f4e4c1;--surface-parchment-aged: #e8d5a3;--surface-overlay: rgba(8, 4, 1, .82);--surface-scroll: #14100a;--candle-glow: rgba(255, 180, 100, .12);--text-parchment-primary: #1a1410;--text-parchment-muted: #58170d;--text-dark-primary: #e2cda0;--text-dark-muted: #9d8e72;--text-dark-heading: #e8d5a3;--text-scroll: #e2cda0;--text-scroll-muted: #9d8e72;--text-dim: #6f6249;--colour-maroon: #58170d;--colour-maroon-light: #7a2b15;--colour-gold: #b9862e;--colour-gold-on-light: #7a5c00;--gold-bright: #d9a84a;--gold-deep: #6e4e18;--colour-success: #2d6a30;--colour-danger: #8b1a1a;--parchment: #f1dfb7;--parchment-warm: #e8cf98;--parchment-aged: #d9b271;--border-dark: #2a1d0d;--border-scroll: rgba(217, 168, 74, .3);--border-parchment: #c9b18a;--font-display: "Uncial Antiqua", serif;--font-accent: "Cormorant Garamond", serif;--font-weathered: "IM Fell DW Pica", serif;--font-heading: "Cinzel", "Mr Eaves Small Caps", serif;--font-body: "EB Garamond", "Bookinsanity", "Book Antiqua", Palatino, Georgia, serif;--font-stat: "JetBrains Mono", "Scaly Sans", "Segoe UI", Calibri, Arial, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-card: 0 2px 8px rgba(0, 0, 0, .3);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .6);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .35s ease;--surface-parchment-live: #d9b271;--ink-primary: #1a1410;--ink-secondary: #4a3824;--ink-tertiary: #6f563a;--ink-heading: #58170d;--ink-accent: #7a2b15;--rule-ink: rgba(26, 20, 16, .35);--rule-ink-heavy: rgba(26, 20, 16, .55);--stat-box-fill: rgba(244, 228, 193, .55);--stat-box-border: #6f563a;--parchment-inner-shadow: inset 0 0 60px rgba(74, 44, 20, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{background-color:var(--surface-base);color:var(--text-dark-primary);font-family:var(--font-body);font-size:1rem;line-height:1.6;min-height:100dvh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 30%,rgba(255,180,100,.12) 0%,transparent 55%),radial-gradient(ellipse at 20% 90%,rgba(122,50,10,.18) 0%,transparent 45%),linear-gradient(180deg,#1d0f05,#0e0703);pointer-events:none;z-index:0}@keyframes flicker{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.85;filter:brightness(1.15)}72%{opacity:.92;filter:brightness(.9)}}.flicker{animation:flicker 4.5s ease-in-out infinite}#root{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0a0502}::-webkit-scrollbar-thumb{background:var(--gold-deep);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--colour-gold)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-dark-heading);line-height:1.2;letter-spacing:.04em}p{max-width:70ch}button{cursor:pointer;border:none;background:none;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.character-creation{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-6) var(--space-4);background-color:var(--surface-base)}.character-creation__panel{width:100%;max-width:520px;background-color:var(--surface-parchment);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);overflow:hidden;display:flex;flex-direction:column}.character-creation__header{position:relative;text-align:center;border-bottom:3px solid var(--colour-gold);overflow:hidden}.character-creation__hero-image{position:relative;height:240px;overflow:hidden}.character-creation__hero-img{display:block;width:100%;height:100%;object-fit:cover;object-position:center center}.character-creation__hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0000001a,#1a080499 85%,#1a0804e6)}.character-creation__header-content{padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,var(--colour-maroon) 0%,#3a0f06 100%)}.character-creation__title{font-family:var(--font-heading);font-size:1.75rem;color:var(--surface-parchment);letter-spacing:.1em;margin-bottom:var(--space-2)}.character-creation__subtitle{font-family:var(--font-body);font-size:.875rem;color:#f4e4c1b3;font-style:italic;max-width:none}.character-creation__form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.character-creation__field{display:flex;flex-direction:column;gap:var(--space-2)}.character-creation__label{font-family:var(--font-stat);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--colour-gold-on-light)}.character-creation__input,.character-creation__select{padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);color:var(--text-parchment-primary);font-family:var(--font-body);font-size:.9375rem;transition:border-color var(--transition-fast)}.character-creation__input:focus,.character-creation__select:focus{border-color:var(--colour-maroon);outline:none;box-shadow:0 0 0 2px #58170d26}.character-creation__roll-btn{padding:var(--space-2) var(--space-6);background-color:var(--surface-elevated);color:var(--colour-gold);border:1px solid var(--colour-gold);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:1rem;letter-spacing:.06em;transition:background-color var(--transition-fast),color var(--transition-fast);align-self:flex-start}.character-creation__roll-btn:hover:not(:disabled){background-color:var(--colour-gold);color:var(--surface-base)}.character-creation__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);padding:var(--space-4);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-md)}.character-creation__stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.character-creation__stat-label{font-family:var(--font-stat);font-size:.625rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-parchment-muted)}.character-creation__stat-value{font-family:var(--font-heading);font-size:1.5rem;color:var(--text-parchment-primary);line-height:1}.character-creation__stat-modifier{font-family:var(--font-stat);font-size:.8125rem;font-weight:700;color:var(--colour-gold-on-light)}.character-creation__error{font-family:var(--font-stat);font-size:.875rem;color:var(--colour-danger);max-width:none}.character-creation__confirm-btn{padding:var(--space-3) var(--space-6);background-color:var(--colour-maroon);color:var(--surface-parchment);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:1.125rem;letter-spacing:.08em;transition:background-color var(--transition-fast),transform var(--transition-fast)}.character-creation__confirm-btn:hover:not(:disabled){background-color:var(--colour-maroon-light)}.character-creation__confirm-btn:active:not(:disabled){transform:translateY(1px)}.character-creation__footer{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-family:var(--font-stat);font-size:.6875rem;color:var(--text-parchment-muted);border-top:1px solid var(--border-parchment);background-color:var(--surface-parchment-aged);opacity:.8}.character-creation__footer-sep{opacity:.4;-webkit-user-select:none;user-select:none}.character-creation__class-locked{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--surface-parchment-aged);border:1px dashed var(--border-parchment);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.875rem;color:var(--text-parchment-muted);font-style:italic}.character-creation__class-locked-icon{font-style:normal;opacity:.5;flex-shrink:0}.character-creation__recommendations{margin-top:var(--space-3);padding:var(--space-4);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-md)}.character-creation__recommendations-heading{font-family:var(--font-stat);font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--colour-gold-on-light);margin-bottom:var(--space-3)}.character-creation__recommendations-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.character-creation__recommendation-btn{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;width:100%;padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);text-align:left;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.character-creation__recommendation-btn:hover{border-color:var(--colour-maroon);background-color:#f9f0dc}.character-creation__recommendation-btn:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}.character-creation__recommendation-btn[aria-pressed=true]{border-color:var(--colour-maroon);background-color:#58170d0f;box-shadow:inset 0 0 0 1px var(--colour-maroon)}.character-creation__recommendation--excellent .character-creation__recommendation-btn{border-color:var(--colour-gold);background-color:#fdf6e0}.character-creation__recommendation--excellent .character-creation__recommendation-btn:hover{border-color:var(--colour-gold-on-light);background-color:#fef2c0}.character-creation__recommendation--excellent .character-creation__recommendation-btn[aria-pressed=true]{border-color:var(--colour-gold-on-light);box-shadow:inset 0 0 0 1px var(--colour-gold-on-light),0 0 0 2px #d4a01733}.character-creation__recommendation-name{grid-column:1;grid-row:1;display:flex;align-items:center;gap:var(--space-1);font-family:var(--font-heading);font-size:.9375rem;color:var(--text-parchment-primary)}.character-creation__recommendation-star{color:var(--colour-gold);font-size:.875rem;line-height:1}.character-creation__recommendation-detail{grid-column:2;grid-row:1 / 3;align-self:center;font-family:var(--font-heading);font-size:1rem;color:var(--colour-gold-on-light);padding-left:var(--space-3);white-space:nowrap}.character-creation__recommendation-tier{grid-column:1;grid-row:2;font-family:var(--font-stat);font-size:.6875rem;color:var(--text-parchment-muted);letter-spacing:.04em}.character-creation__recommendation--excellent .character-creation__recommendation-tier{color:var(--colour-gold-on-light);font-weight:700}.character-creation__stat-racial-bonus{display:inline-block;font-family:var(--font-stat);font-size:.625rem;font-weight:700;letter-spacing:.04em;color:var(--ink-heading);background-color:#58170d14;border:1px solid rgba(88,23,13,.3);border-radius:var(--radius-sm);padding:0 var(--space-1);line-height:1.4;transition:color var(--transition-fast),background-color var(--transition-fast)}.character-creation__half-elf-picks{padding:var(--space-3) var(--space-4);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-md);gap:var(--space-3)}.character-creation__half-elf-hint{font-family:var(--font-body);font-size:.8125rem;font-style:italic;color:var(--text-parchment-muted);line-height:1.45;max-width:none}.character-creation__half-elf-selects{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.character-creation__half-elf-select-wrap{display:flex;flex-direction:column;gap:var(--space-1)}.character-creation__half-elf-select-label{font-family:var(--font-stat);font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--colour-gold-on-light)}.character-creation__alignment-section{display:flex;flex-direction:column;gap:var(--space-2)}.character-creation__alignment-heading{font-family:var(--font-stat);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--colour-gold-on-light);margin:0}.character-creation__alignment-intro{font-family:var(--font-body);font-size:.8125rem;font-style:italic;color:var(--text-parchment-muted);line-height:1.45;max-width:none;margin:0}.character-creation__alignment-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.character-creation__alignment-card{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);text-align:left;font-family:var(--font-stat);font-size:.75rem;font-weight:700;letter-spacing:.04em;color:var(--text-parchment-primary);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.character-creation__alignment-card:hover{border-color:var(--colour-maroon);background-color:#f9f0dc}.character-creation__alignment-card:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}.character-creation__alignment-card--selected{border-color:var(--colour-maroon);background-color:#58170d12;box-shadow:inset 0 0 0 1px var(--colour-maroon)}.character-creation__alignment-desc{display:block;font-family:var(--font-body);font-size:.6875rem;font-weight:400;font-style:italic;color:var(--text-parchment-muted);line-height:1.4;letter-spacing:0}@media (max-width: 639px){.character-creation__alignment-grid{grid-template-columns:1fr}}.character-creation__assign-section{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-md)}.character-creation__assign-heading{font-family:var(--font-stat);font-size:.75rem;font-style:italic;color:var(--text-parchment-muted);margin:0 0 var(--space-2);line-height:1.4;max-width:none}.character-creation__pool{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;margin:0;padding:0}.character-creation__pool-card{display:flex;align-items:center;justify-content:center;min-width:3.5rem;min-height:3.5rem;padding:var(--space-2);background-color:var(--surface-parchment);border:2px solid var(--border-parchment);border-radius:var(--radius-md);font-family:var(--font-heading);font-size:1.375rem;color:var(--text-parchment-primary);cursor:pointer;touch-action:manipulation;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast),background-color var(--transition-fast)}.character-creation__pool-card:hover:not(:disabled){border-color:var(--colour-maroon);background-color:#fdf6e0}.character-creation__pool-card:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}.character-creation__pool-card:active:not(:disabled){transform:scale(.95)}.character-creation__pool-card--selected,.character-creation__pool-card[aria-pressed=true]{border-color:var(--colour-gold-on-light);background-color:#d4a0171f;box-shadow:0 0 0 3px #d4a0174d;transform:translateY(-2px)}.character-creation__slots{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);list-style:none;margin:0;padding:0}.character-creation__slot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:3.5rem;min-height:3.5rem;padding:var(--space-2) var(--space-1);border:2px solid var(--border-parchment);border-radius:var(--radius-md);background-color:var(--surface-parchment);cursor:pointer;touch-action:manipulation;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.character-creation__slot:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}.character-creation__slot--filled{border-color:var(--colour-maroon);background-color:#58170d0a}.character-creation__slot--filled:hover{border-color:var(--colour-maroon-light);background-color:#58170d14}.character-creation__slot--empty:disabled{opacity:.45;cursor:not-allowed;background-color:var(--surface-parchment-aged);border-color:var(--border-parchment)}.character-creation__slot--target{outline:2px dashed var(--colour-gold-on-light);outline-offset:-2px}.character-creation__slot--target.character-creation__slot--empty:not(:disabled){background-color:#d4a0170f}.character-creation__slot--target:hover{border-color:var(--colour-gold-on-light);background-color:#d4a0171a}.character-creation__slot-label{font-family:var(--font-stat);font-size:.5625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-parchment-muted);line-height:1}.character-creation__slot-value{font-family:var(--font-heading);font-size:1.25rem;color:var(--text-parchment-primary);line-height:1}.character-creation__slot--empty .character-creation__slot-value{color:var(--border-parchment)}.character-creation__slot-racial-bonus{display:inline-block;font-family:var(--font-stat);font-size:.5625rem;font-weight:700;letter-spacing:.04em;color:var(--ink-heading);background-color:#58170d14;border:1px solid rgba(88,23,13,.3);border-radius:var(--radius-sm);padding:0 3px;line-height:1.4}.character-creation__slot-modifier{font-family:var(--font-stat);font-size:.625rem;font-weight:700;color:var(--colour-gold-on-light);line-height:1}.character-creation__assign-controls{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--border-parchment)}.character-creation__assign-reset{padding:var(--space-1) var(--space-3);background:none;border:1px solid var(--border-parchment);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.6875rem;font-weight:700;letter-spacing:.06em;color:var(--colour-danger);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.character-creation__assign-reset:hover:not(:disabled){border-color:var(--colour-danger);background-color:#8b1a1a0d}.character-creation__assign-reset:disabled{opacity:.35;cursor:not-allowed}.character-creation__assign-reset:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}.character-creation__assign-status{font-family:var(--font-stat);font-size:.6875rem;color:var(--text-parchment-muted);letter-spacing:.04em}@media (max-width: 640px){.character-creation__pool-card{min-width:3rem;min-height:3rem;font-size:1.125rem}.character-creation__slot{min-width:3rem;min-height:3rem}.character-creation__slot-value{font-size:1rem}}@media (prefers-reduced-motion: reduce){.character-creation__pool-card,.character-creation__pool-card--selected,.character-creation__pool-card[aria-pressed=true]{transform:none;transition:border-color var(--transition-fast),background-color var(--transition-fast)}}.character-creation__reset-btn{background:none;border:none;padding:2px 4px;font-family:var(--font-stat);font-size:.75rem;color:var(--colour-danger);cursor:pointer;text-decoration:underline;text-underline-offset:2px;opacity:.8;transition:opacity .15s,color .15s}.character-creation__reset-btn:hover{opacity:1;color:var(--colour-danger)}.character-creation__reset-btn:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px;border-radius:2px;opacity:1}.module-selection{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);background-color:var(--surface-parchment);border:1px solid var(--border-parchment);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.module-selection--inline{padding:var(--space-4) 0;background:transparent;border:none;box-shadow:none;border-radius:0;border-top:1px solid var(--border-parchment)}.module-selection__heading{font-family:var(--font-heading);font-size:1.125rem;color:var(--ink-heading);letter-spacing:.06em;text-transform:uppercase;margin:0}.module-selection__intro{font-family:var(--font-body);font-size:.9375rem;line-height:1.55;color:var(--ink-secondary);max-width:58ch;margin:0}.module-selection__modules{display:flex;flex-direction:column;gap:var(--space-3)}@media (min-width: 560px){.module-selection__modules{flex-direction:row}}.module-selection__module-card{display:flex;align-items:flex-start;gap:var(--space-3);flex:1;padding:var(--space-4);background-color:var(--surface-parchment-aged);border:2px solid var(--border-parchment);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.module-selection__module-card:hover{border-color:var(--ink-tertiary);background-color:#edddb6}.module-selection__module-card--selected{border-color:var(--colour-maroon);background-color:#58170d0f;box-shadow:0 0 0 1px var(--colour-maroon)}.module-selection__module-card:focus-within{outline:2px solid var(--colour-gold);outline-offset:2px}.module-selection__checkbox{flex-shrink:0;margin-top:2px;width:1.125rem;height:1.125rem;accent-color:var(--colour-maroon);cursor:pointer}.module-selection__module-body{display:flex;flex-direction:column;gap:var(--space-1)}.module-selection__module-name{font-family:var(--font-heading);font-size:1rem;color:var(--ink-heading);letter-spacing:.05em;text-transform:uppercase}.module-selection__module-code{font-family:var(--font-stat);font-size:.75rem;color:var(--ink-tertiary);letter-spacing:.04em}.module-selection__module-desc{font-family:var(--font-body);font-size:.875rem;line-height:1.45;color:var(--ink-secondary);margin-top:var(--space-1)}.module-selection__depth-studies{padding:var(--space-4);background-color:#f4e4c166;border:1px solid var(--border-parchment);border-left:3px solid var(--colour-maroon);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-3);animation:depth-reveal var(--transition-base) ease forwards}@keyframes depth-reveal{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.module-selection__depth-studies{animation:none}}.module-selection__depth-heading,.module-selection__depth-subheading{font-family:var(--font-body);font-size:.875rem;line-height:1.5;color:var(--ink-secondary);margin:0}.module-selection__depth-subheading{font-weight:700;color:var(--ink-primary)}.module-selection__depth-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);margin:0;padding:0}.module-selection__depth-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.module-selection__depth-label:hover .module-selection__depth-text{color:var(--colour-maroon)}.module-selection__depth-checkbox{width:1rem;height:1rem;flex-shrink:0;accent-color:var(--colour-maroon);cursor:pointer}.module-selection__depth-text{font-family:var(--font-body);font-size:.9375rem;color:var(--ink-primary);transition:color var(--transition-fast)}.module-selection__error{font-family:var(--font-stat);font-size:.875rem;color:var(--colour-danger);padding:var(--space-2) var(--space-3);background-color:#8b1a1a12;border:1px solid rgba(139,26,26,.25);border-radius:var(--radius-sm);margin:0}.module-selection__actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-2);border-top:1px solid var(--border-parchment)}.module-selection__back-btn{padding:var(--space-2) var(--space-6);background:transparent;border:1px solid var(--border-parchment);border-radius:var(--radius-sm);color:var(--ink-tertiary);font-family:var(--font-stat);font-size:.875rem;letter-spacing:.04em;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.module-selection__back-btn:hover{border-color:var(--ink-secondary);color:var(--ink-secondary)}.module-selection__continue-btn{padding:var(--space-2) var(--space-6);background-color:var(--colour-maroon);color:var(--surface-parchment);border:none;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.9375rem;letter-spacing:.05em;cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.module-selection__continue-btn:hover:not(:disabled){background-color:var(--colour-maroon-light)}.module-selection__continue-btn:disabled{opacity:.5;cursor:not-allowed}.module-selection__back-btn:focus-visible,.module-selection__continue-btn:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.dice-result{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:10px;padding:10px 18px;background:linear-gradient(180deg,#140a0466,#140a04cc);border-top:1px solid rgba(217,168,74,.15)}.dice-result__mode-badge{display:flex;align-items:center;justify-content:center}.dice-result__mode{display:inline-block;padding:2px 8px;border-radius:3px;font-family:"Cinzel",var(--font-heading),serif;font-size:.5625rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase}.dice-result__mode--normal{background-color:#2a1d0dcc;color:#6f6249;border:1px solid rgba(217,168,74,.15)}.dice-result__mode--advantage{background-color:#2d6a3033;color:#7ec882;border:1px solid rgba(45,106,48,.35)}.dice-result__mode--disadvantage{background-color:#8b1a1a33;color:#e08080;border:1px solid rgba(139,26,26,.35)}.dice-result__dice-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dice-result__die{display:flex;flex-direction:column;align-items:center;gap:3px}.dice-result__die-value{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:radial-gradient(circle at 32% 28%,#2a1d0d,#0a0502);border:1px solid rgba(217,168,74,.4);border-radius:6px;font-family:"Cinzel",var(--font-heading),serif;font-weight:600;font-size:.9375rem;color:var(--gold-bright);box-shadow:inset 0 1px 2px #ffdca033,0 2px 4px #00000080}.dice-result__die--kept .dice-result__die-value{border-color:var(--gold-bright);box-shadow:inset 0 1px 2px #ffdca059,0 2px 4px #00000080,0 0 16px #d9a84a8c}.dice-dropped .dice-result__die-value{opacity:.4;text-decoration:line-through;border-color:#2a1d0dcc;color:#6f6249;box-shadow:none}.dice-result__die-drop-label{font-family:"Cinzel",var(--font-heading),serif;font-size:.5rem;color:#6f6249;letter-spacing:.1em;text-transform:uppercase}.dice-result__modifier{display:flex;flex-direction:column;align-items:flex-start;font-family:"Cinzel",var(--font-heading),serif;font-size:.625rem;letter-spacing:.12em;color:#9d8e72;text-transform:uppercase}.dice-result__modifier-label{font-size:.5625rem;color:#6f6249;letter-spacing:.1em}.dice-result__modifier-value{font-size:.8125rem;font-weight:600;color:var(--gold-bright)}.dice-result__total-section{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.dice-result__total-label{font-family:"Cinzel",var(--font-heading),serif;font-size:.5rem;color:#6f6249;letter-spacing:.2em;text-transform:uppercase;text-align:right}.dice-result__total{margin-left:auto;font-family:"Cinzel",var(--font-heading),serif;font-size:1.625rem;font-weight:600;color:var(--gold-bright);text-shadow:0 0 14px rgba(217,168,74,.55);line-height:1;letter-spacing:.02em}.challenge-cta{margin:18px 4px;padding:16px;border-radius:6px;position:relative;background:linear-gradient(180deg,#1a0e04b3,#0e0703b3);border:1px solid rgba(217,168,74,.35);box-shadow:inset 0 0 20px #ffb46414,0 4px 12px #00000080;display:flex;align-items:center;gap:12px}.challenge-cta:before{content:"";position:absolute;left:30%;right:30%;top:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-bright),transparent);box-shadow:0 0 8px var(--gold-bright)}.challenge-cta:after{content:"";position:absolute;left:0;top:15%;bottom:15%;width:2px;background:linear-gradient(180deg,transparent,var(--gold-bright),transparent);border-radius:0 2px 2px 0}.challenge-cta__rune{width:44px;height:44px;flex-shrink:0;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 40% 35%,rgba(255,200,110,.18) 0%,transparent 60%),linear-gradient(135deg,#58170d,#2a0c04);border:1px solid rgba(217,168,74,.5);box-shadow:inset 0 0 10px #ffc88233,0 0 14px #d9a84a4d;font-family:Uncial Antiqua,serif;font-size:20px;color:var(--gold-bright);text-shadow:0 0 10px rgba(217,168,74,.8);animation:rune-pulse 3.5s ease-in-out infinite}@keyframes rune-pulse{0%,to{box-shadow:inset 0 0 10px #ffc88233,0 0 14px #d9a84a4d}50%{box-shadow:inset 0 0 14px #ffc88259,0 0 22px #d9a84a8c}}.challenge-cta__text{flex:1;min-width:0}.challenge-cta__heading{display:block;font-family:"Cinzel",var(--font-heading),serif;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:3px}.challenge-cta__description{font-family:"Cormorant Garamond",var(--font-accent),serif;font-style:italic;font-size:13px;color:#9d8e72;line-height:1.35}.challenge-cta__button{flex-shrink:0;background:linear-gradient(180deg,#7a2b15,#3a0f06);color:var(--gold-bright);border:1px solid var(--colour-gold);padding:8px 12px;border-radius:4px;font-family:"Cinzel",var(--font-heading),serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.challenge-cta__button:hover:not(:disabled){background:linear-gradient(180deg,#8f3319,#4a1408);box-shadow:0 0 12px #d9a84a4d}.challenge-cta__button:active:not(:disabled){transform:translateY(1px)}.challenge-cta__button:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}.challenge-cta__button:disabled{opacity:.55;cursor:not-allowed}.challenge-cta__label{display:inline-flex;align-items:center;gap:0}.challenge-cta__label-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.challenge-cta__label--loading{font-style:italic;letter-spacing:.04em}.challenge-cta__ellipsis{display:inline-block;animation:ellipsis-fade 1.4s ease-in-out infinite}@keyframes ellipsis-fade{0%,to{opacity:.4}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.challenge-cta__rune{animation:none}.challenge-cta__ellipsis{animation:none;opacity:1}}.narrative-panel{display:flex;flex-direction:column;height:100%;min-height:0;background:#0e0703;border-radius:var(--radius-lg);border:1px solid rgba(217,168,74,.2);box-shadow:inset 0 0 20px #ffb46414,0 4px 12px #00000080;overflow:hidden;position:relative}.narrative-panel:before{content:"";position:absolute;left:30%;right:30%;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-bright),transparent);box-shadow:0 0 8px var(--gold-bright);z-index:1;pointer-events:none}.narrative-panel__scroll{flex:1;min-height:0;overflow-y:auto;padding:20px 20px 4px;scroll-behavior:smooth;position:relative}.narrative-panel__scroll:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent 0%,rgba(217,168,74,.3) 8%,rgba(217,168,74,.3) 92%,transparent 100%);pointer-events:none}.narrative-panel__content{display:flex;flex-direction:column;gap:0}.narrative-panel__paragraph{font-family:EB Garamond,serif;font-size:15px;line-height:1.72;color:#e2cda0;margin:0 0 14px;max-width:70ch}.narrative-panel__paragraph+.narrative-panel__paragraph{text-indent:1.2em}.narrative-panel__paragraph--dropcap:first-letter{float:left;font-family:Uncial Antiqua,serif;font-size:3.6rem;line-height:.8;margin:4px 10px 0 0;padding:6px 8px 4px;color:var(--gold-bright);background:radial-gradient(circle at 40% 35%,rgba(255,200,110,.18) 0%,transparent 60%),linear-gradient(135deg,#58170d,#2a0c04);border:1px solid var(--colour-gold);box-shadow:inset 0 0 12px #ffc88240,0 2px 6px #0000008c;text-shadow:1px 1px 0 rgba(217,168,74,.3)}.narrative-panel__player-action{display:flex;align-items:baseline;gap:6px;padding:6px 10px;margin:12px 0;border-left:2px solid var(--gold-bright);font-family:Cormorant Garamond,serif;font-style:italic;font-size:13.5px;line-height:1.5;color:#c9b68a;max-width:65ch;text-indent:0}.narrative-panel__action-chevron{font-style:normal;color:var(--gold-bright);flex-shrink:0;line-height:1}.narrative-panel__loading{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);margin-top:var(--space-4);color:var(--text-dim, #6f6249);font-family:Cormorant Garamond,serif;font-size:.9375rem;font-style:italic}.narrative-panel__loading-dots{font-size:1.5rem;line-height:1;animation:pulse-dots 1.2s ease-in-out infinite;color:var(--gold-bright)}.narrative-panel__loading-text{opacity:.7}@keyframes pulse-dots{0%,to{opacity:.4}50%{opacity:1}}.narrative-panel__challenge-notice{padding:var(--space-2) var(--space-4);background-color:var(--colour-maroon);color:var(--parchment);font-family:Cinzel,serif;font-size:.8125rem;text-align:center;letter-spacing:.1em;text-transform:uppercase}.narrative-panel__dice-strip{display:flex;align-items:center;padding:10px 18px;background:linear-gradient(180deg,#0e070366,#0e0703cc);border-top:1px solid rgba(217,168,74,.15);animation:dice-strip-reveal var(--transition-base) ease forwards}@keyframes dice-strip-reveal{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.narrative-panel__dice-strip .dice-result{flex-direction:row;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-3);background-color:transparent;border:none;border-radius:0;box-shadow:none;min-width:0;width:100%}.narrative-panel__dice-strip .dice-result__total-section{flex-direction:row;align-items:center;gap:var(--space-2);padding-top:0;border-top:none;width:auto}.narrative-panel__dice-strip .dice-result__total-label{font-size:.625rem}.narrative-panel__dice-strip .dice-result__total{font-size:1.75rem}.narrative-panel__dice-strip .dice-result__die-value{width:2rem;height:2rem;font-size:1rem}.narrative-panel__dice-strip .dice-result__mode{font-size:.625rem;padding:2px var(--space-2)}.narrative-panel__dice-strip .dice-result__modifier-label{font-size:.6875rem}.narrative-panel__dice-strip .dice-result__modifier-value{font-size:.875rem}.narrative-panel__dice-strip .dice-result__die-drop-label{display:none}@media (prefers-reduced-motion: reduce){.narrative-panel__dice-strip{animation:none}}.narrative-panel__form{padding:10px 18px;border-top:1px solid rgba(217,168,74,.15);background:#00000080}.narrative-panel__input-row{display:flex;gap:var(--space-2)}.narrative-panel__input{flex:1;padding:10px 12px;background:#1a0e04cc;border:1px solid rgba(217,168,74,.3);border-radius:var(--radius-md);color:#e2cda0;font-family:EB Garamond,serif;font-style:italic;font-size:13.5px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.narrative-panel__input::placeholder{color:#6f6249}.narrative-panel__input:focus:not(:disabled){border-color:var(--gold-bright);box-shadow:0 0 0 2px #d9a84a26;outline:none}.narrative-panel__input:disabled{opacity:.55}.narrative-panel__submit{padding:9px 14px;background:linear-gradient(180deg,#7a2b15,#3a0f06);color:var(--gold-bright);border:1px solid var(--colour-gold);border-radius:var(--radius-md);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;box-shadow:inset 0 1px #ffc88233,0 2px 4px #0006;transition:background var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.narrative-panel__submit:hover:not(:disabled){background:linear-gradient(180deg,#8a3520,#4a1808)}.narrative-panel__submit:active:not(:disabled){transform:translateY(1px)}.narrative-panel__submit:disabled{opacity:.45}.narrative-panel__char-count{margin-top:var(--space-1);font-family:JetBrains Mono,monospace;font-size:.625rem;color:var(--text-dim, #6f6249);text-align:right;letter-spacing:.05em}@media (min-width: 1024px){.narrative-panel__scroll{font-size:1.0625rem}.narrative-panel__paragraph--dropcap:first-letter{font-size:4.2rem;margin:4px 12px 0 0;padding:7px 9px 5px}.narrative-panel__input-bar{padding:12px 24px 14px}.narrative-panel__input{font-size:.9375rem}}.scene-image{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:var(--radius-md);overflow:hidden;background-color:#100a04;border:1px solid rgba(217,168,74,.15);box-shadow:0 2px 8px #00000080,inset 0 0 20px #0000004d;margin-bottom:var(--space-4);flex-shrink:0}.scene-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 20%,rgba(255,190,120,.1) 0%,transparent 60%),linear-gradient(180deg,transparent 0%,rgba(14,7,3,.4) 45%,rgba(14,7,3,1) 100%);pointer-events:none;z-index:1}.scene-image__loc-strip{position:absolute;left:0;right:0;bottom:0;padding:8px 18px;z-index:2;display:flex;justify-content:space-between;align-items:center;pointer-events:none}.scene-image__loc-name{font-family:Cinzel,serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-bright);text-shadow:0 1px 2px rgba(0,0,0,.6)}.scene-image__loc-day{font-family:EB Garamond,serif;font-style:italic;font-size:10px;letter-spacing:.16em;color:#8a7a5c}.scene-image--shimmer:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 35%,rgba(217,168,74,.06) 50%,rgba(217,168,74,.03) 58%,transparent 65%);background-size:300% 100%;animation:scene-shimmer 2.2s ease-in-out infinite;z-index:3}@keyframes scene-shimmer{0%{background-position:200% center}to{background-position:-200% center}}.scene-image__loading-label{position:absolute;bottom:var(--space-3);left:50%;transform:translate(-50%);font-family:Cinzel,serif;font-size:.625rem;letter-spacing:.18em;text-transform:uppercase;color:#d9a84a66;white-space:nowrap;animation:scene-label-pulse 2.2s ease-in-out infinite;z-index:4}@keyframes scene-label-pulse{0%,to{opacity:.4}50%{opacity:.8}}.scene-image__img{display:block;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease}.scene-image__img--loaded{opacity:1}@media (prefers-reduced-motion: reduce){.scene-image--shimmer:before{animation:none;background:#d9a84a0a;background-size:unset}.scene-image__loading-label{animation:none;opacity:.6}.scene-image__img{transition:none}}.mcq-challenge{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px 18px}.mcq-challenge__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080401c7;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.mcq-challenge__panel{position:relative;z-index:1;width:100%;max-width:340px;max-height:90dvh;overflow-y:auto;border-radius:10px;overflow:hidden;box-shadow:0 20px 60px #000000a6,0 4px 12px #0006;display:flex;flex-direction:column}.mcq-challenge__header{padding:14px 18px;text-align:center;background:linear-gradient(180deg,var(--colour-maroon-light) 0%,var(--colour-maroon) 100%);border-bottom:2px solid var(--colour-gold)}.mcq-challenge__title{font-family:"Cinzel",var(--font-heading),serif;font-size:.8125rem;letter-spacing:.22em;color:var(--parchment);text-align:center;margin:0;text-transform:uppercase}.mcq-challenge__header-sub{display:block;font-family:"EB Garamond",var(--font-body),serif;font-style:italic;font-size:.5625rem;color:#ffe6b4a6;letter-spacing:.14em;margin-top:3px;text-transform:none}.mcq-challenge__body{background:radial-gradient(ellipse at 50% 10%,rgba(255,180,100,.06) 0%,transparent 70%),linear-gradient(180deg,#1a0e04d9,#0e0703f2);padding:18px;display:flex;flex-direction:column;gap:12px}.mcq-challenge__question{font-family:"EB Garamond",var(--font-body),serif;font-size:.96875rem;line-height:1.58;color:#e2cda0;margin:0}.mcq-challenge__options{list-style:none;display:flex;flex-direction:column;gap:8px;margin:0;padding:0}.mcq-challenge__option-item{display:contents}.mcq-challenge__option{display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px;background:#1a0e048c;border:1px solid rgba(217,168,74,.22);border-radius:6px;font-family:"EB Garamond",var(--font-body),serif;font-size:.84375rem;color:#e2cda0;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.mcq-challenge__option:hover:not(:disabled){border-color:var(--gold-bright);background:#d9a84a14;box-shadow:0 0 10px #d9a84a26}.mcq-challenge__option:active:not(:disabled){transform:scale(.99)}.mcq-challenge__option:disabled{cursor:default}.mcq-challenge__option--correct{background:#2d6a302e;border-color:#2d6a3099;color:#a8d9ac}.mcq-challenge__option--incorrect{background:#8b1a1a33;border-color:#8b1a1a99;color:#e08080}.mcq-challenge__option-letter{flex-shrink:0;display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:linear-gradient(180deg,var(--colour-maroon-light),var(--colour-maroon));color:var(--parchment);font-family:"Cinzel",var(--font-heading),serif;font-size:.625rem;letter-spacing:.04em;transition:background var(--transition-fast)}.mcq-challenge__option--correct .mcq-challenge__option-letter{background:linear-gradient(180deg,#3a8a3d,#2d6a30)}.mcq-challenge__option--incorrect .mcq-challenge__option-letter{background:linear-gradient(180deg,#a03030,var(--colour-danger))}.mcq-challenge__option-text{font-family:"EB Garamond",var(--font-body),serif;font-size:.84375rem;line-height:1.4}.mcq-challenge__feedback{padding:var(--space-4);border-radius:6px;border-left:3px solid;display:flex;flex-direction:column;gap:var(--space-3)}.mcq-challenge__feedback--correct{background:#2d6a3026;border-color:#2d6a3099;color:#a8d9ac}.mcq-challenge__feedback--wrong{background:#8b1a1a26;border-color:#8b1a1a99;color:#e08080}.mcq-challenge__feedback-text{font-family:"EB Garamond",var(--font-body),serif;font-size:.875rem;line-height:1.55}.mcq-challenge__modifier{display:flex;align-items:center;gap:var(--space-2);font-family:"Cinzel",var(--font-heading),serif;font-size:.75rem;font-weight:600}.mcq-challenge__modifier-badge{padding:2px 8px;border-radius:3px;background:#0000004d;letter-spacing:.1em;text-transform:uppercase;font-size:.6875rem}.mcq-challenge__modifier-bonus{font-size:.875rem;color:var(--gold-bright)}.mcq-challenge__xp-indicator{display:inline-block;align-self:flex-start;padding:2px 10px;background:#d9a84a1f;border:1px solid rgba(217,168,74,.4);border-radius:3px;color:var(--gold-bright);font-family:"Cinzel",var(--font-heading),serif;font-size:.75rem;font-weight:600;letter-spacing:.1em}.mcq-challenge__roll-btn{align-self:flex-end;background:linear-gradient(180deg,#7a2b15,#3a0f06);color:var(--gold-bright);border:1px solid var(--colour-gold);padding:8px 16px;border-radius:4px;font-family:"Cinzel",var(--font-heading),serif;font-size:.625rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.mcq-challenge__roll-btn:hover{background:linear-gradient(180deg,#8f3319,#4a1408);box-shadow:0 0 12px #d9a84a4d}.mcq-challenge__roll-btn:active{transform:translateY(1px)}.mcq-challenge__roll-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.mcq-challenge__rolling{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0 var(--space-2) 48px;align-self:flex-end}.mcq-challenge__rolling-dots{position:relative;display:inline-block;flex-shrink:0;width:8px;height:8px;border-radius:50%;background-color:var(--gold-bright);animation:mcq-dot-pulse 1.4s ease-in-out 0s infinite}.mcq-challenge__rolling-dots:before{content:"";position:absolute;top:0;left:16px;width:8px;height:8px;border-radius:50%;background-color:var(--gold-bright);animation:mcq-dot-pulse 1.4s ease-in-out .2s infinite}.mcq-challenge__rolling-dots:after{content:"";position:absolute;top:0;left:32px;width:8px;height:8px;border-radius:50%;background-color:var(--gold-bright);animation:mcq-dot-pulse 1.4s ease-in-out .4s infinite}@keyframes mcq-dot-pulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:.9}}.mcq-challenge__rolling-text{font-family:"EB Garamond",var(--font-body),serif;font-size:.875rem;font-style:italic;color:#9d8e72;line-height:1.4;animation:mcq-text-pulse 2s ease-in-out infinite}@keyframes mcq-text-pulse{0%,to{opacity:.7}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.mcq-challenge__rolling-dots,.mcq-challenge__rolling-dots:before,.mcq-challenge__rolling-dots:after,.mcq-challenge__rolling-text{animation:none;opacity:1}}.mcq-challenge__hard-bonus-badge{display:inline-flex;align-items:center;align-self:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#d9a84a1f;border:1px solid rgba(217,168,74,.4);border-radius:3px;color:var(--gold-bright);font-family:"Cinzel",var(--font-heading),serif;font-size:.75rem;font-weight:600;letter-spacing:.06em;animation:hard-badge-glow 2s ease-in-out infinite}@keyframes hard-badge-glow{0%,to{box-shadow:0 0 #d9a84a00}50%{box-shadow:0 0 10px #d9a84a66}}@media (prefers-reduced-motion: reduce){.mcq-challenge__hard-bonus-badge{animation:none}}.mcq-challenge__flag-area{display:flex;justify-content:flex-end}.mcq-challenge__flag-btn{padding:var(--space-1) var(--space-2);background:transparent;border:none;color:#6f6249;font-family:"Cinzel",var(--font-heading),serif;font-size:.625rem;letter-spacing:.1em;text-decoration:underline;text-underline-offset:2px;text-transform:uppercase;cursor:pointer;opacity:.65;transition:opacity var(--transition-fast),color var(--transition-fast)}.mcq-challenge__flag-btn:hover{opacity:1;color:#e08080}.mcq-challenge__flag-btn:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px;border-radius:var(--radius-sm)}@media (max-width: 480px){.mcq-challenge__panel{max-height:95dvh}.mcq-challenge__body{padding:14px}}.icon-bar{display:flex;flex-direction:row;justify-content:space-around;align-items:center;padding:10px 18px 14px;background:#0a0502;border-top:1px solid rgba(217,168,74,.12);margin:0;list-style:none;flex-shrink:0}.icon-bar__button{display:grid;place-items:center;width:44px;height:44px;background:transparent;border:1px solid rgba(217,168,74,.2);border-radius:12px;color:#9d8e72;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.icon-bar__button:hover,.icon-bar__button:focus-visible{color:var(--gold-bright);border-color:var(--gold-bright);background:#d9a84a0f;box-shadow:0 0 14px #d9a84a4d;outline:none}.icon-bar__button:active{opacity:.75;transform:scale(.96)}.icon-bar__button--active{border-color:var(--gold-bright);color:var(--gold-bright);background:#d9a84a0f;box-shadow:0 0 14px #d9a84a4d}.icon-bar__button svg{display:block}[role=dialog]:has(.character-sheet-page){width:760px!important}.character-sheet-page{position:relative;margin:calc(-1 * var(--space-6));padding:var(--space-6) var(--space-6) var(--space-8);border-radius:0 0 var(--radius-lg) var(--radius-lg);min-height:600px;background:var(--surface-parchment-live) url(/backgrounds/parchment.jpg) center / cover no-repeat;color:var(--ink-primary);overflow:hidden}.character-sheet-page:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:var(--parchment-inner-shadow);pointer-events:none;border-radius:inherit;z-index:0}.character-sheet-page>*{position:relative;z-index:1}.identity-band{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding-bottom:var(--space-4);border-bottom:2px solid var(--rule-ink-heavy);margin-bottom:var(--space-4)}.identity-band__info{flex:1;min-width:0}.identity-band__name{margin:0 0 var(--space-1);font-family:var(--font-heading);font-size:1.6rem;color:var(--ink-heading);letter-spacing:.04em;line-height:1.1;text-shadow:1px 1px 0 rgba(26,20,16,.15)}.identity-band__subtitle{margin:0;font-family:var(--font-body);font-size:.95rem;color:var(--ink-primary);line-height:1.4}.identity-band__alignment{margin:var(--space-1) 0 0;font-family:var(--font-body);font-size:.8125rem;font-style:italic;color:var(--ink-tertiary);line-height:1.3}.level-coin{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:var(--ink-heading);border:2px solid var(--ink-accent);box-shadow:0 2px 6px #1a141073,inset 0 1px 2px #f4e4c133;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0}.level-coin__number{font-family:var(--font-stat);font-size:1.25rem;font-weight:700;color:var(--surface-parchment-live);line-height:1}.level-coin__label{font-family:var(--font-heading);font-size:.45rem;letter-spacing:.12em;color:#d9b271bf;text-transform:uppercase;line-height:1;margin-top:1px}.xp-band{margin-bottom:var(--space-4)}.xp-band__labels{display:flex;justify-content:space-between;font-family:var(--font-stat);font-size:.75rem;color:var(--ink-secondary);margin-bottom:var(--space-1)}.xp-band__track{height:6px;background:var(--rule-ink);border-radius:var(--radius-sm);overflow:hidden}.xp-band__fill{height:100%;background:var(--ink-accent);border-radius:var(--radius-sm);transition:width var(--transition-slow)}.character-sheet-page__grid{display:grid;grid-template-columns:72px 1fr;gap:var(--space-4);align-items:start}.ability-strip{display:flex;flex-direction:column}.section-heading{margin:0 0 var(--space-3);font-family:var(--font-heading);font-size:.75rem;font-weight:400;letter-spacing:.14em;color:var(--ink-heading);text-transform:uppercase;text-shadow:none;border-bottom:1px solid var(--rule-ink);padding-bottom:var(--space-1)}.ability-score-stack{display:flex;flex-direction:column;gap:var(--space-2)}.ability-block{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--stat-box-fill);border:1px solid var(--stat-box-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);width:68px;min-height:56px;gap:1px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.ability-block__label{font-family:var(--font-heading);font-size:.6rem;letter-spacing:.1em;color:var(--ink-heading);text-transform:uppercase;line-height:1}.ability-block__label--hidden{display:block;width:auto;height:auto;overflow:visible;font-family:var(--font-heading);font-size:.6rem;letter-spacing:.1em;color:var(--ink-heading);text-transform:uppercase;line-height:1}.ability-block__label--hidden:before{content:attr(data-label)}.ability-block__modifier{font-family:var(--font-stat);font-size:1.1rem;font-weight:700;color:var(--ink-primary);line-height:1}.ability-block__modifier--hero{font-size:1.1rem;font-weight:700;color:var(--ink-primary)}.ability-block__modifier--hidden{display:inline-block;width:0;height:0;overflow:hidden}.ability-block__score{font-family:var(--font-stat);font-size:.65rem;color:var(--ink-secondary);line-height:1}.ability-block__score--subscript{font-size:.65rem;color:var(--ink-secondary)}.main-column{display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.combat-section{display:flex;flex-direction:column;gap:var(--space-2)}.hp-meter{display:flex;flex-direction:column;gap:var(--space-1)}.hp-meter--full-width{width:100%}.hp-meter__header{display:flex;justify-content:space-between;align-items:center}.hp-meter__label{font-family:var(--font-heading);font-size:.75rem;letter-spacing:.1em;color:var(--ink-heading);text-transform:uppercase}.hp-meter__value{display:inline-block;font-family:var(--font-stat);font-size:.8rem;color:var(--ink-secondary)}.hp-meter__value:after{content:attr(data-hp)}.hp-meter__track{height:10px;background:var(--rule-ink);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--stat-box-border)}.hp-meter__fill{height:100%;background:var(--colour-success);border-radius:var(--radius-sm);transition:width .6s cubic-bezier(.22,1,.36,1)}.hp-meter__fill--damage{animation:hp-damage-pulse .7s ease-out}.hp-meter__fill--heal{animation:hp-heal-pulse .7s ease-out}@keyframes hp-damage-pulse{0%{box-shadow:0 0 #dc2626e6;background-color:#dc2626}60%{box-shadow:0 0 14px 6px #dc262600}to{box-shadow:none;background-color:var(--colour-success)}}@keyframes hp-heal-pulse{0%{box-shadow:0 0 #22c55ee6;background-color:#4ade80}60%{box-shadow:0 0 14px 6px #22c55e00}to{box-shadow:none;background-color:var(--colour-success)}}.hp-meter--downed .hp-meter__value,.hp-value--downed{color:#7f1d1d;opacity:.8;font-style:italic}.hp-meter__unconscious{display:inline-block;font-family:var(--font-heading);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:#7f1d1d;opacity:.85;font-style:italic;padding:1px var(--space-2);border:1px solid rgba(127,29,29,.35);border-radius:var(--radius-sm);background:#dc262614}@media (prefers-reduced-motion: reduce){.hp-meter__fill{transition:none}.hp-meter__fill--damage,.hp-meter__fill--heal{animation:none}}.combat-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.combat-pill{display:flex;flex-direction:column;align-items:center;background:var(--stat-box-fill);border:1px solid var(--stat-box-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);min-width:56px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.combat-pill__value{font-family:var(--font-stat);font-size:1.1rem;font-weight:700;color:var(--ink-primary);line-height:1;min-height:1.3em}.combat-pill__value--attr:after{content:attr(data-value)}.footer-band__proficiency-value:after{content:attr(data-proficiency)}.combat-pill__label{font-family:var(--font-heading);font-size:.6rem;letter-spacing:.08em;color:var(--ink-heading);text-transform:uppercase;line-height:1;margin-top:2px}.saves-section{display:flex;flex-direction:column;gap:var(--space-2)}.saving-throws-pills{display:flex;gap:var(--space-2);flex-wrap:wrap}.save-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:var(--stat-box-fill);border:1px solid var(--stat-box-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);min-width:48px;font-family:var(--font-stat);font-size:.7rem;color:var(--ink-secondary);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.save-pill:before{content:attr(data-ability);font-family:var(--font-heading);font-size:.6rem;letter-spacing:.08em;color:var(--ink-heading);text-transform:uppercase;line-height:1}.save-pill:after{content:attr(data-mod);font-family:var(--font-stat);font-size:.75rem;font-weight:700;color:var(--ink-primary);line-height:1}.save-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--ink-heading);background:transparent;flex-shrink:0;display:block}.save-pill[data-proficient=true] .save-dot,.save-pill.proficient .save-dot{background:var(--ink-heading)}.saving-throws-list{display:flex;flex-direction:column;gap:var(--space-2)}.save-row{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-stat);font-size:.8rem;color:var(--ink-secondary);min-height:20px}.save-row:before{content:attr(data-label);font-family:var(--font-stat);font-size:.75rem;color:var(--ink-secondary);letter-spacing:.04em;min-width:28px}.save-row:after{content:attr(data-mod);font-family:var(--font-stat);font-size:.75rem;color:var(--ink-primary);font-weight:700}.save-row[data-proficient=true] .save-dot,.save-row.proficient .save-dot{background:var(--ink-heading)}.footer-band{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-3);border-top:1px solid var(--rule-ink);font-family:var(--font-stat);font-size:.85rem;color:var(--ink-secondary);flex-wrap:wrap;gap:var(--space-2)}.footer-band__item{display:flex;align-items:center;gap:var(--space-1)}.footer-band__label{color:var(--ink-secondary);font-size:.9rem}.skills-section--two-col{display:block}.skills-section--two-col .skills-list{grid-template-columns:1fr 1fr}.skills-group{margin-bottom:var(--space-3)}.skills-group:last-child{margin-bottom:0}.skills-group__heading{margin:0 0 var(--space-1);font-family:var(--font-heading);font-size:.65rem;font-weight:400;font-style:italic;letter-spacing:.08em;color:var(--ink-heading);text-transform:none;text-shadow:none}.skills-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1) var(--space-4)}.skill-row{display:flex;align-items:center;gap:var(--space-1);font-family:var(--font-stat);font-size:.75rem;color:var(--ink-secondary);min-height:16px}.skill-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--ink-heading);background:transparent;flex-shrink:0;display:block}.skill-row--proficient .skill-dot{background:var(--ink-heading)}.skill-row__name{flex:1;color:var(--ink-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skill-row__modifier{font-family:var(--font-stat);font-size:.75rem;font-weight:700;color:var(--ink-primary);text-align:right;min-width:2.2em}.skill-row__modifier--attr:after{content:attr(data-mod)}.skill-row--proficient .skill-row__name{color:var(--ink-primary)}@media (max-width: 640px){.character-sheet-page__grid{grid-template-columns:1fr;gap:var(--space-4)}.ability-strip{flex-direction:row}.ability-score-stack{flex-direction:row;flex-wrap:wrap;gap:var(--space-2);justify-content:center}.ability-block{width:calc(33.333% - var(--space-2));min-width:64px;max-width:96px}.saving-throws-pills{display:grid;grid-template-columns:repeat(3,1fr)}.skills-list,.skills-section--two-col .skills-list{grid-template-columns:1fr}}@media (max-width: 400px){.ability-block{width:calc(33.333% - var(--space-1));min-width:0}}.world-map-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--surface-overlay);z-index:1200}.world-map-modal{display:flex;flex-direction:column;background:var(--surface-elevated);border:2px solid var(--border-dark);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:95vw;height:90vh;max-width:1400px;outline:none;overflow:hidden}.world-map-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);background:var(--colour-maroon);border-bottom:2px solid var(--border-dark);flex-shrink:0}.world-map-modal__title{margin:0;font-family:var(--font-heading);font-size:1.25rem;color:var(--text-dark-heading);letter-spacing:.05em}.world-map-modal__close{background:none;border:none;color:var(--text-dark-heading);cursor:pointer;font-size:1.5rem;line-height:1;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:opacity var(--transition-fast)}.world-map-modal__close:hover{opacity:.7}.world-map-modal__close:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.world-map-modal__map-area{position:relative;flex:1;overflow:hidden;background:#0a0808}.map-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;filter:blur(4px) brightness(.8);z-index:1}.world-map-modal__map-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center;z-index:2;opacity:0;transition:opacity var(--transition-slow)}.world-map-modal__map-img--loaded{opacity:1}.world-map-modal__burg-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:3;pointer-events:none}.world-map-modal__burg-circle{fill:var(--colour-gold);fill-opacity:.75;stroke:var(--colour-maroon);stroke-width:1;cursor:pointer;pointer-events:all;transition:fill-opacity var(--transition-fast),r var(--transition-fast)}.world-map-modal__burg-circle:hover{fill-opacity:1;stroke-width:2}.world-map-modal__burg-circle:focus-visible{outline:none;stroke:var(--colour-gold);stroke-width:3}.world-map-modal__burg-circle--selected{fill:var(--colour-maroon-light);fill-opacity:1;stroke:var(--colour-gold);stroke-width:2.5}@media (prefers-reduced-motion: reduce){.world-map-modal__burg-circle{transition:none}}.world-map-modal__burg-label{font-family:var(--font-stat);font-size:8px;fill:var(--text-dark-primary);fill-opacity:.85;pointer-events:none;paint-order:stroke fill;stroke:#0a0808;stroke-width:2;stroke-linejoin:round}.world-map-modal__tooltip{position:fixed;z-index:1300;display:flex;flex-direction:column;gap:2px;background:var(--surface-parchment);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-card);pointer-events:none;min-width:140px}.world-map-modal__tooltip-name{font-family:var(--font-heading);font-size:.9rem;color:var(--ink-heading)}.world-map-modal__tooltip-state,.world-map-modal__tooltip-population{font-family:var(--font-stat);font-size:.75rem;color:var(--ink-secondary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.asi-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-6);background-color:var(--surface-parchment-aged);border-left:4px solid var(--colour-maroon);border-bottom:1px solid var(--border-parchment);flex-shrink:0}.asi-banner__text{font-family:var(--font-body);font-size:.9375rem;line-height:1.4;color:var(--text-parchment-primary);margin:0;flex:1;min-width:0}.asi-banner__apply-btn{padding:var(--space-2) var(--space-4);background-color:var(--colour-maroon);color:var(--surface-parchment);border:1px solid var(--colour-maroon);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.875rem;letter-spacing:.05em;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.asi-banner__apply-btn:hover{background-color:var(--colour-maroon-light);border-color:var(--colour-maroon-light)}.asi-banner__apply-btn:active{transform:translateY(1px)}.asi-banner__apply-btn:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}@media (max-width: 480px){.asi-banner{flex-direction:column;align-items:flex-start;padding:var(--space-3) var(--space-4)}.asi-banner__apply-btn{flex:1;text-align:center}}@media (prefers-reduced-motion: reduce){.asi-banner__apply-btn{transition:none}}.asi-picker{display:flex;flex-direction:column;gap:var(--space-6)}.asi-picker__modes{display:flex;flex-direction:row;gap:0;border:1px solid var(--border-parchment);border-radius:var(--radius-sm);padding:0;margin:0;overflow:hidden}.asi-picker__modes-legend{font-family:var(--font-stat);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-tertiary);padding:0 var(--space-1) var(--space-2) 0;float:left;width:100%;margin-bottom:var(--space-2)}.asi-picker__mode-label{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment);border-right:1px solid var(--border-parchment);cursor:pointer;font-family:var(--font-stat);font-size:.875rem;color:var(--ink-secondary);transition:background-color var(--transition-fast),color var(--transition-fast);-webkit-user-select:none;user-select:none}.asi-picker__mode-label:last-child{border-right:none}.asi-picker__mode-label:has(.asi-picker__mode-radio:checked){background-color:var(--colour-maroon);color:var(--surface-parchment)}.asi-picker__mode-label:hover:not(:has(.asi-picker__mode-radio:checked)){background-color:var(--surface-parchment-aged)}.asi-picker__mode-radio{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.asi-picker__mode-label:has(.asi-picker__mode-radio:focus-visible){outline:2px solid var(--colour-gold);outline-offset:-2px}.asi-picker__dual-selects{display:flex;gap:var(--space-3)}.asi-picker__dual-selects .asi-picker__select-group{flex:1;min-width:0}.asi-picker__select-group{display:flex;flex-direction:column;gap:var(--space-1)}.asi-picker__select-label{font-family:var(--font-stat);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-tertiary)}.asi-picker__select{width:100%;padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);color:var(--text-parchment-primary);font-family:var(--font-stat);font-size:.9375rem;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast);-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.asi-picker__select:hover{background-color:#dfc99a;border-color:var(--colour-gold-on-light)}.asi-picker__select:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:1px}.asi-picker__preview{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);background-color:var(--surface-parchment);border:1px solid var(--border-parchment);border-radius:var(--radius-sm);border-left:3px solid var(--colour-gold-on-light)}.asi-picker__preview-entry{margin:0;font-family:var(--font-stat);font-size:.9375rem;color:var(--ink-primary);letter-spacing:.02em}.asi-picker__preview-entry strong{display:inline-block;min-width:3rem;font-weight:700;color:var(--ink-heading)}.asi-picker__preview-entry span{font-variant-numeric:tabular-nums;letter-spacing:.01em}.asi-picker__forfeit{display:flex;flex-direction:column;gap:var(--space-4)}.asi-picker__forfeit-message{font-family:var(--font-body);font-size:.9375rem;line-height:1.6;color:var(--ink-tertiary);font-style:italic;margin:0}.asi-picker__actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--rule-ink)}.asi-picker__btn{padding:var(--space-2) var(--space-6);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.9375rem;letter-spacing:.05em;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast),transform var(--transition-fast)}.asi-picker__btn--primary{background-color:var(--colour-maroon);color:var(--surface-parchment);border:1px solid var(--colour-maroon)}.asi-picker__btn--primary:hover:not(:disabled){background-color:var(--colour-maroon-light);border-color:var(--colour-maroon-light)}.asi-picker__btn--primary:active:not(:disabled){transform:translateY(1px)}.asi-picker__btn--primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.asi-picker__btn--primary:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.asi-picker__btn--danger{background:transparent;color:var(--ink-tertiary);border:1px solid var(--border-parchment)}.asi-picker__btn--danger:hover{border-color:var(--colour-danger);color:var(--colour-danger);background-color:#8b1a1a0f}.asi-picker__btn--danger:active{transform:translateY(1px)}.asi-picker__btn--danger:focus-visible{outline:2px solid var(--colour-danger);outline-offset:2px}@media (max-width: 520px){.asi-picker__modes{flex-direction:column}.asi-picker__mode-label{border-right:none;border-bottom:1px solid var(--border-parchment);justify-content:flex-start}.asi-picker__mode-label:last-child{border-bottom:none}.asi-picker__dual-selects{flex-direction:column}}@media (prefers-reduced-motion: reduce){.asi-picker__btn,.asi-picker__select,.asi-picker__mode-label{transition:none}}.voice-picker{position:relative}.voice-picker__toggle{display:flex;align-items:center;gap:var(--space-2);background:none;border:none;padding:var(--space-1) 0;cursor:pointer;font-family:var(--font-heading);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dark-muted);transition:color var(--transition-fast)}.voice-picker__toggle:hover,.voice-picker__toggle--open{color:var(--text-dark-primary)}.voice-picker__toggle:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px;border-radius:var(--radius-sm)}.voice-picker__toggle-chevron{font-size:.5rem;line-height:1;transition:transform var(--transition-fast)}.voice-picker__loading,.voice-picker__error,.voice-picker__empty{font-family:var(--font-stat);font-size:.75rem;letter-spacing:.03em;padding:var(--space-2) var(--space-3)}.voice-picker__loading{color:var(--text-dark-muted);font-style:italic;animation:voice-picker-pulse 1.8s ease-in-out infinite}@keyframes voice-picker-pulse{0%,to{opacity:.5}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.voice-picker__loading{animation:none;opacity:.75}}.voice-picker__error{color:var(--colour-danger)}.voice-picker__empty{color:var(--text-dark-muted);font-style:italic}.voice-picker__list{list-style:none;position:absolute;top:calc(100% + var(--space-1));right:0;z-index:50;min-width:16rem;max-width:22rem;max-height:14rem;overflow-y:auto;background-color:var(--surface-elevated);border:1px solid var(--border-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);animation:voice-picker-reveal var(--transition-base) ease forwards}@keyframes voice-picker-reveal{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.voice-picker__list{animation:none}}.voice-picker__list::-webkit-scrollbar{width:5px}.voice-picker__list::-webkit-scrollbar-track{background:var(--surface-elevated)}.voice-picker__list::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:var(--radius-sm)}.voice-picker__item{border-bottom:1px solid var(--border-dark)}.voice-picker__item:last-child{border-bottom:none}.voice-picker__label{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;column-gap:var(--space-2);row-gap:1px;align-items:center;padding:var(--space-2) var(--space-3);cursor:pointer;transition:background-color var(--transition-fast)}.voice-picker__label:hover{background-color:#d4a0170f}.voice-picker__label--selected{background-color:#58170d2e;border-left:3px solid var(--colour-maroon)}.voice-picker__label--selected:hover{background-color:#58170d3d}.voice-picker__label:focus-within{outline:2px solid var(--colour-gold);outline-offset:-2px}.voice-picker__radio{grid-row:1 / 3;grid-column:1;-moz-appearance:none;appearance:none;-webkit-appearance:none;width:.875rem;height:.875rem;border:1px solid var(--border-dark);border-radius:50%;background-color:var(--surface-base);flex-shrink:0;transition:border-color var(--transition-fast),background-color var(--transition-fast);cursor:pointer}.voice-picker__radio:checked{border-color:var(--colour-maroon);background-color:var(--colour-maroon);box-shadow:inset 0 0 0 2px var(--surface-elevated)}.voice-picker__radio:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.voice-picker__name{grid-row:1;grid-column:2;font-family:var(--font-stat);font-size:.8125rem;font-weight:700;color:var(--text-dark-primary);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-picker__label--selected .voice-picker__name{color:var(--text-dark-heading)}.voice-picker__pill{grid-row:1;grid-column:3;display:inline-flex;align-items:center;padding:1px var(--space-2);background-color:#9a8b7226;border:1px solid rgba(154,139,114,.25);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.625rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dark-muted);white-space:nowrap}.voice-picker__label--selected .voice-picker__pill{background-color:#58170d33;border-color:#58170d66;color:#c88070}.voice-picker__description{grid-row:2;grid-column:2 / 4;font-family:var(--font-stat);font-size:.6875rem;color:var(--text-dark-muted);letter-spacing:.02em;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 480px){.voice-picker__list{position:fixed;top:auto;bottom:var(--space-4);left:var(--space-4);right:var(--space-4);max-width:none;min-width:0}}.dust-motes{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:2}.dust-mote{position:absolute;bottom:-4px;left:var(--x, 50%);width:var(--size, 2px);height:var(--size, 2px);border-radius:50%;background:var(--gold-bright);box-shadow:0 0 4px #d9a84ab3,0 0 8px #d9a84a66;opacity:0;animation:mote-drift var(--duration, 10s) var(--delay, 0s) ease-in-out infinite}@keyframes mote-drift{0%{opacity:0;transform:translateY(0) translate(0)}10%{opacity:.6}50%{opacity:.4;transform:translateY(-45vh) translate(var(--drift, 10px))}90%{opacity:.1}to{opacity:0;transform:translateY(-90vh) translate(calc(var(--drift, 10px) * 1.4))}}@media (prefers-reduced-motion: reduce){.dust-mote{animation:none;opacity:0}}.game-screen{display:flex;flex-direction:column;min-height:100dvh;position:relative;background:radial-gradient(ellipse at 50% 30%,rgba(255,180,100,.12) 0%,transparent 55%),radial-gradient(ellipse at 20% 90%,rgba(122,50,10,.18) 0%,transparent 45%),linear-gradient(180deg,#1d0f05,#0e0703)}.game-screen__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 18px;background:linear-gradient(180deg,#1d0f05,#140a03);border-bottom:1px solid rgba(217,168,74,.15);flex-shrink:0;position:sticky;top:0;z-index:10}.game-screen__title-group{display:flex;align-items:center;gap:var(--space-3)}.game-screen__title{font-family:Cinzel,serif;font-size:.75rem;font-weight:600;color:var(--gold-bright);letter-spacing:.22em;text-transform:uppercase;line-height:1}.game-screen__hp-chip{display:flex;align-items:center;gap:6px;margin-left:var(--space-3)}.game-screen__hp-ring{width:22px;height:22px;border-radius:50%;background:conic-gradient(#c85a3c var(--hp-pct, 72%),rgba(0,0,0,.4) 0);display:grid;place-items:center;flex-shrink:0}.game-screen__hp-ring-inner{width:14px;height:14px;border-radius:50%;background:#0e0703;display:grid;place-items:center;font-family:Cinzel,serif;font-size:7px;color:var(--gold-bright);line-height:1}.game-screen__hp-value{font-family:Cinzel,serif;font-weight:600;font-size:.6875rem;color:var(--gold-bright);letter-spacing:.08em}.game-screen__hp-label{font-family:EB Garamond,serif;font-style:italic;font-size:.625rem;color:var(--text-dim, #6f6249)}.game-screen__unconscious-badge{display:inline-flex;align-items:center;font-family:var(--font-stat);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#fca5a5;background:#dc262626;border:1px solid rgba(220,38,38,.4);border-radius:var(--radius-sm);padding:2px var(--space-2);animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.55}}@media (prefers-reduced-motion: reduce){.game-screen__unconscious-badge{animation:none}}.game-screen__header-actions{display:flex;align-items:center;gap:var(--space-2)}.game-screen__tts-controls{display:flex;align-items:center;gap:var(--space-1)}.tts-pause-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-2);background:transparent;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-size:.875rem;line-height:1;transition:border-color var(--transition-fast),color var(--transition-fast);cursor:pointer}.tts-pause-btn:hover{border-color:var(--gold-bright);color:var(--gold-bright)}.tts-pause-btn:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}.game-screen__save,.game-screen__logout{padding:var(--space-1) var(--space-3);background:transparent;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;transition:border-color var(--transition-fast),color var(--transition-fast);cursor:pointer}.game-screen__save:hover:not(:disabled){border-color:var(--gold-bright);color:var(--gold-bright)}.game-screen__save:disabled{opacity:.45;cursor:not-allowed}.game-screen__logout:hover{border-color:var(--gold-bright);color:var(--gold-bright)}.game-screen__quit-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background-color:#080401d1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:overlay-fade-in var(--transition-base) ease forwards}.game-screen__quit-dialog{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-8);max-width:26rem;width:90%;background:linear-gradient(180deg,#1d0f05,#140a03);border:1px solid rgba(217,168,74,.35);border-radius:var(--radius-md);box-shadow:0 20px 60px #000000a6,0 4px 12px #0006;text-align:center}.game-screen__quit-dialog-text{font-family:EB Garamond,serif;font-size:1rem;line-height:1.6;color:var(--text-dark-primary)}.game-screen__quit-dialog-actions{display:flex;justify-content:center;gap:var(--space-3)}.game-screen__quit-confirm{padding:var(--space-2) var(--space-6);background:linear-gradient(180deg,#7a2b15,#3a0f06);color:var(--gold-bright);border:1px solid var(--colour-gold);border-radius:var(--radius-sm);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.game-screen__quit-confirm:hover:not(:disabled){background:linear-gradient(180deg,#8a3520,#4a1808)}.game-screen__quit-confirm:disabled{opacity:.55;cursor:not-allowed}.game-screen__quit-cancel{padding:var(--space-2) var(--space-6);background:transparent;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.game-screen__quit-cancel:hover:not(:disabled){border-color:var(--gold-bright);color:var(--gold-bright)}.game-screen__quit-cancel:focus-visible,.game-screen__quit-confirm:focus-visible,.game-screen__save:focus-visible,.game-screen__logout:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}.game-screen__main{display:flex;flex:1;min-height:0;padding:var(--space-4) var(--space-4) 0}.game-screen__narrative-wrapper{flex:1;min-height:0;min-height:400px}.game-screen__starting{display:flex;align-items:center;justify-content:center;height:100%;min-height:300px}.game-screen__starting-text{font-family:var(--font-body);font-size:1.0625rem;color:var(--text-dark-muted);font-style:italic;letter-spacing:.02em;animation:session-pulse 2s ease-in-out infinite}@keyframes session-pulse{0%,to{opacity:.5}50%{opacity:1}}.game-screen__start-error{display:flex;align-items:center;justify-content:center;height:100%;min-height:300px;padding:var(--space-6);font-family:var(--font-body);font-size:1rem;color:var(--colour-danger);font-style:italic;text-align:center;line-height:1.6}.game-screen__challenge-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background-color:var(--surface-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:overlay-fade-in var(--transition-base) ease forwards}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.game-screen__challenge-overlay-panel{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);padding:var(--space-8);max-width:28rem;width:90%;background:linear-gradient(180deg,#1a0e04f2,#0e0703fa);border:1px solid rgba(217,168,74,.35);border-radius:var(--radius-md);box-shadow:0 20px 60px #000000a6,inset 0 0 20px #ffb46414;text-align:center}.game-screen__challenge-overlay-text{font-family:Cormorant Garamond,serif;font-style:italic;font-size:1.0625rem;color:var(--text-dark-primary);line-height:1.6}.game-screen__challenge-overlay-text--loading{color:var(--text-parchment-muted);font-style:italic;animation:session-pulse 2s ease-in-out infinite}.game-screen__challenge-overlay-skip{padding:var(--space-2) var(--space-6);background:transparent;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.game-screen__challenge-overlay-skip:hover{border-color:var(--gold-bright);color:var(--gold-bright);background-color:#d9a84a0f}.game-screen__challenge-overlay-skip:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}@media (prefers-reduced-motion: reduce){.game-screen__starting-text,.game-screen__challenge-overlay-text--loading{animation:none;opacity:.8}.game-screen__challenge-overlay{animation:none}}.game-screen__bottom-bar{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);background:#0a0502;border-top:1px solid rgba(217,168,74,.12);flex-shrink:0}.game-screen__world-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:none;border:1px solid rgba(217,168,74,.2);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:Cinzel,serif;font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.game-screen__world-btn:hover{color:var(--gold-bright);border-color:var(--gold-bright)}.game-screen__world-btn:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}@media (prefers-reduced-motion: reduce){.game-screen__world-btn{transition:none}}.game-screen__module-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:2px var(--space-2) 2px var(--space-3);background-color:#d9a84a14;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);font-family:Cinzel,serif;font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dark-muted)}.game-screen__difficulty-chip{display:inline-flex;align-items:center;padding:1px var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.6875rem;font-weight:700;letter-spacing:.05em;background-color:#9a8b7233;color:var(--text-dark-muted);border:1px solid rgba(154,139,114,.25)}.game-screen__difficulty-chip[data-band=mid]{background-color:#b4781426;color:#c8891a;border-color:#b478144d}.game-screen__difficulty-chip[data-band=high]{background-color:#d4a0172e;color:var(--colour-gold);border-color:#d4a01773}.game-screen__flag-btn{padding:var(--space-1) var(--space-3);background:transparent;border:1px solid rgba(139,26,26,.3);border-radius:var(--radius-sm);color:#8b1a1ab3;font-family:var(--font-stat);font-size:.75rem;letter-spacing:.04em;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.game-screen__flag-btn:hover{border-color:var(--colour-danger);color:var(--colour-danger);background-color:#8b1a1a0f}.game-screen__flag-btn:focus-visible{outline:2px solid var(--colour-danger);outline-offset:2px}.game-screen__flag-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;display:flex;align-items:center;justify-content:center;background-color:#080401d1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.game-screen__flag-dialog{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);max-width:22rem;width:90%;background:linear-gradient(180deg,#1d0f05,#140a03);border:1px solid rgba(217,168,74,.35);border-radius:var(--radius-md);box-shadow:0 20px 60px #000000a6}.game-screen__flag-dialog-heading{font-family:Cinzel,serif;font-size:.8125rem;color:var(--gold-bright);letter-spacing:.14em;text-transform:uppercase;margin:0}.game-screen__flag-dialog-label{font-family:EB Garamond,serif;font-style:italic;font-size:.875rem;color:var(--text-dark-muted);letter-spacing:.03em}.game-screen__flag-dialog-select{width:100%;padding:var(--space-2) var(--space-3);background:#1a0e04cc;border:1px solid rgba(217,168,74,.3);border-radius:var(--radius-sm);color:var(--text-dark-primary);font-family:EB Garamond,serif;font-size:.9375rem;cursor:pointer}.game-screen__flag-dialog-select:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}.game-screen__flag-dialog-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.game-screen__flag-dialog-confirm{padding:var(--space-2) var(--space-4);background:linear-gradient(180deg,#7a2b15,#3a0f06);color:var(--gold-bright);border:1px solid var(--colour-gold);border-radius:var(--radius-sm);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background-color var(--transition-fast)}.game-screen__flag-dialog-confirm:hover{background:linear-gradient(180deg,#8a3520,#4a1808)}.game-screen__flag-dialog-confirm:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}.game-screen__flag-dialog-cancel{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid rgba(217,168,74,.25);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:Cinzel,serif;font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.game-screen__flag-dialog-cancel:hover{border-color:var(--gold-bright);color:var(--gold-bright)}.game-screen__flag-dialog-cancel:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}@media (min-width: 1024px){.game-screen__narrative-wrapper{max-width:720px;margin:0 auto;width:100%;position:relative}.game-screen__narrative-wrapper:before,.game-screen__narrative-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0%,rgba(217,168,74,.25) 8%,rgba(217,168,74,.25) 92%,transparent 100%);pointer-events:none}.game-screen__narrative-wrapper:before{left:-32px}.game-screen__narrative-wrapper:after{right:-32px}.game-screen__main{padding:var(--space-4) clamp(var(--space-8),8vw,6rem) 0}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-6);background-color:var(--surface-base);background-image:radial-gradient(ellipse at center,var(--surface-elevated) 0%,var(--surface-base) 70%)}.error-boundary__panel{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);padding:var(--space-8);max-width:26rem;width:100%;background-color:var(--surface-parchment);border:2px solid var(--border-parchment);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);text-align:center;animation:boundary-rise .4s cubic-bezier(.22,1,.36,1) both}@keyframes boundary-rise{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.error-boundary__ornament{font-size:1.5rem;color:var(--colour-gold-on-light);line-height:1;opacity:.7}.error-boundary__title{font-family:var(--font-heading);font-size:1.5rem;color:var(--colour-maroon);letter-spacing:.06em;text-transform:uppercase;line-height:1.2;margin:0}.error-boundary__message{font-family:var(--font-body);font-size:1rem;color:var(--text-parchment-muted);line-height:1.6;font-style:italic;margin:0}.error-boundary__actions{display:flex;flex-direction:column;gap:var(--space-3);width:100%}.error-boundary__btn{width:100%;padding:var(--space-3) var(--space-6);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.875rem;letter-spacing:.04em;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.error-boundary__btn--primary{background-color:var(--colour-maroon);border:1px solid var(--colour-maroon);color:var(--surface-parchment)}.error-boundary__btn--primary:hover{background-color:var(--colour-maroon-light);border-color:var(--colour-maroon-light);box-shadow:0 2px 8px #58170d4d}.error-boundary__btn--secondary{background:transparent;border:1px solid var(--border-parchment);color:var(--text-parchment-muted)}.error-boundary__btn--secondary:hover{border-color:var(--colour-maroon);color:var(--colour-maroon);background-color:#58170d0f}.error-boundary__btn:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:2px}@media (min-width: 480px){.error-boundary__actions{flex-direction:row;justify-content:center}.error-boundary__btn{width:auto;min-width:10rem}}@media (prefers-reduced-motion: reduce){.error-boundary__panel{animation:none}}.app-session-menu{position:relative;display:flex;align-items:flex-end;justify-content:flex-start;min-height:100dvh;padding:54px 24px 44px;overflow:hidden}.app-session-menu:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url(/images/lorekeeper-intro.jpg) center / cover no-repeat;filter:contrast(1.05) brightness(.9);z-index:0}.app-session-menu:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 20%,rgba(255,190,120,.1) 0%,transparent 60%),linear-gradient(180deg,transparent 0%,rgba(14,7,3,.4) 45%,rgba(14,7,3,1) 100%);z-index:1}.app-session-menu__continue,.app-session-menu__no-session{position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;gap:0;width:100%;max-width:380px}.app-session-menu__brand{font-family:"Cinzel",var(--font-heading),serif;font-size:clamp(1.875rem,7vw,2.5rem);font-weight:700;letter-spacing:.16em;color:var(--gold-bright);margin:0;line-height:1;text-shadow:0 2px 14px rgba(0,0,0,.6)}.app-session-menu__tagline{font-family:"EB Garamond",var(--font-body),serif;font-style:italic;color:#c9b68a;font-size:.875rem;margin:18px 0 28px;line-height:1.55;max-width:28ch}.app-session-menu__continue-info{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);margin-bottom:16px}.app-session-menu__character-name{font-family:"Cinzel",var(--font-heading),serif;font-size:clamp(1.25rem,4vw,1.5rem);color:var(--gold-bright);letter-spacing:.08em;line-height:1.15}.app-session-menu__level{font-family:"Cinzel",var(--font-heading),serif;font-size:.6875rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#c9b68a;background:#d9a84a1f;border:1px solid rgba(217,168,74,.3);border-radius:2rem;padding:2px 10px}.app-session-menu__btn{width:100%;border-radius:6px;font-family:"Cinzel",var(--font-heading),serif;letter-spacing:.2em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.app-session-menu__btn:after{content:"›";color:var(--gold-bright);font-size:1.375rem;line-height:1}.app-session-menu__btn:active:not(:disabled){transform:translateY(1px)}.app-session-menu__btn--continue{background:linear-gradient(180deg,#7a2b15,#3a0f06);border:1px solid var(--colour-gold);color:var(--gold-bright);font-size:.75rem;padding:14px 18px;box-shadow:0 4px 16px #0006}.app-session-menu__btn--continue small{font-family:"EB Garamond",var(--font-body),serif;font-style:italic;font-size:.625rem;letter-spacing:.04em;color:#8a7a5c;text-transform:none;display:block;margin-top:3px}.app-session-menu__btn--continue:hover:not(:disabled){background:linear-gradient(180deg,#8f3319,#4a1408);box-shadow:0 6px 24px #0009,0 0 18px #d9a84a33}.app-session-menu__btn--continue:focus-visible{outline-color:var(--gold-bright)}.app-session-menu__btn--new{background:transparent;border:1px solid rgba(217,168,74,.3);color:#c9b68a;font-size:.6875rem;padding:11px 18px;margin-top:10px}.app-session-menu__btn--new:hover:not(:disabled){background:#d9a84a0f;border-color:#d9a84a99;color:var(--gold-bright)}.app-session-menu__no-session .app-session-menu__btn--new{background:linear-gradient(180deg,#7a2b15,#3a0f06);border:1px solid var(--colour-gold);color:var(--gold-bright);font-size:.75rem;padding:14px 18px;margin-top:0;box-shadow:0 4px 16px #0006}.app-session-menu__no-session .app-session-menu__btn--new:hover:not(:disabled){background:linear-gradient(180deg,#8f3319,#4a1408);box-shadow:0 6px 24px #0009,0 0 18px #d9a84a33}.app-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080401d1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:var(--space-6);z-index:100;animation:overlay-appear .18s ease forwards}@keyframes overlay-appear{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){.app-confirm-overlay{animation:none}}.app-confirm-dialog{background:radial-gradient(ellipse at 50% 10%,rgba(255,180,100,.06) 0%,transparent 70%),linear-gradient(180deg,#1a0e04f2,#0e0703fa);border:1px solid rgba(217,168,74,.35);border-radius:10px;box-shadow:0 20px 60px #000000a6,inset 0 0 20px #ffb4640a;padding:var(--space-8) var(--space-6);max-width:340px;width:100%;text-align:center;animation:dialog-appear .22s ease forwards}@keyframes dialog-appear{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.app-confirm-dialog{animation:none}}.app-confirm-message{font-family:"EB Garamond",var(--font-body),serif;font-size:.9375rem;color:#c9b68a;line-height:1.6;margin-bottom:var(--space-6)}.app-confirm-message strong{color:var(--gold-bright);font-weight:600}.app-confirm-actions{display:flex;gap:var(--space-3);justify-content:center}.app-confirm-btn{flex:1;border-radius:4px;font-family:"Cinzel",var(--font-heading),serif;font-size:.625rem;letter-spacing:.18em;text-transform:uppercase;padding:var(--space-3) var(--space-4);transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.app-confirm-btn:active:not(:disabled){transform:translateY(1px)}.app-confirm-btn--confirm{background:linear-gradient(180deg,#7a2b15,#3a0f06);border:1px solid var(--colour-gold);color:var(--gold-bright)}.app-confirm-btn--confirm:hover:not(:disabled){background:linear-gradient(180deg,#8f3319,#4a1408);box-shadow:0 0 12px #d9a84a40}.app-confirm-btn--cancel{background:transparent;border:1px solid rgba(217,168,74,.2);color:#9d8e72}.app-confirm-btn--cancel:hover:not(:disabled){background:#d9a84a0f;border-color:#d9a84a66;color:var(--gold-bright)}@media (min-width: 1024px){.app-session-menu{padding:72px 64px 64px}.app-session-menu__continue,.app-session-menu__no-session{max-width:500px}.app-session-menu__brand{font-size:3.5rem}.app-session-menu__tagline{font-size:1.3125rem;margin:22px 0 36px;max-width:32ch}.app-session-menu__character-name{font-size:1.875rem}.app-session-menu__level{font-size:.8125rem;padding:4px 14px}.app-session-menu__btn--continue{font-size:1rem;padding:18px 24px}.app-session-menu__btn--continue small{font-size:.8125rem}.app-session-menu__btn--new{font-size:.875rem;padding:15px 24px;margin-top:14px}.app-session-menu__no-session .app-session-menu__btn--new{font-size:1rem;padding:18px 24px}.app-session-menu__continue-info{margin-bottom:22px}}
