:root{color-scheme:light dark;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background-color:#0f172a;color:#e2e8f0;line-height:1.4}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b 55%,#0f172a)}.monitor-app{min-height:100vh;display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem}.toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding:1.5rem;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toolbar h1{margin:0;font-size:1.75rem;font-weight:700;color:#f8fafc}.toolbar__subtitle{margin:.35rem 0 0;color:#cbd5f5;font-size:.95rem}.toolbar__filters{display:flex;flex-direction:column;gap:.75rem;min-width:420px}.filter-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.filter-row label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:#cbd5f5}.filter-row input,.filter-row select{padding:.45rem .6rem;border-radius:.6rem;border:1px solid rgba(148,163,184,.3);background:#0f172abf;color:#f8fafc;min-width:140px}.toggle{display:inline-flex;gap:.4rem;align-items:center;font-size:.9rem}.button{padding:.45rem .9rem;border-radius:.6rem;border:1px solid rgba(99,102,241,.6);background:#4f46e533;color:#e0e7ff;cursor:pointer;transition:background .2s ease,transform .15s ease}.button:hover{background:#4f46e559;transform:translateY(-1px)}.button:disabled{opacity:.6;cursor:not-allowed;transform:none}.last-updated,.summary{font-size:.85rem;color:#a5b4fc}.error-banner{background:#f8717126;border:1px solid rgba(248,113,113,.4);color:#fecaca;padding:.75rem 1rem;border-radius:.75rem}.layout{flex:1;display:grid;gap:1.5rem;grid-template-columns:minmax(320px,420px) minmax(0,1fr)}.interaction-list{display:flex;flex-direction:column;gap:.75rem;padding-right:.25rem;overflow-y:auto;max-height:calc(100vh - 220px)}.empty-state{padding:1rem;border-radius:.75rem;text-align:center;background:#94a3b81f;color:#cbd5f5}.interaction-card{border:1px solid transparent;background:#0f172ab3;border-radius:.9rem;padding:.9rem;text-align:left;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:.75rem;transition:transform .2s ease,border-color .2s ease,background .2s ease}.interaction-card:hover{transform:translateY(-2px);border-color:#818cf866}.interaction-card--active{border-color:#6366f1b3;background:#312e8199}.interaction-card__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.interaction-card__title{font-size:1rem;font-weight:600;color:#f1f5f9}.interaction-card__meta{display:flex;gap:.75rem;font-size:.85rem;color:#a5b4fc}.interaction-card__time{font-size:.8rem;color:#cbd5f5}.interaction-card__error{font-size:.8rem;color:#fca5a5;background:#f8717126;border-radius:.6rem;padding:.35rem .5rem}.details{background:#0f172aa6;border:1px solid rgba(148,163,184,.25);border-radius:1rem;padding:1.25rem;overflow-y:auto}.empty-detail{height:100%;display:grid;place-items:center;font-size:1.1rem;color:#cbd5f5;opacity:.75}.detail-panel{display:flex;flex-direction:column;gap:1.5rem}.detail-panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.detail-panel__header h2{margin:0;font-size:1.5rem;color:#f8fafc}.detail-panel__header p{margin:.35rem 0 0;color:#cbd5f5}.detail-panel__status{display:flex;gap:.75rem;align-items:center}.detail-panel__grid{display:grid;gap:1rem 1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.detail-block{background:#1e293bbf;border-radius:.85rem;padding:1rem;border:1px solid rgba(148,163,184,.2)}.detail-block h4{margin:0 0 .5rem;font-size:1rem;color:#e2e8f0}.detail-block pre{margin:0;white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.5;background:#0f172a99;border-radius:.75rem;padding:.75rem;border:1px solid rgba(99,102,241,.15)}.detail-block--meta p{margin:.35rem 0;font-size:.9rem;color:#dbeafe}.detail-error{color:#fca5a5}.detail-panel__timeline{background:#1e293bbf;border-radius:.85rem;padding:1rem 1.25rem;border:1px solid rgba(148,163,184,.2)}.detail-panel__timeline h3{margin-top:0;margin-bottom:.75rem;color:#f1f5f9}.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem}.timeline--loading,.timeline--error,.timeline--empty{color:#cbd5f5;font-size:.95rem}.timeline--error{color:#fca5a5}.timeline__item{border-left:2px solid rgba(99,102,241,.4);padding-left:1rem;position:relative}.timeline__item:before{content:"";position:absolute;left:-9px;top:6px;width:12px;height:12px;border-radius:50%;background:#818cf8cc;box-shadow:0 0 0 4px #818cf826}.timeline__header{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.timeline__time{font-size:.8rem;color:#cbd5f5}.timeline__content p{margin:.25rem 0;color:#dbeafe;font-size:.9rem}.timeline__error{color:#fca5a5}.timeline details{margin-top:.5rem;font-size:.85rem;color:#e0e7ff}.timeline details pre{margin-top:.5rem;background:#0f172a8c;padding:.75rem;border-radius:.75rem;border:1px solid rgba(129,140,248,.2)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.badge--pending{background:#94a3b840;color:#e2e8f0}.badge--retrying{background:#facc1540;color:#facc15}.badge--success{background:#22c55e33;color:#4ade80}.badge--failed{background:#f8717133;color:#f87171}.badge--rejected{background:#f472b633;color:#f472b6}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .55rem;border-radius:999px;background:#4f46e533;color:#a5b4fc;font-size:.75rem}.chip__sub{color:#cbd5f5}@media (max-width: 1100px){.layout{grid-template-columns:1fr}.interaction-list{max-height:none;order:2}.details{order:1}}@media (max-width: 768px){.monitor-app{padding:1rem}.toolbar{flex-direction:column}.toolbar__filters{width:100%;min-width:unset}.filter-row{flex-direction:column;align-items:stretch}.filter-row input,.filter-row select{width:100%}.button,.toggle,.last-updated,.summary{width:100%;text-align:left}}.game-ui-container-wrapper{width:100%;height:80vh;min-height:600px;background:#f8fafc;display:flex;flex-direction:column;position:relative;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;margin-top:1rem}.role-detail-view{display:flex;flex-direction:column;height:auto;min-height:100%;padding-bottom:80px}.nexus-status-bar{width:100%;padding:12px 24px;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -2px 10px #0000001a;font-size:15px;font-weight:500;text-align:center;transition:all .3s ease;position:fixed;bottom:0;left:0;right:0;z-index:1000;color:#374151;display:flex;align-items:center;justify-content:center;gap:16px;min-height:56px}.status-indicator-left{position:absolute;left:24px;padding:4px 12px;background:#f3f4f6;border-radius:6px;font-size:13px;font-weight:600;color:#6b7280;letter-spacing:.5px;white-space:nowrap}.status-message-content{display:inline-block;flex:0 1 auto;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nexus-status-bar.error-state{border-top:1px solid #fee2e2;background:#fffcfc}.nexus-status-bar.error-state .status-message-content{color:#dc2626}@media (prefers-color-scheme: dark){.nexus-status-bar{background:#1e293b;color:#f8fafc;border-color:#94a3b833;box-shadow:0 -4px 12px #0000004d}.status-indicator-left{background:#94a3b833;color:#94a3b8}.nexus-status-bar.error-state{background:#2d1a1a;border-color:#7f1d1d}.nexus-status-bar.error-state .status-message-content{color:#f87171}}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#1e293b,#0f172a);z-index:1000;padding:1.5rem}.auth-form{width:100%;max-width:400px;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:1.5rem;padding:2.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;gap:1.5rem}.auth-form h2{margin:0;font-size:1.75rem;text-align:center;color:#f8fafc}.auth-form p{margin:-1rem 0 .5rem;text-align:center;color:#94a3b8;font-size:.9rem}.auth-field{display:flex;flex-direction:column;gap:.5rem}.auth-field label{font-size:.85rem;font-weight:600;color:#cbd5e1}.auth-field input{padding:.75rem 1rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.3);background:#0f172a;color:#f8fafc;font-size:1rem}.auth-field input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.auth-form .button{padding:.85rem;font-size:1rem;font-weight:600;background:#4f46e5;border:none;color:#fff;margin-top:.5rem}.auth-form .button:hover{background:#4338ca}.logout-button{background:#f8717126!important;border-color:#f871714d!important}.logout-button:hover{background:#f8717140!important}.menu-view{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:4rem 2rem;flex:1}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;width:100%;max-width:900px}.menu-card{background:#1e293b99;border:1px solid rgba(148,163,184,.2);border-radius:1.5rem;padding:2.5rem;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:1.5rem}.menu-card:hover{background:#312e8166;border-color:#6366f180;transform:translateY(-5px);box-shadow:0 10px 25px -5px #0000004d}.menu-card h2{margin:0;color:#f8fafc;font-size:1.5rem}.menu-card p{margin:0;color:#94a3b8;font-size:1rem;line-height:1.5}.menu-card .icon{font-size:3.5rem;margin-bottom:.5rem}.rooms-view{display:flex;flex-direction:column;gap:1.5rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.room-search-bar{display:flex;gap:1rem;width:100%;background:#0f172a99;padding:1.25rem;border-radius:1rem;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.room-search-bar input{flex:1;padding:.75rem 1rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.3);background:#0f172acc;color:#fff;font-size:1rem}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.room-card{background:#1e293b99;border:1px solid rgba(148,163,184,.2);border-radius:1rem;padding:1.5rem;cursor:pointer;transition:all .2s ease}.room-card:hover{border-color:#6366f1;transform:translateY(-2px);background:#1e293bcc}.room-card h3{margin:0 0 .5rem;color:#f8fafc;word-break:break-all;font-size:1.1rem}.room-card .room-id{font-size:.85rem;color:#94a3b8;font-family:Fira Code,monospace}.room-detail-view{display:flex;flex-direction:column;gap:1.5rem;animation:fadeIn .3s ease}.room-detail-header{display:flex;justify-content:space-between;align-items:center}.json-viewer{background:#020617;border-radius:1rem;padding:1.5rem;border:1px solid rgba(148,163,184,.2);overflow-x:auto;box-shadow:inset 0 2px 4px #0000000f}.json-viewer pre{margin:0;color:#10b981;font-family:Fira Code,Courier New,monospace;font-size:.85rem;line-height:1.6}.nav-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.back-button{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid rgba(148,163,184,.3);color:#cbd5f5;padding:.4rem .8rem;border-radius:.5rem;cursor:pointer;font-size:.9rem}.back-button:hover{background:#ffffff0d;border-color:#cbd5f5}.view-toggle{display:flex;background:#0f172a99;padding:.25rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.2);margin-left:1rem}.view-toggle button{padding:.4rem 1rem;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-radius:.5rem;font-size:.85rem;transition:all .2s ease}.view-toggle button.active{background:#4f46e5;color:#fff;box-shadow:0 4px 12px #4f46e533}.room-visual{display:flex;flex-direction:column;gap:1.5rem}.section-title{font-size:1.1rem;font-weight:600;color:#f1f5f9;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-card{background:#1e293b80;border:1px solid rgba(148,163,184,.1);padding:1rem;border-radius:.75rem;display:flex;flex-direction:column;gap:.25rem}.summary-card__label{font-size:.75rem;color:#94a3b8;text-transform:uppercase}.summary-card__value{font-size:1.1rem;font-weight:600;color:#f8fafc;word-break:break-all}.player-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.player-card{background:#1e293b99;border:1px solid rgba(148,163,184,.2);padding:1rem;border-radius:1rem;display:flex;align-items:center;gap:1rem}.player-card__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#a855f7);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;flex-shrink:0}.player-card__avatar--llm{background:linear-gradient(135deg,#10b981,#3b82f6)}.player-card__info{flex:1;min-width:0}.player-card__name{font-weight:600;color:#f8fafc;display:flex;align-items:center;gap:.5rem}.player-card__role{font-size:.8rem;color:#818cf8;font-weight:500}.player-card__status{width:10px;height:10px;border-radius:50%;background:#4ade80}.player-card__status--offline{background:#94a3b8}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{background:#0f172a66;border:1px solid rgba(148,163,184,.1);padding:.75rem 1rem;border-radius:.75rem;display:flex;align-items:center;gap:1.5rem;font-size:.9rem}.history-item__time{color:#64748b;font-family:monospace;width:80px}.history-item__role{font-weight:600;color:#818cf8;width:100px}.history-item__action{flex:1;color:#e2e8f0}.history-item__id{color:#c084fc;font-weight:500;margin-right:.5rem}.phase-badge{padding:.25rem .6rem;border-radius:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase}.phase--lobby{background:#3b82f633;color:#60a5fa}.phase--playing{background:#10b98133;color:#34d399}.phase--paused{background:#f59e0b33;color:#fbbf24}.phase--finished{background:#94a3b833;color:#94a3b8}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.role-card{background:#1e293b99;border:1px solid rgba(148,163,184,.2);padding:1rem;border-radius:1rem;display:flex;flex-direction:column;gap:.5rem}.role-card__header{display:flex;justify-content:space-between;align-items:center}.role-card__id{font-weight:700;color:#818cf8;font-size:1rem;text-transform:uppercase}.role-card__player{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#e2e8f0;background:#0003;padding:.5rem;border-radius:.5rem}.role-card__unassigned{color:#94a3b8;font-style:italic}.game-state-container{position:relative;background:#0f172a66;border:1px solid rgba(148,163,184,.1);border-radius:.75rem;overflow:hidden}.game-state-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#1e293b99;border-bottom:1px solid rgba(148,163,184,.1)}.game-state-header__title{font-size:.8rem;font-weight:600;color:#94a3b8;text-transform:uppercase}.copy-button{padding:.25rem .6rem;font-size:.75rem;background:#4f46e5;color:#fff;border:none;border-radius:.4rem;cursor:pointer;transition:all .2s}.copy-button:hover{background:#6366f1}.copy-button:active{transform:scale(.95)}.game-state-viewer{margin:0;padding:1rem;max-height:400px;overflow-y:auto;font-family:Fira Code,Monaco,Consolas,monospace;font-size:.85rem;line-height:1.5;color:#e2e8f0;white-space:pre-wrap}
