@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: #1a1410;--surface-elevated: #241e17;--surface-parchment: #f4e4c1;--surface-parchment-aged: #e8d5a3;--surface-overlay: rgba(26, 20, 16, .85);--text-parchment-primary: #1a1410;--text-parchment-muted: #58170d;--text-dark-primary: #e8dcc8;--text-dark-muted: #9a8b72;--text-dark-heading: #f4e4c1;--colour-maroon: #58170d;--colour-maroon-light: #7a2b15;--colour-gold: #d4a017;--colour-gold-on-light: #7a5c00;--colour-success: #2d6a30;--colour-danger: #8b1a1a;--border-dark: #3a3028;--border-parchment: #c9b18a;--font-heading: "Mr Eaves Small Caps", "Book Antiqua", Palatino, serif;--font-body: "Bookinsanity", "Book Antiqua", Palatino, Georgia, serif;--font-stat: "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-image:radial-gradient(ellipse at 20% 30%,rgba(58,48,40,.4) 0%,transparent 60%),radial-gradient(ellipse at 80% 70%,rgba(36,30,23,.3) 0%,transparent 60%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--surface-elevated)}::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-dark-muted)}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:column;align-items:center;gap:var(--space-4);padding:var(--space-6) var(--space-8);background-color:var(--surface-elevated);border:1px solid var(--border-dark);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);min-width:200px}.dice-result__mode-badge{display:flex;align-items:center;justify-content:center}.dice-result__mode{display:inline-block;padding:var(--space-1) var(--space-4);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.dice-result__mode--normal{background-color:var(--border-dark);color:var(--text-dark-muted)}.dice-result__mode--advantage{background-color:#2d6a3040;color:#7ec882;border:1px solid rgba(45,106,48,.4)}.dice-result__mode--disadvantage{background-color:#8b1a1a40;color:#e08080;border:1px solid rgba(139,26,26,.4)}.dice-result__dice-row{display:flex;align-items:center;gap:var(--space-4)}.dice-result__die{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);min-width:56px}.dice-result__die-value{display:flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border:2px solid var(--border-dark);border-radius:var(--radius-md);background-color:var(--surface-base);font-family:var(--font-heading);font-size:1.5rem;color:var(--text-dark-primary);box-shadow:inset 0 2px 4px #0000004d}.dice-result__die--kept .dice-result__die-value{border-color:var(--colour-gold);color:var(--colour-gold);box-shadow:0 0 8px #d4a0174d,inset 0 2px 4px #0000004d}.dice-dropped .dice-result__die-value{opacity:.4;text-decoration:line-through;border-color:var(--border-dark);color:var(--text-dark-muted)}.dice-result__die-drop-label{font-family:var(--font-stat);font-size:.625rem;color:var(--text-dark-muted);letter-spacing:.05em;text-transform:uppercase}.dice-result__modifier{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-stat)}.dice-result__modifier-label{font-size:.75rem;color:var(--text-dark-muted);letter-spacing:.05em;text-transform:uppercase}.dice-result__modifier-value{font-size:1rem;font-weight:700;color:var(--colour-gold)}.dice-result__total-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding-top:var(--space-2);border-top:1px solid var(--border-dark);width:100%;text-align:center}.dice-result__total-label{font-family:var(--font-stat);font-size:.6875rem;color:var(--text-dark-muted);letter-spacing:.1em;text-transform:uppercase}.dice-result__total{font-family:var(--font-heading);font-size:3rem;font-weight:700;color:var(--text-dark-heading);line-height:1;letter-spacing:.02em;text-shadow:0 0 20px rgba(212,160,23,.2)}.challenge-cta{display:flex;justify-content:center;padding:var(--space-4) var(--space-6) var(--space-2)}.challenge-cta__button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background-color:var(--surface-parchment);border:2px solid var(--colour-maroon);border-radius:var(--radius-sm);box-shadow:0 2px 6px #58170d2e,inset 0 1px #d4a01733;font-family:var(--font-heading);font-size:.9375rem;letter-spacing:.08em;color:var(--colour-maroon);white-space:nowrap;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);animation:cta-pulse 3s ease-in-out infinite}.challenge-cta__button:hover:not(:disabled){background-color:var(--colour-maroon);border-color:var(--colour-maroon);color:var(--surface-parchment);box-shadow:0 3px 10px #58170d59,inset 0 1px #d4a01726;animation:none}.challenge-cta__button:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 4px #58170d40}.challenge-cta__button:focus-visible{outline:2px solid var(--colour-maroon);outline-offset:3px;animation:none}.challenge-cta__button:disabled{border-color:var(--border-parchment);color:var(--text-parchment-muted);box-shadow:none;cursor:not-allowed;opacity:.7;animation:none}.challenge-cta__label{display:inline-flex;align-items:center;gap:0}.challenge-cta__arrow{display:inline-block;transition:transform var(--transition-fast)}.challenge-cta__button:hover:not(:disabled) .challenge-cta__arrow{transform:translate(3px)}.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 cta-pulse{0%,to{box-shadow:0 2px 6px #58170d2e,inset 0 1px #d4a01733}50%{box-shadow:0 2px 12px #58170d52,inset 0 1px #d4a01759}}@keyframes ellipsis-fade{0%,to{opacity:.4}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.challenge-cta__button{animation:none}.challenge-cta__ellipsis{animation:none;opacity:1}.challenge-cta__button:hover:not(:disabled) .challenge-cta__arrow{transform:none}}.narrative-panel{display:flex;flex-direction:column;height:100%;min-height:0;background-color:var(--surface-parchment);border-radius:var(--radius-lg);border:2px solid var(--border-parchment);box-shadow:var(--shadow-card),inset 0 0 60px #c8a05014;overflow:hidden;position:relative}.narrative-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent 0%,var(--colour-maroon) 15%,var(--colour-gold) 50%,var(--colour-maroon) 85%,transparent 100%);z-index:1}.narrative-panel__scroll{flex:1;min-height:0;overflow-y:auto;padding:var(--space-6) var(--space-6) var(--space-4);scroll-behavior:smooth}.narrative-panel__content{display:flex;flex-direction:column;gap:var(--space-4)}.narrative-panel__paragraph{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--text-parchment-primary);max-width:70ch;text-indent:1.5em}.narrative-panel__player-action{display:flex;align-items:baseline;gap:var(--space-2);padding:var(--space-1) var(--space-4);margin-left:var(--space-4);border-left:2px solid var(--colour-gold);font-family:var(--font-stat);font-size:.9375rem;font-style:italic;line-height:1.5;color:var(--colour-gold-on-light);max-width:65ch;text-indent:0;opacity:.85}.narrative-panel__action-chevron{font-style:normal;font-size:1.1em;color:var(--colour-gold);flex-shrink:0;line-height:1;opacity:.9}.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-parchment-muted);font-family:var(--font-stat);font-size:.875rem;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(--colour-maroon)}.narrative-panel__loading-text{opacity:.8}@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(--surface-parchment);font-family:var(--font-stat);font-size:.8125rem;text-align:center;letter-spacing:.03em}.narrative-panel__dice-strip{display:flex;align-items:center;padding:var(--space-2) var(--space-4);border-top:1px solid var(--border-parchment);background-color:var(--surface-base);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:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--border-parchment);background-color:var(--surface-parchment-aged)}.narrative-panel__input-row{display:flex;gap:var(--space-2)}.narrative-panel__input{flex:1;padding:var(--space-2) var(--space-3);background-color:var(--surface-parchment);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),box-shadow var(--transition-fast)}.narrative-panel__input::placeholder{color:var(--text-parchment-muted);opacity:.7;font-style:italic}.narrative-panel__input:focus:not(:disabled){border-color:var(--colour-maroon);box-shadow:0 0 0 2px #58170d26;outline:none}.narrative-panel__input:disabled{background-color:var(--surface-parchment-aged);opacity:.6}.narrative-panel__submit{padding:var(--space-2) var(--space-4);background-color:var(--colour-maroon);color:var(--surface-parchment);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.9375rem;letter-spacing:.06em;transition:background-color var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.narrative-panel__submit:hover:not(:disabled){background-color:var(--colour-maroon-light)}.narrative-panel__submit:active:not(:disabled){transform:translateY(1px)}.narrative-panel__submit:disabled{opacity:.55}.narrative-panel__char-count{margin-top:var(--space-1);font-family:var(--font-stat);font-size:.75rem;color:var(--text-parchment-muted);text-align:right;opacity:.7}.mcq-challenge{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.mcq-challenge__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--surface-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mcq-challenge__panel{position:relative;z-index:1;width:100%;max-width:640px;max-height:90dvh;overflow-y:auto;background-color:var(--surface-parchment);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);display:flex;flex-direction:column}.mcq-challenge__header{padding:var(--space-4) var(--space-6);background-color:var(--colour-maroon);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-bottom:3px solid var(--colour-gold)}.mcq-challenge__title{font-family:var(--font-heading);font-size:1.25rem;color:var(--surface-parchment);letter-spacing:.08em;text-align:center;margin:0}.mcq-challenge__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.mcq-challenge__question{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--text-parchment-primary);max-width:60ch}.mcq-challenge__options{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.mcq-challenge__option-item{display:contents}.mcq-challenge__option{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background-color:var(--surface-parchment-aged);border:1px solid var(--border-parchment);border-radius:var(--radius-md);color:var(--text-parchment-primary);text-align:left;transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.mcq-challenge__option:hover:not(:disabled){background-color:#dfc99a;border-color:var(--colour-gold-on-light);transform:translate(2px)}.mcq-challenge__option:active:not(:disabled){transform:translate(1px)}.mcq-challenge__option:disabled{cursor:default}.mcq-challenge__option--correct{background-color:#d4edda;border-color:var(--colour-success);color:#1a4a1e}.mcq-challenge__option--incorrect{background-color:#f8d7da;border-color:var(--colour-danger);color:#5c1010}.mcq-challenge__option-letter{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;background-color:var(--colour-maroon);color:var(--surface-parchment);font-family:var(--font-stat);font-size:.75rem;font-weight:700;letter-spacing:0;transition:background-color var(--transition-fast)}.mcq-challenge__option--correct .mcq-challenge__option-letter{background-color:var(--colour-success)}.mcq-challenge__option--incorrect .mcq-challenge__option-letter{background-color:var(--colour-danger)}.mcq-challenge__option-text{font-family:var(--font-body);font-size:.9375rem;line-height:1.4}.mcq-challenge__feedback{padding:var(--space-4);border-radius:var(--radius-md);border-left:4px solid;display:flex;flex-direction:column;gap:var(--space-3)}.mcq-challenge__feedback--correct{background-color:#d4edda;border-color:var(--colour-success);color:#1a4a1e}.mcq-challenge__feedback--wrong{background-color:#f8d7da;border-color:var(--colour-danger);color:#5c1010}.mcq-challenge__feedback-text{font-family:var(--font-body);font-size:.9375rem;line-height:1.6}.mcq-challenge__modifier{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-stat);font-size:.875rem;font-weight:700}.mcq-challenge__modifier-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);background-color:#0000001f;letter-spacing:.05em;text-transform:uppercase}.mcq-challenge__modifier-bonus{font-size:1rem}.mcq-challenge__xp-indicator{display:inline-block;align-self:flex-start;padding:var(--space-1) var(--space-3);background-color:#7a5c001f;border:1px solid var(--colour-gold-on-light);border-radius:var(--radius-sm);color:var(--colour-gold-on-light);font-family:var(--font-stat);font-size:.875rem;font-weight:700;letter-spacing:.04em}.mcq-challenge__roll-btn{align-self:flex-end;padding:var(--space-2) var(--space-6);background-color:var(--colour-maroon);color:var(--surface-parchment);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:1rem;letter-spacing:.06em;transition:background-color var(--transition-fast),transform var(--transition-fast)}.mcq-challenge__roll-btn:hover{background-color:var(--colour-maroon-light)}.mcq-challenge__roll-btn:active{transform:translateY(1px)}.mcq-challenge__roll-btn:disabled{opacity:.5;cursor:not-allowed;transform: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(--colour-maroon);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(--colour-maroon);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(--colour-maroon);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:var(--font-body);font-size:.9375rem;font-style:italic;color:var(--text-parchment-muted);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-color:#d4a01724;border:1px solid rgba(212,160,23,.5);border-radius:var(--radius-sm);color:var(--colour-gold-on-light);font-family:var(--font-stat);font-size:.875rem;font-weight:700;letter-spacing:.04em;animation:hard-badge-glow 2s ease-in-out infinite}@keyframes hard-badge-glow{0%,to{box-shadow:0 0 #d4a01700}50%{box-shadow:0 0 8px #d4a01766}}@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:var(--ink-tertiary);font-family:var(--font-stat);font-size:.75rem;letter-spacing:.03em;text-decoration:underline;text-underline-offset:2px;cursor:pointer;opacity:.65;transition:opacity var(--transition-fast),color var(--transition-fast)}.mcq-challenge__flag-btn:hover{opacity:1;color:var(--colour-danger)}.mcq-challenge__flag-btn:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px;border-radius:var(--radius-sm)}@media (max-width: 480px){.mcq-challenge__panel{max-height:95dvh}.mcq-challenge__body{padding:var(--space-4)}}.icon-bar{display:flex;flex-direction:row;align-items:center;gap:var(--space-2);padding:0;margin:0;list-style:none}.icon-bar__button{display:flex;align-items:center;justify-content:center;padding:var(--space-2);background:transparent;border:1px solid var(--border-dark);border-radius:var(--radius-sm);color:var(--text-dark-muted);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.icon-bar__button:hover,.icon-bar__button:focus-visible{color:var(--colour-gold);border-color:var(--colour-gold);outline:none}.icon-bar__button:active{opacity:.75}.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}}.game-screen{display:flex;flex-direction:column;min-height:100dvh;background-color:var(--surface-base)}.game-screen__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);background-color:var(--surface-elevated);border-bottom:1px solid var(--border-dark);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:var(--font-heading);font-size:1.25rem;color:var(--colour-gold);letter-spacing:.12em;text-transform:uppercase}.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 var(--border-dark);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(--colour-gold);color:var(--colour-gold)}.tts-pause-btn:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.game-screen__save,.game-screen__logout{padding:var(--space-1) var(--space-3);background:transparent;border:1px solid var(--border-dark);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:var(--font-stat);font-size:.8125rem;letter-spacing:.04em;transition:border-color var(--transition-fast),color var(--transition-fast);cursor:pointer}.game-screen__save:hover:not(:disabled){border-color:var(--colour-gold);color:var(--colour-gold)}.game-screen__save:disabled{opacity:.45;cursor:not-allowed}.game-screen__logout:hover{border-color:var(--colour-gold);color:var(--colour-gold)}.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:var(--surface-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);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-color:var(--surface-parchment);border:2px solid var(--border-parchment);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);text-align:center}.game-screen__quit-dialog-text{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--text-parchment-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-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)}.game-screen__quit-confirm:hover:not(:disabled){background-color:var(--colour-maroon-light)}.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 var(--border-parchment);border-radius:var(--radius-sm);color:var(--text-parchment-muted);font-family:var(--font-stat);font-size:.875rem;letter-spacing:.04em;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.game-screen__quit-cancel:hover:not(:disabled){border-color:var(--colour-maroon);color:var(--colour-maroon)}.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(--colour-gold);outline-offset:2px}.game-screen__main{display:flex;flex:1;min-height:0;padding:var(--space-4)}.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-color:var(--surface-parchment);border:2px solid var(--border-parchment);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);text-align:center}.game-screen__challenge-overlay-text{font-family:var(--font-body);font-size:1.0625rem;color:var(--text-parchment-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 var(--border-parchment);border-radius:var(--radius-sm);color:var(--text-parchment-muted);font-family:var(--font-stat);font-size:.875rem;letter-spacing:.04em;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(--colour-maroon);color:var(--colour-maroon);background-color:#58170d0f}.game-screen__challenge-overlay-skip:focus-visible{outline:2px solid var(--colour-maroon);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-color:var(--surface-elevated);border-top:1px solid var(--border-dark);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 var(--border-dark);border-radius:var(--radius-sm);color:var(--text-dark-muted);font-family:var(--font-stat);font-size:.8rem;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.game-screen__world-btn:hover{color:var(--text-dark-primary);border-color:var(--text-dark-muted)}.game-screen__world-btn:focus-visible{outline:2px solid var(--colour-gold);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:#d4a0171a;border:1px solid rgba(212,160,23,.3);border-radius:var(--radius-sm);font-family:var(--font-stat);font-size:.75rem;color:var(--text-dark-muted);letter-spacing:.04em}.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:var(--surface-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.game-screen__flag-dialog{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);max-width:22rem;width:90%;background-color:var(--surface-parchment);border:2px solid var(--border-parchment);border-radius:var(--radius-md);box-shadow:var(--shadow-modal)}.game-screen__flag-dialog-heading{font-family:var(--font-heading);font-size:1rem;color:var(--ink-heading);letter-spacing:.06em;text-transform:uppercase;margin:0}.game-screen__flag-dialog-label{font-family:var(--font-stat);font-size:.875rem;color:var(--ink-secondary);letter-spacing:.03em}.game-screen__flag-dialog-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(--ink-primary);font-family:var(--font-stat);font-size:.875rem;cursor:pointer}.game-screen__flag-dialog-select:focus-visible{outline:2px solid var(--colour-gold);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-color:var(--colour-maroon);color:var(--surface-parchment);border:none;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.875rem;letter-spacing:.05em;cursor:pointer;transition:background-color var(--transition-fast)}.game-screen__flag-dialog-confirm:hover{background-color:var(--colour-maroon-light)}.game-screen__flag-dialog-confirm:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.game-screen__flag-dialog-cancel{padding:var(--space-2) var(--space-4);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)}.game-screen__flag-dialog-cancel:hover{border-color:var(--colour-maroon);color:var(--colour-maroon)}.game-screen__flag-dialog-cancel:focus-visible{outline:2px solid var(--colour-gold);outline-offset:2px}.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{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-6)}.app-session-menu__continue,.app-session-menu__no-session{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);background-color:var(--surface-parchment);background-image:radial-gradient(ellipse at 30% 20%,rgba(212,160,23,.12) 0%,transparent 55%),radial-gradient(ellipse at 70% 80%,rgba(88,23,13,.08) 0%,transparent 55%);border:2px solid var(--border-parchment);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal),var(--parchment-inner-shadow),0 0 0 1px #d4a01733;padding:var(--space-8) clamp(var(--space-6),8vw,4rem);max-width:440px;width:100%;text-align:center}.app-session-menu__continue-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.app-session-menu__character-name{font-family:var(--font-heading);font-size:clamp(1.5rem,4vw,2rem);color:var(--colour-maroon);letter-spacing:.06em;line-height:1.15}.app-session-menu__level{font-family:var(--font-stat);font-size:.8125rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--colour-gold-on-light);background-color:#d4a01726;border:1px solid rgba(212,160,23,.4);border-radius:2rem;padding:var(--space-1) var(--space-4)}.app-session-menu__btn{width:100%;border-radius:var(--radius-md);font-family:var(--font-heading);letter-spacing:.06em;transition:background-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.app-session-menu__btn:active:not(:disabled){transform:translateY(1px)}.app-session-menu__btn--continue{background-color:var(--colour-maroon);border:2px solid var(--colour-maroon-light);color:var(--surface-parchment);font-size:clamp(1rem,2.5vw,1.125rem);padding:var(--space-4) var(--space-6);box-shadow:0 4px 16px #58170d66,inset 0 1px #f4e4c126}.app-session-menu__btn--continue:hover:not(:disabled){background-color:var(--colour-maroon-light);box-shadow:0 6px 24px #58170d8c,inset 0 1px #f4e4c133}.app-session-menu__btn--continue:focus-visible{outline-color:var(--colour-maroon)}.app-session-menu__btn--new{background-color:transparent;border:1px solid var(--border-parchment);color:var(--text-parchment-muted);font-size:.9375rem;padding:var(--space-3) var(--space-6)}.app-session-menu__btn--new:hover:not(:disabled){background-color:#58170d14;border-color:var(--colour-maroon-light);color:var(--colour-maroon)}.app-session-menu__no-session .app-session-menu__btn--new{background-color:var(--colour-maroon);border:2px solid var(--colour-maroon-light);color:var(--surface-parchment);font-size:clamp(1rem,2.5vw,1.125rem);padding:var(--space-4) var(--space-6);box-shadow:0 4px 16px #58170d66,inset 0 1px #f4e4c126}.app-session-menu__no-session .app-session-menu__btn--new:hover:not(:disabled){background-color:var(--colour-maroon-light);box-shadow:0 6px 24px #58170d8c}.app-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--surface-overlay);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-color:var(--surface-parchment);background-image:radial-gradient(ellipse at 25% 25%,rgba(212,160,23,.1) 0%,transparent 60%);border:2px solid var(--border-parchment);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal),var(--parchment-inner-shadow),0 0 0 1px #8b1a1a26;padding:var(--space-8) var(--space-6);max-width:400px;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:var(--font-body);font-size:1rem;color:var(--text-parchment-primary);line-height:1.6;margin-bottom:var(--space-6);max-width:100%}.app-confirm-message strong{color:var(--colour-maroon);font-weight:700}.app-confirm-actions{display:flex;gap:var(--space-3);justify-content:center}.app-confirm-btn{flex:1;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:.9375rem;letter-spacing:.05em;padding:var(--space-3) var(--space-4);transition:background-color 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-color:var(--colour-danger);border:2px solid rgba(139,26,26,.7);color:var(--surface-parchment);box-shadow:0 3px 12px #8b1a1a59}.app-confirm-btn--confirm:hover:not(:disabled){background-color:#a32020;box-shadow:0 5px 18px #8b1a1a80}.app-confirm-btn--cancel{background-color:transparent;border:1px solid var(--border-parchment);color:var(--text-parchment-muted)}.app-confirm-btn--cancel:hover:not(:disabled){background-color:#58170d12;border-color:var(--colour-maroon-light);color:var(--colour-maroon)}
