*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #171717;--panel: #1f1f1f;--elevated: #282828;--sunken: #0a0a0a;--border: #2a2a2a;--border-hi: #3d3d3d;--border-focus: #d4a020;--gold: #d4a020;--gold-light: #f0c040;--gold-bright: #f8d870;--gold-dark: #7a5c0e;--gold-dim: #3a2c08;--gold-glow: rgba(212,160,32,.3);--crimson: #dc2626;--crimson-light: #f87171;--crimson-dim: #7f1d1d;--crimson-glow: rgba(220,38,38,.28);--arcane: #7c3aed;--arcane-light: #a78bfa;--arcane-dim: #3b1c7a;--arcane-glow: rgba(124,58,237,.25);--emerald: #059669;--emerald-light: #34d399;--emerald-dim: #064e3b;--cobalt: #2563eb;--cobalt-light: #60a5fa;--cobalt-dim: #1e3a8a;--red: var(--crimson);--red-light: var(--crimson-light);--red-dim: var(--crimson-dim);--green: var(--emerald);--green-light: var(--emerald-light);--green-dim: var(--emerald-dim);--blue: var(--cobalt);--blue-light: var(--cobalt-light);--orange: #ea580c;--orange-light:#fb923c;--navy-light: var(--cobalt-light);--text: #f0f0f0;--text-dim: #9a9a9a;--text-muted: #5a5a5a;--text-faint: #2d2d2d;--parch: #f0e8d4;--parch-light: #faf4e8;--parch-ink: #1a1410;--parch-dim: #6a5838;--parch-border: #c0a870;--font-display: "Cinzel", "Palatino Linotype", Georgia, serif;--font-content: "Lora", "Georgia", "Times New Roman", serif;--font-body: "Inter", "Segoe UI", system-ui, sans-serif;--font-mono: "Courier New", "Consolas", monospace;--radius: 5px;--radius-lg: 9px;--radius-xl: 14px;--shadow: 0 8px 32px rgba(0,0,0,.85), 0 2px 8px rgba(0,0,0,.5);--shadow-sm: 0 2px 12px rgba(0,0,0,.6);--shadow-gold: 0 0 24px rgba(212,160,32,.2);--shadow-inset: inset 0 1px 3px rgba(0,0,0,.7);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--bg)}body{min-height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--sunken)}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dark)}h1,h2,h3,h4{font-family:var(--font-display);color:var(--gold-light);letter-spacing:.05em;font-weight:700;line-height:1.2}h1{font-size:2rem}h2{font-size:1.2rem}h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);font-weight:700}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.93) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}@keyframes pulse-gold{0%,to{box-shadow:0 0 #d4a0208c}50%{box-shadow:0 0 0 8px #d4a02000}}@keyframes pulse-green{0%,to{box-shadow:0 0 #34d39980}50%{box-shadow:0 0 0 8px #34d39900}}@keyframes pulse-arcane{0%,to{box-shadow:0 0 #a78bfa80}50%{box-shadow:0 0 0 8px #a78bfa00}}@keyframes torch-flicker{0%,to{opacity:1}91%{opacity:.97}93%{opacity:.82}95%{opacity:.94}97%{opacity:.86}}@keyframes entry-pop{0%{opacity:0;transform:translate(-8px)}60%{opacity:1;transform:translate(2px)}to{opacity:1;transform:translate(0)}}button{font-family:var(--font-body);font-size:13px;cursor:pointer;border:none;border-radius:var(--radius);padding:7px 14px;transition:background .2s,box-shadow .2s,transform .12s,color .18s,border-color .2s;outline:none;letter-spacing:.02em}button:active:not(:disabled){transform:scale(.96)}button:disabled{opacity:.35;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--gold-dim);color:var(--gold-light);border:1px solid var(--gold-dark);font-family:var(--font-display);font-weight:600;letter-spacing:.07em}.btn-primary:hover:not(:disabled){background:var(--gold-dark);color:var(--gold-bright);box-shadow:0 0 18px #d4a02066}.btn-secondary{background:var(--elevated);color:var(--text-dim);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border-hi);color:var(--text);border-color:var(--border-hi)}.btn-danger{background:var(--crimson-dim);color:var(--crimson-light);border:1px solid #991b1b;font-weight:600}.btn-danger:hover:not(:disabled){background:#991b1b;color:#fecaca;box-shadow:0 0 14px var(--crimson-glow)}.btn-icon{background:transparent;color:var(--text-muted);border:1px solid transparent;padding:5px 9px;font-size:16px;line-height:1;transition:background .15s,color .15s,border-color .15s}.btn-icon:hover{background:var(--elevated);color:var(--text);border-color:var(--border)}.btn-icon.active{background:var(--gold-dim);color:var(--gold-light);border-color:var(--gold-dark);box-shadow:0 0 10px var(--gold-glow)}input,select,textarea{font-family:var(--font-body);font-size:13px;background:var(--sunken);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:8px 11px;width:100%;outline:none;transition:border-color .18s,box-shadow .18s}input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4a02024,var(--shadow-inset)}input::placeholder{color:var(--text-faint);font-style:italic}select option{background:var(--panel)}label{font-size:11px;font-weight:600;color:var(--text-muted);display:block;margin-bottom:5px;text-transform:uppercase;letter-spacing:.09em;font-family:var(--font-body)}.field{margin-bottom:14px}.parchment{background:var(--parch-light);color:var(--parch-ink);font-family:var(--font-content)}.parchment h1,.parchment h2,.parchment h3{color:#7a1c00}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.panel-header{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.panel-body{padding:12px 14px}.gold-rule{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dark),transparent);margin:8px 0}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.badge-gold{background:var(--gold-dim);color:var(--gold-light);border:1px solid var(--gold-dark)}.badge-crimson{background:var(--crimson-dim);color:var(--crimson-light);border:1px solid #991b1b}.badge-green{background:var(--emerald-dim);color:var(--emerald-light);border:1px solid var(--emerald)}.badge-red{background:var(--crimson-dim);color:var(--crimson-light);border:1px solid var(--crimson)}.badge-arcane{background:var(--arcane-dim);color:var(--arcane-light);border:1px solid var(--arcane)}.badge-gray{background:var(--elevated);color:var(--text-dim);border:1px solid var(--border)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.align-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.hp-bar-outer{height:7px;background:var(--sunken);border-radius:3px;overflow:hidden;flex:1;border:1px solid rgba(0,0,0,.4)}.hp-bar-inner{height:100%;border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fade-in .2s ease}.modal{background:var(--panel);border:1px solid var(--border-hi);border-top:2px solid var(--gold);border-radius:var(--radius-lg);padding:28px;width:400px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow),var(--shadow-gold);animation:scale-in .24s cubic-bezier(.34,1.15,.64,1)}.modal h2{margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border);font-size:1.1rem}.context-menu{position:fixed;background:var(--elevated);border:1px solid var(--border-hi);border-top:2px solid var(--gold-dark);border-radius:var(--radius);z-index:900;min-width:172px;box-shadow:var(--shadow);overflow:hidden;animation:scale-in .16s cubic-bezier(.34,1.2,.64,1);transform-origin:top left}.context-menu button{display:block;width:100%;text-align:left;padding:9px 14px;border-radius:0;background:transparent;color:var(--text-dim);border:none;border-bottom:1px solid var(--border);font-size:13px;transition:background .12s,color .12s}.context-menu button:last-child{border-bottom:none}.context-menu button:hover{background:#d4a0201a;color:var(--text)}.join-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 90% 60% at 50% 0%,rgba(212,160,32,.08) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(124,58,237,.07) 0%,transparent 50%),var(--bg);padding:20px;overflow:auto;animation:fade-in .7s ease}.join-card{background:var(--panel);border:1px solid var(--border-hi);border-top:3px solid var(--gold);border-radius:var(--radius-xl);padding:38px 34px 34px;width:490px;max-width:100%;box-shadow:var(--shadow),var(--shadow-gold);animation:slide-up .45s cubic-bezier(.34,1.1,.64,1)}.join-logo{text-align:center;margin-bottom:10px;font-size:2.8rem;color:var(--gold);text-shadow:0 0 30px var(--gold-glow),0 0 60px rgba(212,160,32,.12);animation:torch-flicker 6s ease-in-out infinite}.join-title{text-align:center;font-family:var(--font-display);font-size:1.8rem;font-weight:900;color:var(--gold-light);letter-spacing:.12em;margin-bottom:5px;text-shadow:0 0 40px rgba(212,160,32,.35)}.join-subtitle{text-align:center;color:var(--text-muted);margin-bottom:30px;font-size:11px;letter-spacing:.12em;text-transform:uppercase}.join-divider{display:flex;align-items:center;gap:10px;margin:22px 0}.join-divider:before,.join-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-hi))}.join-divider:after{background:linear-gradient(90deg,var(--border-hi),transparent)}.join-divider span{font-size:11px;color:var(--text-muted);font-family:var(--font-display);letter-spacing:.1em}.join-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px}.join-tab{flex:1;padding:10px 6px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;cursor:pointer;border-radius:0;transition:color .2s,border-color .2s;margin-bottom:-1px}.join-tab:hover{color:var(--text-dim)}.join-tab.active{color:var(--gold-light);border-bottom-color:var(--gold)}.sidebar-tab-bar{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-tab{flex:1;padding:9px 4px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:10px;font-weight:700;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-1px}.sidebar-tab:hover{color:var(--text-dim)}.sidebar-tab.active{color:var(--gold-light);border-bottom-color:var(--gold)}.dm-layout{display:flex;height:100vh;overflow:hidden}.dm-sidebar{width:272px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.dm-sidebar-section{border-bottom:1px solid var(--border);padding:12px}.dm-sidebar-section h3{margin-bottom:8px;display:flex;align-items:center;gap:6px}.dm-sidebar-section h3:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border-hi),transparent)}.dm-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.dm-toolbar{background:var(--surface);border-bottom:1px solid var(--border);padding:7px 10px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.tool-sep{width:1px;height:26px;background:var(--border-hi);margin:0 4px;flex-shrink:0}.dm-map-area{flex:1;overflow:hidden;position:relative}.player-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.player-header{background:var(--surface);border-bottom:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.player-map-area{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}.player-footer{background:var(--surface);border-top:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;gap:16px;flex-shrink:0;flex-wrap:wrap}.turn-indicator{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#0f0f0ff7;border:1px solid var(--gold-dark);border-top:2px solid var(--gold);border-radius:var(--radius-lg);padding:8px 24px;font-family:var(--font-display);font-weight:700;color:var(--gold-light);font-size:14px;pointer-events:none;z-index:100;letter-spacing:.07em;box-shadow:0 4px 24px #000c,var(--shadow-gold);animation:slide-up .25s ease;white-space:nowrap}.turn-indicator.my-turn{border-color:var(--emerald);border-top-color:var(--emerald-light);color:var(--emerald-light);background:#06120cf7;animation:slide-up .25s ease,pulse-green 2s ease-in-out infinite}.turn-list{list-style:none}.turn-list-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius);margin-bottom:3px;border-left:3px solid transparent;transition:background .18s,border-color .18s}.turn-list-item:hover{background:var(--elevated)}.turn-list-item.active{background:#d4a0201a;border-left-color:var(--gold);animation:pulse-gold 2.4s ease-in-out infinite}.turn-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;box-shadow:0 1px 4px #0009;border:1px solid rgba(255,255,255,.15)}.initiative-num{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--gold);min-width:22px;text-align:right;opacity:.9}.player-item{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:var(--radius);margin-bottom:2px;transition:background .12s}.player-item:hover{background:#d4a0200f}.player-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.player-dot.online{background:var(--emerald-light);box-shadow:0 0 6px #34d399b3}.player-dot.offline{background:var(--text-faint)}.map-card{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:4px;cursor:pointer;transition:background .15s,border-color .2s,box-shadow .2s;animation:fade-in .2s ease}.map-card:hover{background:var(--elevated);border-color:var(--border-hi)}.map-card.active{border-color:var(--gold);background:#d4a02014;box-shadow:0 0 12px var(--gold-glow)}.notification{position:fixed;top:16px;right:16px;background:var(--panel);border:1px solid var(--border-hi);border-left:3px solid var(--text-muted);border-radius:var(--radius);padding:11px 16px;max-width:320px;z-index:9999;box-shadow:var(--shadow);animation:slide-in-right .28s cubic-bezier(.34,1.1,.64,1);font-size:13px}.notification.error{border-left-color:var(--crimson-light);color:var(--crimson-light)}.notification.success{border-left-color:var(--emerald-light);color:var(--emerald-light)}.notification.info{border-left-color:var(--arcane-light);color:var(--arcane-light)}.combat-log-entry{animation:entry-pop .22s ease}.canvas-container{width:100%;height:100%;overflow:hidden;background:#080808;cursor:default}canvas{display:block}.location-map-container{position:relative;width:100%;height:100%;overflow:hidden}.location-map-img{width:100%;height:100%;object-fit:contain;display:block}.code-display{font-family:var(--font-mono);font-size:1.4rem;font-weight:700;color:var(--gold-bright);letter-spacing:.22em;text-align:center;background:var(--sunken);border:1px solid var(--gold-dark);border-radius:var(--radius);padding:10px;margin:8px 0;text-shadow:0 0 20px var(--gold-glow)}.divider{border:none;border-top:1px solid var(--border);margin:8px 0}.empty-state{text-align:center;color:var(--text-muted);font-size:13px;padding:24px;font-style:italic;font-family:var(--font-content)}
