:root{--bg-base: #eef0f8;--bg-surface: rgba(255, 255, 255, .82);--bg-elevated: rgba(255, 255, 255, .94);--text-primary: #0f0e18;--text-secondary: #5c5a72;--accent: #5b4ddb;--accent-2: #0d9f8e;--rpg-charm: #a67c2d;--danger: #dc2626;--warning: #c2410c;--border: rgba(30, 27, 75, .085);--shadow: 0 2px 8px rgba(22, 18, 55, .04), 0 16px 48px rgba(22, 18, 55, .07);--shadow-accent: 0 0 0 1px rgba(91, 77, 219, .11), 0 12px 40px rgba(91, 77, 219, .16);--panel-blur: blur(20px) saturate(1.2);--radius: 20px;--radius-sm: 12px;--radius-pill: 999px;--sidebar-width: 280px;--header-height: 76px;--content-max: 1600px;--paper-noise: radial-gradient(circle at 20% 20%, rgba(0,0,0,.02) 0 1px, transparent 1px 100%), radial-gradient(circle at 80% 40%, rgba(0,0,0,.015) 0 1px, transparent 1px 100%), radial-gradient(circle at 40% 80%, rgba(0,0,0,.012) 0 1px, transparent 1px 100%)}[data-theme=dark]{--bg-base: #06060d;--bg-surface: rgba(22, 24, 38, .78);--bg-elevated: rgba(16, 18, 30, .88);--text-primary: #eceef7;--text-secondary: #9499b8;--accent: #9b8cff;--accent-2: #2dd4bf;--rpg-charm: #d4b87c;--danger: #f87171;--warning: #fbbf24;--border: rgba(120, 130, 200, .14);--shadow: 0 8px 32px rgba(0, 0, 0, .45), 0 24px 64px rgba(0, 0, 0, .35);--shadow-accent: 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent), 0 0 32px color-mix(in srgb, var(--accent) 18%, transparent), 0 20px 50px rgba(0, 0, 0, .55);--paper-noise: radial-gradient(circle at 20% 20%, rgba(255, 255, 255, .022) 0 1px, transparent 1px 100%), radial-gradient(circle at 80% 40%, rgba(255, 255, 255, .018) 0 1px, transparent 1px 100%), radial-gradient(circle at 40% 80%, rgba(255, 255, 255, .012) 0 1px, transparent 1px 100%)}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}.aether-app-bg{min-height:100vh;font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;color:var(--text-primary);background:radial-gradient(ellipse 120% 80% at 0% 0%,color-mix(in srgb,var(--accent) 12%,transparent),transparent 52%),radial-gradient(ellipse 90% 70% at 100% 10%,color-mix(in srgb,var(--accent-2) 8%,transparent),transparent 45%),linear-gradient(180deg,rgba(255,255,255,.5),transparent 42%),var(--paper-noise),var(--bg-base);overflow-x:hidden;position:relative}[data-theme=dark] .aether-app-bg{background:radial-gradient(ellipse 100% 70% at 50% -20%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 55%),radial-gradient(ellipse 60% 50% at 100% 0%,color-mix(in srgb,var(--accent-2) 10%,transparent),transparent 50%),radial-gradient(ellipse 50% 40% at 0% 100%,rgba(212,184,124,.04),transparent 55%),var(--paper-noise),var(--bg-base)}.aether-app-bg:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.22;background:linear-gradient(transparent 97%,#00000005),linear-gradient(90deg,transparent 97%,rgba(0,0,0,.018) 100%);background-size:24px 24px;-webkit-mask-image:radial-gradient(circle at center,black 38%,transparent 88%);mask-image:radial-gradient(circle at center,black 38%,transparent 88%)}[data-theme=dark] .aether-app-bg:before{opacity:.1;background:linear-gradient(transparent 97%,#ffffff08),linear-gradient(90deg,transparent 97%,rgba(255,255,255,.03) 100%)}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input{font:inherit}.app-shell{min-height:100vh}.sidebar{width:100%;position:relative;padding:20px;border-right:none;border-bottom:1px solid var(--border);background:var(--bg-elevated);backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);box-shadow:none}.main{min-width:0}@media(min-width:921px){.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;height:100dvh;max-height:100dvh;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;border-right:1px solid var(--border);border-bottom:none;box-shadow:inset -1px 0 #ffffff08;z-index:25}.main{margin-left:var(--sidebar-width)}}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:var(--header-height);padding:18px 28px;background:color-mix(in srgb,var(--bg-elevated) 92%,transparent);backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);border-bottom:1px solid var(--border);box-shadow:0 1px color-mix(in srgb,var(--text-primary) 4%,transparent)}[data-theme=dark] .topbar{background:color-mix(in srgb,var(--bg-elevated) 88%,rgba(0,0,0,.35));box-shadow:0 1px color-mix(in srgb,var(--accent) 12%,transparent)}.content{width:min(100%,var(--content-max));margin:0 auto;padding:28px}.section{margin-bottom:28px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2{margin:0;font-family:Cinzel,serif;font-size:1.15rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary)}[data-theme=dark] .section-title h2{text-shadow:0 0 28px color-mix(in srgb,var(--accent) 22%,transparent),0 1px 0 color-mix(in srgb,var(--rpg-charm) 35%,transparent)}.grid{display:grid;gap:18px}.grid.dashboard{grid-template-columns:1.3fr 1fr 1fr}.grid.character{grid-template-columns:320px 1fr 1fr 1fr;align-items:start}.grid.compendium{grid-template-columns:260px 340px 1fr}.grid.live{grid-template-columns:1.4fr 420px}@media(max-width:1200px){.grid.dashboard,.grid.character,.grid.compendium,.grid.live{grid-template-columns:1fr}}@media(max-width:920px){.main{margin-left:0}}.brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}.brand__sigil{width:42px;height:42px;border-radius:14px;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4),transparent 42%),linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent-2) 55%,var(--accent)) 52%,color-mix(in srgb,var(--accent) 70%,#fff 30%));box-shadow:var(--shadow-accent);position:relative}.brand__sigil:before{content:"✦";position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff;font-size:20px;font-weight:700}.brand__text strong{display:block;font-family:Cinzel,serif;letter-spacing:.08em;font-size:1rem}.brand__text span{color:var(--text-secondary);font-size:.86rem}.nav{display:grid;gap:8px}.nav__item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:var(--text-secondary);transition:.2s ease;border:1px solid transparent}.nav__item:hover,.nav__item.is-active{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent);border-color:color-mix(in srgb,var(--accent) 22%,transparent);box-shadow:inset 3px 0 0 var(--accent)}.nav__icon{width:18px;height:18px;border-radius:6px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 25%,transparent),transparent);border:1px solid var(--border);flex-shrink:0}.muted{color:var(--text-secondary)}.eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary)}.title-xl,.title-lg,.title-md{font-family:Cinzel,serif;margin:0;line-height:1.1}.title-xl{font-size:clamp(1.8rem,4vw,2.8rem)}.title-lg{font-size:1.35rem}.title-md{font-size:1.05rem}.kpi{display:flex;align-items:baseline;gap:10px}.kpi strong{font-size:1.8rem;font-weight:700}.kpi span{color:var(--text-secondary);font-size:.92rem}.card{position:relative;background:var(--bg-surface);backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card--cut{clip-path:polygon(0 0,calc(100% - 24px) 0,100% 24px,100% 100%,0 100%)}.card--accent:before{content:"";position:absolute;top:18px;left:0;bottom:18px;width:3px;border-radius:999px;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent-2) 70%,var(--accent)),transparent);box-shadow:0 0 14px color-mix(in srgb,var(--accent) 40%,transparent),0 0 20px color-mix(in srgb,var(--accent-2) 15%,transparent)}.card__body{padding:18px}.card__header{display:flex;align-items:start;justify-content:space-between;gap:12px;margin-bottom:16px}.card__footer{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;height:42px;padding:0 16px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-primary);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.btn:hover{transform:translateY(-1px)}.btn--primary{background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 20%,transparent),color-mix(in srgb,var(--accent) 8%,transparent));border-color:color-mix(in srgb,var(--accent) 38%,transparent);box-shadow:var(--shadow-accent)}.btn--primary:hover{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 22%,transparent),0 0 18px color-mix(in srgb,var(--accent) 28%,transparent)}.btn--ghost{border-color:var(--border);background:color-mix(in srgb,var(--bg-surface) 70%,transparent)}.btn--danger{border-color:color-mix(in srgb,var(--danger) 35%,transparent);color:#fff;background:linear-gradient(180deg,color-mix(in srgb,var(--danger) 90%,#fff 10%),var(--danger));box-shadow:0 8px 24px color-mix(in srgb,var(--danger) 24%,transparent)}.btn--pill{border-radius:var(--radius-pill)}.dice-btn{position:relative;width:58px;height:58px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--accent) 50%,transparent);background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 35%),color-mix(in srgb,var(--bg-surface) 70%,transparent);color:var(--accent);box-shadow:var(--shadow-accent);display:grid;place-items:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.dice-btn:hover{transform:rotate(-8deg) scale(1.03);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent),0 0 22px color-mix(in srgb,var(--accent) 32%,transparent)}.dice-btn:before{content:"⬡";font-size:1.35rem;line-height:1}.dice-btn__result{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);white-space:nowrap;padding:6px 10px;border-radius:999px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);font-size:.82rem}.field{display:grid;gap:8px}.field label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.input{width:100%;padding:10px 0 12px;border:none;border-bottom:2px solid color-mix(in srgb,var(--text-secondary) 25%,transparent);outline:none;background:transparent;color:var(--text-primary);transition:border-color .18s ease,box-shadow .18s ease}.input:focus{border-bottom-color:var(--accent);box-shadow:0 8px 18px -14px color-mix(in srgb,var(--accent) 60%,transparent)}.search{position:relative}.search:before{content:"◌";position:absolute;left:0;top:9px;color:var(--accent);font-size:1rem}.search .input{padding-left:22px}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-pill);border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 72%,transparent);color:var(--text-secondary);font-size:.84rem}.tag:before{content:"✧";color:var(--accent);font-size:.8rem}.pill{display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;border:1px solid var(--border);color:var(--text-secondary);font-size:.8rem}.status{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;color:var(--text-secondary)}.status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 10px color-mix(in srgb,var(--accent-2) 45%,transparent)}.stack{display:flex;align-items:center}.avatar{width:38px;height:38px;border-radius:50%;border:2px solid var(--bg-base);background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 40%,#fff 60%),color-mix(in srgb,var(--accent-2) 35%,#fff 65%));display:grid;place-items:center;color:#fff;font-weight:700;margin-left:-8px;box-shadow:var(--shadow)}.avatar:first-child{margin-left:0}.hero{display:grid;gap:18px;grid-template-columns:1.5fr 1fr;margin-bottom:28px}.hero__panel{min-height:240px;display:flex;flex-direction:column;justify-content:space-between;padding:22px;position:relative;overflow:hidden}.hero__panel--map{background:linear-gradient(180deg,#0000000a,#00000014),radial-gradient(circle at top left,color-mix(in srgb,var(--accent) 12%,transparent),transparent 40%),linear-gradient(135deg,rgba(255,255,255,.06),transparent 40%),var(--bg-surface)}.hero__panel--map:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.24;background-image:linear-gradient(30deg,transparent 24%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 25%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 26%,transparent 27%,transparent 74%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 75%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 76%,transparent 77%,transparent),linear-gradient(90deg,transparent 24%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 25%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 26%,transparent 27%,transparent 74%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 75%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 76%,transparent 77%,transparent),linear-gradient(150deg,transparent 24%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 25%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 26%,transparent 27%,transparent 74%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 75%,color-mix(in srgb,var(--text-secondary) 18%,transparent) 76%,transparent 77%,transparent);background-size:46px 80px;background-position:0 0,0 0,23px 40px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.mini-stat{padding:14px;border-radius:14px;background:color-mix(in srgb,var(--bg-surface) 72%,transparent);border:1px solid var(--border)}.mini-stat strong{display:block;font-size:1.2rem;margin-top:4px}.char-side{position:sticky;top:94px}.portrait{aspect-ratio:4 / 5;border-radius:18px;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.22),transparent 24%),linear-gradient(180deg,color-mix(in srgb,var(--accent) 20%,transparent),transparent 35%),linear-gradient(135deg,color-mix(in srgb,var(--accent) 60%,#fff 40%),color-mix(in srgb,var(--accent-2) 55%,#fff 45%));box-shadow:var(--shadow);position:relative;overflow:hidden}.portrait:after{content:"WIZARD";position:absolute;right:-18px;bottom:18px;padding:8px 14px;transform:rotate(-90deg);transform-origin:right bottom;letter-spacing:.18em;font-size:.72rem;color:#ffffffd9;background:#0000002e;border-radius:999px}.char-name{margin:16px 0 6px;font-family:Cinzel,serif;font-size:1.35rem}.resource-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.resource{padding:14px;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 74%,transparent);text-align:center}.resource strong{display:block;font-size:1.3rem;margin-top:6px}.hp-bar{position:relative;height:12px;border-radius:999px;background:color-mix(in srgb,var(--text-secondary) 14%,transparent);overflow:hidden;margin-top:10px}.hp-bar__fill{width:72%;height:100%;background:linear-gradient(90deg,#9b1c1c,var(--danger) 55%,#ff867a);box-shadow:inset 0 0 8px #ffffff2e,0 0 18px #dc262642;border-radius:inherit}[data-theme=dark] .hp-bar__fill{background:linear-gradient(90deg,#7f1d1d,#ef4444 50%,#ff8b8b);box-shadow:0 0 16px #ef444459}.stat-wheel{width:92px;aspect-ratio:1;border-radius:50%;margin:8px auto 10px;background:radial-gradient(circle at center,transparent 52%,color-mix(in srgb,var(--accent) 18%,transparent) 53%,transparent 58%),conic-gradient(from -90deg,var(--accent) 0 72%,color-mix(in srgb,var(--text-secondary) 14%,transparent) 72% 100%);display:grid;place-items:center;box-shadow:inset 0 0 14px #ffffff0a}.stat-wheel span{width:56px;height:56px;display:grid;place-items:center;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);font-weight:700}.ability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.ability-card{position:relative;padding:14px;border-radius:16px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 78%,transparent);overflow:hidden}.ability-card:after{content:"✦";position:absolute;right:10px;bottom:8px;font-size:3rem;color:color-mix(in srgb,var(--accent) 12%,transparent);pointer-events:none}.ability-card small{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.ability-card strong{display:block;margin-top:6px;font-size:1.4rem}.list{display:grid;gap:10px}.list-item{padding:14px;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 76%,transparent);transition:.18s ease}.list-item:hover,.list-item.is-active{border-color:color-mix(in srgb,var(--accent) 28%,transparent);box-shadow:var(--shadow-accent)}.spell-card{position:relative;padding-left:18px}.spell-card:before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:4px;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--accent-2))}.map-editor{display:grid;grid-template-columns:88px 1fr;gap:18px;min-height:380px}.tools{display:grid;gap:10px;align-content:start}.tool{aspect-ratio:1;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 78%,transparent);display:grid;place-items:center;color:var(--text-secondary);cursor:default;font-size:1.15rem;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.tool.is-active{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent),0 0 22px color-mix(in srgb,var(--accent) 38%,transparent),inset 0 1px #ffffff1f;transform:translateY(-1px)}.map-canvas{position:relative;border-radius:18px;overflow:hidden;border:1px solid color-mix(in srgb,var(--border) 80%,#000 20%);min-height:380px;background:radial-gradient(ellipse 120% 100% at 50% 100%,#151820,#07080c 55%);box-shadow:inset 0 0 0 1px #ffffff0a,inset 0 -24px 48px #00000073}.map-canvas__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.92;filter:saturate(1.05) contrast(1.06);transform:scale(1.01)}.map-canvas__bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000001f,#00000059);pointer-events:none}.map-canvas__grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.22;pointer-events:none;background-image:linear-gradient(to right,rgba(255,255,255,.14) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.14) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 72% 68% at 52% 48%,black 12%,rgba(0,0,0,.45) 55%,transparent 88%);-webkit-mask-image:radial-gradient(ellipse 72% 68% at 52% 48%,black 12%,rgba(0,0,0,.45) 55%,transparent 88%)}.map-canvas__torch{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 52% 46%,rgba(255,236,200,.38) 0%,rgba(255,210,140,.12) 28%,transparent 52%);mix-blend-mode:screen}.map-canvas__vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 85% 90% at 50% 48%,transparent 0%,transparent 22%,rgba(0,0,0,.55) 58%,rgba(0,0,0,.88) 100%)}.map-canvas__tokens{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none}.token{position:absolute;width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.72);display:grid;place-items:center;color:#fff;font-weight:800;font-size:1rem;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 0 0 1px #00000059,0 10px 22px #0000008c,inset 0 2px 6px #ffffff38}.token--red{background:linear-gradient(145deg,#fb7185,#b91c1c 45%,#7f1d1d);top:56%;left:22%;box-shadow:0 0 0 1px #00000059,0 10px 22px #0000008c,0 0 20px #f8717173,inset 0 2px 6px #ffffff38}.token--purple{background:linear-gradient(145deg,#d8b4fe,#9333ea 42%,#4c1d95);top:24%;left:40%;box-shadow:0 0 0 1px #00000059,0 10px 22px #0000008c,0 0 22px #c084fc80,inset 0 2px 6px #ffffff40}.token--green{background:linear-gradient(145deg,#6ee7b7,#059669 45%,#064e3b);top:40%;left:62%;box-shadow:0 0 0 1px #00000059,0 10px 22px #0000008c,0 0 24px #34d3998c,inset 0 2px 6px #ffffff47}.map-editor-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}.map-editor-meta{font-size:.88rem;color:var(--text-secondary)}.map-editor-meta strong{color:var(--text-primary)}.masonry{columns:4 220px;column-gap:16px}.media-item{break-inside:avoid;margin-bottom:16px;border-radius:16px;overflow:hidden;position:relative;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--bg-surface)}.media-thumb{min-height:140px;background:radial-gradient(circle at top left,rgba(255,255,255,.16),transparent 25%),linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,#445),#1a1e29)}.media-thumb.h-sm{height:160px}.media-thumb.h-md{height:220px}.media-thumb.h-lg{height:300px}.media-overlay{position:absolute;inset:auto 10px 10px 10px;padding:10px 12px;border-radius:12px;background:#0000006b;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:10px;opacity:0;transform:translateY(8px);transition:.18s ease}.media-item:hover .media-overlay{opacity:1;transform:translateY(0)}.session-map{min-height:480px;border-radius:18px;border:1px solid color-mix(in srgb,var(--border) 80%,#000 20%);overflow:hidden;position:relative;background:radial-gradient(ellipse 120% 100% at 50% 100%,#151820,#07080c 55%);box-shadow:inset 0 0 0 1px #ffffff0a}.session-map:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 48% 44%,rgba(255,236,200,.28) 0%,rgba(255,200,120,.08) 32%,transparent 54%);mix-blend-mode:screen;pointer-events:none}.session-map:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.1) 1px,transparent 1px);background-size:36px 36px;opacity:.2;mask-image:radial-gradient(ellipse 78% 72% at 50% 46%,black 18%,transparent 82%);-webkit-mask-image:radial-gradient(ellipse 78% 72% at 50% 46%,black 18%,transparent 82%);pointer-events:none}.gm-book{position:absolute;left:16px;top:16px;width:220px;padding:14px;border-radius:16px;background:var(--bg-elevated);border:1px solid var(--border);backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur)}.chat{display:grid;gap:12px}.roll{padding:14px;border-radius:16px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-surface) 78%,transparent);box-shadow:var(--shadow)}.roll__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.roll__result{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:54px;padding:0 12px;border-radius:18px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 35%,transparent),color-mix(in srgb,var(--accent) 10%,transparent));border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);color:var(--text-primary);font-weight:700;font-size:1.25rem;box-shadow:var(--shadow-accent)}.roll.is-crit .roll__result{background:linear-gradient(135deg,#f7d774,#c89b1e);border-color:#ffd70059;color:#2a1c00;box-shadow:0 0 22px #ffd70047}.footer-note{padding:18px;border-radius:16px;border:1px dashed var(--border);color:var(--text-secondary);font-size:.92rem;background:color-mix(in srgb,var(--bg-surface) 62%,transparent)}:root,[data-theme=light]{--bg-base: #eef1f4;--bg-surface: #ffffff;--bg-elevated: #f8fafb;--bg-overlay: #ffffff;--bg-sunken: #e8ecf1;--bg-input: #f3f5f7;--border: #dfe4ea;--border-strong: #c5ccd6;--border-focus: #0d9488;--text-primary: #0f1419;--text-secondary: #4a5568;--text-muted: #8b95a5;--text-placeholder: #a8b0bd;--text-on-accent: #ffffff;--text-on-dark: #f4f7fa;--accent: #0f9488;--accent-hover: #0d7f75;--accent-active: #0a6b62;--accent-subtle: rgba(15, 148, 136, .1);--accent-subtle-hover: rgba(15, 148, 136, .16);--accent-border: rgba(15, 148, 136, .28);--accent-glow: rgba(15, 148, 136, .35);--mystic: #6366f1;--mystic-subtle: rgba(99, 102, 241, .1);--mystic-border: rgba(99, 102, 241, .28);--danger: #dc3545;--danger-hover: #c82333;--danger-subtle: rgba(220, 53, 69, .1);--danger-border: rgba(220, 53, 69, .28);--success: #15803d;--success-subtle: rgba(21, 128, 61, .1);--success-border: rgba(21, 128, 61, .28);--warning: #b45309;--warning-subtle: rgba(180, 83, 9, .1);--warning-border: rgba(180, 83, 9, .28);--info: #2563eb;--info-subtle: rgba(37, 99, 235, .1);--info-border: rgba(37, 99, 235, .28);--resource-hp: #dc3545;--resource-mind: #2563eb;--resource-luck: #15803d;--resource-stress: #6366f1;--shadow-xs: 0 1px 2px rgba(15, 20, 25, .05);--shadow-sm: 0 1px 3px rgba(15, 20, 25, .06), 0 1px 2px rgba(15, 20, 25, .04);--shadow-md: 0 4px 12px rgba(15, 20, 25, .08), 0 2px 4px rgba(15, 20, 25, .04);--shadow-lg: 0 12px 28px rgba(15, 20, 25, .1), 0 4px 8px rgba(15, 20, 25, .05);--shadow-xl: 0 24px 48px rgba(15, 20, 25, .12);--shadow-accent: 0 0 0 3px rgba(15, 148, 136, .22);--canvas-shell-bg: #dce1e8;--canvas-toolbar-bg: #e8ecf2;--canvas-toolbar-border: #cdd4df;--canvas-tool-active: rgba(15, 148, 136, .14);--sidebar-bg: #f0f3f6;--sidebar-border: #dfe4ea;--sidebar-item-hover: rgba(15, 20, 25, .04);--sidebar-item-active: rgba(15, 148, 136, .12);--sidebar-item-active-text: #0f766e;--sidebar-icon-color: #64748b;--sidebar-icon-active: #0f9488;--header-bg: rgba(255, 255, 255, .86);--header-border: #e2e8f0;--header-backdrop: blur(16px) saturate(1.2)}[data-theme=dark]{--bg-base: #06080c;--bg-surface: #0c0f14;--bg-elevated: #12161e;--bg-overlay: #181d27;--bg-sunken: #040508;--bg-input: #0f1319;--border: #1e2530;--border-strong: #2a3342;--border-focus: #5eead4;--text-primary: #e8ecf1;--text-secondary: #94a3b8;--text-muted: #5c677a;--text-placeholder: #3d4654;--text-on-accent: #031512;--text-on-dark: #e8ecf1;--accent: #5eead4;--accent-hover: #7cf0df;--accent-active: #4dd4bf;--accent-subtle: rgba(94, 234, 212, .1);--accent-subtle-hover: rgba(94, 234, 212, .18);--accent-border: rgba(94, 234, 212, .32);--accent-glow: rgba(94, 234, 212, .45);--mystic: #a5b4fc;--mystic-subtle: rgba(165, 180, 252, .12);--mystic-border: rgba(165, 180, 252, .35);--danger: #f87171;--danger-hover: #ef4444;--danger-subtle: rgba(248, 113, 113, .12);--danger-border: rgba(248, 113, 113, .35);--success: #4ade80;--success-subtle: rgba(74, 222, 128, .12);--success-border: rgba(74, 222, 128, .35);--warning: #fbbf24;--warning-subtle: rgba(251, 191, 36, .12);--warning-border: rgba(251, 191, 36, .35);--info: #60a5fa;--info-subtle: rgba(96, 165, 250, .12);--info-border: rgba(96, 165, 250, .35);--resource-hp: #f87171;--resource-mind: #60a5fa;--resource-luck: #4ade80;--resource-stress: #a5b4fc;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 6px rgba(0, 0, 0, .45);--shadow-md: 0 6px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 14px 36px rgba(0, 0, 0, .55);--shadow-xl: 0 24px 56px rgba(0, 0, 0, .6);--shadow-accent: 0 0 0 3px rgba(94, 234, 212, .22);--canvas-shell-bg: #050608;--canvas-toolbar-bg: #0a0c10;--canvas-toolbar-border: #161b24;--canvas-tool-active: rgba(94, 234, 212, .14);--sidebar-bg: #080b10;--sidebar-border: #141922;--sidebar-item-hover: rgba(255, 255, 255, .04);--sidebar-item-active: rgba(94, 234, 212, .1);--sidebar-item-active-text: #5eead4;--sidebar-icon-color: #64748b;--sidebar-icon-active: #5eead4;--header-bg: rgba(8, 11, 16, .88);--header-border: #141922;--header-backdrop: blur(16px) saturate(1.15)}:root{--font-sans: "Inter", "Plus Jakarta Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 34px;--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.55;--leading-relaxed: 1.7;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-2xl: 24px;--radius-full: 9999px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--header-h: 56px;--sidebar-w: 244px;--sidebar-w-sm: 58px;--content-max: 1200px;--content-pad: 28px;--t-fast: .14s cubic-bezier(.4, 0, .2, 1);--t-base: .22s cubic-bezier(.4, 0, .2, 1);--t-slow: .34s cubic-bezier(.4, 0, .2, 1);--t-layout: .24s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 100;--z-header: 110;--z-float: 150;--z-dropdown: 200;--z-modal: 300;--z-toast: 400;--fx-shimmer: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, .04) 50%, transparent 60%);--hp-color: var(--resource-hp);--mp-color: var(--resource-mind);--xp-color: var(--resource-luck);--gold-color: var(--accent);--accent-2: var(--mystic);--rpg-charm: #c9a227;--shadow: var(--shadow-md);--radius: var(--radius-xl);--sidebar-width: var(--sidebar-w);--header-height: var(--header-h)}html{--aether-font-display: "Cinzel", "Times New Roman", serif;--aether-font-body: "Plus Jakarta Sans", "Inter", system-ui, -apple-system, sans-serif;--aether-bg-base: var(--bg-base);--aether-bg-elevated: var(--bg-elevated);--aether-accent-magic: var(--accent);--aether-accent-danger: var(--danger);--aether-accent-success: var(--accent-2);--aether-rpg-charm: var(--rpg-charm, #a67c2d);--aether-text: var(--text-primary);--aether-text-muted: var(--text-secondary);--aether-border-subtle: var(--border);--aether-border-input: color-mix(in srgb, var(--text-secondary) 38%, transparent);--aether-glass-header: var(--bg-elevated);--aether-shadow-card: var(--shadow);--aether-map-stage: #080a12;--aether-panel-dim: color-mix(in srgb, var(--bg-surface) 62%, #000 38%)}html,body{margin:0;min-height:100%;font-family:var(--aether-font-body);color:var(--text-primary);background:transparent}:root{--scrollbar-size: 5px;--scrollbar-thumb: color-mix(in srgb, var(--border-strong, #c5ccd6) 70%, transparent);--scrollbar-thumb-hover: color-mix(in srgb, var(--accent) 55%, var(--border-strong));--scrollbar-track: transparent}[data-theme=dark]{--scrollbar-thumb: color-mix(in srgb, var(--border) 90%, var(--bg-elevated));--scrollbar-thumb-hover: color-mix(in srgb, var(--accent) 50%, var(--border))}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:999px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}::-webkit-scrollbar-corner{background:transparent}#app{min-height:100vh}.aether-display{font-family:var(--aether-font-display);font-weight:600;letter-spacing:.04em}.aether-subtitle{color:var(--text-secondary);font-size:.95rem;line-height:1.55;max-width:52rem}.aether-card-cut{position:relative;filter:drop-shadow(var(--shadow))}.aether-card-cut-inner{clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);border-radius:0}.aether-card-cut-inner :deep(.n-card){--n-border-color: transparent !important}.aether-card-accent-left{position:relative;padding-left:4px}.aether-card-accent-left:before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 35%,transparent));pointer-events:none}.aether-hex-btn{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--accent);background:var(--bg-surface);color:var(--accent);cursor:pointer;transition:transform .15s ease,box-shadow .2s ease;box-shadow:0 0 12px color-mix(in srgb,var(--accent) 25%,transparent)}.aether-hex-btn:hover{transform:scale(1.05);box-shadow:0 0 18px color-mix(in srgb,var(--accent) 40%,transparent)}.aether-hex-btn:active{transform:scale(.97)}.aether-input-line{border-bottom:2px solid var(--aether-border-input);border-radius:0;transition:border-color .2s ease,box-shadow .25s ease}.aether-input-line:focus-within{border-color:var(--accent);box-shadow:0 6px 18px -8px color-mix(in srgb,var(--accent) 45%,transparent)}.aether-chip-token{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:2px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:border-color .2s,color .2s,box-shadow .2s}.aether-chip-token:hover,.aether-chip-token.is-on{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 25%,transparent)}.aether-hex-grid-bg{background-color:#0003;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cpath fill='none' stroke='rgba(255,255,255,0.12)' d='M14 0v17M0 8.5h28M0 25h28M14 33v16'/%3E%3C/svg%3E");background-size:28px 49px}[data-theme=light] .aether-hex-grid-bg{background-color:#1f1a170f;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cpath fill='none' stroke='rgba(31,26,23,0.1)' d='M14 0v17M0 8.5h28M0 25h28M14 33v16'/%3E%3C/svg%3E")}[data-theme=dark] .map-editor-root .panels :deep(.n-card){background-color:var(--aether-panel-dim)!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.map-editor-root .stage-wrap{background:var(--aether-map-stage)!important;box-shadow:inset 0 0 0 1px var(--border)}.aether-btn-glow :deep(.n-button--primary-type){box-shadow:0 0 14px color-mix(in srgb,var(--accent) 35%,transparent)}.aether-btn-glow :deep(.n-button--primary-type:hover){box-shadow:0 0 20px color-mix(in srgb,var(--accent) 48%,transparent)}.aether-search-dust:focus-within{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent),0 0 24px color-mix(in srgb,var(--accent) 18%,transparent);transition:box-shadow .35s ease}.content.content--full{width:100%;max-width:none;margin:0;padding:12px 16px 32px}.shell-root{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) minmax(0,1fr);grid-template-areas:"header header" "sidebar main";height:100dvh;max-height:100dvh;overflow:hidden;transition:grid-template-columns var(--t-layout)}.shell-root.shell-root--collapsed{grid-template-columns:var(--sidebar-w-sm) 1fr}.shell-main{grid-area:main;min-height:0;overflow-y:auto;overflow-x:hidden;background:transparent}.shell-main__inner{position:relative;min-height:calc(100dvh - var(--header-h));padding:var(--content-pad)}.shell-main__inner--flush{padding:0;min-height:calc(100dvh - var(--header-h))}.shell-main__inner:not(.shell-main__inner--flush):before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:0;opacity:.35;pointer-events:none;background-image:linear-gradient(color-mix(in srgb,var(--border) 22%,transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in srgb,var(--border) 22%,transparent) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.12) 45%,transparent 78%);mask-image:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.12) 45%,transparent 78%)}.shell-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:calc(var(--z-sidebar) - 1);display:none}@media(max-width:768px){.shell-root{grid-template-columns:1fr;grid-template-areas:"header" "main"}.shell-root.shell-root--collapsed{grid-template-columns:1fr}.shell-sidebar-overlay{display:block}.shell-main__inner{padding:var(--sp-4)}.shell-main__inner--flush{padding:0}}.page-wrap{max-width:var(--content-max);margin:0 auto;padding:0}.section-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-4);letter-spacing:-.02em}.text-accent{color:var(--accent)}.ep-hero{position:relative;border-radius:var(--radius-xl);padding:var(--sp-6) var(--sp-8);background:linear-gradient(135deg,var(--bg-surface) 0%,color-mix(in srgb,var(--bg-surface) 88%,var(--mystic-subtle)) 100%);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.ep-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(125deg,color-mix(in srgb,var(--accent) 45%,transparent),transparent 40%,color-mix(in srgb,var(--mystic) 35%,transparent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.55}.ep-hero__inner{position:relative;z-index:1;display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:var(--sp-5)}.ep-hero__eyebrow{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:var(--sp-2)}.ep-hero__title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;margin-bottom:var(--sp-2)}.ep-hero__lead{font-size:var(--text-md);color:var(--text-secondary);max-width:36rem;line-height:var(--leading-relaxed)}.ep-panel{background:color-mix(in srgb,var(--bg-surface) 92%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:border-color var(--t-base),box-shadow var(--t-base),background-color var(--t-slow)}.ep-panel:hover{border-color:color-mix(in srgb,var(--border-strong) 70%,var(--accent-border));box-shadow:var(--shadow-sm)}.app-header[data-v-5d05b95e]{grid-area:header;position:sticky;top:0;z-index:var(--z-header);height:var(--header-h);display:flex;align-items:center;gap:var(--sp-3);padding:0 var(--sp-5);background:var(--header-bg);backdrop-filter:var(--header-backdrop);-webkit-backdrop-filter:var(--header-backdrop);border-bottom:1px solid var(--header-border)}.header-toggle[data-v-5d05b95e]{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}.header-toggle[data-v-5d05b95e]:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border)}.header-logo[data-v-5d05b95e]{display:flex;align-items:center;gap:7px;text-decoration:none;flex-shrink:0}.header-logo__mark[data-v-5d05b95e]{display:flex;align-items:center;justify-content:center;color:var(--accent);line-height:0;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--accent) 35%,transparent))}.header-logo__text[data-v-5d05b95e]{font-size:var(--text-md);font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.header-logo__accent[data-v-5d05b95e]{color:var(--accent)}.header-center[data-v-5d05b95e]{flex:1;display:flex;align-items:center;min-width:0}.header-breadcrumb[data-v-5d05b95e]{display:flex;align-items:center;gap:var(--sp-1);flex-wrap:wrap;min-width:0}.header-breadcrumb__item[data-v-5d05b95e]{font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:color var(--t-fast)}.header-breadcrumb__item[data-v-5d05b95e]:hover{color:var(--accent)}.header-breadcrumb__item--current[data-v-5d05b95e]{color:var(--text-primary);font-weight:500}.header-breadcrumb__sep[data-v-5d05b95e]{color:var(--text-muted);font-size:var(--text-sm)}.header-actions[data-v-5d05b95e]{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.header-session-badge[data-v-5d05b95e]{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);background:var(--accent-subtle);border:1px solid var(--accent-border);color:var(--accent);font-size:var(--text-xs);font-weight:600;text-decoration:none;transition:background var(--t-fast);max-width:200px}.header-session-badge span[data-v-5d05b95e]:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-session-badge[data-v-5d05b95e]:hover{background:var(--accent-subtle-hover)}.header-session-badge__dot[data-v-5d05b95e]{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);flex-shrink:0;animation:pulse-dot-5d05b95e 2s ease-in-out infinite}.header-icon-btn[data-v-5d05b95e]{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}.header-icon-btn[data-v-5d05b95e]:hover{background:var(--bg-elevated);color:var(--accent);border-color:var(--border)}@keyframes pulse-dot-5d05b95e{0%,to{opacity:1}50%{opacity:.5}}.app-sidebar[data-v-ea6e025d]{grid-area:sidebar;position:relative;align-self:stretch;min-height:0;height:100%;width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;overflow:hidden;transition:width var(--t-layout);z-index:var(--z-sidebar);flex-shrink:0}.app-sidebar--collapsed[data-v-ea6e025d]{width:var(--sidebar-w-sm)}.sidebar-nav[data-v-ea6e025d]{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-3) var(--sp-2);display:flex;flex-direction:column;gap:2px}.sidebar-group-label[data-v-ea6e025d]{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:var(--sp-3) var(--sp-2) var(--sp-1);white-space:nowrap;overflow:hidden}.sidebar-group-divider[data-v-ea6e025d]{height:1px;background:var(--border);margin:var(--sp-2) var(--sp-2)}.sidebar-item[data-v-ea6e025d]{position:relative;display:flex;align-items:center;gap:var(--sp-3);padding:8px var(--sp-2);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;white-space:nowrap;overflow:hidden;transition:background var(--t-fast),color var(--t-fast);border:none;background:transparent;width:100%;text-align:left;cursor:pointer;font:inherit}.sidebar-item[data-v-ea6e025d]:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-item--active[data-v-ea6e025d]{background:var(--sidebar-item-active);color:var(--sidebar-item-active-text)}.sidebar-item--active[data-v-ea6e025d]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;border-radius:0 var(--radius-full) var(--radius-full) 0;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--mystic) 70%,var(--accent)));box-shadow:0 0 12px color-mix(in srgb,var(--accent) 40%,transparent)}.sidebar-item__icon[data-v-ea6e025d]{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;color:var(--sidebar-icon-color);transition:color var(--t-fast)}.sidebar-item:hover .sidebar-item__icon[data-v-ea6e025d],.sidebar-item--active .sidebar-item__icon[data-v-ea6e025d]{color:var(--sidebar-icon-active)}.sidebar-item__label[data-v-ea6e025d]{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar-item__chev[data-v-ea6e025d]{margin-left:auto;opacity:.72;font-size:1rem;font-weight:600}.sidebar-session[data-v-ea6e025d]{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);margin:0 var(--sp-2) var(--sp-2);border-radius:var(--radius-md);background:var(--accent-subtle);border:1px solid var(--accent-border);flex-shrink:0}.sidebar-session__dot[data-v-ea6e025d]{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex-shrink:0;animation:pulse-dot-ea6e025d 2s ease-in-out infinite}.sidebar-session__info[data-v-ea6e025d]{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-session__name[data-v-ea6e025d]{font-size:var(--text-sm);font-weight:600;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-session__role[data-v-ea6e025d]{font-size:var(--text-xs);color:var(--text-muted)}.sidebar-session__btn[data-v-ea6e025d]{width:24px;height:24px;border-radius:var(--radius-sm);background:var(--accent-subtle-hover);border:1px solid var(--accent-border);color:var(--accent);display:flex;align-items:center;justify-content:center;text-decoration:none;flex-shrink:0;transition:background var(--t-fast)}.sidebar-session__btn[data-v-ea6e025d]:hover{background:var(--accent);color:var(--text-on-accent)}.sidebar-footer[data-v-ea6e025d]{padding:var(--sp-2);border-top:1px solid var(--border);flex-shrink:0;margin-top:auto}.sidebar-user[data-v-ea6e025d]{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-2);border-radius:var(--radius-md);overflow:hidden}.sidebar-user__avatar[data-v-ea6e025d]{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent-subtle);border:1.5px solid var(--accent-border);color:var(--accent);font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user__info[data-v-ea6e025d]{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-user__name[data-v-ea6e025d]{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user__role[data-v-ea6e025d]{font-size:var(--text-xs);color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user__settings[data-v-ea6e025d]{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);flex-shrink:0}.sidebar-user__settings[data-v-ea6e025d]:hover{background:var(--bg-elevated);color:var(--text-secondary);border-color:var(--border)}.sidebar-user__logout[data-v-ea6e025d]{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);flex-shrink:0}.sidebar-user__logout[data-v-ea6e025d]:hover{background:color-mix(in srgb,var(--error, #c0392b) 12%,transparent);color:var(--error, #e74c3c);border-color:color-mix(in srgb,var(--error, #c0392b) 30%,transparent)}.sidebar-guest[data-v-ea6e025d]{padding:var(--sp-2) var(--sp-2);display:flex;flex-direction:column;gap:var(--sp-2)}.sidebar-guest__btn[data-v-ea6e025d]{display:flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}.sidebar-guest__btn--primary[data-v-ea6e025d]{background:var(--accent);color:var(--text-on-accent, #fff);border:1px solid var(--accent)}.sidebar-guest__btn--primary[data-v-ea6e025d]:hover{filter:brightness(1.08)}.sidebar-guest__btn--secondary[data-v-ea6e025d]{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.sidebar-guest__btn--secondary[data-v-ea6e025d]:hover{border-color:var(--accent-border);color:var(--accent);background:var(--accent-subtle)}@media(max-width:768px){.app-sidebar[data-v-ea6e025d]{position:fixed;top:var(--header-h);left:0;height:calc(100dvh - var(--header-h));transform:translate(-100%);transition:transform var(--t-layout);box-shadow:var(--shadow-xl)}.app-sidebar--open[data-v-ea6e025d]{transform:translate(0);width:var(--sidebar-w)!important}}@keyframes pulse-dot-ea6e025d{0%,to{opacity:1}50%{opacity:.4}}
