@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.border{border-width:1px}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.underline{text-decoration-line:underline}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{color-scheme:dark;--bg-deep: #0f0e0c;--bg-surface: #1a1815;--bg-elevated: #242119;--bg-card: #2a261f;--bg-hover: #332e25;--bg-active: #3d3628;--accent: #d4a24e;--accent-dim: #b8893d;--accent-bright: #edb85a;--accent-glow: rgba(212, 162, 78, .15);--accent-glow-strong: rgba(212, 162, 78, .3);--text-primary: #e8e0d4;--text-secondary: #a69d8f;--text-muted: #8d8474;--text-accent: #d4a24e;--border: #3a352c;--border-strong: #534b3e;--border-accent: #6b5c3e;--success: #5a9e6f;--error: #c45252;--info: #5a8fa6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(212, 162, 78, .1);--font-display: "Cinzel", "Palatino Linotype", "Book Antiqua", serif;--font-body: "Crimson Pro", "Georgia", serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-width: 260px;--header-height: 72px;--footer-height: 64px;--ease-out: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--accent, #d4a24e);outline-offset:2px;border-radius:4px}input:focus-visible,textarea:focus-visible,select:focus-visible{outline-color:var(--accent-dim, #b8893d);outline-offset:1px}.home-hero-card:focus-visible{transform:translateY(-4px);box-shadow:0 12px 40px #00000080}.home-card-new:focus-visible{border-color:var(--accent-dim, #b8893d);background:var(--accent-glow, rgba(212,162,78,.15))}.home-library-btn:focus-visible{background:#d4a24e1a;border-color:var(--accent, #d4a24e);color:var(--accent, #d4a24e)}.portrait-action-btn:focus-visible{background:var(--bg-hover, #332e25);border-color:var(--accent-dim, #b8893d)}.share-modal-close:focus-visible{color:var(--text-primary, #e8e0d4)}html{font-size:17px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;background:var(--bg-deep);color:var(--text-primary);font-family:var(--font-body);line-height:1.6;min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh}@media (hover: none){.touch-target,.share-modal-close,.sheet-modal-close-btn,.status-hp-btn,.home-card-btn,.cond-add-btn,.cond-end-turn-btn,.persist-confirm-btn,.persist-roll-btn,.persist-remove-btn,.portrait-action-btn,.portrait-delete-btn,.dying-undo-btn,.dying-manual-btn{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}}.wizard-container{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden}.wizard-header{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;position:relative}.wizard-header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:var(--header-height)}.wizard-logo{display:flex;align-items:center;gap:12px}.wizard-logo-icon{font-size:28px;line-height:1;filter:drop-shadow(0 0 6px rgba(212,162,78,.4))}.wizard-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--accent);letter-spacing:.04em;margin:0}.wizard-subtitle{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.wizard-title-accent{color:var(--text-primary);font-weight:400;font-size:.9em;opacity:.85}.wizard-app-footer{display:none;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-family:var(--font-body);font-size:.7rem;color:var(--text-muted);background:var(--bg-surface);border-top:1px solid var(--border);letter-spacing:.03em;flex-shrink:0}.wizard-app-footer-brand{font-family:var(--font-display);color:var(--accent-dim);font-weight:600;font-size:.72rem;letter-spacing:.05em}.wizard-app-footer-sep{color:var(--border-strong);font-size:.8rem}.wizard-app-footer-link{color:var(--text-secondary);text-decoration:none;transition:color .2s}.wizard-app-footer-link:hover{color:var(--accent);text-decoration:underline}@media (min-width: 769px){.wizard-app-footer{display:flex}}.wizard-identity-bar{display:flex;align-items:center;gap:8px;flex-shrink:1;min-width:0}.wizard-identity-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px 4px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-family:var(--font-body);font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative}.wizard-identity-badge:hover{border-color:var(--accent-dim);background:#d4a24e14;color:var(--accent)}.wizard-identity-icon{font-size:.85rem;line-height:1;flex-shrink:0}.wizard-identity-value{font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.03em;color:var(--text-primary);transition:color .2s}.wizard-identity-badge:hover .wizard-identity-value{color:var(--accent)}.wizard-identity-edit{font-size:.65rem;color:var(--text-muted);opacity:0;transform:translate(-3px);transition:all .2s ease;flex-shrink:0}.wizard-identity-badge:hover .wizard-identity-edit{opacity:1;transform:translate(0)}.wizard-identity-class{border-color:#e0784533}.wizard-identity-class:hover{border-color:#e0784580;background:#e078450f}.wizard-identity-ancestry{border-color:#94b8db33}.wizard-identity-ancestry:hover{border-color:#94b8db80;background:#94b8db0f}.wizard-identity-name{font-family:var(--font-display);font-size:.85rem;color:var(--accent-bright);letter-spacing:.02em;opacity:.9;padding-left:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.wizard-step-group{margin-bottom:4px}.wizard-step-group:last-child{margin-bottom:0}.wizard-step-group-label{font-family:var(--font-display);font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);padding:10px 20px 4px;opacity:.7}.wizard-step-group:first-child .wizard-step-group-label{padding-top:4px}.wizard-step-group+.wizard-step-group{border-top:1px solid var(--border);padding-top:4px;margin-top:4px}.wizard-progress-track{height:3px;background:var(--border);width:100%;position:absolute;bottom:0;left:0}.wizard-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-dim),var(--accent-bright));transition:width .5s var(--ease-out);box-shadow:0 0 8px #d4a24e4d}.wizard-body{display:flex;flex:1;overflow:hidden}.wizard-sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border);overflow-y:auto;padding:16px 0;background-image:radial-gradient(ellipse at 50% 0%,rgba(212,162,78,.03) 0%,transparent 60%)}.wizard-step-list{list-style:none;margin:0;padding:0}.wizard-step-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 20px;border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:.9rem;color:var(--text-secondary);text-align:left;transition:all .2s ease;border-left:3px solid transparent}.wizard-step-item:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.wizard-step-item:disabled{cursor:not-allowed;opacity:.35}.wizard-step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);font-size:.75rem;font-weight:500;flex-shrink:0;transition:all .2s ease}.wizard-step-text{display:flex;flex-direction:column;min-width:0}.wizard-step-label{font-weight:500;line-height:1.2}.wizard-step-desc{font-size:.72rem;color:var(--text-muted);line-height:1.3}.wizard-step-active{background:var(--accent-glow)!important;color:var(--accent-bright)!important;border-left-color:var(--accent)}.wizard-step-active .wizard-step-number{background:var(--accent);border-color:var(--accent);color:var(--bg-deep);font-weight:700;box-shadow:0 0 10px #d4a24e4d}.wizard-step-active .wizard-step-desc{color:var(--text-secondary)}.wizard-step-completed .wizard-step-number{background:var(--success);border-color:var(--success);color:#fff}.wizard-step-completed .wizard-step-label{color:var(--text-secondary)}.wizard-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-deep);background-image:radial-gradient(ellipse at 50% 0%,rgba(212,162,78,.02) 0%,transparent 50%)}.wizard-content-inner{flex:1;overflow-y:auto;padding:32px 40px;display:flex;flex-direction:column;align-items:center}.wizard-content-inner>*{width:100%;max-width:840px}.wizard-step-header{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border)}.wizard-step-header-icon{font-size:2rem;line-height:1}.wizard-step-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em;margin:0}.wizard-step-subtitle{font-size:.85rem;color:var(--text-muted);margin:2px 0 0}.wizard-step-content{max-width:840px}.wizard-placeholder{color:var(--text-muted);font-style:italic;padding:40px 0;text-align:center}.wizard-nav-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 40px;border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;height:var(--footer-height)}.wizard-btn{font-family:var(--font-body);font-size:.9rem;font-weight:500;padding:8px 24px;border-radius:6px;border:1px solid var(--border);cursor:pointer;transition:all .2s ease}.wizard-btn:disabled{opacity:.3;cursor:not-allowed}.wizard-btn-back{background:transparent;color:var(--text-secondary)}.wizard-btn-back:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.wizard-btn-next{background:var(--accent);color:var(--bg-deep);border-color:var(--accent);font-weight:600}.wizard-btn-next:hover:not(:disabled),.wizard-btn-next:focus-visible:not(:disabled){background:var(--accent-bright);box-shadow:var(--shadow-glow)}.wizard-btn-finish{background:var(--success);border-color:var(--success);color:#0b1410;font-weight:700;letter-spacing:.02em;padding-left:18px;padding-right:18px;min-height:44px}.wizard-btn-finish:hover:not(:disabled),.wizard-btn-finish:focus-visible{background:#6fb886;box-shadow:0 0 18px #5a9e6f59}.wizard-nav-indicator{font-size:.8rem;color:var(--text-muted);font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:8px}.wizard-autosave-pill{font-size:.7rem;padding:2px 8px;border-radius:999px;letter-spacing:.02em;transition:opacity .2s}.wizard-autosave-saving{background:#d4a24e1f;color:var(--accent);border:1px solid rgba(212,162,78,.3)}.wizard-autosave-saved{background:#5a9e6f1f;color:var(--success);border:1px solid rgba(90,158,111,.3)}.wizard-mobile-nav{display:none}.tooltip-trigger{position:relative;cursor:help;border-bottom:1px dotted var(--text-muted)}.tooltip-popover{position:fixed;z-index:9999;pointer-events:auto;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-lg);animation:tooltip-in .15s var(--ease-out)}@keyframes tooltip-in{0%{opacity:0;transform:translateY(4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.tooltip-short{max-width:280px;padding:8px 12px}.tooltip-short .tooltip-desc{font-size:.82rem;color:var(--text-primary);margin:0;line-height:1.4}.tooltip-short .tooltip-formula{font-size:.72rem;color:var(--accent);margin:4px 0 0;font-family:var(--font-mono)}.tooltip-medium{max-width:340px;padding:12px 16px}.tooltip-medium .tooltip-desc{font-size:.85rem;color:var(--text-primary);margin:0;line-height:1.5}.tooltip-medium .tooltip-formula{font-size:.75rem;color:var(--accent);margin:6px 0 0;font-family:var(--font-mono)}.tooltip-medium .tooltip-effect{font-size:.8rem;color:var(--text-secondary);margin:6px 0 0;font-style:italic}.tooltip-rich{max-width:400px;padding:0;overflow:hidden}.tooltip-rich-content{padding:14px 16px}.tooltip-traits{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.tooltip-trait-badge{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:3px;background:#4a3520;color:var(--accent);border:1px solid var(--border-accent)}.tooltip-rich .tooltip-desc{font-size:.85rem;color:var(--text-primary);margin:0 0 8px;line-height:1.5}.tooltip-field{margin:6px 0;font-size:.8rem;line-height:1.4}.tooltip-field-label{display:inline;color:var(--accent);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.tooltip-field-label:after{content:"  "}.tooltip-field-value{color:var(--text-secondary)}.tooltip-aon-link{display:block;margin-top:10px;padding-top:8px;border-top:1px solid var(--border);font-size:.72rem;color:var(--info);text-decoration:none;opacity:.7;transition:opacity .15s}.tooltip-aon-link:hover{opacity:1;color:var(--accent-bright)}.info-tip-icon{display:inline-flex;align-items:center;color:var(--text-muted);vertical-align:middle;margin-left:4px;transition:color .15s}.info-tip-icon:hover{color:var(--accent)}.info-hint{color:var(--text-muted);font-size:.85em;cursor:help}.term-link{border-bottom:1px dotted var(--accent);cursor:help;display:inline;transition:border-bottom-color .15s}.term-link:hover{border-bottom-color:var(--accent-light, #f0c06a)}.concept-step{display:flex;flex-direction:column;gap:28px}.concept-intro-text{font-size:1.05rem;color:var(--text-secondary);line-height:1.6;margin:0}.concept-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--font-display);font-size:.8rem;font-weight:500;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.form-label-optional{font-family:var(--font-body);font-size:.75rem;color:var(--text-muted);text-transform:none;letter-spacing:0;font-weight:400}.form-input,.form-select,.form-textarea{font-family:var(--font-body);font-size:.95rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:10px 14px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input-large{font-size:1.2rem;padding:14px 18px;font-family:var(--font-display);letter-spacing:.01em}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='%23706858'%3E%3Cpath d='M4.427 6.427l3.396 3.396a.25.25 0 00.354 0l3.396-3.396A.25.25 0 0011.396 6H4.604a.25.25 0 00-.177.427z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-char-count{font-size:.72rem;color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums}.form-preview-name{font-family:var(--font-display);font-size:1.6rem;color:var(--accent-bright);margin-top:4px;letter-spacing:.03em;text-shadow:0 0 20px rgba(212,162,78,.2);animation:name-glow .3s var(--ease-out)}@keyframes name-glow{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-row{display:flex;gap:8px;align-items:center}.form-btn-small{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;transition:all .15s;flex-shrink:0}.form-btn-small:hover{background:var(--bg-hover);color:var(--text-primary)}.concept-flavor{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px 20px}.concept-flavor-title{font-family:var(--font-display);font-size:.85rem;color:var(--accent-dim);margin:0 0 8px;letter-spacing:.04em}.concept-flavor-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.concept-flavor-list li{font-size:.85rem;color:var(--text-secondary);padding-left:16px;position:relative;line-height:1.5}.concept-flavor-list li:before{content:"›";position:absolute;left:0;color:var(--accent-dim);font-weight:600}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 768px){.wizard-sidebar{display:none}.wizard-content-inner{padding:20px 16px}.wizard-nav-footer{padding:12px 16px}.wizard-header-inner{padding:0 16px}.wizard-identity-bar{gap:4px}.wizard-identity-badge{padding:3px 8px 3px 6px;font-size:.72rem}.wizard-identity-value{font-size:.7rem}.wizard-identity-edit{display:none}.wizard-identity-name{max-width:90px;font-size:.75rem}.wizard-logo-icon{font-size:22px}.wizard-title{font-size:1rem}.wizard-subtitle,.slb-btn-label{display:none}.slb-btn{padding:.4rem .6rem;font-size:.95rem;min-width:36px;justify-content:center}.slb-saved-indicator{display:none}.save-load-bar{gap:.3rem}.wizard-mobile-nav{display:block;background:var(--bg-surface);border-top:1px solid var(--border);flex-shrink:0}.wizard-mobile-current{display:flex;align-items:center;gap:10px;width:100%;min-height:44px;padding:8px 16px;background:transparent;border:none;cursor:pointer;font-family:var(--font-body)}.wizard-mobile-current-num{font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.wizard-mobile-current-label{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--accent);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wizard-mobile-current-caret{margin-left:auto;font-size:.72rem;color:var(--text-secondary);flex-shrink:0;border:1px solid var(--border);border-radius:999px;padding:3px 10px;background:var(--bg-card)}.wizard-mobile-track{height:3px;background:var(--border)}.wizard-mobile-track-fill{height:100%;background:linear-gradient(90deg,var(--accent-dim),var(--accent-bright));transition:width .4s var(--ease-out)}.wizard-step-title{font-size:1.2rem}.wizard-step-header-icon{font-size:1.5rem}.form-preview-name{font-size:1.3rem}.step-intro{font-size:.95rem;line-height:1.55;margin-bottom:1.25rem}}@media (max-width: 480px){.wizard-logo>div{display:none}.wizard-identity-name{display:none}}.wizard-mobile-sheet-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:flex-end;animation:wizard-sheet-fade .18s ease-out}@keyframes wizard-sheet-fade{0%{opacity:0}}.wizard-mobile-sheet{width:100%;max-height:75dvh;overflow-y:auto;background:var(--bg-surface);border-top:1px solid var(--border-strong);border-radius:16px 16px 0 0;padding:6px 0 max(16px,env(safe-area-inset-bottom));animation:wizard-sheet-up .22s var(--ease-out)}@keyframes wizard-sheet-up{0%{transform:translateY(40px);opacity:.5}}.wizard-mobile-sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--border-strong);margin:6px auto 4px}.wizard-mobile-sheet-group+.wizard-mobile-sheet-group{border-top:1px solid var(--border);margin-top:6px;padding-top:6px}.wizard-mobile-sheet .wizard-step-item{min-height:44px;padding:8px 20px}.step-intro{color:var(--text-secondary);font-size:1.05rem;line-height:1.7;margin-bottom:2rem}.pick-section{margin-bottom:2rem}.pick-section-title{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--text-primary);letter-spacing:.06em;text-transform:uppercase;margin:0 0 .75rem;display:flex;align-items:center;gap:.25rem}.pick-sublabel{font-size:.88rem;color:var(--text-secondary);margin:.75rem 0 .5rem}.pick-sublabel-note{color:var(--text-muted);font-style:italic}.tile-grid{display:flex;flex-wrap:wrap;gap:8px}.pick-tile{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg-card);border:2px solid var(--border);border-radius:6px;padding:10px 18px;cursor:pointer;transition:all .15s ease;color:var(--text-primary);font-family:var(--font-body);min-width:110px}.pick-tile:hover{border-color:var(--border-strong);background:var(--bg-hover)}.pick-tile-active{border-color:var(--accent);background:var(--bg-active);box-shadow:0 0 10px #d4a24e1a}.pick-tile-name{font-family:var(--font-display);font-size:.88rem;font-weight:600;letter-spacing:.02em}.pick-tile-active .pick-tile-name{color:var(--accent-bright)}.pick-tile-stats{font-size:.7rem;color:var(--text-muted);white-space:nowrap}.detail-panel{background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--accent-dim);border-radius:6px;padding:1rem 1.25rem;margin-bottom:2rem}.detail-panel-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.detail-panel-name{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--accent-bright);margin:0}.detail-panel-traits{display:flex;gap:5px}.detail-panel-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.55;margin:0 0 .75rem}.detail-panel-row{display:flex;flex-wrap:wrap;gap:.6rem 1.1rem}.stat-chip{display:inline-flex;align-items:center;gap:4px;font-size:.8rem}.stat-chip-label{color:var(--text-muted);font-weight:500;text-transform:uppercase;font-family:var(--font-display);font-size:.6rem;letter-spacing:.05em}.stat-chip-value{color:var(--text-primary);font-weight:500}.trait-badge{display:inline-block;font-family:var(--font-display);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:#d4a24e1a;border:1px solid rgba(212,162,78,.25);border-radius:3px;padding:1px 7px;line-height:1.4}.trait-badge-sm{font-size:.55rem;padding:0 5px;margin-left:4px;vertical-align:middle}.compact-list{display:flex;flex-direction:column;gap:6px}.compact-option{display:flex;gap:10px;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;padding:10px 14px;cursor:pointer;transition:all .15s ease;text-align:left;color:var(--text-primary);font-family:var(--font-body)}.compact-option:hover{border-color:var(--border-strong);background:var(--bg-hover)}.compact-option-active{border-color:var(--accent);background:var(--bg-active)}.compact-radio{flex-shrink:0;width:16px;height:16px;border:2px solid var(--border-strong);border-radius:50%;margin-top:2px;transition:all .15s}.compact-radio-on{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 3px var(--bg-active)}.compact-option-body{display:flex;flex-direction:column;gap:2px;min-width:0}.compact-option-name{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:2px;flex-wrap:wrap}.compact-option-active .compact-option-name{color:var(--accent-bright)}.compact-option-effect{font-size:.86rem;color:var(--text-secondary);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.compact-option-active .compact-option-effect{color:var(--text-secondary);-webkit-line-clamp:unset}.compact-option-prereq{font-size:.75rem;color:var(--text-muted);font-style:italic}.boost-toggle-row{display:flex;flex-wrap:wrap;gap:8px}.boost-toggle{display:flex;flex-direction:column;gap:6px;background:var(--bg-card);border:2px solid var(--border);border-radius:6px;padding:10px 14px;cursor:pointer;transition:all .15s ease;text-align:left;color:var(--text-primary);font-family:var(--font-body);flex:1;min-width:200px}.boost-toggle:hover{border-color:var(--border-strong);background:var(--bg-hover)}.boost-toggle-active{border-color:var(--accent);background:var(--bg-active);box-shadow:0 0 8px #d4a24e14}.boost-toggle-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary)}.boost-toggle-active .boost-toggle-label{color:var(--accent)}.boost-toggle-tags{display:flex;gap:4px;flex-wrap:wrap}.boost-tag{display:inline-block;font-family:var(--font-mono);font-size:.68rem;font-weight:600;padding:1px 7px;border-radius:3px}.boost-tag-fixed{color:#8cc49a;background:#5a9e6f26;border:1px solid rgba(90,158,111,.3)}.boost-tag-free{color:var(--accent);background:#d4a24e1f;border:1px solid rgba(212,162,78,.25)}.boost-tag-flaw{color:#d47a7a;background:#c452521f;border:1px solid rgba(196,82,82,.25)}.free-boost-pickers{margin-top:.75rem;padding:.75rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:5px}.boost-picker-row{display:flex;gap:.6rem;flex-wrap:wrap}.boost-select{flex:1;min-width:140px;max-width:200px}.step-summary{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:1rem 1.25rem;margin-top:1rem}.step-summary-complete{border-color:var(--success);box-shadow:0 0 10px #5a9e6f14}.step-summary-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin:0 0 .75rem}.step-summary-complete .step-summary-title{color:var(--success)}.step-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.35rem 1.25rem}.summary-row{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:2px 0}.summary-row-label{font-family:var(--font-display);font-size:.65rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.summary-row-value{font-size:.85rem;color:var(--text-secondary)}.summary-row-done .summary-row-value{color:var(--text-primary)}.summary-flaw{color:#d47a7a;font-size:.78rem}@media (max-width: 768px){.tile-grid{gap:6px}.pick-tile{min-width:90px;padding:8px 14px}.boost-toggle{min-width:160px}.boost-select{max-width:none}.step-summary-grid{grid-template-columns:1fr}}.boost-row-pair{display:flex;gap:1.5rem;flex-wrap:wrap}.boost-picker-group{display:flex;flex-direction:column;gap:6px;min-width:140px}.boost-picker-label{font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.boost-chip{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-card);border:2px solid var(--border);border-radius:5px;padding:6px 14px;cursor:pointer;transition:all .12s ease}.boost-chip:hover{border-color:var(--border-strong);background:var(--bg-hover)}.boost-chip-active{color:var(--accent-bright);border-color:var(--accent);background:var(--bg-active)}.boost-chip-wide{padding:6px 18px;font-family:var(--font-body);font-size:.85rem;font-weight:500}.stat-chip-hover{cursor:help;transition:color .15s}.stat-chip-hover:hover .stat-chip-value{color:var(--accent-bright)}.summary-row-hover{cursor:help;transition:color .15s}.summary-row-hover:hover{color:var(--accent-bright)}.pick-tile-disabled{opacity:.4;cursor:not-allowed}.pick-tile-disabled:hover{border-color:var(--border);background:var(--bg-card)}.levelup-banner{padding:14px 16px;margin-bottom:12px;background:color-mix(in srgb,#5a9e6f 12%,var(--surface));border:1px solid #5a9e6f;border-radius:10px}.levelup-banner-header{display:flex;align-items:flex-start;gap:10px}.levelup-banner-icon{font-size:1.4rem;flex-shrink:0}.levelup-banner-title{display:block;color:#5a9e6f;font-family:var(--font-display);font-size:.95rem;margin-bottom:3px}.levelup-banner-features{display:block;font-size:.78rem;color:var(--text-muted);font-style:italic}.levelup-banner-dismiss{margin-left:auto;flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}.levelup-banner-dismiss:hover{background:#ffffff14;color:var(--text)}.levelup-banner-pending{margin:8px 0 0 34px;font-size:.8rem;color:#d4a24e}.level-selector{display:flex;align-items:center;gap:1rem}.level-slider{flex:1;max-width:300px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-card);border-radius:3px;outline:none}.level-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0000004d;-webkit-transition:transform .15s,box-shadow .15s;transition:transform .15s,box-shadow .15s}.level-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 10px #d4a24e66}.level-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent);border:none;border-radius:50%;cursor:pointer}.level-display{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--accent-bright);min-width:80px}.progression-timeline{display:flex;flex-direction:column;gap:6px}.level-block{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;overflow:hidden;transition:border-color .2s}.level-block-done{border-color:var(--success)}.level-block-header{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);font-family:var(--font-body);text-align:left;transition:background .15s}.level-block-header:hover{background:var(--bg-hover)}.level-block-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:50%;font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--text-secondary);flex-shrink:0}.level-block-done .level-block-badge{background:var(--success);border-color:var(--success);color:var(--bg-deep)}.level-block-title{flex:1;font-family:var(--font-display);font-size:.9rem;font-weight:600;display:flex;align-items:baseline;gap:8px}.level-block-features{font-family:var(--font-body);font-size:.8rem;font-weight:400;color:var(--text-muted)}.level-block-status{font-size:.75rem;color:var(--text-muted)}.level-block-done .level-block-status{color:var(--success)}.level-block-chevron{color:var(--text-muted);font-size:.8rem;transition:transform .2s}.level-block-chevron-open{transform:rotate(180deg)}.level-block-content{padding:12px 14px 14px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border);margin-top:0}.level-section-label{display:block;font-family:var(--font-display);font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.level-features{display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start}.level-features .level-section-label{width:100%}.feature-pill{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:.82rem;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:4px;padding:6px 12px}.feature-pill-type{font-family:var(--font-display);font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-dim)}.feature-pill-hover{cursor:help;transition:border-color .15s,color .15s,background .15s}.feature-pill-hover:hover{border-color:var(--accent);background:var(--bg-hover)}.feature-pill-hover:hover .feature-pill-type{color:var(--accent-bright)}.level-proficiencies{padding-top:8px;border-top:1px dashed var(--border)}.prof-tags{display:flex;flex-wrap:wrap;gap:5px}.prof-tag{font-size:.72rem;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:3px;padding:2px 8px}.level-choices{display:flex;flex-direction:column;gap:12px}.choice-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.choice-row-vertical{flex-direction:column;align-items:flex-start}.choice-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);min-width:100px}.choice-label-note{font-family:var(--font-body);font-size:.72rem;font-weight:400;color:var(--text-muted);text-transform:none;letter-spacing:0}.choice-buttons{display:flex;gap:6px;flex-wrap:wrap}.choice-row-placeholder{opacity:.7}.choice-placeholder{font-size:.82rem;color:var(--text-muted);font-style:italic;background:var(--bg-surface);border:1px dashed var(--border);border-radius:4px;padding:6px 12px}.level-block .compact-list{max-height:400px;overflow-y:auto}.level-quick-picks{display:flex;gap:6px;margin-top:10px}.level-quick-btn{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:4px 12px;cursor:pointer;transition:all .15s}.level-quick-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.level-quick-btn-active{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}.choice-row-header{display:flex;align-items:center;justify-content:space-between;width:100%;gap:10px}.choice-selected-badge{font-size:.78rem;color:var(--accent-bright);background:#d4a24e1f;border:1px solid rgba(212,162,78,.25);border-radius:4px;padding:2px 10px}.feat-picker-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:10px 14px;cursor:pointer;color:var(--text-primary);font-family:var(--font-body);transition:all .15s}.feat-picker-toggle:hover{border-color:var(--border-strong);background:var(--bg-hover)}.feat-picker-toggle-open{border-color:var(--accent);border-bottom-left-radius:0;border-bottom-right-radius:0}.feat-picker-toggle-selected{border-color:var(--accent-dim)}.feat-picker-selected{display:flex;align-items:baseline;gap:8px}.feat-picker-selected-name{font-family:var(--font-display);font-weight:600;color:var(--accent-bright)}.feat-picker-selected-level{font-size:.75rem;color:var(--text-muted)}.feat-picker-placeholder{color:var(--text-muted)}.feat-picker-chevron{color:var(--text-muted);font-size:.8rem;transition:transform .2s}.feat-picker-chevron.open{transform:rotate(180deg)}.feat-picker-dropdown{background:var(--bg-elevated);border:1px solid var(--accent);border-top:none;border-radius:0 0 6px 6px;max-height:400px;overflow-y:auto}.feat-level-group{border-bottom:1px solid var(--border)}.feat-level-group:last-child{border-bottom:none}.feat-level-header{font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-dim);background:var(--bg-surface);padding:6px 14px;position:sticky;top:0;z-index:1}.feat-list{display:flex;flex-direction:column}.feat-option{display:flex;flex-direction:column;gap:4px;padding:10px 14px;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text-primary);font-family:var(--font-body);transition:background .12s}.feat-option:last-child{border-bottom:none}.feat-option:hover{background:var(--bg-hover)}.feat-option-active{background:var(--bg-active);border-left:3px solid var(--accent)}.feat-option-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.feat-option-name{font-family:var(--font-display);font-size:.94rem;font-weight:600}.feat-option-active .feat-option-name{color:var(--accent-bright)}.feat-option-traits{display:flex;align-items:center;gap:4px}.feat-option-prereq{font-size:.72rem;color:var(--text-muted);font-style:italic}.feat-option-effect{font-size:.85rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.feat-option-active .feat-option-effect{-webkit-line-clamp:unset}.action-icon{display:inline-flex;align-items:center;font-size:.9rem;color:var(--accent);margin-right:4px}.action-reaction{font-size:.85rem}.action-free{font-size:.8rem;opacity:.7}.skill-select{font-family:var(--font-body);font-size:.9rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:8px 32px 8px 12px;cursor:pointer;outline:none;width:100%;max-width:280px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='%23706858'%3E%3Cpath d='M4.427 6.427l3.396 3.396a.25.25 0 00.354 0l3.396-3.396A.25.25 0 0011.396 6H4.604a.25.25 0 00-.177.427z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .15s}.skill-select:focus{border-color:var(--accent)}.skill-select option{background:var(--bg-elevated);color:var(--text-primary)}.attribute-boost-grid{display:flex;flex-wrap:wrap;gap:6px}.boost-chip-disabled{opacity:.35;cursor:not-allowed}.boost-chip-disabled:hover{border-color:var(--border);background:var(--bg-card)}.choice-label-group{display:flex;align-items:center;gap:4px}.skill-grid{display:flex;flex-wrap:wrap;gap:6px}.skill-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:.82rem;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:5px;padding:6px 12px;cursor:pointer;transition:all .12s}.skill-chip:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-hover);color:var(--text-primary)}.skill-chip-active{color:var(--accent-bright);border-color:var(--accent);background:var(--bg-active)}.skill-chip-disabled{opacity:.4;cursor:not-allowed}.skill-chip-check{color:var(--success);font-size:.9rem}.feat-option-disabled{opacity:.5;cursor:not-allowed}.feat-option-disabled:hover{background:transparent}.feat-already-taken{font-family:var(--font-body);font-size:.72rem;font-weight:400;color:var(--text-muted);font-style:italic;margin-left:8px}.skill-increase-dropdown{max-height:350px}.skill-increase-list{display:flex;flex-direction:column}.skill-increase-option{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text-primary);font-family:var(--font-body);transition:background .12s}.skill-increase-option:last-child{border-bottom:none}.skill-increase-option:hover:not(:disabled){background:var(--bg-hover)}.skill-increase-option-active{background:var(--bg-active);border-left:3px solid var(--accent)}.skill-increase-option-disabled{opacity:.5;cursor:not-allowed}.skill-increase-option-disabled:hover{background:transparent}.skill-increase-name{font-family:var(--font-display);font-size:.85rem;font-weight:600}.skill-increase-option-active .skill-increase-name{color:var(--accent-bright)}.skill-increase-ranks{display:flex;align-items:center;gap:6px;font-size:.78rem}.rank-current{color:var(--text-muted)}.rank-arrow{color:var(--accent-dim)}.rank-next{color:var(--success);font-weight:600}.rank-reason{color:var(--text-muted);font-style:italic;font-size:.72rem}.prof-tag-hover{cursor:help;transition:border-color .15s,color .15s}.prof-tag-hover:hover{border-color:var(--accent-dim);color:var(--accent-bright)}.summary-section{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.summary-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.summary-row-main{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0}.summary-main-label{font-family:var(--font-display);font-size:.72rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.summary-main-value{font-size:.9rem;color:var(--text-primary);font-weight:500}.summary-section-title{display:block;font-family:var(--font-display);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}.summary-chips{display:flex;flex-wrap:wrap;gap:6px}.summary-chip{font-size:.78rem;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:4px 10px}.summary-missing{color:var(--error);font-style:italic}.summary-section-missing{background:#c452520d;border:1px solid rgba(196,82,82,.2);border-radius:6px;padding:12px;margin-top:1rem}.summary-missing-title{color:var(--error)}.summary-missing-list{list-style:none;padding:0;margin:0}.summary-missing-list li{font-size:.82rem;color:var(--text-secondary);padding:2px 0 2px 16px;position:relative}.summary-missing-list li:before{content:"•";position:absolute;left:0;color:var(--error)}.warning-panel{display:flex;align-items:center;gap:10px;background:#d4a24e14;border:1px solid rgba(212,162,78,.25);border-radius:6px;padding:12px 16px;margin-bottom:1.5rem;font-size:.9rem;color:var(--text-secondary)}.warning-icon{font-size:1.1rem;color:var(--accent)}.pick-section-count{font-family:var(--font-body);font-size:.75rem;font-weight:400;color:var(--text-muted);margin-left:8px;text-transform:none;letter-spacing:0}.boost-sources{display:flex;flex-direction:column;gap:8px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.boost-source-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}.boost-source-row:last-child{border-bottom:none}.boost-source-label{display:flex;align-items:baseline;gap:8px}.boost-source-name{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--text-primary)}.boost-source-sublabel{font-size:.75rem;color:var(--text-muted)}.boost-source-values{display:flex;gap:6px;flex-wrap:wrap}.boost-source-none{color:var(--text-muted);font-size:.85rem}.boost-chip-positive{color:var(--success);background:#5a9e6f1a;border-color:#5a9e6f40}.boost-chip-negative{color:var(--error);background:#c452521a;border-color:#c4525240}.attribute-boost-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.attribute-boost-card{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:14px 12px;cursor:pointer;transition:all .15s;position:relative;font-family:var(--font-body);color:var(--text-primary)}.attribute-boost-card:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-hover)}.attribute-boost-card-active{border-color:var(--accent);background:var(--bg-active)}.attribute-boost-card-active .attribute-boost-abbr{color:var(--accent-bright)}.attribute-boost-card-disabled{opacity:.4;cursor:not-allowed}.attribute-boost-abbr{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-secondary)}.attribute-boost-name{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.attribute-boost-preview{font-size:.85rem;color:var(--text-secondary);margin-top:4px}.attribute-boost-card-active .attribute-boost-preview{color:var(--success)}.attribute-boost-check{position:absolute;top:6px;right:8px;color:var(--success);font-size:.9rem}.attribute-scores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.attribute-score-card{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:14px;text-align:center}.attribute-score-header{display:flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:8px}.attribute-score-abbr{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--accent-bright)}.attribute-score-name{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.attribute-score-values{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-bottom:6px}.attribute-score-number{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--text-primary)}.attribute-score-mod{font-family:var(--font-display);font-size:1rem;font-weight:600}.mod-positive{color:var(--success)}.mod-negative{color:var(--error)}.attribute-score-breakdown{display:flex;justify-content:center;gap:8px;font-size:.72rem}.breakdown-boosts{color:var(--success)}.breakdown-flaws{color:var(--error)}.summary-attributes{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.summary-attr{display:flex;align-items:baseline;gap:4px;min-width:60px}.summary-attr-abbr{font-family:var(--font-display);font-size:.72rem;font-weight:600;color:var(--text-muted)}.summary-attr-mod{font-family:var(--font-display);font-size:1rem;font-weight:700}.skill-sources{display:flex;flex-direction:column;gap:8px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.skill-source-row{display:flex;align-items:flex-start;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);gap:16px}.skill-source-row:last-child{border-bottom:none}.skill-source-label{display:flex;flex-direction:column;gap:2px;min-width:120px}.skill-source-name{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--text-primary)}.skill-source-sublabel{font-size:.72rem;color:var(--text-muted)}.skill-source-values{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;flex:1}.skill-source-chip{font-size:.78rem;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:4px 10px;opacity:.85}.skill-source-chip-lore{color:var(--accent);border-color:var(--border-accent)}.skill-source-none{color:var(--text-muted);font-size:.82rem;font-style:italic}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.skill-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;transition:all .15s;cursor:help}.skill-card:hover{border-color:var(--border-strong);background:var(--bg-hover)}.skill-card-trained{border-color:var(--success);background:#5a9e6f0d}.skill-card-trained:hover{background:#5a9e6f1a}.skill-card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.skill-card-name{font-family:var(--font-display);font-size:.82rem;font-weight:600;color:var(--text-primary)}.skill-card-attr{font-size:.68rem;color:var(--text-muted);font-weight:500}.skill-card-mod{margin-bottom:6px}.skill-mod-value{font-family:var(--font-display);font-size:1.4rem;font-weight:700}.skill-card-breakdown{display:flex;flex-direction:column;align-items:flex-start;gap:3px;font-size:.72rem}.wiz-skill-prof-badge{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--success);background:#5a9e6f26;border-radius:3px;padding:2px 6px}.wiz-skill-prof-badge.skill-prof-untrained{color:var(--text-muted);background:var(--bg-surface)}.skill-breakdown-text{color:var(--text-muted)}.skill-card-source{font-size:.68rem;color:var(--text-muted);margin-top:6px;font-style:italic}.lore-skills-list{display:flex;flex-wrap:wrap;gap:10px}.lore-skill-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--accent-dim);border-radius:8px;padding:12px 16px;min-width:180px}.lore-skill-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.lore-skill-name{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--accent-bright)}.lore-skill-attr{font-size:.68rem;color:var(--text-muted);font-weight:500}.lore-skill-mod{margin-bottom:6px}.lore-skill-info{display:flex;align-items:center;gap:8px}.lore-skill-source{font-size:.7rem;color:var(--text-muted)}.summary-chip-lore{color:var(--accent);border-color:var(--border-accent)}@media (max-width: 768px){.level-selector{flex-direction:column;align-items:flex-start;gap:8px}.level-slider{max-width:100%;width:100%}.choice-row{flex-direction:column;align-items:flex-start;gap:6px}.choice-label{min-width:auto}.feat-picker-dropdown{max-height:300px}.skill-select{max-width:100%}.attribute-boost-selector,.attribute-scores-grid{grid-template-columns:repeat(2,1fr)}.summary-attributes{gap:8px}.summary-attr{min-width:50px}.skills-grid{grid-template-columns:repeat(2,1fr)}.skill-source-row{flex-direction:column;gap:8px}.skill-source-values{justify-content:flex-start}.feats-list{grid-template-columns:1fr}}.feats-empty{color:var(--text-muted);font-style:italic;font-size:.9rem;padding:12px 16px;background:var(--bg-surface);border:1px dashed var(--border);border-radius:6px}.feats-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.feat-card{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:8px;padding:14px 16px;transition:all .15s;cursor:help}.feat-card:hover{border-color:var(--border-strong);background:var(--bg-hover)}.feat-card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.feat-card-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary)}.feat-card-level{font-size:.72rem;color:var(--text-muted);font-weight:500}.feat-card-traits{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.feat-trait{font-size:.68rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:#d4a24e1a;border:1px solid rgba(212,162,78,.25);border-radius:3px;padding:2px 8px}.feat-card-description{font-size:.88rem;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.feat-card-effect{font-size:.82rem;color:var(--text-primary);line-height:1.5;background:var(--bg-surface);border-radius:4px;padding:10px 12px;margin-bottom:10px}.feat-card-source{font-size:.72rem;color:var(--text-muted);font-style:italic}.feats-note{display:flex;align-items:flex-start;gap:8px;margin-top:1rem;padding:10px 14px;background:#5c8ec414;border:1px solid rgba(92,142,196,.2);border-radius:6px;font-size:.85rem;color:var(--text-secondary)}.note-icon{color:#5c8ec4;font-size:1rem}.budget-panel{display:flex;flex-wrap:wrap;gap:16px;padding:16px 20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem}.budget-item{display:flex;flex-direction:column;gap:4px}.budget-item-remaining{margin-left:auto}.budget-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.budget-value{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary)}.budget-spent{color:var(--accent)}.budget-positive{color:var(--success)}.budget-negative{color:var(--error)}.shop-tabs{display:flex;gap:8px;margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:12px}.shop-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-family:var(--font-display);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.shop-tab:hover{background:var(--bg-hover);border-color:var(--border-strong)}.shop-tab-active{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}.shop-tab-icon{font-size:1rem}.shop-search{position:relative;margin-bottom:1rem}.shop-search-input{width:100%;padding:10px 36px 10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem}.shop-search-input:focus{outline:none;border-color:var(--accent-dim)}.shop-search-input::-moz-placeholder{color:var(--text-muted)}.shop-search-input::placeholder{color:var(--text-muted)}.shop-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px 8px}.shop-search-clear:hover{color:var(--text-primary)}.shop-content{max-height:400px;overflow-y:auto;padding-right:8px;margin-bottom:1.5rem}.shop-list{display:flex;flex-direction:column;gap:16px}.shop-category{margin-bottom:8px}.shop-category-title{font-family:var(--font-display);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.shop-items{display:flex;flex-direction:column;gap:6px}.shop-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;transition:all .15s}.shop-item:hover{background:var(--bg-hover);border-color:var(--border-strong)}.shop-item-owned{border-color:var(--success);background:#5a9e6f14}.shop-item-selectable{cursor:pointer}.shop-item-selected{border-color:var(--accent);background:#d4a24e1a}.shop-item-disabled{opacity:.5;cursor:not-allowed}.shop-item-main{flex:1;min-width:0}.shop-item-name{display:block;font-family:var(--font-display);font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-item-stats{font-size:.78rem;color:var(--text-secondary)}.shop-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;min-width:70px}.shop-item-price{font-size:.82rem;font-weight:500;color:var(--accent)}.shop-item-bulk{font-size:.7rem;color:var(--text-muted)}.shop-item-actions{display:flex;align-items:center;gap:6px}.shop-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:4px;background:var(--bg-surface);color:var(--text-primary);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .15s}.shop-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-dim)}.shop-btn:disabled{opacity:.4;cursor:not-allowed}.shop-btn-add{color:var(--success)}.shop-btn-remove{color:var(--error)}.shop-qty{font-size:.85rem;font-weight:600;color:var(--text-primary);min-width:20px;text-align:center}.shop-item-check{color:var(--accent);font-size:1.1rem;font-weight:600}.equipment-empty{color:var(--text-muted);font-style:italic;font-size:.9rem;padding:16px;background:var(--bg-surface);border:1px dashed var(--border);border-radius:6px;text-align:center}.owned-equipment{display:flex;flex-direction:column;gap:12px}.owned-section{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:12px 14px}.owned-section-title{display:block;font-family:var(--font-display);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.owned-items{display:flex;flex-direction:column;gap:6px}.owned-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-surface);border-radius:4px}.owned-item-name{flex:1;font-size:.9rem;color:var(--text-primary)}.owned-item-info{font-size:.78rem;color:var(--text-secondary)}.owned-item-remove{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s}.owned-item-remove:hover{color:var(--error);background:#c452521a}.summary-negative{color:var(--error)!important}.summary-warning-text{font-size:.85rem;color:var(--text-secondary);margin:0}@media (max-width: 600px){.budget-panel{gap:12px}.budget-item-remaining{margin-left:0;width:100%}.shop-tabs{flex-wrap:wrap}.shop-tab{flex:1;min-width:80px;justify-content:center;padding:8px 10px}.shop-tab-label{display:none}.shop-item{flex-wrap:wrap}.shop-item-meta{flex-direction:row;gap:10px}}.no-spells-panel{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 2rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:2rem}.no-spells-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.no-spells-title{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.no-spells-text{font-size:1.05rem;color:var(--text-secondary);margin-bottom:.5rem}.no-spells-text strong{color:var(--accent)}.no-spells-subtext{font-size:.9rem;color:var(--text-muted);max-width:500px;line-height:1.5}.traditions-intro{font-size:.95rem;color:var(--text-secondary);margin-bottom:1rem}.traditions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.tradition-card{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:8px;padding:14px 16px}.tradition-name{display:block;font-family:var(--font-display);font-size:.95rem;font-weight:600;margin-bottom:4px}.tradition-desc{font-size:.85rem;color:var(--text-secondary)}.spellcasting-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.spellcasting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.spellcasting-tradition{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--accent)}.spellcasting-type{font-size:.85rem;color:var(--text-secondary)}.spell-slots-info{color:var(--text-muted);font-style:italic}.summary-note{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.5}.warning-panel{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#c452521a;border:1px solid rgba(196,82,82,.3);border-radius:6px;color:var(--text-secondary);font-size:.9rem}.warning-icon{font-size:1.2rem;color:#d47a7a}.review-header{text-align:center;padding:1.5rem;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-card) 100%);border:1px solid var(--border);border-bottom:3px solid var(--accent);border-radius:12px;margin-bottom:1.5rem}.review-name-block{display:flex;align-items:baseline;justify-content:center;gap:12px;margin-bottom:.5rem}.review-character-name{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--accent);margin:0}.review-pronouns{font-size:.9rem;color:var(--text-muted);font-style:italic}.review-subtitle{font-family:var(--font-display);font-size:1.1rem;color:var(--text-secondary);margin-bottom:.25rem}.review-player{font-size:.85rem;color:var(--text-muted)}.review-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem;margin-bottom:1rem}.review-section-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.review-core-stats{display:flex;flex-wrap:wrap;gap:12px}.review-stat-box{flex:1;min-width:100px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;text-align:center}.review-stat-hp{border-color:#c45c5c;background:#c45c5c1a}.review-stat-ac{border-color:#5c8ec4;background:#5c8ec41a}.review-stat-label{display:block;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.review-stat-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary)}.review-attributes{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.review-attr{display:flex;flex-direction:column;align-items:center;padding:10px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.review-attr-abbr{font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.review-attr-mod{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--accent)}.review-attr-score{font-size:.75rem;color:var(--text-muted)}.review-saves{display:flex;gap:12px}.review-save{flex:1;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.review-save-name{font-size:.9rem;color:var(--text-secondary)}.review-save-value{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary)}.review-skills{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px}.review-skill{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;font-size:.85rem}.review-skill-trained{border-left:3px solid var(--success);background:#5a9e6f14}.review-skill-lore{border-left-color:var(--accent);background:#d4a24e14}.review-skill-name{color:var(--text-secondary)}.review-skill-trained .review-skill-name{color:var(--text-primary);font-weight:500}.review-skill-value{font-family:var(--font-display);font-weight:600;color:var(--text-muted)}.review-skill-trained .review-skill-value{color:var(--success)}.review-feats{display:flex;flex-direction:column;gap:8px}.review-feat{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.review-feat-name{font-family:var(--font-display);font-size:.95rem;font-weight:500;color:var(--text-primary)}.review-feat-type{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:2px 8px;background:var(--bg-surface);border-radius:3px}.review-features{display:flex;flex-direction:column;gap:8px}.review-feature{padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px}.review-feature-name{display:block;font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.review-feature-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.review-equipment{display:flex;flex-direction:column;gap:12px}.review-equip-group{padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.review-equip-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:6px}.review-equip-items{display:flex;flex-wrap:wrap;gap:6px}.review-equip-item{font-size:.9rem;color:var(--text-primary);padding:4px 10px;background:var(--bg-surface);border-radius:4px}.review-notes{font-size:.95rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;margin:0}.review-empty{font-size:.9rem;color:var(--text-muted);font-style:italic;margin:0}@media (max-width: 600px){.review-character-name{font-size:1.5rem}.review-name-block{flex-direction:column;gap:4px}.review-attributes{grid-template-columns:repeat(3,1fr)}.review-saves{flex-direction:column}.review-skills{grid-template-columns:1fr}}.racket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;width:100%}.racket-tile{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;color:var(--text-primary);font-family:var(--font-body)}.racket-tile:hover{border-color:var(--accent-dim);background:var(--bg-hover)}.racket-tile-active{border-color:var(--accent);background:var(--bg-active);box-shadow:0 0 12px #d4a24e26}.racket-tile-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary)}.racket-tile-active .racket-tile-name{color:var(--accent)}.racket-tile-key{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-dim)}.racket-tile-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.4}@media (max-width: 600px){.racket-grid{grid-template-columns:1fr}}.spellbook-stats-bar{display:flex;flex-wrap:wrap;gap:2px;padding:12px 16px;background:linear-gradient(135deg,#7b68ee0f,#7b68ee05);border:1px solid rgba(123,104,238,.2);border-radius:8px;margin-bottom:1.5rem}.spellbook-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;min-width:80px;cursor:help}.spellbook-stat-label{font-family:var(--font-display);font-size:.58rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.spellbook-stat-value{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--text-primary);text-transform:capitalize}.spellbook-subclass-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-bottom:1.5rem}.spellbook-subclass-card{background:var(--bg-surface);border:1px solid rgba(123,104,238,.2);border-left:3px solid #7b68ee;border-radius:6px;padding:14px 16px}.spellbook-subclass-type{display:block;font-family:var(--font-display);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#7b68ee;margin-bottom:4px}.spellbook-subclass-name{display:block;font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:6px}.spellbook-subclass-effect{font-size:.82rem;color:var(--text-secondary);line-height:1.45;margin:0}.spellbook-subclass-effect strong{color:var(--accent)}.spellbook-container{background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg),inset 0 1px #d4a24e0d;margin-bottom:1.5rem;background-image:radial-gradient(ellipse at 20% 0%,rgba(123,104,238,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(212,162,78,.03) 0%,transparent 50%)}.spellbook-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:linear-gradient(180deg,rgba(123,104,238,.08) 0%,transparent 100%);border-bottom:1px solid var(--border)}.spellbook-title-area{display:flex;align-items:center;gap:10px}.spellbook-ornament{color:var(--accent-dim);font-size:1rem;opacity:.6}.spellbook-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:.06em;margin:0}.spellbook-mode-toggle{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:3px}.spellbook-mode-btn{font-family:var(--font-body);font-size:.78rem;font-weight:500;padding:6px 14px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s;white-space:nowrap}.spellbook-mode-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.spellbook-mode-active{background:#7b68ee26!important;color:#a899f0!important;font-weight:600}.spellbook-body{display:grid;grid-template-columns:240px 1fr;min-height:500px}.spellbook-page{padding:16px}.spellbook-page-left{background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:12px;box-shadow:inset -4px 0 12px #00000026}.spellbook-page-right{display:flex;flex-direction:column;gap:12px;overflow:hidden}.spellbook-page-header{padding-bottom:8px;border-bottom:1px solid var(--border)}.spellbook-page-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--text-primary);letter-spacing:.04em}.spellbook-page-subtitle{font-family:var(--font-body);font-size:.72rem;font-weight:400;color:var(--text-muted);letter-spacing:0;text-transform:none;margin-left:4px}.spellbook-rank-tabs{display:flex;flex-direction:column;gap:4px}.spellbook-slot-tab{display:grid;grid-template-columns:28px 1fr auto;grid-template-rows:auto auto;gap:0 8px;align-items:center;padding:8px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;font-family:var(--font-body);color:var(--text-primary);text-align:left}.spellbook-slot-tab:hover{border-color:var(--border-strong);background:var(--bg-hover)}.spellbook-slot-tab-active{border-color:#7b68ee;background:#7b68ee1a;box-shadow:0 0 8px #7b68ee1a}.spellbook-slot-rank{grid-row:1 / 3;grid-column:1;font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text-muted);text-align:center}.spellbook-slot-tab-active .spellbook-slot-rank{color:#a899f0}.spellbook-slot-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);grid-column:2}.spellbook-slot-tab-active .spellbook-slot-label{color:var(--text-primary)}.spellbook-slot-dots{display:flex;gap:3px;grid-column:2}.spellbook-slot-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-deep);border:1px solid var(--border-strong);transition:all .2s}.spellbook-slot-dot-filled{background:#7b68ee;border-color:#7b68ee;box-shadow:0 0 4px #7b68ee66}.spellbook-slot-count{grid-row:1 / 3;grid-column:3;font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.spellbook-slot-tab-active .spellbook-slot-count{color:#a899f0}.spellbook-allowance-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;margin-bottom:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:.8rem}.spellbook-allowance-item{display:flex;align-items:center;gap:8px}.spellbook-allowance-icon{font-size:1.3rem}.spellbook-allowance-item strong{color:var(--accent);font-family:var(--font-display);font-size:.78rem;display:block}.spellbook-allowance-detail{font-size:.72rem;color:var(--text-secondary);display:block}.spellbook-allowance-counts{display:flex;gap:8px;flex-shrink:0}.spellbook-allowance-badge{padding:3px 10px;border-radius:12px;font-size:.68rem;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap}.spellbook-badge-full{background:#d4a24e26;border-color:var(--accent-dim);color:var(--accent)}.spellbook-overlimit-notice{display:flex;align-items:center;gap:8px;padding:8px 14px;margin-bottom:14px;background:#c452521f;border:1px solid rgba(196,82,82,.35);border-radius:6px;font-size:.75rem;color:var(--text-primary)}.spellbook-overlimit-notice span:first-child{font-size:1rem}.spellbook-in-book-badge{font-size:.75rem;opacity:.7;margin-right:4px}.spellbook-bond-reminder{display:flex;gap:10px;padding:12px;background:#d4a24e0f;border:1px solid rgba(212,162,78,.15);border-radius:6px;font-size:.78rem;color:var(--text-secondary);line-height:1.4;margin-top:auto}.spellbook-bond-reminder strong{color:var(--accent);font-family:var(--font-display);font-size:.72rem;letter-spacing:.04em;display:block;margin-bottom:2px}.spellbook-bond-reminder p{margin:0}.spellbook-bond-icon{color:var(--accent);font-size:1.2rem;flex-shrink:0}.spellbook-search{position:relative}.spellbook-search-input{width:100%;padding:8px 32px 8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);font-size:.88rem;outline:none;transition:border-color .15s}.spellbook-search-input:focus{border-color:#7b68ee;box-shadow:0 0 0 2px #7b68ee26}.spellbook-search-input::-moz-placeholder{color:var(--text-muted)}.spellbook-search-input::placeholder{color:var(--text-muted)}.spellbook-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:2px 6px}.spellbook-search-clear:hover{color:var(--text-primary)}.spellbook-spell-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding-right:4px;max-height:440px}.spellbook-empty{text-align:center;color:var(--text-muted);font-style:italic;padding:40px 20px;font-size:.9rem}.spellbook-spell-card{display:flex;flex-direction:column;gap:4px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;text-align:left;font-family:var(--font-body);color:var(--text-primary);width:100%}.spellbook-spell-card:hover{border-color:var(--border-strong);background:var(--bg-hover)}.spellbook-spell-selected{border-color:#7b68ee;background:#7b68ee14;box-shadow:0 0 6px #7b68ee1a}.spellbook-spell-selected:hover{background:#7b68ee1f}.spellbook-spell-disabled{opacity:.45;cursor:not-allowed}.spellbook-spell-disabled:hover{border-color:var(--border);background:var(--bg-card)}.spellbook-spell-header{display:flex;align-items:center;gap:8px}.spellbook-spell-check{font-size:.9rem;color:var(--text-muted);flex-shrink:0;width:18px;text-align:center}.spellbook-spell-selected .spellbook-spell-check{color:#7b68ee}.spellbook-spell-title{flex:1;display:flex;align-items:baseline;gap:8px;min-width:0}.spellbook-spell-name{font-family:var(--font-display);font-size:.88rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spellbook-spell-selected .spellbook-spell-name{color:#c5b4ff}.spellbook-spell-actions{font-size:.7rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.spellbook-spell-expand{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:2px 6px;transition:color .15s;flex-shrink:0}.spellbook-spell-expand:hover{color:var(--text-primary)}.spellbook-spell-traits{display:flex;flex-wrap:wrap;gap:4px;padding-left:26px}.spellbook-trait{display:inline-block;font-family:var(--font-display);font-size:.55rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#a899f0;background:#7b68ee1a;border:1px solid rgba(123,104,238,.2);border-radius:3px;padding:1px 6px}.spellbook-meta-tag{display:inline-block;font-size:.6rem;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:3px;padding:1px 6px}.spellbook-spell-brief{font-size:.78rem;color:var(--text-muted);line-height:1.4;margin:0;padding-left:26px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.spellbook-spell-selected .spellbook-spell-brief{color:var(--text-secondary);-webkit-line-clamp:2}.spellbook-spell-details{padding:8px 12px 4px 26px;border-top:1px dashed var(--border);margin-top:4px}.spellbook-spell-effect{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin:0 0 6px}.spellbook-spell-heighten{font-size:.78rem;color:var(--text-muted);line-height:1.4;margin:0 0 4px;font-style:italic}.spellbook-heighten-label{color:var(--accent-dim);font-weight:600;font-style:normal}.spellbook-spell-meta-line{font-size:.75rem;color:var(--text-muted);margin:0 0 2px}.spellbook-footer-ornament{text-align:center;padding:10px;color:var(--text-muted);font-size:.85rem;opacity:.4;letter-spacing:.3em;border-top:1px solid var(--border)}@media (max-width: 768px){.spellbook-body{grid-template-columns:1fr}.spellbook-page-left{box-shadow:none;border-right:none;border-bottom:1px solid var(--border)}.spellbook-rank-tabs{flex-direction:row;flex-wrap:wrap;gap:4px}.spellbook-slot-tab{grid-template-columns:auto 1fr;grid-template-rows:auto;min-width:0;padding:6px 10px}.spellbook-slot-rank{grid-row:1}.spellbook-slot-dots{display:none}.spellbook-slot-count{grid-row:1;grid-column:3}.spellbook-stats-bar{gap:0}.spellbook-stat{padding:6px 10px;min-width:60px}.spellbook-subclass-row{grid-template-columns:1fr}.spellbook-mode-toggle{flex-direction:column}.spellbook-header{flex-direction:column;gap:10px;align-items:flex-start}.spellbook-spell-list{max-height:350px}.spellbook-bond-reminder{display:none}}@media print{@page{size:A4;margin:0}.player-shell,.player-shell>*:not(.sheet-modal-overlay),.sheet-modal-overlay>*:not(.sheet-modal),.sheet-modal>.sheet-modal-toolbar{display:none!important}.sheet-modal-overlay{position:static!important;background:none!important;overflow:visible!important}.sheet-modal{position:static!important;width:100%!important;max-width:none!important;max-height:none!important;overflow:visible!important;box-shadow:none!important;background:#fff!important;border-radius:0!important;display:block!important}.sheet-modal-content{overflow:visible!important;max-height:none!important;padding:0!important}html,body{margin:0!important;padding:0!important;background:#fff!important;color:#000!important;overflow:visible!important;height:auto!important;min-height:auto!important;max-height:none!important}#root{min-height:auto!important;height:auto!important}.wizard-container{display:block!important;overflow:visible!important;min-height:auto!important;max-height:none!important;background:#fff!important}.wizard-header,.wizard-sidebar,.wizard-nav-footer,.wizard-mobile-nav,.wizard-step-header,.wizard-progress-track,.wizard-identity-bar,.no-print,.sheet-controls{display:none!important}.wizard-body{display:block!important;overflow:visible!important}.wizard-content{display:block!important;overflow:visible!important;background:#fff!important;background-image:none!important}.wizard-content-inner{padding:0!important;overflow:visible!important;display:block!important}.wizard-content-inner>*,.wizard-step-content{max-width:none!important}.sheet-step,.character-sheet-preview{background:#fff!important}.save-load-bar,.slb-toast,.slb-overlay{display:none!important}}.save-load-bar{display:flex;align-items:center;gap:.35rem;margin-left:auto;flex-shrink:0}.slb-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .65rem;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:5px;font-family:var(--font-body);font-size:.78rem;cursor:pointer;transition:all .15s var(--ease-out);white-space:nowrap}.slb-btn:hover,.slb-btn:focus-visible{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.slb-btn-save{background:#d4a24e1f;color:var(--accent);border-color:var(--border-accent)}.slb-btn-save:hover{background:#d4a24e38;color:var(--accent-bright)}.slb-btn-danger{color:var(--error);border-color:#c452524d}.slb-btn-danger:hover{background:#c4525226}.slb-btn-small{padding:.2rem .5rem;font-size:.72rem}.slb-saved-indicator{font-size:.72rem;color:var(--success);opacity:.8;padding-left:.3rem;display:flex;align-items:center;gap:.3rem;white-space:nowrap}.slb-cloud-syncing{color:#8bb8d4;animation:slb-cloud-pulse 1.2s ease-in-out infinite}.slb-cloud-synced{color:var(--success)}.slb-cloud-error{color:#c47a52}@keyframes slb-cloud-pulse{0%,to{opacity:.85}50%{opacity:.4}}.slb-retry-btn{background:none;border:1px solid currentColor;border-radius:4px;color:inherit;cursor:pointer;font-size:.68rem;padding:0 .35rem;line-height:1.4;opacity:.85;transition:opacity .15s}.slb-retry-btn:hover{opacity:1}.slb-conflict-modal{max-width:440px}.slb-conflict-title{font-family:var(--font-display);color:var(--accent-gold);font-size:1rem;margin:0}.slb-conflict-body{padding:1.2rem 1.5rem 1.4rem;display:flex;flex-direction:column;gap:1rem}.slb-conflict-subtitle{color:var(--text-muted);font-size:.83rem;margin:0;line-height:1.5}.slb-conflict-options{display:flex;gap:.75rem}.slb-conflict-option{flex:1;padding:.85rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);color:var(--text-primary);font-family:var(--font-body);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.slb-conflict-option:hover:not(:disabled){border-color:var(--accent-gold);background:#d4a24e14}.slb-conflict-option:disabled{opacity:.55;cursor:not-allowed}.slb-conflict-option-cloud{border-color:#8bb8d459}.slb-conflict-option-cloud:hover:not(:disabled){border-color:#8bb8d4;background:#8bb8d414}.slb-conflict-option-label{font-weight:600;font-size:.88rem;margin-bottom:.3rem}.slb-conflict-option-hint{color:var(--text-muted);font-size:.75rem}.slb-toast{position:fixed;bottom:max(1.5rem,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);padding:.6rem 1.2rem;border-radius:8px;font-family:var(--font-body);font-size:.85rem;z-index:9999;animation:slb-toast-in .3s var(--ease-out);pointer-events:none}.slb-toast-success{background:#5a9e6fe6;color:#fff;box-shadow:0 4px 20px #5a9e6f4d}.slb-toast-error{background:#c45252e6;color:#fff;box-shadow:0 4px 20px #c452524d}.slb-toast-info{background:#5a8fa6e6;color:#fff;box-shadow:0 4px 20px #5a8fa64d}@keyframes slb-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.slb-overlay{position:fixed;inset:0;background:#000000b3;z-index:9000;display:flex;align-items:center;justify-content:center;animation:slb-fade-in .2s ease}@keyframes slb-fade-in{0%{opacity:0}to{opacity:1}}.slb-modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:12px;width:90%;max-width:560px;max-height:80vh;max-height:min(80vh,var(--app-visible-height, 80vh) - 32px);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slb-modal-in .25s var(--ease-out)}@keyframes slb-modal-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.slb-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.slb-modal-header h3{margin:0;font-family:var(--font-display);font-size:1.1rem;color:var(--accent)}.slb-modal-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:.25rem;line-height:1}.slb-modal-close:hover{color:var(--text-primary)}.slb-modal-toolbar{display:flex;align-items:center;gap:.35rem;padding:.6rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.slb-toolbar-spacer{flex:1}.slb-modal-count{font-family:var(--font-body);font-size:.8rem;font-weight:400;color:var(--text-muted)}.slb-modal-footer{padding:.5rem 1.25rem;border-top:1px solid var(--border);font-size:.7rem;color:var(--text-muted);text-align:center}.slb-char-current{display:inline-block;font-family:var(--font-body);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:#d4a24e26;border:1px solid rgba(212,162,78,.3);border-radius:3px;padding:0 5px;margin-left:6px;vertical-align:middle}.slb-confirm-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--error);margin:0 0 .5rem}.slb-confirm-text{font-size:.85rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.45}.slb-overlay-top{z-index:9500}.slb-autosave-banner{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.25rem;background:#5a8fa614;border-bottom:1px solid rgba(90,143,166,.2)}.slb-autosave-info{display:flex;flex-direction:column;gap:.1rem}.slb-autosave-label{font-size:.72rem;color:var(--info);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.slb-autosave-name{font-size:.82rem;color:var(--text-secondary)}.slb-char-list{overflow-y:auto;padding:.5rem;flex:1;min-height:0}.slb-empty{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.slb-empty p{margin:.25rem 0}.slb-empty-hint{font-size:.8rem;opacity:.7}.slb-char-card{display:flex;align-items:center;padding:.65rem .75rem;border-radius:8px;border:1px solid transparent;transition:all .15s var(--ease-out);margin-bottom:.35rem}.slb-char-card:hover{background:var(--bg-hover);border-color:var(--border)}.slb-char-card-active{border-color:var(--border-accent)!important;background:#d4a24e0f}.slb-char-info{flex:1;display:flex;flex-direction:column;gap:.1rem;cursor:pointer;min-width:0}.slb-char-name{font-family:var(--font-display);font-size:.92rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slb-char-detail{font-size:.78rem;color:var(--text-secondary)}.slb-char-date{font-size:.7rem;color:var(--text-muted)}.slb-char-actions{display:flex;align-items:center;gap:.2rem;flex-shrink:0;margin-left:.5rem}.slb-icon-btn{background:none;border:1px solid transparent;border-radius:5px;padding:.3rem;cursor:pointer;font-size:.9rem;line-height:1;transition:all .15s ease}.slb-icon-btn:hover{background:var(--bg-card);border-color:var(--border)}.slb-icon-btn-danger:hover{background:#c452521f;border-color:#c452524d}.slb-confirm{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:10px;padding:1.5rem;max-width:340px;text-align:center;box-shadow:var(--shadow-lg)}.slb-confirm p{margin:0 0 1rem;color:var(--text-primary);font-size:.95rem}.slb-confirm-actions{display:flex;gap:.5rem;justify-content:center}@media (max-width: 768px){.save-load-bar{gap:.2rem}.slb-btn{padding:.25rem .4rem;font-size:.7rem}.slb-saved-indicator{display:none}}.deity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.5rem}.deity-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.2rem;padding:.65rem .5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s ease;font-family:var(--font-body)}.deity-card:hover{border-color:var(--accent);background:#d4a24e0f}.deity-card-active{border-color:var(--accent);background:#d4a24e1f;box-shadow:0 0 0 2px #d4a24e40}.deity-card-name{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text-primary)}.deity-card-active .deity-card-name{color:var(--accent)}.deity-card-title{font-size:.7rem;color:var(--text-muted);font-style:italic}.deity-card-font{font-size:.7rem;color:var(--text-secondary);margin-top:.15rem}.deity-card-weapon{font-size:.65rem;color:var(--text-muted)}.deity-card-custom{border-style:dashed;opacity:.8}.deity-card-custom:hover{opacity:1}.deity-card-custom.deity-card-active{opacity:1;border-style:solid}.deity-detail-card{margin-top:1rem;border:1px solid var(--accent);border-radius:var(--radius);background:var(--bg-elevated);overflow:hidden}.deity-detail-header{display:flex;align-items:baseline;gap:.75rem;padding:.75rem 1rem;background:#d4a24e14;border-bottom:1px solid var(--border)}.deity-detail-name{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--accent);margin:0}.deity-detail-title{font-size:.8rem;font-style:italic;color:var(--text-muted)}.deity-detail-collapse{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:.2rem .4rem}.deity-detail-collapse:hover{color:var(--accent)}.deity-detail-body{padding:.75rem 1rem}.deity-detail-row{margin-bottom:.6rem}.deity-detail-row:last-child{margin-bottom:0}.deity-detail-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.15rem}.deity-detail-value{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.deity-detail-anathema{color:var(--error)}.deity-detail-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem 1rem;margin:.75rem 0;padding:.65rem .75rem;background:#00000026;border-radius:var(--radius)}.deity-stat{display:flex;flex-direction:column}.deity-stat-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.deity-stat-value{font-size:.82rem;color:var(--text-primary)}.deity-detail-collapsed{display:flex;flex-direction:column;width:100%;margin-top:.75rem;padding:.6rem 1rem;background:#d4a24e0f;border:1px solid rgba(212,162,78,.25);border-radius:var(--radius);cursor:pointer;transition:all .15s ease;text-align:left}.deity-detail-collapsed:hover{border-color:var(--accent);background:#d4a24e1a}.deity-collapsed-name{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--accent)}.deity-collapsed-stats{font-size:.75rem;color:var(--text-secondary);margin-top:.15rem}.deity-collapsed-expand{font-size:.7rem;color:var(--text-muted);margin-top:.25rem}.deity-font-auto{font-size:.7rem;color:var(--accent);font-style:italic;margin-left:.5rem}.racket-tile:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}@media (max-width: 480px){.deity-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.deity-detail-stats{grid-template-columns:1fr 1fr}}.selection-page{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg-deep)}.selection-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:var(--header-height);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.selection-logo{display:flex;align-items:center;gap:12px}.selection-chosen-badge{font-family:var(--font-display);font-size:.85rem;color:var(--accent);background:var(--bg-elevated);border:1px solid var(--border-accent);padding:6px 16px;border-radius:20px}.selection-chosen-label{color:var(--text-secondary);font-family:var(--font-body);margin-right:4px}.selection-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 32px 60px;overflow-y:auto}.selection-prompt{text-align:center;margin-bottom:40px;max-width:600px}.selection-prompt-title{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--accent);margin:0 0 12px;letter-spacing:.02em}.selection-prompt-subtitle{font-family:var(--font-body);font-size:1.1rem;color:var(--text-secondary);line-height:1.6;margin:0}.selection-back-btn{display:inline-block;margin-bottom:16px;background:none;border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;padding:6px 16px;border-radius:6px;cursor:pointer;transition:all .2s}.selection-back-btn:hover{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-glow)}.selection-step-indicator{display:flex;justify-content:center;gap:10px;margin-top:20px}.selection-step-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:all .3s}.selection-step-dot.active{background:var(--accent);box-shadow:0 0 8px #d4a24e80}.selection-step-dot.completed{background:var(--success)}.selection-grid{display:grid;gap:24px;width:100%;max-width:1100px}.selection-grid.class-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}.selection-grid.ancestry-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.selection-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 20px 22px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .3s var(--ease-out);position:relative;overflow:hidden}.selection-card:before{content:"";position:absolute;inset:0;border-radius:12px;background:radial-gradient(ellipse at top,var(--card-glow, transparent) 0%,transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}.selection-card:hover{border-color:var(--card-accent, var(--accent));transform:translateY(-4px);box-shadow:0 8px 30px #00000080,0 0 20px var(--card-glow, transparent)}.selection-card:hover:before{opacity:1}.selection-card:active{transform:translateY(-1px)}.selection-card-icon-wrap{width:80px;height:80px;margin-bottom:16px;position:relative;z-index:1}.selection-card-icon{width:100%;height:100%}.selection-card-name{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0 0 8px;position:relative;z-index:1;transition:color .3s}.selection-card:hover .selection-card-name{color:var(--card-accent, var(--accent))}.selection-card-tagline{font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0 0 16px;flex:1;position:relative;z-index:1}.selection-card-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding-top:14px;border-top:1px solid var(--border);width:100%;position:relative;z-index:1}.selection-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.selection-stat-label{font-family:var(--font-body);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.selection-stat-value{font-family:var(--font-display);font-size:.8rem;font-weight:500;color:var(--text-primary)}.selection-card-arrow{margin-top:14px;font-family:var(--font-display);font-size:.8rem;color:var(--card-accent, var(--accent));opacity:0;transform:translateY(6px);transition:all .3s var(--ease-out);position:relative;z-index:1}.selection-card:hover .selection-card-arrow{opacity:1;transform:translateY(0)}.selection-footer{display:flex;justify-content:center;align-items:center;gap:8px;padding:16px;background:var(--bg-surface);border-top:1px solid var(--border);font-family:var(--font-body);font-size:.8rem;color:var(--text-muted);flex-shrink:0}@media (max-width: 768px){.selection-main{padding:24px 16px 40px}.selection-prompt-title{font-size:1.5rem}.selection-grid.class-grid,.selection-grid.ancestry-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.selection-card{padding:20px 14px 16px}.selection-card-icon-wrap{width:60px;height:60px}.selection-card-name{font-size:1.05rem}}@media (max-width: 480px){.selection-header{padding:0 16px}.selection-grid.class-grid,.selection-grid.ancestry-grid{grid-template-columns:1fr 1fr;gap:12px}.selection-card-tagline{font-size:.78rem}.selection-card-stats{gap:6px}.selection-chosen-badge{font-size:.75rem;padding:4px 10px}}.hc-home{min-height:100vh;min-height:100dvh;background:var(--bg-deep);display:flex;flex-direction:column;align-items:center;padding:0 24px 60px;position:relative;overflow:hidden}.hc-home-particles{position:fixed;inset:0;pointer-events:none;z-index:0}.hc-particle{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);background:var(--accent);border-radius:50%;opacity:0;animation:hc-float var(--dur) var(--delay) ease-in-out infinite}@keyframes hc-float{0%,to{opacity:0;transform:translateY(0)}50%{opacity:.35;transform:translateY(-20px)}}.hc-home-header{width:100%;max-width:960px;display:flex;align-items:center;justify-content:space-between;padding:40px 0 20px;position:relative;z-index:1}.hc-home-logo{display:flex;align-items:center;gap:14px}.hc-home-logo-icon{font-size:2rem;filter:drop-shadow(0 0 8px rgba(212,162,78,.4))}.hc-home-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.1}.hc-home-title-accent{color:var(--accent)}.hc-home-subtitle{font-family:var(--font-body);font-size:.8rem;color:var(--text-secondary);letter-spacing:.02em}.hc-home-author{font-family:var(--font-body);font-size:.8rem;color:var(--text-muted)}.hc-home-author a{color:var(--accent-dim);text-decoration:none}.hc-home-author a:hover{color:var(--accent);text-decoration:underline}.hc-home-toolbar{width:100%;max-width:960px;display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border);margin-bottom:8px;position:relative;z-index:1}.hc-home-toolbar-right{display:flex;gap:8px}.hc-home-btn{font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;padding:8px 18px;border-radius:6px;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s var(--ease-out)}.hc-home-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-dim)}.hc-home-btn-primary{background:linear-gradient(135deg,#5a3a1a,#3a2510);border-color:var(--accent-dim);color:var(--accent-bright)}.hc-home-btn-primary:hover{background:linear-gradient(135deg,#6b4a22,#4a3018);box-shadow:0 0 16px #d4a24e33}.hc-home-btn-danger{border-color:#5a2020;color:#c45252}.hc-home-btn-danger:hover{background:#2a1515;border-color:#c45252}.hc-home-btn-large{padding:14px 32px;font-size:.9rem}.hc-home-count{width:100%;max-width:960px;font-family:var(--font-body);font-size:.85rem;color:var(--text-muted);margin:8px 0 4px;position:relative;z-index:1}.hc-home-grid{width:100%;max-width:960px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:12px 0;position:relative;z-index:1}.hc-char-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--card-accent, var(--accent));border-radius:8px;padding:16px;position:relative;transition:all .25s var(--ease-out);animation:hc-card-in .4s var(--ease-out) backwards}.hc-char-card:hover{border-color:var(--card-accent, var(--accent));box-shadow:0 4px 20px #0006,0 0 0 1px var(--card-accent);transform:translateY(-2px)}@keyframes hc-card-in{0%{opacity:0;transform:translateY(12px)}}.hc-card-active-badge{position:absolute;top:8px;right:8px;font-family:var(--font-display);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border-radius:4px;background:#5a9e6f33;color:var(--success);border:1px solid rgba(90,158,111,.3)}.hc-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.hc-card-class-icon{font-size:1.4rem;flex-shrink:0}.hc-card-identity{min-width:0}.hc-card-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hc-card-subtitle{font-family:var(--font-body);font-size:.82rem;color:var(--text-secondary)}.hc-card-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;padding:8px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.hc-card-stat{font-family:var(--font-body);font-size:.78rem;color:var(--text-muted);white-space:nowrap}.hc-card-actions{display:flex;gap:6px;margin-bottom:8px}.hc-card-btn{font-family:var(--font-display);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:6px 12px;border-radius:5px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .2s var(--ease-out)}.hc-card-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.hc-card-btn-build{border-color:var(--accent-dim);color:var(--accent)}.hc-card-btn-build:hover{background:#d4a24e1a}.hc-card-btn-play{border-color:#5a9e6f66;color:var(--success)}.hc-card-btn-play:hover{background:#5a9e6f1a}.hc-card-btn-icon{padding:6px 8px;font-size:.85rem;min-width:30px;justify-content:center}.hc-card-btn-danger{border-color:#3a1a1a;color:#a04040}.hc-card-btn-danger:hover{background:#2a1212;color:#c45252;border-color:#c45252}.hc-card-footer{display:flex;justify-content:flex-end}.hc-card-saved{font-family:var(--font-body);font-size:.72rem;color:var(--text-muted)}.hc-home-empty{text-align:center;padding:80px 20px;position:relative;z-index:1}.hc-home-empty-icon{font-size:3rem;margin-bottom:16px;filter:drop-shadow(0 0 12px rgba(212,162,78,.3))}.hc-home-empty h2{font-family:var(--font-display);font-size:1.4rem;color:var(--text-primary);margin:0 0 8px}.hc-home-empty p{font-family:var(--font-body);font-size:1rem;color:var(--text-secondary);margin:0 0 28px}.hc-home-footer{width:100%;max-width:960px;font-family:var(--font-body);font-size:.75rem;color:var(--text-muted);text-align:center;padding:24px 0;margin-top:auto;position:relative;z-index:1}.hc-toast{position:fixed;bottom:max(24px,env(safe-area-inset-bottom));right:max(24px,env(safe-area-inset-right));font-family:var(--font-body);font-size:.9rem;padding:12px 20px;border-radius:8px;color:var(--text-primary);z-index:9999;animation:hc-toast-in .3s var(--ease-out);box-shadow:var(--shadow-lg)}.hc-toast-success{background:#1a3020;border:1px solid #2a5a3a}.hc-toast-error{background:#301a1a;border:1px solid #5a2a2a}.hc-toast-info{background:#1a2530;border:1px solid #2a3a5a}@keyframes hc-toast-in{0%{opacity:0;transform:translateY(12px)}}@media (max-width: 600px){.hc-home-header{flex-direction:column;align-items:flex-start;gap:8px}.hc-home-toolbar{flex-direction:column;gap:10px}.hc-home-grid{grid-template-columns:1fr}.hc-card-actions{flex-wrap:wrap}}.pm-shell{min-height:100vh;min-height:100dvh;background:var(--bg-deep);display:flex;flex-direction:column}.pm-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.pm-header-left{display:flex;align-items:center;gap:12px}.pm-header-home-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:6px 8px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.pm-header-home-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent-dim)}.pm-header-identity{min-width:0}.pm-header-name{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-header-subtitle{font-family:var(--font-body);font-size:.8rem;color:var(--text-secondary)}.pm-header-right{display:flex;gap:8px;flex-shrink:0}.pm-header-btn{font-family:var(--font-display);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:7px 14px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .2s}.pm-header-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-dim)}.pm-status-bar{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding:12px 24px;background:var(--bg-surface);border-bottom:2px solid var(--border-strong);position:sticky;top:53px;z-index:99}.pm-status-section{display:flex;flex-direction:column;align-items:center;gap:2px}.pm-status-section label{font-family:var(--font-display);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.pm-status-value{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-primary)}.pm-status-danger{color:var(--error)!important}.pm-status-warn{color:var(--accent)!important}.pm-status-hp{flex-direction:row;align-items:center;gap:8px}.pm-status-hp label{font-size:.7rem}.pm-hp-display{display:flex;align-items:baseline;gap:2px}.pm-hp-current{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text-primary)}.pm-hp-separator{font-family:var(--font-display);font-size:1rem;color:var(--text-muted)}.pm-hp-max{font-family:var(--font-display);font-size:1rem;color:var(--text-secondary)}.pm-hp-temp{font-family:var(--font-body);font-size:.75rem;color:var(--info);padding:2px 6px;background:#5a8fa61a;border-radius:4px}.pm-hero-dots{display:flex;gap:4px}.pm-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-strong);background:transparent;transition:all .2s}.pm-dot-filled{background:var(--accent);border-color:var(--accent);box-shadow:0 0 6px #d4a24e66}.pm-status-conditions{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}.pm-condition-chip{font-family:var(--font-display);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:3px 10px;border-radius:4px;background:#c4525226;color:#e06060;border:1px solid rgba(196,82,82,.25)}.pm-status-xp{flex-direction:row;align-items:center;gap:8px;margin-left:auto}.pm-status-xp label{font-size:.7rem}.pm-xp-bar{width:100px;height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}.pm-xp-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s var(--ease-out)}.pm-xp-text{font-family:var(--font-body);font-size:.72rem;color:var(--text-muted);white-space:nowrap}.pm-tabs{display:flex;gap:0;padding:0 24px;background:var(--bg-surface);border-bottom:1px solid var(--border);overflow-x:auto}.pm-tab{font-family:var(--font-display);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:12px 20px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:6px;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.pm-tab:hover{color:var(--text-secondary);background:#ffffff05}.pm-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.pm-tab-icon{font-size:1rem}.pm-panel-content{flex:1;padding:24px;max-width:960px;width:100%;margin:0 auto}.pm-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;min-height:300px}.pm-placeholder-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.pm-placeholder-title{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--text-primary);margin:0 0 8px}.pm-placeholder-desc{font-family:var(--font-body);font-size:.95rem;color:var(--text-secondary);margin:0 0 20px;max-width:400px}.pm-placeholder-tag{font-family:var(--font-display);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:4px 14px;border-radius:4px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.pm-quick-actions{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 24px;background:var(--bg-surface);border-top:1px solid var(--border);position:sticky;bottom:0;z-index:100}.pm-qa-btn{font-family:var(--font-display);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:8px 18px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.pm-qa-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-dim)}.portrait-container{display:flex;flex-direction:column;gap:8px}.portrait-label{font-family:var(--font-display);font-size:.8rem;font-weight:500;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.portrait-wrapper{position:relative;border-radius:8px;overflow:hidden;border:2px solid var(--border)}.portrait-sm{width:60px;height:60px}.portrait-md{width:120px;height:120px}.portrait-lg{width:180px;height:180px}.portrait-xl{width:240px;height:240px}.portrait-readonly{border:none}.portrait-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.portrait-overlay{position:absolute;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .2s}.portrait-wrapper:hover .portrait-overlay{opacity:1}.portrait-action-btn{font-family:var(--font-body);font-size:.75rem;padding:6px 12px;border-radius:4px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:all .15s}.portrait-action-btn:hover{background:var(--bg-hover);border-color:var(--accent-dim)}.portrait-replace-btn:hover{color:var(--accent)}.portrait-delete-btn:hover{color:#e05c5c;border-color:#e05c5c}.portrait-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:var(--bg-card);border:2px dashed var(--border);border-radius:8px;cursor:pointer;transition:all .2s;padding:20px;text-align:center}.portrait-dropzone:hover,.portrait-dropzone-active{border-color:var(--accent-dim);background:var(--bg-hover)}.portrait-dropzone-icon{font-size:2rem;opacity:.6}.portrait-dropzone-text{display:flex;flex-direction:column;gap:4px}.portrait-dropzone-main{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--text-primary)}.portrait-dropzone-sub{font-size:.8rem;color:var(--text-secondary)}.portrait-dropzone-hint{font-size:.7rem;color:var(--text-muted)}.portrait-error{font-size:.75rem;color:#e05c5c;margin-top:4px}.concept-portrait-group{margin-bottom:8px}.pm-qa-btn-levelup{background:linear-gradient(135deg,#3a4a1a,#2a3510);border-color:var(--success);color:var(--success);animation:pm-levelup-glow 2s ease-in-out infinite}@keyframes pm-levelup-glow{0%,to{box-shadow:0 0 8px #5a9e6f33}50%{box-shadow:0 0 20px #5a9e6f66}}@media (max-width: 768px){.pm-header{padding:10px 16px}.pm-header-name{font-size:1rem}.pm-status-bar{padding:10px 16px;gap:14px}.pm-tabs{padding:0 12px}.pm-tab{padding:10px 14px;font-size:.7rem}.pm-panel-content{padding:16px}.pm-quick-actions{padding:10px 16px;gap:8px}.pm-qa-btn{padding:7px 12px;font-size:.68rem}}@media (max-width: 480px){.pm-header-right{flex-direction:column;gap:4px}.pm-tab-label{display:none}.pm-tab{padding:10px 12px}.pm-tab-icon{font-size:1.2rem}.pm-status-xp{display:none}.pm-status-conditions{margin-left:0;width:100%}}.languages-step{display:flex;flex-direction:column;gap:1.5rem}.lang-rules-card{background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--accent-dim);border-radius:6px;padding:12px 16px}.lang-rules-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-dim);margin:0 0 8px}.lang-rules-grid{display:flex;flex-direction:column;gap:4px}.lang-rules-item{display:flex;align-items:baseline;gap:10px;font-size:.88rem}.lang-rules-label{font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);min-width:110px;flex-shrink:0}.lang-rules-value{color:var(--text-secondary);font-size:.88rem}.lang-base-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.lang-chip{display:inline-flex;align-items:center;gap:5px;font-size:.85rem;padding:5px 12px;border-radius:5px}.lang-chip-base{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);cursor:default}.lang-slots{display:flex;flex-direction:column;gap:10px}.lang-slot-row{display:flex;align-items:center;gap:12px}.lang-slot-source{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.03em;color:var(--text-muted);min-width:110px;flex-shrink:0}.lang-no-slots{font-size:.9rem;color:var(--text-muted);font-style:italic;margin:0}.summary-chip-chosen{color:var(--accent-bright);border-color:var(--border-accent);background:#d4a24e12}.lang-custom-select{position:relative;flex:1;min-width:200px;max-width:320px;font-family:var(--font-body)}.lang-custom-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:border-color .15s,background .15s;text-align:left}.lang-custom-trigger:hover{border-color:var(--border-strong);background:var(--bg-hover)}.lang-custom-select.lang-custom-select-open .lang-custom-trigger,.lang-custom-trigger-chosen{border-color:var(--accent-dim)}.lang-custom-select.lang-custom-select-open .lang-custom-trigger{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.lang-custom-trigger-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lang-custom-placeholder{color:var(--text-muted);font-style:italic}.lang-custom-chevron{color:var(--text-muted);font-size:.75rem;margin-left:8px;flex-shrink:0;transition:transform .2s;display:inline-block}.lang-custom-chevron.open{transform:rotate(180deg)}.lang-custom-dropdown{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--bg-elevated);border:1px solid var(--accent-dim);border-top:none;border-radius:0 0 6px 6px;max-height:260px;overflow-y:auto;box-shadow:var(--shadow-md)}.lang-custom-optgroup{font-family:var(--font-display);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-dim);padding:6px 12px 3px;background:var(--bg-surface);position:sticky;top:0;z-index:1}.lang-custom-optgroup-uncommon{color:#a899f0;border-top:1px solid var(--border);margin-top:2px}.lang-custom-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 14px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);font-size:.88rem;text-align:left;cursor:pointer;transition:background .12s}.lang-custom-option:last-child{border-bottom:none}.lang-custom-option:hover:not(:disabled){background:var(--bg-hover)}.lang-custom-option-active{background:#d4a24e1a;color:var(--accent-bright)}.lang-custom-option-active:hover{background:#d4a24e26}.lang-custom-option-blank{color:var(--text-muted);font-style:italic;font-size:.82rem}.lang-custom-option-uncommon{color:#c5b4ff}.lang-custom-option-taken{opacity:.45;cursor:not-allowed}.lang-custom-option-taken:hover{background:transparent}.lang-custom-taken-badge{display:inline-block;font-family:var(--font-display);font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-deep);border:1px solid var(--border);border-radius:3px;padding:1px 6px;margin-left:8px;flex-shrink:0}.lang-custom-dropdown::-webkit-scrollbar{width:6px}.lang-custom-dropdown::-webkit-scrollbar-track{background:var(--bg-elevated)}.lang-custom-dropdown::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}@media (max-width: 600px){.lang-custom-select{max-width:100%}.lang-slot-row{flex-direction:column;align-items:flex-start;gap:4px}.lang-slot-source{min-width:auto}}.feat-picker-root{position:relative;width:100%}.feat-picker-dropdown-enhanced{max-height:560px;overflow:hidden;display:flex;flex-direction:column}.fp-search-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.fp-search-icon{font-size:1.1rem;color:var(--text-muted);flex-shrink:0;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.fp-search-input{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;padding:7px 10px;outline:none;transition:border-color .15s,box-shadow .15s}.fp-search-input:focus{border-color:var(--accent-dim);box-shadow:0 0 0 2px var(--accent-glow)}.fp-search-input::-moz-placeholder{color:var(--text-muted);font-style:italic}.fp-search-input::placeholder{color:var(--text-muted);font-style:italic}.fp-search-clear{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:4px 6px;border-radius:4px;line-height:1;flex-shrink:0;transition:color .15s,background .15s}.fp-search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.fp-filter-bar{display:flex;flex-direction:column;gap:6px;padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0}.fp-filter-group{display:flex;align-items:center;gap:8px}.fp-filter-label{font-family:var(--font-display);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex-shrink:0;min-width:44px}.fp-filter-tabs{display:flex;gap:4px;flex-wrap:wrap}.fp-filter-tabs-scroll{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.fp-filter-tabs-scroll::-webkit-scrollbar{height:3px}.fp-filter-tabs-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}.fp-filter-tab{font-family:var(--font-display);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;border:1px solid var(--border);border-radius:4px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.fp-filter-tab:hover{border-color:var(--border-strong);color:var(--text-secondary);background:var(--bg-hover)}.fp-filter-tab-active{background:#d4a24e26!important;border-color:var(--accent-dim)!important;color:var(--accent)!important}.fp-filter-tab-skill.fp-filter-tab-active{background:#5a8fa626!important;border-color:#5a8fa666!important;color:var(--info)!important}.fp-filter-group-skills .fp-filter-label{color:var(--info);opacity:.8}.fp-results-bar{display:flex;align-items:center;justify-content:space-between;padding:5px 14px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.fp-results-count{font-family:var(--font-body);font-size:.72rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.fp-clear-all{font-family:var(--font-body);font-size:.72rem;color:var(--accent-dim);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:3px;transition:color .15s,background .15s}.fp-clear-all:hover{color:var(--accent);background:var(--accent-glow)}.fp-list{overflow-y:auto;flex:1}.fp-empty{text-align:center;padding:32px 20px;color:var(--text-muted);font-style:italic;font-size:.9rem}.feat-source-badge{display:inline-block;font-family:var(--font-display);font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:1px 6px;border-radius:3px;border:1px solid;vertical-align:middle;flex-shrink:0;line-height:1.5}.feat-repeatable-badge{display:inline-block;font-family:var(--font-display);font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:1px 6px;border-radius:3px;color:var(--success);background:#5a9e6f1f;border:1px solid rgba(90,158,111,.3);margin-left:6px;vertical-align:middle}.feat-option-right{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:auto}.feat-option-special{font-size:.72rem;color:var(--accent-dim);font-style:italic;line-height:1.4}.feat-level-count{font-family:var(--font-body);font-size:.65rem;font-weight:400;color:var(--text-muted);margin-left:6px;text-transform:none;letter-spacing:0}.fp-highlight{background:#d4a24e40;color:var(--accent-bright);border-radius:2px;padding:0 1px;font-weight:700}.feat-prereq-label{font-weight:600;color:var(--accent-dim);font-style:normal}.choice-selected-badge-warn{border-color:var(--accent);color:var(--accent)}.feat-prereq-warn-icon{color:var(--accent);margin-left:4px}.feat-picker-toggle-prereq-warn{border-color:var(--accent)}.feat-prereq-warning-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;margin-top:6px;background:#d4a24e14;border:1px solid rgba(212,162,78,.25);border-radius:6px}.feat-prereq-warning-icon{color:var(--accent);font-size:1rem}.feat-prereq-warning-text{font-size:.82rem;color:var(--text-secondary)}.feat-option-prereq-unmet{opacity:.5;cursor:help}.feat-option-prereq-unmet:hover{opacity:.65}.feat-prereq-lock-badge{font-size:.68rem;font-weight:600;color:var(--text-muted);background:#70685826;border:1px solid rgba(112,104,88,.25);border-radius:3px;padding:1px 6px;margin-left:6px}.feat-option-prereq-failed{color:var(--error)}.feat-prereq-failed-detail{display:block;margin-top:2px}.feat-prereq-failed-item{display:inline-block;font-size:.7rem;color:var(--error);background:#c4525214;border-radius:3px;padding:1px 5px;margin-right:4px}.fp-filter-tab-prereq-met{border-color:#5a9e6f4d}.fp-filter-tab-prereq-met.fp-filter-tab-active{background:#5a9e6f1f;border-color:var(--success);color:var(--success)}.fp-filter-tab-prereq-unmet{border-color:#c452524d}.fp-filter-tab-prereq-unmet.fp-filter-tab-active{background:#c452521f;border-color:var(--error);color:var(--error)}@media (max-width: 768px){.feat-picker-dropdown-enhanced{max-height:420px}.fp-filter-bar{gap:4px}.fp-filter-tab{font-size:.78rem;padding:3px 7px}}.review-feats-detailed{display:flex;flex-direction:column;gap:10px}.review-feat-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:12px 14px;transition:border-color .2s}.review-feat-card:hover{border-color:#d4a24e40}.review-feat-card-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}.review-feat-card-name{font-weight:700;color:var(--text-primary, #e8e0d4);font-size:.92rem}.review-feat-card-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.review-feat-card-type{background:#d4a24e26;color:#d4a24e;font-size:.68rem;font-weight:600;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.review-feat-card-level{color:var(--text-muted, #a69d8f);font-size:.72rem;font-weight:600}.review-feat-card-actions{color:#d4a24e;font-size:.88rem;letter-spacing:-1px}.review-feat-card-traits{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.review-feat-card-trait{background:#ffffff0f;color:var(--text-muted, #a69d8f);font-size:.65rem;padding:1px 6px;border-radius:3px;border:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.03em}.review-feat-card-prereq{color:var(--text-muted, #a69d8f);font-size:.76rem;font-style:italic;margin-bottom:5px}.review-feat-card-desc{color:var(--text-secondary, #c4b99a);font-size:.82rem;line-height:1.5}.review-feat-card-choice{margin-top:6px;padding:5px 10px;background:#7ec4671a;border:1px solid rgba(126,196,103,.25);border-radius:5px;color:#7ec467;font-size:.78rem;font-weight:600}@media (max-width: 480px){.review-feat-card-header{flex-direction:column;align-items:flex-start;gap:4px}.review-feat-card{padding:10px 12px}}.equip-info-page{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:20px;padding-bottom:32px}.equip-info-header{text-align:center;margin-bottom:4px}.equip-info-icon{font-size:2.2rem;display:block;margin-bottom:6px}.equip-info-title{font-family:Cinzel,serif;font-size:1.5rem;color:var(--text-primary, #e8e0d4);margin:0 0 6px}.equip-info-subtitle{color:var(--text-muted, #a69d8f);font-size:.92rem;margin:0}.equip-info-highlight{background:linear-gradient(135deg,#d4a24e1f,#d4a24e0a);border:1.5px solid rgba(212,162,78,.35);border-radius:12px;padding:18px 20px}.equip-info-highlight-label{color:var(--text-muted, #a69d8f);font-size:.88rem;margin-bottom:12px}.equip-info-highlight-label strong{color:#d4a24e;font-size:1rem}.equip-info-highlight-row{display:flex;flex-direction:column;gap:12px}.equip-info-stat{display:flex;align-items:flex-start;gap:10px}.equip-info-stat-icon{font-size:1.3rem;flex-shrink:0;margin-top:1px}.equip-info-stat-label{color:var(--text-muted, #a69d8f);font-size:.82rem;display:block;margin-bottom:2px}.equip-info-stat-value{color:var(--text-primary, #e8e0d4);font-weight:600;font-size:1rem}.equip-info-stat-items{font-size:.88rem;font-weight:400;line-height:1.45}.equip-info-gm-note,.equip-info-play-note{display:flex;gap:14px;padding:16px 18px;border-radius:10px;align-items:flex-start}.equip-info-gm-note{background:#4e9ad414;border:1px solid rgba(78,154,212,.25)}.equip-info-play-note{background:#7ec46714;border:1px solid rgba(126,196,103,.25)}.equip-info-gm-icon,.equip-info-play-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.equip-info-gm-text,.equip-info-play-text{color:var(--text-secondary, #c4b99a);font-size:.88rem;line-height:1.55}.equip-info-gm-text strong,.equip-info-play-text strong{color:var(--text-primary, #e8e0d4)}.equip-info-table-wrap{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:18px}.equip-info-table-title{font-family:Cinzel,serif;font-size:1rem;color:var(--text-primary, #e8e0d4);margin:0 0 2px}.equip-info-table-source{color:var(--text-muted, #a69d8f);font-size:.76rem;margin:0 0 14px;font-style:italic}.equip-info-table-scroll{overflow-x:auto}.equip-info-table{width:100%;border-collapse:collapse;font-size:.84rem}.equip-info-table th{text-align:left;color:var(--text-muted, #a69d8f);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.1)}.equip-info-table td{padding:8px 10px;color:var(--text-secondary, #c4b99a);border-bottom:1px solid rgba(255,255,255,.04)}.equip-info-cell-level{font-weight:700;color:var(--text-primary, #e8e0d4);width:50px;text-align:center}.equip-info-cell-currency{color:#d4a24e;font-weight:600;white-space:nowrap;width:100px}.equip-info-cell-items{font-size:.82rem;line-height:1.45}.equip-info-row-active{background:#d4a24e1a}.equip-info-row-active td{color:var(--text-primary, #e8e0d4)}.equip-info-row-active .equip-info-cell-currency{color:#e8c05a}.equip-info-show-all-btn{display:block;margin:12px auto 0;background:none;border:1px solid rgba(212,162,78,.3);color:#d4a24e;padding:6px 16px;border-radius:6px;cursor:pointer;font-size:.8rem;transition:background .2s}.equip-info-show-all-btn:hover{background:#d4a24e1a}.equip-info-rules{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:18px}.equip-info-rules-title{font-family:Cinzel,serif;font-size:1rem;color:var(--text-primary, #e8e0d4);margin:0 0 14px}.equip-info-rule{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary, #c4b99a);font-size:.86rem;line-height:1.5}.equip-info-rule:last-child{border-bottom:none;padding-bottom:0}.equip-info-rule-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}.equip-info-rule strong{color:var(--text-primary, #e8e0d4)}@media (max-width: 480px){.equip-info-page{gap:16px}.equip-info-highlight{padding:14px}.equip-info-gm-note,.equip-info-play-note{flex-direction:column;gap:8px}.equip-info-table{font-size:.78rem}}.scg-banner{border-radius:10px;padding:12px 16px;margin-bottom:20px;font-family:var(--font-body);transition:all .3s var(--ease-out)}.scg-banner-pending{background:linear-gradient(135deg,#d4a24e1a,#d4a24e0d);border:1px solid rgba(212,162,78,.35);box-shadow:0 0 16px #d4a24e0f,inset 0 1px #d4a24e1f}.scg-banner-done{background:linear-gradient(135deg,#5a9e6f1f,#5a9e6f0d);border:1px solid rgba(90,158,111,.35);box-shadow:0 0 16px #5a9e6f0f;display:flex;align-items:center;gap:10px}.scg-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.scg-icon{font-size:1rem;flex-shrink:0;line-height:1}.scg-title{font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--accent);letter-spacing:.04em;text-transform:uppercase;flex:1}.scg-done-text{font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--success);letter-spacing:.04em;text-transform:uppercase}.scg-progress{font-size:.72rem;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:2px 8px;white-space:nowrap}.scg-chips{display:flex;flex-wrap:wrap;gap:6px}.scg-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#d4a24e14;border:1px solid rgba(212,162,78,.28);border-radius:100px;color:var(--accent-bright);font-size:.78rem;font-family:var(--font-body);cursor:pointer;transition:all .18s ease;white-space:nowrap}.scg-chip:hover{background:#d4a24e2e;border-color:#d4a24e8c;transform:translateY(-1px);box-shadow:0 3px 8px #d4a24e1f}.scg-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:scg-pulse 2s ease-in-out infinite}.scg-chip-arrow{font-size:.7rem;opacity:.6;margin-left:2px}@keyframes scg-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}.pick-section-required>.pick-section-title:after{content:"Required";display:inline-block;margin-left:10px;padding:2px 7px;background:#d4a24e26;border:1px solid rgba(212,162,78,.4);border-radius:100px;font-size:.65rem;font-family:var(--font-display);font-weight:600;color:var(--accent);letter-spacing:.07em;text-transform:uppercase;vertical-align:middle}.pick-section-done>.pick-section-title:after{content:"✓Done";display:inline-block;margin-left:10px;padding:2px 7px;background:#5a9e6f1f;border:1px solid rgba(90,158,111,.35);border-radius:100px;font-size:.65rem;font-family:var(--font-display);font-weight:600;color:var(--success);letter-spacing:.07em;text-transform:uppercase;vertical-align:middle}@keyframes scg-section-flash{0%{box-shadow:0 0 #d4a24e00}25%{box-shadow:0 0 0 4px #d4a24e66}70%{box-shadow:0 0 0 8px #d4a24e26}to{box-shadow:0 0 #d4a24e00}}.scg-pulse-target{animation:scg-section-flash 1.6s ease-out forwards!important;border-radius:10px}.wizard-step-pending-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#d4a24e2e;border:1px solid rgba(212,162,78,.45);border-radius:100px;font-size:.78rem;font-family:var(--font-display);font-weight:700;color:var(--accent);flex-shrink:0;margin-left:auto}@media (max-width: 600px){.scg-banner{padding:10px 12px}.scg-chip{font-size:.73rem;padding:3px 8px}.scg-title{font-size:.72rem}}.concept-collapsible-section{margin-bottom:1.25rem;border:1px solid rgba(255,255,255,.08);border-radius:10px;overflow:hidden;background:#ffffff05}.concept-collapsible-header{width:100%;display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ffffff08;border:none;cursor:pointer;color:#ccc;font-family:var(--font-display);font-size:.9rem;letter-spacing:.03em;text-align:left;transition:background .2s}.concept-collapsible-header:hover{background:#ffffff0f;color:#eee}.concept-collapsible-header.concept-collapsible-open{color:var(--accent);background:#d4a24e0f;border-bottom:1px solid rgba(212,162,78,.15)}.concept-collapsible-icon{font-size:1rem;flex-shrink:0}.concept-collapsible-title{font-weight:600}.concept-collapsible-filled{margin-left:.5rem;font-size:.75rem;color:var(--accent);opacity:.85;font-family:var(--font-body);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.concept-collapsible-chevron{margin-left:auto;font-size:.85rem;flex-shrink:0}.concept-collapsible-body{padding:1rem;border-top:1px solid rgba(255,255,255,.05)}.concept-appearance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.concept-deity-intro{font-size:.85rem;color:#aaa;margin-bottom:.75rem;line-height:1.5}.concept-deity-mode-row{display:flex;gap:.5rem;margin-bottom:.75rem}.concept-deity-mode-btn{flex:1;padding:.4rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:transparent;color:#aaa;font-size:.82rem;cursor:pointer;transition:all .2s}.concept-deity-mode-btn:hover{border-color:#ffffff40;color:#ddd}.concept-deity-mode-btn.active{border-color:var(--accent);background:#d4a24e1f;color:var(--accent);font-weight:600}.concept-deity-group-label{font-size:.75rem;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:#888;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.concept-deity-selected-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:#d4a24e1a;border:1px solid rgba(212,162,78,.25);border-radius:6px;font-size:.85rem;color:var(--accent);margin-bottom:.75rem}.concept-deity-clear-btn{background:none;border:none;color:#888;font-size:.78rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .2s}.concept-deity-clear-btn:hover{color:#c45c5c}.deity-card-list{display:flex;flex-direction:column;gap:.5rem}.deity-card{border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff05;cursor:pointer;transition:all .2s;overflow:hidden}.deity-card:hover{border-color:#d4a24e59;background:#d4a24e0a}.deity-card-selected{border-color:var(--accent)!important;background:#d4a24e14!important;box-shadow:0 0 0 1px #d4a24e33}.deity-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:.6rem .75rem .4rem;gap:.5rem}.deity-card-name-block{display:flex;flex-direction:column;gap:.1rem;min-width:0}.deity-card-name{font-family:var(--font-display);font-size:.95rem;color:#e8e0d0;font-weight:600}.deity-card-title{font-size:.75rem;color:#999;font-style:italic}.deity-card-meta{display:flex;align-items:center;gap:.35rem;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.deity-type-badge{font-size:.65rem;padding:1px 6px;border-radius:10px;background:#5c9fd426;border:1px solid rgba(92,159,212,.3);color:#5c9fd4;font-family:var(--font-display);letter-spacing:.05em}.deity-sanct-badge{font-size:.65rem;padding:1px 6px;border-radius:10px;font-family:var(--font-display)}.deity-sanct-holy{background:#d4a24e1f;border:1px solid rgba(212,162,78,.3);color:var(--accent)}.deity-sanct-unholy{background:#c45c5c1f;border:1px solid rgba(196,92,92,.3);color:#c45c5c}.deity-expand-btn{background:none;border:none;color:#666;cursor:pointer;font-size:.8rem;padding:2px 4px;border-radius:3px;transition:color .2s}.deity-expand-btn:hover{color:var(--accent)}.deity-card-domains{display:flex;flex-wrap:wrap;gap:.3rem;padding:0 .75rem .6rem}.deity-domain-tag,.deity-skill-tag,.deity-weapon-tag{font-size:.68rem;padding:1px 6px;border-radius:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:#bbb;text-transform:capitalize}.deity-skill-tag{border-color:#5cb87a40;color:#5cb87a}.deity-weapon-tag{border-color:#c45c5c33;color:#c47a7a}.deity-card-details{padding:.5rem .75rem .75rem;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.35rem}.deity-detail-row{display:flex;gap:.5rem;font-size:.8rem}.deity-detail-label{font-family:var(--font-display);color:var(--accent);min-width:110px;flex-shrink:0;font-size:.72rem;padding-top:1px}.deity-detail-value{color:#bbb;line-height:1.45}.deity-card-selected-banner{background:#d4a24e1f;border-top:1px solid rgba(212,162,78,.2);text-align:center;font-size:.72rem;color:var(--accent);font-family:var(--font-display);letter-spacing:.06em;padding:3px}@media (max-width: 600px){.concept-appearance-grid{grid-template-columns:1fr 1fr}.deity-card-header{flex-direction:column;gap:.4rem}.deity-card-meta{justify-content:flex-start}}.kofi-float-btn{position:fixed;bottom:max(1.25rem,env(safe-area-inset-bottom));right:max(1.25rem,env(safe-area-inset-right));z-index:9999;width:44px;height:44px;background:#ff5e5b;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0006;transition:transform .2s,box-shadow .2s,background .2s;text-decoration:none}.kofi-float-btn:hover{background:#e04e4b;transform:translateY(-2px) scale(1.08);box-shadow:0 4px 16px #ff5e5b73}.kofi-float-icon{width:24px;height:24px;-o-object-fit:contain;object-fit:contain;filter:brightness(0) invert(1)}@media (max-width: 600px){.kofi-float-btn{bottom:.75rem;right:.75rem;width:40px;height:40px}.kofi-float-icon{width:21px;height:21px}}#root:has(.wizard-container) .kofi-float-btn{display:none}@media (max-width: 768px){#root:has(.v2-shell) .kofi-float-btn{display:none}}.vh-callout{background:#9b78ff12;border:1px solid rgba(155,120,255,.25);border-radius:8px;padding:.75rem 1rem;margin-bottom:.75rem}.vh-callout-text{font-size:.82rem;color:#ccc;line-height:1.55;margin:0 0 .65rem}.vh-callout-text strong{color:#b89cff;font-family:var(--font-display);font-size:.85rem;letter-spacing:.03em}.vh-toggle-row{display:flex;gap:.75rem;flex-wrap:wrap}.vh-toggle-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.55rem .85rem;background:#ffffff0a;border:1px solid rgba(155,120,255,.25);border-radius:8px;cursor:pointer;transition:background .18s,border-color .18s;text-align:left;min-width:160px}.vh-toggle-btn:hover{background:#9b78ff1f;border-color:#9b78ff80}.vh-toggle-btn-active{background:#9b78ff2e!important;border-color:#9b78ff!important;box-shadow:0 0 0 1px #9b78ff66}.vh-toggle-name{font-family:var(--font-display);font-size:.92rem;color:#ddd;font-weight:600}.vh-toggle-legacy{font-size:.72rem;color:#888;font-style:italic}.vh-toggle-trait{font-size:.75rem;color:#b89cff;font-family:var(--font-display);letter-spacing:.02em}.vh-base-ability{background:#9b78ff0f;border-left:3px solid #9b78ff;border-radius:0 6px 6px 0;padding:.5rem .75rem;font-size:.82rem;color:#ccc;margin-bottom:.75rem;line-height:1.5}.vh-base-ability strong{color:#b89cff}.trait-badge-vh{background:#9b78ff40!important;border:1px solid rgba(155,120,255,.5)!important;color:#cbb8ff!important}.feat-pool-badge{font-family:var(--font-body);font-size:.72rem;color:#b89cff;font-weight:400;margin-left:.5rem;opacity:.85}.feat-source-legend{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:#999;margin-bottom:.5rem;padding:0 .25rem}.feat-source-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.feat-source-base{background:#4a90e2}.feat-source-connected{background:#9b78ff}.compact-option-connected-ancestry{border-left:2px solid rgba(155,120,255,.4)!important}.compact-option-connected-ancestry.compact-option-active{border-left-color:#9b78ff!important}.feat-source-tag{display:inline-block;font-size:.68rem;font-family:var(--font-display);background:#9b78ff26;border:1px solid rgba(155,120,255,.35);color:#b89cff;border-radius:4px;padding:1px 5px;margin-left:5px;letter-spacing:.03em;vertical-align:middle}@media (max-width: 600px){.vh-toggle-row{flex-direction:column}.vh-toggle-btn{min-width:unset;width:100%}}.bg-remaster-compat-note{display:flex;align-items:center;gap:.45rem;background:#8264dc14;border:1px solid rgba(130,100,220,.25);border-radius:6px;padding:.35rem .75rem;margin:.5rem 0 .75rem;font-size:.78rem;color:#b8a8e0}.bg-remaster-compat-icon{color:#9b7fd4;font-size:.75rem;flex-shrink:0}.skill-choice-feat-hint{display:block;font-size:.7rem;color:#9b7fd4;margin-top:2px;font-style:italic}.home-storage-warning{display:flex;align-items:flex-start;gap:.65rem;background:#d4a24e14;border:1px solid rgba(212,162,78,.3);border-radius:8px;padding:.7rem 1rem;margin-bottom:1.5rem;max-width:860px}.home-storage-warning-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.home-storage-warning-text{font-size:.82rem;color:#c8b88a;line-height:1.55}.home-storage-warning-text strong{color:#d4a24e}.home-storage-warning-text code{background:#ffffff14;border-radius:3px;padding:1px 5px;font-size:.78rem;color:#e0c97a;font-family:monospace}@media (max-width: 600px){.home-storage-warning{flex-direction:column;gap:.4rem}}.customization-step{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:2rem}.custom-gm-note{display:flex;align-items:center;gap:.5rem;background:#4664b41f;border:1px solid rgba(100,140,220,.3);border-radius:6px;padding:.5rem .8rem;font-size:.78rem;color:#a8b8e0;margin-top:.4rem}.custom-gm-icon{font-size:.9rem;color:#7a9ed0;flex-shrink:0}.custom-section{padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:1rem}.custom-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.custom-section-title{font-family:Cinzel Decorative,Cinzel,serif;font-size:.85rem;font-weight:600;color:var(--text-primary);letter-spacing:.06em;display:flex;align-items:center;gap:.5rem;margin:0}.custom-section-icon{font-size:1rem;opacity:.9}.custom-add-btn{background:rgba(var(--accent-gold-rgb, 180,140,70),.15);border:1px solid rgba(var(--accent-gold-rgb, 180,140,70),.4);color:var(--accent-gold);border-radius:5px;padding:.32rem .8rem;font-size:.77rem;font-family:Cinzel,serif;cursor:pointer;letter-spacing:.05em;transition:background .15s,border-color .15s;white-space:nowrap}.custom-add-btn:hover{background:rgba(var(--accent-gold-rgb, 180,140,70),.28);border-color:var(--accent-gold)}.custom-empty-state{display:flex;align-items:center;gap:.6rem;color:var(--text-muted);font-size:.8rem;font-style:italic;padding:.4rem 0}.custom-empty-icon{font-size:1rem;opacity:.5}.custom-skill-list{display:flex;flex-direction:column;gap:.6rem}.custom-skill-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.custom-skill-select{background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:5px;color:var(--text-primary);padding:.28rem .6rem;font-size:.82rem;font-family:Crimson Pro,serif;cursor:pointer;min-width:130px}.custom-skill-select:focus{outline:none;border-color:var(--accent-gold)}.custom-rank-group{display:flex;gap:.3rem;flex-wrap:wrap}.custom-rank-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.18);color:var(--text-muted);border-radius:4px;padding:.22rem .55rem;font-size:.73rem;font-family:Cinzel,serif;cursor:pointer;transition:all .13s;letter-spacing:.03em}.custom-rank-btn:hover{background:#ffffff1a;color:var(--text-primary)}.custom-rank-btn-active{background:#ffffff1a;font-weight:700}.custom-remove-btn{background:transparent;border:1px solid rgba(200,80,80,.3);color:#c85050b3;border-radius:4px;padding:.18rem .5rem;font-size:.9rem;cursor:pointer;transition:all .13s;flex-shrink:0;margin-left:auto}.custom-remove-btn:hover{background:#c8505026;color:#e07070;border-color:#e07070}.custom-skill-chips{display:flex;flex-wrap:wrap;gap:.4rem;padding-top:.2rem;border-top:1px solid rgba(255,255,255,.07)}.custom-skill-chip{display:flex;align-items:center;gap:.35rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:.2rem .65rem;font-size:.75rem}.custom-chip-skill{color:var(--text-primary)}.custom-chip-rank{font-weight:600;font-size:.7rem}.custom-feat-picker{border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#0003;overflow:hidden}.custom-feat-controls{padding:.8rem 1rem .6rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.5rem}.custom-feat-search{background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:5px;color:var(--text-primary);padding:.38rem .7rem;font-size:.82rem;font-family:Crimson Pro,serif;width:100%;box-sizing:border-box}.custom-feat-search::-moz-placeholder{color:var(--text-muted);opacity:.7}.custom-feat-search::placeholder{color:var(--text-muted);opacity:.7}.custom-feat-search:focus{outline:none;border-color:var(--accent-gold)}.custom-feat-filters{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem}.custom-filter-label{font-size:.72rem;color:var(--text-muted);font-family:Cinzel,serif;letter-spacing:.04em;text-transform:uppercase}.custom-filter-chip{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);color:var(--text-muted);border-radius:20px;padding:.18rem .6rem;font-size:.72rem;font-family:Cinzel,serif;cursor:pointer;transition:all .13s;letter-spacing:.03em}.custom-filter-chip:hover{background:#ffffff1a;color:var(--text-primary)}.custom-filter-chip.active{background:rgba(var(--accent-gold-rgb, 180,140,70),.2);border-color:var(--accent-gold);color:var(--accent-gold)}.custom-feat-count{font-size:.72rem;color:var(--text-muted);font-style:italic}.custom-feat-results{max-height:340px;overflow-y:auto;display:flex;flex-direction:column;gap:0}.custom-feat-results::-webkit-scrollbar{width:5px}.custom-feat-results::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.custom-feat-empty{padding:1rem;text-align:center;color:var(--text-muted);font-style:italic;font-size:.8rem}.custom-feat-row{display:flex;flex-direction:column;gap:.25rem;padding:.6rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background .12s;position:relative}.custom-feat-row:hover{background:#ffffff0d}.custom-feat-row:last-child{border-bottom:none}.custom-feat-row-selected{background:rgba(var(--accent-gold-rgb, 180,140,70),.08)}.custom-feat-row-selected:hover{background:rgba(var(--accent-gold-rgb, 180,140,70),.12)}.custom-feat-main{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.3rem}.custom-feat-name{font-family:Cinzel,serif;font-size:.8rem;color:var(--text-primary);font-weight:600;letter-spacing:.04em}.custom-feat-badges{display:flex;align-items:center;gap:.3rem}.custom-feat-type-badge{border:1px solid;border-radius:3px;padding:.05rem .35rem;font-size:.78rem;font-family:Cinzel,serif;letter-spacing:.04em;text-transform:uppercase}.custom-feat-source-badge{background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:3px;padding:.05rem .35rem;font-size:.78rem;color:var(--text-muted);font-family:monospace;letter-spacing:.02em}.custom-feat-level-badge{background:#c8a0641a;border:1px solid rgba(200,160,100,.25);border-radius:3px;padding:.05rem .35rem;font-size:.78rem;color:var(--accent-dim);font-family:Cinzel,serif}.custom-feat-prereqs{font-size:.72rem;color:var(--text-muted);font-style:italic}.custom-feat-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.custom-feat-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:.7rem;color:var(--text-muted);font-family:Cinzel,serif;letter-spacing:.04em;pointer-events:none;white-space:nowrap}.custom-feat-toggle-on{color:var(--accent-gold);font-weight:700}.custom-selected-feats{display:flex;flex-direction:column;gap:.4rem}.custom-selected-feats-title{font-size:.72rem;font-family:Cinzel,serif;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.2rem}.custom-selected-feat-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.4rem .6rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.09);border-radius:6px;cursor:default}.custom-selected-feat-row:hover{background:#ffffff12}.custom-lore-input{flex:1 1 140px;min-width:120px;max-width:200px;padding:.35rem .65rem;background:#ffffff0d;border:1px solid rgba(212,162,78,.35);border-radius:6px;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .2s}.custom-lore-input::-moz-placeholder{color:#ffffff4d;font-style:italic}.custom-lore-input::placeholder{color:#ffffff4d;font-style:italic}.custom-lore-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 2px #d4a24e26}@media (max-width: 600px){.custom-skill-row{flex-direction:column;align-items:flex-start}.custom-lore-input{max-width:100%}.custom-remove-btn{margin-left:0}.custom-feat-toggle{display:none}}.fp-selected-card{margin-top:.5rem;padding:.7rem .9rem;background:#d4a24e0f;border:1px solid rgba(212,162,78,.2);border-radius:6px;display:flex;flex-direction:column;gap:.35rem;animation:fp-card-in .15s ease}.fp-selected-card-unmet{background:#dc50500f;border-color:#dc505040}@keyframes fp-card-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.fp-selected-card-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}.fp-selected-card-traits{display:flex;flex-wrap:wrap;gap:.25rem}.fp-selected-card-source{font-size:.72rem;opacity:.8;font-style:italic;white-space:nowrap}.fp-selected-card-prereq{font-size:.8rem;color:var(--text-muted);line-height:1.4}.fp-selected-card-prereq-unmet{color:#dc6464e6}.fp-selected-card-failed{color:#dc5050e6;font-style:italic}.fp-selected-card-label{font-family:Cinzel,serif;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-gold);opacity:.85}.fp-selected-card-description{font-size:.83rem;color:var(--text-secondary);line-height:1.5;margin:0;font-style:italic}.fp-selected-card-effect{font-size:.83rem;color:var(--text-primary);line-height:1.55;margin:0;padding:.35rem .55rem;background:#ffffff08;border-left:2px solid rgba(212,162,78,.4);border-radius:0 4px 4px 0}.fp-selected-card-special{font-size:.8rem;color:var(--text-muted);line-height:1.4;margin:0;font-style:italic}.vh-callout{background:#d4a24e0d;border:1px solid rgba(212,162,78,.18);border-radius:8px;padding:.85rem 1rem;margin-bottom:.75rem}.vh-callout-text{font-size:.85rem;color:var(--text-secondary);margin:0 0 .75rem;line-height:1.5}.vh-toggle-row{display:flex;flex-wrap:wrap;gap:.5rem}.vh-toggle-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.55rem .85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:border-color .15s,background .15s;min-width:140px;text-align:left}.vh-toggle-btn:hover{border-color:var(--accent-dim);background:var(--bg-hover)}.vh-toggle-btn-active{border-color:var(--accent)!important;background:#d4a24e1a!important}.vh-toggle-btn-pc2{border-color:#7b68ee59}.vh-toggle-btn-pc2.vh-toggle-btn-active{border-color:#7b68ee!important;background:#7b68ee1a!important}.vh-toggle-source{font-size:.65rem;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;padding:.1rem .35rem;border-radius:3px;background:#ffffff0f;color:var(--text-muted);margin-bottom:.1rem}.vh-toggle-name{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text-primary)}.vh-toggle-legacy{font-size:.75rem;color:var(--text-muted);font-style:italic}.vh-toggle-trait{font-size:.75rem;color:var(--accent)}.vh-base-ability{font-size:.85rem;color:var(--text-secondary);background:#ffffff08;border-left:2px solid rgba(212,162,78,.4);padding:.5rem .75rem;border-radius:0 5px 5px 0;margin-bottom:.25rem;line-height:1.5}.draconic-exemplar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;margin-top:.4rem}.draconic-exemplar-card{display:flex;flex-direction:column;gap:.2rem;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:7px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.draconic-exemplar-card:hover{border-color:var(--accent-dim);background:var(--bg-hover)}.draconic-exemplar-active{border-color:#7b68ee!important;background:#7b68ee1a!important}.exemplar-dragon{font-family:var(--font-display);font-size:.82rem;font-weight:600;color:var(--text-primary)}.exemplar-tradition{font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.exemplar-damage{font-size:.75rem;color:var(--text-secondary)}.exemplar-save{font-size:.72rem;color:var(--text-muted)}.exemplar-speeds{font-size:.7rem;color:var(--text-muted);font-style:italic}.familiar-ability-source-badge{display:inline-block;font-size:.6rem;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;padding:.05rem .3rem;border-radius:3px;background:#7b68ee33;color:#a899f0;border:1px solid rgba(123,104,238,.3);margin-left:.35rem;vertical-align:middle}.familiar-ability-pc2{border-color:#7b68ee33}.familiar-ability-pc2.familiar-ability-selected{border-color:#7b68ee80;background:#7b68ee14}.familiar-ability-prereq{color:#a8855a;background:#a8855a1f;border:1px solid rgba(168,133,90,.3)}.companion-field-source-badge{display:inline-block;font-size:.6rem;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;padding:.05rem .3rem;border-radius:3px;background:#7b68ee33;color:#a899f0;border:1px solid rgba(123,104,238,.3);margin-left:.4rem;vertical-align:middle}.companion-field-sublabel{font-size:.78rem;color:var(--text-muted);font-style:italic;font-weight:400}.companion-type-chip-specific{height:auto;min-height:60px;padding-bottom:.4rem}.companion-type-trait{font-size:.65rem;color:#a899f0;text-transform:uppercase;letter-spacing:.04em;margin-top:.15rem}.specific-familiar-detail{margin-top:.6rem;padding:.75rem .9rem;background:#7b68ee0f;border:1px solid rgba(123,104,238,.2);border-radius:7px;display:flex;flex-direction:column;gap:.5rem}.specific-familiar-desc{font-size:.84rem;color:var(--text-secondary);margin:0;line-height:1.5;font-style:italic}.specific-familiar-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.specific-familiar-req{font-size:.78rem;color:var(--accent);font-family:var(--font-display)}.specific-familiar-note{font-size:.76rem;color:var(--text-muted);font-style:italic}.specific-familiar-granted{font-size:.8rem;color:var(--text-secondary)}.specific-familiar-granted-label{color:var(--text-muted);font-style:italic}.specific-familiar-unique{display:flex;flex-direction:column;gap:.4rem;border-top:1px solid rgba(255,255,255,.06);padding-top:.4rem}.specific-familiar-unique-item{display:flex;flex-direction:column;gap:.15rem}.specific-familiar-unique-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.specific-familiar-unique-desc{font-size:.78rem;color:var(--text-secondary);line-height:1.45}.class-level1-section{border-left:3px solid rgba(212,162,78,.4)}.class-level1-section .pick-section-title{color:#d4a24e}.class-future-section{background:#ffffff05}.class-future-toggle{display:flex;align-items:center;gap:8px;background:none;border:1px dashed rgba(255,255,255,.12);border-radius:8px;padding:10px 14px;color:var(--text-muted);font-size:13px;cursor:pointer;width:100%;text-align:left;transition:border-color .15s,color .15s}.class-future-toggle:hover{border-color:#ffffff40;color:var(--text-secondary)}.class-future-toggle-icon{font-size:.78rem;flex-shrink:0}.class-future-toggle-label{flex:1}.class-future-toggle-badge{background:#d4a24e26;color:#d4a24e;border-radius:4px;padding:2px 7px;font-size:.78rem;font-weight:700}.level-selector-future{display:flex;align-items:center;gap:10px;margin:12px 0 8px;padding:10px 14px;background:#ffffff08;border-radius:8px}.level-selector-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.wizard-step-group-hint{font-size:.78rem;color:var(--text-muted);padding:0 20px 6px;opacity:.65;line-height:1.4;font-style:italic}.wizard-phase-badge{display:inline-block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:4px;padding:2px 6px;margin-right:8px;vertical-align:middle}.wizard-phase-badge-1{background:#d4a24e26;color:#d4a24e;border:1px solid rgba(212,162,78,.3)}.wizard-phase-badge-2{background:#60a5fa1f;color:#60a5fa;border:1px solid rgba(96,165,250,.25)}.wizard-phase-badge-3{background:#a78bfa1f;color:#a78bfa;border:1px solid rgba(167,139,250,.25)}.cascade-alerts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.cascade-alert{display:flex;align-items:center;gap:10px;background:color-mix(in srgb,var(--alert-color, #60a5fa) 8%,transparent);border:1px solid color-mix(in srgb,var(--alert-color, #60a5fa) 30%,transparent);border-radius:8px;padding:10px 14px;font-size:13px}.cascade-alert-icon{font-size:16px;flex-shrink:0}.cascade-alert-msg{flex:1;color:var(--text-primary)}.cascade-alert-btn{background:color-mix(in srgb,var(--alert-color, #60a5fa) 15%,transparent);border:1px solid color-mix(in srgb,var(--alert-color, #60a5fa) 35%,transparent);color:var(--alert-color, #60a5fa);border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.cascade-alert-btn:hover{background:color-mix(in srgb,var(--alert-color, #60a5fa) 25%,transparent)}.skills-readonly-notice{display:flex;align-items:flex-start;gap:12px;background:#60a5fa14;border:1px solid rgba(96,165,250,.2);border-radius:8px;padding:12px 16px;margin-bottom:16px;font-size:13px;color:var(--text-secondary);line-height:1.5}.skills-readonly-icon{font-size:18px;flex-shrink:0;color:#60a5fa;margin-top:1px}.share-modal-overlay{position:fixed;inset:0;background:#000000a6;z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px}.share-modal{background:var(--bg-panel, #1e1c17);border:1px solid var(--color-border, #3a352c);border-radius:12px;width:100%;max-width:480px;max-height:90vh;max-height:min(90vh,var(--app-visible-height, 90vh) - 32px);overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 20px 60px #0009}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--color-border, #3a352c)}.share-modal-title{font-family:Cinzel,serif;font-size:1.05rem;color:var(--accent, #d4a24e);margin:0}.share-modal-close{background:none;border:none;color:var(--text-muted, #a69d8f);font-size:1.1rem;cursor:pointer;padding:4px 6px;border-radius:4px;line-height:1}.share-modal-close:hover{color:var(--text-main, #e8e0d4)}.share-modal-tabs{display:flex;border-bottom:1px solid var(--color-border, #3a352c)}.share-tab{flex:1;background:none;border:none;padding:10px;font-size:.85rem;color:var(--text-muted, #a69d8f);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.share-tab-active{color:var(--accent, #d4a24e);border-bottom-color:var(--accent, #d4a24e)}.share-modal-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:14px}.share-modal-sub{font-size:.82rem;color:var(--text-muted, #a69d8f);margin:0;line-height:1.5}.share-qr-area{display:flex;justify-content:center}.share-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.share-qr-img{border-radius:8px;border:2px solid var(--color-border, #3a352c);display:block}.share-qr-caption{font-size:.75rem;color:var(--text-muted, #a69d8f);margin:0;text-align:center}.share-qr-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:220px;height:220px;border:2px dashed var(--color-border, #3a352c);border-radius:8px;color:var(--text-muted, #a69d8f);font-size:.82rem}.share-qr-spinner{width:28px;height:28px;border:3px solid rgba(212,162,78,.2);border-top-color:var(--accent, #d4a24e);border-radius:50%;animation:share-spin .7s linear infinite}@keyframes share-spin{to{transform:rotate(360deg)}}.share-qr-too-large{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px;background:#c4525214;border:1px solid rgba(196,82,82,.25);border-radius:8px;text-align:center;width:100%}.share-qr-too-large-icon{font-size:1.4rem}.share-qr-too-large p{margin:0;font-size:.83rem;color:#c45c5c}.share-qr-too-large-hint{color:var(--text-muted, #a69d8f)!important}.share-url-row{display:flex;gap:8px}.share-url-input{flex:1;background:var(--bg-deep, #13120e);border:1px solid var(--color-border, #3a352c);border-radius:6px;color:var(--text-main, #e8e0d4);font-size:.78rem;padding:7px 10px;min-width:0;font-family:monospace}.share-url-input::-moz-placeholder{color:var(--text-muted, #6b6358)}.share-url-input::placeholder{color:var(--text-muted, #6b6358)}.share-btn{border:none;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600;padding:7px 14px;white-space:nowrap;transition:opacity .15s}.share-btn:disabled{opacity:.5;cursor:not-allowed}.share-btn-primary{background:var(--accent, #d4a24e);color:#1a1815}.share-btn-primary:hover:not(:disabled){opacity:.85}.share-btn-secondary{background:transparent;border:1px solid var(--color-border, #3a352c);color:var(--text-main, #e8e0d4)}.share-btn-secondary:hover{border-color:var(--accent, #d4a24e);color:var(--accent, #d4a24e)}.share-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.share-actions-note{font-size:.75rem;color:var(--text-muted, #a69d8f);line-height:1.4}.share-drop-zone{border:2px dashed var(--color-border, #3a352c);border-radius:8px;padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;gap:6px}.share-drop-zone:hover,.share-drop-zone-active{border-color:var(--accent, #d4a24e);background:#d4a24e0d}.share-drop-icon{font-size:1.8rem}.share-drop-label{font-size:.85rem;color:var(--text-main, #e8e0d4);margin:0}.share-drop-hint{font-size:.75rem;color:var(--text-muted, #a69d8f);margin:0}.share-file-hidden{display:none}.share-url-import{display:flex;flex-direction:column;gap:6px}.share-url-import-label{font-size:.8rem;color:var(--text-muted, #a69d8f)}.share-feedback{font-size:.83rem;padding:8px 12px;border-radius:6px}.share-feedback-error{background:#c452521f;border:1px solid rgba(196,82,82,.3);color:#c45c5c}.share-feedback-ok{background:#4aa0601f;border:1px solid rgba(74,160,96,.3);color:#4a9d5f}.share-import-note{font-size:.75rem;color:var(--text-muted, #6b6358);margin:0;line-height:1.4}.url-import-banner{position:fixed;top:0;left:0;right:0;z-index:8500;background:var(--bg-panel, #1e1c17);border-bottom:2px solid var(--accent, #d4a24e);padding:10px 16px}.url-import-banner-error{border-bottom-color:#c45c5c;background:#c452521f;display:flex;align-items:center;gap:12px;font-size:.85rem;color:#c45c5c}.url-import-banner-body{display:flex;align-items:center;gap:12px;flex-wrap:wrap;max-width:900px;margin:0 auto}.url-import-banner-icon{font-size:1.2rem;flex-shrink:0}.url-import-banner-text{flex:1;font-size:.85rem;color:var(--text-main, #e8e0d4);min-width:0}.url-import-banner-note{color:var(--text-muted, #a69d8f)}.url-import-banner-actions{display:flex;gap:8px;flex-shrink:0}.url-import-btn{border:none;border-radius:5px;cursor:pointer;font-size:.82rem;font-weight:600;padding:6px 12px}.url-import-btn-accept{background:var(--accent, #d4a24e);color:#1a1815}.url-import-btn-accept:hover{opacity:.85}.url-import-btn-dismiss{background:transparent;border:1px solid var(--color-border, #3a352c);color:var(--text-muted, #a69d8f)}.url-import-btn-dismiss:hover{color:var(--text-main, #e8e0d4)}body.herocore-no-decoration img[src^="/images/"],body.herocore-no-decoration .home-hero-art{display:none!important}body.herocore-no-decoration .home-hero-card .home-hero-content{padding-top:1.5rem}.kit-modal-overlay{position:fixed;inset:0;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);box-sizing:border-box;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(2px)}.kit-modal{background:var(--bg-card);border:1px solid rgba(212,162,78,.35);border-radius:14px;width:100%;max-width:520px;max-height:82vh;max-height:min(82vh,var(--app-visible-height, 82vh) - 32px);display:flex;flex-direction:column;box-shadow:0 24px 60px #0009,0 0 0 1px #d4a24e1a}.kit-modal-header{padding:18px 20px 14px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.kit-modal-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--accent-bright);letter-spacing:.03em;margin-bottom:5px}.kit-modal-subtitle{font-size:.8rem;color:var(--text-muted);line-height:1.4;margin-bottom:10px}.kit-modal-totals{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.kit-total-chip{font-size:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:3px 10px;color:var(--text-secondary);white-space:nowrap}.kit-modal-list{flex:1;overflow-y:auto;padding:8px 4px 8px 12px;scrollbar-width:thin;scrollbar-color:rgba(212,162,78,.3) transparent}.kit-modal-item{padding:10px 12px 10px 10px;border-radius:8px;margin-bottom:4px;background:#ffffff05;border:1px solid transparent;transition:background .15s,border-color .15s}.kit-modal-item:hover{background:#d4a24e0d;border-color:#d4a24e26}.kit-modal-item-header{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.kit-modal-item-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center;opacity:.85}.kit-modal-item-name-block{display:flex;align-items:baseline;gap:6px;flex:1;min-width:0}.kit-modal-item-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kit-modal-item-qty{font-size:.8rem;font-weight:700;color:var(--accent-bright);background:#d4a24e1f;border-radius:4px;padding:0 5px;flex-shrink:0}.kit-modal-item-note{font-size:.72rem;color:var(--text-muted);font-style:italic;flex-shrink:0}.kit-modal-item-pills{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap;margin-left:auto}.kit-pill{font-size:.7rem;border-radius:4px;padding:2px 7px;font-weight:600;white-space:nowrap}.kit-pill-hands{background:#63b3ed1f;color:#63b3ed;border:1px solid rgba(99,179,237,.2)}.kit-pill-bulk{background:#ffffff0f;color:var(--text-muted);border:1px solid rgba(255,255,255,.08)}.kit-pill-price{background:#d4a24e1a;color:var(--accent-bright);border:1px solid rgba(212,162,78,.2)}.kit-modal-item-desc{margin-top:5px;margin-left:27px;font-size:.78rem;color:var(--text-muted);line-height:1.45;border-left:2px solid rgba(212,162,78,.2);padding-left:8px}.kit-modal-actions{display:flex;gap:10px;padding:14px 20px;border-top:1px solid rgba(255,255,255,.07);justify-content:flex-end;flex-shrink:0}.kit-modal-cancel{padding:8px 18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:background .15s}.kit-modal-cancel:hover{background:#ffffff1a;color:var(--text-primary)}.kit-modal-confirm{padding:8px 20px;background:linear-gradient(135deg,#d4a24e,#c4922e);border:none;border-radius:6px;color:#1a1008;font-weight:700;font-size:.85rem;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.kit-modal-confirm:hover{opacity:.9;transform:translateY(-1px)}.eq-shop-row-kit{border-left:3px solid rgba(212,162,78,.5);background:#d4a24e06}.eq-kit-badge{display:inline-block;font-size:.68rem;font-weight:700;background:#d4a24e2e;color:var(--accent-bright);border-radius:4px;padding:1px 6px;margin-left:7px;vertical-align:middle;border:1px solid rgba(212,162,78,.25)}.eq-kit-preview{display:flex;flex-wrap:wrap;gap:4px;padding:5px 0 8px 2px}.eq-kit-preview-chip{font-size:.7rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:2px 7px;color:var(--text-muted);white-space:nowrap}.about-overlay{position:fixed;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);box-sizing:border-box;inset:0;z-index:1000;background:#0a0908d9;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:about-overlay-in .2s ease}@keyframes about-overlay-in{0%{opacity:0}to{opacity:1}}.about-modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-top:2px solid var(--accent);border-radius:6px;box-shadow:0 0 0 1px #d4a24e14,0 20px 60px #000000b3,0 0 40px #d4a24e0d;width:100%;max-width:680px;max-height:90vh;max-height:min(90vh,var(--app-visible-height, 90vh) - 32px);display:flex;flex-direction:column;animation:about-modal-in .25s var(--ease-out);overflow:hidden}@keyframes about-modal-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.about-header{position:relative;text-align:center;padding:1.75rem 3rem 1.25rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-surface) 100%);flex-shrink:0}.about-header-ornament{color:var(--accent-dim);font-size:.7rem;letter-spacing:.5rem;margin-bottom:.25rem}.about-title{font-family:var(--font-display);font-size:1.75rem;font-weight:600;color:var(--accent);margin:.15rem 0;letter-spacing:.08em;text-shadow:0 0 20px rgba(212,162,78,.3)}.about-tagline{font-family:var(--font-body);font-size:.9rem;color:var(--text-secondary);font-style:italic;margin:.15rem 0 .4rem;letter-spacing:.03em}.about-close-btn{position:absolute;top:.85rem;right:.85rem;background:none;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:.8rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.about-close-btn:hover{color:var(--text-primary);border-color:var(--border-strong);background:var(--bg-hover)}.about-body{overflow-y:auto;flex:1;padding:0 1.75rem;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.about-body::-webkit-scrollbar{width:5px}.about-body::-webkit-scrollbar-track{background:transparent}.about-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.about-section{padding:1.25rem 0}.about-section-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin:0 0 .85rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.about-section-content{font-family:var(--font-body);font-size:.97rem;color:var(--text-primary);line-height:1.75}.about-section-content p{margin:0 0 .75rem;color:var(--text-secondary)}.about-section-content p:last-child{margin-bottom:0}.about-section-content strong{color:var(--text-primary);font-weight:600}.about-section-content em{color:var(--text-primary);font-style:italic}.about-links{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.about-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--accent);text-decoration:none;font-size:.9rem;padding:.3rem .75rem;border:1px solid var(--border-accent);border-radius:4px;background:var(--accent-glow);transition:background .15s,border-color .15s,color .15s}.about-link:hover{background:var(--accent-glow-strong);border-color:var(--accent-dim);color:var(--accent-bright)}.about-link-inline{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(212,162,78,.3);transition:border-color .15s,color .15s}.about-link-inline:hover{color:var(--accent-bright);border-bottom-color:var(--accent)}.about-section-legal .about-section-title{color:var(--text-secondary)}.about-orc-block{border:1px solid var(--border);border-left:3px solid var(--accent-dim);border-radius:4px;background:var(--bg-card);overflow:hidden;margin-bottom:.85rem}.about-orc-row{display:grid;grid-template-columns:180px 1fr;gap:0;border-bottom:1px solid var(--border);font-size:.88rem;line-height:1.65}.about-orc-row:last-child{border-bottom:none}.about-orc-label{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--accent-dim);text-transform:uppercase;padding:.85rem .9rem .75rem;background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;align-items:flex-start}.about-orc-text{padding:.75rem 1rem;color:var(--text-secondary);font-size:.87rem;line-height:1.7}.about-orc-text strong{color:var(--text-primary)}.about-orc-text em{color:var(--text-primary);font-style:italic}.about-legal-note{font-size:.82rem!important;color:var(--text-muted)!important;font-style:italic;line-height:1.6!important}.about-credits-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.about-credit-item{display:flex;flex-direction:column;gap:.15rem;padding:.6rem .85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;font-size:.87rem}.about-credit-label{font-family:var(--font-display);font-size:.68rem;font-weight:600;letter-spacing:.06em;color:var(--accent-dim);text-transform:uppercase}.about-credit-item span:not(.about-credit-label),.about-credit-item a{color:var(--text-secondary)}.about-version-block{border:1px solid var(--border);border-left:3px solid var(--accent-dim);border-radius:4px;background:var(--bg-card);overflow:hidden;margin-bottom:.75rem}.about-version-block-planned{border-left-color:var(--border-strong);opacity:.85}.about-version-header{display:flex;align-items:center;gap:.6rem;padding:.55rem .9rem;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.about-version-badge{font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.06em;color:var(--bg-deep);background:var(--accent);padding:.15rem .5rem;border-radius:3px}.about-version-badge-planned{background:var(--border-strong);color:var(--text-secondary)}.about-version-title{font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.05em;color:var(--text-primary)}.about-version-grid{padding:.75rem .9rem;display:flex;flex-direction:column;gap:.75rem}.about-version-group{display:flex;flex-direction:column;gap:.35rem}.about-version-group-label{font-family:var(--font-display);font-size:.68rem;font-weight:600;letter-spacing:.05em;color:var(--text-muted);text-transform:uppercase}.about-version-tags{display:flex;flex-wrap:wrap;gap:.3rem}.about-tag{font-size:.78rem;font-family:var(--font-body);padding:.15rem .5rem;border-radius:3px;border:1px solid;white-space:nowrap}.about-tag-done{color:var(--success);border-color:#5a9e6f4d;background:#5a9e6f14}.about-tag-partial{color:var(--accent-dim);border-color:#d4a24e4d;background:#d4a24e14}.about-tag-planned{color:var(--text-muted);border-color:var(--border);background:transparent}.about-section-support{background:linear-gradient(135deg,rgba(212,162,78,.03) 0%,transparent 60%);border-radius:4px;padding:1.25rem .5rem}.about-kofi-wrapper{display:flex;justify-content:center;margin:1rem 0}.about-kofi-btn{display:inline-flex;align-items:center;gap:.6rem;padding:.6rem 1.4rem;background:#ff5e5b;color:#fff;font-weight:600;font-size:.95rem;border-radius:6px;text-decoration:none;transition:background .2s,transform .15s;font-family:var(--font-display);letter-spacing:.02em}.about-kofi-btn:hover{background:#e04e4b;transform:translateY(-1px)}.about-kofi-icon{width:22px;height:22px;-o-object-fit:contain;object-fit:contain}.about-divider{text-align:center;color:var(--text-muted);font-size:.75rem;letter-spacing:.1em;margin:0;opacity:.6}.about-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-top:1px solid var(--border);background:var(--bg-elevated);font-size:.78rem;color:var(--text-muted);font-family:var(--font-display);letter-spacing:.04em;flex-shrink:0}.about-footer-sep{color:var(--border-strong)}@media (max-width: 600px){.about-modal{max-height:95vh;max-height:min(95vh,var(--app-visible-height, 95vh) - 16px);border-radius:4px}.about-header{padding:1.25rem 2.5rem 1rem}.about-title{font-size:1.35rem}.about-orc-row{grid-template-columns:1fr}.about-orc-label{border-right:none;border-bottom:1px solid var(--border);padding:.5rem .9rem}.about-credits-grid{grid-template-columns:1fr}.about-footer{flex-wrap:wrap;text-align:center;gap:.25rem}}.about-activate-wrapper{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);text-align:center}.about-activate-hint{font-size:.85rem;color:var(--text-muted);margin:0 0 .75rem}.about-activate-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:transparent;border:1px solid rgba(212,162,78,.45);border-radius:6px;font-family:var(--font-display);font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--accent);cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s}.about-activate-btn:hover{background:#d4a24e14;border-color:#d4a24eb3;box-shadow:0 0 10px #d4a24e26}.about-activate-btn--active{background:#d4a24e1a;border-color:#d4a24e99}.about-activate-btn--active:hover{background:#d4a24e26;border-color:var(--accent);box-shadow:0 0 12px #d4a24e33}.about-supporter-info{margin-top:.85rem;padding:.85rem 1rem;background:#d4a24e0f;border:1px solid rgba(212,162,78,.2);border-radius:6px;text-align:left;animation:supporter-info-in .2s ease-out}@keyframes supporter-info-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.about-supporter-info p{font-size:.82rem;color:var(--text-secondary);line-height:1.55;margin:0 0 .5rem}.about-supporter-info p:last-child{margin-bottom:0}.about-supporter-info a{color:var(--accent-dim);text-decoration:none}.about-supporter-info a:hover{color:var(--accent);text-decoration:underline}.about-toggle-row{display:flex;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;background:#d4a24e0a;border:1px solid rgba(212,162,78,.18);border-radius:6px;cursor:pointer;transition:background .2s,border-color .2s}.about-toggle-row:hover{background:#d4a24e14;border-color:#d4a24e4d}.about-toggle-input{margin-top:.2rem;flex-shrink:0;width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.about-toggle-text{display:flex;flex-direction:column;gap:.25rem}.about-toggle-label{font-size:.92rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em}.about-toggle-hint{font-size:.8rem;color:var(--text-secondary);line-height:1.5}.whatsnew-overlay{position:fixed;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);box-sizing:border-box;inset:0;background:#0a0a0ec7;backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:whatsnew-fade-in .18s ease-out}@keyframes whatsnew-fade-in{0%{opacity:0}to{opacity:1}}.whatsnew-modal{background:var(--bg-secondary, #1c1a17);color:var(--text-primary, #e8e0d4);border:1px solid var(--border-color, #4a3f30);border-radius:8px;width:100%;max-width:760px;max-height:90vh;max-height:min(90vh,var(--app-visible-height, 90vh) - 32px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0009;animation:whatsnew-slide-up .22s cubic-bezier(.2,.9,.3,1)}@keyframes whatsnew-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.whatsnew-header{position:relative;text-align:center;padding:1.4rem 1.4rem 1.1rem;background:linear-gradient(180deg,rgba(212,162,78,.08),transparent);border-bottom:1px solid var(--border-color, #4a3f30)}.whatsnew-header-ornament{font-size:.85rem;color:var(--accent-gold, #d4a24e);letter-spacing:.4em;opacity:.7}.whatsnew-title{font-family:Cinzel,Georgia,serif;font-size:1.7rem;font-weight:600;margin:.2rem 0 .3rem;color:var(--text-primary, #e8e0d4);letter-spacing:.05em}.whatsnew-tagline{margin:0;font-size:.9rem;color:var(--text-secondary, #a69d8f)}.whatsnew-close-btn{position:absolute;top:.8rem;right:.9rem;width:32px;height:32px;border:none;background:#ffffff0f;color:var(--text-secondary, #a69d8f);border-radius:50%;font-size:1rem;cursor:pointer;transition:background .12s,color .12s,transform .12s;display:flex;align-items:center;justify-content:center}.whatsnew-close-btn:hover{background:#ffffff1f;color:var(--text-primary, #e8e0d4);transform:rotate(90deg)}.whatsnew-body{flex:1;overflow-y:auto;padding:1.5rem 1.6rem;scroll-behavior:smooth}.whatsnew-body::-webkit-scrollbar{width:8px}.whatsnew-body::-webkit-scrollbar-track{background:#0003}.whatsnew-body::-webkit-scrollbar-thumb{background:#d4a24e40;border-radius:4px}.whatsnew-body::-webkit-scrollbar-thumb:hover{background:#d4a24e66}.whatsnew-version+.whatsnew-version{margin-top:2rem}.whatsnew-version-head{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem}.whatsnew-version-badge{display:inline-block;padding:.3rem .7rem;background:linear-gradient(135deg,#d4a24e,#b8862f);color:#1c1a17;font-family:Cinzel,Georgia,serif;font-weight:700;font-size:.95rem;letter-spacing:.05em;border-radius:4px;box-shadow:0 2px 6px #d4a24e4d}.whatsnew-version-meta{display:flex;flex-direction:column;gap:.1rem}.whatsnew-version-codename{font-family:Cinzel,Georgia,serif;font-size:1.05rem;color:var(--text-primary, #e8e0d4);font-weight:600}.whatsnew-version-date{font-size:.78rem;color:var(--text-secondary, #a69d8f);text-transform:uppercase;letter-spacing:.08em}.whatsnew-version-highlight{margin:.4rem 0 1.2rem;padding:.7rem .9rem;background:#d4a24e14;border-left:3px solid var(--accent-gold, #d4a24e);border-radius:0 4px 4px 0;font-style:italic;font-size:.95rem;color:var(--text-primary, #e8e0d4)}.whatsnew-section{margin:1.2rem 0}.whatsnew-section-title{display:flex;align-items:center;gap:.5rem;margin:0 0 .7rem;font-family:Cinzel,Georgia,serif;font-size:1rem;font-weight:600;color:var(--accent-gold, #d4a24e);border-bottom:1px solid rgba(212,162,78,.2);padding-bottom:.35rem}.whatsnew-section-icon{font-size:1.1rem}.whatsnew-section-known .whatsnew-section-title{color:#d4a04e;border-bottom-color:#d4a04e40}.whatsnew-item-list{list-style:none;padding:0;margin:0}.whatsnew-item{padding:.7rem .9rem;margin:.5rem 0;background:#ffffff06;border-left:2px solid rgba(212,162,78,.4);border-radius:0 4px 4px 0;transition:background .12s}.whatsnew-item:hover{background:#ffffff0d}.whatsnew-item-known{border-left-color:#dc824680;background:#dc82460d}.whatsnew-item-known:hover{background:#dc824614}.whatsnew-item-title{font-weight:600;font-size:.95rem;color:var(--text-primary, #e8e0d4);margin-bottom:.25rem}.whatsnew-item-desc{font-size:.88rem;color:var(--text-secondary, #a69d8f);line-height:1.45}.whatsnew-divider{text-align:center;margin:1.8rem 0 .6rem;color:#d4a24e66;font-size:.85rem;letter-spacing:.3em}.whatsnew-footer{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.4rem;background:#00000040;border-top:1px solid var(--border-color, #4a3f30);font-size:.82rem;color:var(--text-secondary, #a69d8f);font-style:italic}.whatsnew-footer-close{padding:.45rem 1.1rem;background:linear-gradient(135deg,#d4a24e,#b8862f);color:#1c1a17;border:none;border-radius:4px;font-family:Cinzel,Georgia,serif;font-weight:600;font-size:.85rem;letter-spacing:.05em;cursor:pointer;transition:transform .12s,box-shadow .12s}.whatsnew-footer-close:hover{transform:translateY(-1px);box-shadow:0 4px 10px #d4a24e4d}.whatsnew-footer-close:active{transform:translateY(0)}.whatsnew-trigger-btn{position:relative;background:none;border:none;color:inherit;font:inherit;cursor:pointer;padding:.2rem .4rem;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;transition:color .12s}.whatsnew-trigger-btn:hover{color:var(--accent-gold, #d4a24e)}.whatsnew-trigger-btn .whatsnew-unread-dot{position:absolute;top:0;right:-2px;width:8px;height:8px;background:#e8504a;border-radius:50%;box-shadow:0 0 6px #e8504a99;animation:whatsnew-pulse 1.6s ease-in-out infinite}@keyframes whatsnew-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}@media (max-width: 640px){.whatsnew-overlay{padding:.5rem}.whatsnew-modal{max-height:95vh;max-height:min(95vh,var(--app-visible-height, 95vh) - 16px);border-radius:6px}.whatsnew-header{padding:1.1rem 1rem .9rem}.whatsnew-title{font-size:1.4rem}.whatsnew-body{padding:1rem}.whatsnew-version-head{flex-wrap:wrap}.whatsnew-footer{flex-direction:column;gap:.6rem;padding:.8rem 1rem}}.home-screen{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-deep);color:var(--text-primary);font-family:var(--font-body);overflow-x:hidden}.home-bg-grain{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px}.home-header{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,var(--bg-deep) 60%,transparent);padding:28px 32px 20px}.home-header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.home-logo{display:flex;align-items:center;gap:14px}.home-logo-icon{font-size:2rem;color:var(--accent);filter:drop-shadow(0 0 8px rgba(212,162,78,.3))}.home-logo-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.04em}.home-logo-accent{color:var(--accent)}.home-logo-tagline{display:block;font-family:var(--font-body);font-size:.78rem;color:var(--text-muted);letter-spacing:.06em;margin-top:2px}.home-library-btn{display:flex;align-items:center;gap:6px;padding:7px 16px;border-radius:8px;border:1px solid rgba(212,162,78,.3);background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.88rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.home-library-btn:hover{background:#d4a24e1a;border-color:var(--accent);color:var(--accent)}.home-hero-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:36px}.home-hero-row-three{grid-template-columns:1fr 1fr 1fr}@media (max-width: 900px){.home-hero-row-three{grid-template-columns:1fr 1fr}.home-hero-row-three .home-hero-codex{grid-column:1 / -1}}@media (max-width: 600px){.home-hero-row-three{grid-template-columns:1fr}.home-hero-row-three .home-hero-codex{grid-column:auto}}.home-hero-card{position:relative;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),border-color .3s;text-align:left;font-family:var(--font-body);color:var(--text-primary);padding:0}.home-hero-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000080}.home-hero-build:hover{border-color:var(--accent-dim);box-shadow:0 12px 40px #00000080,0 0 30px #d4a24e1a}.home-hero-play:hover{border-color:var(--success);box-shadow:0 12px 40px #00000080,0 0 30px #5a9e6f1a}.home-hero-art{position:relative;width:100%;height:180px;overflow:hidden}.home-hero-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center 20%;object-position:center 20%;transition:transform .5s var(--ease-out),filter .3s;filter:brightness(.85) saturate(.9)}.home-hero-card:hover .home-hero-art img{transform:scale(1.06);filter:brightness(.95) saturate(1)}.home-hero-art-fade{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to top,var(--bg-card) 0%,transparent 100%);pointer-events:none}.home-hero-content{padding:4px 22px 22px;display:flex;flex-direction:column;gap:4px}.home-hero-icon{font-size:1.4rem;line-height:1}.home-hero-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.03em}.home-hero-build .home-hero-title{color:var(--accent)}.home-hero-play .home-hero-title{color:var(--success)}.home-hero-desc{font-size:.84rem;color:var(--text-secondary);line-height:1.5;margin:2px 0 0}.home-hero-cta{display:inline-block;margin-top:8px;font-family:var(--font-display);font-size:.82rem;font-weight:600;letter-spacing:.03em;opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s var(--ease-out)}.home-hero-build .home-hero-cta{color:var(--accent)}.home-hero-play .home-hero-cta{color:var(--success)}.home-hero-card:hover .home-hero-cta{opacity:1;transform:translateY(0)}.home-hero-disabled{opacity:.68;cursor:not-allowed;pointer-events:none}.home-hero-disabled .home-hero-art img{filter:brightness(.5) saturate(.3)}.home-hero-codex:hover{border-color:#7b68ee;box-shadow:0 12px 40px #00000080,0 0 30px #7b68ee26}.home-hero-codex .home-hero-title,.home-hero-codex .home-hero-cta{color:#9d8fe8}.home-hero-codex .home-hero-art img{-o-object-position:center 30%;object-position:center 30%}.home-main{position:relative;z-index:1;flex:1;max-width:1100px;width:100%;margin:0 auto;padding:12px 32px 60px}@media (max-width: 768px){.home-main--returning{display:flex;flex-direction:column}.home-main--returning>.home-hero-row{order:10;margin-top:24px}}.home-roster-header{display:flex;align-items:baseline;gap:12px;margin-bottom:24px}.home-roster-title{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0}.home-roster-count{font-size:.82rem;color:var(--text-muted)}.home-roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:32px}.home-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out),border-color .2s}.home-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.home-card-new{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;border-style:dashed;border-color:var(--border-strong);min-height:180px;background:transparent;color:var(--text-secondary);font-family:var(--font-body);text-align:center}.home-card-new:hover{border-color:var(--accent-dim);background:var(--accent-glow)}.home-card-new-icon{font-size:2.4rem;color:var(--accent-dim);line-height:1;transition:color .2s}.home-card-new:hover .home-card-new-icon{color:var(--accent)}.home-card-new-label{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary)}.home-card-new-hint{font-size:.78rem;color:var(--text-muted)}.home-card-character{border-left:4px solid var(--card-accent, var(--accent-dim));position:relative}.home-card-character:hover{border-color:var(--card-accent, var(--accent));border-left-color:var(--card-accent, var(--accent))}.home-card-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}.home-card-class-icon{font-size:1.6rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:8px;border:1px solid var(--border)}.home-card-identity{flex:1;min-width:0}.home-card-name{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-card-class-line{font-size:.82rem;color:var(--text-secondary);display:flex;align-items:center;gap:5px;flex-wrap:wrap}.home-card-dot{color:var(--text-muted)}.home-card-level{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--accent);background:var(--accent-glow);padding:1px 7px;border-radius:4px}.home-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.home-card-meta-item{font-size:.76rem;color:var(--text-secondary);background:var(--bg-elevated);padding:3px 8px;border-radius:4px}.home-card-hp{color:var(--success)}.home-card-actions{display:flex;gap:6px;margin-top:auto}.home-card-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 10px;font-family:var(--font-body);font-size:.82rem;font-weight:500;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;background:var(--bg-elevated);color:var(--text-secondary)}.home-card-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.home-card-btn-build:hover{border-color:var(--accent-dim);color:var(--accent)}.home-card-btn-play:hover{border-color:var(--success);color:var(--success)}.home-card-btn-export,.home-card-btn-delete{flex:0 0 auto;padding:7px 10px}.home-card-btn-delete:hover{border-color:var(--error);color:var(--error)}.home-card-saved{margin-top:10px;font-size:.72rem;color:var(--text-muted);text-align:right}.home-import-bar{display:flex;align-items:center;gap:12px}.home-import-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--bg-card);border:1px dashed var(--border-strong);border-radius:8px;color:var(--text-secondary);font-family:var(--font-body);font-size:.88rem;cursor:pointer;transition:all .15s}.home-import-btn:hover{border-color:var(--accent-dim);color:var(--text-primary);background:var(--accent-glow)}.home-import-error{font-size:.82rem;color:var(--error)}.home-overlay{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(6px);animation:p-fade-in .2s ease}.home-confirm{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:14px;padding:28px 32px;max-width:400px;width:90%;box-shadow:var(--shadow-lg);animation:p-slide-up .25s var(--ease-out)}.home-confirm h3{font-family:var(--font-display);font-size:1.15rem;color:var(--text-primary);margin:0 0 8px}.home-confirm p{font-size:.9rem;color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.home-confirm-actions{display:flex;gap:10px;justify-content:flex-end}.home-confirm-cancel{padding:8px 18px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-family:var(--font-body);font-size:.88rem;cursor:pointer;transition:all .15s}.home-confirm-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.home-confirm-delete{padding:8px 18px;background:var(--error);border:1px solid transparent;border-radius:6px;color:#fff;font-family:var(--font-body);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s}.home-confirm-delete:hover{filter:brightness(1.1)}.home-toast{position:fixed;bottom:max(32px,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:10000;background:var(--bg-card);border:1px solid var(--accent-dim);color:var(--accent);padding:10px 24px;border-radius:8px;font-family:var(--font-body);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);animation:p-toast-in .3s var(--ease-out);pointer-events:none}.home-footer{position:relative;z-index:1;text-align:center;padding:20px 32px;font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:8px;border-top:1px solid var(--border)}.home-footer-brand{font-family:var(--font-display);font-weight:600;color:var(--text-secondary)}.home-footer-link{color:var(--accent-dim);text-decoration:none;transition:color .15s}.home-footer-link:hover{color:var(--accent)}.supporter-activation-overlay{position:fixed;inset:0;z-index:2000;background:#0a0908eb;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:supporter-overlay-in .25s var(--ease-out)}@keyframes supporter-overlay-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.supporter-activation-modal{background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:12px;box-shadow:var(--shadow-lg),0 0 40px #d4a24e1f;width:100%;max-width:480px;overflow:hidden;animation:supporter-modal-in .3s var(--ease-out)}@keyframes supporter-modal-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.supporter-activation-header{padding:2rem 2rem 1.5rem;text-align:center;background:linear-gradient(180deg,rgba(212,162,78,.08) 0%,transparent 100%);border-bottom:1px solid var(--border)}.supporter-activation-star{font-size:1.8rem;color:var(--accent);margin-bottom:.5rem;text-shadow:0 0 16px rgba(212,162,78,.6);animation:supporter-star-pulse 2.5s ease-in-out infinite}@keyframes supporter-star-pulse{0%,to{text-shadow:0 0 16px rgba(212,162,78,.6)}50%{text-shadow:0 0 28px rgba(212,162,78,.9)}}.supporter-activation-title{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--accent);margin:0 0 .4rem;letter-spacing:.03em}.supporter-activation-sub{font-size:.95rem;color:var(--text-secondary);margin:0}.supporter-activation-body{padding:1.75rem 2rem 2rem}.supporter-activation-desc{font-size:.95rem;color:var(--text-secondary);margin:0 0 1.25rem;line-height:1.6}.supporter-activation-highlight{color:var(--accent);font-weight:600}.supporter-activation-warning{display:flex;gap:.65rem;align-items:flex-start;background:#d4a24e12;border:1px solid rgba(212,162,78,.25);border-radius:6px;padding:.75rem .9rem;margin-bottom:1.25rem}.supporter-warning-icon{flex-shrink:0;font-size:.95rem;margin-top:.05rem}.supporter-warning-text{font-size:.83rem;color:var(--text-secondary);line-height:1.5}.supporter-warning-text strong{color:var(--accent-bright);display:block;margin-bottom:.2rem}.supporter-activation-input-group{margin-bottom:1rem}.supporter-activation-label{display:block;font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}.supporter-activation-input{width:100%;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:6px;padding:.7rem 1rem;font-family:var(--font-mono),monospace;font-size:1rem;letter-spacing:.08em;color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.supporter-activation-input::-moz-placeholder{color:var(--text-muted);letter-spacing:.04em}.supporter-activation-input::placeholder{color:var(--text-muted);letter-spacing:.04em}.supporter-activation-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #d4a24e26}.supporter-activation-input.supporter-activation-input-error{border-color:var(--error);box-shadow:0 0 0 2px #c4525226}.supporter-activation-error-msg{font-size:.85rem;color:var(--error);margin:.5rem 0 0}.supporter-activation-actions{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.25rem}.supporter-activation-btn-primary{width:100%;padding:.8rem 1rem;background:linear-gradient(135deg,var(--accent-dim) 0%,var(--accent) 100%);border:none;border-radius:6px;font-family:var(--font-display);font-size:.9rem;font-weight:600;letter-spacing:.04em;color:#1a1510;cursor:pointer;transition:opacity .2s,transform .1s,box-shadow .2s;box-shadow:0 2px 12px #d4a24e40}.supporter-activation-btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #d4a24e66}.supporter-activation-btn-primary:disabled{opacity:.5;cursor:not-allowed}.supporter-activation-btn-secondary{width:100%;padding:.65rem 1rem;background:transparent;border:1px solid var(--border-strong);border-radius:6px;font-size:.88rem;color:var(--text-secondary);cursor:pointer;transition:border-color .2s,color .2s}.supporter-activation-btn-secondary:hover:not(:disabled){border-color:var(--border-accent);color:var(--text-primary)}.supporter-activation-kofi-hint{font-size:.82rem;color:var(--text-muted);text-align:center;margin:0}.supporter-activation-kofi-link{color:var(--accent-dim);text-decoration:none}.supporter-activation-kofi-link:hover{color:var(--accent);text-decoration:underline}.supporter-activation-success{padding:2rem 2rem 2.25rem;text-align:center}.supporter-activation-success-icon{font-size:3rem;margin-bottom:1rem;animation:supporter-trophy-bounce .6s var(--ease-out)}@keyframes supporter-trophy-bounce{0%{transform:scale(0) rotate(-10deg)}70%{transform:scale(1.15) rotate(3deg)}to{transform:scale(1) rotate(0)}}.supporter-activation-success h2{font-family:var(--font-display);font-size:1.3rem;color:var(--accent);margin:0 0 .6rem}.supporter-activation-success>p{font-size:.95rem;color:var(--text-secondary);margin:0 0 1.25rem;line-height:1.6}.supporter-activation-save-reminder{display:flex;gap:.7rem;align-items:flex-start;text-align:left;background:#d4a24e12;border:1px solid rgba(212,162,78,.25);border-radius:6px;padding:.9rem 1rem;margin-bottom:1.25rem}.supporter-save-icon{flex-shrink:0;font-size:1rem}.supporter-activation-save-reminder strong{display:block;font-size:.88rem;color:var(--accent-bright);margin-bottom:.3rem}.supporter-activation-save-reminder p{font-size:.82rem!important;color:var(--text-secondary)!important;margin:0!important;line-height:1.5}.supporter-activation-save-reminder a{color:var(--accent-dim);text-decoration:none}.supporter-activation-save-reminder a:hover{color:var(--accent);text-decoration:underline}.supporter-activation-redirect{font-size:.82rem!important;color:var(--text-muted)!important;font-style:italic;margin-top:.5rem!important}.supporter-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;background:linear-gradient(135deg,#d4a24e1f,#edb85a2e);border:1px solid rgba(212,162,78,.45);border-radius:20px;font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);white-space:nowrap;box-shadow:0 0 8px #d4a24e1f;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:box-shadow .2s}.supporter-badge:hover{box-shadow:0 0 14px #d4a24e47}.supporter-badge-star{font-size:.8rem;animation:badge-star-shine 3s ease-in-out infinite}@keyframes badge-star-shine{0%,to{opacity:1}50%{opacity:.6;text-shadow:0 0 6px var(--accent)}}.home-header-badge-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.supporter-badge-wrapper{position:relative;display:inline-flex}button.supporter-badge{background:linear-gradient(135deg,#d4a24e1f,#edb85a2e);border:1px solid rgba(212,162,78,.45);cursor:pointer}button.supporter-badge:hover{box-shadow:0 0 18px #d4a24e59;border-color:#d4a24eb3}.supporter-badge-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:500;width:300px;background:var(--bg-surface);border:1px solid rgba(212,162,78,.35);border-radius:8px;box-shadow:var(--shadow-lg),0 0 20px #d4a24e1a;padding:1rem 1rem .9rem;animation:supporter-popover-in .18s ease-out}@keyframes supporter-popover-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.supporter-badge-popover-title{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--accent);margin:0 0 .6rem;padding-right:1.2rem}.supporter-badge-popover p{font-size:.8rem;color:var(--text-secondary);line-height:1.55;margin:0 0 .5rem}.supporter-badge-popover p:last-child{margin-bottom:0}.supporter-badge-popover a{color:var(--accent-dim);text-decoration:none}.supporter-badge-popover a:hover{color:var(--accent);text-decoration:underline}.supporter-badge-popover-thanks{font-size:.78rem;color:var(--text-muted);margin:0 0 .65rem;font-style:italic}.supporter-badge-perks{list-style:none;margin:0 0 .9rem;padding:0;display:flex;flex-direction:column;gap:.3rem}.supporter-badge-perks li{display:flex;align-items:baseline;gap:.4rem;font-size:.78rem;color:var(--text-secondary);line-height:1.4}.supporter-perk-icon{flex-shrink:0;font-size:.7rem;width:1rem;text-align:center;opacity:.8}.supporter-perk-legend{color:var(--accent-dim)!important}.supporter-badge-token-section{border-top:1px solid var(--border);padding-top:.7rem;margin-top:.1rem}.supporter-badge-token-section p{font-size:.78rem;color:var(--text-secondary);margin:0 0 .3rem;line-height:1.5}.supporter-badge-token-label{font-size:.7rem!important;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)!important;margin-bottom:.2rem!important}.supporter-badge-token-value{font-family:var(--font-mono),monospace;font-size:.82rem!important;letter-spacing:.05em;color:var(--accent)!important;font-weight:600;margin-bottom:.25rem!important}.supporter-badge-token-hint{font-size:.72rem!important;color:var(--text-muted)!important}.supporter-badge-popover-close{position:absolute;top:.5rem;right:.6rem;background:none;border:none;font-size:1rem;color:var(--text-muted);cursor:pointer;line-height:1;padding:.1rem .3rem;border-radius:3px;transition:color .15s}.supporter-badge-popover-close:hover{color:var(--text-primary)}.home-kofi-nudge{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .6rem;background:transparent;border:1px solid rgba(212,162,78,.2);border-radius:20px;font-family:var(--font-display);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;white-space:nowrap;transition:color .2s,border-color .2s,box-shadow .2s}.home-kofi-nudge:hover{color:var(--accent);border-color:#d4a24e73;box-shadow:0 0 8px #d4a24e1f}.supporter-activate-link{font-size:.78rem;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.supporter-activate-link:hover{color:var(--accent-dim)}
