:root{--bg: #0d0d0f;--bg-elevated: #161619;--bg-card: #1c1c1f;--bg-secondary: #161619;--border: #2a2a2e;--border-muted: #3d3d42;--text: #f4f4f5;--text-muted: #a8a8b3;--text-dim: #71717a;--accent: #e5b318;--accent-hover: #f0c420;--accent-muted: rgba(229, 179, 24, .18);--success: #22c55e;--success-muted: rgba(34, 197, 94, .18);--error: #ef4444;--error-muted: rgba(239, 68, 68, .18);--warn: #f59e0b;--warn-muted: rgba(245, 158, 11, .18);--link: #e5b318;--link-hover: #f0c420;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 20px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-heading: "Sora", var(--font);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font);font-size:16px;line-height:1.55;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--link);text-decoration:none;transition:color .15s ease}a:hover{color:var(--link-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{width:272px;background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease}.app-layout.sidebar-collapsed .sidebar{width:60px}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border);min-height:56px}.sidebar-brand{font-family:var(--font-heading);font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--text);white-space:nowrap;overflow:hidden}.sidebar-toggle{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s}.sidebar-toggle:hover{color:var(--text);background:#ffffff12}.app-layout.sidebar-collapsed .sidebar-head{justify-content:center;padding:var(--space-4) var(--space-3)}.sidebar-nav-wrap{flex:1;overflow-y:auto;padding:var(--space-3) 0}.sidebar-nav-group{margin-bottom:var(--space-4)}.sidebar-nav-group:last-child{margin-bottom:0}.sidebar-nav-group-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:0 var(--space-5);margin-bottom:var(--space-2)}.app-layout.sidebar-collapsed .sidebar-nav-group-title{display:none}.sidebar-nav-group .sidebar-nav{padding:0;flex:none}.sidebar-nav{list-style:none;margin:0;padding:0}.sidebar-nav a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);color:var(--text-muted);font-weight:500;font-size:.9375rem;transition:color .15s,background .15s}.app-layout.sidebar-collapsed .sidebar-nav a{justify-content:center;padding:var(--space-4)}.sidebar-nav-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px}.sidebar-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-layout.sidebar-collapsed .sidebar-nav-label{display:none}.sidebar-nav a:hover{color:var(--text);background:#ffffff0d}.sidebar-nav a.active{color:var(--accent);background:var(--accent-muted);border-right:3px solid var(--accent)}.app-layout.sidebar-collapsed .sidebar-nav a.active{border-right:none;border-left:3px solid var(--accent)}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-2);flex-shrink:0}.sidebar-footer-user{font-size:.8125rem;color:var(--text-muted)}.app-layout.sidebar-collapsed .sidebar-footer{padding:var(--space-3)}.app-layout.sidebar-collapsed .sidebar-footer>*{display:none}.sidebar-footer label{display:block;font-size:.8125rem;color:var(--text-muted);margin-bottom:var(--space-2)}.main{flex:1;min-width:0;padding:var(--space-5) var(--space-6);overflow:auto;background:var(--bg)}@media (min-width: 1200px){.main{padding:var(--space-6) var(--space-8)}}.main-inner{max-width:1600px;margin:0 auto}.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-muted);margin-bottom:var(--space-4)}.breadcrumb-item{color:var(--text-muted);text-decoration:none}.breadcrumb-item:hover{color:var(--accent)}.breadcrumb-item--current{color:var(--text);font-weight:500}.breadcrumb-item:not(:last-child):after{content:"›";margin-left:var(--space-2);color:var(--text-muted);font-weight:400}.page{max-width:1440px;margin:0 auto}.page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5)}.page-header .toolbar{margin:0;flex-shrink:0}.page-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;margin:0 0 var(--space-2);color:var(--text)}.page-desc{margin:0 0 var(--space-2);font-size:.9375rem;color:var(--text-muted);line-height:1.5}.page-header .error-msg{margin:var(--space-2) 0 0}.page-back{display:inline-block;margin-bottom:var(--space-4);font-size:.9375rem;color:var(--text-muted)}.page-back:hover{color:var(--link)}.card-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text);margin:0 0 var(--space-3);letter-spacing:-.01em}.card-title:first-child{margin-top:0}.text-muted{color:var(--text-muted);font-size:.9375rem;line-height:1.5;margin:0 0 var(--space-4)}.muted{color:var(--text-muted);font-size:.9375rem}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-4);color:var(--text-muted);font-size:1rem}.page-loading__spinner{width:44px;height:44px;border:3px solid var(--border-muted);border-top-color:var(--accent);border-radius:50%;animation:kiosk-spin .8s linear infinite}.page-empty{padding:var(--space-8) var(--space-6);text-align:center;color:var(--text-muted);font-size:.9375rem;line-height:1.5}.page-empty__title{font-weight:600;font-size:1.0625rem;color:var(--text);margin:0 0 var(--space-2)}.cards{display:flex;gap:var(--space-5);flex-wrap:wrap;margin-bottom:var(--space-6)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5) var(--space-6);min-width:160px;box-shadow:var(--shadow)}.card-label{font-size:.8125rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2);font-weight:600}.card-value{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.card-value.success{color:var(--success)}.card-value.error{color:var(--error)}.card-value.warn{color:var(--warn)}.card-sublabel{font-size:.8125rem;color:var(--text-muted);margin-top:var(--space-1)}.toolbar{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center;margin-bottom:var(--space-5)}.list-filters{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.list-filters .input,.list-filters .select{margin:0}.list-count{margin:0 0 var(--space-4);font-size:.9375rem;color:var(--text-muted)}.input,.select,.btn{font-family:var(--font);font-size:.9375rem}.input,.select{padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--border-muted);background:var(--bg-card);color:var(--text);min-height:42px;transition:border-color .15s,box-shadow .15s}.input{min-width:200px}.input::placeholder{color:var(--text-dim)}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.select{cursor:pointer}.btn{padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);border:none;font-weight:600;cursor:pointer;transition:background .15s,color .15s,transform .05s;min-height:42px;display:inline-flex;align-items:center;justify-content:center}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#0d0d0f}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--border-muted);color:var(--text)}.btn-secondary:hover{background:var(--border);color:var(--text)}.btn-sm{font-size:.8125rem;padding:var(--space-2) var(--space-3);min-height:32px}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:#ffffff0f;color:var(--text)}.btn-danger{background:var(--error-muted);color:var(--error)}.btn-danger:hover{background:#ef444447;color:#fca5a5}.tabs{display:inline-flex;gap:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.tabs button{padding:var(--space-2) var(--space-3);font-size:.875rem;background:transparent;color:var(--text-muted);border:none;cursor:pointer}.tabs button:hover{color:var(--text);background:#ffffff0a}.tabs button.active{background:var(--border-muted);color:var(--text)}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.table{width:100%;border-collapse:collapse;font-size:.9375rem}.table th{text-align:left;padding:var(--space-4) var(--space-5);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border)}.table td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#ffffff08}.table a{font-weight:500;color:var(--text)}.table a:hover{color:var(--link)}.badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-online{background:var(--success-muted);color:var(--success)}.badge-offline{background:var(--error-muted);color:var(--error)}.badge-error{background:var(--warn-muted);color:var(--warn)}.badge-updating{background:var(--accent-muted);color:var(--accent)}.badge-pending{background:#71717a40;color:var(--text-dim)}.detail-list{display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-6);max-width:560px}.detail-list dt{color:var(--text-muted);font-size:.9375rem}.detail-list dd{margin:0;color:var(--text)}.detail-list a{word-break:break-all}.empty,.error-msg{padding:var(--space-8);text-align:center;color:var(--text-muted);font-size:1rem}.error-msg{color:var(--error)}.form-error{margin:0 0 var(--space-4);padding:var(--space-3) var(--space-4);font-size:.9375rem;color:var(--error);background:var(--error-muted);border-radius:var(--radius-sm)}.loading{padding:var(--space-8);color:var(--text-muted);font-size:1rem}.swatch{display:inline-block;width:18px;height:18px;border-radius:6px;vertical-align:middle}.modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-4);animation:modal-fade-in .15s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:520px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal.modal--wide{max-width:640px}.config-modal-form{display:flex;flex-direction:column;gap:0}.config-modal-section{margin-bottom:var(--space-5)}.config-modal-section:last-of-type{margin-bottom:0}.config-modal-section-title{margin:0 0 var(--space-3);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.config-modal-section .form-row{margin-bottom:var(--space-3)}.config-modal-section .form-row:last-child{margin-bottom:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-heading);margin:0;font-size:1.125rem;font-weight:600;color:var(--text)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 var(--space-1);border-radius:var(--radius-sm);transition:color .15s,background .15s}.modal-close:hover{color:var(--text);background:#ffffff0f}.modal-body{padding:var(--space-5);overflow-y:auto}.modal-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);flex-wrap:wrap}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:10001;display:flex;flex-direction:column;gap:var(--space-2);max-width:360px;pointer-events:none}.toast-container>*{pointer-events:auto}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-lg);font-size:.9375rem;line-height:1.4;animation:toast-in .2s ease;cursor:default}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast--success{border-left:4px solid var(--success)}.toast--error{border-left:4px solid var(--error)}.toast--info{border-left:4px solid var(--accent)}.toast__message{flex:1;min-width:0}.toast__close{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:1.25rem;line-height:1;cursor:pointer;padding:0 var(--space-1);border-radius:var(--radius-sm)}.toast__close:hover{color:var(--text);background:#ffffff0f}.kiosk-detail__issued-token-modal{padding:var(--space-5)}.kiosk-detail__issued-token-modal h2{margin:0 0 var(--space-2);font-size:1.125rem}.kiosk-detail__issued-token-hint{margin:0 0 var(--space-3);font-size:.9375rem;color:var(--text-muted)}.kiosk-detail__issued-token-input{width:100%;padding:var(--space-3) var(--space-4);font-family:ui-monospace,monospace;font-size:.875rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.form-row{margin-bottom:var(--space-4)}.form-row label{display:block;font-size:.875rem;font-weight:500;color:var(--text-muted);margin-bottom:var(--space-2)}.form-row .input,.form-row .select{width:100%;max-width:100%}.form-hint{display:block;font-size:.8125rem;color:var(--text-muted);margin-top:var(--space-2);line-height:1.4}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--border)}.table-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.table-actions .btn{font-size:.8125rem;padding:var(--space-2) var(--space-3)}.dashboard-block{margin-bottom:var(--space-8)}.dashboard-block__title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 var(--space-4)}.dashboard-block--warn .dashboard-block__title{color:var(--warn, #b8860b)}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-4)}.dashboard-cards--primary{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.dashboard-card .card-value{font-size:1.5rem}.dashboard-charts{display:flex;gap:var(--space-6);flex-wrap:wrap;margin-bottom:var(--space-5)}.chart-donut-wrap{display:flex;align-items:center;gap:var(--space-6);flex-wrap:wrap}.chart-donut{width:140px;height:140px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chart-donut-inner{width:80px;height:80px;border-radius:50%;background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center}.chart-donut-total{font-size:1.5rem;font-weight:700;color:var(--text)}.chart-donut-label{font-size:.8125rem;color:var(--text-muted)}.chart-legend{list-style:none;margin:0;padding:0;font-size:.9375rem;color:var(--text-muted)}.chart-legend li{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.chart-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chart-bars{display:flex;flex-direction:column;gap:var(--space-4)}.chart-bar-row{display:flex;align-items:center;gap:var(--space-3)}.chart-bar-label{width:80px;font-size:.9375rem;color:var(--text-muted)}.chart-bar-track{flex:1;height:26px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden}.chart-bar-fill{height:100%;border-radius:var(--radius-sm);min-width:4px;transition:width .3s ease}.chart-bar-value{font-weight:600;min-width:2.5rem;text-align:right}.kiosks-page{max-width:1440px;margin:0 auto}.kiosks-page__header{margin-bottom:var(--space-6)}.kiosks-page__title{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;letter-spacing:-.03em;margin:0 0 var(--space-2);color:var(--text)}.kiosks-page__subtitle{margin:0;font-size:1rem;color:var(--text-muted);line-height:1.45}.kiosks-page__error{padding:var(--space-4) var(--space-5);margin-bottom:var(--space-4);background:var(--error-muted);color:var(--error);border-radius:var(--radius-sm);font-size:.9375rem}.kiosks-page__count{font-size:.9375rem;color:var(--text-muted);margin:0 0 var(--space-4)}.kiosks-page__loading,.kiosks-page__empty{padding:var(--space-8) var(--space-6);text-align:center;color:var(--text-muted);font-size:1rem}.kiosks-page__loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.kiosks-page__loading-spinner{width:44px;height:44px;border:3px solid var(--border-muted);border-top-color:var(--accent);border-radius:50%;animation:kiosk-spin .8s linear infinite}@keyframes kiosk-spin{to{transform:rotate(360deg)}}.kiosks-page__empty-title{font-weight:600;font-size:1.125rem;color:var(--text);margin:0 0 var(--space-2)}.kiosks-page__empty-desc{margin:0;font-size:.9375rem;line-height:1.5}.kiosk-stats{display:flex;gap:var(--space-6);margin-bottom:var(--space-6);padding:var(--space-5) var(--space-6);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.kiosk-stat{display:flex;flex-direction:column;gap:var(--space-1)}.kiosk-stat-value{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text)}.kiosk-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.kiosk-stat--online .kiosk-stat-value{color:var(--success)}.kiosk-stat--offline .kiosk-stat-value{color:var(--text-dim)}.kiosks-filters{margin-bottom:var(--space-5)}.kiosks-filters__row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.kiosks-filters__search{min-width:240px}.kiosks-filters__select{min-width:140px}.kiosks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.kiosk-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5) var(--space-6);cursor:pointer;transition:border-color .2s,box-shadow .2s;text-align:left;border-left-width:4px}.kiosk-card:hover{border-color:var(--border-muted);box-shadow:var(--shadow)}.kiosk-card--online{border-left-color:var(--success)}.kiosk-card--offline{border-left-color:var(--text-dim)}.kiosk-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.kiosk-card__name{font-weight:600;font-size:1.0625rem;color:var(--text);word-break:break-word;flex:1;min-width:0;line-height:1.35}.kiosk-card__badge{flex-shrink:0}.kiosk-card__meta{font-size:.8125rem;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2);line-height:1.4}.kiosk-card__meta span+span:before{content:" · ";color:var(--text-dim)}.kiosk-card__version{font-family:ui-monospace,monospace}.kiosk-card__time{color:var(--text-dim)}.kiosk-card__states{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.kiosk-card__state{font-size:.6875rem;padding:var(--space-1) var(--space-2);border-radius:6px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.kiosk-card__state--kvm{color:var(--success)}.kiosk-card__state--vpn{color:var(--text-dim)}.kiosk-card__state--updating{color:var(--warn)}.kiosk-card__last-cmd,.kiosk-card__last-alert{font-size:.8125rem;color:var(--text-muted);margin-bottom:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kiosk-card__last-cmd-type{font-weight:500;margin-right:var(--space-1)}.kiosk-card__last-alert-label{color:var(--error);margin-right:var(--space-1)}.kiosk-card__last-alert-msg{color:var(--text-muted)}.kiosk-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.kiosk-card__tag{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:6px;font-size:.75rem;font-weight:500;border:1px solid}.kiosk-card__health{font-size:.75rem;padding:var(--space-1) var(--space-3);border-radius:6px;font-weight:500}.kiosk-card__health--warn{background:var(--warn-muted);color:var(--warn)}.kiosk-card__health--critical{background:#ef444433;color:var(--error)}.kiosk-aside-overlay{position:fixed;inset:0;background:#00000080;z-index:500;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.kiosk-aside-overlay--open{opacity:1;visibility:visible}.kiosk-aside{position:fixed;top:0;right:0;width:min(460px,100vw);max-width:100%;height:100vh;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:-8px 0 32px #0006;z-index:501;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease}.kiosk-aside-overlay--open .kiosk-aside{transform:translate(0)}.kiosk-aside__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.kiosk-aside__title{font-family:var(--font-heading);margin:0;font-size:1.125rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kiosk-aside__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .15s,color .15s}.kiosk-aside__close:hover{background:#ffffff0f;color:var(--text)}.kiosk-aside__body{flex:1;overflow-y:auto;padding:var(--space-5)}.kiosk-aside__uuid{margin-bottom:var(--space-5);padding:var(--space-4);background:var(--bg-elevated);border-radius:var(--radius-sm)}.kiosk-aside__uuid-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:var(--space-1);font-weight:600}.kiosk-aside__uuid-value{font-size:.8125rem;word-break:break-all;color:var(--text-dim);line-height:1.4}.kiosk-aside__section{margin-bottom:var(--space-5)}.kiosk-aside__section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 var(--space-2)}.kiosk-aside__dl{display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-4);margin:0;font-size:.9375rem}.kiosk-aside__dl dt{color:var(--text-muted)}.kiosk-aside__dl dd{margin:0;color:var(--text)}.kiosk-aside__last-cmd,.kiosk-aside__last-alert{margin-top:var(--space-3);font-size:.875rem;color:var(--text)}.kiosk-aside__last-alert{color:var(--error)}.kiosk-aside__muted{color:var(--text-muted);font-size:.8125rem}.kiosk-aside__degradation{margin-top:var(--space-2);font-size:.875rem;color:var(--warn)}.kiosk-aside__actions{display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);flex-shrink:0}.kiosk-aside__btn{flex:1;min-width:120px}.kiosk-aside__kvm-hint{margin:var(--space-1) 0 0;font-size:.875rem}.kiosk-aside__kvm-hint a{color:var(--link)}.kiosk-aside__delete-confirm{width:100%;display:flex;flex-direction:column;gap:var(--space-3)}.kiosk-aside__delete-question{font-size:.9375rem;color:var(--text-muted);line-height:1.45}.kiosk-aside__delete-btns{display:flex;gap:var(--space-3)}.kiosk-detail{max-width:760px}.kiosk-detail-error,.kiosk-detail-loading{padding:var(--space-8);text-align:center;color:var(--text-muted);font-size:1rem}.kiosk-detail-error{color:var(--error)}.kiosk-detail-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.kiosk-detail-loading__spinner{width:44px;height:44px;border:3px solid var(--border-muted);border-top-color:var(--accent);border-radius:50%;animation:kiosk-spin .8s linear infinite}.kiosk-detail__breadcrumb{font-size:.9375rem;margin-bottom:var(--space-4);color:var(--text-muted)}.kiosk-detail__breadcrumb a{color:var(--link)}.kiosk-detail__breadcrumb a:hover{color:var(--link-hover)}.kiosk-detail__breadcrumb-sep{margin:0 var(--space-2);color:var(--text-dim)}.kiosk-detail__breadcrumb-current{color:var(--text)}.kiosk-detail__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.kiosk-detail__header-main{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.kiosk-detail__health-badge--ok{background:var(--success-muted);color:var(--success)}.kiosk-detail__health-badge--warning{background:var(--warn-muted);color:var(--warn)}.kiosk-detail__health-badge--critical{background:var(--error-muted);color:var(--error)}.kiosk-detail__title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;margin:0;color:var(--text);line-height:1.25}.kiosk-detail__actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.kiosk-detail__delete-hint{font-size:.9375rem;color:var(--text-muted);line-height:1.4}.kiosk-detail__uuid{margin-bottom:var(--space-6);padding:var(--space-4) var(--space-5);background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:.875rem}.kiosk-detail__uuid-label{color:var(--text-muted);margin-right:var(--space-2)}.kiosk-detail__uuid code{word-break:break-all;color:var(--text-dim)}.kiosk-detail__tab-bar{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-5);border-bottom:1px solid var(--border);padding-bottom:var(--space-3)}.kiosk-detail__tab{padding:var(--space-2) var(--space-4);font-size:.9375rem;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,background .15s}.kiosk-detail__tab:hover{color:var(--text);background:#ffffff0d}.kiosk-detail__tab.kiosk-detail__tab--active{color:var(--accent);background:var(--accent-muted)}.kiosk-detail__sections{display:flex;flex-direction:column;gap:var(--space-6)}.kiosk-detail__sections .kiosk-detail__section[data-tab]{display:none}.kiosk-detail__sections[data-active-tab=overview] .kiosk-detail__section[data-tab=overview],.kiosk-detail__sections[data-active-tab=inventory] .kiosk-detail__section[data-tab=inventory],.kiosk-detail__sections[data-active-tab=commands] .kiosk-detail__section[data-tab=commands],.kiosk-detail__sections[data-active-tab=timeline] .kiosk-detail__section[data-tab=timeline],.kiosk-detail__sections[data-active-tab=updates] .kiosk-detail__section[data-tab=updates],.kiosk-detail__sections[data-active-tab=announcements] .kiosk-detail__section[data-tab=announcements]{display:block}.kiosk-detail__section{padding:var(--space-5) var(--space-6);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.kiosk-detail__section-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 var(--space-3);line-height:1.3}.kiosk-detail__dl{display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-6);margin:0;font-size:.9375rem;line-height:1.5}.kiosk-detail__dl dt{color:var(--text-muted)}.kiosk-detail__dl dd{margin:0;color:var(--text)}.kiosk-detail__groups,.kiosk-detail__notes{margin:0;font-size:.9375rem;color:var(--text);line-height:1.55}.kiosk-detail__maintenance-toggle{display:inline-flex;align-items:center;gap:var(--space-3)}.kiosk-detail__maintenance-toggle input[type=checkbox]{margin:0}.kiosk-detail__muted{margin:0;font-size:.9375rem;color:var(--text-muted);line-height:1.45}.kiosk-detail__muted code{font-size:.875em;background:var(--bg-elevated);padding:.1rem .35rem;border-radius:6px}.kiosk-detail__quick-commands{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2)}.kiosk-detail__health{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-4);margin-top:var(--space-2)}.kiosk-detail__health-warn{color:var(--error);font-weight:500}.kiosk-detail__health-ok,.kiosk-detail__health-uptime,.kiosk-detail__health-link{color:var(--text-muted);font-size:.9375rem}.kiosk-detail__run-command{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-top:var(--space-3)}.kiosk-detail__run-command-input{flex:1;min-width:14rem}.kiosk-detail__run-command-timeout{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.9375rem;color:var(--text-muted)}.kiosk-detail__run-command-timeout input{width:4rem;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-sm)}.kiosk-detail__run-command-error{margin:var(--space-2) 0 0;font-size:.9375rem;color:var(--error)}.kiosk-detail__commands{display:flex;flex-direction:column;gap:var(--space-2)}.kiosk-detail__command-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3) var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--border);font-size:.9375rem}.kiosk-detail__command-row:last-child{border-bottom:none}.kiosk-detail__command-type{font-weight:500;color:var(--text);min-width:6rem}.kiosk-detail__command-msg{color:var(--text-muted);max-width:18rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kiosk-detail__command-date{color:var(--text-dim);font-size:.875rem;margin-left:auto}.kiosk-detail__kvm-hint{margin:var(--space-1) 0 0;font-size:.875rem;color:var(--text-muted)}.kiosk-detail__kvm-hint a{color:var(--link)}.kiosk-detail__kvm-error{margin:var(--space-1) 0 0;font-size:.875rem;color:var(--error)}.kvm-viewer__mode{display:flex;align-items:center;gap:var(--space-1)}.kvm-viewer__mode-label{color:var(--text-muted);font-size:.875rem;margin-right:var(--space-1)}.kvm-viewer__mode .btn-sm.active{background:var(--bg-elevated);font-weight:600}.kiosk-detail__vpn-peers{display:flex;flex-direction:column;gap:var(--space-4)}.kiosk-detail__vpn-peer{padding:var(--space-4);background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border)}.kiosk-detail__vpn-dl{margin:0}.kiosk-detail__vpn-dl dt{color:var(--text-muted)}.kiosk-detail__vpn-dl dd{margin:0 0 var(--space-1);color:var(--text)}.kiosk-detail__vpn-code{font-size:.875em;word-break:break-all;color:var(--text-dim)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.login-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-title{font-family:var(--font-heading);margin:0 0 var(--space-2);font-size:1.5rem;font-weight:700;color:var(--text);text-align:center;line-height:1.25}.login-subtitle{margin:0 0 var(--space-6);font-size:1rem;color:var(--text-muted);text-align:center;line-height:1.5}.login-form .form-row{margin-bottom:var(--space-4)}.login-form .form-row .input{width:100%}.login-error{margin:0 0 var(--space-4);padding:var(--space-3) var(--space-4);background:var(--error-muted);color:var(--error);border-radius:var(--radius-sm);font-size:.9375rem;line-height:1.4}.login-submit{width:100%;margin-top:var(--space-2)}.login-hint{margin:var(--space-6) 0 0;font-size:.875rem;color:var(--text-muted);text-align:center;line-height:1.5}.login-hint a{color:var(--link)}.announcement-preview__body{font-size:.9375rem;line-height:1.5}.announcement-preview__body p{margin:0 0 .5em}.announcement-preview__body p:last-child{margin-bottom:0}.announcement-preview__body h1,.announcement-preview__body h2,.announcement-preview__body h3{margin:.75em 0 .35em;font-size:1rem;font-weight:600}.announcement-preview__body ul,.announcement-preview__body ol{margin:.5em 0;padding-left:1.25em}.announcement-preview__body li{margin-bottom:.25em}.announcement-preview__body a{color:var(--link);text-decoration:none}.announcement-preview__body a:hover{text-decoration:underline}.announcement-preview__body code{background:var(--bg-secondary);padding:.1em .35em;border-radius:4px;font-size:.9em}.announcement-preview__body pre{margin:.5em 0;overflow-x:auto}.announcement-preview__body pre code{padding:.5em;display:block}:root{--bg: #10131a;--bg-elevated: #171d27;--bg-card: #1b2230;--bg-secondary: #222c3d;--border: #2f3b52;--border-muted: #3c4c67;--text: #e6ecf7;--text-muted: #aebcd4;--text-dim: #8797b3;--accent: #8bb7ff;--accent-hover: #a2c6ff;--accent-muted: rgba(139, 183, 255, .15);--success: #67c689;--error: #df8181;--warn: #d9b069;--link: #a6c7ff;--link-hover: #bfd7ff;--radius: 16px;--radius-sm: 10px;--shadow: 0 20px 48px rgba(2, 6, 23, .38);--shadow-lg: 0 30px 80px rgba(2, 6, 23, .5)}body{background:radial-gradient(1100px 460px at -10% -10%,rgba(104,130,173,.17),transparent 65%),radial-gradient(980px 520px at 120% 0%,rgba(120,156,201,.1),transparent 62%),linear-gradient(180deg,#10131a,#0f1219);color:var(--text)}.app-layout--neo .sidebar{background:linear-gradient(180deg,#0b1426f2,#0a101ff2);border-right:1px solid rgba(114,138,192,.24);backdrop-filter:blur(10px)}.sidebar-brand-wrap{display:inline-flex;align-items:center;gap:.6rem}.sidebar-brand-dot{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,#7dd3fc,#93c5fd);box-shadow:0 0 18px #7dd3fccc}.sidebar-head{min-height:68px;padding-top:1.1rem;padding-bottom:1.1rem}.sidebar-brand{font-size:1rem;letter-spacing:.01em}.sidebar-nav-group-title{color:#7f96c4}.sidebar-nav a{border-radius:12px;margin:.1rem .5rem;padding-right:.95rem;padding-left:.95rem}.app-layout.sidebar-collapsed .sidebar-nav a{margin-left:.25rem;margin-right:.25rem}.sidebar-nav a.active{border-right:none;background:linear-gradient(90deg,#7dd3fc33,#7dd3fc1a);color:#d9f1ff;box-shadow:inset 0 0 0 1px #7dd3fc66}.sidebar-footer{border-top-color:#728ac040}.main{padding-top:1.25rem}.topbar{position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1rem 1.15rem;border:1px solid rgba(137,166,214,.22);border-radius:14px;background:linear-gradient(180deg,#1b2332e6,#161d2be0);backdrop-filter:blur(8px);box-shadow:var(--shadow)}.topbar__title{margin:0;font-size:1.1rem;line-height:1.25;letter-spacing:-.01em;color:#edf5ff}.topbar__subtitle{margin:.35rem 0 0;color:var(--text-muted);font-size:.86rem}.topbar-user{display:inline-flex;align-items:center;gap:.6rem;padding:.4rem .5rem .4rem .75rem;border-radius:999px;border:1px solid rgba(137,166,214,.24);background:#131925c7}.topbar-user__name{color:#d0defc;font-size:.82rem;font-weight:600}.main-inner>.breadcrumb{margin-bottom:1rem;padding-left:.2rem}.page-title{font-size:1.65rem;letter-spacing:-.025em}.card,.table-wrap,.kiosk-detail__section,.kiosk-card,.login-card,.modal{background:linear-gradient(180deg,#141f38e6,#0e172be0);border-color:#7e91b647;box-shadow:var(--shadow)}.table th{background:#080e1bcc}.table tbody tr:hover{background:#8bb7ff14}.input,.select{background:#131927e6;border-color:#7e91b65c}.btn-primary{color:#13203a;background:linear-gradient(135deg,#8bb7ff,#a9c9ff)}.btn-primary:hover{background:linear-gradient(135deg,#a2c6ff,#bfd7ff)}.btn-secondary{border:1px solid rgba(118,145,208,.36);background:#101a2ee0}.btn-ghost:hover{background:#8bb7ff1f;color:#e3edff}.badge-online{color:#70d396}.badge-offline{color:#e59191}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.overview-panel{border:1px solid rgba(126,145,182,.3);border-radius:var(--radius);background:linear-gradient(180deg,#1c2434cc,#19202fd9);padding:1rem 1.1rem}.overview-panel__title{margin:0 0 .4rem;font-size:.92rem;color:#d6e2f7;letter-spacing:.01em}.overview-panel__text{margin:0;font-size:.88rem;color:var(--text-muted);line-height:1.45}.overview-panel__chips{margin-top:.65rem;display:flex;flex-wrap:wrap;gap:.5rem}.list-toolbar-card{margin-bottom:1rem;padding:.75rem 1rem;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.section-title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--text)}@media (max-width: 980px){.topbar{position:static;flex-direction:column;align-items:stretch}.topbar__right{display:flex;justify-content:flex-start}}
