/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-amber-800:oklch(47.3% .137 46.201);--color-violet-600:oklch(54.1% .281 293.009);--color-violet-700:oklch(49.1% .27 292.581);--color-violet-800:oklch(43.2% .232 292.759);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--font-weight-semibold:600;--tracking-wide:.025em;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.h-10{height:calc(var(--spacing) * 10)}.w-10{width:calc(var(--spacing) * 10)}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-amber-500{border-color:var(--color-amber-500)}.bg-amber-600{background-color:var(--color-amber-600)}.bg-violet-600{background-color:var(--color-violet-600)}.px-3{padding-inline:calc(var(--spacing) * 3)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media(hover:hover){.hover\:bg-amber-700:hover{background-color:var(--color-amber-700)}.hover\:bg-violet-700:hover{background-color:var(--color-violet-700)}}.disabled\:bg-amber-800:disabled{background-color:var(--color-amber-800)}.disabled\:bg-violet-800:disabled{background-color:var(--color-violet-800)}.disabled\:opacity-50:disabled{opacity:.5}}:root{--parchment:#f5e6c8;--parchment-mid:#edd9a8;--parchment-dark:#dfc58a;--ink:#1e120a;--ink-light:#3d2410;--gold:#c9a227;--gold-bright:#f0c040;--gold-dim:#8a6a10;--blood:#7a1515;--blood-bright:#a82020;--mist:#4a7a8a;--mist-light:#7aaebb;--stone:#1a1410;--stone-mid:#2a2018;--ember:#c06020;--shadow:#0009}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--ink);background-color:#0d0905;background-image:radial-gradient(at 20%,#783c0a26,#0000 60%),radial-gradient(at 80% 20%,#50280a1a,#0000 50%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;height:100vh;font-family:Crimson Text,serif;display:block;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex;overflow:hidden}header{text-align:center;border-bottom:2px solid var(--gold-dim);z-index:10;background:linear-gradient(#16100a,#0d0905);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;height:64px;display:flex;position:relative}header h1{color:var(--gold);text-shadow:0 0 15px #c9a22766;letter-spacing:.1em;text-transform:uppercase;font-family:Cinzel Decorative,serif;font-size:clamp(1.1rem,3.5vw,1.8rem);font-weight:700;line-height:1.2}header p{color:var(--gold-dim);letter-spacing:.3em;text-transform:uppercase;margin-top:-4px;font-family:Cinzel,serif;font-size:.625rem}.title-screen{background:#0d0905;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow-y:auto}.title-screen-bg{background-blend-mode:overlay;opacity:.15;pointer-events:none;background-image:radial-gradient(circle at 20% 30%,#c9a22726,#0000 40%),radial-gradient(circle at 80% 70%,#7a15151a,#0000 40%),url('data:image/svg+xml,%3Csvg width="100" height="100" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="n"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.8" numOctaves="4" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100" height="100" filter="url('%23n')"/%3E%3C/svg%3E');position:absolute;top:0;right:0;bottom:0;left:0}.title-screen-content{z-index:10;flex-direction:column;align-items:center;width:100%;max-width:600px;padding:40px;display:flex;position:relative}.title-logo{text-align:center;color:var(--mist);text-shadow:0 4px 20px #000c;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;font-family:Cinzel Decorative,serif;font-size:3rem;line-height:1.1}.title-logo-highlight{color:var(--gold);text-shadow:0 0 20px #c9a22780,0 0 40px #c9a22733;font-size:4.5rem;display:block}.title-subtitle{color:var(--gold-dim);letter-spacing:.3em;text-transform:uppercase;margin-bottom:64px;font-family:Cinzel,serif;font-size:1rem}.title-actions{flex-direction:column;width:100%;max-width:400px;display:flex}.start-adventure-btn{letter-spacing:.15em;border:1px solid var(--gold);border-radius:8px;width:100%;padding:16px 32px;font-size:1.1rem;box-shadow:0 0 20px #c9a22733,inset 0 0 10px #c9a2271a}.start-adventure-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #c9a22766,inset 0 0 15px #c9a22733}.title-saves-header{color:var(--gold);text-align:center;text-transform:uppercase;letter-spacing:.1em;margin:0 0 16px;font-family:Cinzel,serif;font-size:.9rem}.title-save-card{border:1px solid var(--gold-dim);background:#1a1410cc;border-radius:6px;justify-content:space-between;align-items:center;padding:16px;transition:border-color .2s,background .2s;display:flex}.title-save-card:hover{border-color:var(--gold);background:#c9a2271a}.title-save-info strong{color:var(--gold);margin-bottom:4px;font-size:1.1rem;display:block}.title-save-info span{color:var(--mist);opacity:.8;font-family:Inter,sans-serif;font-size:.8rem;display:block}.title-delete-btn{color:#d44;cursor:pointer;background:#a820201a;border:1px solid #a8202033;border-radius:4px;padding:8px;transition:all .2s;display:flex}.title-delete-btn:hover{color:#fff;background:#a82020cc;border-color:#f66}.app{background:var(--parchment);border-left:3px solid var(--gold-dim);border-right:3px solid var(--gold-dim);flex-direction:column;flex:1;width:100%;max-width:900px;margin:0 auto;display:flex;position:relative;overflow:hidden}.app:before{content:"";pointer-events:none;opacity:.5;z-index:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;top:0;right:0;bottom:0;left:0}.panel{z-index:1;flex-direction:column;flex:1;min-height:0;display:none;position:relative}.panel.active{display:flex}.chat-log{scrollbar-width:thin;scrollbar-color:var(--gold-dim) var(--parchment-mid);flex-direction:column;flex:1;gap:24px;padding:24px;display:flex;overflow-y:auto}.chat-log::-webkit-scrollbar{width:6px}.chat-log::-webkit-scrollbar-track{background:var(--parchment-mid)}.chat-log::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:3px}.msg{max-width:88%;animation:.3s forwards fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg.dm{align-self:flex-start}.msg.player{align-self:flex-end}.msg.system{align-self:center;max-width:96%}.msg-label{letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;font-family:inherit;font-size:.625rem;font-weight:700}.msg.dm .msg-label{color:var(--blood);padding-left:4px}.msg.player .msg-label{color:var(--mist);text-align:right;padding-right:4px}.msg-bubble{padding:16px;font-size:1rem;line-height:1.625;position:relative;overflow:visible}.msg.dm .msg-bubble{border-left:4px solid var(--blood);background:#ede0c0;border-radius:0 12px 12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.msg.player .msg-bubble{border-right:4px solid var(--mist);background:#f0e8d5;border-radius:12px 0 12px 12px;box-shadow:0 1px 2px #0000000d}.msg.system .msg-bubble{border:1px dashed var(--gold-dim);text-align:center;color:var(--ink-light);background:#c9a2271f;border-radius:4px;font-size:.92rem;font-style:italic}.typing-indicator{border-left:4px solid var(--blood);background:#ede0c0;border-radius:0 12px 12px;align-self:flex-start;align-items:center;gap:5px;padding:16px;display:flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.typing-dot{background:var(--blood);opacity:.7;border-radius:50%;width:7px;height:7px;animation:1.2s infinite typingBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.chat-input-area{background:var(--parchment-mid);border-top:2px solid var(--gold-dim);z-index:20;flex-shrink:0;gap:12px;padding:12px;display:flex}.chat-input-area textarea{background:var(--parchment);resize:none;min-height:46px;max-height:110px;color:var(--ink);border:2px solid #c9a22766;border-radius:8px;flex:1;padding:12px;font-family:Crimson Text,serif;font-size:.875rem;line-height:1.4;transition:border-color .2s}.chat-input-area textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 8px #c9a22733}.chat-input-area textarea::placeholder{color:var(--gold-dim);font-style:italic}.send-btn{background:var(--blood);color:#f5e6c8;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border:1px solid #0d090533;border-radius:8px;flex-shrink:0;padding:0 32px;font-family:Cinzel,serif;font-size:.75rem;font-weight:700;transition:background .2s,box-shadow .2s;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.send-btn:hover{background:#a82020;box-shadow:0 10px 15px -3px #0003}.send-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.char-sheet{scrollbar-width:thin;scrollbar-color:var(--gold-dim) var(--parchment-mid);flex:1;padding:20px;overflow-y:auto}.char-empty{text-align:center;color:#8b6f47;padding-top:60px;font-size:1.05rem;font-style:italic;line-height:1.8}.char-name-display{color:var(--blood);text-align:center;text-shadow:1px 1px 3px #00000026;margin-bottom:4px;font-family:Cinzel Decorative,serif;font-size:1.6rem}.char-tagline{text-align:center;color:var(--gold-dim);border-bottom:1px solid var(--parchment-dark);margin-bottom:20px;padding-bottom:16px;font-size:1rem;font-style:italic}.stat-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;display:grid}.stat-box{background:var(--parchment-mid);border:2px solid var(--parchment-dark);text-align:center;border-radius:6px;padding:10px}.stat-label{letter-spacing:.15em;color:var(--gold-dim);text-transform:uppercase;margin-bottom:4px;font-family:Cinzel,serif;font-size:.6rem}.stat-value{color:var(--blood);font-family:Cinzel,serif;font-size:1.4rem;font-weight:700}.stat-mod{color:var(--ink-light);font-size:.8rem}.char-section{margin-bottom:16px}.char-section-title{letter-spacing:.2em;text-transform:uppercase;color:var(--gold-dim);border-bottom:1px solid var(--parchment-dark);margin-bottom:8px;padding-bottom:4px;font-family:Cinzel,serif;font-size:.75rem}.char-section-body{color:var(--ink-light);font-size:.98rem;line-height:1.6}.hp-bar-wrap{background:#d4b87a;border-radius:4px;height:14px;margin-top:4px;overflow:hidden}.hp-bar{background:linear-gradient(90deg,var(--blood),var(--blood-bright));border-radius:4px;height:100%;transition:width .5s}.spells-sheet{scrollbar-width:thin;scrollbar-color:var(--gold-dim) var(--parchment-mid);flex:1;padding:20px;overflow-y:auto}.spells-sheet::-webkit-scrollbar{width:6px}.spells-sheet::-webkit-scrollbar-track{background:var(--parchment-mid)}.spells-sheet::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:3px}.spells-empty{text-align:center;color:#8b6f47;padding-top:60px;font-size:1.05rem;font-style:italic;line-height:1.8}.spell-slots-row{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.slot-pip-group{flex-direction:column;align-items:center;gap:4px;display:flex}.slot-pip-label{letter-spacing:.1em;color:var(--gold-dim);text-transform:uppercase;font-family:Cinzel,serif;font-size:.55rem}.slot-pips{gap:4px;display:flex}.slot-pip{border:2px solid var(--mist);background:var(--mist-light);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:background .15s,border-color .15s}.slot-pip.used{background:var(--parchment-dark);border-color:#b0956a}.slot-pip:hover{border-color:var(--gold)}.spell-item-btn{text-align:left;background:var(--parchment-mid);border:2px solid var(--parchment-dark);color:#fff;cursor:pointer;border-radius:8px;width:100%;padding:12px 16px;font-family:Cinzel,serif;font-size:1.1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 6px #0000004d}.spell-item-btn:hover{border-color:var(--gold);color:var(--gold);background:#dcb45033;box-shadow:0 0 10px #dcb4504d}.spell-card{background:var(--parchment-mid);border:2px solid var(--parchment-dark);cursor:default;border-radius:8px;margin-bottom:10px;padding:12px 14px;transition:border-color .2s,box-shadow .2s;position:relative}.spell-card:hover{border-color:var(--mist);box-shadow:0 2px 10px #4a7a8a33}.spell-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.spell-name{color:var(--blood);font-family:Cinzel,serif;font-size:.92rem;font-weight:600;line-height:1.2}.spell-badge-row{flex-wrap:wrap;flex-shrink:0;gap:5px;display:flex}.spell-badge{letter-spacing:.08em;white-space:nowrap;border-radius:10px;padding:2px 7px;font-family:Cinzel,serif;font-size:.58rem}.badge-level{color:var(--blood);background:#7a151526;border:1px solid #7a15154d}.badge-school{color:var(--mist);background:#4a7a8a26;border:1px solid #4a7a8a4d}.badge-ritual{color:var(--gold-dim);background:#c9a22726;border:1px solid #c9a2274d}.badge-conc{color:var(--ember);background:#c0602026;border:1px solid #c060204d}.spell-meta{color:var(--ink-light);flex-wrap:wrap;gap:14px;margin-bottom:6px;font-size:.8rem;display:flex}.spell-meta span{align-items:center;gap:3px;display:flex}.spell-meta-icon{opacity:.6}.spell-desc{color:var(--ink-light);font-size:.95rem;line-height:1.55}.ability-card{background:linear-gradient(135deg,#ede0c0 0%,var(--parchment-mid) 100%);border:2px solid var(--parchment-dark);border-left:4px solid var(--blood);border-radius:0 8px 8px 0;margin-bottom:10px;padding:12px 14px}.ability-name{color:var(--blood);margin-bottom:4px;font-family:Cinzel,serif;font-size:.9rem}.ability-uses{color:var(--gold-dim);margin-bottom:5px;font-size:.8rem;font-style:italic}.ability-desc{color:var(--ink-light);font-size:.95rem;line-height:1.5}.cantrip-card{background:#4a7a8a14;border:1px solid #4a7a8a40;border-radius:6px;margin-bottom:8px;padding:10px 13px}.cantrip-name{color:var(--mist);margin-bottom:3px;font-family:Cinzel,serif;font-size:.85rem}.save-panel-inner{scrollbar-width:thin;scrollbar-color:var(--gold-dim) var(--parchment-mid);flex:1;padding:20px;overflow-y:auto}.save-panel-inner h2{color:var(--blood);letter-spacing:.05em;margin-bottom:10px;font-family:Cinzel,serif;font-size:1rem}.save-panel-inner textarea{background:var(--parchment-mid);border:2px solid var(--parchment-dark);width:100%;color:var(--ink);resize:none;border-radius:6px;padding:10px;font-family:monospace;font-size:.78rem}.action-btn{letter-spacing:.1em;cursor:pointer;background:var(--parchment-mid);color:var(--ink);border:1px solid #0000;border-radius:6px;margin-top:8px;padding:9px 20px;font-family:Cinzel,serif;font-size:.75rem;transition:all .2s;display:inline-block}.action-btn:hover{opacity:1;filter:brightness(1.1);transform:translateY(-1px)}.btn-gold{background:var(--gold);color:var(--stone)}.btn-green{color:#f0e8d5;background:#3a6040}.save-divider{background:var(--parchment-dark);height:1px;margin:20px 0}.tabs{border-top:1px solid var(--gold-dim);z-index:20;background:#1a1410;flex-shrink:0;justify-content:center;align-items:center;height:48px;display:flex}.tab-btn{color:var(--gold-dim);letter-spacing:.2em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px 0 10px;font-family:Cinzel,serif;font-size:.75rem;font-weight:700;transition:color .2s}.tab-btn.active{color:var(--gold);border-bottom:2px solid var(--gold)}.tab-btn:hover:not(.active){color:var(--gold)}.roll-badge{background:var(--blood);color:#f5e6c8;letter-spacing:.1em;text-transform:uppercase;vertical-align:middle;border-radius:9999px;margin:0 2px;padding:4px 12px;font-family:Cinzel,serif;font-size:.625rem;font-weight:700;display:inline-block}.gold-text{color:var(--gold-dim);font-weight:600}.em-text{color:var(--ink-light);font-style:italic}#loading-overlay{z-index:100;background:#0d0905b3;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:none;position:fixed;top:0;right:0;bottom:0;left:0}#loading-overlay.visible{display:flex}#loading-overlay p{color:var(--gold);letter-spacing:.15em;font-family:Cinzel,serif;font-size:.85rem}.rune-spin{font-size:2rem;animation:2s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spell-subtab-container{padding:4px}.msg-bubble p{margin-bottom:.5em}.msg-bubble p:last-child{margin-bottom:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
