:root{--color-deep-spring-green: #00E66E;--color-spring-green: #57FF88;--color-light-spring-green: #9BFFB7;--color-soft-green: #F0FFF4;--color-vibrant-violet: #7952FF;--color-violet: #9771FF;--color-light-violet: #CAB9FF;--color-soft-violet: #FAF8FF;--color-deep-green: #001F1D;--color-gray: #646464;--color-light-gray: #F7F7F7;--color-white: #FFFFFF;--color-primary: var(--color-deep-spring-green);--color-primary-dark: #00C45C;--color-secondary: var(--color-vibrant-violet);--color-text: var(--color-deep-green);--color-text-muted: var(--color-gray);--color-bg: #EFF6F2;--color-surface: var(--color-white);--color-border: #E0EDE8;--font-headline: "Bai Jamjuree", sans-serif;--font-body: "Nunito", sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 31, 29, .06);--shadow-md: 0 4px 16px rgba(0, 31, 29, .08);--shadow-lg: 0 8px 32px rgba(0, 31, 29, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);font-weight:400;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-headline);font-weight:500;line-height:1.3}input,select,textarea,button{font-family:var(--font-body)}button{cursor:pointer;border:none;outline:none}input,select,textarea{outline:none}a{text-decoration:none;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;font-weight:600;transition:all .18s ease;cursor:pointer;border:none}.btn-primary{background:var(--color-deep-spring-green);color:var(--color-deep-green)}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #00e66e59}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-vibrant-violet);color:var(--color-white)}.btn-secondary:hover{background:#6940e0;transform:translateY(-1px);box-shadow:0 4px 12px #7952ff59}.btn-outline{background:transparent;border:1.5px solid var(--color-border);color:var(--color-text)}.btn-outline:hover{border-color:var(--color-deep-spring-green);color:var(--color-deep-green);background:var(--color-soft-green)}.btn-danger{background:#ff4d4f;color:var(--color-white)}.btn-danger:hover{background:#e03e40}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.badge-green{background:var(--color-soft-green);color:#00924a}.badge-violet{background:#f0edff;color:var(--color-vibrant-violet)}.badge-gray{background:var(--color-light-gray);color:var(--color-gray)}.login-root{display:flex;min-height:100vh;height:100%}.login-left{position:relative;flex:0 0 42%;background:var(--color-deep-green);display:flex;align-items:stretch;overflow:hidden}.login-left-inner{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;padding:60px 48px;gap:28px}.login-brand-logo{display:block;width:100%;max-width:300px;height:auto;max-height:56px;object-fit:contain;object-position:left center}.login-left-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:radial-gradient(ellipse 60% 40% at 20% 80%,rgba(0,230,110,.15) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 80% 20%,rgba(121,82,255,.2) 0%,transparent 60%)}.login-tagline{font-size:36px;font-weight:600;color:var(--color-white);line-height:1.25}.login-left-sub{font-size:15px;color:#ffffffa6;max-width:320px;line-height:1.7}.login-dots{display:flex;gap:8px;margin-top:12px}.login-dot{width:8px;height:8px;border-radius:50%;background:#ffffff40}.login-dot-active{width:24px;height:8px;border-radius:4px;background:var(--color-deep-spring-green)}.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--color-soft-green)}.login-form-card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:48px 44px;width:100%;max-width:440px}.login-form-header{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}.login-form-brand-logo{display:block;width:100%;max-width:250px;height:auto;object-fit:contain;object-position:left center}.login-form-title{font-size:26px;color:var(--color-deep-green);margin-top:4px}.login-form-sub{font-size:14px;color:var(--color-gray)}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:7px}.login-label{font-size:13px;font-weight:600;color:var(--color-deep-green)}.login-input-wrap{position:relative}.login-input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--color-gray);display:flex;align-items:center}.login-input{width:100%;padding:11px 14px 11px 40px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;color:var(--color-deep-green);background:var(--color-white);transition:border-color .18s,box-shadow .18s;font-family:var(--font-body)}.login-input::placeholder{color:#b0c4be}.login-input:focus{outline:none;border-color:var(--color-deep-spring-green);box-shadow:0 0 0 3px #00e66e26}.login-error{background:#fff1f0;border:1px solid #ffccc7;color:#cf1322;border-radius:var(--radius-md);padding:10px 14px;font-size:13px}.login-error-locked{background:#fff7e6;border-color:#ffd591;color:#d46b08}.login-input:disabled{background:#f5f5f5;color:var(--color-gray);cursor:not-allowed}.login-submit-btn{width:100%;padding:13px;font-size:15px;margin-top:8px;border-radius:var(--radius-md)}.login-submit-btn:disabled{opacity:.75;cursor:not-allowed;transform:none!important}.login-spinner{width:20px;height:20px;border:2.5px solid rgba(0,31,29,.2);border-top-color:var(--color-deep-green);border-radius:50%;animation:login-spin .7s linear infinite;display:inline-block}@keyframes login-spin{to{transform:rotate(360deg)}}.login-hint{margin-top:20px;font-size:12px;color:var(--color-gray);display:flex;align-items:center;gap:6px;justify-content:center}@media (max-width: 768px){.login-left{display:none}.login-form-card{padding:36px 24px}}.session-expired-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;background:#001f1d8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.session-expired-modal{width:100%;max-width:400px;background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:40px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;animation:session-expired-in .2s ease}@keyframes session-expired-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.session-expired-icon{width:72px;height:72px;border-radius:50%;background:#fff8f0;border:3px solid rgba(232,135,46,.25);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.session-expired-title{font-size:20px;color:var(--color-deep-green);margin:0}.session-expired-message{font-size:14px;color:var(--color-gray);line-height:1.6;margin:0}.layout-root{display:flex;height:100vh;overflow:hidden}.layout-main{flex:1;min-width:0;min-height:0;overflow-y:auto;overflow-x:hidden;background:var(--color-bg)}.layout-content{padding:32px 36px}.layout-content:has(.dashboard-root){padding:clamp(16px,2vh,24px) clamp(20px,2.5vw,36px)}@media (max-width: 900px){.layout-content{padding:20px 16px}.layout-content:has(.dashboard-root){padding:16px}}.sidebar{width:240px;min-width:240px;background:var(--color-deep-green);display:flex;flex-direction:column;height:100vh;overflow:hidden;transition:width .22s ease,min-width .22s ease;position:relative;z-index:10}.sidebar.sidebar-collapsed{width:68px;min-width:68px}.sidebar-top{position:relative;display:flex;align-items:center;padding:14px 44px 12px 14px;border-bottom:1px solid rgba(255,255,255,.07);min-height:58px}.sidebar-brand-logo{display:block;width:100%;height:auto;max-height:52px;object-fit:contain;object-position:left center}.sidebar.sidebar-collapsed .sidebar-top{justify-content:center;padding:16px 12px 14px}.sidebar.sidebar-collapsed .sidebar-collapse-btn{position:static;margin-left:0}.sidebar-collapse-btn{position:absolute;top:14px;right:12px;background:#ffffff12;border:none;border-radius:var(--radius-sm);color:#ffffff80;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.sidebar-collapse-btn:hover{background:#ffffff1f;color:#ffffffe6}.sidebar-section{padding:20px 20px 6px}.sidebar-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff4d}.sidebar-nav{flex:1;display:flex;flex-direction:column;padding:8px 10px;gap:2px;overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:var(--radius-md);background:transparent;border:none;color:#ffffff8c;cursor:pointer;transition:all .16s ease;text-align:left;position:relative;white-space:nowrap;font-family:var(--font-body)}.sidebar-nav-item:hover{background:#ffffff12;color:#ffffffe6}.sidebar-nav-item.sidebar-nav-active{background:#00e66e1f;color:var(--color-deep-spring-green)}.sidebar-nav-icon{flex-shrink:0;display:flex;align-items:center}.sidebar-nav-label{font-size:14px;font-weight:500;flex:1}.sidebar-nav-group{display:flex;flex-direction:column;gap:2px}.sidebar-chevron{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#ffffff59;transition:transform .2s ease}.sidebar-chevron-open{transform:rotate(180deg)}.sidebar-subnav{display:flex;flex-direction:column;gap:2px;padding-left:14px;margin-left:20px;border-left:1px solid rgba(255,255,255,.1)}.sidebar-subnav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);background:transparent;border:none;color:#ffffff73;cursor:pointer;transition:all .16s ease;text-align:left;position:relative;white-space:nowrap;font-family:var(--font-body);font-size:13px;font-weight:500}.sidebar-subnav-item:hover{background:#ffffff0f;color:#ffffffd9}.sidebar-subnav-active{background:#00e66e1a;color:var(--color-deep-spring-green)}.sidebar-subnav-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.6}.sidebar-subnav-active .sidebar-subnav-dot{opacity:1}.sidebar-subnav-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar-active-bar{position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-deep-spring-green);border-radius:2px}.sidebar-bottom{padding:14px 10px;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:8px}.sidebar-user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:#ffffff0d}.sidebar-user-card-collapsed{justify-content:center;padding:10px}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:var(--color-deep-spring-green);color:var(--color-deep-green);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{font-size:13px;font-weight:600;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:#fff6;white-space:nowrap}.sidebar-logout-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-md);background:transparent;border:none;color:#ffffff73;cursor:pointer;font-size:14px;font-weight:500;transition:all .16s;font-family:var(--font-body)}.sidebar-logout-btn:hover{background:#ff4d4f1f;color:#ff7875}.sidebar-logout-collapsed{justify-content:center}.sidebar-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 4px 2px;margin-top:4px;border-top:1px solid rgba(255,255,255,.07)}.sidebar-meta-collapsed{justify-content:center;padding:10px 0 2px}.sidebar-version{font-size:10px;font-weight:600;color:#ffffff59;letter-spacing:.02em;white-space:nowrap}.sidebar-meta .logo-sm{height:26px;opacity:.9}.sidebar-meta .logo-icon-only{width:28px;height:28px;opacity:.9}.logo{display:flex;align-items:center;-webkit-user-select:none;user-select:none}.logo-img{display:block;width:auto;height:100%;object-fit:contain}.logo-sm{height:28px}.logo-md{height:36px}.logo-lg{height:52px}.logo-icon-only{width:32px;height:32px;overflow:hidden;border-radius:var(--radius-sm)}.logo-icon-only .logo-img{width:auto;height:32px;max-width:none;object-fit:cover;object-position:left center}.dashboard-root{display:flex;flex-direction:column;gap:clamp(12px,1.6vh,18px)}.dashboard-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;flex-shrink:0}.dashboard-error{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--radius-md);background:#fff5f5;border:1px solid #ffd6d6;color:#cf1322;font-size:14px;font-weight:500}.dashboard-greeting{font-size:15px;color:var(--color-gray);margin-bottom:6px}.dashboard-greeting strong{font-weight:700;color:var(--color-deep-green)}.dashboard-title{font-size:28px;color:var(--color-deep-green)}.dashboard-sub{font-size:14px;color:var(--color-gray);margin-top:4px}.dashboard-header-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right}.dashboard-live-status{display:flex;align-items:center;gap:8px}.dashboard-live-dot{width:8px;height:8px;border-radius:50%;background:var(--color-deep-spring-green);box-shadow:0 0 0 2px #00e66e33}.dashboard-live-dot-pulse{animation:dashboard-live-pulse 1s ease-in-out infinite}@keyframes dashboard-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.dashboard-live-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-deep-spring-green)}.dashboard-last-updated{font-size:13px;font-weight:600;color:var(--color-deep-green);margin:0}.dashboard-refresh-interval{font-size:12px;color:var(--color-gray);margin:0}.dashboard-refresh-control{display:flex;align-items:center;gap:8px}.dashboard-refresh-label{font-size:12px;color:var(--color-gray)}.dashboard-refresh-options{display:inline-flex;border:1px solid var(--color-border, #e2e8e8);border-radius:8px;overflow:hidden;background:#fff}.dashboard-refresh-option{border:none;background:transparent;padding:4px 10px;font-size:12px;font-weight:600;color:var(--color-gray);cursor:pointer;transition:background .15s,color .15s}.dashboard-refresh-option+.dashboard-refresh-option{border-left:1px solid var(--color-border, #e2e8e8)}.dashboard-refresh-option:hover{background:#0000000a;color:var(--color-deep-green)}.dashboard-refresh-option-active,.dashboard-refresh-option-active:hover{background:var(--color-deep-green);color:#fff}.dashboard-poll-error{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);background:#fff8e6;border:1px solid #f0d78c;color:#8a6d1d;font-size:13px}.dashboard-skeleton-card{pointer-events:none}.dashboard-skeleton-block{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-light-gray) 0%,#e8efec 40%,var(--color-light-gray) 80%);background-size:200% 100%;animation:dashboard-skeleton-shimmer 1.4s ease-in-out infinite;overflow:hidden;max-width:100%}.dashboard-skeleton-icon{width:44px;height:44px;border-radius:var(--radius-md)}.dashboard-skeleton-badge{width:52px;height:22px;border-radius:99px}.dashboard-skeleton-value{width:72%;height:32px;margin-top:2px}.dashboard-skeleton-label{width:48%;height:14px}.dashboard-skeleton-progress{width:100%;height:6px;border-radius:99px}.dashboard-skeleton-footer{width:85%;height:12px}.dashboard-skeleton-secondary-icon{width:44px;height:44px;border-radius:50%;flex-shrink:0}.dashboard-skeleton-secondary-text{flex:1;display:flex;flex-direction:column;gap:8px}.dashboard-skeleton-secondary-value{width:56px;height:28px}.dashboard-skeleton-secondary-label{width:120px;height:14px}.dashboard-skeleton-sites-title{width:120px;height:20px}.dashboard-skeleton-sites-sub{width:280px;max-width:100%;height:14px;margin-top:8px}.dashboard-skeleton-operational{width:110px;height:32px;border-radius:99px;flex-shrink:0}.dashboard-skeleton-table th{color:transparent;-webkit-user-select:none;user-select:none}.dashboard-skeleton-table{table-layout:fixed}.dashboard-skeleton-table-wrap{overflow:auto}.dashboard-skeleton-table td{overflow:hidden}.dashboard-skeleton-table .dashboard-skeleton-block{width:100%}.dashboard-skeleton-cell-site{max-width:140px;height:16px}.dashboard-skeleton-cell-pill{max-width:72px;height:26px;border-radius:99px}.dashboard-skeleton-cell-short{max-width:48px;height:14px}.dashboard-skeleton-cell-medium{max-width:72px;height:14px}@keyframes dashboard-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dashboard-primary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(10px,1.2vw,16px)}.dashboard-primary-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:clamp(12px,1.6vh,18px);display:flex;flex-direction:column;gap:clamp(6px,.8vh,10px);min-width:0}.dashboard-primary-top{display:flex;align-items:flex-start;justify-content:space-between}.dashboard-primary-icon{width:clamp(34px,4vh,40px);height:clamp(34px,4vh,40px);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-primary-icon svg{width:clamp(18px,2vh,22px);height:clamp(18px,2vh,22px)}.dashboard-accent-blue .dashboard-primary-icon{background:#e8f0ff;color:#3b6fe8}.dashboard-accent-violet .dashboard-primary-icon{background:#f0edff;color:var(--color-vibrant-violet)}.dashboard-accent-teal .dashboard-primary-icon{background:#e6faf5;color:#0d9b8a}.dashboard-accent-orange .dashboard-primary-icon{background:#fff3e8;color:#e8872e}.dashboard-accent-green .dashboard-primary-icon,.dashboard-accent-green .dashboard-secondary-icon{background:var(--color-soft-green);color:#00924a}.dashboard-live-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.06em;background:var(--color-soft-green);color:#00924a}.dashboard-live-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-deep-spring-green);animation:dashboard-pulse 2s ease-in-out infinite}.dashboard-primary-value{font-size:30px;font-weight:600;color:var(--color-deep-green);line-height:1.1}.dashboard-primary-label{font-size:13px;font-weight:600;color:var(--color-deep-green)}.dashboard-progress-track{height:6px;border-radius:99px;background:var(--color-light-gray);overflow:hidden}.dashboard-accent-blue .dashboard-progress-fill{background:#3b6fe8}.dashboard-accent-violet .dashboard-progress-fill{background:var(--color-vibrant-violet)}.dashboard-accent-teal .dashboard-progress-fill{background:#0d9b8a}.dashboard-accent-orange .dashboard-progress-fill{background:#e8872e}.dashboard-accent-green .dashboard-progress-fill{background:var(--color-deep-spring-green)}.dashboard-progress-fill{height:100%;border-radius:99px;transition:width .4s ease}.dashboard-primary-footer{font-size:12px;color:var(--color-gray);line-height:1.4}.dashboard-secondary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(10px,1.2vw,16px)}.dashboard-secondary-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:clamp(12px,1.5vh,16px) clamp(14px,1.6vh,18px);display:flex;align-items:center;gap:12px;min-width:0}.dashboard-secondary-icon{width:clamp(36px,4vh,42px);height:clamp(36px,4vh,42px);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-accent-teal .dashboard-secondary-icon{background:#e6faf5;color:#0d9b8a}.dashboard-accent-green .dashboard-secondary-icon{background:var(--color-soft-green);color:#00924a}.dashboard-accent-orange .dashboard-secondary-icon{background:#fff3e8;color:#e8872e}.dashboard-secondary-value{font-size:26px;font-weight:600;color:var(--color-deep-green);line-height:1.1}.dashboard-secondary-label{font-size:13px;color:var(--color-gray);margin-top:2px}.dashboard-sites-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;min-height:clamp(220px,32vh,360px)}.dashboard-sites-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:clamp(12px,1.6vh,16px) clamp(16px,2vw,24px);border-bottom:1px solid var(--color-border);flex-shrink:0}.dashboard-sites-title{font-size:18px;font-weight:600;color:var(--color-deep-green)}.dashboard-sites-sub{font-size:13px;color:var(--color-gray);margin-top:2px}.dashboard-overall-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:99px;font-size:12px;font-weight:600;white-space:nowrap}.dashboard-overall-ok{background:var(--color-soft-green);color:#00924a}.dashboard-overall-warning{background:#fff8e6;color:#b8860b}.dashboard-overall-danger{background:#fff5f5;color:#cf1322}.dashboard-overall-dot{width:8px;height:8px;border-radius:50%;animation:dashboard-pulse 2s ease-in-out infinite}.dashboard-overall-ok .dashboard-overall-dot{background:var(--color-deep-spring-green)}.dashboard-overall-warning .dashboard-overall-dot{background:#e8a317}.dashboard-overall-danger .dashboard-overall-dot{background:#cf1322}.dashboard-operational-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:99px;font-size:12px;font-weight:600;background:var(--color-soft-green);color:#00924a;white-space:nowrap}.dashboard-operational-dot{width:8px;height:8px;border-radius:50%;background:var(--color-deep-spring-green);animation:dashboard-pulse 2s ease-in-out infinite}.dashboard-table-wrap{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}.dashboard-sites-table{width:100%;min-width:880px;border-collapse:collapse}.dashboard-sites-table th{text-align:left;padding:clamp(10px,1vh,14px) clamp(14px,1.5vw,24px);font-size:12px;font-weight:600;color:var(--color-gray);border-bottom:1px solid var(--color-border);white-space:nowrap;position:sticky;top:0;background:var(--color-white);z-index:1}.dashboard-sites-table td{padding:clamp(12px,1.2vh,16px) clamp(14px,1.5vw,24px);font-size:13px;color:var(--color-deep-green);border-bottom:1px solid var(--color-border);vertical-align:middle}.dashboard-sites-table tbody tr:last-child td{border-bottom:none}.dashboard-site-name{font-size:14px;font-weight:600;color:var(--color-deep-green)}.dashboard-site-url{font-size:12px;color:var(--color-gray);margin-top:2px}.dashboard-status-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:600}.dashboard-status-operational{background:var(--color-soft-green);color:#00924a}.dashboard-status-down{background:#fff5f5;color:#cf1322}.dashboard-table-empty{color:var(--color-gray)}.dashboard-table-metric{display:inline-flex;align-items:center;gap:6px;color:var(--color-deep-green)}@keyframes dashboard-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}@media (max-width: 1400px){.dashboard-primary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 1200px){.dashboard-primary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 900px){.dashboard-secondary-grid{grid-template-columns:1fr}.dashboard-sites-header{flex-direction:column;align-items:flex-start}}@media (max-width: 600px){.dashboard-primary-grid{grid-template-columns:1fr}}@media (max-height: 820px){.dashboard-primary-footer{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dashboard-sites-card{min-height:clamp(180px,28vh,280px)}}.db-root{display:flex;flex-direction:column;gap:24px}.db-page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.db-title{font-size:26px;color:var(--color-deep-green)}.db-sub{font-size:14px;color:var(--color-gray);margin-top:6px}.db-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.db-backup-table-btn{background:var(--color-deep-spring-green)!important;color:var(--color-deep-green)!important;border:none!important;padding:11px 22px;font-size:14px;font-weight:600;border-radius:var(--radius-md);box-shadow:none}.db-backup-table-btn:hover{background:var(--color-primary-dark)!important;transform:translateY(-1px);box-shadow:0 4px 12px #00e66e59}.db-backup-table-btn:active{transform:translateY(0)}.db-submenu{display:flex;gap:8px;padding:4px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);width:fit-content}.db-submenu-item{padding:10px 18px;border:none;border-radius:var(--radius-md);background:transparent;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-gray);cursor:pointer;transition:all .15s}.db-submenu-item:hover{color:var(--color-deep-green);background:var(--color-soft-green)}.db-submenu-active{background:var(--color-deep-spring-green);color:var(--color-deep-green)}.db-submenu-active:hover{background:var(--color-primary-dark);color:var(--color-deep-green)}.db-tables-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.db-tables-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--color-border)}.db-tables-count{font-size:13px;font-weight:600;color:var(--color-gray)}.db-tables-error{margin:0 20px 12px}.db-tables-empty{text-align:center;padding:32px 16px!important;color:var(--color-gray);font-size:14px}.db-tables-wrap{overflow-x:auto}.db-tables-table{width:100%;border-collapse:collapse;font-size:14px}.db-tables-table thead th{padding:12px 22px;text-align:left;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-gray);background:var(--color-light-gray);border-bottom:1px solid var(--color-border);white-space:nowrap}.db-tables-row{border-bottom:1px solid var(--color-border);transition:background .12s}.db-tables-row:last-child{border-bottom:none}.db-tables-row:hover{background:#f8fcf9}.db-tables-table tbody td{padding:14px 22px;color:var(--color-deep-green);vertical-align:middle}.db-tables-num{color:var(--color-gray)!important;font-size:13px!important;width:48px}.db-tables-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1.5px solid #ffd6d6;border-radius:var(--radius-sm);background:#fff5f5;color:#ff4d4f;cursor:pointer;transition:all .15s}.db-tables-delete-btn:hover{background:#ff4d4f;color:var(--color-white);border-color:#ff4d4f}.db-tables-protected{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-light-gray);color:var(--color-gray);cursor:default}.db-tables-skeleton{pointer-events:none}.db-skeleton-block{display:inline-block;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-light-gray) 0%,#e8efec 40%,var(--color-light-gray) 80%);background-size:200% 100%;animation:db-skeleton-shimmer 1.4s ease-in-out infinite}.db-tables-skeleton-count{width:72px;height:16px}.db-tables-skeleton-table th{color:transparent;-webkit-user-select:none;user-select:none}.db-tables-skeleton-num{width:18px;height:14px}.db-tables-skeleton-name{width:min(180px,70%);height:16px}.db-tables-skeleton-size{width:88px;height:14px}.db-tables-skeleton-action{width:72px;height:32px;border-radius:var(--radius-sm)}@keyframes db-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.db-delete-modal{background:var(--color-white);border-radius:var(--radius-lg);padding:28px 32px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);text-align:center}.db-delete-modal-icon{width:56px;height:56px;border-radius:50%;background:#fff0f0;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.db-delete-modal-title{font-size:20px;color:var(--color-deep-green);margin-bottom:8px}.db-delete-modal-sub{font-size:14px;color:var(--color-gray);line-height:1.6;margin-bottom:24px}.db-delete-modal-actions{display:flex;gap:10px;justify-content:center}.db-confirm-modal{background:var(--color-white);border-radius:var(--radius-lg);padding:28px 32px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);text-align:center}.db-confirm-modal-icon{width:56px;height:56px;border-radius:50%;background:var(--color-soft-green);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.db-confirm-modal-title{font-size:20px;color:var(--color-deep-green);margin-bottom:8px}.db-confirm-modal-sub{font-size:14px;color:var(--color-gray);line-height:1.6;margin-bottom:20px}.db-confirm-modal-error{margin-bottom:16px;text-align:left}.db-confirm-modal-actions{display:flex;gap:10px;justify-content:center}.db-create-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px 0 4px}.db-create-success-icon{width:80px;height:80px;border-radius:50%;background:var(--color-soft-green);border:3px solid rgba(0,230,110,.35);display:flex;align-items:center;justify-content:center;animation:db-create-tick-in .45s ease-out}@keyframes db-create-tick-in{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.db-create-success-title{font-size:20px;color:var(--color-deep-green);margin:4px 0 0}.db-create-success-sub{font-size:14px;color:var(--color-gray);margin:0;animation:db-create-pulse 1.5s ease-in-out infinite}@keyframes db-create-pulse{0%,to{opacity:1}50%{opacity:.55}}.db-required{color:#ff4d4f}.db-step-bar{display:flex;align-items:center;background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:18px 28px;box-shadow:var(--shadow-sm)}.db-step-item{display:flex;align-items:center;gap:10px;flex:1}.db-step-item:last-child{flex:none}.db-step-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--color-gray);background:var(--color-white);flex-shrink:0;transition:all .2s}.db-step-circle.db-step-active,.db-step-circle.db-step-done{border-color:var(--color-deep-spring-green);background:var(--color-deep-spring-green);color:var(--color-deep-green)}.db-step-label{font-size:13px;font-weight:500;color:var(--color-gray);white-space:nowrap}.db-step-label.db-step-label-active{font-weight:700;color:var(--color-deep-green)}.db-step-line{flex:1;height:2px;background:var(--color-border);margin:0 12px;transition:background .2s}.db-step-line.db-step-line-done{background:var(--color-deep-spring-green)}.db-step-content{display:flex;flex-direction:column;gap:18px}.db-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}.db-csv-loading-overlay-full{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#fffffff0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.db-csv-loading-panel{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:420px;padding:36px 40px;text-align:center;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.db-csv-loading-spinner{width:48px;height:48px;border:4px solid rgba(0,230,110,.2);border-top-color:var(--color-deep-spring-green);border-radius:50%;animation:db-spin .75s linear infinite}.db-csv-loading-title{margin:4px 0 0;font-size:18px;color:var(--color-deep-green)}.db-csv-loading-name{margin:0;font-size:13px;font-weight:600;color:var(--color-deep-green);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-csv-loading-sub{margin:0;font-size:13px;color:var(--color-gray);line-height:1.55}.db-drop-zone.db-drop-loading{pointer-events:none;cursor:wait;border-color:var(--color-deep-spring-green)}.db-two-col .db-card{display:flex;flex-direction:column}@media (max-width: 900px){.db-two-col{grid-template-columns:1fr}}.db-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden;padding-bottom:20px}.db-card-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--color-border);font-size:14px;font-weight:600;color:var(--color-deep-green)}.db-card-header-split{justify-content:space-between;gap:12px}.db-card-header-title{display:flex;align-items:center;gap:10px;min-width:0}.db-table-target{padding:18px 20px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:14px}.db-toggle-row{display:flex;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.db-toggle-btn{flex:1;padding:9px 16px;background:var(--color-white);color:var(--color-gray);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all .15s;font-family:var(--font-body)}.db-toggle-btn+.db-toggle-btn{border-left:1.5px solid var(--color-border)}.db-toggle-btn.db-toggle-active{background:var(--color-deep-green);color:var(--color-white)}.db-field{display:flex;flex-direction:column;gap:6px}.db-label{font-size:13px;font-weight:600;color:var(--color-deep-green)}.db-select,.db-input{padding:10px 13px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;color:var(--color-deep-green);background:var(--color-white);font-family:var(--font-body);transition:border-color .18s,box-shadow .18s;width:100%}.db-select:focus,.db-input:focus{outline:none;border-color:var(--color-deep-spring-green);box-shadow:0 0 0 3px #00e66e26}.db-input-error{border-color:#ff4d4f!important;box-shadow:0 0 0 3px #ff4d4f1f!important}.db-error-msg{font-size:12px;color:#ff4d4f}.db-hint{font-size:12px;color:var(--color-gray);display:flex;align-items:center;gap:5px}.db-code{font-family:monospace;padding:1px 6px;border-radius:4px;font-size:14px;color:var(--color-deep-green)}.db-drop-zone{margin:18px 20px 0;border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:32px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .18s;background:var(--color-light-gray);min-height:160px}.db-drop-zone:hover,.db-drop-zone.db-drop-over{border-color:var(--color-deep-spring-green);background:var(--color-soft-green)}.db-drop-zone.db-drop-done{border-color:var(--color-deep-spring-green);border-style:solid;background:var(--color-soft-green)}.db-drop-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--color-deep-spring-green);display:flex;align-items:center;justify-content:center;color:var(--color-deep-green);margin-bottom:4px}.db-drop-text{font-size:14px;font-weight:600;color:var(--color-deep-green)}.db-drop-sub{font-size:12px;color:var(--color-gray)}.db-drop-limit{margin:4px 0 0;font-size:12px;font-weight:600;color:var(--color-deep-green)}.db-drop-note{margin:10px 20px 0;font-size:14px;font-weight:600;color:#cf1322;line-height:1.5;text-align:left}.db-file-success{display:flex;flex-direction:column;align-items:center;gap:6px}.db-file-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-deep-spring-green);display:flex;align-items:center;justify-content:center;color:var(--color-deep-green);margin-bottom:4px}.db-file-name{font-size:14px;font-weight:600;color:var(--color-deep-green)}.db-file-size{font-size:12px;color:var(--color-gray)}.db-change-file{font-size:12px;color:var(--color-deep-spring-green);font-weight:600;margin-top:4px}.db-file-loading{display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}.db-file-loading-spinner{width:40px;height:40px;border:3.5px solid rgba(0,230,110,.2);border-top-color:var(--color-deep-spring-green);border-radius:50%;animation:db-spin .75s linear infinite}.db-file-loading-name{font-size:13px;font-weight:600;color:var(--color-deep-green);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-file-loading-sub{font-size:12px;color:var(--color-gray)}.db-file-error{margin:0 20px 16px;padding:10px 14px;background:#fff1f0;border:1px solid #ffccc7;border-radius:var(--radius-md);color:#cf1322;font-size:13px;display:flex;align-items:center;gap:8px}.db-empty-mapping{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--color-gray);font-size:14px;padding:20px}.db-mapping-table{display:flex;flex-direction:column;flex:1}.db-mapping-header{display:grid;grid-template-columns:1fr 28px 1fr 32px;align-items:center;gap:0;padding:10px 20px;background:var(--color-light-gray);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray);border-bottom:1px solid var(--color-border)}.db-mapping-rows{display:flex;flex-direction:column;max-height:340px;overflow-y:auto}.db-mapping-row{display:grid;grid-template-columns:1fr 28px 1fr 32px;align-items:center;gap:0;padding:11px 20px;border-bottom:1px solid var(--color-border);transition:background .12s}.db-mapping-row:last-child{border-bottom:none}.db-mapping-row:hover{background:#f8fcf9}.db-mapping-error{margin:16px 20px}.db-col-source-name{font-size:13px;font-weight:700;color:var(--color-deep-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-mapping-arrow{font-size:14px;color:var(--color-border);text-align:center}.db-map-select,.db-map-input{width:100%;padding:6px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-body);color:var(--color-gray);background:transparent;transition:border-color .15s,color .15s}.db-map-select:focus,.db-map-input:focus{outline:none;border-color:var(--color-deep-spring-green);color:var(--color-deep-green);background:var(--color-white)}.db-map-input{font-family:monospace}.db-map-remove-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-gray);cursor:pointer;transition:all .15s;margin-left:4px}.db-map-remove-btn:hover{border-color:#ff4d4f;color:#ff4d4f;background:#fff1f0}.db-custom-columns{border-top:1px solid var(--color-border);background:#fafcfb}.db-custom-columns-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-gray)}.db-custom-columns-hint{font-size:12px;font-weight:500;letter-spacing:normal;text-transform:none;color:var(--color-gray);opacity:.85}.db-add-column-btn{padding:6px 12px;font-size:12px;min-height:32px}.db-custom-columns-empty{margin:0;padding:0 20px 16px;font-size:13px;color:var(--color-gray)}.db-custom-columns-table-header,.db-custom-column-row{display:grid;grid-template-columns:1fr 1fr 32px;align-items:center;gap:12px;padding:10px 20px}.db-custom-columns-table-header{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:var(--color-light-gray)}.db-custom-columns-rows{display:flex;flex-direction:column}.db-custom-column-row{border-bottom:1px solid var(--color-border)}.db-custom-column-row:last-child{border-bottom:none}.db-custom-column-row:hover{background:#f8fcf9}.db-removed-columns{padding:12px 20px;border-top:1px solid var(--color-border);background:var(--color-light-gray);display:flex;flex-direction:column;gap:8px}.db-removed-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-gray)}.db-removed-list{display:flex;flex-wrap:wrap;gap:6px}.db-removed-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;border:1px dashed var(--color-border);background:var(--color-white);color:var(--color-gray);font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all .15s}.db-removed-chip:hover{border-color:var(--color-deep-spring-green);color:var(--color-deep-green);background:var(--color-soft-green)}.db-step-footer{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px;padding-top:4px}.db-migrate-overlay-full{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#fffffff0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.db-migrate-overlay-card{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:420px;padding:36px 40px;text-align:center;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.db-migrate-spinner{width:56px;height:56px;border:4px solid rgba(0,230,110,.2);border-top-color:var(--color-deep-spring-green);border-radius:50%;animation:db-spin .75s linear infinite}.db-migrate-overlay-title{margin:4px 0 0;font-size:18px;color:var(--color-deep-green)}.db-migrate-overlay-sub{margin:0;font-size:14px;color:var(--color-gray);line-height:1.5}.db-migrate-overlay-file{margin:0;font-size:13px;font-weight:600;color:var(--color-deep-green);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-preview-hint{flex:1;margin:0;font-size:13px;color:var(--color-gray)}.db-migrate-error{flex:1 1 100%;margin:0 0 4px}.db-preview-header{background:var(--color-soft-green);border:1px solid rgba(0,230,110,.2);border-radius:var(--radius-md);padding:12px 18px}.db-preview-info{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-deep-green)}.db-table-wrap{overflow-x:auto}.db-data-table{width:100%;border-collapse:collapse;font-size:13px}.db-data-table thead th{padding:11px 14px;text-align:left;font-size:12px;font-weight:600;color:var(--color-gray);background:var(--color-light-gray);border-bottom:1px solid var(--color-border);white-space:nowrap;font-family:monospace}.db-data-table tbody tr{border-bottom:1px solid var(--color-border);transition:background .12s}.db-data-table tbody tr:last-child{border-bottom:none}.db-data-table tbody tr:hover{background:#f8fcf9}.db-data-table tbody td{padding:12px 14px;color:var(--color-deep-green);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-spinner{width:16px;height:16px;border:2px solid rgba(0,31,29,.2);border-top-color:var(--color-deep-green);border-radius:50%;animation:db-spin .7s linear infinite;display:inline-block}@keyframes db-spin{to{transform:rotate(360deg)}}.db-success-card{background:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:56px 40px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.db-success-icon{width:80px;height:80px;border-radius:50%;background:var(--color-soft-green);border:3px solid rgba(0,230,110,.3);display:flex;align-items:center;justify-content:center;margin-bottom:8px}.db-success-title{font-size:24px;color:var(--color-deep-green)}.db-success-sub{font-size:15px;color:var(--color-gray);max-width:480px}.db-success-stats{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-top:12px}.db-success-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:18px 24px;border-right:1px solid var(--color-border)}.db-success-stat:last-child{border-right:none}.db-success-stat-val{font-size:22px;font-weight:600;color:var(--color-deep-green)}.db-success-stat-label{font-size:12px;color:var(--color-gray);text-align:center}.db-success-actions{margin-top:8px;display:flex;justify-content:center;gap:10px}.db-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#001f1d80;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:db-overlay-in .15s ease}@keyframes db-overlay-in{0%{opacity:0}to{opacity:1}}.db-backup-modal{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:440px;overflow:hidden;animation:db-modal-in .18s ease}@keyframes db-modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.db-backup-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border)}.db-backup-modal-title{display:flex;align-items:center;gap:10px}.db-backup-modal-title h2{font-size:16px;font-weight:700;color:var(--color-deep-green)}.db-backup-modal-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-soft-green);color:#00924a;display:flex;align-items:center;justify-content:center}.db-modal-close{background:none;border:none;color:var(--color-gray);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s,color .15s}.db-modal-close:hover{background:var(--color-light-gray);color:var(--color-deep-green)}.db-backup-form{display:flex;flex-direction:column;gap:18px;padding:24px}.db-backup-checkbox{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-deep-green);cursor:pointer;-webkit-user-select:none;user-select:none}.db-backup-checkbox input{width:16px;height:16px;accent-color:var(--color-deep-spring-green);cursor:pointer;flex-shrink:0}.db-backup-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:6px;border-top:1px solid var(--color-border);margin-top:4px}.db-backup-success-modal{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:40px 32px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;animation:db-modal-in .18s ease}.db-backup-success-icon{width:72px;height:72px;border-radius:50%;background:var(--color-soft-green);border:3px solid rgba(0,230,110,.3);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.db-backup-success-title{font-size:20px;color:var(--color-deep-green)}.db-backup-success-sub{font-size:14px;color:var(--color-gray);line-height:1.6}.db-backup-success-rows{font-size:14px;color:var(--color-deep-green);margin-top:4px}.db-backup-success-rows strong{color:var(--color-deep-green)}.db-backup-success-note{font-size:13px;color:var(--color-gray);margin-top:2px}.not-found-root{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:32px 20px;background:var(--color-bg)}.not-found-card{width:100%;max-width:420px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:48px 36px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.not-found-icon{width:80px;height:80px;border-radius:50%;background:var(--color-soft-green);border:3px solid rgba(0,230,110,.35);display:flex;align-items:center;justify-content:center;margin-bottom:8px;animation:not-found-icon-in .45s ease-out}@keyframes not-found-icon-in{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.not-found-code{font-family:var(--font-headline);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--color-deep-spring-green);margin:0}.not-found-title{font-size:26px;color:var(--color-deep-green);margin:0}.not-found-sub{font-size:14px;color:var(--color-gray);line-height:1.6;margin:0 0 12px;max-width:300px}.not-found-back-btn{display:inline-flex;align-items:center;gap:8px;min-width:140px;justify-content:center;margin-top:4px}.server-unreachable-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px}.server-unreachable-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#f1f5f4b8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.server-unreachable-dialog{position:relative;z-index:1;width:min(100%,400px);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:36px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.server-unreachable-icon{width:64px;height:64px;border-radius:50%;background:#fff5f5;border:2px solid #FFD6D6;color:#cf1322;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.server-unreachable-title{font-size:22px;color:var(--color-deep-green);margin:0}.server-unreachable-sub{font-size:14px;color:var(--color-gray);margin:0 0 8px;line-height:1.5}.server-unreachable-refresh-btn{min-width:140px;margin-top:4px}
