@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard-dynamic-subset.min.css";:root{--primary-900: #1E3A8A;--primary-600: #2563eb;--primary-300: rgb(147, 197, 253);--primary-50: #EFF6FF;--red-50: #FEECEB;--red-500: #f44336;--yellow-500: #FEC02E;--yellow-50: #FFFDE7;--green-700: #00AA33;--green-400: #29D668;--green-50: #E5FAEA;--blue-500: #4FC3F7;--blue-100: #C8ECFD;--blue-50: #EDF9FE;--purple-500: #4649E3;--purple-50: #EAEAFC;--success: #22C55E;--error: #F96767;--primary: #2563EB;--primary-rgb: 37, 99, 235;--primary-light: #EFF6FF;--primary-dark: #1d4ed8;--secondary: #6b7280;--warning: #f59e0b;--info: #3b82f6;--info-500: #4FC3F7;--info-600: #48B1E1;--info-700: #388AAF;--graph-set-a1: #50E3C2;--graph-set-a2: #3BB5B0;--graph-set-a3: #31C1D9;--graph-set-a4: #1C90C3;--graph-set-a5: #0070C4;--graph-set-a6: #00599D;--graph-set-b1: #BEE6FF;--graph-set-b2: #89CDF8;--graph-set-b3: #54A6D9;--graph-set-b4: #2E83B6;--graph-set-b5: #025B93;--dashboard-shadow: 0 0 20px 0 #b3b3b320;--floating-shadow: 0 0 20px 0 #b3b3b330;--modal-shadow: 0 0 20px 0 #44444430;--radius: 8px;--radius-full: 9999px;--transition: all .2s ease-in-out}.theme-light{--gray-200: #F1F2F4;--gray-400: #CBD5E0;--gray-600: #718096;--gray-700: #323B49;--gray-800: #1F2937;--bg-body: #f9fafb;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--text-base: #111827;--text-secondary: #6b7280;--border-color: #e5e7eb;--sidebar-btn-bg: #EFF6FF;--sidebar-btn-text: #2563EB}.theme-dark{--gray-200: #404040;--gray-400: #737373;--gray-600: #d4d4d4;--gray-700: #e5e5e5;--gray-800: #f5f5f5;--bg-body: #1a1a1a;--bg-primary: #262626;--bg-secondary: #2d2d2d;--text-base: #fafafa;--text-secondary: #a3a3a3;--border-color: #404040;--sidebar-btn-bg: #2563EB;--sidebar-btn-text: #EFF6FF}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.align-center{align-items:center}.align-start{align-items:flex-start}.align-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.justify-around{justify-content:space-around}.items-start{align-items:flex-start}.items-center{align-items:center}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.cursor-pointer{cursor:pointer;transition:opacity .13s}.cursor-pointer:active{opacity:.3}.gap-1{gap:2px}.gap-2{gap:4px}.gap-3{gap:6px}.gap-4{gap:8px}.gap-5{gap:10px}.gap-6{gap:12px}.gap-7{gap:14px}.gap-8{gap:16px}.gap-10{gap:20px}.gap-12{gap:24px}.gap-14{gap:28px}.gap-16{gap:32px}.gap-20{gap:40px}.gap-24{gap:48px}.gap-28{gap:56px}.gap-32{gap:64px}.m-1{margin:2px}.m-2{margin:4px}.m-4{margin:8px}.m-5{margin:10px}.mt-1{margin-top:2px}.mt-2{margin-top:4px}.mt-4{margin-top:8px}.mt-5{margin-top:10px}.mt-8{margin-top:16px}.mt-10{margin-top:20px}.mt-12{margin-top:24px}.mt-14{margin-top:28px}.mt-16{margin-top:32px}.mt-20{margin-top:40px}.mb-1{margin-bottom:2px}.mb-2{margin-bottom:4px}.mb-4{margin-bottom:8px}.mb-5{margin-bottom:10px}.mb-10{margin-bottom:20px}.mb-16{margin-bottom:32px}.mb-20{margin-bottom:40px}.ml-1{margin-left:2px}.ml-2{margin-left:4px}.ml-4{margin-left:8px}.ml-5{margin-left:10px}.mr-1{margin-right:2px}.mr-2{margin-right:4px}.mr-4{margin-right:8px}.mr-5{margin-right:10px}.mr-10{margin-right:20px}.mx-1{margin-left:2px;margin-right:2px}.mx-2{margin-left:4px;margin-right:4px}.mx-4{margin-left:8px;margin-right:8px}.mx-5{margin-left:10px;margin-right:10px}.mx-8{margin-left:16px;margin-right:16px}.my-1{margin-top:2px;margin-bottom:2px}.my-2{margin-top:4px;margin-bottom:4px}.my-4{margin-top:8px;margin-bottom:8px}.my-5{margin-top:10px;margin-bottom:10px}.my-8{margin-top:16px;margin-bottom:16px}.my-10{margin-top:20px;margin-bottom:20px}.my-12{margin-top:24px;margin-bottom:24px}.my-14{margin-top:28px;margin-bottom:28px}.my-16{margin-top:32px;margin-bottom:32px}.my-20{margin-top:40px;margin-bottom:40px}.my-30{margin-top:60px;margin-bottom:60px}.p-0{padding:0}.p-1{padding:2px}.p-2{padding:4px}.p-4{padding:8px}.p-5{padding:10px}.p-8{padding:16px}.p-10{padding:20px}.p-16{padding:32px}.p-20{padding:40px}.pt-1{padding-top:2px}.pt-2{padding-top:4px}.pt-4{padding-top:8px}.pt-5{padding-top:10px}.pt-8{padding-top:16px}.pt-10{padding-top:20px}.pt-16{padding-top:32px}.pt-20{padding-top:40px}.pb-1{padding-bottom:2px}.pb-2{padding-bottom:4px}.pb-4{padding-bottom:8px}.pb-5{padding-bottom:10px}.pb-10{padding-bottom:20px}.pb-12{padding-bottom:24px}.pb-14{padding-bottom:28px}.pb-16{padding-bottom:32px}.pb-20{padding-bottom:40px}.pl-1{padding-left:2px}.pl-2{padding-left:4px}.pl-4{padding-left:8px}.pl-5{padding-left:10px}.pl-8{padding-left:16px}.pl-10{padding-left:20px}.pl-20{padding-left:40px}.pl-24{padding-left:48px}.pl-32{padding-left:64px}.pr-1{padding-right:2px}.pr-2{padding-right:4px}.pr-4{padding-right:8px}.pr-5{padding-right:10px}.pr-10{padding-right:20px}.pr-16{padding-right:32px}.px-1{padding-left:2px;padding-right:2px}.px-2{padding-left:4px;padding-right:4px}.px-4{padding-left:8px;padding-right:8px}.px-5{padding-left:10px;padding-right:10px}.px-6{padding-left:12px;padding-right:12px}.px-7{padding-left:14px;padding-right:14px}.px-8{padding-left:16px;padding-right:16px}.px-9{padding-left:18px;padding-right:18px}.px-10{padding-left:20px;padding-right:20px}.px-12{padding-left:24px;padding-right:24px}.px-14{padding-left:28px;padding-right:28px}.px-15{padding-left:30px;padding-right:30px}.px-16{padding-left:32px;padding-right:32px}.px-20{padding-left:40px;padding-right:40px}.px-24{padding-left:48px;padding-right:48px}.px-28{padding-left:56px;padding-right:56px}.px-30{padding-left:60px;padding-right:60px}.px-36{padding-left:72px;padding-right:72px}.px-40{padding-left:80px;padding-right:80px}.px-32{padding-left:64px;padding-right:64px}.py-1{padding-top:2px;padding-bottom:2px}.py-2{padding-top:4px;padding-bottom:4px}.py-3{padding-top:6px;padding-bottom:6px}.py-4{padding-top:8px;padding-bottom:8px}.py-5{padding-top:10px;padding-bottom:10px}.py-10{padding-top:20px;padding-bottom:20px}.py-16{padding-top:32px;padding-bottom:32px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-normal{font-weight:400}.text-h1{font-size:32px;font-weight:700}.text-h2{font-size:24px;font-weight:700}.text-b1-700{font-size:20px;font-weight:700}.text-b1-400{font-size:20px;font-weight:400}.text-b2-700{font-size:16px;font-weight:700}.text-b2-400{font-size:16px;font-weight:400}.text-b3-700{font-size:14px;font-weight:700}.text-b3-400{font-size:14px;font-weight:400}.text-c1-700{font-size:14px;font-weight:700}.text-c1-400{font-size:14px;font-weight:400}.text-c2-700{font-size:12px;font-weight:700}.text-c2-400{font-size:12px;font-weight:400}.text-c3-700{font-size:10px;font-weight:700}.text-c3-400{font-size:10px;font-weight:400}.font-light{font-weight:300}.font-weight-500{font-weight:500}.font-weight-600{font-weight:600}.font-weight-700{font-weight:700}.font-size-5{font-size:.5rem}.font-size-6{font-size:.6rem}.font-size-7{font-size:.7rem}.font-size-8{font-size:.8rem}.font-size-9{font-size:.9rem}.font-size-10{font-size:1rem}.font-size-11{font-size:1.1rem}.font-size-12{font-size:1.2rem}.font-size-13{font-size:1.3rem}.font-size-15{font-size:1.5rem}.font-size-20{font-size:2rem}.font-size-25{font-size:2.5rem}.font-size-175{font-size:1.75rem}.text-lg{font-size:1.125rem}.text-base{color:var(--text-base)}.text-primary{color:var(--primary-600)}.text-primary-900{color:var(--primary-900)}.text-primary-dark{color:var(--primary-dark)}.text-secondary{color:var(--secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.text-info{color:var(--info)}.text-white{color:#fff}.text-gray-50{color:var(--gray-50)}.text-gray-100{color:var(--gray-100)}.text-gray-200{color:var(--gray-200)}.text-gray-300{color:var(--gray-300)}.text-gray-400{color:var(--gray-400)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-800{color:var(--gray-800)}.text-gray-900{color:var(--gray-900)}.text-red-500{color:var(--red-500)}.text-blue-500{color:var(--blue-500)}.text-blue-50{color:var(--blue-50)}.text-blue-100{color:var(--blue-500)}.text-green-700{color:var(--green-700)}.text-green-400{color:var(--green-400)}.text-green-50{color:var(--green-50)}.text-green-100{color:var(--green-500)}.text-yellow-500{color:var(--yellow-500)}.text-yellow-50{color:var(--yellow-50)}.text-info-500{color:var(--info-500)}.text-info-600{color:var(--info-600)}.text-info-700{color:var(--info-700)}.text-gold{color:gold}.text-underline{text-decoration:underline}.bg-body{background-color:var(--bg-body)}.bg-white{background-color:var(--white)}.bg-gray-200{background-color:var(--gray-200)}.bg-gray-400{background-color:var(--gray-400)}.bg-gray-600{background-color:var(--gray-600)}.bg-gray-700{background-color:var(--gray-700)}.bg-gray-800{background-color:var(--gray-800)}.bg-primary{background-color:var(--bg-primary)}.bg-primary-light{background-color:var(--primary-light)}.bg-primary-dark{background-color:var(--primary-dark)}.bg-secondary{background-color:var(--secondary)}.bg-success{background-color:var(--success)}.bg-warning{background-color:var(--warning)}.bg-error{background-color:var(--error)}.bg-info{background-color:var(--info)}.bg-transparent{background-color:transparent}.bg-blue-50{background-color:var(--blue-50)}.bg-red-100{background-color:#fee2e2}.bg-black{background-color:#000}.bg-black-opacity-30{background-color:#0000004d}.bg-black-opacity-20{background-color:#0003}.bg-black-opacity-10{background-color:#0000001a}.border{border:1px solid var(--border-color)}.border-0{border:none}.border-2{border-width:2px}.border-100{border-radius:100ph}.border-gray{border-color:var(--border-color)}.border-gray-200{border-color:var(--gray-200)}.border-gray-300{border-color:var(--gray-300)}.border-primary{border-color:var(--primary)}.border-red-400{border-color:#f87171}.border-blue-500{border-color:var(--blue-500)}.border-white-600{border-color:#fff}.border-b{border-bottom:1px solid var(--border-color)}.border-b-2{border-bottom-width:2px}.border-t{border-top:1px solid var(--border-color)}.border-t-primary{border-top-color:var(--primary)}.shadow-dashboard{box-shadow:var(--dashboard-shadow)}.shadow-floating{box-shadow:var(--floating-shadow)}.shadow-modal{box-shadow:var(--modal-shadow)}.shadow{box-shadow:var(--shadow)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.rounded{border-radius:var(--radius)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.rounded-top{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-bottom{border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius)}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.top-4{top:16px}.top-8{top:32px}.top-10{top:40px}.top-12{top:48px}.top-14{top:56px}.top-16{top:64px}.top-20{top:80px}.top-24{top:96px}.top-28{top:112px}.top-32{top:128px}.bottom-0{bottom:0}.bottom-4{bottom:16px}.bottom-8{bottom:32px}.left-0{left:0}.left-4{left:16px}.left-8{left:32px}.right-4{right:16px}.right-8{right:32px}.absolute-horizontal-center{left:50%;transform:translate(-50%)}.center-horizontal{margin:0 auto}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-100{z-index:100}.w-full{width:100%}.w-three-quarter{width:75%}.w-half{width:50%}.w-quarter{width:25%}.h-full{height:100%}.h-half{height:50%}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.h-1{height:4px}.h-2{height:8px}.h-3{height:12px}.h-4{height:16px}.h-5{height:20px}.h-6{height:24px}.h-7{height:28px}.h-8{height:32px}.h-10{height:40px}.h-12{height:48px}.h-32{height:128px}.w-1{width:4px}.w-2{width:8px}.w-3{width:12px}.w-4{width:16px}.w-5{width:20px}.w-6{width:24px}.w-7{width:28px}.w-8{width:32px}.w-10{width:40px}.w-12{width:48px}.w-16{width:64px}.w-20{width:80px}.animate-spin{animation:spin 1s linear infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}.hover\:text-gray-700:hover{color:var(--gray-700)}.hover\:bg-gray-100:hover{background-color:var(--gray-100)}.hover\:shadow-md:hover{box-shadow:var(--shadow-md)}.overflow-y-scroll{overflow-y:scroll;-webkit-overflow-scrolling:touch}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--primary);border-radius:50%;border-top-color:var(--white);animation:spin 1s ease-in-out infinite}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;display:inline-block}.status-badge.success{background-color:var(--green-50);color:var(--green-700)}.status-badge.error{background-color:var(--red-50);color:var(--red-500)}.status-badge.warning{background-color:var(--yellow-50);color:var(--yellow-500)}.status-badge.info{background-color:var(--blue-50);color:var(--blue-500)}.status-badge.critical{background-color:var(--purple-50);color:var(--purple-500)}.status-badge.unknown{background-color:var(--gray-200);color:var(--gray-700)}.hr-gray{height:1px;background:var(--gray-300)}.disabled{opacity:.3;pointer-events:none}.white-space-nowrap{white-space:nowrap}.user-select-none{-webkit-user-select:none;user-select:none}.transition{transition:var(--transition)}.transition-fast{transition:var(--transition-fast)}.transition-slow{transition:var(--transition-slow)}.transform{transform:translateY(-2px)}.transform-hover:hover{transform:translateY(-1px)}.transform-active:active{transform:translateY(0)}.object-cover{object-fit:cover}.app-header{height:120px;background:var(--bg-primary)}.header-left{gap:1rem}.app-title{margin:0}.header-button{background:none;border:none;padding:.5rem;border-radius:100vh;font-size:1.125rem;min-width:2.5rem;height:2.5rem}.header-button:hover{background-color:var(--gray-100)}.header-btn.btn{width:40px;height:40px;border-radius:100vh;background:var(--bg-primary);border:2px solid var(--gray-400);display:flex;align-items:center;justify-content:center;position:relative}.header-btn.btn>svg{color:var(--gray-600)}.notification-count{position:absolute;top:4px;right:4px;transform:translate(50%,-50%);background:var(--error);color:var(--bg-primary);border-radius:100vh;padding:2px 6px;font-size:12px;font-weight:400}.app-sidebar{width:320px;background:var(--bg-primary);border-right:1px solid var(--border-color);transition:width .3s ease;overflow-y:overlay;overflow-x:hidden}.app-sidebar::-webkit-scrollbar{width:0;height:0}.app-sidebar::-webkit-scrollbar-track{width:0;height:0}.app-sidebar::-webkit-scrollbar-thumb{display:none}.app-sidebar::-webkit-scrollbar-thumb:hover{display:none}.app-sidebar.collapsed{width:80px}.sidebar-toggle{position:absolute;top:60px;left:320px;transform:translate(-50%,-50%);background:var(--primary-600);border-radius:100vh;width:60px;height:60px;color:#fff;z-index:888;transition:all .3s ease}.sidebar-toggle.collapsed{left:40px}.sidebar-toggle:hover{background-color:var(--primary-300)}.sidebar-toggle>svg{color:#fff;font-size:2rem}.sidebar-header{position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;width:319px;height:240px;padding:60px 0;background:var(--bg-primary);transition:width .3s ease}.sidebar-header:has(.collapsed){padding:0;height:120px;width:79px}.sidebar-logo.collapsed{width:40px;height:40px;opacity:0}.sidebar-nav{margin-top:240px;height:calc(100% - 240px)}.sidebar-nav.collapsed{margin-top:120px;height:calc(100% - 120px)}.nav-menu{list-style:none;margin:0;padding:0;gap:.5rem}.nav-item{width:100%;height:80px}.nav-link{flex:1;width:100%;height:100%;padding:0 40px;text-decoration:none;color:var(--gray-400);display:grid;grid-template-columns:30px 1fr;align-items:center}.nav-link:hover{background-color:var(--gray-100);color:var(--gray-600)}.nav-link.active{background-color:var(--sidebar-btn-bg);color:var(--sidebar-btn-text)}.nav-link.active>.nav-label{color:var(--sidebar-btn-text);font-weight:700;font-size:20px}.nav-icon{font-size:1.25rem;margin-right:.75rem;min-width:1.25rem;color:var(--gray-400)}.nav-label{color:var(--gray-600);font-size:20px;font-weight:400}.nav-label{white-space:nowrap;flex:1}.nav-arrow{font-size:.75rem;transition:transform .2s ease;margin-left:auto}.nav-arrow.expanded{transform:rotate(180deg)}.nav-item.has-children .nav-link{cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--bg-primary)}.nav-item.has-children .nav-link:hover{background:var(--bg-secondary)}.nav-item.has-children .nav-link.expanded{background:var(--sidebar-btn-bg);color:var(--sidebar-btn-text)}.sub-menu{list-style:none;margin:0;padding:0;background:var(--bg-secondary);border-radius:.375rem;margin:0 .5rem .25rem;overflow:hidden}.sub-nav-item{margin:0}.sub-nav-link{padding:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.8rem}.sub-nav-link:hover{background-color:var(--gray-100);color:var(--text-primary)}.sub-nav-link.active{background-color:var(--sidebar-btn-bg);color:var(--sidebar-btn-text)}.sub-nav-icon{font-size:1rem;margin-right:.5rem;min-width:1rem}.sub-nav-label{font-size:.8rem;font-weight:400;white-space:nowrap}.app-sidebar.collapsed .nav-link{justify-content:center;padding:0;align-items:center;display:flex}.app-sidebar.collapsed .nav-icon{margin-right:0}.app-sidebar.collapsed .nav-label,.app-sidebar.collapsed .nav-arrow{display:none}.theme-toggle-segment{display:flex;background:var(--gray-200);border-radius:8px;padding:4px;gap:0;box-shadow:inset 0 1px 3px #0000001a;border:1px solid var(--gray-300)}.theme-segment-option{display:flex;align-items:center;gap:8px;padding:8px 16px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:var(--gray-600);min-width:80px;justify-content:center;position:relative}.theme-segment-option:hover{color:var(--gray-700)}.theme-segment-option.active{background:var(--bg-primary);color:var(--gray-700);box-shadow:0 1px 3px #0000001a;font-weight:600}.theme-segment-option:active{transform:scale(.98)}.theme-icon{width:16px;height:16px;color:inherit;transition:color .2s ease}.theme-segment-option span{font-size:14px;font-weight:inherit;color:inherit}.theme-toggle-segment.collapsed{padding:4px;min-width:40px;justify-content:center}.theme-segment-option.collapsed{padding:8px;min-width:36px;width:36px;height:36px;border-radius:8px;justify-content:center;background:var(--bg-primary);color:var(--gray-700);box-shadow:0 1px 3px #0000001a;font-weight:600}.theme-segment-option.collapsed:hover{background:var(--gray-100);color:var(--gray-800)}.theme-segment-option.collapsed:active{transform:scale(.95)}.theme-segment-option.collapsed .theme-icon{width:18px;height:18px}.theme-segment-option.collapsed span{display:none}@media (max-width: 768px){.theme-toggle-segment{padding:3px}.theme-segment-option{padding:6px 12px;min-width:70px;font-size:13px}.theme-icon{width:14px;height:14px}.theme-segment-option span{font-size:13px}.theme-toggle-segment.collapsed{padding:2px;min-width:36px}.theme-segment-option.collapsed{padding:6px;min-width:32px;width:32px;height:32px}.theme-segment-option.collapsed .theme-icon{width:16px;height:16px}}.app-footer{background:var(--bg-primary);border-top:1px solid var(--border-color);padding:1rem 0;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:0 1rem}.footer-left{flex:1}.footer-text{font-size:.875rem}.footer-center{flex:2}.footer-nav{gap:1.5rem}.footer-link{font-size:.875rem;text-decoration:none}.footer-link:hover{color:var(--text-primary)}.footer-right{flex:1}.version-text{font-size:.875rem}.app-layout{height:100vh;background-color:var(--bg-secondary)}.app-content{flex:1;overflow:hidden;background-color:var(--bg-secondary)}.main-content{flex:1;overflow:hidden;background-color:var(--bg-primary)}.content-wrapper{flex:1;overflow-y:auto}.app-layout.sidebar-collapsed>.sidebar{width:60px}.app-layout.sidebar-collapsed>.sidebar .nav-item-text{display:none}.app-layout.sidebar-collapsed>.sidebar .nav-item-icon{margin-right:0}.app-layout,.sidebar,.main-content{transition:all .3s ease}.content-wrapper::-webkit-scrollbar{width:6px}.content-wrapper::-webkit-scrollbar-track{background:var(--gray-100);border-radius:3px}.content-wrapper::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.content-wrapper::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dashboard-page-container{padding:32px;background-color:var(--bg-body);min-width:1500px;height:100%}.dashboard-header{margin-bottom:32px}.edit-mode-toggle{padding:8px 16px;background:var(--primary-600);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.edit-mode-toggle:hover{background:var(--primary-700)}.edit-mode-toggle.active{background:var(--green-600)}.edit-mode-toggle.active:hover{background:var(--green-700)}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:24px;width:100%}.dashboard-weather-forecast-item{display:flex;align-items:center;gap:20px;padding:15px 10px;border-radius:8px;background:var(--bg-primary)}.dashboard-weather-forecast-item:nth-child(odd){background:var(--bg-body)}.region-selector{position:relative;width:100%;background:var(--bg-primary);z-index:1000;box-shadow:var(--dashboard-shadow)}.region-selector.absolute{z-index:2000;contain:none}.region-selector.absolute .region-dropdown-panel.absolute{min-width:100%;border-top:none}.region-selector.compact .region-header-item{height:60px;padding:8px 12px}.region-selector.compact .region-dropdown-panel.absolute{min-height:200px}.region-header{display:grid;align-items:center;grid-template-columns:1fr 1fr 1fr}.region-header-item{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 12px;height:80px;border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative}.region-header-item:after{content:"";display:block;width:1px;height:33%;background:var(--gray-400);position:absolute;right:0;top:33%;bottom:0}.region-header-item:last-child:after{display:none}.region-header-item.active{color:var(--primary-600)}.region-label{font-size:20px;font-weight:400;color:var(--gray-700)}.region-header-item.active .region-label{color:var(--primary-600)}.region-selector-chevron.chevron{font-size:12px;color:var(--gray-400);transition:transform .2s ease}.region-selector-chevron.chevron.up{color:var(--primary-600);transform:rotate(180deg)}.region-separator{color:var(--gray-400);font-size:16px;margin:0 8px}.region-dropdown-panel{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-primary);max-height:300px;overflow:hidden}.region-dropdown-panel.absolute{position:absolute!important;top:100%!important;left:0!important;right:0!important;z-index:9999!important;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f!important;border:1px solid var(--gray-200);background:var(--bg-primary)!important;display:grid!important;grid-template-columns:1fr 1fr 1fr!important;width:100%!important;min-width:100%!important}.region-column{min-width:120px;background:var(--gray-200)}.region-column:last-child{border-right:none}.region-option{height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:400;transition:all .2s ease;background:var(--bg-primary)}.region-option.selected{background:var(--primary-50);color:var(--primary-600)}.region-option:last-child{border-bottom:none}.region-column:has(.region-option){max-height:250px;overflow-y:auto}.region-column:has(.region-option)::-webkit-scrollbar{width:6px}.region-column:has(.region-option)::-webkit-scrollbar-track{background:#f1f5f9}.region-column:has(.region-option)::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.region-column:has(.region-option)::-webkit-scrollbar-thumb:hover{background:#94a3b8}.region-dropdown-panel{animation:slideDown .2s ease-out}.draggable-card{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.dashboard-card{background:var(--bg-primary);border-radius:var(--radius);padding:24px;box-shadow:var(--dashboard-shadow);transition:var(--transition);width:100%;height:100%;box-sizing:border-box;overflow:hidden;display:flex;flex-direction:column}.dashboard-card.primary-card{background:var(--primary-600)}.dashboard-card.none-card{background:transparent;box-shadow:none;border-radius:0;padding:0}.dashboard-card.dispatch-card,.dashboard-card.charging-demand-card,.dashboard-card.power-demand-card{padding:24px}.dashboard-card.none-card:hover{box-shadow:none;transform:none}.dashboard-card:hover{box-shadow:var(--floating-shadow);transform:translateY(-2px)}.dashboard-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dashboard-status-badge{padding:4px 12px;border-radius:100vh;font-size:20px;font-weight:700}.dashboard-status-badge.active{color:#fff;background:var(--red-500)}.icon-container{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center}.icon-white{background:#fff;color:var(--primary-600)}.icon-blue{background:var(--primary-50);color:var(--primary-600)}.icon-primary{background:var(--primary-600);color:#fff}.icon-green{background:var(--green-50);color:var(--green-400)}.icon-yellow{background:var(--yellow-50);color:var(--yellow-500)}.icon{font-size:20px}.metric-value{font-size:32px;font-weight:700;color:var(--gray-800);margin:8px 0}.temperature{font-size:24px;font-weight:700;color:var(--gray-800);margin:8px 0}.weather-details{display:flex;gap:12px;font-size:12px;color:var(--gray-600)}.current-price{font-size:18px;font-weight:700;color:#2563eb;margin-bottom:8px}.price-range{display:flex;gap:12px;font-size:12px;color:var(--gray-600);margin-bottom:12px}.price-chart{margin-top:12px;height:120px;width:100%}.chart-bars{display:flex;gap:8px;align-items:end}.bar{flex:1;height:20px;background:var(--gray-200);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--gray-600)}.bar.active{background:#2563eb;color:#fff}.charger-status{display:flex;gap:8px;border-radius:100vh;background:var(--bg-body);padding:4px 8px;font-size:16px;font-weight:400}.dispatch-time{font-size:16px;font-weight:500;color:var(--gray-800);margin-bottom:4px}.relative-time{color:var(--primary-600);background:var(--blue-50);padding:4px 8px;border-radius:100vh;font-size:14px;font-weight:700}.last-dispatch-time-info{border-radius:8px;background:var(--bg-body);width:fit-content;padding:4px 8px}.demand-info{display:flex;align-items:center;gap:8px;margin-bottom:16px}.increase{color:#16a34a;font-weight:500}.demand-value{font-size:20px;font-weight:700;color:var(--gray-800);margin-bottom:8px}.comparison{margin-bottom:12px}.chart-placeholder{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:var(--radius);padding:20px;text-align:center;color:var(--gray-500);font-size:12px;margin-top:12px}.dr-dispatch-area{background:#fee2e2;color:#dc2626;padding:4px 8px;border-radius:4px;font-size:10px;margin:8px 0;display:inline-block}.data-point{background:var(--gray-100);padding:4px 8px;border-radius:4px;font-size:10px;margin-top:8px;display:inline-block}.card-actions{display:flex;gap:8px}.btn-secondary{padding:6px 12px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:var(--radius);font-size:12px;color:var(--gray-700);cursor:pointer;transition:var(--transition)}.btn-secondary:hover{background:var(--gray-200)}@media (max-width: 768px){.dashboard-card{padding:16px}.metric-value{font-size:24px}.temperature{font-size:20px}.current-price{font-size:16px}}.dashboard-charging-demand-chart-container,.dashboard-power-demand-chart-container{flex:1;min-height:0;overflow:auto}.dashboard-comparison{border-radius:100vh;padding:4px 8px;font-size:12px;font-weight:400;color:var(--gray-600);display:flex;align-items:center;gap:4px}.dashboard-comparison.increase{background:var(--green-50);color:var(--green-400)}.dashboard-comparison.decrease{background:var(--yellow-50);color:var(--yellow-500)}.dashboard-comparison.same{background:var(--gray-200);color:var(--gray-600)}.dashboard-comparison.warning{background:var(--red-50);color:var(--red-500)}.dashboard-comparison.none{background:var(--gray-200);color:var(--gray-600)}.power-demand-chart-container{position:relative;width:100%;height:100%;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;overflow:hidden}.change-arrow{color:#10b981;font-weight:700;font-size:16px}.change-percentage{color:#10b981;font-weight:600}.change-time{color:#64748b;font-weight:400}.power-demand-chart-wrapper{position:relative;width:100%;height:100%}.hovered-point{position:absolute;top:0;bottom:0;width:2px;z-index:8;transform:translate(-50%)}.hovered-point-circle{display:none}.hovered-point-line{position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:1px;background:#3b82f6;opacity:.6}.power-demand-tooltip{position:absolute;top:20px;left:50%;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:16px 20px;box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.2);z-index:10;min-width:180px;text-align:center;pointer-events:none}.power-demand-tooltip-value{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.power-demand-tooltip-comparison{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px}.power-demand-comparison-badge{display:inline-flex;align-items:center;gap:6px;background:#f0f9ff;border:1px solid #e0f2fe;border-radius:20px;padding:6px 12px;font-size:12px}.power-demand-comparison-badge.increase{background:#f0fdf4;border-color:#bbf7d0}.power-demand-comparison-badge.decrease{background:#fef2f2;border-color:#fecaca}.comparison-arrow{font-size:12px;font-weight:600}.comparison-arrow.increase{color:#16a34a}.comparison-arrow.decrease{color:#dc2626}.comparison-percentage{font-size:12px;font-weight:600}.comparison-percentage.increase{color:#16a34a}.comparison-percentage.decrease{color:#dc2626}.comparison-time{font-size:11px;color:#64748b}.dashboard-dr-history-item{display:grid;grid-template-columns:1fr 1fr .5fr auto;align-items:center;gap:2px}.dashboard-dr-working-info{width:fit-content;background:var(--bg-body);color:var(--gray-600);padding:4px 12px;border-radius:100vh;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center}.dashboard-dr-working-info.working{background:var(--red-500);color:#fff}.dashboard-dr-working-info.not-working{background:var(--gray-600);color:#fff}.draggable-card.edit-mode{position:relative}.draggable-card.edit-mode:not(.disabled){cursor:move}.draggable-card.edit-mode:not(.disabled):active{cursor:grabbing}.draggable-card.edit-mode.dragging{z-index:1000}.draggable-card.disabled .card-edit-overlay{pointer-events:auto;opacity:1!important}.drag-handle{position:absolute;top:8px;right:8px;width:32px;height:32px;background:var(--primary-600);border-radius:4px;cursor:grab!important;z-index:10;opacity:.7;transition:opacity .2s;display:flex;align-items:center;justify-content:center;pointer-events:auto}.drag-handle:before{content:"⋮⋮";color:#fff;font-size:14px;line-height:1;font-weight:700}.draggable-card.edit-mode:hover .drag-handle{opacity:1;background:var(--primary-600)}.drag-handle:hover{opacity:1!important;background:var(--primary-600)}.card-edit-overlay{position:absolute;top:8px;right:8px;z-index:100;opacity:0;transition:opacity .2s;pointer-events:none}.draggable-card.edit-mode:hover .card-edit-overlay,.draggable-card.edit-mode .card-edit-overlay:hover{opacity:1;pointer-events:auto}.draggable-card.edit-mode .toggle-card-btn:hover~*,.draggable-card.edit-mode .card-edit-overlay:hover{opacity:1;pointer-events:auto}.toggle-card-btn{padding:8px 16px;background:var(--primary-600);border:none;border-radius:4px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;pointer-events:auto;z-index:101;box-shadow:0 2px 4px #0000001a;user-select:none;-webkit-user-select:none}.toggle-card-btn:hover{background:var(--primary-700);box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.toggle-card-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.simple-bar-chart{width:100%;height:100px;position:relative}.simple-bar-chart canvas{width:100%!important;height:100%!important}@media (max-width: 768px){.simple-bar-chart{height:80px}}.chart-wrapper{position:relative;background:var(--bg-primary);padding:20px;border:1px solid var(--gray-400)}.chart-wrapper.no-border{background:var(--bg-primary);border:none}.chart-wrapper.no-padding{padding:0}.chart-wrapper canvas{max-height:100%!important}.line-chart{min-height:300px}.chart-loading{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text-secondary)}.chart-loading .loading-spinner{width:24px;height:24px;border:2px solid var(--gray-400);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-right:12px}.chart-update-overlay{position:absolute;inset:0;background:#fffc;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.chart-update-spinner{width:20px;height:20px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-600);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:8px}.chart-update-overlay span{font-size:12px;color:var(--gray-600);font-weight:500}.smooth-chart{transition:opacity .3s ease}.smooth-chart.updating{opacity:.95}.chart-error{display:flex;align-items:center;justify-content:center;height:300px;color:var(--gray-600);text-align:center;padding:20px}.chart-error .error-icon{font-size:24px;margin-bottom:8px}.chart-no-data{display:flex;align-items:center;justify-content:center;height:300px;color:var(--gray-600);text-align:center;padding:20px}.grid-layout-group{margin-bottom:40px}.group-label{margin-bottom:16px;font-weight:600}.grid-layout-container{position:relative;min-height:200px;width:100%}.grid-layout-container.edit-mode{border:2px solid var(--gray-400);padding:16px;border-radius:var(--radius);transition:border-color .2s,background-color .2s;background-color:var(--bg-body)}.grid-layout-container.edit-mode:hover{border-color:var(--primary-600)}.grid-layout-container.edit-mode.dragging-active{border-color:var(--primary-600);background-color:var(--primary-50);transition:border-color .2s,background-color .2s}.grid-layout-container.disabled-group{background-color:var(--bg-body);border:1px solid var(--gray-200)}.empty-layout-message{padding:40px;text-align:center;color:var(--gray-500);font-size:14px}.dashboard-grid-layout{position:relative}.grid-item-wrapper{width:100%;height:100%;box-sizing:border-box;overflow:hidden}.grid-item-wrapper.react-grid-item,.react-grid-item{box-sizing:border-box}.grid-item-wrapper.react-grid-item{transition:all .2s ease}.grid-item-wrapper.react-grid-item.cssTransforms{transition-property:transform}.grid-item-wrapper.react-grid-item.resizing{z-index:1;will-change:width,height}.grid-item-wrapper.react-grid-item.dragging{z-index:2;will-change:transform}.grid-item-wrapper.react-grid-item.react-draggable-dragging{transition:none;z-index:3}.grid-item-wrapper.react-grid-item.dropping{visibility:hidden}.grid-item-wrapper.react-grid-item.react-grid-placeholder{background:var(--primary-50);opacity:.4;border:2px dashed var(--primary-600);border-radius:var(--radius);transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.grid-item-wrapper.react-grid-item.react-draggable{cursor:move}.grid-item-wrapper.react-grid-item.react-draggable-dragging{cursor:grabbing}.grid-item-wrapper.react-grid-item.react-draggable-draggable{cursor:move!important}.grid-item-wrapper.react-grid-item.react-draggable-dragging{cursor:grabbing!important;opacity:.8;z-index:1000}.drag-handle{cursor:grab!important;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing!important}.edit-mode .draggable-card{cursor:move}.edit-mode .draggable-card:active{cursor:grabbing}.skeleton{background:var(--gray-400);display:inline-block;position:relative;overflow:hidden}.skeleton-text{display:block;margin-bottom:8px}.skeleton-text:last-child{margin-bottom:0}.skeleton-text-lines{display:flex;flex-direction:column}.skeleton-circle{display:inline-block}.skeleton-rectangle{display:block}.skeleton-table{width:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.skeleton-table-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.skeleton-table-header-cell{padding:16px 12px;display:inline-block;vertical-align:top;width:12.5%}.skeleton-table-body{background-color:var(--bg-primary)}.skeleton-table-row{display:flex;border-bottom:1px solid var(--border-color);padding:16px 12px;align-items:center}.skeleton-table-row:last-child{border-bottom:none}.skeleton-table-row.even-row{background-color:var(--bg-secondary)}.skeleton-table-row.odd-row{background-color:var(--bg-primary)}.skeleton-table-cell{flex:1;padding:0 8px;display:flex;align-items:center}.skeleton-card{border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background-color:var(--bg-primary);box-shadow:0 1px 3px #0000001a}.skeleton-card-content{padding:16px}.skeleton-list-item{display:flex;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--border-color)}.skeleton-list-item:last-child{border-bottom:none}.skeleton-avatar,.skeleton-image{margin-right:16px;flex-shrink:0}.skeleton-list-content{flex:1;min-width:0}.skeleton-list-item.dark{border-bottom-color:#656871}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;width:100%}@media (max-width: 768px){.skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.skeleton-table-header-cell{width:25%}.skeleton-table-row{flex-wrap:wrap}.skeleton-table-cell{min-width:50%;margin-bottom:8px}}.skeleton{background:var(--gray-400)}.skeleton.dark{background:#656871;background-image:linear-gradient(to right,#656871,#888b94 20%,#656871 40% 100%)}.skeleton.high-contrast{background:#999;background-image:linear-gradient(to right,#999,#737373 20%,#999 40% 100%)}.skeleton[aria-hidden=true]{display:none}.skeleton .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.dashboard-skeleton-group{margin-bottom:32px}.dashboard-skeleton-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:24px;width:100%}.dashboard-skeleton-card-wrapper,.dashboard-skeleton-card{width:100%;height:100%;min-height:180px}.skeleton-text-title,.skeleton-button,.skeleton-region-selector,.skeleton-aggregation{background:var(--gray-400);border-radius:var(--radius);position:relative;overflow:hidden}.skeleton-text-title:before,.skeleton-button:before,.skeleton-region-selector:before,.skeleton-aggregation:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.dashboard-skeleton-card .skeleton-card{opacity:.8;transition:opacity .3s ease}.dashboard-skeleton-card .skeleton-card:hover{opacity:1}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.accordion{background:var(--bg-primary);overflow:hidden}.accordion-item{border-bottom:1px solid var(--border-color)}.accordion-item:first-child{border-top:1px solid var(--border-color)}.accordion-item:last-child{border-bottom:none}.accordion-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;transition:var(--transition);background:var(--bg-primary)}.accordion-header:hover{background:var(--gray-200)}.accordion-header-content{display:flex;align-items:center;gap:12px;flex:1;margin-left:8px}.accordion-title{font-size:16px;font-weight:700;color:var(--text-base);line-height:1.4}.accordion-title.open{color:var(--primary-600)}.accordion-badge{font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--gray-200);padding:2px 8px;border-radius:var(--radius)}.accordion-chevron{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-secondary);transition:.13s;transform:rotate(-90deg)}.accordion-chevron.open{transform:rotate(0)}.accordion-content{background:var(--bg-primary);border-top:1px solid var(--border-color)}.accordion-child-item{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 12px 48px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border-color)}.accordion-child-item.selected{background:var(--gray-200)}.accordion-child-item:last-child{border-bottom:none}.accordion-child-item:hover{background:var(--gray-200)}.accordion-child-content{display:flex;flex-direction:column;gap:4px;flex:1}.accordion-child-title{font-size:16px;font-weight:400;color:var(--text-base);line-height:1.3}.accordion-child-title.selected{font-weight:700}.accordion-child-subtitle{font-size:16px;font-weight:400;color:var(--text-secondary)}.accordion-child-badge{font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--gray-200);padding:2px 8px;border-radius:var(--radius);min-width:40px;text-align:center}.accordion-content{animation:slideDown .2s ease-out}@media (max-width: 768px){.accordion-header{padding:12px 16px}.accordion-child-item{padding:10px 16px 10px 32px}.accordion-title,.accordion-child-title{font-size:13px}}.charger-comp-modal-background{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;display:flex;justify-content:center;align-items:flex-start;z-index:9999;overflow-y:auto}.charger-comp-modal-container{background:var(--bg-secondary);max-width:90%;min-width:1600px;width:fit-content;max-height:calc(100vh - 40px);box-shadow:0 4px 12px #0003;position:relative;animation:fadeIn .3s ease;margin:auto;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.charger-comp-modal-header{height:120px;background-color:var(--bg-primary);position:relative;display:flex;align-items:center;padding:0 32px}.charger-comp-modal-header h3{padding:0;margin:0;font-size:24px;font-weight:700;color:var(--text-primary)}.charger-comp-modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.charger-comp-modal-close-btn:hover{background:var(--gray-200);color:var(--text-base)}.charger-comp-modal-content-divide-container{display:grid;grid-template-columns:520px 1fr;gap:16px;background-color:var(--bg-secondary);flex:1;min-height:0}.charger-comp-modal-content-divide-content{flex:1;background-color:var(--bg-primary);overflow-y:overlay;min-height:0}.charger-comp-modal-category-select-list{position:relative}.charger-list{max-height:300px;overflow-y:auto;padding:0;background:var(--bg-primary)}.charger-comp-modal-container .charger-comp-modal-charger-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 20px 12px 48px;cursor:pointer;transition:var(--transition);background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.charger-comp-modal-container .charger-comp-modal-charger-item:last-child{border-bottom:none}.charger-comp-modal-container .charger-comp-modal-charger-item:hover,.charger-comp-modal-container .charger-comp-modal-charger-item.selected{background:var(--gray-200)}.charger-comp-modal-container .charger-comp-modal-charger-item.selected.charger-a{background:#2563eb1a;border-left:3px solid var(--primary-600)}.charger-comp-modal-container .charger-comp-modal-charger-item.selected.charger-b{background:#10b9811a;border-left:3px solid var(--green-400)}.charger-comp-modal-container .charger-item-info{display:flex;flex-direction:column;gap:4px;flex:1}.charger-comp-modal-container .charger-item-main{font-size:16px;font-weight:400;color:var(--text-base);line-height:1.3}.charger-comp-modal-container .charger-item-main.selected{font-weight:700}.charger-comp-modal-container .charger-item-sub{font-size:16px;font-weight:400;color:var(--text-secondary)}.charger-comp-modal-container .charger-comp-modal-charger-item .selection-indicator{margin-left:10px;font-size:12px;font-weight:500;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.charger-comp-modal-container .charger-comp-modal-charger-item .selection-indicator.charger-a{background-color:var(--primary-600)}.charger-comp-modal-container .charger-comp-modal-charger-item .selection-indicator.charger-b{background-color:var(--green-400)}.charger-comp-modal-container .selected-charger-display-container{padding:16px;display:flex;flex-direction:column;gap:16px}.charger-comp-modal-container .selected-charger-placeholder{padding:16px;border:1px dashed var(--border-color);border-radius:var(--radius);text-align:center;color:var(--text-secondary);min-height:80px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px}.charger-comp-modal-container .selected-charger-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);padding:12px;width:100%;text-align:left;display:flex;flex-direction:column;gap:4px}.charger-comp-modal-container .selected-charger-card.charger-a{background:#2563eb0d;border-left:4px solid var(--primary-600)}.charger-comp-modal-container .selected-charger-card.charger-b{background:#10b9810d;border-left:4px solid var(--green-400)}.charger-comp-modal-container .selected-charger-card .title{font-size:14px;font-weight:600;color:var(--text-base)}.charger-comp-modal-container .selected-charger-card .subtitle{font-size:12px;color:var(--text-secondary)}.charger-comp-modal-content-divide-content.right{padding:32px}.charger-comp-modal-content-divide-content.right .charger-comp-modal-category-select-header{padding:16px}.charger-comp-modal-container .charger-comparison-table{width:100%;border-collapse:collapse;background:var(--bg-primary);overflow:hidden}.charger-comp-modal-container .charger-comparison-table th,.charger-comp-modal-container .charger-comparison-table td{padding:16px 20px;text-align:center;border-bottom:8px solid var(--bg-primary)}.charger-comp-modal-container .charger-comparison-table thead{border-bottom:8px solid var(--bg-primary)}.charger-comp-modal-container .charger-comparison-table thead th{font-weight:400}.charger-comp-modal-container .charger-comparison-table th{background:var(--bg-primary);color:var(--text-base);font-size:16px;font-weight:700}.charger-comp-modal-container .charger-comparison-table th:first-child{background:var(--gray-200)}.charger-comp-modal-container .charger-comparison-table td{background:var(--bg-primary);color:var(--gray-700);font-size:16px;font-weight:400;position:relative}.charger-comp-modal-container .charger-comparison-table td:last-child:before{content:"";display:block;width:1px;height:80%;background:var(--gray-400);position:absolute;top:50%;transform:translateY(-50%);left:0}.charger-comp-modal-container .charger-comparison-table tr:last-child th,.charger-comp-modal-container .charger-comparison-table tr:last-child td{border-bottom:none}.charger-comp-modal-container .charger-header{display:flex;align-items:center;justify-content:center;gap:8px}.charger-comp-modal-container .charger-header .charger-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.charger-comp-modal-container .charger-header .charger-icon.charger-a{color:var(--primary-600)}.charger-comp-modal-container .charger-header .charger-icon.charger-b{color:var(--green-400)}.charger-icon-container{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:100vh}.charger-icon-container.charger-a{background-color:#93c5fd66;color:var(--primary-600)}.charger-icon-container.charger-b{background-color:#1dd66866;color:var(--green-700)}.charger-comp-modal-container .charger-header .charger-name{font-size:20px;font-weight:700}.charger-comp-modal-container .charger-header .charger-name.charger-a{color:var(--primary-600)}.charger-comp-modal-container .charger-header .charger-name.charger-b{color:var(--green-400)}.charger-comp-modal-container .charger-header .charger-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.charger-comp-modal-container .charger-header .charger-close-btn:hover{background:var(--gray-200);color:var(--text-base)}.charger-comp-modal-container .charger-placeholder{color:var(--text-secondary);font-style:italic;text-align:center}.charger-charts-comparison{margin-top:32px;padding-top:32px;border-top:1px solid var(--border-color)}.charger-charts-header{margin-bottom:24px}.charger-charts-header h3{font-size:20px;font-weight:700;color:var(--text-base);margin:0 0 8px}.charger-charts-header p{font-size:14px;color:var(--text-secondary);margin:0}.tabs.charger-comp-modal-tabs{grid-template-columns:repeat(3,1fr)}.charger-tab-content{min-height:500px}.charger-chart-section{width:100%}.charger-chart-header{margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.charger-chart-title{font-size:18px;font-weight:600;color:var(--text-base);margin:0}@media (max-width: 768px){.charger-tabs{flex-direction:column;gap:0}.charger-tab{border-bottom:1px solid var(--border-color);border-right:none}.charger-tab.active{border-bottom-color:var(--border-color);border-left:3px solid var(--primary-600)}.charger-tab.active:after{display:none}}.dr-resource-card{background:var(--bg-primary);border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:all .2s ease;overflow:hidden}.dr-resource-card:hover{border-color:var(--primary-600);box-shadow:0 2px 8px #3b82f61a}.dr-resource-card.expanded{border-color:var(--primary-600);box-shadow:0 2px 8px #3b82f626}.dr-resource-header{display:flex;align-items:center;justify-content:space-between;padding:16px;min-height:56px}.dr-resource-header-left{display:flex;align-items:center;gap:12px;flex:1}.dr-resource-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--primary-300);border-radius:100vh;flex-shrink:0}.dr-resource-title{font-size:14px;font-weight:500;color:var(--gray-700);line-height:1.4}.dr-resource-toggle{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease;flex-shrink:0}.dr-resource-toggle:hover{background-color:var(--gray-200)}.dr-resource-content{padding:16px;border-top:1px solid var(--gray-200);animation:slideDown .2s ease-out}.dr-resource-info-row{display:flex;align-items:center;margin-bottom:12px}.dr-resource-info-row:last-child{margin-bottom:0}.dr-resource-info-row.divide{display:grid;grid-template-columns:1fr 1fr}.dr-resource-label{font-size:14px;color:var(--gray-700);font-weight:400;min-width:fit-content;width:80px}.dr-resource-value{font-size:14px;color:var(--gray-600);font-weight:400}.dr-resource-value.station-count{color:var(--blue-500)}.dr-resource-value.charger-count{color:var(--green-400)}.dr-resource-card.collapsed .dr-resource-content{display:none}@media (max-width: 768px){.dr-resource-header{padding:12px}.dr-resource-content{padding:0 12px 12px}.dr-resource-title{font-size:13px}}.station-card{background:var(--bg-primary);border:1px solid var(--gray-200);border-radius:8px;margin-bottom:8px;transition:all .2s ease;overflow:hidden;cursor:pointer}.station-card:hover{border-color:var(--primary-600);box-shadow:0 2px 8px #3b82f61a}.station-card.expanded{border-color:var(--primary-600);box-shadow:0 2px 8px #3b82f626}.station-header{display:flex;align-items:center;justify-content:space-between;padding:16px;min-height:56px}.station-header-left{display:flex;align-items:center;gap:12px;flex:1}.station-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--primary-300);border-radius:100vh;flex-shrink:0}.station-title{font-size:14px;font-weight:500;color:var(--gray-700);line-height:1.4}.station-toggle{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease;flex-shrink:0}.station-toggle:hover{background-color:var(--gray-200)}.toggle-icon{transition:transform .2s ease}.toggle-icon.expanded{transform:rotate(180deg)}.station-content{padding:16px;border-top:1px solid #F3F4F6;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:200px;padding-top:16px;padding-bottom:16px}}.station-info-row{display:flex;align-items:center;margin-bottom:16px}.station-info-row:last-child{margin-bottom:0}.station-info-row.divide{display:grid;grid-template-columns:1fr 1fr}.station-label.one-row{width:110px}.station-label{font-size:14px;color:var(--gray-700);font-weight:400;min-width:fit-content}.station-value{font-size:14px;color:var(--gray-600);font-weight:400}.station-value.charger-count{color:var(--green-400)}.station-value.power-demand{color:var(--red-500)}.station-card.collapsed .station-content{display:none}@media (max-width: 768px){.station-header,.station-content{padding:12px}.station-title{font-size:13px}}.station-marker{position:relative;cursor:pointer;transition:transform .2s ease;display:flex;flex-direction:column;align-items:center}.station-marker-pin{position:relative;width:42px;height:55px;display:flex;align-items:center;justify-content:center}.station-marker-pin svg{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.station-marker-stats{position:absolute;top:-8px;right:-8px;background:#f44;color:#fff;border-radius:50%;width:20px;height:20px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 4px #0003}.station-marker-shadow{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:20px;height:8px;background:#0003;border-radius:50%;filter:blur(4px)}.station-marker.selected{transform:scale(1.2)}.station-marker.selected .station-marker-pin svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.station-marker-name{position:absolute;bottom:-20px;font-size:14px;font-weight:500;color:var(--gray-700);width:max-content}.pagination-wrapper{margin-top:20px;display:flex;justify-content:center}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.pagination-info{display:flex;gap:2rem;font-size:.875rem;color:#6b7280}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:.5rem;border:1px solid var(--gray-400);background-color:var(--bg-primary);color:var(--gray-800);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.pagination-prev-btn{border-top-left-radius:8px;border-bottom-left-radius:8px}.pagination-next-btn{border-top-right-radius:8px;border-bottom-right-radius:8px}.pagination-btn:hover:not(.disabled){background-color:var(--bg-secondary);border-color:#9ca3af}.pagination-btn:active:not(.disabled){background-color:#e5e7eb;transform:translateY(1px)}.pagination-btn.disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.pagination-btn.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.pagination-btn.active:hover{background-color:#2563eb;border-color:#2563eb}.pagination-group-btn{font-weight:700;font-size:1rem}.page-numbers{display:flex;gap:.25rem}.pagination-small .pagination-btn{min-width:1.5rem;height:1.5rem;padding:.25rem;font-size:.75rem}.pagination-small .pagination-info{font-size:.75rem;gap:1rem}.pagination-small .pagination-controls{gap:.25rem}.pagination-small .page-numbers{gap:.125rem}.pagination-large .pagination-btn{min-width:3rem;height:3rem;padding:.75rem;font-size:1rem}.pagination-large .pagination-info{font-size:1rem;gap:3rem}.pagination-large .pagination-controls{gap:.75rem}.pagination-large .page-numbers{gap:.5rem}@media (max-width: 640px){.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-info{flex-direction:column;gap:.5rem;text-align:center}.page-numbers{order:3;width:100%;justify-content:center;margin-top:.5rem}}.map-dashboard-container{display:flex;flex-direction:column;width:100%;min-width:1560px;height:calc(100vh - 52px);background:#f8f9fa}.map-dashboard-content{display:flex;flex:1;width:100%;height:100%}.map-area{flex:1;position:relative;background:#e9ecef;overflow:hidden}.map-container{width:100%;height:100%;position:relative}.sidebar{width:520px;height:100%;background:var(--bg-secondary);display:flex;flex-direction:column;overflow-y:auto}.sidebar-back-container{padding:20px 40px 0}.sidebar-back{color:var(--primary-600);cursor:pointer}.sidebar-back:active{opacity:.3}.region-level{margin-bottom:16px}.region-level:last-child{margin-bottom:0}.region-level label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#495057}.region-level select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;color:#495057;background:#fff;cursor:pointer;transition:border-color .2s ease}.region-level select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.region-level select:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.dr-resource-list{flex:1;padding:24px 40px}.dr-resource-list h3{margin:0 0 20px;font-size:18px;font-weight:600;color:var(--gray-700)}.dr-resource-list-title-region{color:var(--primary-600)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--gray-700);font-size:14px}.resource-items{display:flex;flex-direction:column;gap:16px;overflow-y:auto}.no-data{text-align:center;padding:40px;color:var(--gray-700);font-size:14px}.station-list{flex:1;padding:24px 40px}.station-list h3{margin:0 0 20px;font-size:18px;font-weight:600;color:var(--gray-700)}.station-list-title-region{color:var(--primary-600)}.station-items{display:flex;flex-direction:column;gap:8px;overflow-y:auto}.naver-map-marker{cursor:pointer;transition:all .3s ease}.naver-map-marker:hover{transform:scale(1.05)}@media (max-width: 1200px){.sidebar{width:400px}}@media (max-width: 768px){.map-dashboard-content{flex-direction:column}.sidebar{width:100%;height:40vh;border-left:none;border-top:1px solid #e9ecef}.region-selector,.dr-resource-list{padding:16px}}@media (max-width: 480px){.breadcrumb{padding:12px 16px;font-size:12px}.region-selector h3,.dr-resource-list h3,.station-list h3{font-size:16px}.resource-item,.station-item{padding:12px}.resource-name,.station-name{font-size:14px}.resource-location,.station-details{font-size:12px}.station-icon{width:32px;height:32px;font-size:20px}}.mini-dashboard{position:absolute;bottom:0;left:50%;transform:translate(-50%);right:0;background:var(--bg-primary);border-top:1px solid var(--gray-200);z-index:1000;max-height:50vh;height:550px;overflow:hidden;margin:0 auto;width:calc(100% - 100px);border-radius:12px 12px 0 0;padding:0 40px 40px}.mini-dashboard.open{transform:translate(-50%) translateY(0);transition:transform .3s cubic-bezier(.25,.46,.45,.94)}.mini-dashboard:not(.open){transform:translate(-50%) translateY(calc(100% - 36px));transition:transform .3s cubic-bezier(.25,.46,.45,.94)}.mini-dashboard-handle{width:120px;height:4px;background:var(--gray-200);border-radius:2px;margin:16px auto;cursor:pointer;transition:background-color .2s ease}.mini-dashboard-handle:hover{background:var(--gray-300)}.mini-dashboard-header{display:flex;align-items:center;gap:16px}.mini-dashboard-header h2{margin:0;font-size:24px;font-weight:700;color:var(--primary-600)}.mini-dashboard-header .detail-btn{font-size:14px;font-weight:400;color:var(--gray-600);cursor:pointer;text-decoration:underline}.mini-dashboard-header .detail-btn:active{opacity:.8}.mini-dashboard-tabs-container{margin-bottom:20px}.mini-dashboard-tabs{grid-template-columns:repeat(4,1fr)}.mini-dashboard-content{max-height:calc(50vh - 100px);overflow-y:auto;display:flex;flex-direction:column;gap:16px;margin-top:20px}.mini-dashboard-content.stat{display:grid;grid-template-columns:1fr 1fr;gap:32px}.mini-dashboard-summary-info{width:100%;height:100%;background:var(--bg-secondary);border-radius:12px;padding:20px;display:grid;grid-template-columns:1fr 1fr;gap:16px}.mini-dashboard-summary-item{display:flex;align-items:center;gap:8px}.mini-dashboard-summary-item-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:100vh}.mini-dashboard-summary-item-icon.charger{background:var(--yellow-50)}.mini-dashboard-summary-item-icon.charger svg{color:var(--yellow-500)}.mini-dashboard-summary-item-icon.bolt{background:var(--green-50)}.mini-dashboard-summary-item-icon.bolt svg{color:var(--green-400)}.mini-dashboard-summary-item-icon.battery{background:var(--blue-50)}.mini-dashboard-summary-item-icon.battery svg{color:var(--blue-500)}.mini-dashboard-summary-item-icon.time{background:var(--purple-50)}.mini-dashboard-summary-item-icon.time svg{color:var(--purple-500)}.mini-dashboard-summary-item-text{display:flex;flex-direction:column;gap:4px}.mini-dashboard-summary-item-text-title{font-size:16px;font-weight:400;color:var(--gray-600)}.mini-dashboard-summary-item-text-value{font-size:16px;font-weight:400;color:var(--gray-700)}.realtime-charts-container{display:flex;flex-direction:column;gap:16px;height:100%}.realtime-charts-container .realtime-chart{flex:1;min-height:200px}.not-found-container{display:flex;align-items:center;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;background:var(--bg-body)}.error-code{font-size:64px;font-weight:700;color:var(--primary-600);line-height:1}.error-title{font-size:2rem;font-weight:600;color:var(--text-color);margin-bottom:1rem}.error-message{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.5}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.charger-management-container{padding:2rem;min-width:1500px}.charger-management-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.charger-management-header h1{margin:0 0 .5rem;color:var(--text-color)}.charger-management-header p{margin:0;color:var(--text-secondary)}.charger-controls{align-items:center;gap:1rem;margin-bottom:2rem;display:flex;justify-content:flex-end}.loading-container{display:flex;justify-content:center;align-items:center;padding:3rem;text-align:center}.loading-container p{color:var(--text-secondary);font-size:1.1rem}.error-container{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem;text-align:center;gap:1rem}.error-container p{color:var(--danger-color, #dc3545);font-size:1.1rem;margin:0}.error-container button{padding:.5rem 1rem;border-radius:4px;border:none;background-color:var(--primary-color);color:#fff;cursor:pointer;font-size:.9rem}.error-container button:hover{background-color:var(--primary-hover-color)}.no-data{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.loading-text{color:var(--text-secondary);font-style:italic;font-size:.9rem}.auth-required{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem;text-align:center;gap:1rem}.auth-required p{color:var(--text-secondary);font-size:1.1rem;margin:0}@media (max-width: 768px){.charger-management-container{padding:1rem}.charger-stats{grid-template-columns:repeat(2,1fr)}.charger-controls{flex-direction:column}.charger-table{overflow-x:auto}.charger-table table{min-width:600px}}.primary-table td.charger-dr-resource.no-assigned{color:var(--gray-400);font-weight:600}.station-search-modal-container{min-width:1000px!important}.station-management-container{padding:2rem;min-width:1500px}.selector-container{position:relative;width:100%}.selector-container.disabled{opacity:.6;cursor:not-allowed}.selector-trigger{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background-color:var(--bg-primary);border:1px solid var(--gray-400);border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:40px}.selector-trigger:hover:not(.disabled){border-color:var(--primary-600)}.selector-trigger.open{border-color:var(--primary-600);box-shadow:0 0 0 3px var(--primary-50)}.selector-trigger.disabled{cursor:not-allowed;background-color:var(--gray-100)}.selector-label{font-size:14px;color:var(--gray-800);flex:1;text-align:left}.selector-label.placeholder{color:var(--gray-400)}.selector-chevron{width:16px;height:16px;color:var(--gray-500);transition:transform .2s ease;flex-shrink:0;margin-left:8px}.selector-chevron.up{transform:rotate(180deg);color:var(--primary-600)}.selector-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background-color:var(--bg-primary);border:1px solid var(--gray-300);border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;display:flex;flex-direction:column;overflow:hidden;animation:slideDown .2s ease-out}.selector-search{display:flex;align-items:center;padding:12px;border-bottom:1px solid var(--gray-200);background-color:var(--gray-50);gap:8px}.selector-search-icon{width:16px;height:16px;color:var(--gray-500);flex-shrink:0}.selector-search-input{flex:1;border:none;outline:none;background:transparent;font-size:14px;color:var(--gray-800);padding:0}.selector-search-input::placeholder{color:var(--gray-400)}.selector-options{max-height:240px;overflow-y:auto;padding:4px 0}.selector-options::-webkit-scrollbar{width:6px}.selector-options::-webkit-scrollbar-track{background:var(--gray-100)}.selector-options::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.selector-options::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.selector-option{padding:10px 16px;font-size:14px;color:var(--gray-800);cursor:pointer;transition:all .2s ease}.selector-option:hover{background-color:var(--primary-50);color:var(--primary-600)}.selector-option.selected{background-color:var(--primary-50);color:var(--primary-600);font-weight:500}.selector-option-create{border-top:1px solid var(--gray-200);margin-top:4px;padding-top:12px;color:var(--primary-600);font-weight:500}.selector-option-create:hover{background-color:var(--primary-50);color:var(--primary-600)}.selector-loading,.selector-error,.selector-empty{padding:16px;text-align:center;font-size:14px;color:var(--gray-500)}.selector-error{color:var(--error-600)}.dr-history-container{padding:24px;background:var(--bg-primary);min-height:100vh}.calendar-filter-section{margin-bottom:24px}.calendar-filters{display:flex;gap:16px;flex-wrap:wrap;width:300px}.calendar-filters .calendar-wrapper{flex:1;min-width:200px}@media (max-width: 768px){.calendar-filters{flex-direction:column}.calendar-filters .calendar-wrapper{min-width:100%}}.dr-history-container .primary-table{margin-bottom:24px}.calendar-wrapper{position:relative;display:inline-block;width:100%}.calendar-input{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid var(--gray-400);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:var(--transition);min-height:42px}.calendar-input:hover{border-color:var(--primary)}.calendar-input.disabled{background:var(--gray-200);color:var(--gray-600);cursor:not-allowed}.calendar-text{flex:1;text-align:left;font-size:16px;font-weight:400;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:var(--bg-primary);border:1px solid var(--gray-400);border-radius:8px;box-shadow:var(--floating-shadow);margin-top:4px;overflow:hidden}.calendar-container{padding:16px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius);cursor:pointer;font-size:16px;color:var(--gray-600);transition:var(--transition)}.calendar-nav-btn:hover{background:var(--gray-200);color:var(--text-base)}.calendar-month-year{font-size:16px;font-weight:600;color:var(--text-base)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{display:flex;align-items:center;justify-content:center;height:32px;font-size:12px;font-weight:500;color:var(--gray-600)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius);cursor:pointer;font-size:14px;color:var(--text-base);transition:var(--transition);position:relative}.calendar-day:hover{background:var(--gray-200);color:var(--text-base)}.calendar-day.other-month{color:var(--gray-400)}.calendar-day.selected{background:var(--primary);color:#fff;font-weight:600}.calendar-day.temp-selected{background:var(--primary);color:#fff;font-weight:600;border:2px solid var(--primary-300)}.calendar-day.in-range{background:var(--primary-50);color:var(--primary-900)}.calendar-day.hovered{background:var(--primary-300)}.calendar-day.today{border:2px solid var(--yellow-500);font-weight:600}.calendar-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:16px;position:relative}.calendar-actions:before{content:"";position:absolute;top:0;left:16px;right:16px;height:1px;background:var(--gray-400)}.calendar-actions-right{display:flex;gap:8px}.calendar-btn{padding:8px 24px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);border:1px solid transparent}.calendar-btn.cancel{background:var(--bg-primary);color:var(--primary-600);border:1px solid var(--gray-400)}.calendar-btn.cancel:hover{background:var(--gray-200)}.calendar-btn.confirm{background:var(--primary);color:#fff;border-color:var(--primary)}.calendar-btn.confirm:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.calendar-btn.today{color:var(--gray-700);padding:0;background:none}.report-management-container{padding:2rem;min-width:1500px}.report-management-content{display:flex;flex-direction:column;gap:20px}.file-input-container{width:100%}.file-input-container.disabled{opacity:.6;cursor:not-allowed}.file-input-hidden{display:none}.file-input-dropzone{min-height:120px;border:2px dashed var(--gray-400);border-radius:8px;padding:20px;background-color:var(--bg-primary);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:12px}.file-input-dropzone:hover:not(.disabled){border-color:var(--primary-600);background-color:var(--primary-50)}.file-input-dropzone.dragging{border-color:var(--primary-600);background-color:var(--primary-50);box-shadow:0 0 0 3px var(--primary-300)}.file-input-dropzone.has-files{min-height:auto;border-style:solid;border-color:var(--gray-400)}.file-input-dropzone.disabled{cursor:not-allowed;background-color:var(--gray-100)}.file-input-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px;text-align:center}.file-input-placeholder-text{font-size:14px;color:var(--gray-600);font-weight:500}.file-input-placeholder-hint{font-size:12px;color:var(--gray-400)}.file-input-files{display:flex;flex-direction:column;gap:12px}.file-input-file-item{display:flex;align-items:center;gap:12px;padding:12px;background-color:var(--bg-primary);border:1px solid var(--gray-400);border-radius:6px;transition:all .2s ease;cursor:default}.file-input-preview{width:48px;height:48px;border-radius:4px;overflow:hidden;flex-shrink:0;border:1px solid var(--gray-400)}.file-input-preview img{width:100%;height:100%;object-fit:cover}.file-input-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.file-input-file-name{font-size:14px;color:var(--gray-800);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-input-file-size{font-size:12px;color:var(--gray-600)}.file-input-remove-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background-color:transparent;border-radius:4px;cursor:pointer;transition:all .2s ease;flex-shrink:0;color:var(--gray-700)}.file-input-remove-btn:hover:not(:disabled){background-color:var(--red-50);color:var(--red-500)}.file-input-remove-btn:disabled{cursor:not-allowed;opacity:.5}.file-input-remove-btn svg{width:16px;height:16px}.file-input-add-btn{margin-top:12px;padding:8px 16px;border:1px solid var(--gray-300);border-radius:6px;background-color:var(--bg-primary);color:var(--gray-700);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.file-input-add-btn:hover:not(:disabled){border-color:var(--info-600);background-color:var(--info-50);color:var(--info-700)}.file-input-add-btn:disabled{cursor:not-allowed;opacity:.6}.file-input-error{margin-top:8px;padding:8px 12px;background-color:var(--red-50);border:1px solid var(--red-400);border-radius:4px;color:var(--red-500);font-size:12px;white-space:pre-line}@media (max-width: 768px){.file-input-dropzone{min-height:100px;padding:16px}.file-input-file-item{padding:10px}.file-input-preview{width:40px;height:40px}}.settings-container{padding:2rem;min-width:1500px}.settings-content{display:flex;flex-direction:column;gap:20px;flex:1}.system-setup-group-container{display:flex;flex-direction:column;gap:40px;flex:1}.system-setup-group{border-bottom:1px solid var(--gray-400);padding-bottom:40px}.system-setup-group:last-child{border-bottom:none}.system-setup-group-content{background:var(--bg-body)}.system-setup-item{border-radius:var(--radius);border:1px solid var(--gray-400);height:72px;display:grid;grid-template-columns:280px 1fr;position:relative}.system-setup-item.edit{box-shadow:0 0 10px #19aeff4c}.system-setup-item-key{border-radius:var(--radius) 0 0 var(--radius)}.system-setup-item-value{border-radius:0 var(--radius) var(--radius) 0;border-left:1px solid var(--gray-400);background:var(--bg-primary);word-break:break-all}.system-setup-item-function-container{left:280px;bottom:calc(100% + 4px)}.system-setup-item-function-button{width:20px;height:20px;background:none}.modal-container.alert-setup-target-edit-modal{min-width:800px}.user-management-container{padding:2rem;min-width:1500px}.input-field{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--gray-300);border-radius:var(--radius-md);background:var(--white);color:var(--gray-900);font-size:var(--font-size-b1);transition:all .2s ease}.input-field:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.input-field::placeholder{color:var(--gray-500)}.btn-icon{padding:var(--spacing-2);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:18px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btb-icon:active{opacity:.3}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-5)}.role-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s ease;display:flex;flex-direction:column}.role-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-200)}.role-card-header{padding:var(--spacing-5);display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--gray-100)}.role-card-actions{display:flex;gap:var(--spacing-2)}.role-card-body{padding:var(--spacing-5);flex:1}.role-stat{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);background:var(--gray-50);border-radius:var(--radius-md)}.role-features{display:flex;flex-direction:column;gap:var(--spacing-2)}.role-card-footer{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid var(--gray-100);background:var(--gray-50)}.badge{display:inline-flex;align-items:center;border-radius:var(--radius-full);font-size:var(--font-size-b2);font-weight:500;white-space:nowrap;padding:3px 5px}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--green-100);color:var(--green-700)}.badge-info{background:var(--primary-600);color:#fff}.badge-gray{background:var(--gray-100);color:var(--gray-700)}.role-feature-table{overflow-x:auto}.role-feature-table table{table-layout:fixed;min-width:800px}.feature-name-col{width:250px;min-width:250px}.role-col{width:120px;min-width:120px}.role-header-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.btn-icon-sm{padding:var(--spacing-1);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;opacity:.6;transition:all .2s ease}.btn-icon-sm:hover{opacity:1;background:var(--red-50)}.feature-name-cell{font-weight:600!important;color:var(--gray-800)!important}.feature-info{display:flex;flex-direction:column;gap:var(--spacing-1)}.feature-display-name{font-weight:600;color:var(--gray-900)}.feature-id{font-size:var(--font-size-b2);color:var(--gray-500)}.checkbox-cell{text-align:center!important;padding:var(--spacing-3)!important;vertical-align:middle!important}.checkbox-wrapper{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.feature-checkbox{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{width:20px;height:20px;border:2px solid var(--gray-300);border-radius:var(--radius-sm);background:var(--white);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.feature-checkbox:checked+.checkbox-custom{background:var(--primary-600);border-color:var(--primary-600)}.feature-checkbox:checked+.checkbox-custom:after{content:"✓";color:var(--white);font-size:14px;font-weight:700}.checkbox-custom:hover{border-color:var(--primary-500)}.feature-checkbox:focus+.checkbox-custom{box-shadow:0 0 0 3px var(--primary-50)}.role-summary{background:var(--gray-50);padding:var(--spacing-5);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-4)}.summary-card{background:var(--white);padding:var(--spacing-4);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.summary-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-3);margin-bottom:var(--spacing-3);border-bottom:1px solid var(--gray-100)}.summary-features{display:flex;flex-direction:column;gap:var(--spacing-2)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.side-modal{position:fixed;right:0;top:0;bottom:0;width:500px;max-width:90vw;background:var(--white);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.side-modal-header{padding:var(--spacing-6);border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}.modal-close-btn{padding:var(--spacing-2);background:none;border:none;font-size:24px;color:var(--gray-600);cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease;line-height:1}.modal-close-btn:hover{background:var(--gray-100);color:var(--gray-900)}.side-modal-content{flex:1;padding:var(--spacing-6);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-6)}.side-modal-footer{padding:var(--spacing-5);border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:var(--spacing-3)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.form-label{font-size:var(--font-size-b1);font-weight:600;color:var(--gray-900)}.form-hint{margin-top:var(--spacing-1)}.input-field.disabled{background:var(--gray-100);color:var(--gray-600);cursor:not-allowed}.role-checkbox-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.role-checkbox-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);border:1px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.role-checkbox-item:hover{background:var(--gray-50);border-color:var(--primary-300)}.role-checkbox-input{position:absolute;opacity:0;width:0;height:0}.role-checkbox-custom{width:20px;height:20px;border:2px solid var(--gray-300);border-radius:var(--radius-sm);background:var(--white);transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.role-checkbox-input:checked+.role-checkbox-custom{background:var(--primary-600);border-color:var(--primary-600)}.role-checkbox-input:checked+.role-checkbox-custom:after{content:"✓";color:var(--white);font-size:14px;font-weight:700}.role-checkbox-label{font-size:var(--font-size-b1);font-weight:500;color:var(--gray-900);flex:1}.role-feature-count{font-size:var(--font-size-b2)}.selected-roles-preview{padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.confirm-modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:480px;max-width:90vw;animation:fadeInScale .3s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.confirm-modal-header{padding:var(--spacing-6);border-bottom:1px solid var(--gray-200)}.confirm-modal-content{padding:var(--spacing-6)}.delete-user-info{margin-top:var(--spacing-4);padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200);display:flex;flex-direction:column;gap:var(--spacing-3)}.info-row{display:flex;gap:var(--spacing-3);align-items:center}.info-label{font-weight:600;color:var(--gray-700);min-width:80px}.info-value{color:var(--gray-900)}.confirm-modal-footer{padding:var(--spacing-5);border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:var(--spacing-3);background:var(--gray-50)}.btn-danger{background:var(--red-600);color:var(--white);border:none;padding:var(--spacing-3) var(--spacing-5);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:var(--red-700)}.user-email{font-weight:500!important;color:var(--gray-900)!important}.role-row-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-600)}.chevron-btn{padding:var(--spacing-1)!important;display:flex;align-items:center;justify-content:center}.chevron-icon{width:16px;height:16px;transition:transform .2s ease}.chevron-icon.expanded{transform:rotate(180deg)}.feature-detail-row{background:var(--gray-50)!important}.feature-detail-row td{padding:0!important;border-top:none!important;background:var(--gray-50)}.feature-detail-content{padding:var(--spacing-2);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.feature-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.tabs{display:grid;gap:0;border-bottom:2px solid var(--gray-200)}.tabs.grid-cols-2{grid-template-columns:repeat(2,1fr)}.tab{padding:var(--spacing-3) var(--spacing-5);background:none;border:none;border-bottom:2px solid transparent;color:var(--gray-600);font-size:var(--font-size-b1);font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.tab:hover{color:var(--gray-900);background:var(--gray-50)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);font-weight:600}@media (max-width: 768px){.user-management-container{padding:var(--spacing-4)}.page-header{flex-direction:column;gap:var(--spacing-4)}.table-container{overflow-x:auto}.data-table{min-width:800px}.roles-grid{grid-template-columns:1fr}.tab-nav{overflow-x:auto}.summary-grid{grid-template-columns:1fr}.feature-name-col{width:200px;min-width:200px}.role-col{width:100px;min-width:100px}}.relative{position:relative}.password-toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:color .2s ease;z-index:1}.password-toggle-btn:hover:not(:disabled){color:var(--gray-700)}.password-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.password-toggle-btn svg{width:20px;height:20px;pointer-events:none}.relative input[type=password],.relative input[type=text]{padding-right:45px}.user-table{position:relative}.expand-btn{width:28px;height:28px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:all .2s ease;color:var(--gray-600)}.expand-btn:hover:not(.disabled){background:var(--gray-100);color:var(--primary-600)}.expand-btn.disabled{cursor:not-allowed;opacity:.3}.expand-btn svg{width:16px;height:16px;transition:transform .2s ease}.expand-btn.expanded svg{transform:rotate(180deg)}.user-table tr.expanded{background:var(--gray-50)}.expanded-row td{padding:0!important;border-top:none!important;background:var(--gray-50)}.feature-details{padding:20px 24px;animation:slideDown .2s ease}.feature-details-header{display:flex;align-items:center;gap:10px;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid var(--gray-200)}.feature-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.feature-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--gray-700);transition:all .2s ease}.feature-item:hover{border-color:var(--primary-300);background:var(--primary-50)}.feature-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--success-100);color:var(--success-600);border-radius:50%;font-size:12px;font-weight:600;flex-shrink:0}.feature-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.feature-list{grid-template-columns:1fr}.feature-details{padding:15px}}.drsettlement-container,.system-log-container{padding:2rem;min-width:1500px}.system-log-content{display:flex;flex-direction:column;gap:20px}.system-log-table-row-expanded td{padding:0;background-color:var(--gray-50)}.system-log-details{padding:1.5rem}.ai-learning-request-modal{min-width:600px;max-width:1000px;min-height:400px}.ai-learning-steps-container{display:flex;align-items:center;justify-content:start;gap:10px}.ai-learning-steps-wrapper{display:flex;align-items:center;gap:10px}.ai-learning-step{display:flex;align-items:center;gap:8px}.ai-learning-step-number{width:32px;height:32px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:600;font-size:14px;color:#fff;background-color:var(--gray-400);transition:all .3s ease;flex-shrink:0}.ai-learning-step.active .ai-learning-step-number,.ai-learning-step.completed .ai-learning-step-number{background-color:var(--primary-600)}.ai-learning-step-label{font-size:16px;font-weight:500;color:var(--gray-800);white-space:nowrap}.ai-learning-step-separator{font-size:18px;font-weight:600;color:var(--gray-400);margin:0 5px;transition:color .3s ease;display:flex;align-items:center}.ai-learning-step-separator.active{color:var(--gray-800)}.ai-learning-step-content{display:flex;flex-direction:column;justify-content:center;flex:1}.ai-learning-step-content.step-3{gap:20px;justify-content:start;width:600px}.ai-learning-request-type-button{width:250px;height:180px;border-radius:8px;border:1px solid var(--gray-400);padding:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background-color:var(--gray-50)}.ai-learning-request-type-button:hover{background-color:var(--gray-100)}.ai-learning-request-type-button.active{border:3px solid var(--primary-600)}.ai-learning-request-type-button.active p{color:var(--primary-600);font-weight:600}.ai-learning-request-type-button.active svg{color:var(--primary-600)}.modal-footer .btn.disabled,.modal-footer .btn:disabled{background-color:var(--gray-400);color:var(--gray-500);cursor:not-allowed;opacity:.6}.modal-footer .btn.disabled:hover,.modal-footer .btn:disabled:hover{background-color:var(--gray-400);color:var(--gray-500);cursor:not-allowed;opacity:.6}.datetime-input-wrapper{position:relative;display:inline-block;width:100%}.datetime-input-label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--gray-800)}.datetime-input-trigger{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border:1px solid var(--gray-400);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:all .2s ease;min-height:40px}.datetime-input-trigger:hover:not(.disabled){border-color:var(--primary-600)}.datetime-input-trigger.open{border-color:var(--primary-600);box-shadow:0 0 0 3px var(--primary-50)}.datetime-input-trigger.disabled{background:var(--gray-100);cursor:not-allowed;opacity:.6}.datetime-input-trigger.error{border-color:var(--error)}.datetime-input-text{flex:1;text-align:left;font-size:14px;font-weight:400;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.datetime-input-text.placeholder{color:var(--gray-400)}.datetime-input-icon{width:20px;height:20px;color:var(--gray-600);flex-shrink:0;margin-left:8px}.datetime-input-error-message{margin-top:4px;font-size:12px;color:var(--error)}.datetime-input-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:var(--bg-primary);border:1px solid var(--gray-400);border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:4px;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.datetime-input-content{padding:16px}.datetime-calendar-container{margin-bottom:16px}.datetime-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.datetime-calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:var(--gray-600);transition:all .2s ease}.datetime-calendar-nav-btn:hover{background:var(--gray-200);color:var(--gray-800)}.datetime-calendar-month-year{font-size:16px;font-weight:600;color:var(--gray-800)}.datetime-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.datetime-calendar-weekday{text-align:center;font-size:12px;font-weight:600;color:var(--gray-600);padding:8px 0}.datetime-calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.datetime-calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:14px;color:var(--gray-800);transition:all .2s ease;padding:0}.datetime-calendar-day:hover:not(.disabled){background:var(--primary-50);color:var(--primary-700)}.datetime-calendar-day.today{background:var(--primary-100);color:var(--primary-700);font-weight:600}.datetime-calendar-day.selected{background:var(--primary-600);color:var(--white);font-weight:600}.datetime-calendar-day.selected.today{background:var(--primary-700);color:var(--white)}.datetime-calendar-day.other-month{color:var(--gray-400)}.datetime-calendar-day.disabled{color:var(--gray-300);cursor:not-allowed;opacity:.5}.datetime-calendar-day.disabled:hover{background:transparent}.datetime-time-container{padding-top:16px;border-top:1px solid var(--gray-200)}.datetime-time-label{font-size:14px;font-weight:500;color:var(--gray-800);margin-bottom:8px}.datetime-time-inputs{display:flex;align-items:center;justify-content:center}.datetime-time-input-group{display:flex;align-items:center;gap:8px}.datetime-time-input{width:60px;padding:8px 12px;border:1px solid var(--gray-400);border-radius:4px;background:var(--bg-primary);font-size:16px;font-weight:500;text-align:center;color:var(--gray-800);transition:all .2s ease}.datetime-time-input:focus{outline:none;border-color:var(--primary-600);box-shadow:0 0 0 3px var(--primary-50)}.datetime-time-input:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.datetime-time-input::-webkit-inner-spin-button,.datetime-time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.datetime-time-input[type=number]{-moz-appearance:textfield}.datetime-time-separator{font-size:18px;font-weight:600;color:var(--gray-600)}.datetime-input-actions{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--gray-200);background:var(--gray-50)}.datetime-input-actions-right{display:flex;gap:8px}.datetime-input-btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.datetime-input-btn.today{background:transparent;color:var(--primary-600)}.datetime-input-btn.today:hover{background:var(--primary-50)}.datetime-input-btn.cancel{background:var(--gray-200);color:var(--gray-800)}.datetime-input-btn.cancel:hover{background:var(--gray-300)}.datetime-input-btn.confirm{background:var(--primary-600);color:var(--white)}.datetime-input-btn.confirm:hover{background:var(--primary-700)}.ai-module-management-container{padding:2rem;min-width:1500px}.ai-module-management-header{margin-bottom:1.5rem}.ai-module-management-content,.ai-module-management-request-content,.ai-module-management-module-content{width:100%}.error-message{padding:1rem;text-align:center;color:var(--error-700);background-color:var(--error-100);border-radius:4px}.ai-learning-table-row-expanded td{padding:0;background-color:var(--gray-50)}.ai-learning-details{padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section h4{margin:0 0 1rem;font-size:16px;font-weight:600;color:var(--gray-800)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:12px;color:var(--gray-600);font-weight:500}.detail-value{font-size:14px;color:var(--gray-800)}.log-details{background-color:var(--gray-100);border:1px solid var(--gray-300);border-radius:4px;padding:1rem;max-height:300px;overflow-y:auto}.log-details pre{margin:0;font-size:12px;color:var(--gray-800);white-space:pre-wrap;word-break:break-all}.detail-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray-300)}.expand-button{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:color .2s}.expand-button:hover{color:var(--primary-600)}.expand-button svg{width:16px;height:16px}.btn-error{background-color:var(--error-600);color:#fff}.btn-error:hover{background-color:var(--error-700)}.btn-error:disabled{background-color:var(--gray-400);cursor:not-allowed}.modal-container.learning-demand-re-request-modal{min-width:900px}.station-management-container{padding:2rem}.station-management-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.station-management-header h1{margin:0 0 .5rem;color:var(--text-color)}.station-management-header p{margin:0;color:var(--text-secondary)}.station-controls{align-items:center;gap:1rem;margin-bottom:2rem;display:flex;justify-content:flex-end}@media (max-width: 768px){.station-management-container{padding:1rem}.station-stats{grid-template-columns:repeat(2,1fr)}.station-controls{flex-direction:column}.station-table{overflow-x:auto}.station-table table{min-width:600px}}.station-dr-resource.no-assigned{color:var(--gray-400);font-weight:600}.dr-resource-detail{padding:24px;max-width:1200px;margin:0 auto}.resource-id{margin:0;font-size:.9rem;color:var(--text-secondary)}.dr-resource-detail-tabs-container{width:50%}.dr-resource-detail-tabs{grid-template-columns:repeat(2,1fr)}.stations-list,.chargers-list{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.station-item,.charger-item{padding:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000001a}.station-item h4,.charger-item h4{margin:0 0 12px;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.station-item p,.charger-item p{margin:4px 0;color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.dr-resource-detail{padding:16px}.detail-header{flex-direction:column;gap:16px;align-items:stretch}.header-actions{justify-content:flex-end}.detail-tabs{overflow-x:auto;padding-bottom:8px}.tab-button{white-space:nowrap;padding:10px 16px}.info-table th,.info-table td{padding:12px}.info-table th{width:120px}.stations-list,.chargers-list{grid-template-columns:1fr}}.station-accordion{width:100%}.station-accordion .primary-table{background:var(--bg-primary);overflow:hidden}.station-accordion .primary-table table{width:100%;border-collapse:collapse;table-layout:auto}.station-accordion .primary-table thead{border-bottom:3px solid var(--gray-400)}.station-accordion .primary-table th{background:var(--bg-primary);padding:12px 15px;text-align:left;font-size:14px;font-weight:700;color:var(--gray-600);border-bottom:1px solid var(--gray-400)}.station-accordion .primary-table td{padding:15px;border-bottom:1px solid var(--gray-200);font-size:14px;font-weight:400;color:var(--gray-700);vertical-align:middle}.station-row{background:var(--bg-primary);cursor:pointer;transition:all .2s ease}.station-row:hover{background:var(--gray-50)}.station-row:active{opacity:.3}.charger-row{background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;border-left:3px solid var(--primary-100)}.charger-row:hover{background:var(--gray-100)}.charger-row:active{opacity:.3}.station-name{vertical-align:middle;position:relative;padding-left:20px}.station-name>span:last-child{display:inline-block;vertical-align:middle}.station-address{color:var(--text-secondary);word-break:break-all}.chevron.station-accordion-chevron{position:absolute;left:0;top:50%;transform:translateY(-50%) rotate(-90deg);display:flex;align-items:center;justify-content:center;width:16px;height:16px;transition:transform .2s ease;color:var(--text-secondary)}.chevron.station-accordion-chevron.expanded{transform:translateY(-50%) rotate(0)}.chevron.station-accordion-chevron svg{width:12px;height:12px;display:block}.charger-loading-row,.charger-empty-row,.charger-error-row{background:var(--bg-secondary);border-left:3px solid var(--primary-100)}.charger-loading-row td,.charger-empty-row td{font-style:italic;color:var(--text-secondary);border-bottom:1px solid var(--gray-200)}.charger-error-row td{font-style:italic;color:var(--error);border-bottom:1px solid var(--gray-200)}.status-indicator{display:flex;align-items:center;gap:6px;width:fit-content;padding:4px 8px;border-radius:100vh}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-text{font-size:14px;font-weight:500}.station-detail-tabs-container{width:50%}.station-detail-tabs{grid-template-columns:repeat(2,1fr)}.charger-detail{padding:24px;max-width:1200px;margin:0 auto}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--border-color)}.header-content h1{margin:0 0 8px;font-size:2rem;font-weight:600;color:var(--text-primary)}.charger-id,.charger-cpo-id{margin:0;font-size:.9rem;color:var(--text-secondary)}.charger-id{margin-bottom:4px}.header-actions{display:flex;gap:12px}.charger-detail-tabs-container{width:50%}.charger-detail-tabs{grid-template-columns:repeat(2,1fr)}.detail-content{min-height:400px}.info-section{margin-bottom:32px}.info-section h3{margin:0 0 16px;font-size:1.2rem;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.info-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.info-table th,.info-table td{padding:16px;text-align:left;border-bottom:1px solid var(--border-color)}.info-table th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary);width:200px}.info-table td{color:var(--text-primary)}.station-info,.dr-resource-info,.extension-info{padding:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000001a}.station-info h4,.dr-resource-info h4,.extension-info h4{margin:0 0 16px;font-size:1.1rem;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.station-info p,.dr-resource-info p,.extension-info p{margin:8px 0;color:var(--text-secondary);font-size:.9rem}.detail-loading,.detail-error,.detail-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-error h2,.detail-not-found h2{margin:0 0 16px;color:var(--error-color)}.detail-error p,.detail-not-found p{margin:0 0 24px;color:var(--text-secondary)}@media (max-width: 768px){.charger-detail{padding:16px}.detail-header{flex-direction:column;gap:16px;align-items:stretch}.header-actions{justify-content:flex-end}.detail-tabs{overflow-x:auto;padding-bottom:8px}.tab-button{white-space:nowrap;padding:10px 16px}.info-table th,.info-table td{padding:12px}.info-table th{width:120px}}.system-alert-history-container{padding:2rem;min-width:1500px}.system-alert-history-content{display:flex;flex-direction:column;gap:20px}.select-all-checkbox{cursor:pointer;display:flex;align-items:center;justify-content:center;border:2px solid var(--gray-400);border-radius:4px;background-color:var(--bg-primary);transition:all .2s ease;flex-shrink:0;position:relative}.select-all-checkbox:hover:not(.disabled){border-color:var(--primary-600);background-color:var(--primary-50)}.select-all-checkbox.disabled{cursor:not-allowed;opacity:.6}.select-all-checkbox-icon,.select-all-checkbox-partial{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--primary-600);border-radius:2px}.select-all-checkbox-partial-line{font-size:14px;color:#fff;font-weight:700;line-height:1;-webkit-user-select:none;user-select:none}.select-all-checkbox-empty{width:100%;height:100%}.system-alert-detail-container{padding:2rem;min-width:1500px}.system-alert-detail-content{display:flex;flex-direction:column;gap:24px}.system-alert-detail-header{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:2px solid var(--border-color)}.system-alert-detail-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.system-alert-detail-info{display:flex;flex-direction:column;gap:24px}.system-alert-detail-section{display:flex;flex-direction:column;gap:12px}.system-alert-detail-section-title{margin:0;font-size:1.2rem;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.system-alert-detail-content-text{padding:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.system-alert-detail-loading,.system-alert-detail-error,.system-alert-detail-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:16px}.system-alert-detail-loading p,.system-alert-detail-error p,.system-alert-detail-not-found p{color:var(--text-secondary);margin:0}.system-alert-detail-error h2,.system-alert-detail-not-found h2{margin:0;color:var(--text-primary)}.loading-spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cbl-module-management-container,.system-config-key-management-container{padding:2rem;min-width:1500px}.system-config-key-management-group-container{grid-template-columns:250px 1fr}.system-config-key-management-group-container>div>div:first-child{background:var(--bg-primary);padding:10px;text-align:left;font-size:12px;font-weight:700;color:var(--gray-600);border-bottom:1px solid var(--gray-400)}.system-config-key-management-group-name{padding:15px;border-bottom:1px solid var(--gray-400);font-size:14px;font-weight:400;color:var(--gray-700);vertical-align:middle;text-align:left}.system-config-key-management-group-name.selected{background:var(--gray-200)}.system-config-key-management-key{padding:15px;border-bottom:1px solid var(--gray-400);font-size:14px;font-weight:400;color:var(--gray-700);vertical-align:middle;text-align:left;display:flex;justify-content:space-between;align-items:center}*,::backdrop,:after,:before{border:0 solid;box-sizing:border-box;margin:0;padding:0;font-family:Pretendard}html:not(.screen-arch),html:not(.screen-arch) body,#root{height:100%}.App{height:100%;display:flex;flex-direction:column}ul,ol,li{list-style:none}a{color:var(--primary);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-dark)}button{cursor:pointer;border:none;outline:none;transition:var(--transition)}input:focus,textarea:focus,select:focus{outline:none}input:disabled{background-color:var(--bg-primary)}input[type=text]{background-color:var(--bg-primary);color:var(--text-base)}input[type=checkbox]{all:unset;width:16px;height:16px;border-radius:4px;border:1px solid var(--gray-400);background-color:var(--bg-primary);cursor:pointer}input[type=checkbox]{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1px solid var(--gray-400);background-color:var(--bg-primary);cursor:pointer;position:relative}input[type=checkbox]:checked{background-color:var(--primary-600);border-color:var(--primary-600)}input[type=checkbox]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3csvg%20width='12'%20height='12'%20viewBox='0%200%2012%2012'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M2.88867%205.99993L5.11089%208.22215L9.55534%203.77771'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center;filter:brightness(0) invert(1)}input[type=radio]{all:unset;width:16px;height:16px;border-radius:100vh;border:1px solid var(--gray-400);position:relative;cursor:pointer}input[type=radio]:checked{background-color:var(--primary-600);border-color:var(--primary-600)}input[type=radio]:checked:after{content:""!important;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3csvg%20width='12'%20height='12'%20viewBox='0%200%2012%2012'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M2.88867%205.99993L5.11089%208.22215L9.55534%203.77771'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center;filter:brightness(0) invert(1);display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-200);border-radius:var(--radius)}::-webkit-scrollbar-thumb{background:var(--primary-600)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}::selection{background-color:var(--primary-light);color:var(--primary-dark)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}label.required{position:relative}label.required:after{position:absolute;top:0;left:calc(100% + 2px);content:"*";color:var(--red-500)}.btn{border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.btn.big-btn{padding:10px 24px;font-size:16px;font-weight:400}.btn.small-btn{padding:7px 16px;font-size:12px;font-weight:400}.btn.icon-btn{background:none}.btn-primary{background:var(--primary-600);color:#fff}.btn-style-2{background:var(--bg-primary);color:var(--primary-600);border:1px solid var(--gray-400)}.btn-style-3{background:var(--primary-900);color:#fff}.btn-style-4{background:var(--gray-400);color:#fff}.btn-style-5{background:var(--bg-primary);color:var(--gray-600);border:1px solid var(--gray-400)}.btn-green-700{background:var(--green-700);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--secondary-color);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--secondary-hover)}.btn-danger{background:var(--danger-color, #dc3545);color:#fff}.btn-danger:hover{background:var(--danger-hover, #c82333)}.btn:disabled{opacity:.3;cursor:not-allowed}.btn:active{opacity:.3}.btn:hover{transform:translateY(-1px)}.input-primary{border:1px solid var(--gray-400);background:var(--bg-primary);border-radius:8px;padding:10px}.input-primary:focus{background:var(--bg-primary);border-radius:8px;padding:10px;outline:1px solid var(--primary-600);outline-offset:0px}.search-box-container{position:relative}.search-box{background:var(--bg-primary);border:1px solid var(--gray-400);border-radius:8px;padding:10px;display:flex;align-items:center}.search-filter-box{background:var(--bg-primary);border:1px solid var(--gray-400);border-radius:8px;padding:15px 30px 15px 15px;position:absolute;top:calc(100% + 10px);left:30px}.search-filter-box label{cursor:pointer;margin-left:5px}.primary-table{background:var(--bg-primary);overflow:hidden}.primary-table table{width:100%;border-collapse:collapse;table-layout:auto}.primary-table th{background:var(--bg-primary);padding:10px;text-align:left;font-size:12px;font-weight:700;color:var(--gray-600);border-bottom:1px solid var(--gray-400)}.primary-table td{padding:15px;border-bottom:1px solid var(--gray-400);font-size:14px;font-weight:400;color:var(--gray-700);vertical-align:middle;text-align:left}.primary-table tr td:first-child,.primary-table td:first-child{font-weight:700;color:var(--gray-600);font-size:14px}.primary-table tr.primary-table-item-clickable{cursor:pointer;transition:all .2s ease}.primary-table tr.primary-table-item-clickable:active{opacity:.3}.primary-table tr.primary-table-item-clickable:hover{background:var(--gray-200)}.primary-table td.button-container{width:80px;cursor:default}.transparent-table{border-spacing:0 16px;border-collapse:separate}.transparent-table th{width:100%}.transparent-table td{color:var(--text-base)}.gray-table{width:100%;border-collapse:collapse;border-top:2px solid var(--gray-600)}.gray-table tr{border-bottom:1px solid var(--gray-400)}.gray-table th{background:var(--gray-200);color:var(--gray-800);font-size:16px;font-weight:700;text-align:left;padding:10px}.gray-table td{padding:10px;color:var(--gray-700);font-size:16px;font-weight:400}.gray-double-table{width:100%;border-collapse:collapse;border-top:2px solid var(--gray-600)}.gray-double-table tr{border-bottom:1px solid var(--gray-400)}.gray-double-table th{background:var(--gray-200);color:var(--gray-800);font-size:16px;font-weight:700;text-align:center;padding:10px}.gray-double-table td{color:var(--gray-700);font-size:16px;font-weight:400;text-align:center}.modal-background{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;display:flex;justify-content:center;align-items:flex-start;z-index:999;overflow-y:auto;padding:20px 0}.modal-container{background:var(--bg-primary);padding:16px;max-width:90%;min-width:500px;width:fit-content;max-height:calc(100vh - 40px);box-shadow:0 4px 12px #0003;position:relative;animation:fadeIn .3s ease;margin:auto;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.modal-container.overflow-visible{overflow-y:visible}.modal-container.overflow-hidden{overflow-y:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-header>h3{padding:0;margin:0;font-size:20px;font-weight:700;color:var(--text-base)}.close-btn{position:absolute;top:0;right:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary-600);cursor:pointer}.close-btn svg{width:24px;height:24px;color:#fff}.modal-content{flex:1}.modal-footer{display:flex;justify-content:center;gap:1rem}.modal-footer.end{justify-content:flex-end}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.detail-modal-background{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;display:flex;justify-content:center;align-items:flex-start;z-index:9999;overflow-y:auto}.detail-modal-container{background:var(--bg-secondary);max-width:90%;min-width:1200px;width:fit-content;max-height:calc(100vh - 40px);box-shadow:0 4px 12px #0003;position:relative;animation:fadeIn .3s ease;margin:auto;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.detail-modal-header{height:120px;position:relative;display:flex;align-items:center;padding:0 32px}.detail-modal-header>h3{padding:0;margin:0;font-size:24px;font-weight:700;color:var(--text-primary)}.detail-modal-content{flex:1;background-color:var(--bg-primary);position:relative;max-height:calc(100vh - 160px);overflow-y:auto;display:flex;flex-direction:column}.detail-modal-content-divide-container{display:flex;gap:16px;background-color:var(--bg-secondary);flex:1;min-height:0}.detail-modal-content-divide-content{flex:1;background-color:var(--bg-primary);padding:32px;overflow-y:overlay;min-height:0}.detail-page-container{display:flex;flex:1;flex-direction:column;gap:16px;min-width:1500px}.detail-page-content{flex:1;background-color:var(--bg-primary);position:relative;overflow-y:auto;display:flex;flex-direction:column}.detail-page-content-divide-container{display:grid;grid-template-columns:600px 1fr;gap:16px;background-color:var(--bg-secondary);flex:1;min-height:0}.detail-page-content-divide-content{flex:1;background-color:var(--bg-primary);padding:32px;overflow-y:overlay;min-height:0}.detail-page-content-divide-content.right{min-width:800px}.detail-page-charger-comp-charger-title{display:flex;align-items:center;gap:10px}.detail-page-charger-comp-charger-title:before{content:"";display:block;width:30px;height:10px;border-radius:100vh;background-color:var(--gray-400)}.detail-page-charger-comp-charger-title.left:before{background-color:var(--red-500)}.detail-page-charger-comp-charger-title.right:before{background-color:var(--blue-500)}.side-modal-background{position:fixed;top:0;right:0;width:100vw;height:100vh;background-color:#0006;display:flex;justify-content:flex-end;align-items:flex-start;z-index:999;overflow-y:auto}.side-modal-container{background:var(--bg-primary);width:520px;height:100vh;position:fixed;top:0;right:0;z-index:999;box-shadow:-2px 0 10px #0000001a;transition:transform .3s ease;display:flex;flex-direction:column;overflow-y:auto;gap:16px;background-color:var(--bg-secondary);animation:slideIn .3s ease;overflow:hidden}.side-modal-header{height:120px;background-color:var(--bg-primary);position:relative;display:flex;align-items:center;padding:0 32px}.side-modal-header>h3{padding:0;margin:0;font-size:24px;font-weight:700;color:var(--text-base)}.side-modal-close{position:absolute;top:0;right:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary-600);cursor:pointer}.side-modal-close svg{width:24px;height:24px;color:#fff}.side-modal-content{height:calc(100% - 120px);background-color:var(--bg-primary);padding:32px 40px;overflow-y:overlay}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.tabs{border-bottom:1px solid var(--border-color);margin-bottom:24px;display:grid}.tab{background:none;border:none;padding:12px 24px;font-size:16px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:var(--transition);position:relative}.tab:hover{color:var(--text-base);background:var(--gray-50)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);background:var(--bg-primary)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary-600)}.tab.mini-tab{background:none;border:none;padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer}.tab.mini-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--gray-700)}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right)}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right)}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}}.Toastify__toast{--y: 0;position:relative;-ms-touch-action:none;touch-action:none;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0;overflow:hidden}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start;z-index:1}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial;border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp{position:absolute;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{min-height:100vh;display:flex;width:100%}.login-left-section{flex:1.8;background:var(--primary-600);display:flex;align-items:center;justify-content:start;padding:0 128px;position:relative}.login-logo-container{display:flex;align-items:start;gap:20px;color:#fff;transform:translateY(-128px)}.login-logo{width:80px;height:80px;padding:16px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026}.logo-icon{font-size:36px;font-weight:700;color:var(--primary-600);background:linear-gradient(135deg,#ff6b6b,#ee5a24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo-text{display:flex;flex-direction:column;gap:4px}.login-logo-title{font-size:32px;font-weight:700;color:#fff;line-height:1.2}.login-logo-subtitle{font-size:32px;font-weight:700;color:#fff;line-height:1.3}.login-right-section{flex:1;background:#fff;display:flex;align-items:center;justify-content:center;padding:40px}.login-form-container{width:100%;max-width:450px}.login-header{text-align:center;margin-bottom:40px}.login-header h1{color:var(--text-base);margin-bottom:16px;font-size:24px;font-weight:700;line-height:1.2}.login-header p{color:var(--gray-600);font-size:16px;font-weight:400;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:24px}.forgot-password-link{color:var(--primary-600);text-decoration:none;font-size:14px;font-weight:400;margin-top:8px;margin-left:auto;align-self:flex-start;transition:var(--transition)}.forgot-password-link:hover{color:var(--primary-dark);text-decoration:underline}.login-button{background:var(--primary-600);color:#fff;border:none;padding:16px;border-radius:var(--radius);font-size:16px;font-weight:400;cursor:pointer;transition:var(--transition);margin-top:8px;width:100%}.login-button:hover:not(:disabled){background:var(--primary-dark)}.login-button:disabled{background:var(--gray-400);cursor:not-allowed}.login-footer{text-align:center;margin-top:32px}.login-footer p{color:var(--gray-600);font-size:14px;font-weight:400}.register-link{color:var(--gray-700);font-size:14px;text-decoration:none;font-weight:700;margin-left:4px;transition:var(--transition)}.register-link:hover{color:var(--primary-dark);text-decoration:underline}@media (max-width: 768px){.login-container{flex-direction:column}.login-left-section{flex:1;min-height:200px}.login-right-section{flex:1;padding:20px}.login-logo-container{flex-direction:column;text-align:center;gap:16px}.logo-title{font-size:20px}.logo-subtitle{font-size:14px}}.system-login-container{min-height:100vh;display:flex;width:100%;position:relative;align-items:center;justify-content:center}.system-login-form-wrapper{height:fit-content;padding:40px;width:560px;background:#fff;border-radius:var(--radius);box-shadow:var(--modal-shadow);display:flex;align-items:center;justify-content:center}.system-login-form-container{width:100%;max-width:360px}.register-container{min-height:100vh;display:flex;width:100%}.register-left-section{flex:1.8;background:var(--primary-600);display:flex;align-items:center;justify-content:start;padding:0 128px;position:relative}.register-logo-container{display:flex;align-items:start;gap:20px;color:#fff;transform:translateY(-128px)}.register-logo{width:80px;height:80px;padding:16px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026}.register-logo-text{display:flex;flex-direction:column;gap:4px}.register-logo-title{font-size:32px;font-weight:700;color:#fff;line-height:1.2}.register-logo-subtitle{font-size:32px;font-weight:700;color:#fff;line-height:1.3}.register-right-section{flex:1;background:#fff;display:flex;align-items:center;justify-content:center;padding:40px}.register-form-container{width:100%;max-width:450px}.register-header{text-align:center;margin-bottom:40px}.register-header h1{color:var(--text-base);margin-bottom:16px;font-size:24px;font-weight:700;line-height:1.2}.register-header p{color:var(--gray-600);font-size:16px;font-weight:400;line-height:1.5}.register-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--gray-700);font-size:16px;font-weight:700}.form-group input{padding:16px;border:1px solid var(--border-color);border-radius:var(--radius);font-size:16px;line-height:1.5rem;transition:var(--transition);background:#fff;color:var(--gray-700)}.form-group input:focus{outline:none;border-color:var(--primary-600);box-shadow:0 0 0 3px #2563eb1a}.form-group input::placeholder{color:var(--gray-600)}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:var(--radius);font-size:14px;border:1px solid #fecaca;margin-top:8px}.success-message{text-align:center;padding:40px 20px}.success-message h2{color:var(--success);margin-bottom:16px;font-size:24px;font-weight:700}.success-message p{color:var(--text-secondary);font-size:14px;margin-bottom:8px;font-weight:400}.register-button{background:var(--primary-600);color:#fff;border:none;padding:16px;border-radius:var(--radius);font-size:16px;font-weight:400;cursor:pointer;transition:var(--transition);margin-top:8px;width:100%}.register-button:hover:not(:disabled){background:var(--primary-dark)}.register-button:disabled{background:var(--gray-400);cursor:not-allowed}.register-footer{text-align:center;margin-top:32px}.register-footer p{color:var(--gray-600);font-size:14px;font-weight:400}.login-link{color:var(--gray-700);font-size:14px;text-decoration:none;font-weight:700;margin-left:4px;transition:var(--transition)}.login-link:hover{color:var(--primary-dark);text-decoration:underline}@media (max-width: 768px){.register-container{flex-direction:column}.register-left-section{flex:1;min-height:200px}.register-right-section{flex:1;padding:20px}.register-logo-container{flex-direction:column;text-align:center;gap:16px}.logo-title{font-size:20px}.logo-subtitle{font-size:14px}}
