: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}.account-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;border:1px solid rgba(239,68,68,.34);border-radius:18px;background:#ef44441f;box-shadow:0 16px 44px #00000047;padding:.75rem}.account-bar>div{display:grid;gap:.15rem;min-width:0}.account-bar strong,.account-bar span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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);min-height:38rem;isolation:isolate;background:radial-gradient(circle at 50% 38%,rgba(251,191,36,.12),transparent 21rem),radial-gradient(circle at 20% 76%,rgba(20,184,166,.12),transparent 24rem),linear-gradient(135deg,#050506,#151008 48%,#07080a);box-shadow:inset 0 0 0 1px #ffffff0d,inset 0 -110px 180px #0000005c,0 26px 90px #00000057}.play-map:before,.play-map:after,.board-atmosphere{content:"";position:absolute;inset:0;pointer-events:none}.play-map:before{z-index:1;background:linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:6.25rem 6.25rem;mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent)}.play-map:after{z-index:16;background:linear-gradient(to right,rgba(0,0,0,.58),transparent 16%,transparent 84%,rgba(0,0,0,.56)),linear-gradient(to bottom,rgba(0,0,0,.45),transparent 24%,transparent 78%,rgba(0,0,0,.52))}.board-atmosphere{z-index:2;background:radial-gradient(ellipse at 15% 18%,rgba(255,231,186,.16),transparent 19rem),radial-gradient(ellipse at 82% 28%,rgba(129,140,248,.13),transparent 18rem),radial-gradient(ellipse at 58% 86%,rgba(248,113,113,.09),transparent 21rem),repeating-linear-gradient(112deg,rgba(255,255,255,.03) 0 1px,transparent 1px 18px);mix-blend-mode:screen}.play-map.mode-target{box-shadow:inset 0 0 0 1px #f8717157,inset 0 -110px 180px #0000005c,0 0 42px #ef444429,0 26px 90px #00000057}.play-map.mode-measure{box-shadow:inset 0 0 0 1px #7dd3fc5c,inset 0 -110px 180px #0000005c,0 0 42px #0ea5e924,0 26px 90px #00000057}.play-map.mode-ping{box-shadow:inset 0 0 0 1px #fde68a61,inset 0 -110px 180px #0000005c,0 0 42px #f59e0b29,0 26px 90px #00000057}.play-map.mode-paint,.play-map.mode-feature,.play-map.mode-erase{box-shadow:inset 0 0 0 1px #a78bfa75,inset 0 -110px 180px #0000005c,0 0 46px #a78bfa29,0 26px 90px #00000057}.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 50% 50%,rgba(255,255,255,.18),transparent 5rem),radial-gradient(circle at 46% 52%,rgba(14,116,144,.22),transparent 17rem),radial-gradient(circle at 68% 34%,rgba(22,101,52,.2),transparent 20rem),radial-gradient(circle at 28% 70%,rgba(87,83,78,.2),transparent 18rem),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(71,45,20,.22) 2px,transparent 2px),linear-gradient(90deg,rgba(71,45,20,.2) 2px,transparent 2px),linear-gradient(rgba(255,255,255,.11) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(135deg,#d9bd7c,#ba8f52 52%,#8f6235);background-size:auto,auto,auto,auto,auto,auto,100px 100px,100px 100px,25px 25px,25px 25px,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:linear-gradient(90deg,rgba(80,48,20,.28) 0 2px,transparent 2px 4.1666666667%),linear-gradient(rgba(80,48,20,.26) 0 2px,transparent 2px 6.25%),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);background-size:4.1666666667% 100%,100% 6.25%,auto,auto,auto;mix-blend-mode:multiply}.map-layer.parchment:after{content:"";position:absolute;inset:1.25rem;z-index:1;pointer-events:none;border:1px solid rgba(63,38,17,.24);border-radius:18px;box-shadow:inset 0 0 0 1px #ffffff1f,inset 0 0 80px #ffffff14}.board-grid-glow{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(90deg,transparent calc(50% - 1px),rgba(255,255,255,.2) calc(50% - 1px) calc(50% + 1px),transparent calc(50% + 1px)),linear-gradient(transparent calc(50% - 1px),rgba(255,255,255,.18) calc(50% - 1px) calc(50% + 1px),transparent calc(50% + 1px));mix-blend-mode:overlay}.board-cell-layer{position:absolute;inset:0;z-index:2;pointer-events:none}.board-cell{position:absolute;display:grid;place-items:center;border:1px solid rgba(58,38,18,.08);background:transparent;color:#29180cbd;font-size:.72rem;font-weight:950;line-height:1;opacity:.88;padding:0;pointer-events:none;text-shadow:0 1px 0 rgba(255,255,255,.28)}.board-editing .board-cell{cursor:cell;pointer-events:auto}.board-editing .board-cell:hover{z-index:6;outline:3px solid rgba(99,102,241,.72);outline-offset:-3px}.board-cell span,.board-cell small{position:relative;z-index:2}.board-cell small{position:absolute;right:.2rem;bottom:.16rem;border-radius:999px;background:#030712b8;color:#f8fafc;padding:.1rem .22rem;font-size:.52rem}.terrain-difficult{background:repeating-linear-gradient(135deg,rgba(87,83,78,.22) 0 5px,transparent 5px 13px),#57534e29}.terrain-water{background:linear-gradient(135deg,#0e749070,#38bdf82e);color:#083344}.terrain-wall{background:repeating-linear-gradient(45deg,#29252494 0 7px,#78716c6b 7px 14px);color:#f5f5f4}.terrain-cover{background:linear-gradient(135deg,#92400e57,#d6b46c2e)}.terrain-hazard{background:repeating-conic-gradient(from 12deg,rgba(245,158,11,.34) 0 12deg,transparent 12deg 28deg),radial-gradient(circle,rgba(251,191,36,.26),transparent 72%);color:#7c2d12}.terrain-dark{background:#0c0a0952;color:#f8fafc;text-shadow:none}.terrain-elevated{background:radial-gradient(circle at 42% 38%,rgba(255,255,255,.22),transparent 42%),linear-gradient(135deg,#a8a29e52,#57534e2e)}.overlay-movement .board-cell.reachable{background:radial-gradient(circle,rgba(16,185,129,.34),transparent 68%),#10b98114;box-shadow:inset 0 0 0 2px #10b9813d}.overlay-threat .board-cell.threatened{background:radial-gradient(circle,rgba(239,68,68,.35),transparent 70%),#7f1d1d1f;box-shadow:inset 0 0 0 2px #ef444442}.overlay-sight .board-cell.line-cell{background:linear-gradient(135deg,#3b82f62e,#facc1529);box-shadow:inset 0 0 0 2px #60a5fa4d}.overlay-light .terrain-dark{box-shadow:inset 0 0 0 2px #0f172a70}.overlay-light .feature-light{filter:drop-shadow(0 0 28px color-mix(in srgb,var(--feature-color),transparent 24%))}.board-feature{position:absolute;z-index:3;display:grid;place-items:center;gap:.1rem;transform:translate(-50%,-50%) rotate(var(--feature-rotation));border:1px solid color-mix(in srgb,var(--feature-color),#1c1917 32%);background:radial-gradient(circle at 30% 28%,rgba(255,255,255,.22),transparent 36%),color-mix(in srgb,var(--feature-color),#f4e2b5 58%);color:color-mix(in srgb,#1c1917,var(--feature-color) 18%);box-shadow:0 12px 26px #3b230f2e,inset 0 0 24px #ffffff24;padding:.28rem;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none}.board-feature span{font-size:clamp(.8rem,1.4vw,1.45rem);line-height:1}.board-feature strong{max-width:100%;overflow:hidden;font-size:clamp(.52rem,.8vw,.78rem);font-weight:950;line-height:1;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.feature-road,.feature-river,.feature-wall{border-radius:999px}.feature-road{background:repeating-linear-gradient(90deg,rgba(84,52,28,.28) 0 18px,transparent 18px 36px),linear-gradient(180deg,color-mix(in srgb,var(--feature-color),#fff 14%),color-mix(in srgb,var(--feature-color),#3f220d 22%))}.feature-river{background:radial-gradient(circle at 20% 42%,rgba(255,255,255,.36),transparent 22%),repeating-linear-gradient(100deg,rgba(255,255,255,.2) 0 10px,transparent 10px 28px),linear-gradient(90deg,#0e74909e,#38bdf847,#0e749070);color:#082f49}.feature-rift{border-radius:48% 52% 40% 60%;background:radial-gradient(circle at 45% 48%,rgba(255,255,255,.34),transparent 1.4rem),radial-gradient(circle at 52% 44%,color-mix(in srgb,var(--feature-color),#fff 18%),transparent 2.2rem),radial-gradient(ellipse at 50% 50%,color-mix(in srgb,var(--feature-color),#450a0a 42%),transparent 70%);clip-path:polygon(48% 0,58% 21%,50% 38%,64% 56%,51% 73%,57% 100%,42% 78%,49% 59%,36% 41%,47% 22%);color:#fff7ed;filter:drop-shadow(0 0 28px color-mix(in srgb,var(--feature-color),transparent 52%))}.feature-ruins,.feature-cover{border-radius:10px;background:repeating-linear-gradient(90deg,rgba(68,64,60,.28) 0 10px,transparent 10px 22px),color-mix(in srgb,var(--feature-color),#d6d3d1 44%)}.feature-canopy,.feature-fog,.feature-light,.feature-hazard{border-radius:999px}.feature-canopy{background:radial-gradient(circle at 25% 35%,rgba(20,83,45,.68),transparent 38%),radial-gradient(circle at 55% 42%,rgba(22,101,52,.6),transparent 46%),radial-gradient(circle at 70% 68%,rgba(21,128,61,.42),transparent 44%);color:#ecfdf5}.feature-hazard{background:repeating-conic-gradient(from 12deg,color-mix(in srgb,var(--feature-color),transparent 70%) 0 12deg,transparent 12deg 28deg),radial-gradient(circle,color-mix(in srgb,var(--feature-color),transparent 58%),transparent 68%);color:#451a03}.feature-wall{border-radius:8px;background:repeating-linear-gradient(45deg,#44403cb3 0 10px,#a8a29e6b 10px 20px);color:#fafaf9}.feature-door{border-radius:8px;background:linear-gradient(90deg,#451a03bd,color-mix(in srgb,var(--feature-color),#78350f 38%),#451a03b8);color:#fef3c7}.feature-objective{border-radius:999px;background:conic-gradient(from 45deg,color-mix(in srgb,var(--feature-color),#fff 22%),color-mix(in srgb,var(--feature-color),#111827 8%),color-mix(in srgb,var(--feature-color),#fff 22%));color:#f8fafc}.feature-light{border-color:transparent;background:radial-gradient(circle,color-mix(in srgb,var(--feature-color),transparent 28%),transparent 68%);box-shadow:none;color:#78350f;mix-blend-mode:screen}.feature-fog{border-style:dashed;background:repeating-linear-gradient(8deg,rgba(255,255,255,.18) 0 12px,transparent 12px 26px),color-mix(in srgb,var(--feature-color),transparent 48%);color:#334155;opacity:.78}.terrain-road,.terrain-river,.terrain-rift,.terrain-ruins,.terrain-canopy,.terrain-hazard{position:absolute;z-index:2;pointer-events:none}.terrain-road{height:5.6rem;border:1px solid rgba(77,45,20,.28);border-radius:999px;background:repeating-linear-gradient(90deg,rgba(84,52,28,.24) 0 18px,transparent 18px 36px),linear-gradient(180deg,#744e2a6b,#54341c47);box-shadow:inset 0 0 28px #37221238}.road-main{left:3%;top:62%;width:84%;transform:rotate(-8deg)}.road-branch{left:38%;top:38%;width:42%;transform:rotate(31deg);opacity:.76}.terrain-river{left:-4%;top:18%;width:72%;height:8rem;border-radius:42% 58% 48% 52%;background:radial-gradient(circle at 20% 42%,rgba(255,255,255,.34),transparent 3rem),repeating-linear-gradient(100deg,rgba(255,255,255,.18) 0 10px,transparent 10px 28px),linear-gradient(90deg,#0e749094,#38bdf847,#0e749070);filter:drop-shadow(0 12px 24px rgba(8,47,73,.28));transform:rotate(17deg)}.terrain-rift{left:64%;top:23%;width:24rem;height:45rem;border-radius:48% 52% 40% 60%;background:radial-gradient(circle at 45% 48%,rgba(255,255,255,.34),transparent 1.4rem),radial-gradient(circle at 52% 44%,rgba(248,113,113,.82),transparent 2.2rem),radial-gradient(ellipse at 50% 50%,rgba(127,29,29,.72),transparent 16rem);clip-path:polygon(48% 0,58% 21%,50% 38%,64% 56%,51% 73%,57% 100%,42% 78%,49% 59%,36% 41%,47% 22%);filter:drop-shadow(0 0 28px rgba(239,68,68,.34));opacity:.86}.terrain-ruins{width:14rem;height:10rem;border:.55rem solid rgba(68,64,60,.38);border-left-style:dashed;border-bottom-style:dashed;border-radius:14px;background:linear-gradient(90deg,rgba(68,64,60,.28) 10%,transparent 10% 28%,rgba(68,64,60,.2) 28% 38%,transparent 38%),#78716c1f;box-shadow:inset 0 0 22px #29252438}.ruins-one{left:20%;top:46%;transform:rotate(11deg)}.ruins-two{left:78%;top:58%;transform:rotate(-15deg) scale(.82)}.terrain-canopy{width:22rem;height:15rem;border-radius:47% 53% 42% 58%;background:radial-gradient(circle at 25% 35%,rgba(20,83,45,.68),transparent 4rem),radial-gradient(circle at 55% 42%,rgba(22,101,52,.6),transparent 5rem),radial-gradient(circle at 70% 68%,rgba(21,128,61,.42),transparent 4rem);filter:drop-shadow(0 14px 22px rgba(20,83,45,.22));opacity:.82}.canopy-one{left:7%;top:71%}.canopy-two{left:69%;top:7%;transform:rotate(20deg) scale(.9)}.terrain-hazard{width:13rem;height:13rem;border:2px solid rgba(245,158,11,.42);border-radius:999px;background:repeating-conic-gradient(from 12deg,rgba(245,158,11,.2) 0 12deg,transparent 12deg 28deg),radial-gradient(circle,rgba(251,191,36,.24),transparent 68%);box-shadow:0 0 34px #f59e0b29}.hazard-one{left:53%;top:52%}.hazard-two{left:84%;top:32%;transform:scale(.78)}.map-hint{position:absolute;left:1rem;bottom:1rem;z-index:22;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}.board-hud{position:absolute;top:.8rem;left:.8rem;z-index:22;display:flex;flex-wrap:wrap;gap:.5rem;max-width:calc(100% - 6.5rem);pointer-events:none}.board-hud>div{min-width:7.3rem;border:1px solid rgba(255,255,255,.18);border-radius:14px;background:#06080cb8;box-shadow:0 14px 34px #0000004d;backdrop-filter:blur(12px);padding:.55rem .65rem}.board-hud small{display:block;color:#a1a1aa;font-size:.62rem;font-weight:950;text-transform:uppercase}.board-hud strong{display:block;max-width:13rem;overflow:hidden;color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;font-size:.84rem}.board-compass{position:absolute;top:.8rem;right:.8rem;z-index:22;display:grid;place-items:center;width:3.8rem;height:3.8rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:conic-gradient(from 45deg,rgba(255,255,255,.2),transparent 12%,rgba(255,255,255,.16) 25%,transparent 38%,rgba(255,255,255,.18) 50%,transparent 64%,rgba(255,255,255,.16) 75%,transparent 88%,rgba(255,255,255,.2)),#06080cb3;box-shadow:0 14px 34px #0000004d;backdrop-filter:blur(12px);pointer-events:none}.board-compass span{display:grid;place-items:center;width:1.9rem;height:1.9rem;border-radius:999px;background:#0000008a;color:#fde68a;font-size:.8rem;font-weight:950}.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:3.35rem;height:3.35rem;--hp: 100%;--hp-color: #22c55e;border:1px solid rgba(255,255,255,.34);border-radius:999px;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.28),transparent 34%),linear-gradient(145deg,#18181bf5,#030712f5);box-shadow:0 18px 32px #00000070,inset 0 0 0 2px #ffffff14;color:#f8fafc;font-size:1.5rem;transition:transform .16s ease,filter .16s ease,box-shadow .16s ease}.token:hover{transform:translate(-50%,-50%) scale(1.08)}.token-ring{position:absolute;inset:-.45rem;z-index:-1;border-radius:inherit;background:conic-gradient(var(--hp-color) var(--hp),rgba(15,23,42,.7) 0),radial-gradient(circle,transparent 56%,rgba(0,0,0,.72) 58%);box-shadow:0 0 24px color-mix(in srgb,var(--hp-color),transparent 64%)}.party-token{border-color:#93c5fdb3}.enemy-token{border-color:#fca5a5b3}.enemy-token .token-ring{--hp-color: #ef4444}.token.bloodied{--hp-color: #f59e0b}.token.critical-hp{--hp-color: #ef4444}.token-name{position:absolute;left:50%;top:calc(100% + .34rem);max-width:9rem;transform:translate(-50%);border:1px solid rgba(255,255,255,.16);border-radius:999px;background:#030712c7;color:#f8fafc;padding:.18rem .42rem;font-size:.58rem;font-weight:950;line-height:1;opacity:0;pointer-events:none;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;transition:opacity .14s ease}.token:hover .token-name,.token.current .token-name,.token.targeted .token-name{opacity:1}.token-badges{position:absolute;right:-.65rem;top:-.55rem;display:grid;gap:.12rem;pointer-events:none}.token-badges i{display:grid;place-items:center;min-width:1.15rem;height:1.15rem;border:1px solid rgba(255,255,255,.44);border-radius:999px;background:#030712e6;color:#fef3c7;font-size:.5rem;font-style:normal;font-weight:950;line-height:1}.token.current{border-color:#fde68a;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.34),transparent 34%),linear-gradient(145deg,#f59e0b,#92400e);box-shadow:0 0 0 7px #f59e0b33,0 0 40px #f59e0b70,0 18px 32px #00000070}.token.selected{border-color:#c7d2fe;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.34),transparent 34%),linear-gradient(145deg,#818cf8,#4338ca)}.token.targeted{border-color:#fca5a5;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.28),transparent 34%),linear-gradient(145deg,#ef4444,#7f1d1d);box-shadow:0 0 0 7px #ef444438,0 0 40px #ef444461,0 18px 32px #00000070}.token.down{opacity:.58;filter:grayscale(1);background:#27272ae6;border-color:#a1a1aa73;box-shadow:none}.token.stacked{width:2.85rem;height:2.85rem;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:linear-gradient(135deg,#78350ff5,#292524f0);color:#fef3c7;box-shadow:0 14px 30px #00000052,0 0 0 5px #fbbf241f,0 0 28px #fbbf242e;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}.board-fx{position:absolute;z-index:18;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.28);border-radius:999px;background:#030712c7;color:#f8fafc;padding:.3rem .55rem;font-size:.78rem;font-weight:950;pointer-events:none;animation:boardFxRise 1.4s ease-out forwards}.fx-hit{border-color:#10b9818f;background:#052e16d6;color:#d1fae5}.fx-miss{border-color:#ef44448f;background:#450a0ad6;color:#fee2e2}.fx-damage{border-color:#f87171a8;background:#7f1d1de0;color:#fecaca}.fx-heal{border-color:#34d399a8;background:#064e3be0;color:#d1fae5}.fx-move,.fx-ping{border-color:#fde68a9e;background:#451a03d6;color:#fef3c7}@keyframes boardFxRise{0%{opacity:0;transform:translate(-50%,-35%) scale(.86)}16%{opacity:1}to{opacity:0;transform:translate(-50%,-105%) scale(1.08)}}@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}.tactical-readout{position:absolute;right:5.2rem;top:.85rem;z-index:23;display:flex;max-width:min(30rem,100% - 16rem);align-items:center;gap:.55rem;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:#030712c2;color:#f8fafc;box-shadow:0 14px 34px #0000004d;backdrop-filter:blur(12px);padding:.48rem .68rem;pointer-events:none}.tactical-readout strong{font-size:.68rem;font-weight:950;text-transform:uppercase}.tactical-readout span{overflow:hidden;color:#d4d4d8;font-size:.74rem;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.tactical-readout.blocked{border-color:#ef44447a;background:#450a0acc}.tactical-readout.out-of-range{border-color:#f59e0b80;background:#451a03d1}.tactical-readout.cover{border-color:#facc1575;background:#422006d1}.tactical-readout.clear{border-color:#10b9816b;background:#052e16c7}.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%,31rem);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}.provider-grid{display:grid;gap:.65rem}.provider-button{display:flex;align-items:center;justify-content:center;gap:.7rem;width:100%;min-height:3rem;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:#ffffff14;color:var(--text);font:inherit;font-weight:900;cursor:pointer}.provider-button:hover:not(:disabled){border-color:#ffffff47;background:#ffffff21}.provider-button:disabled{opacity:.62;cursor:not-allowed}.provider-mark{display:grid;place-items:center;width:1.55rem;height:1.55rem;border-radius:999px;background:#f8fafc;color:#111827;font-size:.92rem;font-weight:950}.provider-mark.apple{background:#111827;color:#fff;font-size:1.05rem}.auth-divider{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem;color:var(--muted);font-size:.74rem;font-weight:950;text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";height:1px;background:var(--line)}.phone-login{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:.75rem}.phone-recaptcha{min-height:1px}@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))}}@media(max-width:560px){.account-bar{align-items:stretch;flex-direction:column}.phone-login{grid-template-columns:1fr}}
