.character-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px}.character-modal-content{background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:1.5rem;max-width:1200px;max-height:90vh;width:100%;overflow-y:auto;position:relative;box-shadow:0 30px 80px #0f172a40}@supports (backdrop-filter: blur(16px)){.character-modal-content{background:#ffffff8c}}.modal-close-btn{position:absolute;top:1.5rem;right:1.5rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#ffffff4d;border:1px solid rgba(226,232,240,.8);color:#000000b3;border-radius:.75rem;width:36px;height:36px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease-in-out;opacity:.7;box-shadow:0 2px 4px -1px #0000001a}.modal-close-btn:hover{opacity:1;background:#ffffff80;border-color:#cbd5e1}.character-sheet-view{padding:30px;color:#3d2817}.character-sheet-view h1{font-family:Georgia,serif;font-size:2rem;margin-bottom:24px;text-align:center;color:#3d2817;border-bottom:2px solid #8b7355;padding-bottom:12px}.character-sheet-view .section-title{font-size:1.3rem;font-weight:700;margin-top:24px;margin-bottom:12px;padding:8px 12px;background:#8b7355;color:#f5f1e8;border-radius:4px}.character-sheet-view table{width:100%;border-collapse:collapse;margin-bottom:16px;background:#fff;border:1px solid #ddd}.character-sheet-view th{background:#e8e3d8;padding:8px;text-align:left;font-weight:700;border:1px solid #ddd;color:#3d2817}.character-sheet-view td{padding:8px;border:1px solid #ddd;color:#3d2817}.skills-display-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:16px}.skill-display-item{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border:1px solid #ddd;border-radius:4px}.skill-display-name{font-weight:500;color:#3d2817}.skill-display-value{font-weight:700;color:#8b7355}.notes-display-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:16px}.note-section{background:#fff;padding:16px;border:1px solid #ddd;border-radius:4px}.note-section h4{margin:0 0 8px;color:#8b7355;font-size:1rem;font-weight:700}.note-section p{margin:0;color:#3d2817;white-space:pre-wrap;line-height:1.5}.character-modal-content::-webkit-scrollbar{width:10px}.character-modal-content::-webkit-scrollbar-track{background:#e8e3d8;border-radius:4px}.character-modal-content::-webkit-scrollbar-thumb{background:#8b7355;border-radius:4px}.character-modal-content::-webkit-scrollbar-thumb:hover{background:#6d5a43}*,: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}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-6{left:1.5rem;right:1.5rem}.bottom-0{bottom:0}.bottom-\[-40px\]{bottom:-40px}.left-0{left:0}.left-\[50\%\]{left:50%}.right-0{right:0}.top-\[50\%\]{top:50%}.z-10{z-index:10}.z-30{z-index:30}.z-50{z-index:50}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-3{margin-bottom:.75rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-auto{margin-left:auto}.mt-2{margin-top:.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.size-3\.5{width:.875rem;height:.875rem}.h-16{height:4rem}.h-24{height:6rem}.h-6{height:1.5rem}.h-9{height:2.25rem}.h-\[30px\]{height:30px}.h-full{height:100%}.max-h-12{max-height:3rem}.max-h-6{max-height:1.5rem}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.min-h-10{min-height:2.5rem}.min-h-\[40px\]{min-height:40px}.w-\[90\%\]{width:90%}.w-full{width:100%}.max-w-\[1000px\]{max-width:1000px}.max-w-\[160px\]{max-width:160px}.max-w-\[500px\]{max-width:500px}.max-w-\[600px\]{max-width:600px}.max-w-\[800px\]{max-width:800px}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-\[2\]{flex:2}.flex-shrink{flex-shrink:1}.translate-x-\[-50\%\]{--tw-translate-x: -50%;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))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;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))}.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))}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-none{resize:none}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-3{gap:.75rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-12>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(3rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(3rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-b-2{border-bottom-width:2px}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-purple-200{--tw-border-opacity: 1;border-color:rgb(233 213 255 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-white\/30{border-color:#ffffff4d}.border-white\/50{border-color:#ffffff80}.bg-\[rgba\(232\,220\,196\,0\.5\)\]{background-color:#e8dcc480}.bg-black\/50{background-color:#00000080}.bg-blue-50\/60{background-color:#eff6ff99}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-green-50\/60{background-color:#f0fdf499}.bg-purple-50\/60{background-color:#faf5ff99}.bg-slate-500\/10{background-color:#64748b1a}.bg-transparent{background-color:transparent}.bg-white\/50{background-color:#ffffff80}.bg-white\/60{background-color:#fff9}.bg-white\/80{background-color:#fffc}.p-0{padding:0}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-5{padding:1.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-\[18px\]{padding-left:18px;padding-right:18px}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-\[14px\]{padding-top:14px;padding-bottom:14px}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pl-2{padding-left:.5rem}.pr-0\.5{padding-right:.125rem}.pt-0{padding-top:0}.pt-2{padding-top:.5rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-\[0_30px_80px_rgba\(15\,23\,42\,0\.25\)\]{--tw-shadow: 0 30px 80px rgba(15,23,42,.25);--tw-shadow-colored: 0 30px 80px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_5px_13px_rgba\(15\,23\,42\,0\.55\)\]{--tw-shadow: 0 5px 13px rgba(15,23,42,.55);--tw-shadow-colored: 0 5px 13px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_6px_15px_rgba\(15\,23\,42\,0\.25\)\]{--tw-shadow: 0 6px 15px rgba(15,23,42,.25);--tw-shadow-colored: 0 6px 15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px 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}.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)}.blur-3xl{--tw-blur: blur(64px);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)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));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)}.grayscale{--tw-grayscale: grayscale(100%);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)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.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}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.\[transition\:max-height_0\.5s_ease-in-out\,max-width_1s_ease-in-out_0\.5s\]{transition:max-height .5s ease-in-out,max-width 1s ease-in-out .5s}.\[transition\:max-width_1s_ease-in-out\,max-height_0\.5s_ease-in-out\]{transition:max-width 1s ease-in-out,max-height .5s ease-in-out}:root{--ink: #2b2519;--paper: #f5f1e8;--border: #3d2f1f;--accent: #8b7355;--header-bg: #d4c4b0;--title: #3d2f1f;--mono: "Courier New", "Courier", monospace;--serif: "Goudy Old Style", "Garamond", "Palatino Linotype", "Book Antiqua", "Times New Roman", serif;--primary: 240 5.9% 10%;--primary-foreground: 0 0% 98%;--muted-foreground: 220 9% 46%;--ring: 240 5.9% 10%;--input: 220 13% 90%}*{box-sizing:border-box;margin:0;padding:0}body{background:#e8e4d9;color:var(--ink);font-family:var(--serif);padding:20px;line-height:1.4;min-height:100vh;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:var(--background-image, url(/asset/background.jpeg));background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;z-index:-2;pointer-events:none}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:var(--background-image-new, none);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;z-index:-1;opacity:0;transition:opacity .8s ease-in-out;pointer-events:none}body.background-transitioning:after{opacity:1}.home{position:fixed;top:0;left:0;width:100vw;height:100vh;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;padding:0;overflow:hidden}.auth-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;padding:24px;animation:authPageFadeIn .6s ease-out}@keyframes authPageFadeIn{0%{opacity:0}to{opacity:1}}.auth-frame{position:relative;display:flex;align-items:center;justify-content:center;width:110vw;height:110vh;max-width:110vw;max-height:110vh}.auth-container{position:absolute;width:min(480px,92vw);background:var(--paper);border:4px solid var(--border);border-radius:12px;padding:40px 36px;box-shadow:0 0 0 2px var(--accent),0 20px 60px #0006,inset 0 1px #ffffff80;text-align:center;animation:authContainerSlideIn .5s ease-out}@keyframes authContainerSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-container:before{content:"";position:absolute;top:12px;left:12px;right:12px;bottom:12px;border:1px solid var(--accent);border-radius:8px;pointer-events:none;opacity:.3}.auth-container h2{margin-bottom:24px;letter-spacing:3px;font-size:2rem;color:var(--title);text-transform:uppercase;text-shadow:2px 2px 4px rgba(0,0,0,.1);position:relative;padding-bottom:16px}.auth-container h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:80px;height:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.auth-container form{display:flex;flex-direction:column;align-items:center;gap:18px}.auth-container .form-group{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left}.auth-container .form-group label{font-weight:700;color:var(--title);font-size:.95rem;letter-spacing:.5px;margin-left:4px}.auth-container .form-group input{width:100%;border:3px solid var(--border);background:#fff;padding:14px 16px;border-radius:8px;font-family:var(--serif);font-size:1rem;transition:all .3s ease;box-shadow:inset 0 2px 4px #0000000d}.auth-container .form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px #8b735533,inset 0 2px 4px #0000000d;transform:translateY(-1px)}.auth-container .form-group input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.auth-container .form-group.checkbox{flex-direction:row;justify-content:flex-start;align-items:center}.auth-container .form-group.checkbox label{display:flex;align-items:center;gap:10px;font-weight:600;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.auth-container .form-group.checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;margin:0}.auth-container small{color:#6b5a45;font-size:.85rem;margin-top:-4px;margin-left:4px;font-style:italic}.auth-container button[type=submit]{width:100%;margin-top:8px;padding:16px 24px;font-size:1.1rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;border:3px solid var(--border);border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,#6d5840 100%);color:var(--paper);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000004d,inset 0 1px #ffffff4d;position:relative;overflow:hidden}.auth-container button[type=submit]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.auth-container button[type=submit]:hover:not(:disabled):before{left:100%}.auth-container button[type=submit]:hover:not(:disabled){background:linear-gradient(135deg,#6d5840,#5a4633);transform:translateY(-2px);box-shadow:0 6px 20px #0006,0 0 0 3px var(--accent),inset 0 1px #ffffff4d}.auth-container button[type=submit]:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff4d}.auth-container button[type=submit]:disabled{opacity:.6;cursor:not-allowed;background:#999;border-color:#777;transform:none}.auth-container .error-message{width:100%;padding:14px 16px;background:linear-gradient(135deg,#f8d7da,#f5c2c7);border:2px solid #dc3545;border-radius:8px;color:#721c24;font-weight:600;text-align:center;animation:errorShake .5s ease;box-shadow:0 4px 12px #dc354533}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.auth-container .form-links{display:flex;flex-direction:column;gap:10px;font-size:.95rem;margin-top:8px;padding-top:20px;border-top:2px solid rgba(139,115,85,.2);width:100%}.auth-container .form-links a{color:var(--accent);text-decoration:none;font-weight:600;transition:all .2s ease;padding:8px 12px;border-radius:6px}.auth-container .form-links a:hover{background:#8b73551a;color:#6d5840;transform:translate(4px)}.success-message-container{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;animation:successPulse .6s ease-out}@keyframes successPulse{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.success-message-container h2{color:#28a745;font-size:2rem;margin-bottom:8px}.success-message-container h2:before{content:"✓ ";font-size:2.5rem;display:block;margin-bottom:16px;color:#28a745;text-shadow:0 4px 12px rgba(40,167,69,.3)}.success-message-container p{font-size:1.1rem;color:var(--title);line-height:1.6}.home-frame{position:relative;display:flex;justify-content:center;align-items:center;width:100vw;height:100vh;max-width:100vw;max-height:100vh}.frame-image{width:100%;height:100%;max-width:100%;max-height:100vh;-o-object-fit:contain;object-fit:contain}.hero{border:3px solid var(--border);background:var(--paper);padding:24px;box-shadow:0 0 0 1px var(--accent),0 8px 20px #0000004d}.eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--accent);margin-bottom:6px;font-weight:600}.hero h1{margin:0;letter-spacing:3px;font-size:2.2rem;color:var(--title);font-weight:700;text-shadow:2px 2px 0px rgba(0,0,0,.1)}.hero .lede{margin-top:8px;color:var(--ink);font-size:1rem}.home .home-actions{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;margin-top:0}.home-actions button{padding:20px 50px;font-size:1.25rem;min-width:320px;border-radius:8px;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000004d,inset 0 1px #ffffff4d}.home-actions button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.home-actions button:hover:before{left:100%}.home-actions button.primary{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#ffffff80;border:1px solid rgba(226,232,240,1);color:var(--title);font-weight:700;letter-spacing:1px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-radius:.75rem;transition:all .2s ease-in-out}.home-actions button.primary:hover{background:#ffffffb3;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.home-actions button.secondary{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#ffffff80;border:1px solid rgba(226,232,240,1);color:var(--title);font-weight:700;letter-spacing:1px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-radius:.75rem;transition:all .2s ease-in-out}.home-actions button.secondary:hover{background:#ffffffb3;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.home-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.home-card{border:2px solid var(--border);background:var(--paper);padding:16px;box-shadow:0 4px 12px #0003}.home-card h3{margin-bottom:8px;color:var(--title);font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}button,.primary{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#ffffff80;border:1px solid rgba(226,232,240,1);border-radius:.75rem;padding:10px 20px;cursor:pointer;font-weight:700;letter-spacing:1px;font-family:var(--serif);color:var(--title);text-transform:uppercase;font-size:.9rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .2s ease-in-out}button:hover,.primary:hover{background:#ffffffb3;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}button:active,.primary:active{transform:translateY(0);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}button:disabled{opacity:.5;cursor:not-allowed;transform:none}.sheet{max-width:1000px;margin:0 auto;background:var(--paper);padding:2rem;border:8px solid var(--border);box-shadow:0 0 0 2px var(--accent),0 0 0 4px var(--border),0 8px 30px #0006;position:relative}.sheet:before{content:"";position:absolute;top:16px;left:16px;right:16px;bottom:16px;border:1px solid var(--accent);pointer-events:none;opacity:.5}h1{text-align:center;letter-spacing:4px;margin-bottom:20px;font-size:2.5rem;color:var(--title);text-transform:uppercase;font-weight:700;text-shadow:2px 2px 0px rgba(0,0,0,.1)}.section-title{font-weight:700;letter-spacing:2px;color:var(--paper);font-size:.95rem;text-transform:uppercase;margin:16px 0 8px;padding:6px 12px;background:var(--border);box-shadow:2px 2px 4px #0003;border-left:4px solid var(--accent)}table{width:100%;border-collapse:collapse;margin-bottom:12px;background:#fff;border:2px solid var(--border)}th,td{border:1px solid var(--accent);padding:6px 10px;font-size:.9rem;vertical-align:middle}th{background:var(--header-bg);text-align:left;font-weight:700;color:var(--title);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}input,textarea,select{width:100%;border:none;background:transparent;font-size:.9rem;color:var(--ink);padding:4px 6px;outline:none;font-family:var(--serif)}input:focus,textarea:focus,select:focus{background:#d4c4b01a}input[type=number]{text-align:center;font-weight:600}input[type=checkbox]{width:auto;margin-right:6px}textarea{min-height:70px;resize:vertical;font-size:.85rem}.skills-three-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:12px}@media(max-width:1200px){.skills-three-columns{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.skills-three-columns{grid-template-columns:1fr}}.skill-category{background:#fff;border:2px solid var(--border);border-radius:4px;overflow:hidden}.skill-category-title{margin:0;padding:8px 12px;background:var(--header-bg);color:var(--title);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.skills-table{width:100%;font-size:.85rem;margin-bottom:0;border:none}.skills-table td{padding:4px 8px;border:none;border-bottom:1px solid #eee}.skills-table tr:last-child td{border-bottom:none}.skill-name-cell{width:70%}.skill-value-cell{width:30%}.skill-label{display:flex;align-items:center;gap:6px;font-size:.85rem}.skill-base{color:#888;font-size:.75rem}.skill-value-cell input{width:100%;text-align:center;font-weight:600}.notes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:12px}@media(max-width:768px){.notes-grid{grid-template-columns:1fr}}.weapon-row input{text-align:left;font-size:.85rem}.pill-btn{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#ffffff80;border:1px solid rgba(226,232,240,1);border-radius:.75rem;padding:10px 20px;cursor:pointer;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-family:var(--serif);color:var(--title);font-size:.9rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .2s ease-in-out}.pill-btn:hover{background:#ffffffb3;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.pill-btn:active{transform:translateY(0);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.pill-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.json-box{border:2px solid var(--border);padding:12px;background:#2b2519;font-family:var(--mono);font-size:.75rem;white-space:pre-wrap;max-height:250px;overflow:auto;color:#0f0;box-shadow:inset 0 2px 6px #00000080}.sheet:after{content:"";position:absolute;top:8px;left:8px;width:40px;height:40px;border-top:3px solid var(--accent);border-left:3px solid var(--accent);pointer-events:none}.game-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;height:100vh;padding:20px;box-sizing:border-box}.game-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;margin-bottom:16px}.game-header h1{font-size:1.8rem;color:var(--title);margin:0;font-family:var(--serif)}.back-button{padding:10px 20px;color:var(--title);cursor:pointer;font-size:.95rem;font-family:var(--serif);font-weight:700;transition:all .2s}.back-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.back-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0003}.game-main-layout{display:flex;gap:16px;flex:1;min-height:0}.game-chat-container{display:flex;flex-direction:column;flex:2;overflow:hidden}.session-info-bar{padding:12px;display:flex;justify-content:space-between;align-items:center;gap:8px;font-family:var(--mono);font-size:.85rem}.session-metadata,.character-info{display:flex;gap:8px;align-items:center}.session-label,.character-label{color:#666;font-weight:700}.session-value,.character-value{color:var(--title);padding:0;font-weight:600}.view-character-btn{margin-left:12px;padding:6px 12px;background:#5ba3c0;color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:background .2s;font-weight:500}.view-character-btn:hover{background:#4a8ca8}.view-character-btn-sidebar{padding:6px 10px;background:#ffffff80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:var(--title);border:1px solid rgba(226,232,240,.8);border-radius:.5rem;font-size:.75rem;cursor:pointer;transition:all .2s;font-weight:500;white-space:nowrap;box-shadow:0 1px 3px #0000001a}.view-character-btn-sidebar:hover{background:#ffffffb3;border-color:#e2e8f0}.messages-scroll-area{flex:1;overflow-y:auto;padding:20px;background:transparent}.empty-chat-prompt{text-align:center;padding:60px 20px;color:#888;font-style:italic}.empty-chat-prompt p:first-child{font-size:1.5rem;margin-bottom:8px}.chat-message{margin-bottom:20px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.character{margin-left:auto;max-width:75%}.chat-message.keeper{margin-right:auto;max-width:85%}.message-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85rem}.sender-name{font-weight:700;color:var(--title);font-family:var(--serif)}.message-timestamp{color:#999;font-family:var(--mono);font-size:.75rem}.message-text{line-height:1.6;white-space:pre-wrap;word-wrap:break-word;font-family:var(--serif)}.markdown-content{line-height:1.5;word-wrap:break-word;font-family:var(--serif)}.markdown-content p{margin:0 0 .5em}.markdown-content p:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{margin:.8em 0 .3em;font-weight:700;line-height:1.3}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child,.markdown-content h4:first-child,.markdown-content h5:first-child,.markdown-content h6:first-child{margin-top:0}.markdown-content h1{font-size:1.5em}.markdown-content h2{font-size:1.3em}.markdown-content h3{font-size:1.1em}.markdown-content strong{font-weight:700}.markdown-content em{font-style:italic}.markdown-content code{background:#0000001a;padding:.2em .4em;border-radius:3px;font-family:var(--mono);font-size:.9em}.markdown-content pre{background:#0000000d;padding:.75em;border-radius:4px;overflow-x:auto;margin:.5em 0}.markdown-content pre code{background:none;padding:0}.markdown-content ul,.markdown-content ol{margin:.5em 0;padding-left:1.5em}.markdown-content li{margin:.25em 0}.markdown-content blockquote{border-left:3px solid rgba(0,0,0,.2);padding-left:.75em;margin:.5em 0;color:#666;font-style:italic}.markdown-content a{color:#5ba3c0;text-decoration:underline}.markdown-content a:hover{color:#4a8ca8}.markdown-content hr{border:none;border-top:1px solid rgba(0,0,0,.1);margin:.75em 0}.markdown-content table{border-collapse:collapse;width:100%;margin:.5em 0}.markdown-content th,.markdown-content td{border:1px solid rgba(0,0,0,.1);padding:.5em;text-align:left}.markdown-content th{background:#0000000d;font-weight:700}.chat-message.loading .message-text{font-style:italic;color:#666}.typing-indicator{display:inline-block}.typing-indicator span{animation:typingBlink 1.4s infinite;font-size:1.5rem;line-height:1}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBlink{0%,20%{opacity:.3}40%{opacity:1}60%,to{opacity:.3}}.error-message{padding:12px 18px;background:#f8d7da;border:2px solid #dc3545;border-radius:4px;color:#721c24;margin-bottom:16px;font-family:var(--serif)}.action-input{padding:12px 16px;font-family:var(--serif);font-size:.875rem;line-height:1.5;resize:none;min-height:40px;max-height:200px;box-shadow:none}.action-input:focus{outline:none;box-shadow:none}.action-input:disabled{background:#f0f0f080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);cursor:not-allowed;color:#999}.action-input::-moz-placeholder{color:#999;font-style:italic}.action-input::placeholder{color:#999;font-style:italic}.submit-action-btn{color:var(--title);font-family:var(--serif);font-size:1rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s}.submit-action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.submit-action-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0003}.submit-action-btn:disabled{background:#bbbbbb80;border-color:#99999980;cursor:not-allowed;opacity:.6;transform:none}.game-sidebar{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:320px;max-width:400px}.sidebar-tabs{display:flex;gap:8px;padding:12px}.sidebar-tab{flex:1;padding:8px 10px;font-family:var(--serif);font-size:.8rem;font-weight:700;color:var(--title);cursor:pointer;transition:all .2s;text-transform:none;line-height:1.1}.sidebar-tab:hover{transform:none}.sidebar-tab.active{border-color:var(--accent);color:var(--accent);transform:none}.sidebar-content{flex:1;overflow-y:auto;padding:16px;background:transparent}.tab-panel{display:flex;flex-direction:column;gap:16px}.status-section{background:#ffffff80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.8);border-radius:.5rem;padding:12px;box-shadow:0 2px 4px #0000001a}.status-section h3{margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--accent);font-size:1rem;color:var(--title);font-family:var(--serif);text-transform:uppercase;letter-spacing:1px}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#fff6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.6);border-radius:.5rem}.status-label{font-weight:700;color:var(--title);font-size:.85rem;font-family:var(--serif)}.status-value{font-family:var(--mono);color:var(--ink);font-size:.9rem;font-weight:600}.status-list{display:flex;flex-direction:column;gap:8px}.status-item-full{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#fff6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.6);border-radius:.5rem}.status-effects{min-height:60px}.empty-state{text-align:center;color:#999;font-style:italic;padding:20px;font-size:.9rem}.clues-section{background:#ffffff80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.8);border-radius:.5rem;padding:12px;box-shadow:0 2px 4px #0000001a}.clues-section h3{margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--accent);font-size:1rem;color:var(--title);font-family:var(--serif);text-transform:uppercase;letter-spacing:1px}.clues-list{display:flex;flex-direction:column;gap:8px;min-height:100px}.memo-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.memo-hint{margin:0 0 12px;font-size:.85rem;color:#6b7280}.memo-compose{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.memo-input{width:100%;border:1px solid rgba(226,232,240,.8);border-radius:.5rem;padding:10px 12px;font-family:var(--serif);font-size:.9rem;background:#ffffffb3;color:var(--ink);resize:vertical}.memo-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #bf955e33}.memo-input-item{min-height:90px}.memo-list{display:flex;flex-direction:column;gap:12px;min-height:120px}.memo-item{background:#ffffffb3;border:1px solid rgba(226,232,240,.8);border-radius:.5rem;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.memo-item-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--title);font-size:.85rem}.memo-item-meta{font-size:.75rem;color:#6b7280}.memo-actions{display:flex;gap:8px}.memo-btn{padding:6px 12px;border-radius:.5rem;border:1px solid rgba(226,232,240,.9);background:#ffffffb3;font-family:var(--serif);font-size:.8rem;font-weight:600;color:var(--title);cursor:pointer;transition:all .2s}.memo-btn:disabled{opacity:.5;cursor:not-allowed}.memo-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.memo-btn-primary:disabled{background:#bf955e80;border-color:#bf955e80}.memo-btn-ghost{background:transparent;border-color:transparent;color:#b45309}.memo-saved{margin:12px 0 0;font-size:.75rem;color:#6b7280;text-align:right}.skills-grid{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}.skill-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#fff6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.6);border-radius:.5rem;transition:all .2s}.skill-item:hover{background:#fff9;border-color:#e2e8f0e6}.skill-item.occupational{background:#f5e6d3;border-color:#d4a574;font-weight:500}.skill-item.occupational:hover{background:#f0ddc4;border-color:#c49563}.skill-name{font-family:var(--serif);font-size:.85rem;color:var(--ink);flex:1}.skill-value{font-family:var(--mono);font-size:.85rem;font-weight:600;color:var(--title);min-width:40px;text-align:right}@media(max-width:1200px){.game-main-layout{flex-direction:column}.game-sidebar{max-width:none;min-height:300px}}.map-display{padding:1rem;background:var(--paper)}.map-display img{border:2px solid var(--border);border-radius:4px;box-shadow:0 2px 4px #0000001a;max-width:100%;height:auto;transition:transform .2s ease,box-shadow .2s ease}.map-display img:hover{transform:scale(1.02);box-shadow:0 4px 8px #0003}.map-display .empty-state.hidden{display:none}.map-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem}@supports (backdrop-filter: blur(4px)){.map-modal-overlay{background:#0000004d}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.map-modal-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;animation:scaleIn .3s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.map-modal-image{max-width:90%;max-height:calc(85vh - 4rem);width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border:3px solid var(--accent);border-radius:8px;box-shadow:0 8px 32px #00000080;background:var(--paper)}.map-modal-close{position:absolute;top:-2.5rem;right:0;background:var(--accent);color:var(--paper);border:2px solid var(--border);width:40px;height:40px;border-radius:50%;font-size:1.5rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10001;font-family:var(--serif)}.map-modal-close:hover{background:var(--border);transform:rotate(90deg);box-shadow:0 4px 12px #0000004d}.map-modal-title{margin-top:1rem;padding:.5rem 1.5rem;background:var(--accent);color:var(--paper);border:2px solid var(--border);border-radius:4px;font-family:var(--serif);font-size:1.1rem;font-weight:700;text-align:center;box-shadow:0 2px 8px #0000004d}.dice-animation-container{padding:16px;background:linear-gradient(135deg,#fff9e6,#f5e6d3);border:2px solid var(--accent);border-radius:8px;box-shadow:0 4px 12px #00000026;animation:diceContainerFadeIn .3s ease-out}@keyframes diceContainerFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dice-animation-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--accent)}.dice-icon{font-size:1.5rem;animation:diceIconBounce 1s ease-in-out infinite}@keyframes diceIconBounce{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(10deg)}}.dice-label{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--title);text-transform:uppercase;letter-spacing:1px}.dice-rolls-container{display:flex;flex-direction:column;gap:12px}.dice-roll-item{display:flex;align-items:center;gap:16px;padding:12px;background:#fff;border:1px solid var(--border);border-radius:6px;box-shadow:0 2px 4px #0000001a}.dice-expression{font-family:var(--mono);font-size:.9rem;color:var(--ink);font-weight:600;min-width:80px;text-align:center;padding:4px 8px;background:var(--header-bg);border-radius:4px;border:1px solid var(--accent)}.dice-result{flex:1;display:flex;justify-content:center;align-items:center;min-height:60px}.scene-image-wrapper{margin:10px 0 6px}.scene-image{width:100%;max-width:520px;border-radius:10px;border:1px solid rgba(0,0,0,.12);box-shadow:0 6px 18px #0000002e;display:block}.scene-image-caption{margin-top:6px;font-size:.85rem;color:#6a4e2e}.dice-spinning{position:relative;width:100%;height:100%}.dice-spinner{display:flex;justify-content:center;align-items:center;gap:4px;animation:diceSpin .3s linear infinite}@keyframes diceSpin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}.dice-face{font-size:2rem;line-height:1;animation:diceFaceChange .2s linear infinite;opacity:.7}@keyframes diceFaceChange{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.dice-final{animation:diceReveal .5s ease-out}@keyframes diceReveal{0%{opacity:0;transform:scale(.5) rotateY(180deg)}50%{transform:scale(1.1) rotateY(0)}to{opacity:1;transform:scale(1) rotateY(0)}}.dice-final-value{font-family:var(--mono);font-size:2.5rem;font-weight:700;color:var(--title);text-shadow:2px 2px 4px rgba(0,0,0,.2);padding:12px 24px;background:linear-gradient(135deg,var(--accent) 0%,#6d5840 100%);color:var(--paper);border-radius:8px;border:3px solid var(--border);box-shadow:0 4px 8px #0000004d;min-width:80px;text-align:center;animation:diceValuePulse .6s ease-out}@keyframes diceValuePulse{0%{transform:scale(.8);box-shadow:0 0 #8b7355b3}50%{transform:scale(1.05);box-shadow:0 0 0 10px #8b735500}to{transform:scale(1);box-shadow:0 4px 8px #0000004d}}.chat-message.dice-message .message-text{padding:0;background:transparent;border:none;box-shadow:none}.chat-message.dice-message .message-text:before{display:none}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;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))}.hover\:-translate-y-1:hover{--tw-translate-y: -.25rem;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))}.hover\:border-slate-300:hover{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.hover\:bg-white\/70:hover{background-color:#ffffffb3}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-0:focus-visible{--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(0px + 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)}.focus-visible\:ring-1:focus-visible{--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(1px + 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)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-black\/30{background-color:#0000004d}.supports-\[backdrop-filter\]\:bg-white\/55{background-color:#ffffff8c}.supports-\[backdrop-filter\]\:backdrop-blur-2xl{--tw-backdrop-blur: blur(40px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.supports-\[backdrop-filter\]\:backdrop-blur-lg{--tw-backdrop-blur: blur(16px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.supports-\[backdrop-filter\]\:backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}}@media(min-width:640px){.sm\:px-0{padding-left:0;padding-right:0}}@media(min-width:768px){.md\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(prefers-color-scheme:dark){.dark\:border-white\/20{border-color:#fff3}.dark\:bg-slate-900\/60{background-color:#0f172a99}.dark\:bg-slate-950\/60{background-color:#02061799}@supports (backdrop-filter: var(--tw)){.dark\:supports-\[backdrop-filter\]\:bg-slate-900\/40{background-color:#0f172a66}}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}
