.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background-color:#fff;border-top:1px solid #e0e0e0;display:flex;justify-content:space-around;align-items:center;z-index:1000;box-shadow:0 -2px 10px #0000000d}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:none;border:none;cursor:pointer;color:#666;transition:color .2s;min-width:44px;min-height:44px;padding:8px}.nav-item:active{background-color:#f5f5f5}.nav-item.active{color:#1976d2}.nav-icon{font-size:24px;margin-bottom:4px}.nav-label{font-size:12px;font-weight:500}@media (min-width: 768px){.bottom-nav{max-width:768px;left:50%;transform:translate(-50%)}}.mobile-layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f5f5}.mobile-content{flex:1;padding-bottom:60px;overflow-y:auto}@media (min-width: 768px){.mobile-layout{max-width:768px;margin:0 auto;box-shadow:0 0 10px #0000001a}}.page-header{background-color:#1976d2;color:#fff;padding:6px 16px;min-height:56px;box-sizing:border-box;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:8px;position:fixed;top:0;left:0;right:0;z-index:100}.page-header h1{margin:0;font-size:16px;font-weight:600}.back-btn{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;padding:4px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.back-btn:active{opacity:.7}.header-title{display:flex;flex-direction:column;justify-content:center}.header-subtitle{margin:2px 0 0;font-size:13px;opacity:.85;font-weight:400}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.status-online{background-color:#e8f5e9;color:#2e7d32}.status-badge.status-offline{background-color:#ffebee;color:#c62828}.status-badge.status-maintenance{background-color:#fff3e0;color:#ef6c00}.status-badge.status-unknown{background-color:#f5f5f5;color:#666}.loading,.error{padding:40px 16px;text-align:center;color:#666}.error p{margin-bottom:16px}.retry-btn{padding:10px 24px;background-color:#1976d2;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;min-width:44px;min-height:44px}.retry-btn:active{background-color:#1565c0}.user-list-page{height:100vh;background-color:#f5f5f5;padding-top:56px;overflow-y:auto;box-sizing:border-box}.user-list{padding:16px}.user-card{background-color:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:transform .2s,box-shadow .2s;min-height:44px}.user-card:active{transform:scale(.98);box-shadow:0 1px 4px #0000001f}.user-info{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;gap:8px}.user-name{font-size:15px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;max-width:50%}.user-email{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;flex:1;min-width:0}.user-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;padding:10px 0;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0}.user-stats .stat-item{display:flex;flex-direction:column;align-items:center;min-width:0}.user-stats .stat-label{font-size:11px;color:#999;margin-bottom:3px;white-space:nowrap}.user-stats .stat-value{font-size:13px;font-weight:600;color:#333;text-align:center;word-break:break-all;line-height:1.3;max-width:100%}.user-status{display:flex;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 16px}.stat-card{background-color:#fff;border-radius:10px;padding:10px 8px;box-shadow:0 2px 6px #00000012;display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:11px;color:#999;margin-bottom:4px;white-space:nowrap}.stat-value{font-size:16px;font-weight:700;color:#1565c0;white-space:nowrap;line-height:1.2}.stat-sub{font-size:10px;color:#aaa;margin-top:2px;white-space:nowrap}.invest-card{margin:0 16px 16px;background:linear-gradient(135deg,#1a237e,#283593);border-radius:12px;padding:16px;color:#fff}.invest-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.invest-title{font-size:14px;opacity:.9}.invest-ratio{font-size:24px;font-weight:700}.invest-progress-bar{height:6px;background:#fff3;border-radius:3px;margin-bottom:14px;overflow:hidden}.invest-progress-fill{height:100%;background:linear-gradient(90deg,#4fc3f7,#81d4fa);border-radius:3px;transition:width .6s ease}.invest-details{display:flex;justify-content:space-between}.invest-item{display:flex;flex-direction:column;gap:2px}.invest-label{font-size:12px;opacity:.7}.invest-amount{font-size:15px;font-weight:600}.section-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#333}.plant-table{display:flex;flex-direction:column;gap:12px}.plant-row{background-color:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:transform .2s,box-shadow .2s}.plant-row:active{transform:scale(.98);box-shadow:0 1px 4px #0000001f}.plant-row-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.plant-name{font-size:15px;font-weight:600;color:#222;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:8px}.plant-row-top .status-badge{padding:2px 10px;border-radius:10px}.plant-row-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:8px}.metric-item{display:flex;flex-direction:column;align-items:center;text-align:center}.metric-value{font-size:15px;font-weight:600;color:#1565c0;line-height:1.3}.metric-value small{font-size:11px;font-weight:400;color:#555}.metric-label{font-size:11px;color:#999;margin-top:2px}.plant-row-bottom{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #f0f0f0;padding-top:6px}.plant-capacity{font-size:12px;color:#aaa}.plant-arrow{font-size:20px;color:#ccc}.empty-state{padding:40px 16px;text-align:center;color:#999;font-size:14px}.user-dashboard-page{min-height:100vh;background-color:#f5f5f5;padding-top:56px}.plants-section{padding:0 16px 16px}.plant-detail-page{min-height:100vh;background-color:#f5f5f5;padding-top:56px}.plant-info-card{background-color:#fff;margin:16px;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.plant-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.plant-title h2{margin:0;font-size:20px;font-weight:600;color:#333}.plant-title .status-badge{padding:6px 16px;border-radius:16px;font-size:14px}.plant-details{display:flex;flex-direction:column;gap:12px}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:14px;color:#999}.detail-value{font-size:14px;font-weight:500;color:#333;text-align:right}.load-rate-card{margin:16px 0 0;background:linear-gradient(135deg,#1a237e,#283593);border-radius:12px;padding:16px;color:#fff}.load-rate-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.load-rate-title{font-size:14px;opacity:.9}.load-rate-ratio{font-size:24px;font-weight:700}.load-rate-progress-bar{height:6px;background:#fff3;border-radius:3px;margin-bottom:14px;overflow:hidden}.load-rate-progress-fill{height:100%;background:linear-gradient(90deg,#4fc3f7,#81d4fa);border-radius:3px;transition:width .6s ease}.load-rate-details{display:flex;justify-content:space-between}.load-rate-item{display:flex;flex-direction:column;gap:2px}.load-rate-label{font-size:12px;opacity:.7}.load-rate-value{font-size:15px;font-weight:600}.power-data-section{padding:0 16px 16px}.power-data-section .section-title{margin:16px 0 12px;font-size:16px}.report-page{min-height:100%;padding:16px;background:#f5f7fb}.report-page__container{width:100%;max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.report-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.report-page__header h1{margin:0;font-size:28px;color:#16233b}.report-page__header p{margin:6px 0 0;color:#667085}.report-surface-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 10px 30px #1f293714}.report-hero-card{color:#fff;border-radius:16px;padding:18px;background:linear-gradient(135deg,#0f3d91,#1c64f2 55%,#5b8def);box-shadow:0 12px 28px #1c64f23d}.report-section-eyebrow{margin:0 0 6px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#ffffffb8}.report-hero-card__header h2{margin:0;font-size:24px;line-height:1.2}.report-hero-card__subtitle{margin:6px 0 0;font-size:13px;color:#ffffffd1}.report-hero-card__metrics{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.report-hero-card--overview .report-hero-card__metrics{grid-template-columns:1fr}@media (min-width: 360px){.report-hero-card--overview .report-hero-card__metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 768px){.report-hero-card--overview .report-hero-card__metrics{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1280px){.report-hero-card--overview .report-hero-card__metrics{grid-template-columns:repeat(4,minmax(0,1fr))}}.report-hero-card__metric{padding:12px;border-radius:12px;background:#ffffff1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.report-hero-card__label,.report-hero-card__helper,.report-card-header p,.report-user-quick-filter__header p,.report-filter-card__header p,.report-list-card__top p,.report-list-card__meta-item span,.report-empty-state p{color:#667085}.report-hero-card__metric .report-hero-card__label,.report-hero-card__metric .report-hero-card__helper{color:#ffffffbd}.report-hero-card__value{display:block;margin:6px 0 2px;font-size:24px;line-height:1.1}.report-user-quick-filter__header,.report-filter-card__header,.report-card-header,.report-detail-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.report-user-quick-filter__header h3,.report-filter-card__header h3,.report-card-header h3,.report-detail-section__header h3{margin:0;font-size:18px;color:#16233b}.report-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.report-filter-field{display:flex;flex-direction:column;gap:8px}.report-filter-field label{font-size:13px;font-weight:600;color:#344054}.report-user-quick-filter__loading{display:inline-flex;align-items:center;gap:8px;color:#667085}.report-trend-card__body{min-height:320px}.report-detail-section__body--cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.report-list-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #e4ebf7;border-radius:16px;padding:18px;box-shadow:0 8px 20px #0f172a0d}.report-list-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.report-list-card__top h4{margin:0;font-size:18px;color:#16233b}.report-list-card__top p{margin:6px 0 0}.report-list-card__badge{padding:4px 10px;border-radius:999px;background:#e8f1ff;color:#1d4ed8;font-size:12px;font-weight:600}.report-list-card__value-group{margin:18px 0;display:flex;align-items:baseline;gap:8px}.report-list-card__value-group strong{font-size:32px;line-height:1;color:#1c64f2}.report-list-card__value-group span{color:#475467}.report-list-card__meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.report-list-card__meta-item{display:flex;flex-direction:column;gap:4px}.report-list-card__meta-value{color:#16233b}.report-list-card__meta-value--positive{color:#12b76a}.report-list-card__meta-value--negative{color:#f04438}.report-empty-state,.report-loading-state,.report-error-state{min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px}.report-empty-state strong,.report-error-state strong{font-size:18px;color:#16233b}.report-table-view .ant-table{border-radius:12px}.report-table-view .ant-table-container{border-radius:12px;overflow:hidden}@media (max-width: 768px){.report-page{padding:12px}.report-page__header{flex-direction:column}.report-page__header h1,.report-hero-card__header h2{font-size:22px}.report-surface-card,.report-hero-card{padding:14px}.report-list-card__meta-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
