body{margin:0;background-color:#764ba2;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.time-range-selector{background:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:.5rem}.time-range-selector label{font-weight:500;color:#333;font-size:.95rem}.time-range-select{padding:.4rem .8rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;cursor:pointer;outline:none;transition:border-color .3s ease}.time-range-select:hover{border-color:#667eea}.time-range-select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.aqi-reference-container{margin-top:40px;padding:20px;background-color:#f8f9fa;border-radius:8px}.aqi-tables-wrapper{display:flex;gap:20px;flex-wrap:wrap}.aqi-table-section{flex:1;min-width:300px}.aqi-table{width:100%;border-collapse:collapse;margin-top:10px;font-size:.9rem}.aqi-table th,.aqi-table td{padding:8px 12px;border:1px solid #ddd;text-align:left}.aqi-table th{background-color:#eee}@media(max-width:768px){.aqi-tables-wrapper{flex-direction:column}}.dashboard{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:5rem 2rem 2rem}.dashboard-header{text-align:center;color:#fff;margin-bottom:2rem}.dashboard-header h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.subtitle{font-size:1.1rem;opacity:.9}.controls{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.auto-refresh{background:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.auto-refresh label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.auto-refresh input[type=checkbox]{cursor:pointer;width:16px;height:16px}.refresh-btn{background:#4caf50;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .3s ease;box-shadow:0 2px 8px #0000001a}.refresh-btn:hover:not(:disabled){background:#45a049}.refresh-btn:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#f44336;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;text-align:center;max-width:800px;margin-left:auto;margin-right:auto}.latest-readings{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.latest-readings h3{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.3rem}.reading-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.reading-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:10px;text-align:center;box-shadow:0 4px 8px #0000001a}.reading-card.pm1{background:linear-gradient(135deg,#667eea,#764ba2)}.reading-card.pm25{background:linear-gradient(135deg,#f093fb,#f5576c)}.reading-card.pm10{background:linear-gradient(135deg,#4facfe,#00f2fe)}.reading-label{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:.5rem}.reading-value{font-size:2.5rem;font-weight:700;margin:.5rem 0}.reading-unit{font-size:.85rem;opacity:.9}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;max-width:1600px;margin:0 auto}.chart-wrapper{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a}.chart-title{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.2rem}.custom-tooltip{background:#fff;border:1px solid #ccc;border-radius:6px;padding:.75rem;box-shadow:0 2px 8px #0000001a}.tooltip-time{margin:0 0 .5rem;font-size:.85rem;color:#666}.tooltip-value{margin:0;font-weight:700;color:#333}.no-data{text-align:center;padding:3rem;background:#fff;border-radius:12px;color:#666;font-size:1.1rem;max-width:600px;margin:2rem auto;box-shadow:0 4px 12px #0000001a}@media(max-width:768px){.dashboard{padding:1rem}.dashboard-header h1{font-size:1.8rem}.charts-container{grid-template-columns:1fr}.controls{flex-direction:column;gap:1rem}}.custom-date-inputs{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.date-input-group label{color:#fff;font-weight:500}.date-input-group input{padding:.4rem;border-radius:4px;border:1px solid #ccc}.aqi-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1.5rem;border-top:1px solid #eee;padding-top:1.5rem}.aqi-card{padding:1.5rem;border-radius:10px;text-align:center;box-shadow:0 4px 8px #0000001a;transition:transform .2s}.aqi-card:hover{transform:translateY(-2px)}.solar-dashboard{background:linear-gradient(135deg,#667eea,#764ba2)}.reading-card.power{background:linear-gradient(135deg,#4caf50,#45a049)}.reading-card.voltage{background:linear-gradient(135deg,#f5576c,#f093fb)}.reading-card.current{background:linear-gradient(135deg,#4facfe,#00f2fe)}.nav-btn{background:#f5576c;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .3s ease;box-shadow:0 2px 8px #0000001a}.nav-btn:hover{background:#e0485d}.view-mode-toggle input[type=radio]{width:16px;height:16px;accent-color:#4CAF50;cursor:pointer}.time-hint{font-size:.85rem;color:#666;margin-left:.5rem}.study-dashboard{padding-bottom:2rem}.custom-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.custom-modal{background:#1e1e2e;padding:2rem;border-radius:12px;width:90%;max-width:400px;box-shadow:0 10px 30px #00000080;color:#fff;display:flex;flex-direction:column;gap:1rem}.custom-modal h3{margin:0;font-size:1.25rem;font-weight:600}.custom-modal p{color:#a0aec0;margin:0;font-size:.9rem}.modal-input{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);padding:.75rem;border-radius:6px;color:#fff;width:100%;outline:none;font-size:1rem}.modal-input:focus{border-color:#3b82f6}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:.5rem}.modal-btn{padding:.6rem 1.2rem;border-radius:6px;font-weight:500;cursor:pointer;border:none;transition:opacity .2s}.modal-btn:hover{opacity:.9}.modal-btn.secondary{background:#ffffff1a;color:#fff}.modal-btn.primary{background:#3b82f6;color:#fff}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-error{color:#ef4444;font-size:.85rem}.custom-modal.large-modal{max-width:800px;max-height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem;margin-bottom:.5rem}.close-btn{background:transparent;border:none;color:#a0aec0;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#fff}.modal-scroll-area{overflow-y:auto;overflow-x:hidden;max-height:calc(80vh - 120px);padding-right:.5rem}.modal-scroll-area::-webkit-scrollbar{width:8px}.modal-scroll-area::-webkit-scrollbar-track{background:#0003;border-radius:4px}.modal-scroll-area::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.descriptions-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.log-item{display:flex;padding:.75rem;border-radius:6px;background:#ffffff0d;gap:1rem;align-items:flex-start;border-left:4px solid transparent}.log-item.studying{border-left-color:#3b82f6}.log-item.entertainment{border-left-color:#ef4444}.log-time{color:#a0aec0;font-family:monospace;font-size:.9rem;white-space:nowrap}.log-class{font-weight:600;font-size:.85rem;white-space:nowrap}.log-item.studying .log-class{color:#3b82f6}.log-item.entertainment .log-class{color:#ef4444}.log-desc{color:#e2e8f0;line-height:1.4;word-break:break-word}.no-logs{text-align:center;color:#a0aec0;padding:2rem 0}.reading-card.sp-power{background:linear-gradient(135deg,#667eea,#764ba2)}.reading-card.sp-voltage{background:linear-gradient(135deg,#f093fb,#f5576c)}.reading-card.sp-current{background:linear-gradient(135deg,#4facfe,#00f2fe)}.power-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem;max-width:1200px;margin-left:auto;margin-right:auto}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;text-align:center}.stat-label{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;color:#666;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:#333;margin:.5rem 0}.stat-time{font-size:.85rem;color:#999;margin-top:.5rem}.date-inputs{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;background:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.date-input-group{display:flex;align-items:center;gap:.5rem}.date-input-group label{color:#333;font-weight:500;font-size:.95rem}.date-input-group input{padding:.4rem;border-radius:4px;border:1px solid #ccc;font-size:.95rem}.view-mode-toggle{display:flex;gap:1rem;background:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;align-items:center}.view-mode-toggle label{display:flex;align-items:center;gap:.4rem;cursor:pointer;color:#333;font-weight:500;font-size:.95rem}.view-mode-toggle input[type=radio]{width:16px;height:16px;accent-color:#764ba2;cursor:pointer}.auth-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;padding:1rem}.auth-card{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 12px #0003;width:100%;max-width:400px;text-align:center}.auth-card h1{margin-bottom:1.5rem;color:#333;font-size:2rem}.auth-form{display:flex;flex-direction:column;gap:1.2rem}.form-group{text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus{border-color:#764ba2;outline:none}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.8rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .3s;margin-top:1rem}.submit-btn:hover{opacity:.9}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#f44336;background:#ffebee;padding:.8rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.auth-footer{margin-top:1.5rem;font-size:.95rem;color:#666}.auth-footer a{color:#764ba2;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;background:#0003;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08)}.navbar-container{max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 2rem}.navbar-brand{font-weight:800;font-size:1.2rem;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-right:2rem}.navbar-links{display:flex;list-style:none;margin:0;padding:0;gap:.5rem;align-items:center}.navbar-link{padding:.5rem 1rem;border-radius:8px;color:#fffc;text-decoration:none;font-size:.9rem;font-weight:500;transition:all .2s ease}.navbar-link:hover{background:#ffffff1a;color:#fff}.navbar-link--active{background:#fff3;color:#fff;box-shadow:0 2px 10px #0000001a}.navbar-logout{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;padding:.5rem 1.2rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-left:2rem}.navbar-logout:hover{background:#fff;color:#764ba2;border-color:#fff}@media(max-width:900px){.navbar{padding:.5rem 1rem}.navbar-brand{display:none}.navbar-logout{margin-left:.5rem;padding:.4rem .8rem}}*{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}.App{min-height:100vh}
