:root{color-scheme:dark;--bg: #07070c;--panel: rgba(255, 255, 255, .075);--panel-strong: rgba(255, 255, 255, .12);--line: rgba(255, 255, 255, .12);--text: #f8fafc;--muted: #a1a1aa;--soft: #71717a;--primary: #6366f1;--primary-2: #d946ef;--danger: #ef4444;--warn: #f59e0b;--good: #10b981}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at 18% 8%,rgba(99,102,241,.28),transparent 32rem),radial-gradient(circle at 86% 18%,rgba(217,70,239,.16),transparent 28rem),radial-gradient(circle at 45% 92%,rgba(245,158,11,.12),transparent 28rem),var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#00000047;color:var(--text);outline:none;padding:.72rem .82rem}textarea{min-height:7rem;resize:vertical}label{display:grid;gap:.35rem;color:var(--muted);font-size:.76rem;font-weight:800}.help{position:relative;display:inline-grid;place-items:center;width:1.05rem;height:1.05rem;margin-left:.25rem;border:1px solid rgba(255,255,255,.26);border-radius:999px;color:#f8fafc;background:#6366f152;font-size:.68rem;font-weight:950;cursor:help;vertical-align:middle}.help:after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + .55rem);z-index:80;width:min(18rem,80vw);transform:translate(-50%);border:1px solid rgba(255,255,255,.16);border-radius:14px;background:#06060af5;color:#e5e7eb;box-shadow:0 18px 50px #00000073;padding:.7rem;font-size:.76rem;font-weight:750;line-height:1.35;opacity:0;pointer-events:none;transition:opacity .14s ease}.help:hover:after,.help:focus:after{opacity:1}.toolbar .help:after,.map-head .help:after,.map-card>.title-row .help:after{top:calc(100% + .55rem);right:0;bottom:auto;left:auto;transform:none}.map-card,.turn-console,.tools-panel{overflow:visible}.app-shell{display:grid;grid-template-columns:18rem minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:#00000075;backdrop-filter:blur(22px);padding:1rem}.brand{display:flex;gap:.8rem;align-items:center;border-radius:18px;background:var(--panel-strong);padding:.9rem}.brand-mark,.avatar{display:grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary-2));width:2.8rem;height:2.8rem;font-size:1.45rem}.nav{display:grid;gap:.5rem;margin-top:1.5rem}.nav button,.btn{border:1px solid transparent;border-radius:14px;background:#fff;color:#050505;min-height:2.7rem;padding:.6rem .9rem;font-size:.88rem;font-weight:900}.nav button{display:flex;align-items:center;gap:.7rem;justify-content:flex-start;background:transparent;color:#d4d4d8}.nav button.active,.nav button:hover{background:#fff;color:#050505}.btn.ghost{border-color:var(--line);background:#ffffff14;color:var(--text)}.btn.primary{background:var(--primary);color:#fff}.btn.danger{border-color:#ef444452;background:#ef444429;color:#fee2e2}.btn:disabled,button:disabled{cursor:not-allowed;opacity:.52;transform:none}.main{min-width:0;padding:1.5rem}.mobile-nav{display:none;gap:.5rem;overflow-x:auto;margin-bottom:1rem}.stack{display:grid;align-content:start;gap:1rem}.grid{display:grid;gap:1rem}.auto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:.85rem}.two-col{display:grid;grid-template-columns:minmax(0,1fr) 24rem;align-items:start;gap:1rem}.party-layout{grid-template-columns:22rem minmax(0,1fr)}.party-list{position:sticky;top:1rem;max-height:calc(100vh - 2rem);overflow:auto}.party-list .record{min-height:auto}.character-sheet{min-width:0}.character-sheet>.auto-grid{grid-template-columns:repeat(auto-fit,minmax(12rem,1fr))}.character-sheet>.card{background:#ffffff0e;box-shadow:none}.card,.hero{border:1px solid var(--line);border-radius:22px;background:var(--panel);box-shadow:0 18px 50px #00000038;backdrop-filter:blur(16px)}.card{padding:1rem}.hero{padding:1.4rem;background:linear-gradient(135deg,#6366f13d,#d946ef1a,#f59e0b1a)}.hero h1{margin:.9rem 0 0;max-width:58rem;font-size:clamp(2rem,6vw,4.5rem);line-height:.95;letter-spacing:0}.hero p,.muted{color:var(--muted)}.toolbar,.row,.title-row{display:flex;align-items:center;flex-wrap:wrap;gap:.6rem}.title-row{justify-content:space-between}.title-row h2,.title-row h3{margin:0}.pill{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;background:#ffffff17;color:#e4e4e7;padding:.28rem .7rem;font-size:.75rem;font-weight:850}.pill.good{border-color:#10b98157;background:#10b98129;color:#d1fae5}.pill.warn{border-color:#f59e0b5c;background:#f59e0b29;color:#fef3c7}.pill.bad{border-color:#ef444457;background:#ef444429;color:#fee2e2}.stat-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.8rem}.stat{border:1px solid var(--line);border-radius:18px;background:#00000038;padding:1rem}.stat small{color:var(--soft);font-size:.7rem;font-weight:900;text-transform:uppercase}.stat strong{display:block;margin-top:.4rem;font-size:1.8rem}.list{display:grid;gap:.7rem}.record{border:1px solid var(--line);border-radius:18px;background:#00000038;padding:.9rem;text-align:left;color:var(--text)}.record.active{border-color:#6366f1b8;background:#6366f12e}.clickable{cursor:pointer}.hp-bar{overflow:hidden;height:.48rem;border-radius:999px;background:#00000061}.hp-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ef4444,#10b981)}.board{position:relative;overflow:hidden;min-height:34rem;border:1px solid var(--line);border-radius:22px;background:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),radial-gradient(circle at 32% 32%,rgba(255,255,255,.08),transparent 18rem),linear-gradient(135deg,#1c1917,#111827,#3f1d09);background-size:4.1666666667% 6.25%,4.1666666667% 6.25%,auto,auto;touch-action:none}.map-card{overflow:hidden}.map-head{gap:1rem}.map-palette{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tool-chip{border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff14;color:#f8fafc;min-height:2.35rem;padding:.45rem .75rem;font-size:.78rem;font-weight:900}.tool-chip:hover{border-color:#d6b46cb8;background:#d6b46c29}.map-viewport{position:relative;overflow:hidden;height:min(68vh,46rem);min-height:32rem;margin-top:1rem;border:1px solid rgba(255,255,255,.16);border-radius:22px;background:radial-gradient(circle at 50% 45%,rgba(214,180,108,.08),transparent 30rem),linear-gradient(135deg,#07070c,#101014 55%,#08080c);box-shadow:inset 0 0 0 1px #ffffff0a,inset 0 -80px 160px #0000003d;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.map-viewport:active{cursor:grabbing}.play-map{height:min(72vh,48rem)}.map-layer{position:absolute;left:0;top:0;transform-origin:0 0;will-change:transform}.map-layer.parchment{border-radius:26px;border:1px solid rgba(214,180,108,.34);background:radial-gradient(circle at 18% 22%,rgba(89,57,21,.18),transparent 26rem),radial-gradient(circle at 78% 62%,rgba(74,36,17,.16),transparent 30rem),linear-gradient(rgba(88,64,34,.2) 1px,transparent 1px),linear-gradient(90deg,rgba(88,64,34,.18) 1px,transparent 1px),linear-gradient(135deg,#d9bd7c,#ba8f52 52%,#8f6235);background-size:auto,auto,100px 100px,100px 100px,auto;box-shadow:0 35px 120px #0000006b,inset 0 0 0 10px #4b2b1321,inset 0 0 80px #40200c5c}.map-layer.parchment:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.18),transparent 15rem),radial-gradient(circle at 86% 12%,rgba(58,28,12,.14),transparent 20rem),repeating-linear-gradient(8deg,rgba(255,255,255,.025) 0 1px,transparent 1px 13px);mix-blend-mode:multiply}.map-hint{position:absolute;left:1rem;bottom:1rem;z-index:20;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#0000008f;color:#d4d4d8;padding:.45rem .75rem;font-size:.75rem;font-weight:800;pointer-events:none}.zoom-control{display:inline-flex;align-items:center;gap:.45rem;min-height:2.7rem;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:#00000038;padding:.25rem .45rem}.zoom-control .btn{min-width:2.4rem;min-height:2.25rem;padding:.35rem .55rem}.zoom-slider{width:clamp(7rem,13vw,12rem);accent-color:#6366f1}.map-dock{display:grid;grid-template-columns:minmax(18rem,24rem) minmax(0,1fr);align-items:start;gap:1rem}.map-list{max-height:38rem;overflow:auto}.map-detail{min-width:0}.connection-panel,.combat-flow{display:grid;gap:.75rem;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:#ffffff0b;padding:1rem}.play-command-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(19rem,25rem);grid-template-areas:"turn initiative" "turn detail" "notes tools" "log log";align-items:start;gap:1rem}.turn-console{grid-area:turn;border-color:#6366f157;background:linear-gradient(135deg,#6366f124,#ffffff0e 32%,#f59e0b14),var(--panel)}.initiative-panel{grid-area:initiative}.detail-panel{grid-area:detail}.notes-panel{grid-area:notes}.tools-panel{grid-area:tools}.log-panel{grid-area:log}.turn-banner{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.turn-banner h2{margin:.45rem 0 .25rem;font-size:clamp(1.7rem,4vw,3rem)}.turn-steps{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.5rem}.step{border:1px solid rgba(255,255,255,.1);border-radius:14px;background:#00000038;color:var(--muted);padding:.7rem;font-size:.78rem;font-weight:900;text-align:center}.step.active{border-color:#6366f1b8;background:#6366f138;color:#fff}.step.done{border-color:#10b98173;background:#10b98124;color:#d1fae5}.turn-stage{display:grid;gap:.75rem;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:#0000002e;padding:1rem}.turn-stage h3{margin:0}.confirm-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.65rem;border:1px solid rgba(245,158,11,.34);border-radius:18px;background:#f59e0b1f;color:#fef3c7;padding:.8rem}.confirm-strip strong{margin-right:auto}.turn-economy{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.turn-economy>div{display:grid;gap:.25rem;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:#00000038;padding:.8rem}.turn-economy>div.done{border-color:#10b98173;background:#10b98121}.turn-economy span{color:var(--muted);font-size:.78rem}.target-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));gap:.65rem}.target-card{display:grid;gap:.25rem;justify-items:start;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:#00000047;color:#f8fafc;padding:.8rem;text-align:left}.target-card.active,.action-card.active{border-color:#6366f1b8;background:#6366f12e}.target-card span,.target-card small{color:var(--muted)}.vault-layout{display:grid;grid-template-columns:minmax(24rem,.9fr) minmax(28rem,1.15fr);gap:1rem;align-items:start}.inventory-browser,.inventory-editor{min-width:0}.inventory-grid{display:grid;gap:.75rem;max-height:64rem;overflow:auto;padding-right:.25rem}.inventory-card{display:grid;gap:.7rem;width:100%;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:#ffffff0b;color:var(--text);padding:1rem;text-align:left}.inventory-card:hover,.inventory-card.active{border-color:#6366f1b3;background:#6366f12e}.inventory-card p{margin:0;color:#d4d4d8;font-size:.86rem}.inventory-tags,.assignment-strip{display:flex;flex-wrap:wrap;gap:.45rem}.inventory-tags span,.assignment-strip span{border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#00000038;color:#e5e7eb;padding:.36rem .58rem;font-size:.74rem;font-weight:850}.assignment-strip{border:1px solid rgba(255,255,255,.1);border-radius:18px;background:#0000002e;padding:.75rem}.assignment-strip span{display:grid;gap:.15rem;min-width:9rem;border-radius:14px}.assignment-strip strong{color:var(--muted);font-size:.68rem;text-transform:uppercase}.section-label{border-top:1px solid rgba(255,255,255,.1);padding-top:1rem;color:#f8fafc;font-size:.82rem;font-weight:950;text-transform:uppercase}.roll-summary,.item-row{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.roll-summary span{border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff0f;padding:.45rem .7rem;color:var(--muted);font-size:.82rem}.manual-roll{display:flex;flex-wrap:wrap;align-items:end;gap:.75rem;border:1px solid rgba(99,102,241,.26);border-radius:16px;background:#6366f114;padding:.75rem}.manual-roll label,.inline-roll-card label{max-width:11rem}.manual-roll input,.inline-roll-card input{height:2.3rem}.item-actions{align-items:stretch}.inline-roll-card{display:grid;gap:.45rem;min-width:min(16rem,100%);border:1px solid rgba(255,255,255,.1);border-radius:16px;background:#ffffff0d;padding:.55rem}.result-card{border:1px solid rgba(255,255,255,.12);border-radius:16px;background:#ffffff0f;padding:.85rem;font-weight:900}.result-card.good{border-color:#10b98173;background:#10b98124;color:#d1fae5}.result-card.bad{border-color:#ef44446b;background:#ef444421;color:#fee2e2}.compact-combatant{display:grid;gap:.45rem}.connection-panel h3,.combat-flow h3{margin:0}.connection-group{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem}.connection-group>strong{width:100%;color:#e5e7eb;font-size:.78rem}.action-list{display:grid;gap:.65rem}.action-card{display:grid;gap:.25rem;justify-items:start;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:#00000047;color:#f8fafc;padding:.8rem;text-align:left}.action-card:hover:not(:disabled){border-color:#6366f1b8;background:#6366f129}.action-card span,.action-card small{color:var(--muted)}.inline-action{min-height:2.1rem;margin-top:.6rem;padding-block:.35rem}.map-object,.token,.ping,.measure-label{position:absolute;transform:translate(-50%,-50%)}.map-object{z-index:3;--object-color: #a78bfa;--object-size: 1;--object-rotation: 0deg;border:1px solid color-mix(in srgb,var(--object-color),#000 24%);color:#2a170e;display:grid;place-items:center;gap:.08rem;width:calc(6.7rem * var(--object-size));min-height:calc(3.2rem * var(--object-size));padding:calc(.35rem * var(--object-size)) calc(.52rem * var(--object-size));font-size:calc(.68rem * var(--object-size));font-weight:850;line-height:1.1;white-space:nowrap;background:color-mix(in srgb,var(--object-color),#f4e2b5 72%);box-shadow:0 8px 18px #3b230f2e;transform:translate(-50%,-50%) rotate(var(--object-rotation));-webkit-user-select:none;user-select:none}button.map-object{cursor:grab}button.map-object:active{cursor:grabbing}.map-object.active{outline:3px solid rgba(99,102,241,.72);outline-offset:3px;z-index:9}.object-glyph{font-size:calc(1.25rem * var(--object-size));line-height:1}.map-object strong,.map-object small{max-width:100%;overflow:hidden;text-overflow:ellipsis}.map-object small{opacity:.7;font-size:.72em}.shape-pin{width:calc(4.8rem * var(--object-size));min-height:calc(4.8rem * var(--object-size));border-radius:999px 999px 999px 8px;transform:translate(-50%,-64%) rotate(calc(45deg + var(--object-rotation)))}.shape-pin>*{transform:rotate(-45deg)}.shape-label{width:auto;min-width:calc(7rem * var(--object-size));min-height:auto;border-color:transparent;background:transparent;box-shadow:none;color:color-mix(in srgb,var(--object-color),#2a170e 30%);font-family:Georgia,Times New Roman,serif;font-size:calc(1.25rem * var(--object-size));text-shadow:0 1px 0 rgba(255,255,255,.35)}.shape-building,.shape-house{border-radius:10px}.shape-house{clip-path:polygon(50% 0,100% 38%,100% 100%,0 100%,0 38%);padding-top:calc(.9rem * var(--object-size))}.shape-bridge{width:calc(9rem * var(--object-size));min-height:calc(2.2rem * var(--object-size));border-radius:999px;background:repeating-linear-gradient(90deg,rgba(55,33,15,.28) 0 10px,transparent 10px 20px),color-mix(in srgb,var(--object-color),#f4e2b5 62%)}.shape-river,.shape-road,.shape-wall{width:calc(16rem * var(--object-size));min-height:calc(2.4rem * var(--object-size));border-radius:999px;border-style:dashed}.shape-river{color:#082f49;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.36),transparent 1.5rem),color-mix(in srgb,var(--object-color),#bae6fd 52%)}.shape-road{background:repeating-linear-gradient(90deg,rgba(58,36,16,.4) 0 12px,transparent 12px 28px),color-mix(in srgb,var(--object-color),#fde68a 58%)}.shape-lake{width:calc(10rem * var(--object-size));min-height:calc(7rem * var(--object-size));border-radius:53% 47% 57% 43%/48% 58% 42% 52%;color:#082f49}.shape-forest{width:calc(8rem * var(--object-size));min-height:calc(6rem * var(--object-size));border-radius:46% 54% 48% 52%}.shape-mountain{clip-path:polygon(50% 0,100% 100%,0 100%);min-height:calc(6.2rem * var(--object-size));padding-top:calc(2.2rem * var(--object-size))}.shape-boat,.shape-cart,.shape-horse,.shape-car{width:calc(5.6rem * var(--object-size));min-height:calc(3.8rem * var(--object-size));border-radius:18px}.token{z-index:5;display:grid;place-items:center;width:3rem;height:3rem;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:#000000d1;box-shadow:0 16px 30px #00000061;font-size:1.45rem}.token.current{border-color:#fde68a;background:#d97706;box-shadow:0 0 0 6px #f59e0b38}.token.selected{border-color:#c7d2fe;background:var(--primary)}.token.targeted{border-color:#fca5a5;background:#991b1b;box-shadow:0 0 0 7px #ef444438}.token.down{opacity:.58;filter:grayscale(1);background:#27272ae6;border-color:#a1a1aa73;box-shadow:none}.token.stacked{width:2.65rem;height:2.65rem;border-width:2px;font-size:1.24rem;box-shadow:0 14px 28px #0000006b,0 0 0 4px #ffffff14}.token.stacked:after{content:attr(data-stack);position:absolute;right:-.35rem;bottom:-.35rem;display:grid;place-items:center;min-width:1.25rem;height:1.25rem;border:1px solid rgba(255,255,255,.42);border-radius:999px;background:#0f172af5;color:#f8fafc;font-size:.52rem;font-weight:950}.loot-token{z-index:6;display:inline-flex;align-items:center;gap:.3rem;max-width:9rem;transform:translate(-50%,-50%);border:1px solid rgba(251,191,36,.6);border-radius:999px;background:#292524eb;color:#fef3c7;box-shadow:0 14px 30px #00000052,0 0 0 5px #fbbf241f;padding:.36rem .6rem;font-size:.72rem;font-weight:950}.loot-token span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.target-line,.movement-line{position:absolute;inset:0;z-index:4;pointer-events:none}.movement-line line{stroke:#10b981f5;stroke-width:5;stroke-linecap:round;stroke-dasharray:14 10;filter:drop-shadow(0 0 12px rgba(16,185,129,.48))}.movement-line.warn line{stroke:#f59e0bfa;filter:drop-shadow(0 0 14px rgba(245,158,11,.5))}.movement-anchor{position:absolute;z-index:8;min-width:3.7rem;transform:translate(-50%,-50%);border:1px solid rgba(16,185,129,.5);border-radius:999px;background:#052e16e0;color:#d1fae5;padding:.34rem .55rem;font-size:.68rem;font-weight:950;text-align:center;pointer-events:none;box-shadow:0 0 0 5px #10b9811f}.movement-anchor.origin{background:#000000ad;color:#f8fafc}.movement-anchor.warn{border-color:#f59e0ba6;background:#451a03e6;color:#fef3c7;box-shadow:0 0 0 5px #f59e0b24}.ping{z-index:7;width:4.4rem;height:4.4rem;border:3px solid #fef3c7;border-radius:999px;animation:pingFade 1.8s ease-out forwards;pointer-events:none}@keyframes pingFade{0%{opacity:1;transform:translate(-50%,-50%) scale(.35)}to{opacity:0;transform:translate(-50%,-50%) scale(1.3)}}.measure-label{z-index:8;border:1px solid var(--line);border-radius:999px;background:#000000b8;padding:.3rem .6rem;font-size:.75rem;font-weight:900}.session-log{max-height:15rem;overflow:auto}.empty{border:1px dashed var(--line);border-radius:18px;padding:1.2rem;color:var(--muted);text-align:center}.auth-page{display:grid;place-items:center;min-height:100vh;padding:1rem}.auth-card{width:min(100%,28rem);border:1px solid var(--line);border-radius:22px;background:var(--panel);box-shadow:0 22px 70px #0000005c;backdrop-filter:blur(18px);padding:1.2rem}.auth-card h1{margin:0 0 .4rem;font-size:2rem;letter-spacing:0}@media(max-width:1050px){.app-shell{display:block}.sidebar{display:none}.mobile-nav{display:flex}.two-col,.map-dock,.party-layout,.vault-layout{grid-template-columns:1fr}.play-command-grid{grid-template-columns:1fr;grid-template-areas:"turn" "initiative" "detail" "notes" "tools" "log"}.turn-banner{display:grid}.turn-steps,.turn-economy{grid-template-columns:1fr}.party-list{position:static;max-height:none}.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
