@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@24,500,1,0&display=swap";:root{--bg:#faf8f5;--bg-elevated:#fff;--bg-elevated-2:#f4f1ea;--bg-hover:#efece3;--border:#e8e4db;--border-strong:#d0cbc0;--border-active:#0d9488;--text:#1e1a16;--text-secondary:#44403c;--text-muted:#78716c;--text-disabled:#a8a29e;--gold:#0d9488;--gold-bright:#14b8a6;--gold-dim:#115e59;--gold-glow:#0d948838;--red:#e11d48;--red-bright:#f43f5e;--red-dim:#9f1239;--blue:#2563eb;--blue-bright:#3b82f6;--blue-dim:#1e40af;--success:#16a34a;--warning:#ca8a04;--danger:#dc2626;--shadow-sm:0 1px 2px #1e1a160f;--shadow-md:0 4px 16px #1e1a1614;--shadow-lg:0 12px 40px #1e1a161f;--shadow-glow:0 0 14px var(--gold-glow);--font-display:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body:"Inter", -apple-system, "Segoe UI", sans-serif;--font-flavour:"Inter", -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Menlo", "Monaco", "Consolas", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background-color:var(--bg);color:var(--text);overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle,#1e1a1609 1px,#0000 1px);background-size:24px 24px;font-size:14px;line-height:1.5}button{cursor:pointer;appearance:none;background:0 0;border:none;font-family:inherit}.desktop{display:none}.mobile{display:flex}@media (width>=768px){.desktop{display:flex!important}.mobile{display:none!important}}@media (width<=639px){.hide-small{display:none!important}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-elevated-2)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.cr1-table-scroll{border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm);border-radius:8px;overflow-x:auto}.cr1-table{border-collapse:collapse;font-variant-numeric:tabular-nums;font-size:12px;font-family:var(--font-mono)}.cr1-table th,.cr1-table td{border:1px solid var(--border);text-align:center;vertical-align:middle}.cr1-corner{z-index:3;background:var(--bg-elevated-2);font-family:var(--font-display);color:var(--text-muted);text-align:left;white-space:nowrap;padding:8px 10px;font-size:11px;font-weight:600;position:sticky;top:0;left:0}.cr1-col-head{z-index:2;background:var(--bg-elevated-2);min-width:36px;height:110px;padding:8px 6px 6px;position:sticky;top:0}.cr1-col-head img{border:2px solid var(--blue);object-fit:cover;background:var(--bg-elevated);border-radius:50%;width:28px;height:28px;margin:0 auto 4px;display:block}.cr1-col-label{writing-mode:vertical-rl;font-size:10px;font-family:var(--font-body);color:var(--text-secondary);white-space:nowrap;height:70px;margin:0 auto;display:block;transform:rotate(180deg)}.cr1-row-head{z-index:2;background:var(--bg-elevated-2);text-align:left;white-space:nowrap;font-family:var(--font-body);color:var(--text);align-items:center;gap:6px;padding:4px 8px;font-size:11px;font-weight:500;display:flex;position:sticky;left:0}.cr1-row-head img{border:2px solid var(--red);object-fit:cover;background:var(--bg-elevated);border-radius:50%;flex-shrink:0;width:24px;height:24px}.cr1-cell{cursor:pointer;color:#1e1a16;outline:0 solid #0000;width:36px;height:36px;padding:0;font-size:11px;font-weight:600;transition:outline-color .1s,transform .1s}.cr1-cell:hover{outline:2px solid var(--gold);outline-offset:-2px;z-index:1;position:relative;transform:scale(1.05)}.cr1-mirror{cursor:pointer;color:var(--text-muted);background:repeating-linear-gradient(45deg, var(--bg-elevated-2) 0px, var(--bg-elevated-2) 4px, var(--bg-hover) 4px, var(--bg-hover) 8px)!important}.cr1-summary-col{font-family:var(--font-display);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-left:2px solid var(--border-strong);padding:8px 10px;font-size:11px;background:var(--bg-elevated-2)!important}.cr1-summary-cell{color:var(--text);border-left:2px solid var(--border-strong);cursor:default;font-weight:700;background:var(--bg-elevated-2)!important}.cr1-summary-cell:hover{outline:0 solid #0000;transform:none}.blog-page{background:var(--bg);min-height:100vh;color:var(--text);padding:24px 32px 48px}.blog-header{max-width:820px;margin:0 auto 24px}.blog-back{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:12px;font-size:13px;text-decoration:none;display:inline-flex}.blog-back:hover{color:var(--gold)}.blog-header h1{font-family:var(--font-display);color:var(--text);margin:4px 0 8px;font-size:28px;font-weight:700;line-height:1.2}.blog-sub{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.blog-main{max-width:820px;margin:0 auto}.blog-empty{color:var(--text-muted);text-align:center;padding:48px 0}.blog-card-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.blog-card-meta time{font-variant-numeric:tabular-nums}.blog-tag{background:var(--bg-elevated-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:10px;padding:1px 8px;font-size:11px}.blog-byline{color:var(--text-secondary);font-size:12px}.blog-signoff{border-top:1px solid var(--border);color:var(--text-secondary);margin-top:40px;padding-top:20px}.blog-signoff-name{font-family:var(--font-display);color:var(--text);margin-bottom:2px;font-size:15px;font-weight:700}.blog-signoff-bio{font-size:13px}.blog-index-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.blog-index-card a{background:var(--bg-elevated);border:1px solid var(--border);color:inherit;border-radius:8px;padding:16px 20px;text-decoration:none;transition:border-color .15s,transform .15s,box-shadow .15s;display:block}.blog-index-card a:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.blog-index-card h2{font-family:var(--font-display);color:var(--text);margin:0 0 6px;font-size:18px;font-weight:700;line-height:1.3}.blog-index-card p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.blog-sticky-bar{z-index:50;background:var(--bg);border-bottom:1px solid var(--border);margin:-24px -32px 16px;padding:12px 32px;position:sticky;top:0;box-shadow:0 1px 8px -4px #0006}.blog-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;max-width:820px;margin:0 auto;display:flex}.blog-header-row .blog-back{margin-bottom:0}.blog-app-link{background:var(--gold);color:#1a1410;box-shadow:var(--shadow-sm);border-radius:6px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:filter .15s,transform .15s,box-shadow .15s;display:inline-flex}.blog-app-link:hover{filter:brightness(1.08);transform:translateY(-1px)}.blog-rss-link{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:6px;align-items:center;gap:6px;margin-right:auto;padding:6px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s;display:inline-flex}.blog-rss-link:hover{color:var(--gold);border-color:var(--gold)}.blog-app-cta{background:var(--bg-elevated);border:1px solid var(--gold);border-radius:10px;flex-wrap:wrap;align-items:center;gap:16px;margin:40px 0 24px;padding:18px 22px;display:flex}.blog-app-cta-text{flex-direction:column;flex:1;min-width:220px;display:flex}.blog-app-cta-text strong{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:17px}.blog-app-cta-text span{color:var(--text-secondary);font-size:14px;line-height:1.45}.blog-app-cta-button{background:var(--gold);color:#1a1410;white-space:nowrap;box-shadow:var(--shadow-sm);border-radius:6px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:700;text-decoration:none;transition:filter .15s,transform .15s;display:inline-flex}.blog-app-cta-button:hover{filter:brightness(1.08);transform:translateY(-1px)}.blog-signoff-name a{color:var(--text);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .15s,color .15s}.blog-signoff-name a:hover{color:var(--gold);border-bottom-color:var(--gold)}.blog-byline a{color:inherit;text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border)}.blog-byline a:hover{color:var(--gold)}.blog-author-posts-heading{font-family:var(--font-display);color:var(--text);margin:32px 0 12px;font-size:18px;font-weight:700}.blog-author-profile{flex-wrap:wrap;align-items:flex-start;gap:24px;margin:24px 0 8px;display:flex}.blog-author-photo{object-fit:cover;border:2px solid var(--gold);width:160px;height:160px;box-shadow:var(--shadow-sm);border-radius:50%;flex-shrink:0}.blog-author-text{min-width:240px;color:var(--text);flex:1;font-size:15px;line-height:1.6}.blog-author-text p{margin:0 0 14px}.blog-author-link-row a{color:var(--gold);border-bottom:1px solid #0000;font-size:14px;text-decoration:none;transition:border-color .15s}.blog-author-link-row a:hover{border-bottom-color:var(--gold)}.blog-post{color:var(--text);font-size:15px;line-height:1.6}.blog-post .blog-lede{color:var(--text-secondary);border-left:3px solid var(--gold);margin:0 0 28px;padding-left:16px;font-size:17px}.blog-post h2{font-family:var(--font-display);color:var(--text);margin:36px 0 12px;font-size:22px;font-weight:700}.blog-post h3{font-family:var(--font-display);color:var(--text);margin:24px 0 8px;font-size:17px;font-weight:600}.blog-post p{margin:0 0 14px}.blog-post ul{margin:0 0 18px;padding-left:22px}.blog-post li{margin-bottom:8px}.blog-post b{color:var(--text);font-weight:600}.blog-post .cr1-table-scroll{margin:24px 0 32px}.cap-page{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font-body)}.cap-hero{background:linear-gradient(180deg, var(--bg-elevated) 0%, var(--bg) 100%);border-bottom:1px solid var(--border);padding:40px 24px 56px}.cap-hero-inner{text-align:center;max-width:720px;margin:0 auto}.cap-back{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:28px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.cap-back:hover{color:var(--gold)}.cap-logo{font-family:var(--font-display);color:var(--gold);letter-spacing:-.01em;align-items:center;gap:10px;margin-bottom:20px;font-size:16px;font-weight:700;display:inline-flex}.cap-logo svg{color:var(--gold)}.cap-hero h1{font-family:var(--font-display);letter-spacing:-.025em;color:var(--text);margin:0 0 16px;font-size:clamp(28px,5vw,44px);font-weight:800;line-height:1.15}.cap-hero-sub{color:var(--text-secondary);max-width:520px;margin:0 auto 28px;font-size:17px;line-height:1.6}.cap-hero-actions{justify-content:center;gap:12px;display:flex}.cap-cta{border-radius:10px;padding:12px 28px;font-size:15px;font-weight:700;text-decoration:none}.cap-section{padding:56px 24px}.cap-section-alt{background:var(--bg-elevated)}.cap-section-inner{max-width:900px;margin:0 auto}.cap-section h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);text-align:center;margin:0 0 12px;font-size:clamp(22px,4vw,32px);font-weight:800}.cap-section-desc{color:var(--text-secondary);text-align:center;max-width:640px;margin:0 auto 32px;font-size:16px;line-height:1.6}.cap-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px;display:grid}.cap-grid-2{grid-template-columns:repeat(2,1fr);gap:14px;margin-top:20px;display:grid}@media (width<=700px){.cap-grid-3,.cap-grid-2{grid-template-columns:1fr}}.cap-card{background:var(--bg-elevated);border:1px solid var(--border);text-align:center;border-radius:14px;padding:28px 22px;transition:border-color .15s,transform .1s}.cap-card:hover{border-color:var(--gold);transform:translateY(-2px)}.cap-card-icon{width:48px;height:48px;color:var(--gold);margin:0 auto 16px}.cap-card-icon svg{width:48px;height:48px}.cap-card h3{font-family:var(--font-display);color:var(--text);margin:0 0 10px;font-size:17px;font-weight:700}.cap-card p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.55}.cap-card-soon{opacity:.8;border-style:dashed}.cap-card-soon:hover{border-color:var(--text-muted)}.cap-feature{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:18px 18px 16px}.cap-feature-badge{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;color:var(--gold);background:#0d94881a;border-radius:6px;margin-bottom:10px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.cap-feature p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.cap-questions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px;display:flex}.cap-question{font-family:var(--font-display);color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:10px 20px;font-size:15px;font-style:italic;font-weight:600;transition:border-color .12s}.cap-question:hover{border-color:var(--gold)}.cap-checklist{grid-template-columns:repeat(2,1fr);gap:10px 20px;margin-top:24px;display:grid}@media (width<=600px){.cap-checklist{grid-template-columns:1fr}}.cap-check{color:var(--text-secondary);align-items:flex-start;gap:10px;padding:8px 0;font-size:14px;line-height:1.5;display:flex}.cap-check-icon{width:20px;height:20px;color:var(--gold);background:#0d94881f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:12px;font-weight:700;display:flex}.cap-footer{text-align:center;border-top:1px solid var(--border);padding:48px 24px 56px}.cap-footer-text{color:var(--text-muted);margin-top:20px;font-size:14px;line-height:1.6}.cap-footer-link{color:var(--gold);font-weight:600;text-decoration:none}.cap-footer-link:hover{text-decoration:underline}.maps-editor{color:#1a1a1a;background:#faf8f5;min-height:100vh;padding:24px;font-family:-apple-system,BlinkMacSystemFont,Inter,sans-serif}.me-header{margin-bottom:20px}.me-header h1{margin:0 0 4px;font-size:24px;font-weight:800}.me-sub{color:#555;margin:0 0 14px;font-size:13px;line-height:1.5}.me-sub kbd{background:#fff;border:1px solid #c9c4b4;border-radius:4px;padding:1px 6px;font-family:SF Mono,Menlo,monospace;font-size:11px;display:inline-block;box-shadow:0 1px #00000014}.me-controls{flex-wrap:wrap;align-items:center;gap:10px;font-size:13px;display:flex}.me-controls select,.me-controls button{cursor:pointer;background:#fff;border:1px solid #c9c4b4;border-radius:6px;padding:6px 12px;font-size:13px}.me-controls button:hover{background:#f0ede4}.me-stats{color:#555;font-variant-numeric:tabular-nums;margin-left:auto}.me-main{grid-template-columns:1fr 340px;align-items:start;gap:20px;display:grid}@media (width<=1100px){.me-main{grid-template-columns:1fr}}.me-canvas{aspect-ratio:1;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #d0ccc0;border-radius:10px;width:100%;max-width:800px;position:relative;overflow:hidden}.me-map-image{object-fit:cover;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.me-grid{grid-template-columns:repeat(var(--gs), 1fr);grid-template-rows:repeat(var(--gs), 1fr);display:grid;position:absolute;inset:0}.me-cell{cursor:pointer;border:1px solid #1e1a1626;transition:outline-color 50ms}.me-cell:hover{outline-offset:-2px;z-index:1;outline:2px solid #0d9488}.me-cell-open{background:0 0}.me-cell-wall{background:#140f0a73;box-shadow:inset 0 0 0 1px #00000059}.me-cell-chasm{background:repeating-linear-gradient(135deg,#5a140f8c 0 1.5px,#0000 1.5px 6px),#911e1e47}.me-sidebar{background:#fff;border:1px solid #d0ccc0;border-radius:10px;padding:14px 16px}.me-sidebar h3{margin:0 0 6px;font-size:14px;font-weight:700}.me-help{color:#555;margin:0 0 10px;font-size:12px;line-height:1.5}.me-help code{background:#f1ede3;border-radius:3px;padding:1px 5px;font-size:11px}.me-mask{resize:vertical;white-space:pre;background:#fafaf5;border:1px solid #d0ccc0;border-radius:6px;width:100%;min-height:320px;padding:10px;font-family:SF Mono,Menlo,monospace;font-size:11px;line-height:1.2;overflow-x:auto}.me-actions{grid-template-columns:1.4fr 1fr;gap:8px;margin-top:8px;display:grid}.me-copy,.me-save{cursor:pointer;color:#fff;border:0;border-radius:6px;width:100%;padding:8px 12px;font-size:13px;font-weight:600;display:block}.me-copy{background:#0d9488}.me-copy:hover{background:#0b7d72}.me-save{background:#e11d48;box-shadow:0 1px 3px #e11d484d}.me-save:hover:not(:disabled){background:#be123c}.me-save:disabled{opacity:.6;cursor:default}.me-save-error{color:#991b1b;background:#fee2e2;border-radius:6px;margin-top:8px;padding:8px 10px;font-size:12px;line-height:1.4}.me-legend{color:#555;margin-top:14px;font-size:11px;line-height:1.8}.me-swatch{vertical-align:middle;border:1px solid #999;border-radius:2px;width:14px;height:14px;margin-right:6px;display:inline-block}.me-swatch-wall{background:#140f0a8c}.me-swatch-chasm{background:repeating-linear-gradient(135deg,#5a140fb3 0 1.5px,#0000 1.5px 4px),#911e1e66}.me-swatch-open{background:#fff}.controls{padding:8px 12px;padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right));padding-top:max(8px, env(safe-area-inset-top));background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:6px;min-height:52px;display:flex}.controls .logo{font-family:var(--font-display);color:var(--gold);letter-spacing:1px;align-items:center;gap:6px;margin-right:10px;font-size:18px;font-weight:700;transition:text-shadow .2s;display:flex}.controls .logo:hover{text-shadow:0 0 12px var(--gold-glow)}.controls .logo-mark{flex-shrink:0;display:block}.cap-link{background:var(--bg-elevated-2);border:1px solid var(--border);width:20px;height:20px;color:var(--text-muted);font-family:var(--font-body);border-radius:50%;justify-content:center;align-items:center;margin-left:4px;font-size:11px;font-weight:700;text-decoration:none;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.cap-link:hover{background:var(--gold);color:#fff;border-color:var(--gold)}.blog-link{background:var(--gold);color:#fff;height:20px;font-family:var(--font-body);letter-spacing:.02em;border-radius:10px;align-items:center;gap:4px;margin-left:4px;padding:0 8px;font-size:11px;font-weight:600;text-decoration:none;transition:background .15s,transform .15s;display:inline-flex}.blog-link:hover{background:var(--gold-bright);transform:translateY(-1px)}.twitter-link{background:var(--bg-elevated-2);border:1px solid var(--border);width:20px;height:20px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;margin-left:4px;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.twitter-link:hover{color:#fff;background:#1d9bf0;border-color:#1d9bf0}.btn{height:38px;min-height:38px;font-size:13px;font-weight:600;font-family:var(--font-body);letter-spacing:-.005em;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm);border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;line-height:1;transition:background .15s,box-shadow .15s,border-color .15s,transform 80ms;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--text);color:#fff;border-color:var(--text);box-shadow:0 2px 8px #1e1a1626}.btn-primary:hover{background:#2a2520;border-color:#2a2520;box-shadow:0 4px 14px #1e1a1633}.btn-primary:disabled{background:var(--border-strong);border-color:var(--border-strong);color:var(--text-disabled);cursor:default;box-shadow:none;transform:none}.btn-encounter{align-items:center;gap:5px;display:inline-flex}.btn-start{color:#1e1a16;box-shadow:0 2px 8px var(--gold-glow);background:linear-gradient(135deg,#d4a574 0%,#c6914a 100%);border:1px solid #c6914a;font-weight:700}.btn-start:hover:not(:disabled){box-shadow:0 4px 16px var(--gold-glow);background:linear-gradient(135deg,#deb587 0%,#d4a060 100%);border-color:#c6914a}.btn-start:disabled{background:var(--border-strong);color:var(--text-disabled);border-color:var(--border-strong);box-shadow:none;cursor:default;transform:none}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-secondary:disabled{color:var(--text-disabled);border-color:var(--border);cursor:default;transform:none}.btn-ghost{color:var(--text-secondary);box-shadow:none;background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-hover);color:var(--text);border-color:#0000}.btn-destructive{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.btn-destructive:hover{color:var(--danger);border-color:var(--danger);background:#dc26260f}.btn-sm{border-radius:6px;height:30px;min-height:30px;padding:5px 11px;font-size:11px}@media (width<=767px){.btn{height:auto;min-height:44px}.btn-sm{min-height:32px}.controls-fade-wrap{position:relative}.controls-fade-wrap:after{content:"";pointer-events:none;background:linear-gradient(to right, #fff0, var(--bg-elevated));z-index:1;width:32px;position:absolute;top:0;bottom:0;right:0}.controls{overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;padding:6px 10px;padding-left:max(10px, env(safe-area-inset-left));padding-right:max(10px, env(safe-area-inset-right));padding-top:max(6px, env(safe-area-inset-top));scrollbar-width:none;flex-wrap:nowrap;gap:6px;min-height:56px;overflow:auto hidden}.controls::-webkit-scrollbar{display:none}.controls>*{z-index:2;flex-shrink:0;position:relative}.controls .logo{margin-right:0}.controls .logo-text,.controls .cap-link,.controls .twitter-link{display:none}.controls .btn,.controls .btn-encounter{gap:5px;padding:6px 12px;font-size:12px}}.controls .logo{order:-10}.controls .btn-start{order:-3}.controls .btn-instant{order:-2}.controls .mc-launcher{order:-1}.controls .btn-scenarios{order:0}.controls .btn-encounter{order:1}.controls .btn-parties{order:2}.controls .btn-homebrew{order:3}.controls .btn-maps{order:4}.controls .btn-share{order:5}.controls .btn-clear{order:6}.controls .status{display:none}.speed-control{background:var(--bg-elevated-2);border-radius:10px;align-items:center;gap:4px;padding:4px;display:flex}.speed-seg{color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;border-radius:7px;align-items:center;min-height:30px;padding:7px 12px;transition:background .15s,color .15s,box-shadow .15s;display:flex}.speed-seg:hover:not(.active){color:var(--text)}.speed-seg.active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.status{font-variant-numeric:tabular-nums;align-items:center;gap:8px;margin-left:auto;font-size:13px;display:flex}.dot{border-radius:50%;width:10px;height:10px;display:inline-block}.dot-red{background:var(--red)}.dot-blue{background:var(--blue)}.count-red{color:var(--red);font-weight:700}.count-blue{color:var(--blue);font-weight:700}.vs{color:var(--text-muted);font-weight:700}.team-toggle{background:var(--bg-elevated-2);border-radius:10px;gap:4px;margin-bottom:12px;padding:4px;display:flex}.team-btn{color:var(--text-muted);font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;min-height:40px;padding:9px 12px;transition:background .15s,color .15s,box-shadow .15s}.team-btn:hover:not(.active-red):not(.active-blue){color:var(--text)}.team-btn.active-red{background:var(--red);color:#fff;box-shadow:0 2px 6px #e11d484d}.team-btn.active-blue{background:var(--blue);color:#fff;box-shadow:0 2px 6px #2563eb4d}@media (width<=767px){.team-btn{min-height:44px}}.picker-mode-toggle{background:var(--bg-elevated-2);border-radius:10px;gap:4px;margin-bottom:12px;padding:4px;display:flex}.picker-mode-btn{color:var(--text-muted);font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;min-height:36px;padding:9px 12px;transition:background .15s,color .15s,box-shadow .15s}.picker-mode-btn:hover:not(.active){color:var(--text)}.picker-mode-btn.active{background:var(--text);color:var(--bg)}.picker-mode-btn-heroes.active{color:#1a130a;background:#c69a3f;box-shadow:0 2px 6px #c69a3f59}.hero-item.selected{box-shadow:0 0 0 1px #c69a3f,0 4px 12px #c69a3f40;outline-color:#c69a3f!important}.hero-glyph{width:48px;height:48px;font-family:var(--font-body);letter-spacing:.5px;color:#1a130a;text-shadow:0 1px #ffffff40;background:linear-gradient(145deg,#e6c06e 0%,#c69a3f 60%,#8b6a22 100%);border:1.5px solid #8b6a22;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.hero-portrait-wrap{flex-shrink:0;width:48px;height:48px;position:relative}.hero-thumb{box-sizing:border-box;border:1.5px solid #8b6a22!important}.hero-portrait-level{color:#1a130a;text-align:center;min-width:18px;height:18px;font-size:10px;font-weight:700;line-height:18px;font-family:var(--font-body);pointer-events:none;background:#c69a3f;border:1.5px solid #1a130a;border-radius:9px;padding:0 4px;position:absolute;bottom:-3px;right:-3px}.hero-level-badge{color:#1a130a;vertical-align:middle;background:#c69a3f;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.hero-primary{border:1px solid #c69a3f66;color:#c69a3f!important;background:#c69a3f26!important}.search-input{background:var(--bg-elevated-2);width:100%;color:var(--text);font-size:13px;font-family:var(--font-body);border:1px solid #0000;border-radius:8px;outline:none;margin-bottom:10px;padding:10px 12px 10px 36px;transition:background .15s,border-color .15s,box-shadow .15s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{background:var(--bg-elevated);border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}.search-wrapper{position:relative}.search-icon{color:var(--text-muted);pointer-events:none;width:16px;height:16px;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.cr-filter-row{align-items:center;gap:8px;margin-bottom:12px;display:flex}.cr-filter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;font-size:11px;font-weight:600}.cr-filter-select{background:var(--bg-elevated-2);color:var(--text);border:1px solid var(--border);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239e9e9e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:8px;flex:1;padding:8px 28px 8px 10px}.cr-filter-select:hover{background-color:var(--bg-hover)}.cr-filter-select:focus-visible{outline:2px solid var(--accent,#4a9eff);outline-offset:1px}.creature-picker-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:14px}.monster-list{-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;flex-direction:column;gap:8px;padding:12px 12px 14px;display:flex;overflow-y:auto}.monster-item{text-align:left;border:1px solid var(--border);background:var(--bg-elevated);width:100%;color:var(--text);cursor:grab;min-height:92px;box-shadow:var(--shadow-sm);border-radius:12px;padding:16px;transition:background .12s,border-color .12s,transform 80ms,box-shadow .12s;display:block}.monster-item:active{cursor:grabbing}.monster-item:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 12px #0d94881a}.monster-item.selected{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-glow);background:#0d948814}.monster-item-row{align-items:flex-start;gap:14px;display:flex}.monster-thumb{object-fit:cover;background:var(--bg-elevated-2);border:1px solid var(--border);border-radius:10px;flex-shrink:0;width:56px;height:56px}.monster-item.selected .monster-thumb{border-color:var(--gold)}.monster-item-info{flex:1;min-width:0}.monster-name{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text);word-break:break-word;font-size:15px;font-weight:700;line-height:1.25;display:block}.monster-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;font-size:11px;font-weight:500;line-height:1.35;display:flex}.monster-cr{color:var(--gold);font-variant-numeric:tabular-nums;letter-spacing:.02em;white-space:nowrap;background:#0d94881f;border-radius:8px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.quick-add{border-bottom:1px solid var(--border);background:var(--bg-elevated-2);align-items:center;gap:10px;padding:12px 14px;display:flex}.quick-add-label{font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:700}.quick-add-input{border:1px solid var(--border);text-align:center;background:var(--bg-elevated);width:58px;color:var(--text);font-size:14px;font-weight:600;font-family:var(--font-display);font-variant-numeric:tabular-nums;border-radius:8px;padding:9px 10px;transition:border-color .12s,box-shadow .12s}.quick-add-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow);outline:none}.quick-add-btn{min-height:38px;font-family:var(--font-display);letter-spacing:.01em;color:#fff;border:none;flex:1;font-size:13px;font-weight:700;box-shadow:0 2px 6px #1e1a1626}.quick-add-btn-red{background:linear-gradient(135deg, var(--red), var(--red-dim))}.quick-add-btn-red:hover{background:linear-gradient(135deg, var(--red-bright), var(--red));box-shadow:0 4px 12px #e11d484d}.quick-add-btn-blue{background:linear-gradient(135deg, var(--blue), var(--blue-dim))}.quick-add-btn-blue:hover{background:linear-gradient(135deg, var(--blue-bright), var(--blue));box-shadow:0 4px 12px #2563eb4d}.grid-wrapper{background:var(--bg-elevated-2);border:1px solid var(--border);contain:strict;box-shadow:inset 0 2px 8px #1e1a160f, var(--shadow-sm);border-radius:14px;position:relative;overflow:hidden}.grid-wrapper canvas{touch-action:none;display:block}.grid-info{color:var(--text-muted);border:1px solid var(--border);font-size:11px;font-family:var(--font-mono);box-shadow:var(--shadow-sm);background:#ffffffeb;border-radius:4px;padding:3px 8px;position:absolute;top:8px;left:8px}.grid-zoom{gap:4px;display:flex;position:absolute;bottom:8px;right:8px}.grid-zoom button{color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#ffffffeb;border-radius:4px;padding:6px 12px;font-size:14px;font-weight:700;transition:color .15s,background .15s}.grid-zoom button:hover{color:var(--gold)}.grid-empty{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.grid-empty-card{text-align:center;background:var(--bg-elevated);border:1px solid var(--border-strong);max-width:300px;box-shadow:var(--shadow-lg);pointer-events:none;border-radius:8px;padding:32px}.grid-empty-card *{pointer-events:none}.grid-empty-card .grid-empty-cta{pointer-events:auto}.results{border-top:1px solid var(--border);background:var(--bg-elevated);flex-wrap:wrap;align-items:center;gap:16px;padding:10px 16px;font-size:13px;display:flex}.results .label{color:var(--text-muted)}.results .win-red{color:var(--red);font-weight:700}.results .win-blue{color:var(--blue);font-weight:700}.victory-card{text-align:center;border-top:1px solid var(--border);background:var(--bg-elevated);padding:24px}.victory-title{font-family:var(--font-display);margin-bottom:8px;font-size:28px;font-weight:700}.victory-mvp{color:var(--gold);font-size:15px;font-family:var(--font-display);letter-spacing:.03em;margin-bottom:8px}.victory-mvp strong{color:var(--text)}.victory-stats{color:var(--text-secondary);font-variant-numeric:tabular-nums;margin-bottom:16px;font-size:13px}.victory-actions{justify-content:center;gap:8px;display:flex}.log-entry{background:var(--bg-elevated-2);color:var(--text-secondary);border-radius:8px;align-items:center;gap:8px;margin:0 10px 6px;padding:9px 12px;font-size:12px;line-height:1.45;display:flex}.log-icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.log-icon svg{width:18px;height:18px}.log-round-divider{width:fit-content;font-family:var(--font-display);letter-spacing:.12em;color:var(--gold);text-transform:uppercase;text-align:center;white-space:nowrap;background:#0d94881f;border-radius:16px;margin:16px auto 12px;padding:5px 14px;font-size:11px;font-weight:700;display:block}.log-round-divider:first-child{margin-top:10px}.log-actor{color:var(--text);flex-shrink:0;margin-right:2px;font-weight:700}.log-actor-red{color:var(--red)}.log-actor-blue{color:var(--blue)}.log-details{color:var(--text-secondary)}.log-damage{font-variant-numeric:tabular-nums;font-weight:700;font-family:var(--font-mono)}.log-damage-hit{color:var(--success)}.log-damage-crit{color:var(--red)}.log-damage-miss{color:var(--text-muted)}.stat-block{padding:12px;font-size:13px}.stat-block-portrait{aspect-ratio:1;border:2px solid var(--border);background:var(--bg-elevated-2);border-radius:8px;width:100%;max-width:256px;margin:0 auto 10px;overflow:hidden;box-shadow:0 2px 12px #0006}.stat-block-portrait img{object-fit:cover;width:100%;height:100%;display:block}.stat-block-portrait-official{aspect-ratio:auto;max-width:none;max-height:400px}.stat-block-portrait-official img{object-fit:contain;height:auto}@media (width<=767px){.stat-block-portrait-official{max-height:40dvh}}.stat-block h3{font-size:18px;font-weight:700;font-family:var(--font-display);color:var(--gold);margin-bottom:4px}.stat-block .meta{color:var(--text-muted);margin-bottom:8px;font-size:12px;font-style:italic}.ability-grid{text-align:center;grid-template-columns:repeat(6,1fr);gap:4px;margin:8px 0;display:grid}.ability-cell{background:var(--bg-elevated-2);border:1px solid var(--border);border-radius:4px;padding:6px 2px}.ability-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.ability-score{font-variant-numeric:tabular-nums;font-weight:700}.ability-mod{color:var(--gold-dim);font-variant-numeric:tabular-nums;font-size:11px}.tab-bar{padding:6px 8px;padding-bottom:max(6px, env(safe-area-inset-bottom,0px));padding-left:max(8px, env(safe-area-inset-left));padding-right:max(8px, env(safe-area-inset-right));border-top:1px solid var(--border);background:var(--bg-elevated);gap:6px;display:flex}.tab-btn{text-align:center;min-height:44px;font-size:12px;font-weight:600;font-family:var(--font-body);background:var(--bg);color:var(--text-muted);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:10px;flex:1;padding:10px 8px;transition:background .15s,color .15s,border-color .15s,box-shadow .15s,transform .1s}.tab-btn:active{box-shadow:none;transform:translateY(1px)}.tab-btn.active{background:var(--text);color:#fff;border-color:var(--text);transform:translateY(-1px);box-shadow:0 2px 10px #1e1a1633}.placing-bar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.placing-bar.red{color:var(--red);background:#e11d481a}.placing-bar.blue{color:var(--blue);background:#2563eb1a}.panel-tabs{background:var(--bg-elevated-2);border-radius:10px;gap:4px;margin:10px;padding:4px;display:flex}.panel-tab{text-align:center;color:var(--text-muted);font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:9px 8px;transition:background .15s,color .15s,box-shadow .15s}.panel-tab:hover:not(.active){color:var(--text)}.panel-tab.active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.progress-bar{background:var(--bg-elevated-2);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill{background:var(--gold);height:100%;transition:width .3s}.modal-overlay{z-index:1000;background:#1e1a1680;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;width:100%;max-width:960px;max-height:85dvh;overflow-y:auto;box-shadow:0 24px 64px #1e1a162e}@media (width<=767px){.modal-content{border-radius:0;max-width:100%;height:100dvh;max-height:100dvh}}.modal-header{border-bottom:1px solid var(--border-strong);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.015em;align-items:center;gap:8px;font-size:20px;font-weight:700;display:flex}.modal-title-icon{display:inline-flex}.modal-close{color:var(--text-muted);background:var(--bg-elevated-2);border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:4px 8px;font-size:18px;transition:background .12s,color .12s;display:flex}.modal-close:hover{color:var(--text);background:var(--bg-hover)}.modal-body{padding:24px}.presets-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width<=767px){.presets-grid{grid-template-columns:1fr}}.preset-card{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;border-radius:10px;grid-template-columns:64px 1fr;gap:10px;padding:10px 12px;transition:border-color .15s,transform .15s,box-shadow .15s;display:grid}.preset-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.preset-thumb{object-fit:cover;background:var(--bg-elevated-2);border:1px solid var(--border);border-radius:6px;align-self:center;width:64px;height:64px}.preset-thumb-blank{background:var(--bg-elevated-2);border:1px solid var(--border);width:64px;height:64px;color:var(--text-muted);border-radius:6px;justify-content:center;align-self:center;align-items:center;font-size:22px;display:flex}.preset-card-content{flex-direction:column;gap:6px;min-width:0;display:flex}.preset-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.preset-title{font-family:var(--font-display);color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:14px;font-weight:700;line-height:1.3;overflow:hidden}.preset-diff{text-transform:uppercase;letter-spacing:.08em;background:var(--bg-elevated);white-space:nowrap;border:1px solid;border-radius:3px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:600;display:inline-block}.preset-roster{flex-direction:column;gap:3px;display:flex}.preset-row{background:var(--bg-elevated-2);border-left:3px solid;border-radius:5px;flex-wrap:wrap;align-items:center;gap:4px;padding:3px 6px;display:flex}.preset-row-red{border-color:var(--red)}.preset-row-blue{border-color:var(--blue)}.preset-chip{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:10px;align-items:center;gap:4px;padding:1px 6px 1px 1px;font-size:11px;display:flex}.preset-chip img{object-fit:cover;background:var(--bg-elevated-2);border-radius:50%;width:18px;height:18px}.preset-chip-count{color:var(--gold);margin-right:1px;font-weight:600}.mc-launcher{align-items:center;display:inline-flex;position:relative}.mc-launcher-btn{letter-spacing:.02em;box-shadow:inset 0 1px 0 #ffffff2e, 0 0 14px var(--gold-glow);align-items:center;padding:10px 18px;font-size:14px;transition:background .15s,box-shadow .15s,transform 80ms;display:inline-flex}.mc-launcher-btn:active{transform:translateY(1px)}.mc-launcher-btn[aria-expanded=true]{background:var(--gold-bright);box-shadow:inset 0 2px 4px #0003, 0 0 18px var(--gold-glow)}.mc-launcher-label-short{display:none}.mc-launcher-label-full{display:inline}.mc-launcher-icon{margin-right:7px}@media (width<=767px){.mc-launcher-btn{letter-spacing:0;box-shadow:var(--shadow-sm);padding:9px 12px;font-size:13px}.mc-launcher-btn:hover{box-shadow:var(--shadow-md)}.mc-launcher-icon,.mc-launcher-label-full{display:none}.mc-launcher-label-short{display:inline}.controls{gap:5px;padding:6px 10px}.controls .logo{margin-right:4px;font-size:15px}}.mc-launcher-menu{z-index:900;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:8px;flex-direction:column;gap:8px;min-width:260px;padding:12px;display:flex;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #0009,0 2px 6px #0006}.mc-launcher-menu-title{font-family:var(--font-display);color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-size:13px;font-weight:700}.mc-launcher-menu-desc{color:var(--text-secondary);margin-bottom:4px;font-size:11px}.mc-launcher-options{flex-direction:column;gap:4px;display:flex}.mc-launcher-option{background:var(--bg-elevated-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:5px;justify-content:space-between;align-items:baseline;gap:12px;min-height:44px;padding:8px 10px;font-family:inherit;transition:background .12s,border-color .12s;display:flex}.mc-launcher-option:hover,.mc-launcher-option:focus-visible{background:var(--bg-hover);border-color:var(--gold-dim);outline:none}.mc-launcher-option-n{font-family:var(--font-display);font-variant-numeric:tabular-nums;color:var(--gold-bright);font-size:16px;font-weight:700}.mc-launcher-option-caption{color:var(--text-muted);font-size:11px;font-style:italic}.mc-launcher-menu-foot{color:var(--text-muted);border-top:1px dashed var(--border);margin-top:2px;padding-top:6px;font-size:10px;line-height:1.3}.mc-launcher-placement-toggle{border-top:1px dashed var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:flex-start;gap:8px;padding:8px 0 6px;font-size:12px;display:flex}.mc-launcher-placement-toggle input[type=checkbox]{cursor:pointer;margin-top:2px}.mc-launcher-placement-hint{color:var(--text-muted);margin-top:2px;font-size:10px;font-style:italic;line-height:1.3;display:block}@media (width<=767px){.mc-launcher-menu{z-index:1100;border-radius:16px 16px 0 0;width:100vw;min-width:0;padding:16px;position:fixed;inset:auto 0 0;box-shadow:0 -4px 24px #0006}}.mc-modal{flex-direction:column;max-width:760px;max-height:85vh;display:flex;overflow:hidden}.mc-modal .modal-header{flex-shrink:0}.mc-modal .modal-body{flex:auto;min-height:0;padding-bottom:28px;overflow-y:auto}.mc-subtitle{font-family:var(--font-body);color:var(--text-muted);text-align:center;letter-spacing:0;margin-bottom:24px;font-size:14px}.mc-winbar{background:var(--bg-elevated-2);border-radius:12px;width:100%;height:48px;display:flex;overflow:hidden;box-shadow:inset 0 2px 4px #1e1a1614}.mc-winbar-seg{justify-content:center;align-items:center;min-width:0;transition:width .4s ease-out;display:flex;position:relative}.mc-winbar-red{background:linear-gradient(135deg, var(--red), var(--red-bright));color:#fff}.mc-winbar-blue{background:linear-gradient(135deg, var(--blue), var(--blue-bright));color:#fff}.mc-winbar-draw{background:repeating-linear-gradient(135deg, var(--border-strong) 0 8px, var(--border) 8px 16px);color:var(--text-secondary)}.mc-winbar-label{font-family:var(--font-display);font-variant-numeric:tabular-nums;text-shadow:0 1px 2px #00000040;letter-spacing:-.01em;font-size:17px;font-weight:800}.mc-winbar-legend{text-transform:uppercase;letter-spacing:.08em;justify-content:center;gap:24px;margin-top:12px;margin-bottom:26px;font-size:11px;font-weight:600;display:flex}.mc-summary-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=600px){.mc-summary-grid{grid-template-columns:repeat(2,1fr)}}.mc-stat{background:var(--bg-elevated);border:1px solid var(--border);text-align:left;border-radius:12px;padding:16px 14px 14px}.mc-stat-label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:600}.mc-stat-value{font-family:var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.03em;font-size:30px;font-weight:800;line-height:1}.mc-stat-sub{font-family:var(--font-body);color:var(--text-muted);font-variant-numeric:tabular-nums;margin-top:6px;font-size:11px;font-weight:500}.mc-survival-tiles{margin-top:22px}.mc-survival-row{align-items:center;gap:12px;padding:10px 0;display:flex}.mc-survival-row+.mc-survival-row{border-top:1px solid var(--border)}.mc-survival-row-label{width:50px;font-family:var(--font-display);letter-spacing:.06em;text-align:right;flex-shrink:0;font-size:12px;font-weight:700}.mc-survival-row-label-red{color:var(--red)}.mc-survival-row-label-blue{color:var(--blue)}.mc-survival-row-tiles{flex-wrap:wrap;flex:1;gap:6px;display:flex}.mc-survival-tile{border:none;border-radius:10px;flex-direction:column;flex:none;justify-content:space-between;width:76px;height:56px;padding:6px 8px;transition:transform .15s;display:flex;overflow:hidden;box-shadow:inset 0 1px #ffffff4d,inset 0 -1px 2px #0000001a,0 2px 6px #1e1a161a}.mc-survival-tile:hover{transform:translateY(-1px)}.mc-survival-tile.tile-rank-0{background:linear-gradient(135deg,#ef4444,#dc2626)}.mc-survival-tile.tile-rank-1{background:linear-gradient(135deg,#f97316,#ea580c)}.mc-survival-tile.tile-rank-2{background:linear-gradient(135deg,#f59e0b,#d97706)}.mc-survival-tile.tile-rank-3{background:linear-gradient(135deg,#eab308,#ca8a04)}.mc-survival-tile.tile-rank-4{background:linear-gradient(135deg,#a3e635,#65a30d)}.mc-survival-tile.tile-rank-5{background:linear-gradient(135deg,#4ade80,#16a34a)}.mc-survival-tile.tile-rank-6{background:linear-gradient(135deg,#10b981,#059669)}.mc-survival-tile.tile-lives{background:linear-gradient(135deg, var(--gold-bright), var(--gold))}.mc-survival-tile.tile-unknown{background:var(--bg-elevated-2);box-shadow:inset 0 1px 2px #1e1a160f}.mc-survival-tile.tile-unknown .mc-survival-tile-name,.mc-survival-tile.tile-unknown .mc-survival-tile-pct{color:var(--text-muted);text-shadow:none}.mc-survival-tile-name{font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #00000040;text-overflow:ellipsis;white-space:nowrap;letter-spacing:0;font-size:10px;font-weight:600;line-height:1.15;overflow:hidden}.mc-survival-tile-pct{font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #0000004d;text-align:right;font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:16px;font-weight:800;line-height:1}.mc-leaderboard{margin-top:22px}.mc-leaderboard-table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%}.mc-leaderboard-table thead th{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:10px 8px;font-size:11px;font-weight:700}.mc-leaderboard-table tbody td{border-bottom:1px solid var(--border);font-family:var(--font-body);color:var(--text);vertical-align:middle;padding:12px 8px;font-size:13px;font-weight:500}.mc-leaderboard-table tbody tr:last-child td{border-bottom:none}.mc-col-name{width:28%}.mc-col-survival{width:22%}.mc-col-num{text-align:right;width:16%}.mc-leaderboard-table thead .mc-col-num{text-align:right}.mc-row-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.mc-row-dot-red{background:var(--red)}.mc-row-dot-blue{background:var(--blue)}.mc-row-name{font-family:var(--font-display);letter-spacing:-.01em;font-size:14px;font-weight:700}.mc-survival-bar{background:var(--bg-elevated-2);border-radius:10px;height:20px;position:relative;overflow:hidden;box-shadow:inset 0 1px 2px #1e1a160d}.mc-survival-fill{border-radius:10px;transition:width .4s ease-out;position:absolute;inset:0 auto 0 0;box-shadow:inset 0 1px #ffffff40}.mc-survival-fill-good{background:linear-gradient(90deg, var(--success), #34d399)}.mc-survival-fill-mid{background:linear-gradient(90deg, var(--warning), #fbbf24)}.mc-survival-fill-bad{background:linear-gradient(90deg, var(--red), var(--red-bright))}.mc-survival-label{font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #1e1a1659;letter-spacing:-.01em;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:absolute;inset:0}.mc-damage-cell{justify-content:flex-end;align-items:center;gap:10px;display:flex}.mc-damage-bar{background:var(--bg-elevated-2);border-radius:4px;flex:0 80px;min-width:0;height:8px;overflow:hidden;box-shadow:inset 0 1px 2px #1e1a160d}.mc-damage-fill{border-radius:4px;height:100%;transition:width .4s ease-out;box-shadow:inset 0 1px #fff3}.mc-damage-fill-red{background:linear-gradient(90deg, var(--red), var(--red-bright))}.mc-damage-fill-blue{background:linear-gradient(90deg, var(--blue), var(--blue-bright))}.mc-damage-num{font-family:var(--font-display);text-align:right;font-variant-numeric:tabular-nums;min-width:38px;color:var(--text);letter-spacing:-.01em;font-size:14px;font-weight:700}.section-header{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--gold);border-bottom:1px solid var(--border);margin:24px 0 14px;padding-bottom:8px;font-size:13px;font-weight:700}.mc-modal .mc-summary-grid .mc-stat-label:before,.mc-modal .section-header:before,.mc-modal .mc-leaderboard-table thead th:before{letter-spacing:normal;text-transform:none;white-space:nowrap;font-feature-settings:"liga";-webkit-font-smoothing:antialiased;vertical-align:-3px;font-variation-settings:"FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;direction:ltr;margin-right:6px;font-family:Material Symbols Rounded;font-size:14px;font-style:normal;font-weight:500;line-height:1;display:inline-block}.mc-modal{position:relative}.mc-modal:before{content:"";background:linear-gradient(90deg, var(--gold) 0%, var(--gold) 33%, var(--red) 33%, var(--red) 50%, var(--blue) 50%, var(--blue) 66%, var(--gold) 66%, var(--gold) 100%);z-index:2;height:3px;position:absolute;top:0;left:0;right:0}.mc-modal .mc-summary-grid .mc-stat{position:relative;overflow:hidden}.mc-modal .mc-summary-grid .mc-stat:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.mc-modal .mc-summary-grid .mc-stat:first-child:before{background:var(--red)}.mc-modal .mc-summary-grid .mc-stat:nth-child(2):before{background:var(--text-muted)}.mc-modal .mc-summary-grid .mc-stat:nth-child(3):before{background:var(--blue)}.mc-modal .mc-summary-grid .mc-stat:nth-child(4):before{background:var(--gold)}.mc-modal .mc-summary-grid .mc-stat-label{justify-content:flex-start;align-items:center;gap:5px;display:flex}.mc-modal .mc-summary-grid .mc-stat:first-child .mc-stat-label:before{content:"sentiment_very_dissatisfied";color:var(--red)}.mc-modal .mc-summary-grid .mc-stat:nth-child(2) .mc-stat-label:before{content:"balance";color:var(--text-muted)}.mc-modal .mc-summary-grid .mc-stat:nth-child(3) .mc-stat-label:before{content:"military_tech";color:var(--blue)}.mc-modal .mc-summary-grid .mc-stat:nth-child(4) .mc-stat-label:before{content:"schedule";color:var(--gold)}.mc-modal .section-header{border-left:3px solid var(--gold);border-bottom:1px solid var(--border);align-items:center;margin-top:26px;padding-bottom:10px;padding-left:14px;display:flex}.mc-modal .section-header:before{vertical-align:-4px;color:var(--gold);content:"category";margin-right:10px;font-size:18px}.mc-modal .mc-survival-tiles .section-header{border-left-color:var(--red)}.mc-modal .mc-survival-tiles .section-header:before{content:"skull";color:var(--red)}.mc-modal .mc-leaderboard .section-header:before{content:"emoji_events"}.mc-modal .mc-leaderboard-table thead th{white-space:nowrap}.mc-modal .mc-leaderboard-table thead th:before{color:var(--text-muted);vertical-align:-2px;margin-right:4px;font-size:12px}.mc-modal .mc-leaderboard-table thead .mc-col-name:before{content:"person"}.mc-modal .mc-leaderboard-table thead .mc-col-survival:before{content:"favorite";color:var(--success)}.mc-modal .mc-leaderboard-table thead th:nth-child(3):before{content:"swords";color:var(--red)}.mc-modal .mc-leaderboard-table thead th:nth-child(4):before{content:"shield";color:var(--blue)}.mc-modal .mc-leaderboard-table thead th:nth-child(5):before{content:"skull";color:var(--text)}.mc-modal .mc-leaderboard-table tbody tr:nth-child(odd) td{background:#1e1a1606}.mc-launcher-btn{background:linear-gradient(180deg, var(--gold-bright), var(--gold));box-shadow:inset 0 1px 0 #ffffff59, 0 4px 14px var(--gold-glow)}.mc-launcher-btn:hover{box-shadow:inset 0 1px 0 #fff6, 0 8px 22px var(--gold-glow)}.monster-item{border-left:3px solid #0000}.monster-item:hover,.monster-item.selected{border-left-color:var(--gold)}.tactics-modal{max-width:560px}.tactics-teams{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=600px){.tactics-teams{grid-template-columns:1fr}}.tactics-team-label{font-family:var(--font-display);letter-spacing:.02em;margin-bottom:10px;font-size:14px;font-weight:700}.tactics-team-label-red{color:var(--red)}.tactics-team-label-blue{color:var(--blue)}.tactics-options{flex-direction:column;gap:6px;display:flex}.tactics-option{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;gap:3px;padding:12px 14px;transition:border-color .12s,background .12s;display:flex}.tactics-option:hover{border-color:var(--gold);background:var(--bg-hover)}.tactics-option.active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-glow);background:#0d948814}.tactics-option-name{font-family:var(--font-display);color:var(--text);font-size:13px;font-weight:700}.tactics-option.active .tactics-option-name{color:var(--gold)}.tactics-option-desc{color:var(--text-muted);font-size:11px;line-height:1.35}.tactics-ff-toggle{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-top:8px;padding:6px 0;font-size:12px;display:flex}.tactics-ff-toggle input[type=checkbox]{cursor:pointer}.tactics-trigger{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;width:100%;font-family:var(--font-body);color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;gap:6px;margin-bottom:12px;padding:8px;font-size:12px;font-weight:600;transition:border-color .12s,color .12s;display:flex}.tactics-trigger:hover{border-color:var(--gold);color:var(--text)}.tactics-trigger svg{width:14px;height:14px;color:var(--gold)}.tactics-trigger-full{display:inline}.tactics-trigger-short{display:none}.share-menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;width:380px;max-width:calc(100vw - 32px);overflow:hidden;box-shadow:0 24px 64px #1e1a1638}.share-menu-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.share-menu-title{font-family:var(--font-display);color:var(--text);margin:0;font-size:18px;font-weight:700}.share-menu-body{padding:20px 22px 24px}.share-menu-buttons{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;display:grid}.share-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-family:var(--font-body);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:18px 8px;font-size:12px;font-weight:600;text-decoration:none;transition:background .12s,border-color .12s,transform 80ms;display:flex}.share-btn:hover{background:var(--bg-hover);transform:translateY(-1px)}.share-btn svg,.share-btn img{width:28px;height:28px}.share-btn-x{color:#000}.share-btn-x:hover{background:#f0f0f0;border-color:#000}.share-btn-reddit{color:#ff4500}.share-btn-reddit:hover{background:#fff1ec;border-color:#ff4500}.share-btn-copy{color:var(--gold)}.share-btn-copy:hover{border-color:var(--gold);background:#0d94880f}.share-menu-url{display:flex}.share-menu-url input{border:1px solid var(--border);width:100%;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-elevated-2);cursor:text;text-overflow:ellipsis;border-radius:8px;padding:10px 14px;font-size:11px}.share-menu-url input:focus{border-color:var(--gold);color:var(--text);outline:none}.share-toast{z-index:2000;background:var(--text);color:#fff;font-family:var(--font-body);pointer-events:none;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;animation:.25s ease-out share-toast-in;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 8px 28px #1e1a1640}@keyframes share-toast-in{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.maps-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.map-card{background:var(--bg-elevated,#fff);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-direction:column;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex;overflow:hidden}.map-card:hover{border-color:var(--teal,#0d9488);transform:translateY(-2px);box-shadow:0 6px 18px #1e1a161f}.map-card-image{aspect-ratio:1;background:#f4f1ea;width:100%;position:relative;overflow:hidden}.map-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.map-card:hover .map-card-image img{transform:scale(1.04)}.map-card-image-blank{background-color:#fff;background-image:linear-gradient(90deg,#1e1a161f 1px,#0000 1px),linear-gradient(#1e1a161f 1px,#0000 1px);background-size:10% 10%}.map-size-badge{letter-spacing:.04em;font-variant-numeric:tabular-nums;white-space:nowrap;border-radius:12px;padding:4px 9px;font-size:10px;font-weight:700;position:absolute;top:8px;right:8px;box-shadow:0 1px 3px #00000026}.map-card-body{flex-direction:column;gap:4px;padding:12px 14px 14px;display:flex}.map-title{font-family:var(--font-display);color:var(--text);margin:0;font-size:15px;font-weight:700;line-height:1.3}.map-description{color:var(--text-muted,#666);margin:0;font-size:12px;line-height:1.45}.mc-progress{background:var(--bg-elevated,#fff);border-top:1px solid var(--border);font-variant-numeric:tabular-nums;flex-direction:column;gap:6px;padding:8px 12px;display:flex}.mc-progress-header{align-items:center;gap:12px;font-size:13px;display:flex}.mc-progress-title{font-family:var(--font-display);color:var(--teal,#0d9488);font-weight:700}.mc-progress-count{color:var(--text,#1a1a1a);font-weight:600}.mc-progress-eta{color:var(--text-muted,#666);flex:1}.mc-progress-cancel{padding:4px 10px;font-size:12px}.mc-progress-bar{background:#ece8de;border-radius:3px;height:6px;overflow:hidden}.mc-progress-bar .progress-fill{background:var(--teal,#0d9488);height:100%;transition:width .2s ease-out}.mc-progress-winbar{color:#fff;letter-spacing:.02em;border:1px solid #d0ccc0;border-radius:4px;height:20px;font-size:11px;font-weight:700;display:flex;overflow:hidden}.mc-progress-win-seg{white-space:nowrap;justify-content:center;align-items:center;transition:width .25s ease-out;display:flex;overflow:hidden}.mc-progress-win-red{background:#dc2626}.mc-progress-win-blue{background:#2563eb}.mc-progress-win-draw{background:#6b7280}.mc-histogram{background:var(--bg-elevated,#fff);border:1px solid var(--border);border-radius:10px;margin:18px 0 8px;padding:12px 14px 14px}.mc-histogram-title{font-family:var(--font-display);color:var(--text,#1a1a1a);letter-spacing:.02em;justify-content:space-between;align-items:baseline;margin-bottom:10px;font-size:13px;font-weight:700;display:flex}.mc-histogram-summary{font-family:var(--font-body);color:var(--text-muted,#666);letter-spacing:0;font-variant-numeric:tabular-nums;font-size:11px;font-weight:500}.mc-histogram-bars{grid-auto-columns:1fr;grid-auto-flow:column;align-items:end;gap:2px;height:88px;padding-bottom:18px;display:grid;position:relative}.mc-histogram-bar-wrap{flex-direction:column;justify-content:flex-end;align-items:stretch;min-width:0;height:100%;display:flex;position:relative}.mc-histogram-bar{background:var(--teal,#0d9488);border-radius:2px 2px 0 0;min-height:2px;transition:height .18s ease-out}.mc-histogram-bar-wrap:hover .mc-histogram-bar{background:var(--teal-strong,#0b7d72);filter:brightness(1.08)}.mc-histogram-xlabel{text-align:center;font-variant-numeric:tabular-nums;color:var(--text-muted,#666);white-space:nowrap;font-size:9px;position:absolute;bottom:-16px;left:0;right:0}.mc-histogram-overflow .mc-histogram-bar{background:#f59e0b}.mc-cancelled-banner{color:#92400e;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin:0 0 14px;padding:10px 14px;font-size:13px;line-height:1.5}.party-config{flex-direction:column;gap:18px;display:flex}.party-config-row{align-items:center;gap:14px;display:flex}.party-config-label{font-family:var(--font-display);color:var(--text-secondary);letter-spacing:.04em;min-width:100px;font-size:12px;font-weight:700}.party-size-toggle{background:var(--bg-elevated-2);border-radius:10px;gap:4px;padding:4px;display:flex}.party-size-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .12s,color .12s}.party-size-btn:hover{color:var(--text)}.party-size-btn.active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.party-level-slider{flex:1;align-items:center;gap:10px;display:flex}.party-level-slider input[type=range]{accent-color:var(--gold);flex:1;height:4px}.party-level-value{font-family:var(--font-display);color:var(--gold);text-align:center;min-width:28px;font-size:15px;font-weight:700}.party-detail-toggle{color:var(--text-muted);align-self:flex-start;font-size:12px}.party-heroes-grid{flex-wrap:wrap;gap:10px;display:flex}.party-hero-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;align-items:center;gap:6px;padding:8px 10px;display:flex}.party-hero-thumb{object-fit:cover;background:var(--bg-elevated-2);border-radius:6px;width:32px;height:32px}.party-hero-class-select,.party-hero-level-select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:3px 6px;font-size:12px}.party-thresholds{font-size:11px;font-weight:600;font-family:var(--font-display);letter-spacing:.03em;flex-wrap:wrap;gap:12px;display:flex}.party-threshold{white-space:nowrap}.eb-modal{background:var(--bg-elevated);border-radius:16px;flex-direction:column;width:min(960px,95vw);max-height:90dvh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000002e}.eb-tabs{border-bottom:1px solid var(--border);background:var(--bg-elevated);gap:0;padding:0 24px;display:flex}.eb-tab{font-size:13px;font-weight:600;font-family:var(--font-display);letter-spacing:.03em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 18px;transition:color .12s,border-color .12s}.eb-tab:hover{color:var(--text)}.eb-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.eb-body{flex:1;padding:20px 24px;overflow-y:auto}.eb-party-stage{max-width:520px;margin:0 auto}.eb-saved-party-row{margin-bottom:16px}.eb-saved-party-controls{align-items:center;gap:8px;display:flex}.eb-saved-party-select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:6px;flex:1;padding:8px 12px;font-size:14px}.eb-party-actions{text-align:right;margin-top:24px}.eb-build-stage{gap:20px;min-height:400px;display:flex}.eb-browser{flex-direction:column;flex:1;min-width:0;display:flex}.eb-browser-filters{flex-shrink:0}.eb-filter-row{gap:6px;margin-bottom:8px;display:flex}.eb-filter-select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;flex:1;padding:6px 8px;font-size:12px}.eb-monster-list{border:1px solid var(--border);background:var(--bg);border-radius:10px;flex:1;overflow-y:auto}.eb-monster-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 10px;transition:background .1s;display:flex}.eb-monster-row:last-child{border-bottom:none}.eb-monster-row:hover{background:var(--bg-hover)}.eb-monster-row.in-roster{background:#0d94880f}.eb-monster-thumb{object-fit:cover;background:var(--bg-elevated-2);border-radius:6px;flex-shrink:0;width:36px;height:36px}.eb-monster-info{flex:1;min-width:0}.eb-monster-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.eb-monster-meta{color:var(--text-muted);font-size:11px}.eb-monster-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.eb-roster-count{color:var(--gold);text-align:center;min-width:18px;font-size:12px;font-weight:700}.eb-roster-panel{border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;flex-direction:column;flex-shrink:0;width:300px;display:flex;overflow:hidden}.eb-roster-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.eb-roster-title{font-family:var(--font-display);color:var(--text);letter-spacing:.04em;margin:0;font-size:13px;font-weight:700}.eb-party-badge{color:var(--blue);background:#3b82f61a;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600}.eb-roster-list{flex:1;padding:6px;overflow-y:auto}.eb-roster-empty{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:13px;font-style:italic}.eb-roster-entry{border-radius:8px;align-items:center;gap:8px;padding:6px 8px;transition:background .1s;display:flex}.eb-roster-entry:hover{background:var(--bg-hover)}.eb-roster-entry-info{flex:1;min-width:0}.eb-roster-entry-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;display:block;overflow:hidden}.eb-roster-entry-meta{color:var(--text-muted);font-size:10px}.eb-roster-entry-controls{align-items:center;gap:2px;display:flex}.eb-roster-entry-count{color:var(--text);text-align:center;min-width:20px;font-size:13px;font-weight:700}.eb-difficulty-section{border-bottom:1px solid var(--border);flex-shrink:0;padding:12px 14px}.eb-xp-row{color:var(--text-secondary);justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.eb-gauge-bar{background:var(--bg-elevated-2);border-radius:4px;height:8px;position:relative;overflow:visible}.eb-gauge-fill{border-radius:4px;height:100%;transition:width .3s,background .3s}.eb-gauge-marker{background:var(--border-strong);opacity:.5;width:1px;height:8px;position:absolute;top:0}.eb-gauge-label{font-family:var(--font-display);letter-spacing:.05em;text-align:center;margin-top:6px;font-size:14px;font-weight:700}.eb-gauge-thresholds{color:var(--text-muted);justify-content:space-between;margin-top:4px;font-size:10px;display:flex}.eb-map-select{color:var(--text-muted);align-items:center;gap:6px;margin-top:10px;font-size:12px;display:flex}.eb-map-label{white-space:nowrap;align-items:center;font-weight:600;display:flex}.eb-map-dropdown{border:1px solid var(--border);background:var(--bg-elevated,#fff);min-width:0;color:var(--text);cursor:pointer;border-radius:6px;flex:1;padding:4px 8px;font-family:inherit;font-size:12px}.eb-map-dropdown:hover{border-color:var(--teal)}.eb-roster-actions{justify-content:space-between;align-items:center;gap:8px;margin-top:10px;display:flex}.eb-sim-results{border-top:1px solid var(--border);margin-top:10px;padding:10px 0}.eb-sim-header{margin-bottom:6px}.eb-sim-title{color:var(--text-muted);font-size:11px;font-weight:600;font-family:var(--font-display);letter-spacing:.04em}.eb-sim-bar{background:var(--bg-elevated-2);border-radius:5px;height:10px;display:flex;overflow:hidden}.eb-sim-bar-blue{background:var(--blue)}.eb-sim-bar-draw{background:var(--text-muted)}.eb-sim-bar-red{background:var(--red)}.eb-sim-stats{justify-content:space-between;margin-top:4px;font-size:12px;font-weight:600;display:flex}.eb-sim-avg{color:var(--text-muted);text-align:center;margin-top:4px;font-size:11px}.eb-sim-verdict{text-align:center;margin-top:6px;font-size:12px;font-style:italic;font-weight:600;line-height:1.4}@media (width<=767px){.eb-modal{width:100vw;height:100dvh;max-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);border-radius:0;margin:0;position:fixed;inset:0}.eb-build-stage{flex-direction:column;min-height:0}.eb-browser{max-height:40vh}.eb-roster-panel{width:100%;max-height:none}.eb-body{flex:1;padding:12px;overflow-y:auto}.eb-tabs{padding:0 12px}.eb-roster-actions{flex-wrap:wrap}.eb-roster-actions .btn{flex:1;min-width:0;font-size:11px!important}.eb-party-stage{max-width:100%}.party-size-toggle{flex-wrap:wrap}}.bs-modal{flex-direction:column;max-width:700px;max-height:85dvh;display:flex;overflow:hidden}.bs-modal .modal-body{flex:auto;min-height:0;padding-bottom:24px;overflow-y:auto}.bs-result{font-family:var(--font-display);text-align:center;letter-spacing:.08em;margin-bottom:4px;font-size:22px;font-weight:900}.bs-section-header{font-family:var(--font-display);color:var(--gold);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--border);margin:20px 0 8px;padding-bottom:4px;font-size:12px;font-weight:700}.bs-creature-list{flex-direction:column;gap:2px;display:flex}.bs-creature-row{border-radius:8px;gap:10px;padding:8px 6px;transition:background .1s;display:flex}.bs-creature-row:hover{background:var(--bg-hover)}.bs-creature-dead{opacity:.65}.bs-portrait{object-fit:cover;background:var(--bg-elevated-2);border-radius:8px;flex-shrink:0;width:40px;height:40px}.bs-creature-info{flex:1;min-width:0}.bs-creature-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.bs-creature-name{font-size:13px;font-weight:700;font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.bs-hp{color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.bs-hp-bar{background:var(--bg-elevated-2);border-radius:3px;height:5px;margin:3px 0 4px;overflow:hidden}.bs-hp-fill{border-radius:3px;height:100%;transition:width .3s}.bs-death-badge{color:var(--danger);white-space:nowrap;background:#dc26261a;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:700}.bs-detail{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;line-height:1.5;overflow:hidden}.bs-killed-by{color:var(--text-secondary);font-style:italic}.bs-actions{border-top:1px solid var(--border);justify-content:center;gap:10px;margin-top:20px;padding-top:16px;display:flex}@media (width<=767px){.bs-modal{max-width:100vw;max-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);border-radius:0}.bs-portrait{width:32px;height:32px}.bs-detail{white-space:normal}}.pb-modal{background:var(--bg-elevated);border-radius:16px;flex-direction:column;width:min(720px,95vw);max-height:90dvh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000002e}.pb-body{flex:1;padding:20px 24px;overflow-y:auto}.pb-list-actions{gap:8px;margin-bottom:16px;display:flex}.pb-empty{text-align:center;color:var(--text-muted);padding:40px 0}.pb-empty p{margin:4px 0}.pb-import-area{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.pb-import-textarea{resize:vertical;background:var(--bg);width:100%;min-height:80px;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px;font-family:monospace;font-size:12px}.pb-import-error{color:#f87171;font-size:13px}.pb-party-list{flex-direction:column;gap:12px;display:flex}.pb-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.pb-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.pb-card-name{color:var(--text);font-size:15px;font-weight:700}.pb-card-meta{color:var(--text-muted);font-size:12px}.pb-card-heroes{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.pb-card-hero{align-items:center;gap:4px;display:flex}.pb-card-hero-thumb{object-fit:cover;border-radius:50%;width:24px;height:24px}.pb-card-hero-label{color:var(--text-muted);font-size:12px}.pb-card-actions{flex-wrap:wrap;gap:6px;display:flex}.pb-toast{background:var(--gold);color:#000;pointer-events:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;animation:.2s pb-fade-in;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}@keyframes pb-fade-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}}.pb-editor{flex-direction:column;gap:16px;display:flex}.pb-editor-name label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.pb-name-input{background:var(--bg);width:100%;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:15px}.pb-hero-list{flex-direction:column;gap:8px;display:flex}.pb-hero-row{background:var(--bg);border:1px solid var(--border);border-radius:8px;overflow:hidden}.pb-hero-summary{cursor:pointer;align-items:center;gap:10px;padding:10px 12px;display:flex}.pb-hero-summary:hover{background:#ffffff08}.pb-hero-thumb{object-fit:cover;border-radius:50%;flex-shrink:0;width:36px;height:36px}.pb-hero-core{flex:1;min-width:0}.pb-hero-name-input{width:100%;color:var(--text);background:0 0;border:1px solid #0000;border-radius:4px;margin-bottom:4px;padding:4px 8px;font-size:14px}.pb-hero-name-input:focus{border-color:var(--border);background:var(--bg);outline:none}.pb-hero-selects{gap:6px;display:flex}.pb-hero-selects select{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:13px}.pb-hero-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:16px}.pb-hero-remove:hover{color:#f87171}.pb-expand-arrow{color:var(--text-muted);flex-shrink:0;font-size:12px}.pb-hero-details{border-top:1px solid var(--border);padding:0 12px 12px}.pb-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--gold);align-items:center;gap:8px;margin:12px 0 6px;font-size:11px;font-weight:700;display:flex}.pb-abilities{flex-wrap:wrap;align-items:end;gap:8px;display:flex}.pb-ability{flex-direction:column;align-items:center;gap:2px;display:flex}.pb-ability label{color:var(--text-muted);font-size:10px;font-weight:700}.pb-ability input{text-align:center;background:var(--bg-elevated);width:48px;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px;font-size:14px}.pb-hp-ac{gap:12px;display:flex}.pb-field{flex-direction:column;gap:2px;display:flex}.pb-field label{color:var(--text-muted);font-size:10px;font-weight:700}.pb-field input{background:var(--bg-elevated);width:64px;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:14px}.pb-weapon{flex-direction:column;gap:8px;display:flex}.pb-weapon-row{flex-wrap:wrap;gap:6px;display:flex}.pb-weapon-row input{background:var(--bg-elevated);min-width:100px;color:var(--text);border:1px solid var(--border);border-radius:4px;flex:1;padding:4px 8px;font-size:13px}.pb-weapon-row select{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:13px}.pb-spells{flex-direction:column;gap:8px;display:flex}.pb-spell-group{flex-direction:column;gap:2px;display:flex}.pb-spell-level{color:var(--text-muted);margin-bottom:2px;font-size:11px;font-weight:600}.pb-spell-item{color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:2px 0;font-size:13px;display:flex}.pb-spell-item input{accent-color:var(--gold)}.pb-spell-reset{margin-left:auto}.pb-editor-actions{flex-direction:column;gap:8px;margin-top:8px;display:flex}.pb-editor-save-row{justify-content:flex-end;gap:8px;display:flex}.btn-sm{padding:4px 10px;font-size:12px}@media (width<=767px){.pb-modal{width:100vw;height:100dvh;max-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);border-radius:0;margin:0;position:fixed;inset:0}.pb-hero-selects,.pb-weapon-row{flex-direction:column}.pb-abilities{justify-content:center;gap:12px}.pb-ability input{width:52px;min-height:44px;padding:6px;font-size:16px}.pb-field input,.pb-weapon-row input,.pb-weapon-row select{min-height:44px;font-size:16px}}.hb-modal{background:var(--bg-elevated);border-radius:16px;flex-direction:column;width:min(760px,95vw);max-height:90dvh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000002e}.hb-body{flex:1;padding:20px 24px;overflow-y:auto}.hb-list-actions{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.hb-storage-hint{color:var(--text-muted);margin-bottom:12px;font-size:11px}.hb-monster-list{flex-direction:column;gap:10px;display:flex}.hb-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.hb-card-header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.hb-card-thumb{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.hb-card-placeholder{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border);justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.hb-card-info{flex:1;min-width:0}.hb-card-name{font-size:14px;font-weight:700}.hb-card-meta{color:var(--text-muted);font-size:12px}.hb-editor{flex-direction:column;gap:12px;display:flex}.hb-basics-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.hb-basics-grid label,.hb-combat-grid label,.hb-defenses label,.hb-traits label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:11px;font-weight:600;display:block}.hb-field-full{grid-column:1/-1}.hb-field select,.hb-field input,.hb-basics-grid select,.hb-basics-grid input,.hb-defenses input,.hb-traits input{background:var(--bg);width:100%;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:13px}.hb-field{flex-direction:column;display:flex}.hb-image-section{align-items:center;gap:12px;display:flex}.hb-image-preview{flex-shrink:0}.hb-image-thumb{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:56px;height:56px}.hb-image-controls{flex-wrap:wrap;gap:8px;display:flex}.hb-combat-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.hb-combat-grid input{background:var(--bg);width:100%;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:13px}.hb-ability-mod{color:var(--text-muted);text-align:center;font-size:11px;display:block}.hb-actions-list{flex-direction:column;gap:6px;display:flex}.hb-action-row{background:var(--bg);border:1px solid var(--border);border-radius:6px;overflow:hidden}.hb-action-summary{cursor:pointer;align-items:center;gap:8px;padding:8px 10px;display:flex}.hb-action-summary:hover{background:#ffffff08}.hb-action-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;font-weight:600;overflow:hidden}.hb-action-type-badge{background:var(--bg-elevated);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-radius:3px;padding:1px 6px;font-size:10px}.hb-action-dmg{color:var(--text-muted);font-size:12px}.hb-action-details{border-top:1px solid var(--border);padding:0 10px 10px}.hb-action-fields{grid-template-columns:1fr 1fr;gap:8px;padding-top:8px;display:grid}.hb-action-fields label{color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:10px;font-weight:600;display:block}.hb-action-fields input,.hb-action-fields select,.hb-action-fields textarea{background:var(--bg-elevated);width:100%;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:5px 8px;font-size:13px}.hb-action-fields textarea{resize:vertical;font-family:inherit}.hb-add-action-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.hb-add-label{color:var(--text-muted);font-size:12px;font-weight:600}.hb-defenses{flex-direction:column;gap:8px;display:flex}.hb-traits{flex-direction:column;gap:6px;display:flex}.hb-trait-row{align-items:center;gap:6px;display:flex}.hb-trait-row input{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;flex:1;padding:5px 8px;font-size:13px}.hb-editor-save{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.hb-clone-section{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;padding:12px}.hb-clone-results{overscroll-behavior:contain;flex-direction:column;gap:2px;max-height:200px;margin-top:6px;display:flex;overflow-y:auto}.hb-clone-item{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px 8px;font-size:13px}.hb-clone-item:hover{background:var(--bg-elevated)}.hb-spell-readonly{padding:8px 0}.hb-spell-desc{color:var(--text);font-size:13px;line-height:1.4}.hb-spell-meta{color:var(--text-muted);margin-top:4px;font-size:11px;font-style:italic}.hb-spell-picker{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-top:6px;padding:10px}.hb-spell-list{overscroll-behavior:contain;flex-direction:column;gap:1px;max-height:200px;margin-top:6px;display:flex;overflow-y:auto}@media (width<=767px){.hb-modal{width:100vw;height:100dvh;max-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);border-radius:0;position:fixed;inset:0}.hb-basics-grid{grid-template-columns:1fr}.hb-combat-grid{grid-template-columns:1fr 1fr}.hb-action-fields{grid-template-columns:1fr}.hb-basics-grid input,.hb-basics-grid select,.hb-combat-grid input,.hb-defenses input,.hb-action-fields input,.hb-action-fields select,.hb-action-fields textarea{min-height:44px;font-size:16px}.hb-clone-results,.hb-spell-list{max-height:50dvh}.hb-clone-item{min-height:44px;padding:10px 8px}}@media (hover:none){.monster-item:hover{border-color:var(--border);box-shadow:var(--shadow-sm);transform:none}.hb-clone-item:hover,.hb-action-summary:hover{background:0 0}.modal-close:hover{color:var(--text-muted);background:var(--bg-elevated-2)}}@media (width<=767px){.creature-picker-header{padding:6px 8px 4px}.team-toggle{margin-bottom:4px;padding:3px}.team-btn{min-height:40px;padding:7px 10px}.picker-mode-toggle{margin-bottom:4px;padding:3px}.picker-mode-btn{min-height:32px;padding:5px 8px;font-size:12px}.picker-search-row{flex-direction:row;align-items:stretch;gap:6px;margin-bottom:4px;display:flex}.picker-search-row .search-wrapper{flex:1}.picker-search-row .search-input{margin-bottom:0;padding:9px 12px 9px 34px;font-size:16px}.tactics-trigger{flex:none;width:auto;margin-bottom:0;padding:4px 10px;font-size:12px}.tactics-trigger-full{display:none}.tactics-trigger-short{font-weight:600;display:inline}.cr-filter-row{margin-bottom:0}.cr-filter-select{padding:8px 28px 8px 10px;font-size:13px}.monster-item{min-height:auto;padding:10px 12px}.monster-list{gap:6px;padding:8px 10px 10px}.monster-thumb{width:44px;height:44px}.monster-name{font-size:14px}.quick-add{gap:8px;padding:8px 12px}}.mobile{overscroll-behavior:none}@media (width<=767px){.mobile .creature-picker-header,.mobile .placing-bar,.mobile .tab-bar,.mobile .quick-add,.mobile .panel-tabs{touch-action:manipulation}.mobile .monster-list{touch-action:pan-y}.mobile .controls{touch-action:pan-x}.mobile{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.mobile input,.mobile textarea,.mobile [contenteditable]{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.mobile img,.mobile [draggable]{-webkit-user-drag:none}}.initiative-tracker{scrollbar-width:none;border-bottom:1px solid var(--border);background:#fff9;flex-direction:row;flex-shrink:0;align-items:center;gap:6px;padding:6px 8px;display:flex;overflow:auto hidden}.initiative-tracker::-webkit-scrollbar{display:none}.initiative-pill{cursor:pointer;transform-origin:50%;background:#ffffffd9;border:2px solid #0000;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;padding:0;transition:box-shadow .18s,opacity .18s;display:flex;position:relative;overflow:visible}.initiative-pill.red{border-color:#e11d48}.initiative-pill.blue{border-color:#2563eb}.initiative-portrait{object-fit:cover;border-radius:50%;width:36px;height:36px;display:block}.initiative-number{color:#fff;text-align:center;background:#1e1a16;border:1.5px solid #ffffffeb;border-radius:8px;min-width:14px;padding:2px 4px;font-family:Outfit,Inter,sans-serif;font-size:10px;font-weight:700;line-height:1;position:absolute;bottom:-4px;right:-4px}.initiative-pill.active{z-index:1;animation:1.6s ease-in-out infinite initiative-active-pulse;transform:scale(1.08);box-shadow:0 0 0 3px #22d3ee,0 0 12px #22d3ee8c}@keyframes initiative-active-pulse{0%,to{box-shadow:0 0 0 3px #22d3ee,0 0 12px #22d3ee8c}50%{box-shadow:0 0 0 4px #22d3ee,0 0 20px #22d3eecc}}.initiative-pill.dead{filter:grayscale();opacity:.45;cursor:default}.initiative-pill.dead .initiative-number{background:#6b6b6b;text-decoration:line-through}.initiative-pill.dead.active{animation:none;transform:scale(1);box-shadow:0 0 0 2px #22d3ee80}@media (width<=767px){.initiative-tracker{gap:5px;padding:4px 6px}.initiative-pill{width:38px;height:38px}.initiative-portrait{width:30px;height:30px}.initiative-number{padding:1.5px 3px;font-size:9px}}@media (hover:none){.initiative-pill:hover{transform:none}.initiative-pill.active:hover{transform:scale(1.08)}}
