*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{color:#1a1a2e;overscroll-behavior:none;background:#f8f7f4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}button{cursor:pointer;appearance:none;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:#f0f0f0}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.controls{background:#fff;border-bottom:1px solid #e5e5e5;flex-wrap:wrap;align-items:center;gap:6px;min-height:44px;padding:8px 12px;display:flex}.controls .logo{color:#6d28d9;margin-right:8px;font-size:18px;font-weight:900}.controls .logo span{color:#1a1a2e}.btn{border-radius:8px;min-height:44px;padding:8px 14px;font-size:13px;font-weight:600}.btn-primary{color:#fff;background:linear-gradient(135deg,#6d28d9,#4f46e5)}.btn-primary:disabled{color:#999;cursor:default;background:#e5e5e5}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:disabled{color:#999;cursor:default}.btn-danger{color:#dc2626;background:#fef2f2}.btn-sm{border-radius:6px;min-height:32px;padding:4px 10px;font-size:11px}.btn-active{color:#fff;background:#6d28d9}.status{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:#dc2626}.dot-blue{background:#2563eb}.count-red{color:#dc2626;font-family:monospace;font-weight:700}.count-blue{color:#2563eb;font-family:monospace;font-weight:700}.vs{color:#9ca3af;font-weight:700}.panel{background:#fff;border:1px solid #e5e5e5;border-radius:0}.panel-header{border-bottom:1px solid #e5e5e5;padding:10px 12px}.panel-header h3{text-transform:uppercase;letter-spacing:1px;color:#6b7280;font-size:12px;font-weight:700}.team-toggle{gap:4px;margin-bottom:8px;display:flex}.team-btn{color:#6b7280;background:#f3f4f6;border-radius:8px;flex:1;padding:10px;font-size:13px;font-weight:700}.team-btn.active-red{color:#fff;background:#dc2626}.team-btn.active-blue{color:#fff;background:#2563eb}.search-input{color:#1a1a2e;background:#fafafa;border:1px solid #e5e5e5;border-radius:8px;outline:none;width:100%;margin-bottom:8px;padding:10px 12px;font-size:14px}.search-input:focus{border-color:#6d28d9}.cr-filters{flex-wrap:wrap;gap:3px;margin-bottom:8px;display:flex}.cr-btn{color:#6b7280;background:#f3f4f6;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:500}.cr-btn.active{color:#fff;background:#6d28d9}.monster-list{-webkit-overflow-scrolling:touch;overflow-y:auto}.monster-item{text-align:left;color:#1a1a2e;cursor:pointer;background:#fff;border-bottom:1px solid #f3f4f6;border-left:3px solid #0000;width:100%;min-height:44px;padding:12px;display:block}.monster-item:active{background:#f8f7f4}.monster-item.selected{background:#f5f3ff;border-left-color:#6d28d9}.monster-name{font-size:14px;font-weight:600}.monster-cr{color:#6d28d9;font-family:monospace;font-size:12px}.monster-meta{color:#6b7280;margin-top:2px;font-size:11px}.quick-add{background:#fafafa;border-bottom:1px solid #e5e5e5;align-items:center;gap:6px;padding:8px 12px;display:flex}.quick-add input[type=number]{text-align:center;border:1px solid #e5e5e5;border-radius:6px;width:50px;padding:6px;font-size:13px}.quick-add .btn{flex:1}.grid-wrapper{contain:strict;background:#fff;border:1px solid #e5e5e5;border-radius:8px;position:relative;overflow:hidden}.grid-wrapper canvas{touch-action:none;display:block}.grid-info{color:#6b7280;background:#ffffffe6;border-radius:4px;padding:3px 8px;font-family:monospace;font-size:11px;position:absolute;top:8px;left:8px}.grid-zoom{gap:4px;display:flex;position:absolute;bottom:8px;right:8px}.grid-zoom button{color:#374151;background:#fffffff2;border-radius:6px;padding:6px 12px;font-size:14px;font-weight:700;box-shadow:0 1px 3px #0000001a}.grid-empty{pointer-events:none;justify-content:center;align-items:center;max-width:100%;max-height:100%;display:flex;position:absolute;inset:0}.grid-empty-card{text-align:center;background:#fffffff2;border:1px solid #e5e5e5;border-radius:12px;max-width:260px;padding:20px;box-shadow:0 4px 12px #0000000d}.results{background:#fafafa;border-top:1px solid #e5e5e5;padding:10px 12px;font-size:12px}.results .label{color:#6b7280}.results .win-red{color:#dc2626;font-weight:700}.results .win-blue{color:#2563eb;font-weight:700}.log-entry{border-bottom:1px solid #f3f4f6;padding:4px 8px;font-size:12px;line-height:1.6}.log-round{color:#6b7280;margin-right:6px;font-family:monospace}.log-actor{margin-right:4px;font-weight:600}.log-details{color:#6b7280}.stat-block{padding:12px;font-size:13px}.stat-block h3{margin-bottom:4px;font-size:16px;font-weight:700}.stat-block .meta{color:#6b7280;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:#f8f7f4;border-radius:6px;padding:6px 2px}.ability-label{color:#6b7280;text-transform:uppercase;font-size:10px}.ability-score{font-weight:700}.ability-mod{color:#6d28d9;font-size:11px}.tab-bar{padding-bottom:env(safe-area-inset-bottom,0px);background:#fff;border-top:1px solid #e5e5e5;display:flex}.tab-btn{text-align:center;color:#6b7280;background:#fff;flex:1;min-height:48px;padding:12px 0;font-size:12px;font-weight:700}.tab-btn.active{color:#6d28d9;background:#f5f3ff}.placing-bar{border-bottom:1px solid #e5e5e5;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.placing-bar.red{color:#dc2626;background:#fef2f2}.placing-bar.blue{color:#2563eb;background:#eff6ff}.panel-tabs{border-bottom:1px solid #e5e5e5;display:flex}.panel-tab{text-align:center;color:#6b7280;background:#fff;flex:1;padding:10px;font-size:12px;font-weight:700}.panel-tab.active{color:#6d28d9;border-bottom:2px solid #6d28d9}.progress-bar{background:#e5e5e5;border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill{background:#6d28d9;height:100%;transition:width .3s}
