@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";.sidebar{width:240px;height:100vh;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);overflow:visible;flex-shrink:0;box-shadow:2px 0 12px rgba(var(--color-shadow-rgb),.05);position:fixed;top:0;left:0;z-index:100}.sidebar--collapsed{width:64px}.sidebar--collapsed .sidebar__nav{padding:12px 8px}.sidebar--collapsed .sidebar__item{justify-content:center;padding:10px}.sidebar--collapsed .sidebar__group{margin-bottom:12px}.sidebar__logo{height:80px;display:flex;align-items:center;justify-content:center;padding:0 16px;border-bottom:1px solid var(--color-border);overflow:hidden;flex-shrink:0}.sidebar__logo-svg{height:60px;width:auto;fill:var(--color-text-primary);color:var(--color-text-primary);transition:color .25s ease}.sidebar__logo-img{height:50px;flex-shrink:0;object-fit:contain}.sidebar__logo-img--collapsed{height:30px}.sidebar__nav{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden}.sidebar__nav::-webkit-scrollbar{width:4px}.sidebar__nav::-webkit-scrollbar-track{background:transparent}.sidebar__nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.sidebar__group{margin-bottom:6px}.sidebar__category{display:block;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:8px 8px 4px;white-space:nowrap}.sidebar__item{position:relative;display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;margin-bottom:2px;text-decoration:none;font-size:14px;font-weight:450;color:var(--color-text-secondary);transition:background .15s ease,color .15s ease;white-space:nowrap}.sidebar__item:hover{background:var(--color-hover);color:var(--color-text-primary)}.sidebar__item:hover .sidebar__icon{color:var(--color-text-primary)}.sidebar__item--active{background:var(--color-accent-light);color:var(--color-accent);font-weight:600}.sidebar__item--active .sidebar__icon{color:var(--color-accent)}.sidebar__item--active:hover{background:var(--color-accent-light);color:var(--color-accent)}.sidebar__icon{flex-shrink:0;color:var(--color-text-muted);transition:color .15s ease}.sidebar__label{white-space:nowrap}.sidebar__badge{margin-left:auto;background:var(--color-accent);color:#fff;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;min-width:25px;text-align:center;flex-shrink:0;letter-spacing:.02em}.sidebar__badge--collapsed{position:absolute;top:1px;right:1px;margin:0;padding:1px 4px;font-size:9px;min-width:15px;border:1.5px solid var(--color-surface)}.sidebar__footer{margin-top:auto;border-top:1px solid var(--color-border);padding-top:8px}.sidebar__user-wrap{position:relative}.sidebar__user{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;border-top:1px solid var(--color-border);cursor:pointer;text-align:left;transition:background .15s}.sidebar__user:hover,.sidebar__user--open{background:var(--color-hover)}.sidebar__user--collapsed{justify-content:center;padding:10px 0}.sidebar__user-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}.sidebar__user-avatar--lg{width:38px;height:38px;font-size:15px}.sidebar__user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sidebar__user-name{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{font-size:11px;color:var(--color-text-muted);white-space:nowrap}.sidebar__user-chevron{color:var(--color-text-muted);flex-shrink:0;transition:transform .2s ease}.sidebar__user-chevron--open{transform:rotate(180deg)}.sidebar__user-menu{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 -4px 20px rgba(var(--color-shadow-rgb),.1);overflow:hidden;animation:slideUpFade .15s ease;z-index:200}.sidebar__user-menu-header{display:flex;align-items:center;gap:12px;padding:14px 14px 12px}.sidebar__user-menu-name{font-size:13px;font-weight:500;color:var(--color-text-primary)}.sidebar__user-menu-email{font-size:11px;color:var(--color-text-muted);margin-top:1px}.sidebar__user-menu-divider{height:1px;background:var(--color-border);margin:0 8px}.sidebar__user-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--color-text-secondary);transition:background .12s;text-align:left}.sidebar__user-menu-item:hover{background:var(--color-hover)}.sidebar__user-menu-item--danger{color:#ef4444}.sidebar__user-menu-item--danger:hover{background:#ef44440f}.sidebar__toggle{position:fixed;left:226px;top:50vh;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.15);z-index:101;transition:left .25s cubic-bezier(.4,0,.2,1),background .15s,color .15s,border-color .15s}.sidebar__toggle:hover{background:var(--color-hover);border-color:var(--color-border-strong);color:var(--color-text-primary)}.sidebar--collapsed .sidebar__toggle{left:50px}.theme-toggle{display:flex;align-items:center;gap:10px;width:calc(100% - 24px);margin:0 12px 8px;padding:8px 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}.theme-toggle:hover{background:var(--color-hover);box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08)}.theme-toggle__track{flex-shrink:0;width:32px;height:18px;border-radius:999px;background:var(--color-border-strong);position:relative;transition:background .25s ease}.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),background .25s}.theme-toggle__label{font-size:12px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.theme-toggle--dark .theme-toggle__track{background:var(--color-accent)}.theme-toggle--dark .theme-toggle__thumb{transform:translate(14px);color:#f59e0b}.theme-toggle--collapsed{width:40px;height:40px;margin:0 auto 8px;padding:0;justify-content:center;border-radius:10px}.theme-toggle--collapsed .theme-toggle__track,.theme-toggle--collapsed .theme-toggle__thumb{position:static;transform:none;background:transparent;box-shadow:none;width:auto;height:auto}.theme-toggle--collapsed .theme-toggle__track{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.theme-toggle--collapsed .theme-toggle__thumb{color:var(--color-text-muted);width:20px;height:20px}.theme-toggle--collapsed:hover .theme-toggle__thumb{color:var(--color-text-primary)}@keyframes slideUpFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:10px;z-index:1000;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:12px;background:var(--color-surface);border:1px solid var(--color-border);min-width:300px;max-width:400px;box-shadow:0 8px 24px #0000001f,0 2px 8px #0000000f;animation:toastSlideIn .25s cubic-bezier(.34,1.2,.64,1);position:relative;overflow:hidden;pointer-events:all}.toast--error{border-left:3px solid #ef4444}.toast--warning{border-left:3px solid #f59e0b}.toast--success{border-left:3px solid #22c55e}.toast--info{border-left:3px solid #3b82f6}.toast__icon-wrap{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}.toast__icon-wrap--error{background:#ef44441a;color:#ef4444}.toast__icon-wrap--warning{background:#f59e0b1a;color:#f59e0b}.toast__icon-wrap--success{background:#22c55e1a;color:#22c55e}.toast__icon-wrap--info{background:#3b82f61a;color:#3b82f6}.toast__body{flex:1;min-width:0}.toast__label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:2px}.toast__title{font-size:13px;font-weight:500;color:var(--color-text-primary);line-height:1.4}.toast__message{font-size:12px;color:var(--color-text-secondary);margin-top:3px;line-height:1.4}.toast__bar{position:absolute;bottom:0;left:0;height:2px;width:100%;animation:toastProgress 5s linear forwards}.toast__bar--error{background:#ef4444}.toast__bar--warning{background:#f59e0b}.toast__bar--success{background:#22c55e}.toast__bar--info{background:#3b82f6}@keyframes toastSlideIn{0%{transform:translate(20px) scale(.96);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes toastProgress{0%{width:100%}to{width:0%}}.opt-summary{display:flex;flex-direction:column;gap:12px}.opt-summary__title-group{display:flex;align-items:center;gap:12px}.opt-summary__status{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:20px}.opt-summary__status--optimal{background:#dcfce7;color:#15803d}.opt-summary__status--warn{background:#fef9c3;color:#a16207}.opt-summary__kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.opt-summary__kpi{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);transition:box-shadow .15s ease}.opt-summary__kpi:hover{box-shadow:0 4px 12px rgba(var(--color-shadow-rgb),.12)}.opt-summary__kpi--green .opt-summary__kpi-icon{background:#dcfce7;color:#16a34a}.opt-summary__kpi--green .opt-summary__kpi-value{color:#15803d}.opt-summary__kpi--red .opt-summary__kpi-icon{background:#fee2e2;color:#dc2626}.opt-summary__kpi--red .opt-summary__kpi-value{color:#b91c1c}.opt-summary__kpi--blue .opt-summary__kpi-icon{background:#dbeafe;color:#2563eb}.opt-summary__kpi--blue .opt-summary__kpi-value{color:var(--color-text-primary)}.opt-summary__kpi--orange .opt-summary__kpi-icon{background:#ffedd5;color:#ea580c}.opt-summary__kpi--orange .opt-summary__kpi-value{color:#c2410c}.opt-summary__kpi--purple .opt-summary__kpi-icon{background:#f3e8ff;color:#9333ea}.opt-summary__kpi--purple .opt-summary__kpi-value{color:#7e22ce}.opt-summary__kpi--cyan .opt-summary__kpi-icon{background:#e0f2fe;color:#0891b2}.opt-summary__kpi--cyan .opt-summary__kpi-value{color:var(--color-text-primary)}.opt-summary__kpi-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.opt-summary__kpi-body{display:flex;flex-direction:column;gap:2px;min-width:0}.opt-summary__kpi-label{font-size:11px;font-weight:500;color:var(--color-text-muted);white-space:nowrap}.opt-summary__kpi-value{font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.3px;white-space:nowrap}.opt-summary__kpi-sub{font-size:11px;color:var(--color-text-muted)}.opt-summary__bar-wrap{display:flex;align-items:center;gap:8px;min-width:120px}.opt-summary__bar-wrap span{font-size:12px;white-space:nowrap;color:var(--color-text-secondary);min-width:48px;text-align:right}.opt-summary__bar{height:6px;border-radius:999px;background:var(--color-accent);min-width:2px;max-width:80px;flex-shrink:0;transition:width .3s ease}.opt-summary__bar--full{background:#dc2626}.opt-summary__footer-stats{display:flex;gap:24px;padding:12px 16px;font-size:13px;color:var(--color-text-secondary);border-top:1px solid var(--color-border);flex-wrap:wrap}.opt-summary__footer-stats strong{color:var(--color-text-primary)}.opt-summary__row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 720px){.opt-summary__row2{grid-template-columns:1fr}}.opt-summary__kpi--row2{width:100%;box-sizing:border-box}.opt-summary__storage-stats{display:flex;gap:16px;margin-bottom:10px;align-items:flex-end}.opt-summary__storage-stat{display:flex;flex-direction:column;gap:2px}.opt-summary__storage-stat--current{flex:1;align-items:center;text-align:center}.opt-summary__storage-stat--current .opt-summary__kpi-value{font-size:16px}.opt-summary__storage-stat-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.opt-summary__storage-track{position:relative;height:8px;background:var(--color-border);border-radius:4px;overflow:visible;margin-bottom:10px}.opt-summary__storage-fill{height:100%;background:var(--color-accent);border-radius:4px;transition:width .4s ease;min-width:4px}.opt-summary__storage-marker{position:absolute;top:-3px;width:2px;height:14px;border-radius:1px;transform:translate(-50%)}.opt-summary__storage-marker--min{background:#ef4444}.opt-summary__storage-marker--max{background:#22c55e}.opt-summary__storage-cycles{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.opt-summary__cycle-item{display:flex;align-items:center;gap:5px}.opt-summary__cycle-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.opt-summary__cycle-dot--charge{background:#22c55e}.opt-summary__cycle-dot--discharge{background:#ef4444}.opt-summary__cycle-val{font-size:12px;font-weight:600;color:var(--color-text-primary)}.opt-summary__cycle-divider{width:1px;height:16px;background:var(--color-border);flex-shrink:0}.opt-summary__price-headline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.opt-summary__price-headline-val{display:flex;flex-direction:column;gap:1px}.opt-summary__price-badge{flex-shrink:0;font-size:15px;font-weight:700;font-family:DM Sans,sans-serif;padding:4px 10px;border-radius:10px;letter-spacing:-.3px}.opt-summary__price-badge--pos{background:#dcfce7;color:#15803d}.opt-summary__price-badge--neg{background:#fee2e2;color:#b91c1c}.opt-summary__price-stack-wrap{margin-top:10px}.opt-summary__price-stack{display:flex;height:22px;border-radius:10px;overflow:hidden;background:var(--color-border);gap:2px}.opt-summary__price-stack-base{position:relative;display:flex;align-items:center;background:var(--color-text-muted);opacity:.5;min-width:0;overflow:hidden}.opt-summary__price-stack-base--anim{animation:stack-grow .55s cubic-bezier(.34,1.1,.64,1) both;animation-delay:.05s}.opt-summary__price-stack-extra{position:relative;display:flex;align-items:center;min-width:0;overflow:hidden}.opt-summary__price-stack-extra--pos{background:#16a34a}.opt-summary__price-stack-extra--neg{background:#dc2626}.opt-summary__price-stack-extra--anim{animation:stack-grow .55s cubic-bezier(.34,1.1,.64,1) both;animation-delay:.18s}.opt-summary__price-stack-inner-label{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;padding:0 7px;letter-spacing:.01em;text-shadow:0 1px 2px rgba(0,0,0,.18);overflow:hidden;text-overflow:ellipsis}.opt-summary__val--pos{color:#15803d}.opt-summary__val--neg{color:#b91c1c}@keyframes stack-grow{0%{width:0!important;opacity:0}to{opacity:1}}.info-modal-backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f12207a;backdrop-filter:blur(6px) saturate(.8);-webkit-backdrop-filter:blur(6px) saturate(.8);animation:info-modal-backdrop-in .16s ease both}@keyframes info-modal-backdrop-in{0%{opacity:0}to{opacity:1}}.info-modal{background:var(--color-surface);border-radius:16px;width:100%;max-width:520px;max-height:84vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 0 0 1px #1a1f3612,0 4px 12px #1a1f360f,0 16px 36px #1a1f3621,0 40px 64px #1a1f3614;animation:info-modal-in .22s cubic-bezier(.28,1.36,.6,1) both}@keyframes info-modal-in{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.info-modal__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px 17px;border-bottom:1px solid var(--color-border);flex-shrink:0}.info-modal__title{margin:0;font-size:14px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.15px}.info-modal__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;color:var(--color-text-muted);background:transparent;border:none;padding:0;cursor:pointer;transition:color .12s,background .12s}.info-modal__close:hover{color:var(--color-text-primary);background:var(--color-hover)}.info-modal__body{padding:22px 20px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.info-modal__body::-webkit-scrollbar{width:4px}.info-modal__body::-webkit-scrollbar-track{background:transparent}.info-modal__body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:99px}.info-modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.info-modal-list{list-style:none;margin:0;padding:0}.info-modal-list li{display:flex;flex-direction:column;gap:3px;padding:13px 0;border-bottom:1px solid var(--color-border);font-size:13px;line-height:1.6;color:var(--color-text-secondary)}.info-modal-list li:first-child{padding-top:0}.info-modal-list li:last-child{border-bottom:none;padding-bottom:0}.info-modal-list li strong{font-size:11px;font-weight:700;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.06em}.info-modal-kv{margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.info-modal-kv>div{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.info-modal-kv dt{font-size:12px;font-weight:500;color:var(--color-text-muted);white-space:nowrap}.info-modal-kv dd{font-size:13px;font-weight:600;color:var(--color-text-primary);text-align:right;margin:0}.info-modal-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin:18px 0 10px}.info-modal-section-label:first-child{margin-top:0}.info-modal-callout{border-radius:10px;padding:12px 14px;font-size:12.5px;line-height:1.55;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-secondary);margin-top:14px}.info-modal-callout--info{background:var(--color-accent-light);border-color:rgba(var(--color-accent),.2);color:#1d4ed8}.info-modal-callout--warn{background:#ffedd5;border-color:#ea580c40;color:#c2410c}.info-modal-callout--danger{background:#fee2e2;border-color:#dc262633;color:#b91c1c}.info-modal-callout--success{background:#dcfce7;border-color:#16a34a33;color:#15803d}*,*: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}.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}.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;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)}.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}.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}.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 .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}}.plan-actions{display:flex;align-items:center;gap:.6rem}.plan-actions .plan-actions__main{white-space:nowrap}.btn.btn--icon{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;border:1px solid var(--gray-300, #d1d5db);border-radius:6px;cursor:pointer}.btn.btn--icon:hover{background:var(--gray-50, #fafafa)}.btn.btn--icon:disabled{opacity:.6;cursor:not-allowed}.action-gear{position:relative}.action-gear .action-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:#fff;border:1px solid var(--gray-200, #e5e7eb);border-radius:10px;box-shadow:0 10px 30px #0000001f;padding:.35rem;z-index:20}.action-gear .action-menu .action-menu__item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border:0;background:transparent;border-radius:8px;cursor:pointer;font-size:.92rem;color:inherit;text-align:left}.action-gear .action-menu .action-menu__item:hover{background:var(--gray-50, #f9fafb)}.action-gear .action-menu .action-menu__item:disabled{opacity:.6;cursor:not-allowed}.action-gear .action-menu .action-menu__item svg{flex:0 0 16px}.action-gear .action-menu .action-menu__item span{flex:1 1 auto}.plan-time-nav{display:flex;align-items:center;gap:4px}.plan-time-nav__label{font-size:13px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap;min-width:120px;text-align:center}.opt-history-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.opt-history-daterange{display:flex;align-items:center;gap:6px;border:1px solid var(--color-border-strong);border-radius:10px;padding:3px 10px;background:var(--color-surface)}.opt-history-daterange__sep{font-size:13px;color:var(--color-text-muted);user-select:none}.opt-history-dateinput{border:none;outline:none;background:transparent;font-size:13px;font-family:DM Sans,sans-serif;color:var(--color-text-primary);cursor:pointer;padding:4px 0}.opt-history-dateinput::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer;filter:var(--date-picker-filter, none)}[data-theme=dark] .opt-history-dateinput{color-scheme:dark}@media (max-width: 600px){.plan-actions{gap:.45rem}.plan-actions .plan-actions__main{padding:0 .75rem;font-size:.9rem}}.hdt-wrap{margin-top:1.5rem;border-top:1px solid var(--color-border);padding-top:1.25rem}.hdt__th-gen{white-space:nowrap}.hdt__dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle;flex-shrink:0}.hdt__td-time{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--color-text-secondary);font-size:12.5px}.hdt__td-gen{white-space:nowrap}.hdt__status{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:6px}.hdt__status--on{background:#dcfce7;color:#15803d}[data-theme=dark] .hdt__status--on{background:#14532d;color:#4ade80}.hdt__status--off{background:var(--color-bg);color:var(--color-text-muted)}.hdt__gen-power{margin-left:6px;font-size:12px;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.hdt__td-storage{white-space:nowrap;font-variant-numeric:tabular-nums}.hdt__storage-from{color:var(--color-text-muted);font-size:12px}.hdt__arrow{margin:0 4px;color:var(--color-text-muted);font-size:11px}.hdt__day-row,.hdt__day-row:hover{background:var(--color-bg)!important}.hdt tbody tr:not(.hdt__day-row){transition:background .12s ease}.hdt tbody tr:not(.hdt__day-row):hover td{background:var(--color-border-strong)!important}.hdt__price-cell{display:flex;flex-direction:row;align-items:center;gap:6px;justify-content:flex-end}.hdt__price-value{white-space:nowrap;width:60px}.hdt__day-cell{padding:0;border-bottom:2px solid var(--color-border-strong);border-top:2px solid var(--color-border-strong)}.hdt__day-cell-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px 6px}.hdt__day-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.hdt__day-stats{display:flex;gap:12px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}.hdt__day-max{color:#16a34a}.hdt__day-min{color:#dc2626}.hdt__td-price--max{background:#22c55e12;color:#16a34a;font-weight:600}.hdt__td-price--min{background:#ef444412;color:#dc2626;font-weight:600}.hdt__price-badge{font-size:9px;margin-right:3px;vertical-align:middle}.hdt__price-badge--max{color:#16a34a}.hdt__price-badge--min{color:#dc2626}.hdt__day-candle{display:flex;align-items:center;gap:8px}.hdt__day-candle-stats{display:flex;flex-direction:column;gap:2px;font-size:.72rem}.hdt__day-ohlc{color:var(--color-text-muted);font-size:.68rem}.planner-page{display:flex;flex-direction:column;width:100%;height:calc(100vh - 48px)}.planner-page .card{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.planner-page .status{display:inline-flex;align-items:center;gap:.25rem;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.planner-page .status__time{font-weight:500;font-size:11px}.planner-page .status--warn{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.planner-page .card__header{flex-shrink:0;flex-wrap:wrap;gap:12px}.planner-page .card__header .header-left{display:flex;align-items:center;gap:10px;min-width:0}.planner-page .card__header .actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-left:auto}.planner-page .field{display:flex;align-items:center;gap:8px}.planner-page .field label{font-size:12px;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.planner-page .field input,.planner-page .field select{height:32px;padding:0 10px;border:1px solid var(--color-border-strong);border-radius:6px;font-size:13px;font-family:DM Sans,sans-serif;background:var(--color-surface);color:var(--color-text-primary);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.planner-page .field input:focus,.planner-page .field select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.planner-page .field input[type=datetime-local]{width:180px}.planner-page .field select{width:90px}.planner-page .skeleton{padding:2rem;text-align:center;color:var(--color-text-muted);border:1px dashed var(--color-border-strong);border-radius:12px;background:var(--color-bg);margin:1rem}.planner{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.planner .planner-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--color-border);gap:12px;flex-wrap:wrap}.planner .planner-head .planner-legend{display:flex;gap:6px;align-items:center}.planner .planner-head .planner-legend .planner-pill{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}.planner .planner-head .planner-legend .planner-pill.mode-auto{background:var(--color-border);color:var(--color-text-secondary)}.planner .planner-head .planner-legend .planner-pill.mode-on{background:#dcfce7;color:#166534}.planner .planner-head .planner-legend .planner-pill.mode-off{background:#fee2e2;color:#991b1b}.planner .planner-head .planner-legend .planner-pill.mode-value{background:#dbeafe;color:#1e3a8a}.planner .planner-head .planner-head-right{display:flex;gap:6px;align-items:center;margin-left:auto}.planner .planner-grid-wrap{flex:1;min-height:0;overflow:auto;width:calc(100% - 2rem);margin:1rem;box-sizing:border-box;border-radius:12px;border:1px solid var(--color-border)}.planner .planner-grid-wrap::-webkit-scrollbar{height:4px;width:4px}.planner .planner-grid-wrap::-webkit-scrollbar-track{background:transparent}.planner .planner-grid-wrap::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.planner .planner-grid{width:100%;display:grid;grid-template-rows:auto repeat(var(--hours),minmax(3.6rem,auto));grid-template-columns:clamp(160px,30%,320px) repeat(var(--gens),minmax(140px,1fr));background:var(--color-bg);overflow:visible;position:relative}.planner .planner-grid .planner-cell{border:0;background:var(--color-surface);display:flex;align-items:center;justify-content:center;font-size:13px;user-select:none;min-height:3.6rem;box-sizing:border-box}.planner .planner-grid .planner-cell:not(.sticky-top){border-top:1px solid var(--color-border)}.planner .planner-grid .planner-cell:not(.sticky-left){border-left:1px solid var(--color-border)}.planner .planner-grid .sticky-top{position:sticky;top:0;z-index:3;background:var(--color-bg);box-shadow:inset 0 -1px 0 var(--color-border)}.planner .planner-grid .sticky-left{position:sticky;left:0;z-index:3;background:var(--color-surface);box-shadow:inset -1px 0 0 var(--color-border)}.planner .planner-grid .sticky-both{position:sticky;top:0;left:0;z-index:4;background:var(--color-bg);box-shadow:inset 0 -1px 0 var(--color-border),inset -1px 0 0 var(--color-border)}.planner .planner-grid .planner-header{flex-direction:column;gap:.35rem;padding:.5rem .75rem;text-align:center}.planner .planner-grid .planner-header .planner-gen-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planner .planner-grid .planner-header .planner-col-actions{display:flex;flex-wrap:wrap;gap:.25rem .5rem;justify-content:center}.planner .planner-grid .planner-header .planner-col-actions .planner-btn{font-size:11px;padding:2px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);cursor:pointer;color:var(--color-text-secondary);white-space:nowrap;transition:background .1s ease}.planner .planner-grid .planner-header .planner-col-actions .planner-btn:hover{background:var(--color-hover)}.planner .planner-grid .planner-time,.planner .planner-grid .planner-corner{text-align:left;padding:11px 16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:var(--color-surface);color:var(--color-text-secondary);font-size:13.5px}.planner .planner-grid .planner-time{font-weight:500;color:var(--color-text-secondary)}.planner .planner-grid .planner-corner{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-bg)}.planner .planner-grid .planner-analog{padding:.35rem .5rem;display:grid;grid-template-rows:auto auto;align-items:center;justify-items:center;row-gap:.3rem;transition:background .15s}.planner .planner-grid .planner-analog.mode-auto{background:var(--color-bg)}.planner .planner-grid .planner-analog.mode-value{background:#fff7ed;border-left:3px solid #f97316}.planner .planner-grid .planner-analog .analog-toggle{border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-bg);padding:2px 10px;font-size:12px;cursor:pointer;text-transform:lowercase;line-height:1.2;transition:background .15s,border-color .15s,color .15s}.planner .planner-grid .planner-analog .analog-toggle.is-manual{background:#fef3c7;border-color:#f59e0b;color:#92400e}.planner .planner-grid .planner-analog .analog-body{display:flex;align-items:center;gap:.5rem;width:100%;justify-content:center}.planner .planner-grid .planner-analog .analog-choice{border:1px solid var(--color-border-strong);border-radius:6px;padding:3px 10px;font-size:12px;cursor:pointer;background:var(--color-bg);transition:background .15s,border-color .15s,color .15s}.planner .planner-grid .planner-analog .analog-choice:hover{background:var(--color-hover)}.planner .planner-grid .planner-analog .analog-choice.active{color:#fff}.planner .planner-grid .planner-analog .analog-choice.active.on{background:#22c55e;border-color:#16a34a}.planner .planner-grid .planner-analog .analog-choice.active.off{background:#ef4444;border-color:#dc2626}.planner .planner-grid .planner-analog .analog-slider-wrap{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0}.planner .planner-grid .planner-analog .analog-range{flex:1;accent-color:var(--color-accent);min-width:80px}.planner .planner-grid .planner-analog .analog-range:disabled{opacity:.5;cursor:not-allowed}.planner .planner-grid .planner-analog .analog-pct{min-width:3rem;text-align:center;font-size:12px;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);padding:2px 6px}.planner .planner-grid .planner-analog .analog-pct.is-off{background:#fee2e2;color:#991b1b;border-color:#fca5a5;font-weight:600}@media (max-width: 900px){.planner .planner-grid{grid-template-columns:clamp(140px,32%,300px) repeat(var(--gens),minmax(110px,1fr))}}@media (max-width: 600px){.planner-page{height:auto}.planner .planner-grid{grid-template-columns:clamp(120px,34%,260px) repeat(var(--gens),minmax(96px,1fr))}.planner-page .card__header .actions{width:100%;justify-content:flex-start}}.settings-page{width:100%;box-sizing:border-box}.settings-page .actions{display:inline-flex;gap:10px}.settings-page .settings-toolbar{margin-bottom:1.5rem}.settings-page .settings-toolbar .search{width:100%;border:1px solid var(--color-border-strong);border-radius:10px;padding:9px 12px;font-size:14px;font-family:DM Sans,sans-serif;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.settings-page .settings-toolbar .search:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.settings-page .section{margin-top:1.5rem}.settings-page .section+.section{padding-top:1.5rem;border-top:1px solid var(--color-border)}.settings-page .section h2{font-size:13px;font-weight:700;color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:1rem}.settings-page .grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}@media (min-width: 1600px){.settings-page .grid{gap:18px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}.settings-page .field{display:flex;flex-direction:column;gap:6px}.settings-page .label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.settings-page .label{font-size:13px;font-weight:600;color:var(--color-text-primary)}.settings-page .input-with-unit{display:flex;align-items:center;gap:8px;border:1px solid var(--color-border-strong);border-radius:6px;padding:8px 12px;background:var(--color-surface);transition:border-color .15s ease,box-shadow .15s ease}.settings-page .input-with-unit:hover{border-color:var(--color-border-strong);filter:brightness(.96)}.settings-page .input-with-unit:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.settings-page .input-with-unit input{border:none;outline:none;background:transparent;font-size:14px;font-family:DM Sans,sans-serif;color:var(--color-text-primary);width:100%;text-align:right}.settings-page .input-with-unit input::placeholder{color:var(--color-text-muted)}.settings-page .input-with-unit .unit{min-width:48px;text-align:right;font-size:13px;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.settings-page .input-with-unit.is-number input{font-variant-numeric:tabular-nums}.settings-page .select{width:100%;border:1px solid var(--color-border-strong);border-radius:6px;padding:9px 12px;font-size:14px;font-family:DM Sans,sans-serif;background:var(--color-surface);color:var(--color-text-primary);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.settings-page .select:hover{border-color:var(--color-border-strong);filter:brightness(.96)}.settings-page .select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.settings-page .notify-block .notify-row{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start}.settings-page .help{font-size:12px;margin-top:4px}.settings-page .help.error{color:#dc2626}.settings-page .skeleton-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,24%)}.settings-page .skeleton-row{height:64px;border-radius:10px;background:linear-gradient(90deg,#eceff3 25%,#f5f7fb 37%,#eceff3 63%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.settings-page .btn--ghost{background:transparent;color:var(--color-text-primary);border-color:var(--color-border-strong)}.settings-page .btn--ghost:hover:not(:disabled){background:var(--color-hover);border-color:var(--color-border-strong);filter:brightness(.96)}.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__actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}.users-table__confirm{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-text-secondary)}.users-tabs{display:flex;gap:4px;background:var(--color-bg);padding:3px;border-radius:10px;border:1px solid var(--color-border)}.users-tabs__btn{padding:5px 14px;border:none;border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.users-tabs__btn:hover{background:var(--color-hover)}.users-tabs__btn--active{background:var(--color-surface);color:var(--color-text-primary);font-weight:600;box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08)}.users-tabs__badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;padding:0 4px;margin-left:6px}.login-events__toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--color-border);gap:12px;flex-wrap:wrap}.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}.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)}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .15s ease}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000026;animation:slideUp .2s cubic-bezier(.34,1.2,.64,1)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal__title{font-size:16px;font-weight:500;color:var(--color-text-primary);margin:0}.modal__body{padding:24px}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--color-border)}.form-grid{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field__label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);display:flex;align-items:center;gap:6px}.form-field__hint{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--color-text-muted)}.form-field__input{padding:9px 12px;border:1px solid var(--color-border);border-radius:10px;background:var(--color-bg);color:var(--color-text-primary);font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}.form-field__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.form-field__input::placeholder{color:var(--color-text-muted)}.role-selector{display:flex;gap:8px}.role-selector__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:1px solid var(--color-border);border-radius:10px;background:var(--color-bg);color:var(--color-text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.role-selector__btn:hover{border-color:var(--color-border-strong)}.toggle-field__btn{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--color-text-secondary);padding:0}.toggle-field__track{width:32px;height:18px;border-radius:999px;background:var(--color-border-strong);position:relative;transition:background .2s}.toggle-field__btn--active .toggle-field__track{background:var(--color-accent)}.toggle-field__thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s cubic-bezier(.34,1.4,.64,1);box-shadow:0 1px 3px #0003}.toggle-field__btn--active .toggle-field__thumb{transform:translate(14px)}.btn--icon-danger{color:var(--color-text-muted)}.btn--icon-danger:hover{color:#ef4444;background:#ef444414}.btn--danger-sm{display:flex;align-items:center;padding:4px 8px;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;transition:background .15s}.btn--danger-sm:hover{background:#dc2626}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.gen-price-analysis__controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:1.5rem}.gen-price-analysis__legend{display:flex;align-items:center;gap:16px;font-size:12px;color:var(--color-text-muted);flex-wrap:wrap}.gen-price-analysis__legend span{display:flex;align-items:center;gap:5px}.gen-price-analysis__legend-hint{margin-left:auto;color:var(--color-text-muted);opacity:.6}@media (max-width: 600px){.gen-price-analysis__legend-hint{display:none}}.gen-price-analysis__dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-right:5px}.gen-price-analysis__dot--all{background:var(--color-border);border:1px solid var(--color-border-strong)}.gen-price-analysis__months{display:flex;flex-direction:column;gap:1rem}.gen-price-analysis__month-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.gen-price-analysis__month-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:.75rem}.gen-price-analysis__month-title{font-family:DM Sans,sans-serif;font-size:14px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.2px}.gen-price-analysis__score-row{display:flex;align-items:center;gap:8px}.gen-price-analysis__score-pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.gen-price-analysis__score-pill.score--great{background:#22c55e1f;color:#16a34a;border:1px solid rgba(34,197,94,.3)}.gen-price-analysis__score-pill.score--ok{background:#eab3081f;color:#ca8a04;border:1px solid rgba(234,179,8,.3)}.gen-price-analysis__score-pill.score--moderate{background:#f973161f;color:#ea580c;border:1px solid rgba(249,115,22,.3)}.gen-price-analysis__score-pill.score--bad{background:#ef44441f;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.gen-price-analysis__histogram{display:flex;align-items:flex-end;gap:3px;height:80px;margin:.75rem 0 .5rem}.gen-price-analysis__bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;cursor:default}.gen-price-analysis__bar-col:hover .gen-price-analysis__bar-all{filter:brightness(1.15)}.gen-price-analysis__bar-all{background:var(--color-border-strong);border-radius:2px 2px 0 0;width:100%;transition:height .3s ease,filter .15s ease}.gen-price-analysis__bar-run{border-radius:2px 2px 0 0;width:100%;position:absolute;bottom:0;left:0;opacity:.88;transition:height .3s ease}.gen-price-analysis__axis{display:flex;justify-content:space-between;margin-top:4px}.gen-price-analysis__axis-label{font-size:10px;color:var(--color-text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.gen-price-analysis__axis-label--mid{opacity:.5}.gen-price-analysis__median{margin-top:6px;font-size:11px;color:var(--color-text-muted)}.gen-price-analysis__median-val{color:var(--color-text-secondary)}.gen-price-analysis__stats{display:flex;gap:20px;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);flex-wrap:wrap}.gen-price-analysis__stat{display:flex;flex-direction:column;gap:3px;min-width:70px}.gen-price-analysis__stat-val{font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.gen-price-analysis__stat-val--empty{color:var(--color-text-muted)}.gen-price-analysis__stat-lbl{font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap}.gen-price-analysis__tooltip{position:fixed;transform:translate(-50%,-100%);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:10px;padding:6px 10px;pointer-events:none;z-index:50;display:flex;flex-direction:column;gap:2px;white-space:nowrap;animation:tooltip-in .08s ease}.gen-price-analysis__tooltip-price{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.gen-price-analysis__tooltip-stat{font-size:13px;font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums}@keyframes tooltip-in{0%{opacity:0;transform:translate(-50%,-90%)}to{opacity:1;transform:translate(-50%,-100%)}}.stat-val--positive{color:#16a34a!important}.stat-val--negative{color:#dc2626!important}.generator-page{width:100%;box-sizing:border-box}.generator-page h1{font-size:22px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.4px;margin-bottom:1.5rem}.generator-form{background:var(--color-surface);border-radius:16px;border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-shadow-rgb),.08);overflow:hidden;margin-bottom:1.5rem}.generator-form__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);cursor:pointer;user-select:none;transition:background .1s ease}.generator-form__header:hover{background:var(--color-hover)}.generator-form__header h2{font-size:16px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.generator-form__header .chevron{color:var(--color-text-muted);transition:transform .2s ease}.generator-form__header .chevron--open{transform:rotate(180deg)}.generator-form__body{padding:1.5rem}.generator-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin-bottom:1.5rem}@media (max-width: 640px){.generator-form__grid{grid-template-columns:1fr}}.generator-form__field{display:flex;flex-direction:column;gap:6px}.generator-form__field label{font-size:12px;font-weight:600;color:var(--color-text-muted);letter-spacing:.04em;text-transform:uppercase}.generator-form__field input[type=text],.generator-form__field input[type=number]{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,box-shadow .15s ease;outline:none}.generator-form__field input[type=text]:focus,.generator-form__field input[type=number]:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.generator-form__field--checkbox{flex-direction:row;align-items:center;gap:10px}.generator-form__field--checkbox label{text-transform:none;font-size:14px;font-weight:500;color:var(--color-text-primary);letter-spacing:0;cursor:pointer}.generator-form__field--checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer}.generator-form__actions{display:flex;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--color-border);gap:8px}.generator-form .subsidy-section{background:var(--color-bg);border-radius:12px;border:1px solid var(--color-border);margin-bottom:1.5rem;overflow:hidden}.generator-form .subsidy-section__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;user-select:none;transition:background .1s ease}.generator-form .subsidy-section__header:hover{background:var(--color-hover)}.generator-form .subsidy-section__header h3{font-size:14px;font-weight:600;color:var(--color-text-primary)}.generator-form .subsidy-section__body{padding:1rem 1.25rem;border-top:1px solid var(--color-border)}.generator-form .subsidy-section .subsidy-table-wrap{overflow-x:auto;margin-bottom:1rem}.generator-form .subsidy-section table{width:100%;border-collapse:collapse;font-size:13px}.generator-form .subsidy-section table th{padding:8px 10px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;text-align:left}.generator-form .subsidy-section table td{padding:6px 8px;border-bottom:1px solid var(--color-border);vertical-align:middle}.generator-form .subsidy-section table .cell-center{text-align:center}.generator-form .subsidy-section table input.input{padding:5px 8px;font-size:13px;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);outline:none;transition:border-color .15s ease}.generator-form .subsidy-section table input.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-light)}.generator-form .subsidy-section table input.input--num{width:80px;text-align:right}.generator-form .subsidy-section table input.input--text{width:100%}.generator-form .subsidy-section .btn-group{display:flex;gap:4px;justify-content:center}.generator-form .subsidy-section .small-button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text-secondary);font-size:13px;cursor:pointer;transition:background .1s ease,color .1s ease}.generator-form .subsidy-section .small-button:hover:not(:disabled){background:var(--color-hover);color:var(--color-text-primary)}.generator-form .subsidy-section .small-button:disabled{opacity:.4;cursor:not-allowed}.generator-form .subsidy-section .small-button.danger:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#fee2e2}.generator-form .subsidy-section__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.generator-form .subsidy-section .hint{font-size:12px;color:var(--color-text-muted);line-height:1.5}.field-hint{font-size:.75rem;color:var(--color-text-muted);font-weight:400}.generator-form__field--full{grid-column:1/-1}.color-picker{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.color-picker__swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s ease,border-color .1s ease;flex-shrink:0}.color-picker__swatch:hover{transform:scale(1.15)}.color-picker__swatch--active{border-color:#1a1f36;transform:scale(1.15);box-shadow:0 0 0 2px #fff,0 0 0 4px #1a1f36}.color-picker__swatch--custom{display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.color-picker__custom{position:relative;cursor:pointer}.color-picker__custom input[type=color]{position:absolute;opacity:0;width:0;height:0}.toggle-field{display:flex;flex-direction:column;gap:4px}.toggle-field__label{font-size:12px;font-weight:500;color:var(--color-text-secondary)}.toggle-field__box{height:36px;padding:0 12px;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);display:flex;align-items:center;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s,color .15s;user-select:none;color:var(--color-text-primary)}.toggle-field__box.is-off{color:var(--color-text-muted);background:var(--color-bg)}.toggle-field__box:hover{background:var(--color-hover)}.notif-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.notif-summary__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:14px}.notif-summary__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-summary__info{display:flex;flex-direction:column;gap:2px}.notif-summary__label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted)}.notif-summary__count{font-size:22px;font-weight:600;color:var(--color-text-primary);line-height:1}.notif-summary__trigger{display:flex;align-items:center}.notif-summary__trigger-system{font-size:11px;font-weight:600;background:var(--color-bg);color:var(--color-text-muted);padding:2px 8px;border-radius:8px;border:1px solid var(--color-border)}.notif-summary__trigger-user{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--color-text-primary)}.notif-summary__trigger-avatar{width:22px;height:22px;border-radius:50%;background:var(--color-accent-light);color:var(--color-accent);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-page__mark-all{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-muted);margin-left:auto}.notif-page__mark-all:hover{color:var(--color-text-primary)}.notif-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:var(--color-text-muted);font-size:14px}.notif-page__table{width:100%}.notif-page__row--unread{background:#3b82f608}.notif-page__type-cell{display:flex;align-items:center;gap:8px;white-space:nowrap}.notif-page__icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-page__type-label{font-size:12px;font-weight:600}.notif-page__title{font-size:13px;font-weight:500;color:var(--color-text-primary)}.notif-page__msg{font-size:12px;color:var(--color-text-secondary)}.notif-page__time{font-size:12px;color:var(--color-text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.notif-page__status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px}.notif-page__status--unread{background:#3b82f61a;color:#3b82f6}.notif-page__status--read{background:var(--color-bg);color:var(--color-text-muted)}: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;inset: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;inset: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:36px;height:36px;object-fit:contain;margin-bottom:20px;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}}@keyframes spin{to{transform:rotate(360deg)}}@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}
