:root{--gradient-primary: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);--gradient-secondary: linear-gradient(135deg, #e0e0e0 0%, #b0b0b0 100%);--gradient-success: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);--glass-bg: rgba(255, 255, 255, .75);--glass-bg-hover: rgba(255, 255, 255, .85);--glass-border: rgba(255, 255, 255, .9);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .1);--text-primary: #2c3e50;--text-secondary: #546e7a;--text-muted: #90a4ae;--text-light: #b0bec5;--text-white: #2c3e50;--text-white-90: rgba(44, 62, 80, .9);--text-white-70: rgba(84, 110, 122, .9);--text-white-50: rgba(144, 164, 174, .9);--accent-primary: #546e7a;--accent-success: #43e97b;--accent-stopped: #f5576c;--accent-warning: #ffa726;--accent-error: #ffa726;--accent-offline: #90a4ae;--header-height: 80px;--card-padding: 1.25rem;--card-gap: 1rem;--border-radius: 16px;--border-radius-lg: 20px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: .9375rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--transition: .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#f5f7fa,#e8eaf0,#dfe3e8);background-attachment:fixed;background-size:400% 400%;animation:gradientShift 15s ease infinite;color:var(--text-primary);font-size:var(--font-size-base);line-height:1.5;min-height:100vh;overflow-x:hidden}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.header{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);box-shadow:0 4px 30px #0000001a;padding:1rem 0;position:relative;z-index:10}.header-content{display:flex;align-items:center;justify-content:center;gap:1.5rem;max-width:1400px;margin:0 auto;padding:0 2rem}.header h1{font-size:var(--font-size-xl);font-weight:700;margin:0;color:var(--text-primary);text-shadow:0 2px 4px rgba(0,0,0,.05)}.header-subtitle{font-size:var(--font-size-sm);opacity:.9;font-weight:400;margin:0}.wind-turbine-animation{position:relative;width:50px;height:60px;filter:drop-shadow(0 2px 10px rgba(255,255,255,.3))}.turbine{position:relative;width:50px;height:60px}.tower{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:5px;height:40px;background:linear-gradient(to bottom,#ffffffe6,#ffffffb3);border-radius:2px}.nacelle{position:absolute;top:20px;left:50%;transform:translate(-50%);width:16px;height:10px;background:#fffffff2;border-radius:5px}.rotor{position:absolute;top:25px;left:50%;transform:translate(-50%);width:6px;height:6px;animation:rotate 3s linear infinite}@keyframes rotate{0%{transform:translate(-50%) rotate(0)}to{transform:translate(-50%) rotate(360deg)}}.blade{position:absolute;top:50%;left:50%;width:2px;height:20px;background:#fffffff2;border-radius:1px;transform-origin:center top}.blade1{transform:translate(-50%,-50%) rotate(0)}.blade2{transform:translate(-50%,-50%) rotate(120deg)}.blade3{transform:translate(-50%,-50%) rotate(240deg)}.main-layout{max-width:1400px;margin:0 auto;padding:1.5rem}.content-area{display:flex;flex-direction:column;gap:1.5rem}.nav-tabs{display:flex;justify-content:space-between;gap:.5rem;flex-wrap:wrap;padding:.75rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius);border:1px solid var(--glass-border);width:100%;margin-bottom:1.5rem}.nav-tab{position:relative;flex:1 1 0;min-width:100px;max-width:200px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.75rem 1rem;color:var(--text-white-90);font-size:var(--font-size-sm);font-weight:500;text-align:center;white-space:nowrap;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px}.nav-tab:hover{background:var(--glass-bg-hover);border-color:#ffffff4d;transform:translateY(-3px) scale(1.02);box-shadow:0 8px 20px #667eea4d,0 4px 10px #0000001a;z-index:2}.nav-tab:hover .nav-tab-label{color:#667eea;font-weight:600;text-shadow:0 0 10px rgba(102,126,234,.3)}.nav-tab:hover:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea26,#764ba226);border-radius:10px;pointer-events:none;animation:glow-fade .3s ease forwards}@keyframes glow-fade{0%{opacity:0}to{opacity:1}}.nav-tab.active{background:var(--gradient-secondary);border-color:#fff6;box-shadow:0 6px 16px #f5576c66,inset 0 2px 4px #fff3;transform:translateY(-2px);color:var(--text-primary);font-weight:600}.nav-tab.active:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 25px #f5576c80,inset 0 2px 4px #fff3}.nav-tab:active{transform:translateY(0) scale(.98);transition-duration:.1s}.nav-tab-label{display:inline-block;transition:all .3s ease}.nav-tab:has(.notification-badge){padding-right:2.5rem}.nav-tab:hover .notification-badge{transform:scale(1.15);box-shadow:0 6px 16px #f54254cc}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--card-gap)}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:var(--card-padding);box-shadow:var(--glass-shadow);transition:all var(--transition);display:flex;flex-direction:column;align-items:center;text-align:center;min-height:120px;justify-content:center}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026;background:var(--glass-bg-hover)}.stat-icon{font-size:2rem;margin-bottom:.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.stat-info{display:flex;flex-direction:column;gap:.375rem;width:100%}.stat-value{font-size:var(--font-size-2xl);font-weight:700;line-height:1;color:var(--text-primary)}.stat-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px}.icon svg{width:24px;height:24px;fill:currentColor}.section-title{font-size:var(--font-size-lg);font-weight:700;margin-bottom:1rem;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.05)}.table-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:1rem;box-shadow:var(--glass-shadow);overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--font-size-sm)}thead{background:#ffffff1a;position:sticky;top:0}th{padding:.75rem;text-align:left;font-weight:600;font-size:var(--font-size-xs);color:var(--text-white);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}td{padding:.625rem .75rem;color:var(--text-white-90);font-size:var(--font-size-sm)}tbody tr{border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s ease}tbody tr:hover{background:#ffffff14}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:1.5rem}.chart-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:1.25rem;box-shadow:var(--glass-shadow);transition:all var(--transition);min-height:400px;display:flex;flex-direction:column}.chart-container:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268780}.chart-container h3{margin-bottom:1rem;font-size:var(--font-size-base);font-weight:600;color:var(--text-white);text-align:center}.chart-container canvas{flex:1;min-height:300px;max-height:400px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e27d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--border-radius-lg);max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0006}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff0d}.modal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--text-white)}.modal-close{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff1a;color:var(--text-white);font-size:1.25rem;cursor:pointer;transition:all var(--transition)}.modal-close:hover{background:#ff576ccc;transform:rotate(90deg)}.modal-body{padding:1.5rem}.turbine-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.875rem;margin-bottom:1.5rem}.info-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;text-align:center}.info-label{font-size:var(--font-size-xs);color:var(--text-white-70);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.375rem}.info-value{font-size:var(--font-size-lg);font-weight:700;color:var(--text-white)}.hourly-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:1.5rem;margin-bottom:1.5rem}.chart-section{background:#ffffff08;border-radius:12px;padding:1.25rem;border:1px solid rgba(255,255,255,.1);height:350px;display:flex;flex-direction:column}.chart-section h3{margin-bottom:1rem;font-size:var(--font-size-base);color:var(--text-white)}.chart-section canvas{flex:1;max-height:270px!important;height:270px!important}.mini-turbine{display:inline-flex;align-items:center;justify-content:center;width:20px;height:24px;position:relative}.mini-turbine .turbine{width:20px;height:24px}.mini-turbine .tower{width:3px;height:14px}.mini-turbine .nacelle{width:8px;height:5px;top:10px}.mini-turbine .rotor{top:12px;width:3px;height:3px}.mini-turbine .blade{width:1.5px;height:8px}.status-running .turbine{filter:drop-shadow(0 0 6px #38ef7d)}.status-error .turbine{filter:drop-shadow(0 0 6px #f5576c)}.status-offline .turbine{filter:drop-shadow(0 0 6px #e91e63);opacity:.5}.status-running .rotor{animation:rotate 1.5s linear infinite}.status-error .rotor{animation:rotate 4s linear infinite}.status-offline .rotor{animation:none}.filter-card-stats{background:var(--glass-bg)}.filter-header-stats{display:flex;align-items:center;gap:.625rem;margin-bottom:.875rem}.filter-icon-stats{font-size:1.25rem}.filter-title-stats{font-size:var(--font-size-base);font-weight:600}.filter-summary-stats{display:flex;flex-direction:column;gap:.375rem;margin-bottom:.875rem;padding:.875rem;background:#ffffff0d;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.summary-text{font-size:var(--font-size-sm);color:var(--text-white-90)}.date-input-stats{padding:.625rem;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:var(--font-size-sm)}.btn-stats{padding:.625rem 1rem;border-radius:8px;border:none;font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition)}.btn-primary-stats{background:var(--gradient-secondary);color:#fff}.btn-primary-stats:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c4d}.btn-secondary-stats{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.tab-content{display:none}.tab-content.active{display:block;animation:fadeIn .3s ease}.status-legend{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:12px;padding:1rem;margin-bottom:1rem}.legend-title{font-weight:600;margin-bottom:.625rem;font-size:var(--font-size-sm)}.legend-items{display:flex;gap:1.25rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);padding:.375rem .75rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.charts-grid,.hourly-charts{grid-template-columns:1fr}}@media (max-width: 768px){.main-layout{padding:1rem}.header h1{font-size:var(--font-size-lg)}.stats-grid{grid-template-columns:1fr}.turbine-info-grid,.parks-grid{grid-template-columns:repeat(2,1fr)}th,td{padding:.5rem;font-size:var(--font-size-xs)}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.hidden{display:none!important}.text-center{text-align:center}.farm-row{background:#ffffff0d;font-weight:600;cursor:pointer}.farm-header-content{display:flex;align-items:center;justify-content:space-between}.farm-name{font-size:var(--font-size-base);font-weight:700}.farm-stats{display:flex;gap:.75rem;flex-wrap:wrap;font-size:var(--font-size-xs)}.farm-stat{display:flex;align-items:center;gap:.25rem;background:#ffffff0d;padding:.25rem .5rem;border-radius:6px}.expand-icon{font-size:1rem;transition:transform var(--transition)}.turbine-row{background:#ffffff05}.turbine-code{display:flex;align-items:center;gap:.375rem;font-weight:500;font-size:var(--font-size-sm)}.clickable-farm,.clickable-turbine{cursor:pointer}.severity-low{background:#43e97b33;color:#43e97b;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.severity-medium{background:#ffa72633;color:#ffa726;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.severity-high{background:#f5576c33;color:#f5576c;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.severity-critical{background:#9c27b033;color:#9c27b0;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.status-active{background:#f5576c33;color:#f5576c;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.status-resolved,.vibration-status-normal{background:#43e97b33;color:#43e97b;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.vibration-status-warning{background:#ffa72633;color:#ffa726;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.vibration-status-critical{background:#f5576c33;color:#f5576c;padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.filter-card-stats{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:1.25rem;box-shadow:var(--glass-shadow);margin-bottom:1.5rem}.filter-header-stats{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.filter-icon-stats{color:var(--text-white-90);font-size:var(--font-size-lg)}.filter-title-stats{color:var(--text-white);font-size:var(--font-size-lg);font-weight:600}.filter-summary-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;padding:.75rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.filter-controls-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.filter-input-stats{display:flex;flex-direction:column;gap:.5rem}.filter-input-stats label{color:var(--text-white-90);font-size:var(--font-size-xs);font-weight:500}.date-input-stats,.select-input-stats{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.625rem;color:var(--text-white);font-size:var(--font-size-sm);transition:all var(--transition)}.date-input-stats:focus,.select-input-stats:focus{outline:none;border-color:#4facfe80;box-shadow:0 0 0 2px #4facfe33}.date-range-stats{display:flex;align-items:center;gap:.5rem}.date-range-stats span{color:var(--text-white-70);font-weight:500}.filter-actions-stats{display:flex;gap:.75rem;grid-column:1 / -1;justify-content:flex-end;margin-top:.5rem}.btn-stats{padding:.625rem 1.25rem;border-radius:8px;border:none;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition);min-width:100px}.btn-primary-stats{background:var(--gradient-secondary);color:#fff;box-shadow:0 4px 12px #f5576c4d}.btn-primary-stats:hover{transform:translateY(-1px);box-shadow:0 6px 16px #f5576c66}.btn-secondary-stats{background:#ffffff1a;color:var(--text-white-90);border:1px solid rgba(255,255,255,.2)}.btn-secondary-stats:hover{background:#ffffff26;transform:translateY(-1px)}@media (max-width: 768px){.filter-controls-stats{grid-template-columns:1fr}.filter-actions-stats{justify-content:stretch}.btn-stats{flex:1}}.filter-panel-compact{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:.75rem 1rem;box-shadow:var(--glass-shadow);margin-bottom:1.5rem;width:100%}.filter-controls-compact{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-item-compact{display:flex;align-items:center;gap:.5rem;min-width:0}.filter-item-compact label{color:var(--text-white-90);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;min-width:fit-content}.input-compact{background:#fffffff2;border:1px solid rgba(0,0,0,.15);border-radius:6px;padding:.375rem .625rem;color:var(--text-primary);font-size:var(--font-size-xs);transition:all var(--transition);min-width:100px;height:32px}.input-compact:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #546e7a33}.date-range-compact{display:flex;align-items:center;gap:.5rem}.date-range-compact span{color:var(--text-white-70);font-weight:500;font-size:var(--font-size-sm)}.filter-actions-compact{display:flex;gap:.5rem;margin-left:auto}.btn-compact{padding:.375rem .75rem;border-radius:6px;border:none;font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap;height:32px;display:flex;align-items:center;justify-content:center}.btn-primary-compact{background:linear-gradient(135deg,#546e7a,#37474f);color:#fff;box-shadow:0 2px 8px #546e7a4d}.btn-primary-compact:hover{transform:translateY(-1px);box-shadow:0 4px 12px #546e7a66;background:linear-gradient(135deg,#607d8b,#455a64)}.btn-secondary-compact{background:#ffffffe6;color:var(--text-primary);border:1px solid rgba(0,0,0,.1)}.btn-secondary-compact:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}@media (max-width: 1024px){.filter-controls-compact{flex-wrap:wrap;gap:.75rem}.filter-actions-compact{margin-left:0;width:100%;justify-content:flex-end}}@media (max-width: 768px){.filter-controls-compact{flex-direction:column;align-items:stretch;gap:.75rem}.filter-item-compact{flex-direction:column;align-items:stretch;gap:.25rem}.filter-item-compact label{text-align:left}.input-compact{min-width:auto;width:100%}.filter-actions-compact{justify-content:stretch}.btn-compact{flex:1}}.status-module{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:.75rem 1rem;box-shadow:var(--glass-shadow);margin-bottom:1.5rem;width:100%}.status-buttons{display:flex;gap:.75rem;justify-content:flex-start;align-items:center;flex-wrap:wrap}.status-header{display:flex;align-items:center;gap:.5rem;margin-right:1rem;white-space:nowrap}.windmill-logo{font-size:1.25rem;color:var(--accent-primary);animation:spin 3s linear infinite}.status-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.status-button{display:flex;align-items:center;gap:.5rem;padding:.375rem 1rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:6px;color:var(--text-primary);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all var(--transition);min-width:160px;justify-content:flex-start;position:relative;overflow:hidden;height:32px}.status-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--status-bg);opacity:0;transition:opacity var(--transition);z-index:0}.status-button:hover:before{opacity:1}.status-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:var(--accent-primary);background:#fff}.status-button.active{background:var(--status-bg);border-color:var(--status-border);color:var(--status-color);box-shadow:0 4px 15px #0000001a}.status-button.active:before{opacity:1}.turbine-logo{z-index:1;position:relative;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));display:flex;align-items:center;justify-content:center}.turbine-logo svg{width:16px;height:16px}.status-info{display:flex;align-items:center;gap:.5rem;z-index:1;position:relative}.status-label{font-weight:600;font-size:var(--font-size-xs);line-height:1.2}.status-count{font-size:var(--font-size-xs);opacity:.8;font-weight:500}.status-button.active .status-icon{animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.turbine-icon{display:inline-block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.turbine-spin .blade,.turbine-spin .blades-compact{transform-origin:50% 50%;animation:turbineRotate 2s linear infinite}@keyframes turbineRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.turbine-icon-compact{display:inline-block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}@media (max-width: 768px){.status-buttons{flex-direction:column;align-items:stretch}.status-header{margin-right:0;margin-bottom:.5rem}.status-button{min-width:auto;justify-content:flex-start}.status-info{align-items:flex-start}}@media (max-width: 480px){.status-module{padding:.5rem .75rem}.status-header{margin-bottom:.5rem}.windmill-logo{font-size:1rem}.status-title{font-size:var(--font-size-xs)}.status-button{padding:.25rem .75rem;gap:.25rem;min-width:140px;height:28px}.turbine-logo svg{width:14px;height:14px}.status-label,.status-count{font-size:.625rem}}.parks-section{margin-bottom:1.5rem}.section-subtitle{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:1rem}.parks-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.5rem}.park-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:0;padding:0;box-shadow:var(--glass-shadow);cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;height:160px}.park-card *{pointer-events:none}.park-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#546e7a0d,#b0bec50d);opacity:0;transition:opacity var(--transition);z-index:0}.park-card:hover:before{opacity:1}.park-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #00000026;border-color:var(--accent-primary)}.park-card-header{background:#90a4ae33;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);padding:.75rem 1rem;text-align:center;margin-bottom:0;z-index:1;position:relative;border-bottom:1px solid rgba(144,164,174,.3)}.park-name{font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);margin:0;text-align:center;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.park-stats{display:flex;justify-content:center;align-items:center;margin:0;padding:.5rem;z-index:1;position:relative;flex:1;min-height:60px}.park-stat{display:flex;align-items:center;justify-content:center;width:100%}.stat-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);line-height:1.1}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.2;text-transform:uppercase;letter-spacing:.5px}.park-status{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;padding:.5rem;z-index:1;position:relative;flex-shrink:0;height:40px}.status-item{display:flex;align-items:center;justify-content:center;padding:.25rem .375rem;border-radius:0;font-size:var(--font-size-xs);font-weight:600;transition:all var(--transition);min-height:24px;text-align:center}.status-item.clickable{cursor:pointer}.status-item.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;filter:brightness(1.1)}.status-item.running{background:#43e97b;color:#000;border:1px solid #43e97b;font-weight:700}.status-item.stopped{background:#f5576c;color:#000;border:1px solid #f5576c;font-weight:700}.status-item.error{background:#ffa726;color:#000;border:1px solid #ffa726;font-weight:700}.status-item.offline{background:#90a4ae;color:#000;border:1px solid #90a4ae;font-weight:700}.status-item .status-icon{width:12px;height:12px}.status-count{font-weight:600}.status-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:.75rem;box-shadow:0 8px 32px #0003;z-index:100;min-width:200px;pointer-events:none;animation:tooltipFadeIn .2s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes errorBlink{0%,50%{opacity:1;transform:scale(1)}25%,75%{opacity:.3;transform:scale(.95)}}.error-blinking{animation:errorBlink 1.5s ease-in-out infinite}.tooltip-header{font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.1)}.tooltip-content{display:flex;flex-direction:column;gap:.375rem}.tooltip-turbine{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-xs);color:var(--text-secondary)}.tooltip-turbine span:last-child{margin-left:auto;font-weight:600;color:var(--text-primary)}.tooltip-more{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;margin-top:.25rem;font-style:italic}.park-details{width:100%}.park-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.btn-back{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-back:hover{background:#fff;border-color:var(--accent-primary);transform:translate(-2px);box-shadow:0 2px 8px #0000001a}.park-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin:0}.park-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.park-charts,.turbines-section{margin-bottom:1.5rem}.turbines-section h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:1rem}.turbines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.turbine-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:.75rem;box-shadow:var(--glass-shadow);transition:all var(--transition)}.turbine-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.clickable-row{cursor:pointer;transition:background-color .2s ease}.clickable-row:hover{background-color:#ffffff1a}.task-modal-content{max-width:700px;max-height:90vh;overflow-y:auto}.task-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.task-info-section{background:#ffffff1a;border-radius:12px;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.status-select{padding:.5rem;border:none;border-radius:6px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.description-section h3,.comments-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:var(--font-size-lg)}.description-section p{color:var(--text-secondary);line-height:1.6;background:#ffffff0d;padding:1rem;border-radius:8px;border-left:4px solid var(--accent-primary)}.comments-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.comment-item{background:#ffffff0d;border-radius:8px;padding:1rem;border-left:4px solid var(--accent-primary)}.comment-item.status_change{border-left-color:#ffa726}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.comment-author{font-weight:600;color:var(--text-primary)}.comment-timestamp{font-size:var(--font-size-sm);color:var(--text-muted)}.comment-type{font-size:var(--font-size-xs);color:var(--accent-primary);background:#546e7a33;padding:.25rem .5rem;border-radius:4px}.comment-content{color:var(--text-secondary);line-height:1.5}.add-comment-section{display:flex;flex-direction:column;gap:1rem}.comment-input{width:100%;padding:1rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:var(--text-primary);font-family:inherit;font-size:var(--font-size-sm);resize:vertical;min-height:80px}.comment-input:focus{outline:none;border-color:var(--accent-primary);background:#ffffff26}.comment-input::placeholder{color:var(--text-muted)}.add-comment-btn{align-self:flex-start;padding:.75rem 1.5rem;font-size:var(--font-size-sm)}.add-comment-btn:disabled{opacity:.5;cursor:not-allowed}.task-modal-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:1rem}.alarm-modal-content{max-width:700px;max-height:90vh;overflow-y:auto}.alarm-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.alarm-info-section,.turbine-info-section{background:#ffffff1a;border-radius:12px;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.turbine-info-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:var(--font-size-lg)}.recommendations-section{background:#43e97b1a;border-radius:12px;padding:1rem;border-left:4px solid #43e97b}.recommendations-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:var(--font-size-lg)}.recommendations-section ul{list-style:none;padding:0;margin:0}.recommendations-section li{padding:.5rem 0;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.recommendations-section li:before{content:"→";color:#43e97b;font-weight:700}.status-resolved{color:#43e97b;font-weight:600}.status-active{color:#f5576c;font-weight:600}.task-created-notification{background:#43e97b33;border:2px solid #43e97b;border-radius:8px;padding:1rem;text-align:center;color:#43e97b;font-weight:600;font-size:var(--font-size-md);animation:fadeIn .3s ease}.task-updated-notification{background:#4fc3f733;border:2px solid #4fc3f7;border-radius:8px;padding:1rem;text-align:center;color:#4fc3f7;font-weight:600;font-size:var(--font-size-md);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alarm-modal-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:1rem;flex-wrap:wrap}.btn-danger{padding:.75rem 1.5rem;background:linear-gradient(135deg,#f5576c,#e91e63);color:#fff;border:none;border-radius:8px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#546e7a,#37474f);color:#fff;border:none;border-radius:8px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #546e7a66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:#ffffff1a;color:var(--text-primary);border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#fff3;transform:translateY(-2px)}.clickable-stat-card{cursor:pointer;transition:all .3s ease}.clickable-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0003;background:#fffffff2}.clickable-stat-card:active{transform:translateY(-2px)}.stats-grid-6{grid-template-columns:repeat(6,1fr)}.stat-card-compact .stat-value{font-size:1.75rem;font-weight:700}.stat-card-compact .stat-label{font-size:.75rem}@media (max-width: 1400px){.stats-grid-6{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.stats-grid-6{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.stats-grid-6{grid-template-columns:1fr}}.pie-charts-section{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:1.5rem 0}.pie-chart-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);transition:all .3s ease}.pie-chart-container:hover{transform:translateY(-2px);box-shadow:0 8px 32px #00000026}.pie-chart-container .chart-title{color:var(--text-primary);font-size:var(--font-size-md);font-weight:600;margin-bottom:1rem;text-align:center}@media (max-width: 1024px){.pie-charts-section{grid-template-columns:1fr}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem}.error-boundary-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2rem;max-width:600px;text-align:center;box-shadow:var(--glass-shadow);border:1px solid var(--glass-border)}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{color:var(--text-primary);font-size:var(--font-size-xl);margin-bottom:1rem}.error-message{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.error-details{text-align:left;margin:1.5rem 0;background:#0000000d;border-radius:8px;padding:1rem}.error-details summary{cursor:pointer;color:var(--text-primary);font-weight:600;margin-bottom:.5rem}.error-stack{color:var(--text-secondary);font-size:var(--font-size-sm);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.error-reset-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#546e7a,#37474f);color:#fff;border:none;border-radius:8px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .3s ease}.error-reset-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #546e7a66}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;min-height:200px}.loading-container-fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-spinner{display:flex;gap:.5rem;align-items:center;justify-content:center}.loading-spinner-small .spinner-circle{width:8px;height:8px}.loading-spinner-medium .spinner-circle{width:12px;height:12px}.loading-spinner-large .spinner-circle{width:16px;height:16px}.spinner-circle{background:var(--accent-primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.spinner-circle:nth-child(1){animation-delay:-.32s}.spinner-circle:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-message{margin-top:1rem;color:var(--text-secondary);font-size:var(--font-size-sm);text-align:center}.turbine-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem}.turbine-logo{display:flex;align-items:center;justify-content:center}.turbine-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.turbine-stats{display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center}.turbine-stat{display:flex;justify-content:center;align-items:center;font-size:.7rem;gap:.25rem}.turbine-stat.power-stat{flex-direction:column;gap:.125rem}.power-display{display:flex;flex-direction:column;align-items:center;gap:.125rem}.power-value{font-size:.8rem;font-weight:700;color:var(--text-primary);line-height:1.1}.power-label{font-size:.6rem;color:var(--text-secondary);text-transform:lowercase;line-height:1}.turbine-stat.wind-stat{flex-direction:column;gap:.125rem}.wind-display{display:flex;flex-direction:column;align-items:center;gap:.125rem}.wind-value{font-size:.8rem;font-weight:700;color:var(--text-primary);line-height:1.1}.wind-label{font-size:.6rem;color:var(--text-secondary);text-transform:lowercase;line-height:1}.turbine-stat.status-stat{flex-direction:row;gap:.25rem}.status-display{display:flex;flex-direction:row;align-items:center;gap:.25rem}.status-text{font-size:.6rem;font-weight:600;color:var(--text-primary);line-height:1;text-transform:uppercase;letter-spacing:.5px}.turbine-stat .stat-label{color:var(--text-secondary)}.turbine-stat .stat-value{color:var(--text-primary);font-weight:600}.turbine-stat .status-icon{display:flex;align-items:center;justify-content:center}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:var(--font-size-xs);font-weight:500}.status-badge.running{background:#43e97b33;color:#43e97b}.status-badge.stopped{background:#9c27b033;color:#9c27b0}.status-badge.error{background:#ffa72633;color:#ffa726}.status-badge.offline{background:#f5576c33;color:#f5576c}.tab-content>*{margin-bottom:1.5rem}.tab-content>*:last-child{margin-bottom:0}.section-title,.table-section,.charts-grid,.filter-panel-compact,.status-module{margin-bottom:1.5rem}@media (max-width: 1024px){.parks-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.parks-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.parks-grid{grid-template-columns:1fr}.park-card{padding:.75rem}.park-name,.stat-value{font-size:var(--font-size-xs)}.stat-label{font-size:.625rem}}@media (max-width: 1200px){.turbines-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width: 768px){.turbines-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.turbine-card{padding:.5rem}.turbine-name{font-size:.75rem}.turbine-stat{font-size:.65rem}}@media (max-width: 480px){.turbines-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.25rem}.turbine-card{padding:.4rem}.turbine-name{font-size:.7rem}.turbine-stat{font-size:.6rem}}.virtualized-list{position:relative;overflow:auto}.virtualized-turbine-grid{position:relative}.optimized-image{position:relative;display:block;transition:opacity .3s ease-in-out}.optimized-image.loading{opacity:0}.optimized-image.loaded{opacity:1}.optimized-image.placeholder{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.optimized-image.error{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--accent-error);flex-direction:column;gap:4px}.placeholder-content,.error-content{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;font-size:.875rem}.icon-sprite{display:inline-block;vertical-align:middle;fill:currentColor;transition:color .2s ease}.turbine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1rem 0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .3s ease-out}.virtualized-list::-webkit-scrollbar{width:8px}.virtualized-list::-webkit-scrollbar-track{background:var(--glass-bg);border-radius:4px}.virtualized-list::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:4px}.virtualized-list::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.notification-badge{position:absolute;top:6px;right:6px;min-width:20px;height:20px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;line-height:1;color:#fff;background:linear-gradient(135deg,#f54254,#ff6b6b);border:2px solid rgba(255,255,255,.3);border-radius:12px;box-shadow:0 2px 8px #f5425480,inset 0 1px 2px #ffffff4d;animation:badge-pulse 2s ease-in-out infinite;z-index:10}@keyframes badge-pulse{0%,to{transform:scale(1);box-shadow:0 2px 8px #f5425480}50%{transform:scale(1.1);box-shadow:0 4px 12px #f54254b3}}.alarm-actions{display:flex;justify-content:flex-end;margin:1rem 0}.btn-mark-all-read{padding:10px 20px;font-size:14px;font-weight:500;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #667eea4d}.btn-mark-all-read:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.btn-mark-all-read:active{transform:translateY(0);box-shadow:0 2px 4px #667eea4d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.turbine-modal-content{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.1);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.turbine-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;border-bottom:1px solid rgba(0,0,0,.1);position:relative}.turbine-modal-title{display:flex;align-items:flex-start;gap:1rem}.title-info h2{font-size:1.125rem;font-weight:700;color:#2c3e50;margin:0 0 .25rem}.turbine-location{font-size:.75rem;color:#546e7a;margin:0 0 .25rem}.turbine-serial{font-size:.7rem;color:#90a4ae;font-family:Courier New,monospace;margin:0}.modal-status-badge{position:absolute;top:1rem;right:3.5rem;display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:20px;font-size:.75rem;font-weight:600}.modal-close-btn{background:#0000000d;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#546e7a;font-size:1.125rem}.modal-close-btn:hover{background:#0000001a;transform:rotate(90deg)}.turbine-modal-body{padding:1rem;display:flex;flex-direction:column;gap:1rem}.section-heading{font-size:.875rem;font-weight:600;color:#2c3e50;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.section-heading i{color:#546e7a}.realtime-grid{display:flex;flex-direction:column;gap:.5rem}.realtime-card{background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:.5rem .75rem;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.realtime-card:hover{background:#fffffff2;box-shadow:0 2px 8px #0000001a}.realtime-card.power{border-left:3px solid #ffd700}.realtime-card.wind{border-left:3px solid #4fc3f7}.realtime-card.temperature{border-left:3px solid #f5576c}.realtime-info{display:flex;justify-content:space-between;align-items:center;width:100%}.realtime-label{font-size:.75rem;color:#546e7a;font-weight:500}.realtime-value{font-size:1.125rem;font-weight:700;color:#2c3e50}.realtime-unit{font-size:.75rem;color:#90a4ae;margin-left:.25rem}.no-data{font-size:.875rem;color:#90a4ae;font-style:italic;font-weight:400}.status-display{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-radius:12px;border:2px solid;font-size:1.125rem;font-weight:600}.status-text{color:#2c3e50}.errors-list{display:flex;flex-direction:column;gap:.75rem}.error-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#ffa7261a;border-left:3px solid #ffa726;border-radius:8px}.error-badge{background:#ffa726;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;font-family:Courier New,monospace}.error-info{flex:1}.error-message{font-size:.875rem;color:#2c3e50;font-weight:500;margin-bottom:.25rem}.error-time{font-size:.75rem;color:#90a4ae}.no-errors{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:#43e97b1a;border-radius:12px;color:#43e97b;font-size:1rem;font-weight:500}.no-errors i{font-size:2rem}.turbine-modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid rgba(0,0,0,.1);background:#f5f7fa80}.control-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em}.control-btn:disabled{opacity:.5;cursor:not-allowed}.start-btn{background:linear-gradient(135deg,#43e97b,#38ef7d);color:#fff;box-shadow:0 2px 8px #43e97b4d}.start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #43e97b66}.stop-btn{background:linear-gradient(135deg,#f5576c,#f093fb);color:#fff;box-shadow:0 2px 8px #f5576c4d}.stop-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.reset-btn{background:linear-gradient(135deg,#ffa726,#ffb74d);color:#fff;box-shadow:0 2px 8px #ffa7264d}.reset-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ffa72666}@media (max-width: 768px){.turbine-modal-content{width:95%;max-height:95vh}.realtime-grid{grid-template-columns:1fr}.turbine-modal-footer{flex-direction:column}.control-btn{width:100%}}.dashboard{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8eaf0,#dfe3e8)}.main-layout{min-height:calc(100vh - 120px);padding:2rem}.tab-content{display:none;animation:fadeIn .3s ease}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-left{background:linear-gradient(135deg,#8a7cf7,#5b6cf5);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:4rem}.login-left .brand{font-size:36px;font-weight:800;letter-spacing:2px;margin-bottom:8px}.login-left .subtitle{font-size:18px;opacity:.95;margin-bottom:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.login-left .desc{opacity:.9;text-align:center;line-height:1.6;white-space:pre-line}.login-right{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:4rem 6rem;background:#fff;position:relative;min-height:100vh}.login-right .welcome{font-size:28px;font-weight:700;color:#344054;margin:0 0 6px}.login-right .hint{color:#667085;margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;width:320px}.login-form label{font-size:12px;color:#475467}.login-form input{height:44px;border:1px solid #e5e7eb;border-radius:10px;padding:0 14px;outline:none;background:#f9fafb}.login-form input:focus{border-color:#7c89f7;box-shadow:0 0 0 3px #7c89f740;background:#fff}.btn-primary.gradient{background:linear-gradient(90deg,#6b7af8,#8a7cf7);color:#fff;height:44px;border:none;border-radius:10px;cursor:pointer}.btn-secondary{background:#eef2ff;color:#344054;height:36px;border:none;border-radius:8px;padding:0 12px;cursor:pointer}.login-error{color:#ef4444;font-size:12px}.test-card{border:1px solid #e5e7eb;background:#f8fafc;border-radius:12px;padding:12px;margin-top:12px;width:320px}.test-card .row{display:flex;gap:8px;align-items:center;font-size:12px;color:#475467}.test-card code{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:2px 6px}.copyright{color:#98a2b3;font-size:12px;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.admin-grid{display:grid;grid-template-columns:1fr;gap:16px}.admin-card{background:#ffffffb3;border:1px solid #e5e7eb;border-radius:12px;padding:16px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.form-grid input,.form-grid select{height:40px;border:1px solid #e5e7eb;border-radius:10px;padding:0 10px;background:#fff}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px;border-bottom:1px solid #eef2f7}.row-actions{display:flex;gap:8px}.audit-filters{margin-bottom:1rem}.filter-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.filter-select,.filter-input{height:40px;border:1px solid #e5e7eb;border-radius:8px;padding:0 12px;background:#fff}.filter-select{min-width:150px}.filter-input{min-width:120px}.audit-stats{display:flex;gap:16px;margin-bottom:1rem}.stat-card{background:#ffffffb3;border:1px solid #e5e7eb;border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center}.stat-label{font-size:12px;color:#6b7280}.stat-value{font-size:18px;font-weight:600;color:#1f2937}.audit-table-container{background:#ffffffb3;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.audit-table{width:100%;border-collapse:collapse}.audit-table th{background:#f8fafc;padding:12px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.audit-table td{padding:12px;border-bottom:1px solid #f3f4f6}.audit-row:hover{background:#f9fafb}.audit-time{font-size:12px;color:#6b7280;white-space:nowrap}.audit-user{font-family:monospace;font-size:12px}.action-badge{font-size:12px;font-weight:500}.audit-resource{font-size:12px;color:#6b7280}.audit-details{font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-ip{font-family:monospace;font-size:11px;color:#6b7280}.loading-message,.empty-message{text-align:center;padding:2rem;color:#6b7280}.error-message{text-align:center;padding:2rem;color:#ef4444}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;background:#fff;border:1px solid #e5e7eb;min-width:300px;max-width:400px;transform:translate(100%);transition:transform .3s ease}.toast-visible{transform:translate(0)}.toast-hidden{transform:translate(100%)}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-icon{font-size:18px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:#ef4444}.toast-warning .toast-icon{color:#f59e0b}.toast-info .toast-icon{color:#3b82f6}.toast-message{flex:1;font-size:14px;color:#374151;line-height:1.4}.toast-close{background:none;border:none;font-size:18px;color:#9ca3af;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.toast-close:hover{background-color:#f3f4f6;color:#6b7280}@media (max-width: 900px){.login-page{grid-template-columns:1fr}.login-right{padding:2rem}.filter-row{flex-direction:column;align-items:stretch}.audit-stats{flex-direction:column}.audit-table-container{overflow-x:auto}.toast-container{right:10px;left:10px}.toast{min-width:auto;max-width:none}}
