:root{--color-primary: #059669;--color-primary-light: #10b981;--color-primary-lighter: #34d399;--color-primary-dark: #047857;--color-primary-darker: #065f46;--color-primary-bg: #ecfdf5;--color-primary-bg-light: #f0fdf4;--gradient-primary: linear-gradient(135deg, #059669 0%, #10b981 50%, #34d399 100%);--gradient-primary-dark: linear-gradient(135deg, #047857 0%, #059669 100%);--gradient-hero: linear-gradient(160deg, #ecfdf5 0%, #d1fae5 40%, #a7f3d0 100%);--gradient-card: linear-gradient(135deg, #f0fdf4 0%, #ecfdf5 50%, #d1fae5 100%);--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-info: #0ea5e9;--color-info-light: #e0f2fe;--text-primary: #111827;--text-secondary: #4b5563;--text-tertiary: #9ca3af;--text-placeholder: #c4c4cd;--text-inverse: #ffffff;--text-link: #059669;--bg-page: #f0fdf4;--bg-white: #ffffff;--bg-card: #ffffff;--bg-hover: #f0fdf4;--bg-active: #d1fae5;--bg-sidebar: #022c22;--bg-sidebar-hover: #064e3b;--bg-sidebar-active: #065f46;--glass-bg: rgba(255, 255, 255, .72);--glass-border: rgba(5, 150, 105, .12);--glass-shadow: 0 8px 32px rgba(5, 150, 105, .06);--border-color: #d1fae5;--border-color-light: #e5e7eb;--border-radius-sm: 6px;--border-radius: 10px;--border-radius-lg: 14px;--border-radius-xl: 20px;--border-radius-2xl: 28px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--font-xs: 10px;--font-sm: 12px;--font-base: 14px;--font-md: 16px;--font-lg: 18px;--font-xl: 20px;--font-2xl: 24px;--font-3xl: 30px;--font-hero: 36px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;--shadow-sm: 0 1px 2px rgba(5, 150, 105, .04);--shadow: 0 1px 3px rgba(5, 150, 105, .06), 0 1px 2px rgba(5, 150, 105, .04);--shadow-md: 0 4px 12px rgba(5, 150, 105, .08);--shadow-lg: 0 10px 30px rgba(5, 150, 105, .1);--shadow-card: 0 2px 8px rgba(5, 150, 105, .06);--shadow-card-hover: 0 8px 24px rgba(5, 150, 105, .12);--shadow-button: 0 4px 14px rgba(5, 150, 105, .25);--transition-fast: .15s ease;--transition: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--admin-sidebar-width: 240px;--header-height: 60px;--content-max-width: 1200px;--mobile-max-width: 480px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}@media (min-width: 1024px){:root{--font-xs: 11px;--font-sm: 13px;--font-base: 15px;--font-md: 17px;--font-lg: 20px;--font-xl: 22px;--font-2xl: 28px;--font-3xl: 34px;--font-hero: 42px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:calc(100vw / 23.4375);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--text-primary);background:var(--bg-page);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}a{color:var(--text-link);text-decoration:none}img{max-width:100%;height:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-primary-lighter);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}@media (min-width: 1024px){html{font-size:16px}body{background:var(--bg-page)}.app-layout{display:flex;min-height:100vh;width:100%}.app-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);color:var(--text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;overflow-x:hidden;box-shadow:2px 0 20px #00000014}.app-main{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;background:var(--bg-page)}.app-main-content{flex:1;padding:var(--spacing-lg);max-width:var(--content-max-width);width:100%;margin:0 auto}.mobile-only{display:none!important}button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}button:active{transform:translateY(0)}.card-hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}}@media (max-width: 1023px){.pc-only{display:none!important}body{padding-bottom:50px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeInUp{animation:fadeInUp var(--transition-slow) ease forwards}.animate-fadeIn{animation:fadeIn var(--transition-slow) ease forwards}.animate-scaleIn{animation:scaleIn var(--transition-slow) ease forwards}.animate-slideInLeft{animation:slideInLeft var(--transition-slow) ease forwards}.animate-slideInRight{animation:slideInRight var(--transition-slow) ease forwards}.stagger-1{animation-delay:.05s;opacity:0}.stagger-2{animation-delay:.1s;opacity:0}.stagger-3{animation-delay:.15s;opacity:0}.stagger-4{animation-delay:.2s;opacity:0}.stagger-5{animation-delay:.25s;opacity:0}.stagger-6{animation-delay:.3s;opacity:0}.stagger-7{animation-delay:.35s;opacity:0}.stagger-8{animation-delay:.4s;opacity:0}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--border-radius-lg);box-shadow:var(--glass-shadow)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:10px 24px;background:var(--gradient-primary);color:var(--text-inverse);border:none;border-radius:var(--border-radius);font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-button);white-space:nowrap}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #05966959}.btn-primary:active{transform:translateY(0)}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:10px 24px;background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:var(--border-radius);font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-outline:hover{background:var(--color-primary-bg);transform:translateY(-1px)}.badge{display:inline-flex;align-items:center;padding:2px 10px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:9999px;font-size:var(--font-xs);font-weight:500}.badge-success{background:var(--color-success-light);color:var(--color-success)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.status-dot.online{background:var(--color-success);box-shadow:0 0 6px #10b98180}.status-dot.offline{background:var(--text-tertiary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--text-tertiary);text-align:center}.empty-state .icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state .title{font-size:var(--font-md);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.skeleton{background:linear-gradient(90deg,var(--color-primary-bg) 25%,var(--color-primary-bg-light) 50%,var(--color-primary-bg) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--border-radius-sm)}.divider{height:1px;background:var(--border-color);margin:var(--spacing) 0}:root{--van-primary-color: var(--color-primary);--van-success-color: var(--color-success);--van-warning-color: var(--color-warning);--van-danger-color: var(--color-danger);--van-text-color: var(--text-primary);--van-text-color-2: var(--text-secondary);--van-text-color-3: var(--text-tertiary);--van-background: var(--bg-page);--van-background-2: var(--bg-white);--van-border-color: var(--border-color)}.van-nav-bar{--van-nav-bar-background: var(--bg-white);--van-nav-bar-title-text-color: var(--text-primary);border-bottom:1px solid var(--border-color)}.van-tab--active{--van-tab-active-text-color: var(--color-primary)}.van-tabs__line{background:var(--color-primary)!important}.van-button--primary{--van-button-primary-background: var(--gradient-primary);--van-button-primary-border-color: var(--color-primary)}.van-search__action,.van-tabbar-item--active{color:var(--color-primary)!important}.admin-theme .van-nav-bar{--van-nav-bar-background: #1d4ed8;--van-nav-bar-title-text-color: #ffffff;--van-nav-bar-text-color: #ffffff;--van-nav-bar-icon-color: #ffffff}.admin-theme .van-tab--active{--van-tab-active-text-color: #2563eb}.admin-theme .van-tabs__line{background:#2563eb!important}.admin-theme .van-button--primary{--van-button-primary-background: linear-gradient(135deg, #1d4ed8, #2563eb);--van-button-primary-border-color: #2563eb}.van-toast{border-radius:12px!important;padding:14px 28px!important;font-size:14px!important;font-weight:500!important;box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f,inset 0 -1px #0000000a!important;max-width:340px!important;word-break:break-word;user-select:none;-webkit-user-select:none;border:none!important}.van-toast--text{padding:10px 24px!important;font-size:13px!important}.van-toast--icon{flex-direction:row!important;min-width:auto!important;width:auto!important;gap:8px!important;justify-content:center!important}.van-toast .van-toast__icon{font-size:18px!important;margin-right:0!important;line-height:1!important;display:flex!important;align-items:center!important}.van-toast .van-toast__text{line-height:1.5!important;letter-spacing:.3px;white-space:nowrap}.van-dialog{border-radius:20px!important;overflow:hidden;background:#fff!important;box-shadow:0 20px 60px #0000002e,0 4px 16px #0000000f!important;animation:dialogScaleIn .25s cubic-bezier(.34,1.56,.64,1);max-width:360px!important}@keyframes dialogScaleIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.van-overlay{backdrop-filter:blur(4px) saturate(120%);-webkit-backdrop-filter:blur(4px) saturate(120%);background:#00000059!important;animation:fadeIn .2s ease-out}.van-dialog__header{padding:26px 24px 6px!important;font-size:18px!important;font-weight:700!important;color:#1a1a2e!important;text-align:center;letter-spacing:-.2px}.van-dialog__message{padding:10px 24px 6px!important;font-size:14px!important;line-height:1.7!important;color:#5a5a72!important;text-align:center}.van-dialog__footer{border-top:none!important;padding:8px 20px 22px!important;display:flex;gap:12px!important}.van-dialog__footer .van-button{flex:1;height:44px!important;border-radius:11px!important;font-size:14px!important;font-weight:600!important;transition:all .2s ease!important}.van-dialog__cancel{color:#6b7280!important;background:#f3f4f6!important;border:1px solid #e5e7eb!important}.van-dialog__cancel:hover,.van-dialog__cancel:active{background:#e9eaef!important;transform:translateY(-1px)}.van-dialog__confirm{color:#fff!important;background:linear-gradient(135deg,#059669,#10b981)!important;border:none!important;box-shadow:0 4px 14px #05966959}.van-dialog__confirm:hover,.van-dialog__confirm:active{transform:translateY(-1px);box-shadow:0 6px 18px #05966973}.dialog-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;margin:0 auto 16px;font-size:26px;line-height:1;background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#059669;box-shadow:0 4px 12px #05966926}.dialog-icon-wrap.dialog-icon--danger{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;box-shadow:0 4px 12px #dc262626;animation:iconShake .5s ease-in-out}@keyframes iconShake{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}.dialog-icon-wrap.dialog-icon--success{background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#059669}.dialog-body-text{text-align:center;font-size:14.5px;line-height:1.7;color:#555;padding:0 4px}.dialog-body-text--success{color:#059669!important;font-weight:600;font-size:15px}.custom-dialog--danger .van-dialog__confirm{background:linear-gradient(135deg,#dc2626,#ef4444)!important;box-shadow:0 4px 14px #dc262659}.custom-dialog--danger .van-dialog__confirm:hover,.custom-dialog--danger .van-dialog__confirm:active{box-shadow:0 6px 18px #dc262673}.custom-dialog--success-alert .van-dialog__confirm{background:linear-gradient(135deg,#059669,#10b981)!important;box-shadow:0 4px 14px #05966959}
