:root{--bg: #060d1b;--bg2: #0c1628;--bg3: #111e33;--bg4: #172440;--border: rgba(148,163,184,.1);--border2: rgba(148,163,184,.18);--text: #e2e8f0;--text2: #94a3b8;--text3: #64748b;--blue: #3b82f6;--blue-bg: rgba(59,130,246,.1);--green: #22c55e;--green-bg: rgba(34,197,94,.1);--yellow: #f59e0b;--yellow-bg: rgba(245,158,11,.1);--red: #f87171;--red-bg: rgba(248,113,113,.1);--purple: #a78bfa;--purple-bg: rgba(167,139,250,.1);--c0: #3b82f6;--c0bg: rgba(59,130,246,.12);--c1: #22c55e;--c1bg: rgba(34,197,94,.12);--c2: #f59e0b;--c2bg: rgba(245,158,11,.12);--c3: #a78bfa;--c3bg: rgba(167,139,250,.12);--mono: "IBM Plex Mono", monospace;--sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.36)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;min-height:100vh;overflow-x:hidden}#toast{position:fixed;right:18px;bottom:18px;z-index:650;min-width:240px;max-width:min(420px,calc(100vw - 36px));padding:12px 14px;border-radius:12px;background:#0f172af5;border:1px solid rgba(59,130,246,.22);box-shadow:0 18px 42px #0000006b;color:#e2e8f0;font-size:13px;line-height:1.45;opacity:0;transform:translateY(10px);transition:opacity .18s ease,transform .18s ease;pointer-events:none}#toast.show{opacity:1;transform:translateY(0)}.task-alert-overlay{position:fixed;inset:0;z-index:640;background:#060d1be0;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}.task-alert-card{width:min(420px,100%);border-radius:18px;border:1px solid rgba(34,197,94,.2);background:linear-gradient(180deg,#091221fa,#0f172afa);box-shadow:0 30px 80px #0000008a;padding:22px 20px 18px;text-align:center}.task-alert-icon{width:52px;height:52px;border-radius:16px;margin:0 auto 14px;display:grid;place-items:center;background:var(--green-bg);border:1px solid rgba(34,197,94,.18);color:var(--green);font-size:22px;font-weight:800}.task-alert-title{font-size:18px;font-weight:700;letter-spacing:-.03em;color:var(--text)}.task-alert-sub{margin-top:8px;font-size:13px;line-height:1.6;color:var(--text2)}.task-alert-actions{margin-top:16px;display:flex;justify-content:center}.task-alert-btn{border:1px solid rgba(59,130,246,.24);background:#3b82f624;color:#bfdbfe;padding:10px 14px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer}#lobby{position:fixed;inset:0;z-index:500;background:#060d1bf5;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px}#lobby.hidden{display:none}.lobby-card{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:480px;overflow:hidden;box-shadow:0 32px 80px #0000008a,0 0 0 1px #94a3b80f}.lobby-header{padding:32px 32px 24px;text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(15,30,60,.6) 0%,transparent 100%)}.lobby-logo{width:48px;height:48px;margin:0 auto 16px;background:linear-gradient(135deg,#1d4ed8,#3b82f6);border:1px solid rgba(59,130,246,.4);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #3b82f640}.lobby-logo svg{width:24px;height:24px;color:#fff}.lobby-title{font-size:20px;font-weight:700;letter-spacing:-.03em;color:#fff}.lobby-sub{font-size:12px;color:var(--text3);margin-top:5px;letter-spacing:.01em}.lobby-stats-strip{padding:10px 32px 14px;font-size:11px;color:var(--text3);text-align:center;letter-spacing:.01em;border-top:1px solid var(--border2);margin-top:4px}.lobby-stats-strip span{color:var(--text2);font-family:var(--mono);font-weight:600}.lobby-auth-chip{display:flex;align-items:center;gap:7px;margin:10px 32px 0;padding:7px 12px;border-radius:9px;font-size:12px;font-weight:500;line-height:1.4}.lobby-auth-chip.lac-ok{background:#16a34a1a;border:1px solid rgba(22,163,74,.22);color:#4ade80}.lobby-auth-chip.lac-anon{background:#64748b14;border:1px solid rgba(100,116,139,.18);color:var(--text3)}.lobby-body{padding:28px 32px 32px}.lobby-step{display:none}.lobby-step.active{display:block}.lobby-field-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.lobby-input{width:100%;background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:var(--sans);font-size:14px;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.lobby-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.lobby-input::placeholder{color:var(--text3)}.lobby-room-availability{margin-top:10px;padding:10px 12px;border-radius:10px;border:1px solid rgba(59,130,246,.22);background:#3b82f614;color:#bfdbfe;font-size:12px;line-height:1.45}.lobby-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:18px;padding:4px;background:var(--bg);border:1px solid var(--border2);border-radius:10px}.lobby-tab{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 6px;background:transparent;border:none;border-radius:7px;color:var(--text3);font-family:var(--sans);font-size:12px;font-weight:600;cursor:pointer;transition:background .14s,color .14s}.lobby-tab:hover{color:var(--text2);background:#ffffff0a}.lobby-tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 4px #0000002e}.lobby-modes{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}.lobby-mode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;background:var(--bg);border:1px solid var(--border2);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s,transform .12s;color:var(--text2);text-align:center}.lobby-mode-btn:hover{border-color:var(--blue);color:var(--text);background:#3b82f60f;transform:translateY(-1px)}.lobby-mode-btn svg{width:28px;height:28px}.lobby-mode-btn .lmb-title{font-size:14px;font-weight:600}.lobby-mode-btn .lmb-sub{font-size:11px;color:var(--text3);line-height:1.4}.lobby-room-id-display{background:var(--bg);border:1px solid rgba(59,130,246,.25);border-radius:10px;padding:18px;text-align:center;margin:16px 0;cursor:pointer;transition:border-color .15s,box-shadow .15s}.lobby-room-id-display:hover{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61a}.lobby-room-label{font-size:11px;color:var(--text3);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.07em}.lobby-room-code{font-family:var(--mono);font-size:26px;font-weight:500;color:var(--blue);letter-spacing:.12em}.lobby-copy-hint{font-size:10px;color:var(--text3);margin-top:6px}.lobby-room-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:20px;font-size:10px;font-weight:600;background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.25);margin-left:8px;vertical-align:middle;text-transform:uppercase;letter-spacing:.06em;font-family:var(--mono)}.lobby-error{font-size:12px;color:var(--red);margin-top:8px;min-height:18px;display:flex;align-items:center;gap:5px}.lobby-actions{display:flex;gap:10px;margin-top:20px}.lobby-btn-back{flex-shrink:0;padding:10px 16px;border-radius:8px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-family:var(--sans);font-size:13px;cursor:pointer;transition:all .15s}.lobby-btn-back:hover{border-color:var(--border2);color:var(--text);background:var(--bg3)}.lobby-btn-primary{flex:1;padding:10px 18px;border-radius:8px;border:1px solid rgba(59,130,246,.5);background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px #1d4ed84d}.lobby-btn-primary:hover{background:linear-gradient(135deg,#2563eb,#3b82f6);box-shadow:0 6px 20px #1d4ed861}.lobby-btn-primary:disabled{opacity:.4;cursor:not-allowed}.lobby-btn-primary.loading:after{content:"";width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:spin .6s linear infinite;margin-left:6px}@keyframes spin{to{transform:rotate(360deg)}}.header{position:sticky;top:0;z-index:100;background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px;height:52px;display:flex;align-items:center;gap:0}.header-left{display:flex;flex-direction:column;justify-content:center;min-width:0;flex-shrink:0;padding:8px 0}.header-spacer{flex:1}.header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.header-sep{width:1px;height:22px;background:var(--border);margin:0 6px;flex-shrink:0}.header-title{font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--text);white-space:nowrap}.header-sub{font-size:11px;color:var(--text3);margin-top:1px;max-width:380px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clock{font-family:var(--mono);font-size:17px;font-weight:500;letter-spacing:.04em;color:var(--text2);min-width:76px;text-align:right}.insumos-toggle{display:inline-flex;align-items:center;gap:7px;cursor:pointer;user-select:none;font-size:12px;color:var(--text3);padding:4px 2px}.insumos-toggle input{display:none}.it-track{width:34px;height:18px;border-radius:9px;background:var(--bg4);border:1px solid var(--border2);position:relative;transition:background .2s,border-color .2s;flex-shrink:0}.it-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:var(--text3);transition:transform .2s,background .2s}.insumos-toggle input:checked~.it-track{background:var(--blue-bg);border-color:var(--blue)}.insumos-toggle input:checked~.it-track .it-thumb{transform:translate(16px);background:var(--blue)}.it-label{transition:color .2s}.insumos-toggle input:checked~.it-label{color:var(--text2)}.insumos-toggle:hover .it-label{color:var(--text)}.proposal-banner{display:flex;align-items:center;gap:10px;background:#f59e0b14;border-bottom:1px solid rgba(245,158,11,.3);padding:8px 24px;font-size:13px;color:var(--yellow)}.proposal-banner svg{color:var(--yellow)}#proposalText{flex:1}.prop-btn{padding:4px 14px;border-radius:6px;font-size:12px;font-weight:600;border:1px solid;cursor:pointer;transition:all .15s}.prop-approve{background:#22c55e1a;border-color:#22c55e66;color:var(--green)}.prop-approve:hover{background:#22c55e33}.prop-reject{background:#ef444414;border-color:#ef44444d;color:var(--red)}.prop-reject:hover{background:#ef444429}.part-input.proposing{border-color:#f59e0b80!important;background:#f59e0b0a!important;color:var(--yellow)!important}.room-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;border-radius:20px;background:var(--bg3);border:1px solid var(--border2);font-size:12px;font-family:var(--mono);color:var(--text2);cursor:pointer;transition:all .15s}.room-chip:hover{border-color:var(--blue);color:var(--text);box-shadow:0 0 0 3px #3b82f614}.room-chip .rc-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse-dot 2.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.45}}.room-chip .rc-role{font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.06em}.rc-host{background:var(--purple-bg);color:var(--purple)}.rc-guest{background:var(--blue-bg);color:var(--blue)}.btn{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:7px;border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-family:var(--sans);font-size:13px;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1}.btn:hover{border-color:var(--blue);color:var(--text);background:#3b82f614}.btn.active{background:var(--blue-bg);border-color:var(--blue);color:var(--blue)}.btn-upload{border-color:#3b82f659;color:var(--blue)}.btn-upload:hover{background:var(--blue-bg)}.btn-push{border-color:#a78bfa4d;color:var(--purple)}.btn-push:hover{background:var(--purple-bg);border-color:var(--purple)}.btn-sm{font-size:11px;padding:4px 10px}.btn svg{width:14px;height:14px;flex-shrink:0}.btn-push.active{background:var(--purple-bg);border-color:var(--purple);color:var(--purple)}.push-status{display:none}#closedBanner{display:none;background:var(--red-bg);border-bottom:1px solid rgba(248,113,113,.2);padding:9px 24px;font-size:12px;color:var(--red);align-items:center;gap:10px}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid var(--border)}.metric{background:var(--bg2);padding:16px 24px;border-right:1px solid var(--border)}.metric:last-child{border-right:none}.metric-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:4px}.metric-value{font-size:28px;font-family:var(--mono);font-weight:500;line-height:1}.mv-blue{color:var(--blue)}.mv-green{color:var(--green)}.mv-yellow{color:var(--yellow)}.mv-purple{color:var(--purple)}.progress-wrap{height:2px;background:var(--bg3)}.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,#1d4ed8,#3b82f6);transition:width .6s ease}.presence-bar{display:none;background:var(--bg);border-bottom:1px solid var(--border);padding:8px 24px;align-items:center;gap:12px;flex-wrap:wrap}.presence-bar.visible{display:flex}.presence-label{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.presence-players{display:flex;gap:6px;flex-wrap:wrap}.presence-player{display:inline-flex;align-items:center;gap:6px;padding:3px 10px 3px 6px;border-radius:20px;background:var(--bg2);border:1px solid var(--border);font-size:11px;color:var(--text2);white-space:nowrap;transition:border-color .15s}.presence-player.is-self{border-color:#3b82f666;color:var(--blue);background:var(--blue-bg)}.presence-player.is-host{border-color:#a78bfa4d}.pp-avatar{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.pp-name{font-size:11px}.pp-crown{font-size:10px}.presence-leave{margin-left:auto;font-size:11px;color:var(--text3);cursor:pointer;padding:3px 8px;border-radius:6px;border:1px solid transparent;transition:all .15s}.presence-leave:hover{border-color:var(--red);color:var(--red)}.presence-summary{font-size:11px;color:var(--purple);cursor:pointer;padding:3px 8px;border-radius:6px;border:1px solid rgba(167,139,250,.25);background:var(--purple-bg);transition:all .15s}.presence-summary:hover{border-color:var(--purple)}.presence-summary.active{color:var(--green);border-color:#22c55e40;background:var(--green-bg)}.config-panel{background:var(--bg2);border-bottom:1px solid var(--border);padding:12px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.config-label{font-size:12px;color:var(--text2);white-space:nowrap;font-weight:500}.participant-inputs{display:flex;gap:10px;flex:1;flex-wrap:wrap}.part-input-wrap{display:flex;align-items:center;gap:6px}.part-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.p0{background:var(--c0)}.p1{background:var(--c1)}.p2{background:var(--c2)}.p3{background:var(--c3)}.part-input{background:var(--bg);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--sans);font-size:12px;padding:4px 10px;width:148px;transition:border-color .15s}.part-input:focus{outline:none;border-color:var(--blue)}.layout-sync-panel{display:none;grid-template-columns:1fr;gap:14px;background:linear-gradient(180deg,#0c1628f0,#080e1bf5);border-bottom:1px solid var(--border);padding:18px 24px 20px}.layout-sync-panel.is-collapsed{gap:8px}.layout-sync-panel.is-collapsed .layout-sync-controls,.layout-sync-panel.is-collapsed .layout-sync-stats,.layout-sync-panel.is-collapsed .layout-sync-grid{display:none}.layout-sync-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.layout-sync-controls{display:flex;flex-direction:column;align-items:flex-end;gap:8px;min-width:220px}.layout-collapse-btn{align-self:flex-end}.layout-sync-select-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}.layout-sync-select{width:100%;max-width:300px;padding:9px 12px;border-radius:10px;border:1px solid var(--border2);background:#060d1be6;color:var(--text);font-family:var(--sans);font-size:13px}.layout-sync-select:focus{outline:none;border-color:#3b82f673;box-shadow:0 0 0 3px #3b82f624}.layout-sync-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);font-weight:700}.layout-sync-title{font-size:16px;font-weight:700;color:var(--text);margin-top:4px}.layout-sync-sub{font-size:12px;color:var(--text2);margin-top:4px}.layout-sync-chip{flex-shrink:0;padding:6px 10px;border-radius:999px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--purple);border:1px solid rgba(167,139,250,.24);background:var(--purple-bg)}.layout-sync-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.layout-sync-stat{padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#0a1221b8}.layout-sync-stat span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:700}.layout-sync-stat strong{display:block;margin-top:6px;font-size:15px;font-family:var(--mono);color:var(--text)}.layout-sync-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.layout-sync-field{border:1px solid var(--border);border-radius:12px;padding:12px 14px;background:#070c16cc;box-shadow:inset 0 1px #ffffff05}.layout-sync-field.is-active{border-color:#3b82f652;background:linear-gradient(180deg,#3b82f614,#070c16e0)}.layout-sync-field-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:700}.layout-sync-field-value{margin-top:6px;font-size:13px;color:var(--text);font-weight:600}.layout-sync-field-meta{margin-top:4px;font-size:11px;color:var(--text2);font-family:var(--mono)}.panel-collapse-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:1px solid var(--border2);background:var(--bg2);cursor:pointer;color:var(--text3);flex-shrink:0;transition:background .12s,color .12s}.panel-collapse-btn:hover{background:var(--bg3);color:var(--text)}.panel-collapse-btn svg{width:12px;height:12px}.admin-panel-card{display:none;margin:12px 0 0;padding:14px 24px 18px;background:linear-gradient(180deg,#f851490d,#080e1bf5);border-top:1px solid rgba(248,81,73,.16);border-bottom:1px solid rgba(148,163,184,.1)}.admin-panel-card.is-collapsed .admin-actions,.admin-panel-card.is-collapsed .admin-list-title,.admin-panel-card.is-collapsed .admin-list{display:none!important}.admin-head-actions{display:flex;align-items:center;gap:10px}.admin-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.admin-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);font-weight:700}.admin-title{font-size:15px;font-weight:700;color:var(--text);margin-top:4px}.admin-sub{font-size:12px;color:var(--text2);margin-top:4px}.admin-badge{flex-shrink:0;padding:6px 10px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.22)}.admin-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.admin-list-title{margin-top:14px;margin-bottom:8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:700}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-participant-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:#0a1221c7}.admin-participant-meta{min-width:0}.admin-participant-name{font-size:13px;color:var(--text);font-weight:600}.admin-participant-id{margin-top:2px;font-size:10px;color:var(--text3);font-family:var(--mono)}.admin-participant-actions{display:flex;gap:8px;flex-shrink:0}.admin-mini-btn{border-radius:8px;padding:6px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--border2);background:transparent;color:var(--text2);cursor:pointer}.admin-mini-btn.is-danger{border-color:#f8717159;color:var(--red)}.admin-mini-btn.is-danger:hover{background:#f8717114}.admin-mini-btn.is-muted{opacity:.5;cursor:not-allowed}.freeze-overlay{position:fixed;inset:0;z-index:9999;display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#030712e0;backdrop-filter:blur(6px);text-align:center;padding:24px}.freeze-emoji{font-size:48px}.freeze-title{font-size:18px;font-weight:700;color:var(--yellow);letter-spacing:.02em}.freeze-sub{max-width:440px;font-size:13px;color:var(--text2)}.summary-layout-audit{display:none;margin-top:10px;padding:14px;border-radius:12px;border:1px solid rgba(59,130,246,.2);background:#3b82f60f}.summary-layout-audit-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.summary-layout-audit-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);font-weight:700}.summary-layout-audit-title{margin-top:4px;font-size:15px;font-weight:700;color:var(--text)}.summary-layout-audit-source{flex-shrink:0;padding:5px 10px;border-radius:999px;border:1px solid rgba(59,130,246,.2);background:#3b82f61a;color:#bfdbfe;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.summary-layout-audit-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.summary-layout-audit-pill{border:1px solid rgba(148,163,184,.14);border-radius:10px;padding:8px 10px;background:#070c16c7;font-size:11px}.summary-layout-audit-pill strong{display:block;font-size:12px;color:var(--text);margin-bottom:3px}.summary-layout-audit-pill span{color:var(--text2);font-family:var(--mono)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px;gap:14px;color:var(--text3);text-align:center}.empty-state svg{width:40px;height:40px;opacity:.25}.empty-state .empty-title{font-size:16px;font-weight:500;color:var(--text2)}.empty-state .empty-sub{font-size:13px;max-width:360px;line-height:1.6}.act-row{display:grid;grid-template-columns:48px 80px minmax(0,1fr) minmax(160px,220px) minmax(110px,150px);gap:12px 16px;align-items:start;padding:12px 20px;border-bottom:1px solid var(--border);border-left:3px solid transparent;transition:background .12s,border-left-color .15s;background:var(--bg)}@media (max-width: 960px){.act-row{grid-template-columns:40px 70px minmax(0,1fr);grid-template-rows:auto auto}.act-row>.act-assign-col{grid-column:2 / -1}.act-row>.act-status{grid-column:2 / -1;display:flex;flex-wrap:wrap;gap:8px;align-items:center}}.act-row:hover{background:var(--bg2)}.act-row.state-done{opacity:.44}.act-row.state-warn{border-left-color:var(--yellow)}.act-row.state-ok{border-left-color:#22c55e8c}.act-num{font-family:var(--mono);font-size:20px;font-weight:500;color:var(--text3);text-align:center;padding-top:3px}.act-qa-col{display:flex;flex-direction:column;gap:5px;padding-top:3px}.qa-pill{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;font-family:var(--mono);width:fit-content}.qa-ok{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.2)}.qa-warn{background:var(--yellow-bg);color:var(--yellow);border:1px solid rgba(245,158,11,.2)}.qa-none{background:var(--bg3);color:var(--text3);border:1px solid var(--border)}.act-sistemas{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.act-fase{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.act-desc{font-size:12px;color:var(--text2);line-height:1.5}.act-monto{font-family:var(--mono);font-size:12px;color:var(--blue);margin-top:3px}.act-time-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.act-time-field{display:flex;flex-direction:column;gap:4px}.act-time-field span{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3)}.act-time-picker{position:relative;display:flex;align-items:center;min-height:38px}.act-time-btn{width:38px;height:38px;border-radius:11px;border:1px solid rgba(59,130,246,.18);background:#3b82f61a;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:inset 0 1px #ffffff8c}.act-time-btn svg{width:16px;height:16px}.act-time-input{position:absolute;inset:0;width:100%;opacity:0;pointer-events:auto;cursor:pointer;z-index:1}.act-time-input:focus{outline:none;border-color:transparent;box-shadow:none}.act-time-preview{font-size:11px;color:var(--text2);font-family:var(--mono);line-height:1.3;min-height:14px}.badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.badge-ip{background:var(--blue-bg);color:var(--blue);border:1px solid rgba(59,130,246,.2)}.badge-gem{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.2)}.badge-spei{background:var(--blue-bg);color:var(--blue);border:1px solid rgba(59,130,246,.2)}.badge-spid,.badge-all{background:var(--purple-bg);color:var(--purple);border:1px solid rgba(167,139,250,.2)}.act-assign-col{display:flex;flex-direction:column;gap:8px}.assign-selector{display:flex;gap:5px;flex-wrap:wrap}.assign-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px 3px 6px;border-radius:20px;border:1px solid var(--border2);background:var(--bg2);cursor:pointer;transition:all .12s;font-size:11px;color:var(--text3);font-family:var(--sans);white-space:nowrap;user-select:none}.assign-pill:hover{color:var(--text2);background:var(--bg3)}.assign-pill .pdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.assign-pill.sel-0{border-color:var(--c0);color:var(--c0);background:var(--c0bg)}.assign-pill.sel-1{border-color:var(--c1);color:var(--c1);background:var(--c1bg)}.assign-pill.sel-2{border-color:var(--c2);color:var(--c2);background:var(--c2bg)}.assign-pill.sel-3{border-color:var(--c3);color:var(--c3);background:var(--c3bg)}.assign-hint{font-size:10px;color:var(--text3);font-style:italic}.assign-divider{height:1px;background:var(--border)}.chk-rows{display:flex;flex-direction:column;gap:5px;min-height:20px}.chk-row{display:flex;align-items:center;gap:7px;cursor:pointer}.chk-box{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}.chk-box svg{width:9px;height:9px;stroke:var(--green);display:none}.chk-box.c0{border-color:var(--c0)}.chk-box.c1{border-color:var(--c1)}.chk-box.c2{border-color:var(--c2)}.chk-box.c3{border-color:var(--c3)}.chk-box.checked.c0{background:var(--c0bg)}.chk-box.checked.c0 svg{stroke:var(--c0);display:block}.chk-box.checked.c1{background:var(--c1bg)}.chk-box.checked.c1 svg{stroke:var(--c1);display:block}.chk-box.checked.c2{background:var(--c2bg)}.chk-box.checked.c2 svg{stroke:var(--c2);display:block}.chk-box.checked.c3{background:var(--c3bg)}.chk-box.checked.c3 svg{stroke:var(--c3);display:block}.chk-name{font-size:12px;color:var(--text2);transition:color .12s}.chk-row:hover .chk-name{color:var(--text)}.no-assigned{font-size:11px;color:var(--text3);font-style:italic}.act-status{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.status-pill{font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;white-space:nowrap;font-family:var(--mono)}.sp-pending{background:var(--bg3);color:var(--text3);border:1px solid var(--border)}.sp-partial{background:var(--blue-bg);color:var(--blue);border:1px solid rgba(59,130,246,.25)}.sp-done{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.25)}.act-pct{font-size:11px;color:var(--text3);font-family:var(--mono)}.btn-detail{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);color:var(--text3);font-size:11px;font-family:var(--sans);cursor:pointer;transition:all .12s;white-space:nowrap}.btn-detail:hover{border-color:var(--blue);color:var(--text);background:#3b82f614}.btn-detail.open{border-color:var(--blue);color:var(--blue);background:var(--blue-bg)}.btn-detail svg{width:11px;height:11px;transition:transform .2s}.btn-detail.open svg{transform:rotate(180deg)}.focus-viewers{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--blue);margin-top:3px;font-family:var(--mono);letter-spacing:.01em}.focus-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;animation:focus-pulse 1.6s ease-in-out infinite}@keyframes focus-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.65)}}.act-dl-row{display:flex;align-items:center;gap:4px}.btn-dl-card{display:inline-flex;align-items:center;gap:3px;padding:4px 8px;border-radius:6px;border:1px solid rgba(59,130,246,.3);background:var(--blue-bg);color:var(--blue);font-size:11px;font-family:var(--sans);cursor:pointer;transition:all .12s;white-space:nowrap;font-weight:500}.btn-dl-card:hover{border-color:var(--blue);background:#3b82f629}.detail-panel{display:none;background:var(--bg2);border-bottom:1px solid var(--border);border-left:3px solid rgba(59,130,246,.35);padding:0 24px 20px}.detail-panel.open{display:block}.detail-hdr{padding:14px 0 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.detail-hdr-title{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;font-family:var(--mono)}.detail-actions{display:flex;gap:8px;flex-wrap:wrap}.insumo-list{display:flex;flex-direction:column;gap:10px}.insumo-block{background:var(--bg3);border:1px solid var(--border);border-radius:10px;overflow:hidden}.insumo-head{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.insumo-filename{font-family:var(--mono);font-size:12px;color:var(--blue);display:flex;align-items:center;gap:8px}.insumo-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:11px;color:var(--text2)}.insumo-actions{display:flex;gap:6px;flex-shrink:0}.insumo-warns{margin:0 14px 10px;background:var(--yellow-bg);border:1px solid rgba(245,158,11,.2);border-radius:6px;padding:8px 12px;font-size:11px;color:var(--yellow);line-height:1.6}.insumo-warns b{display:block;margin-bottom:2px}.trace-wrap{overflow-x:auto;border-top:1px solid var(--border);max-height:220px;overflow-y:auto}.trace-table{width:100%;border-collapse:collapse;font-size:11px;font-family:var(--mono);white-space:nowrap}.trace-table th{text-align:left;padding:5px 10px;color:var(--text3);background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;font-weight:600;letter-spacing:.04em}.trace-table td{padding:4px 10px;color:var(--text2);border-bottom:1px solid rgba(255,255,255,.03);max-width:200px;overflow:hidden;text-overflow:ellipsis}.trace-table tr:last-child td{border-bottom:none}.trace-table tr:hover td{background:#ffffff05;color:var(--text)}.trace-more{padding:6px 14px 10px;font-size:11px;color:var(--text3);font-style:italic}.insumo-empty{padding:10px 14px;font-size:11px;color:var(--red)}.summary-overlay{position:fixed;inset:0;z-index:520;background:#060d1be0;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}.summary-card{width:100%;max-width:1040px;max-height:92vh;overflow:hidden;background:var(--bg2);border:1px solid var(--border2);border-radius:16px;box-shadow:0 32px 80px #00000080;display:flex;flex-direction:column}.summary-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 18px;border-bottom:1px solid var(--border)}.summary-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:600;margin-bottom:6px}.summary-title{font-size:22px;font-weight:700;letter-spacing:-.03em}.summary-sub{font-size:12px;color:var(--text2);margin-top:4px}.summary-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text2);cursor:pointer;transition:all .15s;font-size:20px;line-height:1}.summary-close:hover{color:var(--text);border-color:var(--red);background:var(--red-bg)}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:18px 24px 10px}.summary-stat{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.summary-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:600;margin-bottom:6px}.summary-stat-value{font-size:22px;font-family:var(--mono);color:var(--text)}.summary-stat-hint{font-size:11px;color:var(--text2);margin-top:4px}.summary-section{padding:14px 24px 0;overflow-y:auto}.summary-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:10px}.summary-body{display:grid;gap:10px}.summary-activity{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.summary-activity-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.summary-activity-title{font-size:15px;font-weight:600}.summary-activity-sub{font-size:12px;color:var(--text2);margin-top:3px}.summary-activity-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.summary-activity-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 14px;margin-top:14px}.summary-activity-grid div{background:var(--bg4);border:1px solid var(--border);border-radius:8px;padding:10px 12px}.summary-activity-grid span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:4px;font-weight:600}.summary-activity-grid strong{font-size:13px;font-weight:600;color:var(--text)}.lobby-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;padding:14px 32px 18px;border-top:1px solid var(--border2);margin-top:8px}.lobby-stat{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;border-right:1px solid var(--border2)}.lobby-stat:last-child{border-right:none}.lobby-stat span{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3)}.lobby-stat strong{font-size:22px;font-weight:800;font-family:var(--mono);color:var(--text);line-height:1}@media (max-width: 900px){.header{padding:0 16px}.header-sep{margin:0 3px}.clock{font-size:14px;min-width:60px}.it-label{display:none}.lobby-stats{grid-template-columns:repeat(2,minmax(0,1fr));padding:12px 18px 0}}@media (max-width: 700px){.header-left .header-sub,#uploadLabel,#pushBtnLabel{display:none}.btn{padding:6px 10px}.header{height:auto;min-height:52px;padding:8px 12px;flex-wrap:wrap}.header-spacer{display:none}.header-right{flex-wrap:wrap;gap:4px}.lobby-stats{padding:10px 14px 0;grid-template-columns:1fr}.lobby-stat strong{font-size:18px}}
