.site-footer[data-astro-cid-sz7xmlte]{padding:20px 24px;border-top:1px solid var(--border);margin-top:40px;text-align:center;backdrop-filter:blur(4px)}.footer-inner[data-astro-cid-sz7xmlte]{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}.footer-copyright[data-astro-cid-sz7xmlte]{font-size:.78rem;color:var(--text-dim)}.footer-github[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-dim);text-decoration:none;transition:color .2s}.footer-github[data-astro-cid-sz7xmlte]:hover{color:var(--text)}.footer-github[data-astro-cid-sz7xmlte] i[data-astro-cid-sz7xmlte]{font-size:1.1rem}.footer-icon-credit[data-astro-cid-sz7xmlte]{font-size:.7rem;color:var(--text-faint, #666)}.footer-icon-credit[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:inherit;text-decoration:none}.footer-icon-credit[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--text-dim)}.footer-counter[data-astro-cid-sz7xmlte]{font-size:.78rem;color:var(--text-dim)}:root{--t: .18s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--r-sm: 4px;--r-md: 7px;--r-lg: 10px;--r-xl: 14px;--font-body: "Segoe UI", "Microsoft YaHei", system-ui, -apple-system, sans-serif;--space-xs: 5px;--space-sm: 9px;--space-md: 18px;--space-lg: 26px;--space-xl: 34px;--space-2xl: 50px;--border-subtle: rgba(255,255,255,.028);--border: rgba(255,255,255,.055);--border-strong: rgba(255,255,255,.09);--shadow-sm: 0 1px 2px rgba(0,0,0,.18), 0 1px 4px rgba(0,0,0,.12);--shadow-md: 0 2px 4px rgba(0,0,0,.1), 0 6px 18px rgba(0,0,0,.3);--shadow-lg: 0 3px 6px rgba(0,0,0,.08), 0 10px 32px rgba(0,0,0,.38);font-size:16px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px;border:1px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}[data-theme=dnd]{--bg-base: #020206;--bg-layer: #08080e;--bg-card: linear-gradient(150deg, #0e0e18 0%, #0a0a12 55%, #06060e 100%);--bg-panel: #0c0c16;--text: #f0f0f8;--text-dim: #8888a8;--text-gold: #ff4444;--accent: #d42020;--accent-dim: rgba(212,32,32,.2);--accent2: #2244cc;--accent3: #2266dd;--border: #1e1e30;--border-bright: #d42020;--shadow: 0 2px 4px rgba(0,0,0,.1), 0 6px 18px rgba(0,0,0,.3);--font-display: "Georgia", "KaiTi", serif;--overlay: rgba(4,4,8,.92);--dice-face: #d42020;--glow-spread: 0 0 24px rgba(212,32,32,.2);--ornament: "⚔️"}[data-theme=coc]{--bg-base: #020206;--bg-layer: #08080e;--bg-card: linear-gradient(150deg, #0e0e18 0%, #0a0a12 55%, #06060e 100%);--bg-panel: #0c0c16;--text: #f0f0f8;--text-dim: #8888a8;--text-gold: #2dd4bf;--accent: #0d9488;--accent-dim: rgba(13,148,136,.2);--accent2: #2244cc;--accent3: #0f766e;--border: #1e1e30;--border-bright: #0d9488;--shadow: 0 2px 4px rgba(0,0,0,.1), 0 6px 18px rgba(0,0,0,.3);--font-display: "Times New Roman", "KaiTi", serif;--overlay: rgba(4,4,8,.92);--dice-face: #0d9488;--glow-spread: 0 0 24px rgba(13,148,136,.2);--ornament: "🐙"}[data-theme=cyberpunk]{--bg-base: #020206;--bg-layer: #08080e;--bg-card: linear-gradient(150deg, #0e0e18 0%, #0a0a12 55%, #06060e 100%);--bg-panel: #0c0c16;--text: #f0f0f8;--text-dim: #8888a8;--text-gold: #44ccff;--accent: #0088cc;--accent-dim: rgba(0,136,204,.2);--accent2: #2244cc;--accent3: #006699;--border: #1e1e30;--border-bright: #0088cc;--shadow: 0 2px 4px rgba(0,0,0,.1), 0 6px 18px rgba(0,0,0,.3);--font-display: "Trebuchet MS", "KaiTi", "Microsoft YaHei", sans-serif;--overlay: rgba(4,4,8,.92);--dice-face: #0088cc;--glow-spread: 0 0 24px rgba(0,136,204,.2);--ornament: ">"}[data-theme=pathfinder]{--bg-base: #020206;--bg-layer: #08080e;--bg-card: linear-gradient(150deg, #0e0e18 0%, #0a0a12 55%, #06060e 100%);--bg-panel: #0c0c16;--text: #f0f0f8;--text-dim: #8888a8;--text-gold: #e8b830;--accent: #c89820;--accent-dim: rgba(200,152,32,.2);--accent2: #2244cc;--accent3: #8a7020;--border: #1e1e30;--border-bright: #c89820;--shadow: 0 2px 4px rgba(0,0,0,.1), 0 6px 18px rgba(0,0,0,.3);--font-display: "Georgia", "KaiTi", serif;--overlay: rgba(4,4,8,.92);--dice-face: #c89820;--glow-spread: 0 0 24px rgba(200,152,32,.2);--ornament: "🗡️"}[data-color-scheme=light]{--bg-base: #f0f0f5;--bg-layer: #e8e8f0;--bg-card: linear-gradient(150deg, #ffffff 0%, #f5f5fa 55%, #eeeef5 100%);--bg-panel: #fafaff;--text: #1a1a2e;--text-dim: #6a6a88;--border: #d0d0dc;--border-subtle: rgba(0,0,0,.06);--border-strong: rgba(0,0,0,.1);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.08);--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 2px 4px rgba(0,0,0,.05), 0 6px 16px rgba(0,0,0,.12);--shadow-lg: 0 3px 6px rgba(0,0,0,.04), 0 10px 28px rgba(0,0,0,.15);--overlay: rgba(240,240,245,.92);--accent-dim: rgba(120,120,160,.12);--glow-spread: 0 0 16px rgba(120,120,160,.08);--accent2: #3355cc;--accent3: #4477dd}[data-color-scheme=light][data-theme=dnd]{--accent-dim: rgba(212,32,32,.1);--glow-spread: 0 0 16px rgba(212,32,32,.08);--text-gold: #c42020}[data-color-scheme=light][data-theme=coc]{--accent-dim: rgba(13,148,136,.1);--glow-spread: 0 0 16px rgba(13,148,136,.08);--text-gold: #0a8a7e}[data-color-scheme=light][data-theme=cyberpunk]{--accent-dim: rgba(0,136,204,.1);--glow-spread: 0 0 16px rgba(0,136,204,.08);--text-gold: #0077bb}[data-color-scheme=light][data-theme=pathfinder]{--accent-dim: rgba(200,152,32,.1);--glow-spread: 0 0 16px rgba(200,152,32,.08);--text-gold: #b08820}[data-color-scheme=light] body:before{opacity:.08}[data-color-scheme=light] #particles{opacity:.2}[data-color-scheme=light] .nav-tab{color:#335}[data-color-scheme=light] .nav-tab.active{background:#0000000d;color:var(--text-gold)}[data-color-scheme=light] .nav-tab:hover{background:#00000008;color:#1a1a2e}[data-color-scheme=light] .theme-dropdown-item{color:#335}[data-color-scheme=light] .theme-dropdown-item:hover{color:#1a1a2e}[data-color-scheme=light] .theme-select-native{color:#335}[data-color-scheme=light] .nav-tab:hover{border-color:var(--border-strong)}[data-color-scheme=light] ::-webkit-scrollbar-thumb{background:#0000002e}[data-color-scheme=light] ::-webkit-scrollbar-thumb:hover{background:#00000059}[data-color-scheme=light] input[type=text],[data-color-scheme=light] input[type=password],[data-color-scheme=light] input[type=number],[data-color-scheme=light] select,[data-color-scheme=light] textarea{background:#0000000a}[data-color-scheme=light] .note-card{background:#00000008}[data-color-scheme=light] .note-card:hover{background:#0000000d}[data-color-scheme=light] .skill-row-coc{background:#00000008}[data-color-scheme=light] .theme-badge{background:var(--accent);color:#fff;border-color:var(--accent)}[data-color-scheme=light] .theme-badge:hover{filter:brightness(1.12)}[data-color-scheme=light] .rpg-card{background:linear-gradient(150deg,#fff,#f5f5fa 55%,#eeeef5);border-color:#d0d0dc}[data-color-scheme=light] .rpg-card .subtitle,[data-color-scheme=light] .rpg-card p{color:#5a5a7a}[data-color-scheme=light] .rpg-card .tag{background:#0000000d;color:#4a4a6a;border-color:#0000001a}@media print{[data-color-scheme=dark] body{--bg-base: #fff;--text: #000}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);font-size:.92rem;background:var(--bg-base);color:var(--text);min-height:100vh;overflow-x:hidden;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out);line-height:1.55}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 15% 40%,var(--accent-dim) 0%,transparent 60%),radial-gradient(ellipse at 85% 25%,rgba(34,68,204,.04) 0%,transparent 55%);pointer-events:none;z-index:0;opacity:.18}#particles{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55}#app{position:relative;z-index:1;max-width:1340px;margin:0 auto;padding:0 24px}nav{display:flex;align-items:center;justify-content:space-between;padding:9px 22px;margin:16px 0;background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-wrap:wrap;gap:10px;backdrop-filter:blur(8px);position:relative;z-index:50}.nav-brand{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--text-gold);display:flex;align-items:center;gap:10px}.nav-icon{width:28px;height:28px;border-radius:4px;flex-shrink:0}.nav-tabs{display:flex;gap:4px;flex-wrap:wrap}.nav-tab{padding:10px 20px;border:1px solid transparent;background:transparent;color:var(--text-dim);border-radius:var(--r-md);cursor:pointer;font-size:.92rem;font-weight:500;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);white-space:nowrap;position:relative}.nav-tab:hover{color:var(--text);border-color:var(--border);background:#ffffff08}.nav-tab.active{color:var(--text-gold);border-color:var(--border-bright);background:var(--accent-dim)}.nav-tab.active:after{content:"";position:absolute;bottom:-1px;left:20%;width:60%;height:2px;background:var(--border-bright);border-radius:1px}.theme-badge{padding:5px 14px;border-radius:20px;font-size:.78rem;font-weight:600;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--border-bright);letter-spacing:.02em;cursor:pointer;user-select:none;white-space:nowrap;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out)}.theme-badge:hover{background:var(--accent);color:#fff}.theme-picker{position:relative;display:inline-flex;align-items:center}.theme-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--bg-panel);border:1px solid var(--border-bright);border-radius:var(--r-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:fadeIn .18s var(--ease-out)}.theme-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.82rem;color:var(--text);cursor:pointer;transition:background var(--t) var(--ease-out);font-family:var(--font-body)}.theme-dropdown-item:hover{background:var(--accent-dim);color:var(--text-gold)}.theme-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.theme-select-native{padding:4px 10px;border-radius:20px;font-size:.76rem;font-weight:600;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--border-bright);font-family:inherit;cursor:pointer;max-width:160px}[data-game-active] .theme-badge,[data-game-active] .theme-select-native{opacity:.45;cursor:not-allowed;pointer-events:none}[data-game-active] #page-home .hero,[data-game-active] .rpg-grid,[data-game-active] .char-select-section,[data-game-active] .api-section{display:none!important}.color-scheme-toggle{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out);flex-shrink:0}.color-scheme-toggle:hover{color:var(--text);border-color:var(--border-bright);background:var(--accent-dim)}.notes-preview{min-height:200px;max-height:420px;overflow-y:auto;padding:14px 16px;border:1px solid var(--border);border-radius:var(--r-md);background:#00000014;font-size:.88rem;line-height:1.7;font-family:var(--font-body)}.notes-preview h1,.notes-preview h2,.notes-preview h3{color:var(--text-gold);margin:12px 0 4px;font-family:var(--font-display)}.notes-preview h1{font-size:1.3rem}.notes-preview h2{font-size:1.1rem}.notes-preview h3{font-size:.95rem}.notes-preview p{margin:4px 0}.notes-preview ul,.notes-preview ol{padding-left:20px;margin:4px 0}.notes-preview code{background:var(--accent-dim);padding:1px 6px;border-radius:3px;font-size:.8rem}.notes-preview pre{background:#00000026;padding:12px;border-radius:var(--r-md);overflow-x:auto;font-size:.8rem}.notes-preview pre code{background:none;padding:0}.notes-preview blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-dim);margin:8px 0}.notes-preview table{border-collapse:collapse;width:100%;margin:8px 0;font-size:.78rem}.notes-preview th,.notes-preview td{border:1px solid var(--border);padding:4px 8px;text-align:left}.notes-preview th{background:var(--accent-dim)}.notes-preview a{color:var(--accent)}.notes-preview hr{border:none;border-top:1px solid var(--border);margin:12px 0}.notes-preview img{max-width:100%;border-radius:var(--r-md)}.note-checkbox{margin-right:8px;accent-color:var(--accent);cursor:pointer;width:15px;height:15px}.notes-toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:8px}.note-select-all{font-size:.7rem;color:var(--text-dim);cursor:pointer;user-select:none}.note-select-all:hover{color:var(--text)}.note-card.selected-note{border-color:var(--accent);background:var(--accent-dim)}.editor-toolbar{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px}.editor-toolbar button{padding:3px 8px;font-size:.72rem;border-radius:var(--r-sm);background:var(--bg-panel);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;font-family:var(--font-display);transition:background var(--t),color var(--t),border-color var(--t)}.editor-toolbar button:hover{color:var(--text);border-color:var(--border-bright)}.page{display:none;animation:fadeIn .35s var(--ease-out);position:relative}.page.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero{text-align:center;padding:48px 20px 24px}.hero h1{font-family:var(--font-display);font-size:2.8rem;color:var(--text-gold);margin-bottom:10px;text-shadow:0 0 20px var(--accent-dim)}.hero p{color:var(--text-dim);font-size:1.1rem;max-width:620px;margin:0 auto}.rpg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:22px;padding:16px 0 28px}.rpg-card{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:34px 26px 28px;cursor:pointer;transition:background .35s var(--ease-in-out),color .35s var(--ease-out),border-color .35s var(--ease-out),opacity .35s var(--ease-out),transform .35s var(--ease-out);border:2px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow);contain:layout style}.rpg-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 80% 0%,var(--accent-dim),transparent 60%);opacity:0;transition:opacity .4s}.rpg-card:hover:before{opacity:1}.rpg-card:hover{transform:translateY(-3px);border-color:var(--border-bright);box-shadow:var(--shadow-md),var(--glow-spread)}.rpg-card.selected{border-color:var(--border-bright);box-shadow:0 0 32px var(--accent-dim),var(--shadow-md)}.rpg-card.selected:after{content:"✓";position:absolute;top:14px;right:18px;font-size:1.1rem;color:#111;background:var(--text-gold);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.rpg-card-icon{font-size:2.4rem;font-weight:900;margin-bottom:14px;opacity:.9;letter-spacing:.04em}.rpg-card h3{font-family:var(--font-display);font-size:1.4rem;color:var(--text-gold);margin-bottom:2px}.rpg-card .subtitle{color:var(--text-dim);font-size:.82rem;margin-bottom:14px}.rpg-card p{color:var(--text-dim);font-size:.88rem;line-height:1.55}.rpg-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}.rpg-card .tag{padding:4px 12px;border-radius:14px;font-size:.73rem;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--accent)}.rpg-card.dnd-card,.rpg-card.coc-card,.rpg-card.cyberpunk-card,.rpg-card.pathfinder-card{border-top:2px solid var(--accent)}.api-section{margin-top:10px}.coc-reference-card{display:flex;align-items:center;gap:18px;padding:20px 24px;border:1px solid var(--border);border-radius:var(--r-lg);background:#00000026;transition:border-color var(--t) var(--ease-out)}.coc-reference-card:hover{border-color:var(--accent)}.coc-reference-icon{font-size:2.4rem;flex-shrink:0}.coc-reference-content h4{color:var(--text-gold);font-family:var(--font-display);margin-bottom:4px;font-size:.92rem}.coc-reference-content p{color:var(--text-dim);font-size:.78rem;line-height:1.5;margin-bottom:8px}.api-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.api-card{padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);background:#00000026}.api-card:hover{border-color:var(--accent);background:#ffffff08;transform:translateY(-1px)}.api-card h4{color:var(--text-gold);font-size:.9rem;margin-bottom:2px}.api-card .api-desc{font-size:.78rem;color:var(--text-dim);line-height:1.4}.char-layout{display:grid;grid-template-columns:280px 1fr 290px;gap:20px;padding:10px 0}.char-lock-overlay{position:absolute;inset:0;z-index:10;background:#0000008c;border-radius:var(--r-lg);display:flex;align-items:flex-start;justify-content:center;padding-top:120px}.char-lock-banner{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--accent2);border-radius:var(--r-md);padding:14px 24px;font-size:.88rem;font-weight:600;color:var(--accent2);box-shadow:0 4px 24px #00000080}.char-lock-icon{font-size:1.4rem}input[type=text],input[type=password],input[type=number],select,textarea{width:100%;padding:10px 14px;font-family:inherit;font-size:.88rem;background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.portrait-zone{width:100%;aspect-ratio:3/4;border:1px dotted var(--border-strong);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);background:#0000002e;overflow:hidden;position:relative;margin-bottom:18px}.attr-section{margin-bottom:10px}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;max-height:420px;overflow-y:auto;padding-right:4px}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.equip-table{width:100%;font-size:.82rem;border-collapse:collapse}.btn{padding:10px 22px;border-radius:var(--r-md);cursor:pointer;font-size:.85rem;font-weight:600;font-family:inherit;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);border:1px solid transparent;display:inline-flex;align-items:center;gap:6px;user-select:none}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}.field-row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}.field-row>:first-child{flex:1}.dice-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:10px 0}@keyframes pulse-border{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}.notes-layout{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}.notes-editor textarea{min-height:380px;resize:vertical;font-family:var(--font-display);line-height:1.8;font-size:.92rem}.notes-list{max-height:460px;overflow-y:auto}.note-card{padding:14px 16px;border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:10px;cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);background:#0000001f}.note-card:hover{border-color:var(--accent);background:#ffffff05}.note-card .note-date{font-size:.73rem;color:var(--text-dim)}.note-card .note-title{font-size:.9rem;color:var(--text);margin-top:4px;font-weight:500}.note-tags{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.note-tag{display:inline-block;padding:1px 8px;border-radius:10px;font-size:.65rem;cursor:pointer;background:var(--border);color:var(--text-dim);transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out)}.note-tag:hover,.note-tag.active{background:var(--accent);color:#fff}a.note-tag{text-decoration:none}.note-ref-item{border-bottom:1px solid var(--border-subtle)}.notes-reference{max-height:520px;overflow-y:auto}.initiative-panel{margin-top:18px}.toast-container{position:fixed;bottom:30px;right:30px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px}@media(max-width:700px){#app{padding:0 12px}.hero{padding:24px 12px 16px}.hero h1{font-size:1.6rem}.rpg-grid{grid-template-columns:1fr;gap:14px}.rpg-card{padding:24px 16px 20px}nav{padding:6px 10px;margin:8px 0}.nav-brand{font-size:1.1rem}.nav-tab{padding:8px 12px;font-size:.78rem;min-height:40px}.dice-big-num{font-size:3.5rem}.btn{min-height:40px;font-size:.8rem;padding:8px 14px}.dice-die{width:52px;height:52px}body{overscroll-behavior:contain}.panel{padding:12px 14px}.dice-layout{gap:12px}.notes-preview{min-height:150px;max-height:300px}.theme-badge{display:none}.theme-select-native{display:inline-block!important}#themeDropdown{display:none!important}.toast-container{bottom:16px;right:50%;transform:translate(50%)}.toast{min-width:200px;text-align:center}.hero p{font-size:.9rem}.kp-chat-panel{height:380px}.mp-lobby-card{padding:24px 16px}.char-layout{grid-template-columns:1fr;gap:12px}.char-layout>div:first-child{order:0}.char-layout>div:nth-child(2){order:1}.char-layout>div:nth-child(3){order:2}.portrait-zone{max-width:200px;margin:0 auto 14px}.skills-grid{grid-template-columns:1fr;max-height:none}.equip-table{font-size:.72rem}.equip-table th,.equip-table td{padding:4px 6px}.spell-card-header{flex-wrap:wrap}.init-row{flex-wrap:wrap;gap:4px}.notes-layout{grid-template-columns:1fr;gap:12px}.notes-layout .notes-editor{order:0}.notes-layout>div:nth-child(2){order:1}.notes-layout .notes-reference{order:2;max-height:none}.notes-editor textarea{min-height:220px}.editor-toolbar button{padding:6px 10px;font-size:.78rem}.config-model-row{flex-direction:column}.config-model-row .btn{width:100%;justify-content:center}.config-actions{flex-direction:column}.config-actions .btn{width:100%;justify-content:center}.config-field-row{flex-direction:column;gap:10px}.game-save-chronicle{flex-direction:column}.game-save-chronicle>.panel{min-width:0!important;flex:none!important;width:100%}}@media(min-width:701px)and (max-width:960px){.nav-tab{padding:9px 16px}.hero h1{font-size:2.2rem}.rpg-grid{grid-template-columns:repeat(2,1fr)}}.char-select-section{border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 20px;margin-bottom:20px;background:var(--bg-panel)}.kp-hero{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:0;margin-bottom:28px;border:2px solid var(--border-bright);background:var(--bg-card);box-shadow:var(--shadow-md),0 0 40px var(--accent-dim);cursor:pointer;transition:background .35s var(--ease-in-out),color .35s var(--ease-out),border-color .35s var(--ease-out),opacity .35s var(--ease-out),transform .35s var(--ease-out)}@keyframes kp-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes kp-pulse{0%,to{box-shadow:0 0 0 0 var(--accent-dim)}50%{box-shadow:0 0 0 6px transparent}}@keyframes kp-arrow{0%,to{transform:translate(0);opacity:.55}50%{transform:translate(4px);opacity:1}}.kp-chat-wrapper{margin-bottom:28px;animation:fadeIn .4s ease}.kp-config{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:end;padding:14px 0}.coc-status-bar{display:flex;gap:10px;flex-wrap:wrap;padding:10px 0;margin-bottom:4px}.empty-state{color:var(--text-dim);font-size:.82rem;padding:16px 8px;text-align:center;line-height:1.5}.chronicle-entry{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.03)}@media(max-width:700px){.kp-hero-inner{flex-direction:column;text-align:center;padding:20px}.kp-hero-arrow{display:none}.kp-chat-panel{height:420px}.kp-msg{max-width:92%}}.mp-lobby{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:20px}.mp-char-pick{margin-top:18px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);background:#00000026}.mp-slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}.mp-room{animation:fadeIn .4s ease}.mp-sidebar{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;overflow:hidden}.mp-main{display:flex;flex-direction:column;overflow:hidden}.mp-msg{max-width:85%;padding:10px 14px;border-radius:var(--r-md);font-size:.84rem;line-height:1.55;animation:msgIn .3s ease}.mp-phase-badge{padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:600;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--accent)}.mp-turn-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 18px;margin-bottom:12px;background:var(--accent-dim);border:1px solid var(--text-gold);border-radius:var(--r-md);font-size:.85rem;color:var(--text)}.mp-lobby-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 18px;margin-bottom:12px;background:var(--accent-dim);border:1px solid var(--accent3);border-radius:var(--r-md);font-size:.82rem;color:var(--text-dim)}.mp-kp-quick-actions{display:flex;gap:6px;flex-wrap:wrap;padding:8px 16px 0}.mp-overlay{position:fixed;inset:0;z-index:9998;background:var(--overlay);display:flex;align-items:center;justify-content:center}.mp-reconnect-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;padding:12px 24px;border-radius:var(--r-md);background:#e8a030;color:#000;font-weight:600;font-size:.85rem;box-shadow:0 4px 20px #0006;animation:toastIn .35s ease}.coc-status-mini{display:flex;gap:12px;flex-wrap:wrap;align-items:center;padding:8px 12px;margin-bottom:12px;border:1px solid var(--border);border-radius:var(--r-md);background:#0000001f;font-size:.78rem}.skill-row-coc{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--r-sm);background:#00000014;margin-bottom:3px;transition:background var(--t) var(--ease-out)}.spell-level-head{font-size:.8rem;font-weight:600;color:var(--text-gold);padding:8px 0 4px;border-bottom:1px solid var(--border);margin-bottom:6px;font-family:var(--font-display)}@media(max-width:800px){.mp-room-body{grid-template-columns:1fr;height:auto}.mp-sidebar{max-height:200px}.mp-room-header{flex-direction:column;align-items:flex-start}.mp-msg{max-width:94%}.mp-lobby-card{padding:32px 20px}}.combat-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.timeout-bar{height:3px;background:var(--accent);border-radius:2px;transition:width 1s linear;margin-top:4px;will-change:width}.mp-phase-badge.combat{background:#dc3c2826;color:#e04848}.panel{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm);contain:layout style}.panel h3{font-family:var(--font-display);color:var(--text-gold);font-size:1rem;margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.panel h3 .icon{font-size:1.2rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--border-bright);box-shadow:0 0 0 1px var(--accent-dim)}select{cursor:pointer}select option{background:var(--bg-layer);color:var(--text)}label{display:block;color:var(--text-dim);font-size:.78rem;margin-bottom:4px;margin-top:12px}label:first-child{margin-top:0}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{filter:brightness(1.2);box-shadow:0 0 20px var(--accent-dim);transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text-gold);border-color:var(--accent)}.btn-secondary:hover{background:var(--accent-dim)}.btn-ghost{background:transparent;color:var(--text-dim);border-color:var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--text-dim)}.btn-save{background:var(--accent3);color:#fff;border-color:var(--accent3)}.btn-save:hover{filter:brightness(1.2)}.btn:disabled,.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}input:disabled,select:disabled,textarea:disabled{opacity:.45;cursor:not-allowed}.btn-danger{background:var(--accent2);color:#fff;border-color:var(--accent2)}.btn-danger:hover{filter:brightness(1.2)}.btn-accent{background:var(--text-gold);color:#111;border-color:var(--text-gold)}.btn-accent:hover{filter:brightness(1.1);box-shadow:var(--glow-spread)}.btn-sm{padding:6px 14px;font-size:.78rem}.btn-xs{padding:4px 10px;font-size:.72rem;border-radius:var(--r-sm)}.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.btn-full{width:100%;padding:13px;font-size:.95rem;justify-content:center}.panel-header h3{margin:0;padding:0;border:none}.panel-body{margin-top:16px}.panel-actions{display:flex;gap:6px}.toast{padding:13px 24px;border-radius:var(--r-lg);background:var(--bg-panel);border:1px solid var(--border-strong);color:var(--text);box-shadow:var(--shadow-md);animation:toastIn .28s var(--ease-out),toastOut .25s var(--ease-out) 2.8s forwards;font-size:.88rem;backdrop-filter:blur(8px)}@keyframes toastIn{0%{transform:translate(24px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastOut{to{opacity:0;transform:translateY(-6px)}}.loading-state{text-align:center;padding:24px;color:var(--text-dim);font-size:.85rem;animation:fadeIn .25s var(--ease-out)}.error-state{color:var(--accent2);padding:16px;font-size:.85rem;line-height:1.6;background:#00000026;border-radius:var(--r-md);border:1px solid var(--accent2)}.portrait-zone:hover{border-color:var(--border-bright);background:#0000004d}.portrait-zone.drag-over{border-color:var(--accent);background:var(--accent-dim)}.portrait-zone img{width:100%;height:100%;object-fit:cover}.emoji-portrait-picker{margin-bottom:18px;text-align:center}.emoji-picker-label{font-size:.68rem;color:var(--text-dim);display:block;margin-bottom:6px}.emoji-portrait-grid{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.emoji-portrait-grid span{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;font-size:1.1rem;cursor:pointer;border:1px solid var(--border);background:#00000026;transition:background var(--t) var(--ease-out),border-color var(--t) var(--ease-out),transform var(--t) var(--ease-out);user-select:none}.emoji-portrait-grid span:hover{background:var(--accent-dim);border-color:var(--accent);transform:scale(1.15)}.portrait-zone .placeholder{text-align:center;color:var(--text-dim)}.portrait-zone .placeholder .ph-icon{font-size:2.8rem;margin-bottom:10px;display:block}.attr-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding:6px 10px;border-radius:var(--r-sm);transition:background var(--t) var(--ease-out)}.attr-bar-row:hover{background:#ffffff05}.attr-bar-name{width:70px;font-family:var(--font-display);font-size:.8rem;color:var(--text-gold);text-align:right;flex-shrink:0}.attr-bar-track{flex:1;height:18px;background:#00000059;border-radius:9px;overflow:hidden;position:relative;border:1px solid var(--border)}.attr-bar-fill{height:100%;border-radius:9px;transition:width .3s var(--ease-out),background .3s var(--ease-out);pointer-events:none}.attr-slider{position:absolute;inset:0 -1px;width:calc(100% + 2px);height:18px;-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer;margin:0;padding:0;border:none;outline:none;z-index:1;opacity:0;transition:opacity .2s ease}.attr-bar-row:hover .attr-slider{opacity:1}.attr-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:22px;border-radius:4px;background:var(--accent);border:2px solid var(--text-gold);cursor:pointer;box-shadow:0 0 6px var(--accent-dim)}.attr-slider::-moz-range-thumb{width:16px;height:22px;border-radius:4px;background:var(--accent);border:2px solid var(--text-gold);cursor:pointer;box-shadow:0 0 6px var(--accent-dim)}.attr-bar-val{width:36px;text-align:center;font-weight:700;font-size:.95rem;color:var(--text);flex-shrink:0}.attr-bar-mod{width:42px;text-align:center;font-size:.78rem;color:var(--text-dim);flex-shrink:0}.attr-bar-btns{display:flex;gap:3px;flex-shrink:0}.attr-bar-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:#0000004d;color:var(--text);cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.attr-bar-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.attr-bar-btn:active{transform:scale(.94)}.pts-remaining-bar{text-align:center;padding:10px;border-radius:var(--r-md);background:var(--accent-dim);color:var(--text-gold);font-weight:700;margin-top:8px;font-size:.88rem;transition:color var(--t)}.skill-chip{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:var(--r-sm);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);border:1px solid transparent;font-size:.82rem;user-select:none}.skill-chip:hover{border-color:var(--border);background:#ffffff05}.skill-chip.proficient{border-color:var(--accent3);background:var(--accent-dim)}.skill-chip .skill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.skill-chip .skill-dot.off{background:var(--border)}.skill-chip .skill-dot.on{background:var(--accent3);box-shadow:0 0 6px var(--accent3)}.skill-chip .skill-name{flex:1;font-size:.8rem}.skill-chip .skill-bonus{font-weight:700;color:var(--text-gold);font-size:.8rem;width:28px;text-align:right}.trait-tag{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:18px;font-size:.8rem;background:#0003;border:1px solid var(--border);transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.trait-tag:hover{border-color:var(--accent)}.trait-tag .trait-remove{cursor:pointer;color:var(--accent2);font-weight:700;font-size:.9rem}.trait-tag .trait-remove:hover{color:#f44}.preset-tags{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:8px}.preset-tag{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.72rem;cursor:pointer;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--accent);transition:background var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.preset-tag:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.preset-save{cursor:pointer;color:var(--text-dim);font-size:.75rem;padding:0 2px;transition:color var(--t) var(--ease-out)}.preset-save:hover{color:var(--accent)}.inline-input{background:transparent;border:none;border-bottom:1px dotted var(--border-strong);color:var(--text);font-size:.82rem;padding:2px 4px;width:80px;font-family:inherit;transition:border-color var(--t) var(--ease-out)}.inline-input:focus{outline:none;border-bottom-color:var(--accent)}.inline-input.wide{width:140px}.equip-table th{text-align:left;color:var(--text-dim);font-weight:500;padding:6px 8px;border-bottom:1px solid var(--border);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.equip-table td{padding:7px 8px;border-bottom:1px solid rgba(255,255,255,.03)}.equip-table tr:hover td{background:#ffffff04}.equip-del-btn{color:var(--accent2);cursor:pointer;border:none;background:none;font-size:.9rem;padding:2px 6px;border-radius:4px}.equip-del-btn:hover{background:var(--accent-dim)}.init-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px;background:#0000001f;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.init-row.active-turn{border-color:var(--accent);box-shadow:0 0 14px var(--accent-dim)}.init-row .init-num{font-weight:700;font-size:1.2rem;color:var(--text-gold);width:32px;text-align:center}.init-row .init-name{flex:1;font-size:.85rem}.init-row .init-hp{font-size:.78rem;color:var(--text-dim)}.char-select-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.char-select-header h3{margin:0;padding:0;border:none;font-size:1rem;color:var(--text-gold)}.char-select-list{display:flex;flex-wrap:wrap;gap:10px;min-height:40px}.char-select-empty{color:var(--text-dim);font-size:.85rem;padding:8px 0;width:100%}.char-select-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border:2px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);background:#00000026;min-width:180px}.char-select-card:hover{border-color:var(--accent);background:#00000040;transform:translateY(-1px)}.char-select-card.selected{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 10px var(--accent-dim)}.char-select-card.selected .char-select-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}.char-select-dot{width:10px;height:10px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.char-select-info{flex:1;min-width:0}.char-select-name{font-weight:600;color:var(--text);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.char-select-meta{font-size:.75rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spell-card{border:1px solid var(--border);border-radius:var(--r-sm);background:#0000001a;margin-bottom:6px;transition:border-color var(--t) var(--ease-out);overflow:hidden}.spell-card:hover{border-color:var(--border-strong)}.spell-card.prepared{border-color:var(--accent)}.spell-card-header{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer}.spell-card-name{flex:1;font-weight:600;font-size:.85rem;color:var(--text)}.spell-card-school{font-size:.7rem;color:var(--text-dim);padding:2px 6px;border-radius:var(--r-sm);background:#ffffff0a}.spell-card-prep{cursor:pointer;font-size:.9rem;color:var(--text-gold);transition:color var(--t);padding:2px 4px}.spell-card-prep:hover{color:var(--accent)}.spell-card-body{padding:0 10px 8px;border-top:1px solid var(--border-subtle)}.spell-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.72rem;color:var(--text-dim);padding-top:6px}.spell-card-meta span{white-space:nowrap}.spell-card-desc{font-size:.78rem;color:var(--text-dim);margin-top:6px;line-height:1.4}.dice-strip{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:20px}.dice-die{width:70px;height:70px;border-radius:var(--r-md);border:2px solid var(--border);background:var(--bg-panel);color:var(--text);cursor:pointer;font-weight:700;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;position:relative;font-size:1.1rem}.dice-die span{font-size:.62rem;color:var(--text-dim)}.dice-die:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-dim);transform:translateY(-2px)}.dice-die.active{border-color:var(--accent);background:var(--accent-dim);color:var(--text-gold)}.dice-die.active:after{content:"";position:absolute;inset:-3px;border-radius:inherit;border:2px solid var(--accent);animation:pulse-border 1.5s ease infinite}.dice-result-zone{text-align:center;padding:32px 0}.dice-big-num{font-size:5rem;font-weight:700;color:var(--text-gold);font-family:var(--font-display);line-height:1;will-change:transform,opacity}.dice-sub-label{color:var(--text-dim);font-size:.9rem;margin-top:6px}.roll-input-row{display:flex;gap:10px;margin-bottom:14px}.roll-input-row input{flex:1}.roll-history-list{max-height:400px;overflow-y:auto}.roll-entry{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);margin-bottom:3px;background:#00000026;border:1px solid transparent;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.roll-entry:hover{border-color:var(--border)}.roll-entry .roll-icon{font-size:1.3rem;flex-shrink:0}.roll-entry .roll-text{flex:1;font-size:.84rem}.roll-entry .roll-val{font-weight:700;color:var(--text-gold);font-size:1.1rem;flex-shrink:0}.roll-entry .roll-time{font-size:.7rem;color:var(--text-dim);flex-shrink:0;margin-left:4px}.kp-theme-tag{font-size:.75rem;color:var(--text-dim)}.spells-hint{font-size:.72rem;color:var(--text-dim);margin-top:4px}.kp-hero:hover{box-shadow:var(--shadow-md),0 0 48px var(--accent-dim);transform:translateY(-1px)}.kp-hero-inner{display:flex;align-items:center;gap:20px;padding:20px 26px}.kp-hero-icon{font-size:4rem;flex-shrink:0;animation:kp-float 3s ease-in-out infinite;will-change:transform}.kp-hero-text{flex:1}.kp-hero-text h2{font-family:var(--font-display);font-size:1.7rem;color:var(--text-gold);margin-bottom:4px}.kp-hero-text p{color:var(--text-dim);font-size:.92rem;line-height:1.5}.kp-hero-badge{display:inline-block;padding:6px 16px;border-radius:20px;font-size:.78rem;font-weight:700;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--border-bright);margin-top:8px;animation:kp-pulse 2s ease infinite}.kp-hero-arrow{font-size:2rem;color:var(--text-gold);animation:kp-arrow 1.5s ease-in-out infinite;will-change:transform,opacity}.kp-chat-panel{display:flex;flex-direction:column;height:560px;contain:layout style}.kp-chat-msgs{flex:1;overflow-y:auto;padding:8px 4px;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth;contain:layout style}.kp-msg{max-width:85%;padding:12px 16px;border-radius:var(--r-md);font-size:.88rem;line-height:1.6}.kp-msg:not(.streaming):not(.no-anim){animation:msgIn .3s ease}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kp-msg.gm{align-self:flex-start;background:var(--bg-panel);border:1px solid var(--border);border-bottom-left-radius:2px}.kp-msg.player{align-self:flex-end;background:var(--accent-dim);border:1px solid var(--accent);border-bottom-right-radius:2px;color:var(--text)}.kp-msg.system{align-self:center;max-width:95%;background:#00000040;border:1px dashed var(--border);font-size:.8rem;color:var(--text-dim);text-align:center;padding:8px 16px;border-radius:var(--r-sm)}.kp-msg .msg-header{font-size:.72rem;color:var(--text-dim);margin-bottom:4px;font-weight:600;letter-spacing:.03em}.kp-msg .msg-bracket{font-style:italic;font-size:.78rem;color:var(--text-dim);opacity:.72}.kp-msg .msg-dice{display:inline-block;margin:6px 2px;padding:4px 10px;background:#0000004d;border-radius:12px;font-weight:700;color:var(--text-gold);font-size:.85rem}.kp-msg.streaming{contain:layout style}.kp-msg.streaming .msg-body{min-height:0}.kp-msg.streaming:after{content:"▊";animation:blink .8s step-end infinite;color:var(--text-gold);margin-left:2px;contain:strict}@keyframes blink{50%{opacity:0}}.kp-msg .msg-body{white-space:pre-wrap}.kp-msg .msg-body p{margin:6px 0}.kp-msg .msg-body p:first-child{margin-top:0}.kp-msg .msg-body p:last-child{margin-bottom:0}.kp-msg .msg-body strong{color:var(--text-gold);font-weight:700}.kp-msg .msg-body em{color:var(--accent);font-style:italic}.kp-msg .msg-body blockquote{border-left:3px solid var(--accent);padding:4px 12px;margin:8px 0;color:var(--text-dim);font-style:italic;background:#0000001a;border-radius:0 var(--r-sm) var(--r-sm) 0}.kp-msg .msg-body ul,.kp-msg .msg-body ol{padding-left:20px;margin:6px 0}.kp-msg .msg-body li{margin-bottom:2px}.kp-msg .msg-body code{background:#0000004d;padding:1px 6px;border-radius:3px;font-size:.82em;color:var(--text-gold)}.kp-msg .msg-body pre{background:#0000004d;padding:10px 12px;border-radius:var(--r-sm);overflow-x:auto;margin:8px 0}.kp-msg .msg-body pre code{background:none;padding:0;color:var(--text)}.kp-msg .msg-body h1,.kp-msg .msg-body h2,.kp-msg .msg-body h3,.kp-msg .msg-body h4{color:var(--text-gold);font-family:var(--font-display);margin:10px 0 6px;line-height:1.3}.kp-msg .msg-body h1{font-size:1.15rem}.kp-msg .msg-body h2{font-size:1.05rem}.kp-msg .msg-body h3{font-size:.95rem}.kp-msg .msg-body h4{font-size:.9rem}.kp-msg .msg-body hr{border:none;border-top:1px solid var(--border);margin:12px 0}.kp-msg .msg-body a{color:var(--accent);text-decoration:underline}.kp-msg .msg-body table{border-collapse:collapse;margin:8px 0;font-size:.82rem}.kp-msg .msg-body th,.kp-msg .msg-body td{border:1px solid var(--border);padding:4px 10px;text-align:left}.kp-msg .msg-body th{background:var(--accent-dim);color:var(--text-gold);font-weight:600}.kp-input-row{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border);margin-top:8px}.kp-input-row input{flex:1;padding:12px 16px;font-size:.9rem}.kp-action-buttons{display:flex;gap:8px;flex-wrap:wrap;padding:8px 4px 4px;justify-content:center}.kp-action-btn{padding:10px 22px;border-radius:24px;font-size:.88rem;font-weight:600;border:2px solid var(--accent);background:var(--accent-dim);color:var(--text-gold);cursor:pointer;transition:transform var(--t) var(--ease-out),box-shadow var(--t) var(--ease-out);font-family:var(--font-body);flex:0 1 auto;min-width:80px}.kp-action-btn:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--accent-dim);background:var(--accent);color:#fff}.kp-action-btn:active{transform:scale(.97)}.kp-quick-actions{display:flex;gap:6px;flex-wrap:wrap;padding-top:8px}.kp-quick-btn{padding:6px 14px;border-radius:16px;font-size:.76rem;border:1px solid var(--border);background:#0003;color:var(--text-dim);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);white-space:nowrap}.kp-quick-btn:hover{border-color:var(--accent);color:var(--text-gold);background:var(--accent-dim)}.kp-config label{margin-top:0}.kp-config .btn{min-height:42px;align-self:end}.game-save-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:4px;cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.game-save-item:hover{border-color:var(--accent);background:#ffffff05}.game-save-name{font-weight:600;color:var(--text);font-size:.85rem}.game-save-meta{font-size:.78rem;color:var(--text-dim);margin-top:2px}.kp-status-bar{display:flex;gap:16px;flex-wrap:wrap;align-items:center;padding:10px 14px;margin-bottom:12px;border:1px solid var(--border);border-radius:var(--r-md);background:#0000001f;font-size:.78rem}.kp-stat{display:flex;align-items:center;gap:8px}.kp-stat-label{font-weight:600;color:var(--text-gold);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.kp-stat-val{font-weight:700;color:var(--text);font-size:.85rem;min-width:50px}.kp-stat-bar{width:80px;height:6px;background:#00000059;border-radius:3px;overflow:hidden;border:1px solid var(--border)}.kp-stat-fill{height:100%;border-radius:3px;transition:width .4s var(--ease-out)}.kp-stat-fill.san{background:linear-gradient(90deg,#6a5acd,#9b8aed)}.kp-stat-fill.hp{background:linear-gradient(90deg,#d4443a,#e87870)}.kp-stat-fill.luck{background:linear-gradient(90deg,#e8a030,#f0c060)}.kp-ending-overlay{position:fixed;inset:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;animation:endingFadeIn .6s ease;backdrop-filter:blur(8px)}@keyframes endingFadeIn{0%{opacity:0}to{opacity:1}}.kp-ending-card{max-width:560px;width:90%;background:var(--bg-panel);border:2px solid var(--border-bright);border-radius:var(--r-xl);padding:40px 32px;text-align:center;animation:endingScaleIn .5s cubic-bezier(.68,-.55,.27,1.55);box-shadow:0 0 60px var(--accent-dim)}@keyframes endingScaleIn{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.kp-ending-icon{font-size:4rem;margin-bottom:16px}.kp-ending-title{font-family:var(--font-display);font-size:2rem;color:var(--text-gold);margin-bottom:8px}.kp-ending-subtitle{font-size:1rem;color:var(--text-dim);margin-bottom:20px;line-height:1.6}.kp-ending-stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}.kp-ending-stat{padding:12px 18px;border:1px solid var(--border);border-radius:var(--r-md);background:#00000026;min-width:100px}.kp-ending-stat-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.kp-ending-stat-val{font-size:1.3rem;font-weight:700;color:var(--text-gold);font-family:var(--font-display)}.kp-ending-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.kp-ending-actions .btn{min-width:140px;justify-content:center}.kp-dice-card{background:var(--bg-panel);border:2px solid var(--accent);border-radius:var(--r-lg);padding:18px 22px;margin:8px 4px;text-align:center;animation:kpDiceCardIn .35s var(--ease-out);box-shadow:0 0 20px var(--accent-dim);position:relative;overflow:hidden}.kp-dice-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--text-gold),var(--accent));background-size:200% 100%;animation:shimmer 2s linear infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes kpDiceCardIn{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.kp-dice-card-header{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.kp-dice-card-skill{font-size:1.2rem;font-weight:700;color:var(--text-gold);margin-bottom:4px}.kp-dice-card-expr{font-size:1.6rem;font-weight:700;color:var(--text);font-family:var(--font-display);margin:8px 0}.kp-dice-card-vs{font-size:.8rem;color:var(--text-dim);font-weight:400;margin:0 6px}.kp-dice-card-desc{font-size:.82rem;color:var(--text-dim);font-style:italic;margin-bottom:12px;line-height:1.5}.kp-dice-roll-btn{font-size:1.1rem;padding:14px 36px;border-radius:36px;cursor:pointer;margin-top:6px;transition:transform var(--t) var(--ease-out),box-shadow var(--t) var(--ease-out)}.kp-dice-roll-btn:hover{transform:scale(1.05);box-shadow:0 0 30px var(--accent-dim)}.kp-dice-roll-btn:active{transform:scale(.97)}.kp-dice-result{margin:10px 0}.kp-dice-result-num{font-size:3.5rem;font-weight:800;color:var(--text-gold);font-family:var(--font-display);line-height:1;animation:popIn .45s cubic-bezier(.68,-.55,.27,1.55)}@keyframes popIn{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.kp-dice-result-detail{color:var(--text-dim);font-size:.85rem;margin-top:4px}.kp-dice-result-verdict{display:inline-block;margin-top:8px;padding:4px 20px;border-radius:20px;font-size:.95rem;font-weight:700;letter-spacing:.05em}.kp-dice-result-verdict.success{background:#4acf6a33;color:#4acf6a;border:1px solid rgba(74,207,106,.4)}.kp-dice-result-verdict.fail{background:#e0484833;color:#e04848;border:1px solid rgba(224,72,72,.4)}.kp-dice-result-diff{font-size:.72rem;color:var(--text-dim);margin-top:4px}.kp-dice-card.rolled{border-color:var(--border-bright);box-shadow:none}.kp-dice-card.rolled:before{display:none}.kp-main-layout{display:flex;gap:16px;align-items:flex-start}.kp-left-column{flex:1;min-width:0}.kp-right-column{width:300px;flex-shrink:0;border:1px solid var(--border);border-radius:var(--r-md);background:#00000026;display:flex;flex-direction:column;max-height:560px;overflow:hidden}.kp-tracking-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.kp-tracking-title{font-size:.82rem;font-weight:600;color:var(--text-gold);font-family:var(--font-display)}.kp-tracking-body{flex:1;overflow-y:auto;padding:12px 14px;font-size:.78rem;line-height:1.55}.tracking-empty{text-align:center;color:var(--text-dim);font-size:.78rem;padding:24px 12px}.tracking-empty-icon{font-size:2rem;margin-bottom:8px}.tracking-section{margin-bottom:16px}.tracking-section-title{font-size:.75rem;font-weight:600;color:var(--text-gold);margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.tracking-field{margin-bottom:4px;line-height:1.5;color:var(--text-dim)}.tracking-label{display:inline-block;min-width:44px;color:var(--text);font-size:.7rem;background:var(--accent-dim);padding:1px 6px;border-radius:3px;margin-right:6px}.tracking-act-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--r-sm);margin-bottom:3px;font-size:.76rem}.act-current{background:var(--accent-dim);border:1px solid var(--accent);color:var(--text)}.act-done{color:var(--text-dim);opacity:.7}.act-pending{color:var(--text-dim);opacity:.5}.act-icon{font-size:.8rem;flex-shrink:0}.act-name{flex:1}.tracking-task{padding:3px 8px;font-size:.73rem;border-radius:var(--r-sm);margin-bottom:2px}.tracking-task.active{color:var(--text)}.tracking-task.completed{color:var(--text-dim);text-decoration:line-through;opacity:.65}.tracking-synopsis{color:var(--text);font-size:.76rem;line-height:1.65;white-space:pre-wrap;padding:8px 10px;background:#0003;border-left:3px solid var(--accent);border-radius:var(--r-sm)}.tracking-outline{color:var(--text-dim);font-size:.74rem;line-height:1.6;white-space:pre-wrap}@media(max-width:800px){.kp-main-layout{flex-direction:column}.kp-right-column{width:100%;max-height:260px}}.scenario-card{border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px;margin-bottom:8px;background:#0000001f;transition:border-color var(--t) var(--ease-out)}.scenario-card:hover{border-color:var(--accent)}.scenario-card.active-scenario{border-color:var(--border-bright);background:var(--accent-dim)}.scenario-card-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.scenario-card-name{font-weight:600;color:var(--text);font-size:.85rem}.scenario-active-badge{padding:1px 8px;border-radius:10px;font-size:.65rem;background:var(--accent);color:#fff}.scenario-card-meta{font-size:.7rem;color:var(--text-dim);margin-bottom:3px}.scenario-card-desc{font-size:.73rem;color:var(--text-dim);line-height:1.4;margin-bottom:6px}.scenario-card-actions{display:flex;gap:4px}.scenario-edit-form .form-row{margin-bottom:10px}.scenario-edit-form label{display:block;font-size:.73rem;margin-bottom:2px}.scenario-edit-form input,.scenario-edit-form textarea,.scenario-edit-form select{font-size:.78rem}.scenario-array-field{border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 8px;margin-bottom:4px;background:#00000014}.mp-lobby-card{text-align:center;max-width:520px;width:100%;padding:48px 36px;border-radius:var(--r-xl);background:var(--bg-panel);border:1px solid var(--border);box-shadow:var(--shadow)}.mp-lobby-icon{font-size:4rem;margin-bottom:14px}.mp-lobby-card h1{font-family:var(--font-display);font-size:2rem;color:var(--text-gold);margin-bottom:8px}.mp-lobby-card>p{color:var(--text-dim);font-size:.9rem;margin-bottom:28px}.mp-tabs{display:flex;gap:4px;justify-content:center;margin-bottom:24px;background:#0003;border-radius:var(--r-md);padding:4px}.mp-tab{padding:10px 28px;border:none;background:transparent;color:var(--text-dim);border-radius:var(--r-sm);cursor:pointer;font-size:.88rem;font-weight:500;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);font-family:inherit}.mp-tab.active{background:var(--accent-dim);color:var(--text-gold)}.mp-tab:hover:not(.active){color:var(--text)}.mp-tab-panel{display:none;animation:fadeIn .35s ease}.mp-tab-panel.active{display:block}.mp-form{text-align:left}.mp-form label{color:var(--text-dim);font-size:.78rem;margin-bottom:4px;margin-top:14px}.mp-form label:first-child{margin-top:0}.mp-form input{width:100%;padding:12px 16px;background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.9rem;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.mp-form input:focus{outline:none;border-color:var(--border-bright);box-shadow:0 0 0 1px var(--accent-dim)}.mp-hint{color:var(--text-dim);font-size:.73rem;margin-top:10px;text-align:center}.mp-tech-note{font-size:.68rem;opacity:.6;margin-top:6px}.mp-char-pick-title{font-size:.8rem;font-weight:700;color:var(--accent);margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em}.mp-char-sel{width:100%;padding:10px 12px;background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.85rem;cursor:pointer;margin-bottom:8px}.mp-char-sel:focus{outline:none;border-color:var(--accent)}.mp-char-sel option{background:var(--bg-layer);color:var(--text)}.mp-char-info{font-size:.72rem;color:var(--text-dim);line-height:1.5;padding:8px;background:#0000001a;border-radius:var(--r-sm);min-height:40px}.mp-char-warn{color:var(--accent2);font-size:.72rem;font-weight:600;padding:6px 10px;border:1px dashed var(--accent2);border-radius:var(--r-sm);margin-top:6px;background:#2244cc0d}.mp-slot{padding:12px 10px;border:1px solid var(--border);border-radius:var(--r-sm);text-align:center;background:#0000001a;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.mp-slot.filled{border-color:var(--accent3);background:var(--accent-dim)}.mp-slot.ready{border-color:var(--accent);background:#00880014}.mp-slot .slot-num{font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.mp-slot .slot-name{font-size:.82rem;color:var(--text);font-weight:600;margin-top:2px}.mp-slot .slot-char{font-size:.68rem;color:var(--text-dim);margin-top:2px}.mp-slot .slot-stats{font-size:.62rem;color:var(--accent2);margin-top:2px}.mp-slot .slot-badge{display:inline-block;padding:2px 6px;border-radius:8px;font-size:.6rem;margin-top:4px;font-weight:600}.mp-slot .slot-badge.ready-badge{background:#00c80026;color:#4b4}.mp-slot .slot-badge.wait-badge{background:var(--accent-dim);color:var(--text-dim)}.mp-room-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 20px;margin-bottom:16px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow)}.mp-room-info{display:flex;align-items:center;gap:10px}.mp-room-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:#4a4;box-shadow:0 0 8px #4a4;transition:background .5s var(--ease-out),box-shadow .5s var(--ease-out)}.mp-room-dot.disconnected{background:#c44;box-shadow:0 0 8px #c44}.mp-room-dot.connecting{background:#e8a030;box-shadow:0 0 8px #e8a030;animation:kp-pulse 1.5s infinite}.mp-room-label-display{font-weight:600;color:var(--text);font-size:.9rem}.mp-room-id{font-family:Consolas,monospace;font-size:.78rem;color:var(--text-gold);background:var(--accent-dim);padding:3px 10px;border-radius:12px;border:1px solid var(--accent)}.mp-room-actions{display:flex;align-items:center;gap:8px}.mp-peer-count{font-size:.78rem;color:var(--text-dim)}.mp-room-body{display:grid;grid-template-columns:240px 1fr;gap:16px;height:calc(100vh - 160px);min-height:600px}.mp-sidebar h3{font-family:var(--font-display);color:var(--text-gold);font-size:.9rem;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.mp-player-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.mp-player-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);border:1px solid var(--border);background:#00000026;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.mp-player-item.host{border-color:var(--text-gold);background:var(--accent-dim)}.mp-player-item.you{border-color:var(--accent)}.mp-player-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--accent)}.mp-player-item.host .mp-player-avatar{border-color:var(--text-gold)}.mp-player-info{flex:1;min-width:0}.mp-player-name{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-player-stats{font-size:.68rem;color:var(--text-dim);margin-top:2px}.mp-player-badge{font-size:.6rem;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em}.mp-player-badge.host-badge{background:var(--accent-dim);color:var(--text-gold);border:1px solid var(--text-gold)}.mp-player-badge.you-badge{background:var(--accent-dim);color:var(--text);border:1px solid var(--accent)}.mp-sidebar-footer{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.mp-my-info{font-size:.73rem;color:var(--text-dim);text-align:center}.mp-kp-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.mp-kp-header{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--border)}.mp-kp-header h3{font-family:var(--font-display);font-size:.95rem;color:var(--text-gold);margin:0;padding:0;border:none}.mp-conn-status{font-size:.7rem;color:var(--text-dim)}.mp-kp-msgs{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.mp-msg.gm{align-self:flex-start;background:var(--bg-panel);border:1px solid var(--border);border-bottom-left-radius:2px}.mp-msg.chat{align-self:flex-start;background:#0003;border:1px solid var(--border);border-radius:var(--r-md);margin-left:20px;font-size:.8rem}.mp-msg.action{align-self:flex-end;background:var(--accent-dim);border:1px solid var(--accent);border-bottom-right-radius:2px}.mp-msg.secret{align-self:flex-end;background:var(--accent-dim);border:1px dashed var(--accent2);border-bottom-right-radius:2px}.mp-msg.system{align-self:center;max-width:95%;background:#00000040;border:1px dashed var(--border);font-size:.76rem;color:var(--text-dim);text-align:center;padding:8px 16px}.mp-msg .msg-sender{font-size:.7rem;font-weight:600;margin-bottom:2px}.mp-msg .msg-dice-tag{display:inline-block;padding:3px 10px;margin-top:4px;background:#0000004d;border-radius:12px;font-weight:700;color:var(--text-gold);font-size:.8rem}.mp-msg .msg-secret-tag{display:inline-block;padding:2px 8px;margin-top:2px;background:var(--accent-dim);border-radius:10px;font-size:.68rem;color:var(--accent2)}.mp-turn-info strong{color:var(--text-gold)}.mp-lobby-btns{display:flex;gap:8px}.mp-quick-btn{padding:5px 12px;border-radius:14px;font-size:.72rem;border:1px solid var(--border);background:#0003;color:var(--text-dim);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);font-family:inherit}.mp-quick-btn:hover{border-color:var(--accent);color:var(--text-gold);background:var(--accent-dim)}.mp-kp-input-row{padding:10px 16px 14px;border-top:1px solid var(--border)}.mp-input-tabs{display:flex;gap:4px;margin-bottom:8px}.mp-input-tab{padding:5px 14px;border-radius:14px;font-size:.73rem;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out);font-family:inherit}.mp-input-tab.active{background:var(--accent-dim);color:var(--text-gold);border-color:var(--accent)}.mp-input-tab:hover:not(.active){color:var(--text);border-color:var(--text-dim)}.mp-input-tab.secret-active{background:var(--accent-dim);border-color:var(--accent2);color:var(--accent2)}.mp-input-wrap{display:flex;gap:8px}.mp-input-wrap input{flex:1;padding:10px 14px;font-family:inherit;font-size:.85rem;background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);transition:background var(--t) var(--ease-out),color var(--t) var(--ease-out),border-color var(--t) var(--ease-out),opacity var(--t) var(--ease-out),transform var(--t) var(--ease-out)}.mp-input-wrap input:focus{outline:none;border-color:var(--border-bright);box-shadow:0 0 0 1px var(--accent-dim)}.mp-input-wrap input:disabled{opacity:.4;cursor:not-allowed}.mp-overlay-card{text-align:center;padding:40px;border-radius:var(--r-xl);background:var(--bg-panel);border:1px solid var(--border);box-shadow:var(--shadow)}.mp-overlay-card .loader{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 18px}@keyframes spin{to{transform:rotate(360deg)}}.mp-overlay-card p{color:var(--text-dim);font-size:.88rem}.mp-reconnect-toast.error{background:#d4443a;color:#fff}.combat-round-badge{background:#dc3c2826;color:#e04848;padding:2px 10px;border-radius:10px;font-size:.78rem;font-weight:700}.combat-current-name{color:var(--text-gold);font-size:.82rem;font-weight:600}.combat-track{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 0;font-size:.75rem}.combatant-tag{display:inline-block;padding:3px 10px;border-radius:8px;background:var(--bg-card);text-align:center;font-size:.72rem;border:1px solid var(--border);transition:background .15s var(--ease-out),border-color .15s var(--ease-out)}.combatant-active{border-color:var(--text-gold);background:#d4943a1f;font-weight:700;box-shadow:0 0 6px #d4943a40}.combatant-waiting{opacity:.6}.combatant-tag small{display:block;opacity:.7;font-size:.65rem}.mp-phase-badge.chase{background:#dca02826;color:#d4a028}.coc-stat{flex:1;min-width:90px;text-align:center;padding:6px 8px;background:#0003;border:1px solid var(--border);border-radius:var(--r-sm)}.coc-stat-label{font-size:.68rem;color:var(--text-dim);display:block;margin-bottom:2px}.coc-stat-val{font-size:.85rem;font-weight:700;color:var(--text)}.coc-stat-bar{height:4px;background:#00000059;border-radius:2px;margin-top:4px;overflow:hidden}.coc-stat-fill{height:100%;border-radius:2px;transition:width .4s var(--ease-out)}.coc-stat-fill.hp{background:#d4443a}.coc-stat-fill.san{background:#6a88cc}.coc-stat-fill.luck{background:#4a4}.chronicle-time{font-size:.68rem;color:var(--text-dim)}.chronicle-text{font-size:.8rem;color:var(--text);margin-top:2px;line-height:1.5}.coc-status-mini .coc-stat{display:flex;align-items:center;gap:4px}.coc-status-mini .coc-stat-label{color:var(--text-dim);font-size:.72rem}.coc-status-mini .coc-stat-val{font-weight:600;color:var(--text)}.coc-status-mini .coc-stat-bar{width:40px;height:4px;border-radius:2px;background:#ffffff0f;margin-left:2px}.coc-status-mini .coc-stat-fill{height:100%;border-radius:2px}.coc-status-mini .coc-stat-fill.luck{background:var(--text-gold)}.skill-row-coc:hover{background:#ffffff08}.skill-name-coc{flex:1;font-size:.82rem;color:var(--text);min-width:80px}.skill-base-coc{font-size:.7rem;color:var(--text-dim);min-width:60px;text-align:right}.skill-val-input{width:44px;padding:2px 4px;text-align:center;background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;font-family:inherit}.skill-val-input:focus{border-color:var(--accent);outline:none}.skill-pct{font-weight:600;font-size:.82rem;color:var(--text-gold);min-width:36px;text-align:right}@media(max-width:700px){.site-footer{padding:14px 12px;margin-top:20px}.footer-inner{gap:12px}.footer-copyright{font-size:.7rem}input[type=text],input[type=number],select,textarea{padding:8px 10px;font-size:.82rem}.notes-editor textarea{min-height:220px}.notes-editor div[style*="display:flex"]{flex-direction:column;gap:6px}.notes-editor div[style*="display:flex"] input[type=text]{width:100%}.notes-toolbar{flex-wrap:wrap;gap:4px}.portrait-zone{max-width:200px;margin:0 auto 14px}.spell-card-body{padding:6px 10px}.spell-card-meta{flex-direction:column;gap:2px}.init-row{padding:6px 8px}.kp-config{grid-template-columns:1fr}.kp-action-buttons{gap:6px}.kp-action-btn{padding:8px 16px;font-size:.8rem;min-width:60px}.game-save-item{flex-wrap:wrap}}@media(min-width:701px)and (max-width:960px){.nav-tab{padding:9px 14px;font-size:.84rem}.hero h1{font-size:2.2rem}.rpg-grid{grid-template-columns:repeat(2,1fr)}}
