:root{--bg-1: #0c1219;--bg-2: #121c27;--panel: #1a2735ee;--panel-solid: #1a2735;--text-main: #e9f1f8;--text-soft: #9eb2c6;--line: #26394a;--line-soft: #2d455a;--button: #223547;--button-hover: #2a4258;--accent: #6bd3ff;--ok: #73e0a7;--err: #ff7e7e}*{box-sizing:border-box}body{margin:0;min-height:100dvh;font-family:Segoe UI,Noto Sans,sans-serif;color:var(--text-main);background:radial-gradient(circle at 15% 10%,#1c2e41 0,transparent 40%),radial-gradient(circle at 80% 90%,#1f3e53 0,transparent 45%),linear-gradient(160deg,var(--bg-1),var(--bg-2))}button,input{font:inherit}.screen{min-height:100dvh;padding:20px 14px;display:flex;justify-content:center}@supports not (height: 100dvh){body,.screen{min-height:100vh}}.panel{width:min(920px,100%);background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 14px 40px #00000040}@media (hover: hover) and (pointer: fine){.panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@media (hover: none) and (pointer: coarse){.panel{background:var(--panel-solid)}}@media (hover: none) and (pointer: coarse){.panel{box-shadow:0 10px 24px #00000030}.recovery-banner--warn,.install-modal{box-shadow:0 12px 28px #0004}}.auth-panel{width:min(520px,100%);margin-top:min(12vh,88px)}.panel-head h1{margin:6px 0;font-size:clamp(20px,5vw,30px)}.panel-head-main{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.16em;color:var(--text-soft);font-size:11px}.sub{margin:0;color:var(--text-soft)}.head-actions{display:flex;align-items:center;gap:10px;margin-top:18px;float:right}.install-btn{border-color:#3f7ea3;color:#bfe8ff}.role-badge{border-radius:999px;border:1px solid var(--line-soft);padding:5px 10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft)}.role-badge.admin{border-color:#4278ad;color:#bde1ff;background:#193850}.role-badge.user{border-color:#3e5668;color:#c8d7e5;background:#1d3040}.auth-form{margin-top:18px;display:grid;gap:10px}.input-label{color:var(--text-soft);font-size:13px}.code-input{width:100%;border-radius:12px;border:1px solid var(--line-soft);background:#16232f;color:var(--text-main);padding:12px 14px;outline:none;letter-spacing:.08em;text-transform:uppercase}.code-input:focus{border-color:#4a708f;box-shadow:0 0 0 3px #39608155}.no-uppercase{text-transform:none;letter-spacing:normal}.primary-btn,.ghost-btn{border:1px solid var(--line-soft);border-radius:12px;color:var(--text-main);cursor:pointer;transition:background .12s ease}.primary-btn{background:linear-gradient(180deg,#2a455d,#22384d);padding:11px 14px}.ghost-btn{background:#182633;padding:8px 11px}.primary-btn:disabled,.ghost-btn:disabled{opacity:.6;cursor:default}.inline-error{margin:10px 0 0;color:#ffd0d0;background:#5a2d35a0;border:1px solid #8a3a47;border-radius:10px;padding:9px 10px;font-size:13px}.recovery-banner{margin-top:14px;border:1px solid #2f6280;border-radius:12px;background:linear-gradient(135deg,#17354a,#1f4f6c);padding:10px 12px;display:flex;justify-content:space-between;align-items:center;gap:12px}.recovery-label{color:#b3d7ef;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.recovery-banner--warn{border-color:#b87a2a;background:linear-gradient(135deg,#3a251b,#1f3a4b);box-shadow:0 10px 26px #0005}.recovery-label.warn{color:#ffd59a;font-weight:800}.groups-wrap{margin-top:16px;display:grid;gap:12px}.view-tabs{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px}.tab-btn{border:1px solid var(--line-soft);border-radius:999px;background:#182633;color:var(--text-soft);padding:7px 12px;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.tab-btn.active{background:#25445a;color:var(--text-main);border-color:#44708f}.gate-group-card{border:1px solid var(--line-soft);border-radius:14px;background:linear-gradient(180deg,#1b2c3c,#172635),radial-gradient(circle at 85% 0,#2f4b64 0,transparent 35%);padding:12px}.group-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.group-head h2{margin:0;font-size:16px}.group-head span{color:var(--text-soft);font-size:12px}.group-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.gate-tile{min-width:0}.gate-btn{width:100%;border:1px solid #2f475b;background:linear-gradient(180deg,var(--button),#1f3242);color:var(--text-main);border-radius:12px;padding:11px 12px;text-align:left;min-height:52px;cursor:pointer;display:grid;gap:6px}.gate-btn.is-busy{border-color:#3f7ea3}.gate-btn.state-oncall{border-color:#3f7ea3;background:linear-gradient(180deg,#2a4f6a,#213f56)}.gate-btn.state-ok{border-color:#3f8d6b;background:linear-gradient(180deg,#2a5945,#23493a)}.gate-btn.state-error{border-color:#8f4d55;background:linear-gradient(180deg,#5a333a,#4c2b31)}.gate-btn:disabled{cursor:default}.gate-btn-main{display:flex;align-items:center;gap:8px;min-width:0}.gate-pulse{width:9px;height:9px;border-radius:999px;background:var(--accent);box-shadow:0 0 #6bd3ff55}.gate-btn.is-busy .gate-pulse{animation:pulse 1s infinite}.gate-btn.state-ok .gate-pulse{background:var(--ok)}.gate-btn.state-error .gate-pulse{background:var(--err)}.gate-desc{font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gate-btn-meta{display:flex;align-items:center;gap:6px;color:var(--text-soft);font-size:12px}.state-icon{font-size:12px}.gate-btn.state-ok .state-text{color:#cbf6df}.gate-btn.state-error .state-text{color:#ffd0d0}.gate-error{margin:5px 4px 0;color:#ffd2d2;font-size:12px}.events-panel{margin-top:16px;border:1px solid var(--line-soft);border-radius:14px;background:#172633b3;padding:12px}.events-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.events-head h2{margin:0;font-size:16px}.events-list{display:grid;gap:8px}.events-empty{margin:2px 0;color:var(--text-soft)}.event-card{border:1px solid #314b60;border-radius:12px;background:linear-gradient(180deg,#1d3041,#192a39);padding:10px}.notification-card.unread{border-color:#4f7994;box-shadow:inset 0 0 0 1px #4f799455}.notification-card.focused{border-color:#76c9e8;box-shadow:0 0 0 2px #76c9e844}.event-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.event-state{border-radius:999px;padding:2px 8px;font-size:12px}.event-state.ok{color:#d4ffe9;background:#24513d}.event-state.err{color:#ffd8d8;background:#5c2933}.event-gate{margin:6px 0;font-weight:600}.event-meta{margin:2px 0;color:#c2d0de;font-size:13px}.event-error{margin:6px 0 0;color:#ffd2d2;font-size:13px}.admin-filters{display:grid;gap:8px;margin-bottom:12px}.admin-actions{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.notification-link-btn{text-decoration:none;display:inline-flex;align-items:center}.admin-result{margin:10px 0;border:1px solid #476985;border-radius:10px;background:#1c3346;color:#d9ecfb;padding:8px 10px;word-break:break-all}.admin-push-panel{margin:10px 0 14px;padding:10px;border:1px solid #36556f;border-radius:10px;background:#13233199}.admin-callbar{margin:8px 0 12px;display:grid;gap:6px}.push-required-banner{margin-top:14px;border:1px solid #8f4d55;border-radius:12px;background:linear-gradient(180deg,#4a2a30,#3c2429);padding:12px;display:grid;gap:8px}.push-required-title{margin:0;font-weight:700}.push-required-text{margin:0;color:#ffd9d9;font-size:13px;line-height:1.35}.offline-banner{margin-top:12px;border:1px solid #4f7994;border-radius:12px;background:linear-gradient(180deg,#1b3447,#182e3e);padding:10px 12px}.offline-banner p{margin:6px 0 0;color:#d6e7f5;font-size:13px;line-height:1.35}.admin-gates-panel{margin-top:12px}.admin-gates-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-gates-list{display:grid;gap:6px;max-height:320px;overflow:auto;border:1px solid #314b60;border-radius:10px;padding:8px;background:#14212cb3}.admin-gate-item{display:grid;grid-template-columns:20px 1fr;align-items:start;gap:8px;padding:6px;border-radius:8px}.admin-gate-text{min-width:0;display:grid;gap:2px}.admin-gate-text strong{line-height:1.25;word-break:break-word}.admin-gate-group{color:#c2d0de;font-size:13px;line-height:1.25;word-break:break-word}@keyframes pulse{0%{box-shadow:0 0 #6bd3ff66}70%{box-shadow:0 0 0 8px #6bd3ff00}to{box-shadow:0 0 #6bd3ff00}}@media (max-width: 780px){.panel-head-main{flex-direction:column;align-items:flex-start}.head-actions{float:none;justify-content:flex-end}}@media (max-width: 640px){.recovery-banner{flex-direction:column;align-items:flex-start}}.recovery-code-row{width:100%;display:flex;gap:12px;align-items:center;justify-content:space-between;margin-top:10px}.recovery-code{font-size:22px;letter-spacing:.12em;padding:6px 8px;border-radius:10px;background:#0000002a;border:1px dashed #ffd59a55}.recovery-actions{display:flex;gap:10px;align-items:center}.recovery-hint{margin:10px 0 0;padding:8px 10px;border-radius:10px;background:#00000026;border:1px solid #00000022;color:#f1e2c7;font-size:12px;line-height:1.35}@media (max-width: 640px){.recovery-code-row{flex-direction:column;align-items:stretch}.recovery-actions{justify-content:flex-end}}.recovery-banner{display:grid;grid-template-columns:1fr;justify-content:initial;align-items:start;gap:10px}.recovery-banner--warn{border-color:#b87a2a;background:linear-gradient(135deg,#2f231c,#1b3344);box-shadow:0 10px 26px #0005}.recovery-label.warn{color:#ffd59a;font-weight:800;line-height:1.2}.browser-guard-warning{border-color:#9f1239;background:#fff1f2;color:#881337;box-shadow:0 8px 18px #88133722}.browser-guard-warning .recovery-label.warn{color:#9f1239}.browser-guard-warning .recovery-hint{background:#ffe4e6;border-color:#fecdd3;color:#881337}.browser-guard-warning .recovery-hint:before{color:#9f1239;background:#ffe4e6;border-color:#fecdd3}.recovery-code-row{width:100%;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px}.recovery-code{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;font-size:22px;letter-spacing:.12em;padding:8px 10px;border-radius:10px;background:#0000002a;border:1px dashed #ffd59a55}.recovery-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.recovery-hint{margin:0;padding:10px 12px 10px 40px;border-radius:10px;background:#00000026;border:1px solid #00000022;color:#f1e2c7;font-size:12px;line-height:1.35;position:relative;max-width:72ch}.recovery-hint:before{content:"ℹ";position:absolute;left:12px;top:10px;width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#ffe2b6;background:#00000030;border:1px solid #00000025}@media (max-width: 640px){.recovery-code-row{grid-template-columns:1fr;align-items:stretch}.recovery-actions{justify-content:flex-start}.recovery-hint{max-width:100%}}.install-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008a;display:flex;align-items:center;justify-content:center;padding:18px;z-index:50}.install-modal{width:min(420px,100%);border:1px solid #36556e;border-radius:14px;background:linear-gradient(180deg,#1c3041,#172636);box-shadow:0 16px 40px #0006;padding:16px}.install-modal h2{margin:0 0 12px;font-size:20px}.install-steps{margin:0 0 14px;padding-left:20px;color:#cfdbe7;display:grid;gap:6px}.push-status-text{clear:both;margin-top:12px}.tab-btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.event-card{content-visibility:auto;contain:layout paint style;contain-intrinsic-size:160px}@media (hover: hover) and (pointer: fine){.primary-btn:hover:not(:disabled){background:linear-gradient(180deg,#30506c,#27425a)}.ghost-btn:hover:not(:disabled){background:#1e3142}.gate-btn:hover:not(:disabled){background:linear-gradient(180deg,var(--button-hover),#264056)}.admin-gate-item:hover{background:#22384a66}}
