*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f7fa;color:#333}.loading{text-align:center;padding:50px;color:#666}.page-container{min-height:100vh;background:#f5f7fa}.card{background:#ffffff;border-radius:12px;padding:20px;margin:16px;box-shadow:0 2px 12px #0000000a}.btn{padding:12px 24px;border-radius:6px;border:none;font-size:14px;cursor:pointer}.btn-primary{background:#1890ff;color:#fff}.btn-secondary{background:#f0f0f0;color:#333}.list{display:flex;flex-direction:column}.list-item{display:flex;align-items:center;padding:20px;background:white;border-radius:8px;margin:8px 16px;box-shadow:0 2px 8px #0000000a}.login-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.logo-area{text-align:center;margin-bottom:60px}.logo{width:120px;height:120px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 30px;box-shadow:0 8px 32px #0000001a}.logo-icon{font-size:60px}.title{color:#fff;font-size:36px;font-weight:700;margin-bottom:12px}.subtitle{color:#fffc;font-size:16px}.form-area{width:100%;max-width:400px}.input-group{position:relative;margin-bottom:24px}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px;color:#666}.input{width:100%;padding:16px 20px 16px 56px;border:none;border-radius:12px;font-size:16px;background:white;box-shadow:0 4px 16px #0000001a;transition:all .3s ease}.input:focus{outline:none;box-shadow:0 4px 20px #00000026}.login-btn{width:100%;padding:16px;background:#ff6b6b;color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #ff6b6b4d}.login-btn:hover{background:#ff5252;transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.fans-container{padding:20px;background:#f5f7fa;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:24px 20px;border-radius:16px;margin-bottom:24px;box-shadow:0 8px 30px #667eea40;position:relative;overflow:hidden}.header:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{transform:translate(0)}50%{transform:translate(-20px)}}.header-info{display:flex;flex-direction:column;position:relative;z-index:1}.welcome{font-size:14px;color:#ffffffd9;font-weight:500;margin-bottom:4px}.username{font-size:22px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.1)}.logout-btn{padding:10px 20px;background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:1}.logout-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stats-bar{display:flex;background:white;border-radius:16px;margin-bottom:24px;padding:24px;box-shadow:0 4px 20px #0000000f}.stat-item{flex:1;text-align:center;position:relative}.stat-item:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:60%;width:1px;background:#f0f0f0}.stat-value{display:block;font-size:32px;font-weight:800;color:#1890ff;margin-bottom:8px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-value.running{color:#52c41a;background:linear-gradient(135deg,#52c41a 0%,#389e0d 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-value.stopped{color:#ff4d4f;background:linear-gradient(135deg,#ff4d4f 0%,#cf1322 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-value.maintenance{color:#faad14;background:linear-gradient(135deg,#faad14 0%,#d48806 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:14px;color:#999;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.section-title{margin:24px 0 16px;padding:0 4px}.title-text{font-size:22px;font-weight:700;color:#333;position:relative;display:inline-block}.title-text:after{content:"";position:absolute;bottom:-8px;left:0;width:40px;height:4px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:2px}.fans-list{display:flex;flex-direction:column;gap:12px}.fan-card{background:white;border-radius:12px;padding:16px;box-shadow:0 2px 12px #0000000a;position:relative;overflow:hidden}.fan-row{display:flex;align-items:center}.fan-info{margin-left:16px;flex:1}.fan-name{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.fan-speed-mini{font-size:14px;color:#666}.fan-status-bar{position:absolute;left:0;top:0;width:4px;height:100%}.fan-status-bar.running{background:#52c41a}.fan-status-bar.stopped{background:#ff4d4f}.fan-status-bar.maintenance{background:#faad14}.fan-icon-small{width:48px;height:48px;position:relative;display:flex;align-items:center;justify-content:center}.fan-blades-small{width:100%;height:100%;position:relative}.blade-mini{position:absolute;width:6px;height:20px;background:#1890ff;border-radius:3px;top:4px;left:50%;transform-origin:center 20px;transform:translate(-50%)}.blade-mini:nth-child(1){transform:translate(-50%) rotate(0)}.blade-mini:nth-child(2){transform:translate(-50%) rotate(120deg)}.blade-mini:nth-child(3){transform:translate(-50%) rotate(240deg)}.fan-center-mini{width:8px;height:8px;background:#1890ff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spinning .fan-blades-small{animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-container{padding:20px;background:#f5f7fa;min-height:100vh}.detail-header{display:flex;align-items:center;background:white;padding:20px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 12px #0000000a}.back-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:15px;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;position:relative;overflow:hidden}.back-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.back-btn:hover:before{left:100%}.back-btn:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.back-btn-header{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:15px;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;position:relative;overflow:hidden}.back-btn-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.back-btn-header:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.back-btn-header:hover:before{left:100%}.back-btn-header:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.detail-title{font-size:24px;font-weight:600;color:#333}.detail-content{display:flex;flex-direction:column;gap:20px}.fan-info-section{background:white;border-radius:12px;padding:40px;text-align:center;box-shadow:0 2px 12px #0000000a}.fan-circle{width:200px;height:200px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;margin:0 auto 30px;position:relative;box-shadow:0 8px 32px #0000001a}.fan-icon{width:80%;height:80%;position:relative;display:flex;align-items:center;justify-content:center}.fan-blades{width:100%;height:100%;position:relative}.blade{position:absolute;width:16px;height:60px;background:white;border-radius:8px;top:20px;left:50%;transform-origin:center 60px;transform:translate(-50%);box-shadow:0 2px 8px #0000001a}.blade:nth-child(1){transform:translate(-50%) rotate(0)}.blade:nth-child(2){transform:translate(-50%) rotate(120deg)}.blade:nth-child(3){transform:translate(-50%) rotate(240deg)}.fan-center{width:20px;height:20px;background:white;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000001a}.spinning .fan-blades{animation:spin 2s linear infinite}.fan-details{display:flex;flex-direction:column;gap:16px;margin-top:20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-label{font-size:16px;color:#666}.info-value{font-size:16px;font-weight:600;color:#333}.info-value.running{color:#52c41a}.info-value.stopped{color:#ff4d4f}.control-section{background:white;border-radius:12px;padding:30px;box-shadow:0 2px 12px #0000000a}.control-btn{width:100%;padding:16px;border:none;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;margin-bottom:30px;transition:all .3s ease}.control-btn.primary{background:#52c41a;color:#fff}.control-btn.danger{background:#ff4d4f;color:#fff}.control-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.slider-section{display:flex;flex-direction:column;gap:16px}.slider-label{font-size:16px;font-weight:600;color:#333;text-align:center}.speed-slider{width:100%;height:8px;border-radius:4px;background:#f0f0f0;outline:none;-webkit-appearance:none}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#1890ff;cursor:pointer;box-shadow:0 2px 8px #00000026}.speed-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#1890ff;cursor:pointer;border:none;box-shadow:0 2px 8px #00000026}.speed-value{text-align:center;font-size:18px;font-weight:600;color:#1890ff}.groups-list{display:flex;flex-direction:column;gap:16px;padding:0 20px 20px}.group-card{background:white;border-radius:16px;padding:20px;box-shadow:0 4px 20px #0000000f;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.group-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.group-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.group-row{display:flex;align-items:center;margin-bottom:16px}.group-icon{width:56px;height:56px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-right:16px;box-shadow:0 4px 12px #667eea4d}.group-icon-text{font-size:28px}.group-info{flex:1}.group-name{font-size:18px;font-weight:700;color:#333;margin-bottom:6px}.group-desc{font-size:14px;color:#666}.group-arrow{font-size:24px;color:#ccc;font-weight:300;transition:transform .3s ease}.group-card:hover .group-arrow{transform:translate(4px);color:#667eea}.group-status-bar{display:flex;justify-content:space-around;background:#f8f9fa;border-radius:10px;padding:14px;margin-top:8px}.status-item{display:flex;flex-direction:column;align-items:center;gap:4px}.status-label{font-size:12px;color:#999;font-weight:500}.status-value{font-size:18px;font-weight:700;color:#333}.status-value.running{color:#52c41a}.status-value.stopped{color:#ff4d4f}.empty-state{text-align:center;padding:60px 20px;color:#999;font-size:16px}.empty-state:before{content:"📭";display:block;font-size:64px;margin-bottom:16px;opacity:.5}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{text-align:center;color:#667eea;font-size:18px;font-weight:600}.loading-spinner:before{content:"";display:block;width:48px;height:48px;border:4px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;margin:0 auto 16px;animation:spin 1s linear infinite}@media (max-width: 768px){.group-card{padding:16px}.group-icon{width:48px;height:48px}.group-icon-text{font-size:24px}.group-name{font-size:16px}.group-desc{font-size:13px}.status-value{font-size:16px}.status-label{font-size:11px}}.wx-flex{display:flex}.wx-row{display:flex;flex-direction:row}.wx-col{display:flex;flex-direction:column}.wx-center{display:flex;justify-content:center;align-items:center}.wx-text-center{text-align:center}.wx-text-left{text-align:left}.wx-text-right{text-align:right}.wx-mt-1{margin-top:8rpx}.wx-mt-2{margin-top:16rpx}.wx-mt-3{margin-top:24rpx}.wx-mb-1{margin-bottom:8rpx}.wx-mb-2{margin-bottom:16rpx}.wx-mb-3{margin-bottom:24rpx}.wx-ml-1{margin-left:8rpx}.wx-ml-2{margin-left:16rpx}.wx-ml-3{margin-left:24rpx}.wx-mr-1{margin-right:8rpx}.wx-mr-2{margin-right:16rpx}.wx-mr-3{margin-right:24rpx}.wx-p-1{padding:8rpx}.wx-p-2{padding:16rpx}.wx-p-3{padding:24rpx}.wx-text-primary{color:#1890ff}.wx-text-success{color:#52c41a}.wx-text-warning{color:#faad14}.wx-text-error{color:#ff4d4f}.wx-text-muted{color:#999}.wx-w-full{width:100%}.wx-h-full{height:100%}.wx-flex-1{flex:1}@media (max-width: 768px){.card{margin:8rpx;padding:16rpx}}
