:root{--bg:#0b1020;--panel:#0b1020db;--text:#eef2ff;--muted:#a8b1c7;--border:#94a3b833;--accent:#4f46e5;--shadow:0 14px 40px #00000047;color:var(--text);background:radial-gradient(circle at top left, #4f46e540, transparent 28%), radial-gradient(circle at top right, #10b98129, transparent 26%), var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{min-height:100vh}a{color:inherit}img,svg{max-width:100%;display:block}input,button{font:inherit}.shell{flex-direction:column;gap:1.25rem;padding:1rem 1rem 3rem;display:flex}.centerShell{place-content:center;min-height:100svh}.header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:.18em;opacity:.7;margin:0 0 .4rem;font-size:.72rem}h1{margin:0;font-size:clamp(1.5rem,5vw,2.8rem);line-height:1.15}.subtitle{max-width:60ch;color:var(--muted);margin-top:.4rem;font-size:.9rem}.actions{flex-wrap:wrap;gap:.5rem;display:flex}.sectionNav{-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:50;background:var(--bg,#0d0f14);border-bottom:1px solid var(--border);gap:.4rem;margin:0 -1rem;padding:.5rem 1rem;display:flex;position:sticky;top:0;overflow-x:auto}.sectionNav::-webkit-scrollbar{display:none}.sectionNavLink{border:1px solid var(--border);white-space:nowrap;color:inherit;background:0 0;border-radius:999px;align-items:center;padding:.45rem .85rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.sectionNavLink:hover{background:#7f7f7f1f}.grid{gap:1rem;display:grid}.metricsGrid{grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr))}.triGrid{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}.duoGrid,.securityGrid{grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr))}.panel{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;padding:1rem}.metricCard h2,.panel h2{margin:0 0 .8rem;font-size:1rem}.panel h3{margin:.75rem 0 .4rem;font-size:.9rem}.metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem .75rem;margin:0;display:grid}.metrics dt{opacity:.7;font-size:.78rem}.metrics dd{margin:.15rem 0 0;font-size:.9rem;font-weight:700}.barWrap{margin-top:.75rem}.barLabel{justify-content:space-between;margin-bottom:.3rem;font-size:.88rem;display:flex}.bar{background:#7f7f7f2e;border-radius:999px;height:9px;overflow:hidden}.barFill{border-radius:inherit;background:linear-gradient(90deg, var(--accent), #60a5fa);height:100%}.subMetrics{color:var(--muted);justify-content:space-between;margin-top:.3rem;font-size:.85rem;display:flex}.kpiRow{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.kpi{border:1px solid var(--border);background:#7f7f7f0d;border-radius:12px;flex:1 1 0;min-width:80px;padding:.65rem}.kpi span{color:var(--muted);font-size:.78rem}.kpi strong{margin-top:.2rem;font-size:1.05rem;display:block}.chips{flex-wrap:wrap;justify-content:flex-start;gap:.35rem;margin-bottom:.75rem;display:flex}.badge,.chip{border:1px solid var(--border);border-radius:999px;align-items:center;gap:.3rem;padding:.22rem .55rem;font-size:.79rem;display:inline-flex}.badge.ok{background:#10b9811f;border-color:#10b98147}.badge.warn{background:#f59e0b1f;border-color:#f59e0b47}.chip.danger,.badge.danger{color:#ef4444e6;background:#ef44441f;border-color:#ef444447}.chip.warn{background:#f59e0b1f;border-color:#f59e0b47}.serviceCards{flex-direction:column;gap:.6rem;display:flex}.serviceCard{border:1px solid var(--border);background:#7f7f7f0a;border-radius:12px;padding:.7rem}.serviceCardMain{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.serviceCardFoot{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.cardList{flex-direction:column;gap:.5rem;display:flex}.cardItem{border:1px solid var(--border);background:#7f7f7f0a;border-radius:12px;padding:.65rem .75rem}.cardItem.selected{border-color:var(--accent);background:#60a5fa12}.cardItemMain{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.cardItemFoot{justify-content:space-between;align-items:center;gap:.5rem;margin-top:.35rem;display:flex}.routeItem.selected{border-color:var(--accent);background:#60a5fa12}.accordion{border:1px solid var(--border);border-radius:12px;margin-top:.75rem;overflow:hidden}.accordionToggle{width:100%;color:inherit;text-align:left;background:#7f7f7f0a;justify-content:space-between;align-items:center;padding:.65rem .75rem;font-size:.9rem;font-weight:600;display:flex;border:none!important;border-radius:0!important}.accordionChevron{opacity:.6;font-size:.7rem}.accordionBody{border-top:1px solid var(--border);padding:.75rem}.list{flex-direction:column;gap:.45rem;margin:0;padding:0;list-style:none;display:flex}.list li{border:1px solid var(--border);background:#7f7f7f0a;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:.6rem;padding:.6rem .7rem;display:flex}.list.narrow li{padding:.5rem .65rem}.list small,.muted{color:var(--muted)}button{font:inherit;border:1px solid var(--border);background:var(--accent);color:#fff;cursor:pointer;border-radius:10px;min-height:44px;padding:.65rem 1rem}button.ghost{color:inherit;background:0 0}button.ghost.danger{color:#ef4444d9;border-color:#ef444447}button.ghost.danger:hover:not(:disabled){background:#ef44441a}button:disabled{opacity:.65;cursor:progress}button.iconBtn{min-height:36px;padding:.4rem .7rem;font-size:1rem}button.inlineBtn{min-height:unset;color:inherit;font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;padding:0}.btn{border:1px solid var(--border);background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-height:44px;padding:.65rem 1rem;font-weight:600;text-decoration:none;display:inline-flex}.metaRow{color:var(--muted);flex-wrap:wrap;gap:.5rem 1rem;font-size:.88rem;display:flex}.logViewer{white-space:pre-wrap;word-break:break-word;min-height:200px;max-height:320px;font-family:var(--mono);border:1px solid var(--border);background:#0000001a;border-radius:12px;padding:.75rem;font-size:.78rem;line-height:1.45;overflow:auto}.notice{border:1px solid var(--border);border-radius:10px;margin-bottom:.9rem;padding:.7rem .8rem;font-size:.88rem}.notice.error{background:#ef44441f;border-color:#ef444447}.loginForm{gap:.8rem;min-width:min(340px,100%);display:grid}.loginForm label{gap:.35rem;font-weight:600;display:grid}.loginForm input{font:inherit;border:1px solid var(--border);color:inherit;background:0 0;border-radius:10px;min-height:44px;padding:.75rem .85rem}.codeRefList{flex-direction:column;gap:.75rem;margin-top:.75rem;display:flex}.codeRefItem{border:1px solid var(--border);background:#7f7f7f0a;border-radius:12px;padding:.75rem}.codeRefHeader{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.3rem;display:flex}.codeRefHeaderRight{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.codeRefPurpose{margin-bottom:.4rem;font-size:.85rem}.codeRef{border:1px solid var(--border);font-family:var(--mono);white-space:pre-wrap;word-break:break-all;background:#0000002e;border-radius:8px;max-height:100px;margin:0;padding:.5rem .65rem;font-size:.75rem;line-height:1.5;overflow-x:auto}.checkRunBtn{min-height:36px;padding:.4rem .75rem;font-size:.82rem;font-weight:600}.checkRunBtn.running{opacity:.7}.checkResult{border-top:1px solid var(--border);margin-top:.6rem;padding-top:.6rem}.checkResultMeta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.4rem;font-size:.78rem;display:flex}.checkOutput{border:1px solid var(--border);font-family:var(--mono);white-space:pre-wrap;word-break:break-all;background:#0000002e;border-radius:8px;max-height:300px;margin:0;padding:.6rem .75rem;font-size:.75rem;line-height:1.5;overflow:auto}.drawerOverlay{z-index:90;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;position:fixed;inset:0}.drawer{z-index:95;background:var(--panel,#1a1f2e);border:1px solid var(--border);border-bottom:none;border-radius:20px 20px 0 0;max-height:88svh;padding:1.25rem;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 32px #00000059}@media (width>=768px){.drawer{border-right:none;border-radius:0;width:min(520px,90vw);max-height:100svh;inset:0 0 0 auto}}.drawerHeader{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.9rem;display:flex}.drawerHeader h2{margin:0;font-size:1.1rem}.drawerMeta{border:1px solid var(--border);background:#7f7f7f0d;border-radius:10px;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;padding:.65rem .75rem;font-size:.88rem;display:flex}.drawerMeta .metaFull{flex:0 0 100%}.drawerActions{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.drawerActions button,.drawerActions .btn{flex:auto}.routeMeta{border:1px solid var(--border);background:#7f7f7f0a;border-radius:10px;margin:.75rem 0;padding:.75rem}.routeMeta h3{margin:0 0 .5rem;font-size:.9rem}.photoGrid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;display:grid}.photoThumb{aspect-ratio:1;cursor:pointer;background:#7f7f7f1a;border:2px solid #0000;border-radius:10px;transition:border-color .15s;position:relative;overflow:hidden}.photoThumb.selected{border-color:var(--accent,#3b82f6)}.photoThumb img{object-fit:cover;width:100%;height:100%;display:block}.photoCheck{background:var(--accent,#3b82f6);color:#fff;opacity:0;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;transition:opacity .15s;display:flex;position:absolute;top:5px;left:5px}.photoThumb.selected .photoCheck{opacity:1}.photoPrivate{background:#0000008c;border-radius:4px;padding:1px 3px;font-size:.7rem;position:absolute;bottom:4px;right:4px}.mediaPlaceholder{width:100%;height:100%;color:var(--muted);background:#7f7f7f1f;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;font-size:1.5rem;display:flex}.mediaPlaceholder span{text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;font-weight:600}.sessionCardList{grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));gap:.6rem;margin-top:.75rem;display:grid}.sessionCard{border:1px solid var(--border);cursor:pointer;background:#7f7f7f0a;border-radius:14px;padding:.75rem;transition:background .15s,border-color .15s}.sessionCard:hover{background:#7f7f7f17;border-color:#7f7f7f59}.sessionCardHead{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.3rem;display:flex}.sessionCardFoot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.45rem;display:flex}.filterRow{flex-wrap:wrap;align-items:center;gap:.65rem;display:flex}.filterInput{font:inherit;border:1px solid var(--border);color:inherit;background:0 0;border-radius:10px;flex:200px;min-width:0;min-height:44px;padding:.55rem .75rem}.mono{font-family:var(--mono);word-break:break-word}.truncate{white-space:nowrap;text-overflow:ellipsis;vertical-align:bottom;max-width:160px;display:inline-block;overflow:hidden}.nowrap{white-space:nowrap}.tableScroll{overflow-x:auto}@media (width<=480px){.shell{padding:.75rem}h1{font-size:1.5rem}.photoGrid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.drawerActions{flex-direction:column}.drawerActions button,.drawerActions .btn{flex:none;width:100%}}@media (width>=1024px){.shell{padding:1.5rem}.sectionNav{margin:0 -1.5rem;padding-left:1.5rem;padding-right:1.5rem}}
