@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,450;9..40,600;9..40,700&display=swap";:root{--color-bg: #f8f9fb;--color-surface: #ffffff;--color-surface-raised: #f3f4f6;--color-border: #e8eaed;--color-border-strong: #d1d5db;--color-hover: #f3f4f6;--color-accent: #2563eb;--color-accent-hover: #1b61cf;--color-accent-light: #eff6ff;--color-text-primary: #1a1f36;--color-text-secondary: #4b5563;--color-text-muted: #9ba3af;--color-shadow-rgb: 26, 31, 54}[data-theme=dark]{--color-bg: #161b27;--color-surface: #1f2535;--color-surface-raised: #283042;--color-border: #323a52;--color-border-strong: #434d6a;--color-hover: #2c3448;--color-accent: #4f8ef7;--color-accent-hover: #6fa3f9;--color-accent-light: #1e3460;--color-text-primary: #eceef4;--color-text-secondary: #a8b0c0;--color-text-muted: #6b7590;--color-shadow-rgb: 0, 0, 0}.login-page{min-height:100vh;display:flex;align-items:stretch;background:var(--color-bg);position:relative;overflow:hidden}.login-page__grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,var(--color-border-strong) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}.login-page__orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.login-page__orb--1{width:600px;height:600px;background:radial-gradient(circle at center,rgba(14,165,233,.22) 0%,rgba(14,165,233,.08) 40%,transparent 70%);top:-200px;left:-150px;animation:orbFloat 8s ease-in-out infinite}.login-page__orb--2{width:500px;height:500px;background:radial-gradient(circle at center,rgba(99,102,241,.18) 0%,rgba(99,102,241,.06) 40%,transparent 70%);bottom:-150px;right:100px;animation:orbFloat 10s ease-in-out infinite reverse}.login-page__orb--3{width:300px;height:300px;background:radial-gradient(circle at center,rgba(34,197,94,.12) 0%,transparent 70%);top:40%;left:35%;animation:orbFloat 12s ease-in-out infinite 2s}.login-page__content{display:flex;width:100%;position:relative;z-index:1}.login-brand{flex:1;display:flex;align-items:center;justify-content:center;padding:60px;position:relative;overflow:hidden;border-right:1px solid var(--color-border)}.login-brand__stripes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-brand__stripes span{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.06) 20%,rgba(0,0,0,.06) 80%,transparent 100%)}.login-brand__stripes span:nth-child(1){left:10 %}.login-brand__stripes span:nth-child(2){left:20 %}.login-brand__stripes span:nth-child(3){left:30 %}.login-brand__stripes span:nth-child(4){left:40 %}.login-brand__stripes span:nth-child(5){left:50 %}.login-brand__stripes span:nth-child(6){left:60 %}.login-brand__stripes span:nth-child(7){left:70 %}.login-brand__stripes span:nth-child(8){left:80 %}.login-brand__stripes span:nth-child(9){left:90 %}.login-brand__stripes span:nth-child(10){left:100 %}.login-brand__inner{max-width:420px;position:relative;z-index:1;animation:fadeSlideUp .6s ease both}.login-brand__badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);background:var(--color-accent-light);border:1px solid rgba(var(--color-accent),.25);padding:4px 12px;border-radius:20px;margin-bottom:32px}.login-brand__badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-accent);animation:blink 2s ease-in-out infinite;flex-shrink:0}.login-brand__logo{height:48px;object-fit:contain;display:block;margin-bottom:28px;width:auto}.login-brand__tagline{font-size:26px;font-weight:300;line-height:1.4;color:var(--color-text-primary);margin:0 0 48px;letter-spacing:-.02em;font-family:Georgia,serif}.login-brand__stats{display:flex;align-items:center;gap:24px}.login-brand__stat{display:flex;flex-direction:column;gap:4px}.login-brand__stat-value{font-size:18px;font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.login-brand__stat-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.login-brand__stat-divider{width:1px;height:32px;background:var(--color-border);flex-shrink:0}.login-form-panel{width:480px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px 56px;background:var(--color-surface);animation:fadeSlideUp .6s ease .15s both}.login-card{width:100%}.login-card__header{margin-bottom:36px}.login-card__icon{width:auto;height:36px;object-fit:contain;margin-bottom:0x;opacity:.8}.login-card__title{font-size:26px;font-weight:500;color:var(--color-text-primary);letter-spacing:-.03em;margin:0 0 6px}.login-card__subtitle{font-size:14px;color:var(--color-text-muted);margin:0}.login-card__error{display:flex;align-items:center;gap:8px;background:#ef44440f;border:1px solid rgba(239,68,68,.2);border-left:3px solid #ef4444;color:#dc2626;font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:24px}.login-card__form{display:flex;flex-direction:column;gap:20px}.login-card__footer{display:flex;justify-content:space-between;margin-top:32px;padding-top:20px;border-top:1px solid var(--color-border);font-size:11px;color:var(--color-text-muted);letter-spacing:.04em}.login-field{display:flex;flex-direction:column;gap:8px}.login-field__label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-secondary)}.login-field__wrap{position:relative;display:flex;align-items:center}.login-field__icon{position:absolute;left:14px;color:var(--color-text-muted);pointer-events:none;flex-shrink:0}.login-field__input{width:100%;padding:12px 44px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text-primary);font-size:14px;transition:border-color .2s,background .2s,box-shadow .2s;outline:none}.login-field__input::placeholder{color:var(--color-text-muted)}.login-field__input:hover:not(:focus){border-color:var(--color-border-strong)}.login-field__input:focus{border-color:var(--color-accent);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-accent-light)}.login-field__toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;padding:4px;border-radius:4px;transition:color .15s}.login-field__toggle:hover{color:var(--color-text-primary)}.login-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 20px;margin-top:8px;background:var(--color-accent);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;letter-spacing:.02em}.login-submit:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 4px 16px rgba(var(--color-accent),.3);transform:translateY(-1px)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-submit__spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-card__divider{display:flex;align-items:center;gap:12px;margin:4px 0}.login-card__divider:before,.login-card__divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-card__divider span{font-size:12px;color:var(--color-text-muted)}.login-submit--sso{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.login-submit--sso:hover:not(:disabled){background:var(--color-hover);box-shadow:none;filter:none}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-30px) scale(1.04)}66%{transform:translate(-15px,15px) scale(.97)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@media (max-width: 768px){.login-brand{display:none}.login-form-panel{width:100%;padding:32px 24px}}.login-theme-toggle{position:fixed;top:20px;right:24px;z-index:10;display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08)}.login-theme-toggle:hover{background:var(--color-hover);box-shadow:0 4px 12px rgba(var(--color-shadow-rgb),.12)}.login-theme-toggle__track{flex-shrink:0;width:32px;height:18px;border-radius:999px;background:var(--color-border-strong);position:relative;transition:background .25s ease}.login-theme-toggle__thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--color-surface);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);box-shadow:0 1px 3px #0003;transition:transform .25s cubic-bezier(.34,1.4,.64,1)}.login-theme-toggle--dark .login-theme-toggle__track{background:var(--color-accent)}.login-theme-toggle--dark .login-theme-toggle__thumb{transform:translate(14px);color:#f59e0b}.users-table{width:100%}.users-table__user{display:flex;align-items:center;gap:10px}.users-table__avatar{width:30px;height:30px;border-radius:50%;background:var(--color-accent-light);color:var(--color-accent);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.users-table__name{font-size:13px;font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:6px}.users-table__you{font-size:10px;font-weight:600;background:var(--color-accent-light);color:var(--color-accent);padding:1px 6px;border-radius:8px}.users-table__email{font-size:12px;color:var(--color-text-secondary)}.users-table__role{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500}.users-table__status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px}.users-table__status--active{background:#22c55e1a;color:#22c55e}.users-table__status--inactive{background:var(--color-bg);color:var(--color-text-muted)}.users-table__date{font-size:12px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.users-table__ip{font-size:12px;font-family:monospace;color:var(--color-text-secondary)}.users-table__device{display:flex;flex-direction:column;gap:2px}.users-table__device-row{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--color-text-primary)}.users-table__os{font-size:11px;color:var(--color-text-muted)}.users-table__provider{font-size:12px;font-weight:500;padding:2px 8px;border-radius:8px}.users-table__provider--keycloak{background:#6366f11a;color:#6366f1}.users-table__provider--local{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.login-events__stats{display:flex;gap:16px}.login-events__stat{font-size:12px;font-weight:600}.login-events__stat--success{color:#22c55e}.login-events__stat--failed{color:#ef4444}.login-events__filters{display:flex;gap:4px;background:var(--color-bg);padding:3px;border-radius:10px;border:1px solid var(--color-border)}.login-events__filter{padding:4px 12px;border:none;border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.login-events__filter:hover{background:var(--color-hover)}.login-events__filter--active{background:var(--color-surface);color:var(--color-text-primary);font-weight:600;box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08)}.login-events__row--failed{background:#ef444408!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow-y:scroll}html,body,#root{height:100%;width:100%}body{font-family:DM Sans,sans-serif;background:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.card{background:var(--color-surface);border-radius:16px;padding:1.5rem;border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08);margin-bottom:1rem;box-sizing:border-box;width:100%}.card__header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--color-border)}.card__header .chevron{color:var(--color-text-muted);transition:transform .2s ease}.card__header .chevron--open{transform:rotate(180deg)}.card__hint{font-size:12px;color:var(--color-text-muted);font-weight:400}.card__chevron{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s ease}.card__title{font-family:DM Sans,sans-serif;font-size:18px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--color-border-strong);border-radius:10px;background:var(--color-surface);color:var(--color-text-primary);font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;line-height:1;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .05s ease}.btn:hover:not(:disabled){background:var(--color-hover);border-color:var(--color-border-strong);filter:brightness(.96)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn svg{display:block;flex-shrink:0}.btn--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent);text-decoration:none}.btn--primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);filter:none}.btn--secondary{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border-strong)}.btn--secondary:hover:not(:disabled){background:var(--color-hover);filter:none}.btn--danger{background:#fee2e2;color:#dc2626;border-color:#fee2e2}.btn--danger:hover:not(:disabled){filter:brightness(.95)}.btn--ghost{background:transparent;border-color:var(--color-border-strong);color:var(--color-text-primary)}.btn--ghost:hover:not(:disabled){background:var(--color-hover);filter:none}.btn--icon{padding:0;width:36px;height:36px;justify-content:center;border-radius:10px}.btn-group-toggle{display:flex;border:1px solid var(--color-border-strong);border-radius:10px;overflow:hidden}.btn-group-toggle__btn{padding:8px 12px;font-size:12px;font-weight:500;font-family:DM Sans,sans-serif;background:var(--color-surface);color:var(--color-text-secondary);border:none;border-left:1px solid var(--color-border-strong);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.btn-group-toggle__btn:first-child{border-left:none}.btn-group-toggle__btn:hover{background:var(--color-hover)}.btn-group-toggle__btn--active{background:var(--color-accent);color:#fff}.btn-group-toggle__btn--active:hover{background:var(--color-accent-hover)}.spinner{width:18px;height:18px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-label{display:flex;flex-direction:column;font-size:13px;font-weight:600;color:var(--color-text-primary);gap:6px}.form-input{padding:8px 12px;font-size:14px;font-family:DM Sans,sans-serif;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);color:var(--color-text-primary);transition:border-color .15s ease;outline:none;width:100%}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.input-with-unit{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);transition:border-color .15s ease}.input-with-unit:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.input-with-unit input{border:none;outline:none;font-size:14px;font-family:DM Sans,sans-serif;background:transparent;text-align:right;flex:1}.input-with-unit .unit{font-size:13px;color:var(--color-text-muted);white-space:nowrap}.plan-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--color-border)}.plan-nav{display:flex;align-items:center;gap:10px}.plan-actions{display:flex;align-items:center;gap:8px}.plan-actions__main{white-space:nowrap}.action-gear{position:relative}.action-gear .action-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 10px 30px rgba(var(--color-shadow-rgb),.16);padding:4px;z-index:20}.action-gear .action-menu__item{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border:none;background:transparent;border-radius:10px;cursor:pointer;font-size:13.5px;font-family:DM Sans,sans-serif;color:var(--color-text-secondary);text-align:left;transition:background .1s ease}.action-gear .action-menu__item:hover{background:var(--color-hover)}.action-gear .action-menu__item:disabled{opacity:.6;cursor:not-allowed}.action-gear .action-menu__item svg{flex-shrink:0}.explanation{padding:1rem 1.25rem;background:var(--color-bg);border-radius:12px;border:1px solid var(--color-border);font-size:14px;line-height:1.6;margin-top:1.5rem}.explanation__title{font-size:16px;font-weight:700;color:var(--color-text-primary);margin-bottom:.5rem}.explanation p{margin:.4rem 0;color:var(--color-text-secondary)}.explanation li{margin-left:1.5rem;list-style-type:disc;color:var(--color-text-secondary)}.subsidy-section{width:100%;background:var(--color-bg);border-radius:12px;border:1px solid var(--color-border);margin:1.25rem 0;padding:1.25rem}.subsidy-section input,.subsidy-section textarea{padding:8px 12px;font-size:14px;font-family:DM Sans,sans-serif;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);color:var(--color-text-primary);transition:border-color .15s ease;outline:none;resize:vertical}.subsidy-section input:focus,.subsidy-section textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.subsidy-table{width:100%;border-spacing:0}.subsidy-table td{border-top:1px solid var(--color-border);padding:8px 0}@media (max-width: 520px){.plan-header{flex-wrap:wrap;gap:8px}.plan-actions{width:100%;justify-content:flex-end}.plan-nav .plan-title{font-size:14px}}.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--color-border)}.table-wrap::-webkit-scrollbar{height:4px}.table-wrap::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.table{width:100%;border-collapse:collapse;font-family:DM Sans,sans-serif;font-size:13.5px}.table__th{padding:10px 16px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}.table__th--left{text-align:left}.table__th--right{text-align:right}.table__th-unit{margin-left:4px;font-weight:400;opacity:.6;font-size:10px}.table tbody tr{transition:background .1s ease}.table tbody tr:hover{background:var(--color-hover)}.table__tr--even{background:var(--color-bg)}.table__tr--total{background:var(--color-hover);border-top:2px solid var(--color-border)}.table__td{padding:11px 16px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.table__td--name{font-weight:500;color:var(--color-text-primary);white-space:nowrap}.table__td--right{text-align:right;font-variant-numeric:tabular-nums}.table__td--total{font-weight:700;color:var(--color-text-primary)}.table .text-right{text-align:right}.table .text-center{text-align:center}.table .col-edit a{color:var(--color-accent)}.table .col-delete svg{color:#dc2626}.table .col-delete button{cursor:pointer;border:0}.skeleton-row{background:linear-gradient(90deg,var(--color-border) 25%,var(--color-bg) 50%,var(--color-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.app{display:flex;min-height:100vh}.app__main{flex:1;overflow:auto;padding:32px;min-width:0;margin-left:240px;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.app__main--collapsed{margin-left:64px}.sidebar{position:fixed;top:0;left:0;height:100vh;width:240px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);z-index:100;overflow:visible}.sidebar--collapsed{width:64px}.sidebar__logo{display:flex;align-items:center;justify-content:center;height:64px;padding:0 16px;border-bottom:1px solid var(--color-border);flex-shrink:0;overflow:hidden}.sidebar__logo-svg{width:100%;max-width:130px;height:auto;display:block}.sidebar__logo-img{width:28px;height:28px;object-fit:contain}.sidebar__nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}.sidebar__section-label{padding:8px 10px 4px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap}.sidebar__nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;color:var(--color-text-secondary);font-size:13.5px;font-weight:500;white-space:nowrap;transition:background .15s,color .15s;cursor:pointer;border:none;background:transparent;width:100%;text-decoration:none}.sidebar__nav-item svg{flex-shrink:0}.sidebar__nav-item:hover{background:var(--color-hover);color:var(--color-text-primary)}.sidebar__nav-item--active{background:var(--color-accent-light);color:var(--color-accent)}.sidebar__footer{padding:8px 8px 12px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:4px}.sidebar__theme-toggle{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;border:none;background:transparent;width:100%;transition:background .15s,color .15s;white-space:nowrap}.sidebar__theme-toggle:hover{background:var(--color-hover);color:var(--color-text-primary)}.sidebar__theme-toggle--collapsed{justify-content:center}.sidebar__theme-track{width:24px;height:16px;border-radius:999px;background:var(--color-border-strong);display:flex;align-items:center;padding:2px;flex-shrink:0;transition:background .2s}.sidebar__theme-toggle--dark .sidebar__theme-track{background:var(--color-accent)}.sidebar__theme-thumb{width:12px;height:12px;border-radius:50%;background:var(--color-surface);display:flex;align-items:center;justify-content:center;transition:transform .2s;color:var(--color-text-muted)}.sidebar__theme-toggle--dark .sidebar__theme-thumb{transform:translate(8px);color:var(--color-accent)}.sidebar__user-wrap{position:relative}.sidebar__user-menu{position:absolute;bottom:calc(100% + 6px);left:8px;right:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 10px 30px rgba(var(--color-shadow-rgb),.16);padding:4px;z-index:200}.sidebar__user-menu-header{display:flex;align-items:center;gap:10px;padding:10px 10px 8px}.sidebar__user-menu-name{font-size:13px;font-weight:600;color:var(--color-text-primary)}.sidebar__user-menu-role{font-size:11px;color:var(--color-text-muted);margin-top:1px}.sidebar__user-menu-divider{height:1px;background:var(--color-border);margin:4px 0}.sidebar__user-menu-item{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border:none;background:transparent;border-radius:10px;cursor:pointer;font-size:13px;font-family:DM Sans,sans-serif;color:var(--color-text-secondary);transition:background .1s}.sidebar__user-menu-item:hover{background:var(--color-hover)}.sidebar__user-menu-item--danger{color:#dc2626}.sidebar__user-menu-item--danger:hover{background:#fee2e2}.sidebar__user-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;border:none;background:transparent;width:100%;cursor:pointer;transition:background .15s}.sidebar__user-btn:hover,.sidebar__user-btn--open{background:var(--color-hover)}.sidebar__user-btn--collapsed{justify-content:center;padding:8px}.sidebar__user-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-accent-light);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.sidebar__user-avatar--lg{width:36px;height:36px;font-size:15px}.sidebar__user-info{flex:1;text-align:left;min-width:0}.sidebar__user-name{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{display:block;font-size:11px;color:var(--color-text-muted);margin-top:1px}.sidebar__user-chevron{color:var(--color-text-muted);flex-shrink:0;transition:transform .2s}.sidebar__user-chevron--open{transform:rotate(180deg)}.sidebar__toggle{position:absolute;top:50%;right:-12px;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted);box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08);transition:background .15s,color .15s;z-index:101}.sidebar__toggle:hover{background:var(--color-hover);color:var(--color-text-primary)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-header__title{font-family:DM Sans,sans-serif;font-size:22px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.4px}.page-header__sub{font-size:13px;color:var(--color-text-muted);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:1.25rem;box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08)}.stat-card__label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:8px}.stat-card__value{font-family:DM Sans,sans-serif;font-size:28px;font-weight:700;color:var(--color-text-primary);line-height:1}.stat-card__sub{font-size:12px;color:var(--color-text-muted);margin-top:6px}.stat-card__icon{float:right;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge--healthy,.badge--running,.badge--deployed,.badge--success{background:#dcfce7;color:#16a34a}.badge--degraded,.badge--warning,.badge--pending{background:#ffedd5;color:#ea580c}.badge--unknown,.badge--stopped,.badge--muted{background:var(--color-hover);color:var(--color-text-muted)}.badge--failed,.badge--error{background:#fee2e2;color:#dc2626}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-muted)}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:14px}.log-viewer{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:1rem;font-family:DM Sans,sans-serif;font-size:12.5px;line-height:1.7;color:var(--color-text-secondary);max-height:480px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.log-viewer::-webkit-scrollbar{width:4px}.log-viewer::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:1.75rem;width:100%;max-width:440px;box-shadow:0 24px 48px rgba(var(--color-shadow-rgb),.2)}.modal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal__head h2{font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;color:var(--color-text-primary)}.modal__body{display:flex;flex-direction:column;gap:14px}.modal__foot{display:flex;justify-content:flex-end;gap:8px;margin-top:1.5rem}.container-cell{display:flex;align-items:center;gap:6px}.container-cell__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.container-cell__dot--ready{background:#16a34a}.container-cell__dot--notready{background:#dc2626}.container-cell__version{font-size:12px;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.container-cell__outdated{font-size:10px;font-weight:700;color:#ea580c;background:#ffedd5;padding:1px 5px;border-radius:999px;cursor:default}.update-row{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:10px}.update-row__check{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-primary);cursor:pointer;flex-wrap:wrap}.update-row__check input[type=checkbox]{width:15px;height:15px;accent-color:var(--color-accent);cursor:pointer}.update-row__current{font-size:11px;font-weight:400;color:var(--color-text-muted);margin-left:4px}.update-row__outdated{font-size:11px;font-weight:600;color:#ea580c;background:#ffedd5;padding:2px 7px;border-radius:999px}.form-hint{font-size:11px;color:var(--color-text-muted);font-weight:400}.wizard-steps{display:flex;align-items:center;padding:0 0 1.5rem;gap:0}.wizard-section-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:-4px}.wizard-step{display:flex;align-items:center;gap:8px;flex:1}.wizard-step__circle{width:28px;height:28px;border-radius:50%;background:var(--color-hover);border:1.5px solid var(--color-border-strong);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.wizard-step__label{font-size:12px;font-weight:500;color:var(--color-text-muted);white-space:nowrap;transition:color .2s}.wizard-step__line{flex:1;height:1.5px;background:var(--color-border);margin:0 8px}.wizard-step--active .wizard-step__circle{background:var(--color-accent-light);border-color:var(--color-accent);color:var(--color-accent)}.wizard-step--active .wizard-step__label{color:var(--color-accent);font-weight:600}.wizard-step--done .wizard-step__circle{background:#dcfce7;border-color:#16a34a;color:#16a34a}.wizard-step--done .wizard-step__label{color:var(--color-text-secondary)}.wizard-step--done .wizard-step__line{background:#16a34a}.wizard-body{padding:.5rem 0 1.5rem;min-height:280px}.wizard-fields{display:flex;flex-direction:column;gap:16px}.wizard-nav{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;border-top:1px solid var(--color-border)}.wizard-summary{display:flex;flex-direction:column;gap:16px}.wizard-summary__section{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:1rem}.wizard-summary__title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px}.wizard-summary__row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--color-border);font-size:13px}.wizard-summary__row:last-child{border-bottom:none}.wizard-summary__row span{color:var(--color-text-secondary)}.wizard-summary__row strong{color:var(--color-text-primary);font-weight:600}.anlagen-list{display:flex;flex-direction:column;gap:12px;padding:4px 0}.anlage-card-full{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:1rem 1.25rem;transition:border-color .15s}.anlage-card-full:hover{border-color:var(--color-border-strong)}.anlage-card-full__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.anlage-card-full__title-wrap{display:flex;align-items:baseline;gap:8px}.anlage-card-full__label{font-family:DM Sans,sans-serif;font-size:15px;font-weight:700;color:var(--color-text-primary)}.anlage-card-full__slug{font-size:11px;color:var(--color-text-muted);font-weight:400}.anlage-card-full__containers{display:flex;gap:24px;margin-bottom:14px;flex-wrap:wrap}.anlage-card-full__container{display:flex;flex-direction:column;gap:4px}.anlage-card-full__container-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.anlage-card-full__actions{display:flex;align-items:center;gap:6px;padding-top:12px;border-top:1px solid var(--color-border)}.delete-warning{display:flex;align-items:flex-start;gap:12px;padding:12px;background:#fee2e2;border-radius:10px;color:#dc2626;font-size:13px;line-height:1.5;margin-bottom:4px}.delete-warning svg{flex-shrink:0;margin-top:2px}.delete-warning strong{display:block;margin-bottom:2px}.anlagen-toolbar{display:flex;align-items:center;gap:12px;padding:0 0 1rem;flex-wrap:wrap}.anlagen-toolbar__search{position:relative;flex:1;min-width:180px}.anlagen-toolbar__search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.anlagen-toolbar__search input{width:100%}.sort-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:500;font-family:DM Sans,sans-serif;background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-strong);border-radius:10px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.sort-btn:hover{background:var(--color-hover)}.sort-btn--active{background:var(--color-accent-light);color:var(--color-accent);border-color:var(--color-accent)}.anlagen-footer{padding:10px 0 2px;font-size:12px;color:var(--color-text-muted);text-align:right}.sidebar__nav-group{display:flex;flex-direction:column;gap:2px}.sidebar__divider{height:1px;background:var(--color-border);margin:8px 10px}.detail-containers{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:4px 0}.detail-container-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:1rem;transition:border-color .15s}.detail-container-card--outdated{border-color:#ea580c;background:#ffedd5}.detail-container-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.detail-container-card__label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.detail-container-card__version{font-family:DM Sans,sans-serif;font-size:20px;font-weight:700;color:var(--color-text-primary);margin-bottom:6px}.detail-container-card__update{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#ea580c}.detail-container-card__ok{font-size:11px;color:#16a34a;font-weight:500}.detail-fields{display:flex;flex-direction:column;gap:2px}.detail-field{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--color-border);gap:12px}.detail-field:last-child{border-bottom:none}.detail-field__label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--color-text-muted);font-weight:500;white-space:nowrap;flex-shrink:0}.detail-field__value{font-size:13px;color:var(--color-text-primary);font-weight:500;text-align:right}.detail-field__value--password{display:flex;align-items:center;gap:6px}
