*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f6ef7;--primary-hover: #3b5de7;--primary-light: #eef1fe;--success: #22c55e;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fffbeb;--danger: #ef4444;--danger-light: #fef2f2;--info: #3b82f6;--info-light: #eff6ff;--cyan: #06b6d4;--purple: #8b5cf6;--bg: #f5f7fa;--bg-white: #ffffff;--border: #e5e7eb;--text: #1f2937;--text-secondary: #6b7280;--text-light: #9ca3af;--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .04);--radius: 8px;--radius-lg: 12px;--sidebar-width: 240px;--sidebar-collapsed: 64px;--topbar-height: 60px;--transition: all .25s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:48px 40px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:24px;color:var(--text);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.login-tabs{display:flex;margin-bottom:24px;border-bottom:2px solid var(--border)}.login-tab{flex:1;padding:10px 0;border:none;background:none;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--transition);position:relative;font-family:inherit}.login-tab:hover{color:var(--text)}.login-tab.active{color:var(--primary)}.login-tab.active:after{content:"";position:absolute;bottom:-2px;left:20%;right:20%;height:2px;background:var(--primary);border-radius:1px}.code-input-row{display:flex;gap:10px}.code-input-row input{flex:1}.send-code-btn{white-space:nowrap;min-width:110px;font-size:13px;background:var(--primary-light);color:var(--primary);border-color:var(--primary-light)}.send-code-btn:hover:not(:disabled){background:var(--primary);color:#fff}.send-code-btn:disabled{background:var(--bg);color:var(--text-light);border-color:var(--border)}.login-form .form-group{margin-bottom:20px}.login-footer{text-align:center;margin-top:24px;color:var(--text-light);font-size:12px}.error-msg{color:var(--danger);font-size:13px;margin-bottom:12px;text-align:center}.admin-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:var(--transition);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{height:var(--topbar-height);display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:18px;font-weight:600;white-space:nowrap}.sidebar-nav{padding:12px 8px}.nav-item{display:flex;align-items:center;padding:10px 16px;color:#ffffffb3;border-radius:var(--radius);margin-bottom:2px;transition:var(--transition);white-space:nowrap;font-size:14px}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:var(--primary);color:#fff}.nav-svg{width:18px;height:18px;flex-shrink:0;fill:currentColor;stroke:currentColor}.nav-item svg.nav-svg{fill:none}.nav-text{margin-left:12px}.nav-group{margin-top:4px}.nav-group-title{cursor:pointer;-webkit-user-select:none;user-select:none}.nav-arrow{width:16px;height:16px;margin-left:auto;transition:transform .25s ease;opacity:.5}.nav-arrow.open{transform:rotate(180deg)}.nav-submenu{overflow:hidden}.nav-item.sub{padding-left:42px;font-size:13px}.nav-item.sub .nav-svg{width:16px;height:16px}.submenu-enter-active,.submenu-leave-active{transition:all .25s ease;max-height:200px}.submenu-enter-from,.submenu-leave-to{max-height:0;opacity:0}.main-area{flex:1;margin-left:var(--sidebar-width);transition:var(--transition)}.sidebar.collapsed~.main-area{margin-left:var(--sidebar-collapsed)}.topbar{height:var(--topbar-height);background:var(--bg-white);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.toggle-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;color:var(--text-secondary)}.toggle-btn:hover{background:var(--bg)}.topbar-right{display:flex;align-items:center;gap:12px}.user-info{color:var(--text);font-weight:500}.role-badge{font-size:12px;padding:2px 8px;background:var(--primary-light);color:var(--primary);border-radius:12px}.logout-btn{background:none;border:1px solid var(--border);padding:6px 16px;border-radius:var(--radius);cursor:pointer;font-size:13px;color:var(--text-secondary);transition:var(--transition)}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.content{padding:24px}.tenant-layout{min-height:100vh;background:var(--bg)}.tenant-header{background:var(--bg-white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;height:var(--topbar-height);gap:24px}.header-left h1{font-size:18px;color:var(--primary)}.tenant-nav{display:flex;gap:4px;flex:1}.tnav-item{padding:8px 16px;color:var(--text-secondary);border-radius:var(--radius);transition:var(--transition);font-size:14px}.tnav-item:hover{background:var(--bg);color:var(--text)}.tnav-item.active{background:var(--primary-light);color:var(--primary);font-weight:500}.header-right{display:flex;align-items:center;gap:12px}.tenant-content{padding:24px;max-width:1200px;margin:0 auto}.page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-title{font-size:22px;font-weight:600;color:var(--text);margin-bottom:24px}.card{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px}.card-title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px;display:flex;align-items:center;gap:16px;transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.stat-card.blue .stat-icon{background:var(--info-light)}.stat-card.green .stat-icon{background:var(--success-light)}.stat-card.orange .stat-icon{background:var(--warning-light)}.stat-card.red .stat-icon{background:var(--danger-light)}.stat-card.purple .stat-icon{background:#f3f0ff}.stat-card.cyan .stat-icon{background:#ecfeff}.stat-value{font-size:24px;font-weight:700;color:var(--text);line-height:1.2}.stat-label{font-size:13px;color:var(--text-secondary);margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.reminder-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.reminder-item:last-child{border-bottom:none}.reminder-label{color:var(--text-secondary)}.reminder-value{font-weight:600}.reminder-value.warning{color:var(--warning)}.reminder-value.danger{color:var(--danger)}.occupancy-item{margin-bottom:16px}.occupancy-item:last-child{margin-bottom:0}.occupancy-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.progress-bar{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--success) 100%);border-radius:4px;transition:width .5s ease}.info-row{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.info-row:last-child{border-bottom:none}.info-label{font-weight:500}.empty-text{color:var(--text-light);text-align:center;padding:24px 0}.form-group{margin-bottom:16px;flex:1}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--bg-white);transition:var(--transition);font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f6ef71a}.form-group input:disabled{background:var(--bg);color:var(--text-light)}.form-group textarea{resize:vertical}.form-row{display:flex;gap:16px}.checkbox-label{display:flex!important;align-items:center;gap:8px;font-size:13px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);background:var(--bg-white);color:var(--text);gap:6px;white-space:nowrap;font-family:inherit}.btn:hover{background:var(--bg)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success);border-color:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-warning{background:var(--warning);border-color:var(--warning);color:#fff}.btn-warning:hover{opacity:.9}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:4px 10px;font-size:12px;height:32px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.btn-block{width:100%;padding:12px;font-size:16px}.data-table-wrapper{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.search-input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;min-width:180px;transition:var(--transition);font-family:inherit}.search-input:focus{outline:none;border-color:var(--primary)}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;table-layout:fixed}.data-table th,.data-table td{word-wrap:break-word}.data-table th{background:var(--bg);padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;vertical-align:middle;height:40px}.data-table th:last-child{text-align:center}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px;white-space:nowrap;vertical-align:middle;height:48px}.data-table td.action-cell{padding:12px 16px;text-align:center;height:48px}.data-table tbody tr{height:48px}.data-table tbody tr:hover{background:var(--bg)}.data-table tbody tr:last-child td{border-bottom:none}.table-loading,.table-empty{text-align:center;padding:48px 16px!important;color:var(--text-light);font-size:14px}.action-cell{display:flex;gap:6px;justify-content:center;align-items:center;height:48px}.data-table td.action-cell{padding:0 16px;text-align:center;height:48px;vertical-align:middle}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border)}.page-info{font-size:13px;color:var(--text-secondary)}.page-btns{display:flex;gap:8px}.page-btns button{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-white);cursor:pointer;font-size:13px;transition:var(--transition);font-family:inherit}.page-btns button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btns button:disabled{opacity:.4;cursor:not-allowed}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.badge-success{background:var(--success-light);color:#15803d}.badge-warning{background:var(--warning-light);color:#b45309}.badge-danger{background:var(--danger-light);color:#dc2626}.badge-info{background:var(--info-light);color:#2563eb}.badge-primary{background:var(--primary-light);color:var(--primary)}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.dialog{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0003;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.dialog-header h3{font-size:18px;font-weight:600}.dialog-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-light);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition)}.dialog-close:hover{background:var(--bg);color:var(--text)}.dialog-body{padding:24px;overflow-y:auto}.dialog-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px}@media (max-width: 768px){.sidebar{width:var(--sidebar-collapsed)}.sidebar .nav-text{display:none}.main-area{margin-left:var(--sidebar-collapsed)}.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.table-toolbar{flex-direction:column;align-items:stretch}.search-input{min-width:100%}.tenant-header{flex-wrap:wrap;height:auto;padding:12px 16px}.tenant-nav{order:3;width:100%;overflow-x:auto}}.perm-tabs{display:flex;gap:8px;margin-bottom:20px}.perm-tab{padding:10px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-white);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);font-family:inherit}.perm-tab:hover{border-color:var(--primary);color:var(--primary)}.perm-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.perm-content{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px}.perm-module{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.perm-module:last-of-type{border-bottom:none;margin-bottom:0}.perm-module-header{margin-bottom:12px}.module-checkbox{font-weight:600;font-size:15px}.module-name{margin-left:4px}.perm-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px 16px;padding-left:24px}.perm-item{font-size:13px;color:var(--text-secondary);padding:4px 0}.perm-item input:checked+span{color:var(--text)}.perm-actions{margin-top:24px;padding-top:20px;border-top:1px solid var(--border);display:flex;gap:12px}.sms-config-form{max-width:700px}.form-hint{display:block;font-size:12px;color:var(--text-light);margin-top:4px}.form-actions{display:flex;gap:12px;margin-top:8px}.switch-row{display:flex;align-items:center;gap:12px}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;border-radius:24px;transition:var(--transition)}.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:var(--transition)}.switch input:checked+.slider{background:var(--success)}.switch input:checked+.slider:before{transform:translate(20px)}.text-success{color:var(--success);font-weight:500}.text-muted{color:var(--text-light)}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.template-list{display:flex;flex-direction:column;gap:12px}.template-item{border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:var(--transition)}.template-item:hover{border-color:var(--primary)}.template-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.template-info{display:flex;align-items:center;gap:8px}.template-name{font-weight:600;font-size:15px}.template-actions{display:flex;gap:6px}.template-body{font-size:13px;color:var(--text-secondary)}.template-field{margin-bottom:4px;display:flex;align-items:flex-start;gap:4px}.field-label{color:var(--text-light);white-space:nowrap;flex-shrink:0}.template-field code{background:var(--bg);padding:1px 6px;border-radius:4px;font-size:12px}.var-tags{display:flex;flex-wrap:wrap;gap:4px}.oss-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}.oss-toolbar-left,.oss-toolbar-right{display:flex;align-items:center;gap:8px}.oss-breadcrumb{display:flex;align-items:center;padding:8px 0;margin-bottom:8px;font-size:13px;border-bottom:1px solid var(--border)}.crumb{color:var(--primary);cursor:pointer;padding:2px 4px;border-radius:4px}.crumb:hover{background:var(--primary-light)}.crumb-sep{color:var(--text-light);margin:0 2px}.oss-list{min-height:200px}.oss-item{display:flex;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);gap:10px;font-size:14px;transition:var(--transition)}.oss-item:last-child{border-bottom:none}.oss-item:hover{background:var(--bg)}.oss-item.folder{cursor:default}.oss-item.folder:hover{background:var(--primary-light)}.oss-item-click{display:flex;align-items:center;gap:10px;flex:1;cursor:pointer;overflow:hidden}.oss-item-icon{width:20px;height:20px;flex-shrink:0;color:var(--text-secondary)}.oss-item.folder .oss-item-icon{color:var(--warning)}.oss-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.oss-item-size{color:var(--text-secondary);font-size:12px;min-width:70px;text-align:right}.oss-item-date{color:var(--text-light);font-size:12px;min-width:140px}.oss-item-actions{display:flex;gap:4px;flex-shrink:0}.upload-btn{position:relative;cursor:pointer}.upload-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000}.upload-box{background:var(--bg-white);padding:32px 40px;border-radius:var(--radius-lg);min-width:360px;text-align:center}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.device-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;justify-content:space-between;transition:var(--transition)}.device-card:hover{border-color:var(--primary)}.device-name{font-weight:600;font-size:14px}.device-serial{font-size:12px;color:var(--text-light);margin-top:2px}.device-status{margin-top:6px}.toggle-text{font-size:13px;color:var(--primary)}.oss-image-upload{display:inline-block}.image-preview{position:relative;width:100px;height:100px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.image-preview img{width:100%;height:100%;object-fit:cover}.image-preview .remove-btn{position:absolute;top:2px;right:2px;width:22px;height:22px;background:#00000080;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1}.image-preview .remove-btn:hover{background:var(--danger)}.upload-area{display:flex;align-items:center;justify-content:center;width:100px;height:100px;border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition)}.upload-area:hover{border-color:var(--primary);color:var(--primary)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px;color:var(--text-light)}.multi-image-list{display:flex;flex-wrap:wrap;gap:8px}.multi-image-list .image-preview,.multi-image-list .upload-area{width:80px;height:80px}.fee-inputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:12px}.fee-input-item label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.fee-input-item input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;transition:var(--transition)}.fee-input-item input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f6ef71a}.multi-select-box{border:1px solid var(--border);border-radius:var(--radius);padding:10px}.multi-select-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:8px}.checkbox-grid{display:flex;flex-wrap:wrap;gap:4px}.checkbox-item{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:4px;font-size:13px;cursor:pointer;transition:var(--transition)}.checkbox-item:hover{background:var(--bg)}.checkbox-item.checked{background:var(--primary-light);color:var(--primary)}.room-select-area{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);padding:12px}.room-select-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.select-count{font-size:13px;color:var(--primary);font-weight:500}.room-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:4px;max-height:240px;overflow-y:auto}.room-checkbox-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:4px;font-size:13px;cursor:pointer;transition:var(--transition)}.room-checkbox-item:hover{background:var(--bg)}.room-checkbox-item.checked{background:var(--primary-light);color:var(--primary)}.table-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid var(--border);display:block;margin:0 auto}
