*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#7c3aed;--secondary:#2563eb;--danger:#ef4444;--warning:#8b5cf6;--success:#22d3ee;--dark:#0b1120;--light:#111827;--border:#94a3b829;--text:#e2e8f0;--text-light:#94a3b8}body{min-height:100vh;color:var(--text);background:radial-gradient(circle at top,#7c3aed29,#0000 30%),radial-gradient(circle at 100% 100%,#2563eb24,#0000 35%),#020617;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}html,body,#root{height:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--light)}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.animate-in{animation:.5s ease-out fadeIn}.animate-slide{animation:.5s ease-out slideInLeft}.pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.bounce{animation:1s ease-in-out infinite bounce}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-muted{color:var(--text-light)}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.px-4{padding:0 1rem}.py-4{padding:1rem 0}.p-4{padding:1rem}button{cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 15px #10b9814d}.btn-primary:hover{background:#059669;transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-secondary{background:var(--secondary);color:#fff;box-shadow:0 4px 15px #06b6d44d}.btn-secondary:hover{background:#0891b2;transform:translateY(-2px);box-shadow:0 6px 20px #06b6d466}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-2px)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}input,textarea,select{border:2px solid var(--border);border-radius:8px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:all .3s}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #10b9811a}label{color:var(--text);margin-bottom:.5rem;font-weight:600;display:block}.card{background:#fff;border-radius:12px;padding:1.5rem;transition:all .3s;box-shadow:0 4px 20px #00000014}.card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.card-header{border-bottom:2px solid var(--border);margin-bottom:1rem;padding-bottom:1rem}.card-footer{border-top:2px solid var(--border);margin-top:1rem;padding-top:1rem}.grid{gap:1.5rem;display:grid}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.alert{border-left:4px solid;border-radius:8px;margin-bottom:1rem;padding:1rem;animation:.3s ease-out slideInLeft}.alert-success{border-color:var(--success);color:#166534;background:#dcfce7}.alert-warning{border-color:var(--warning);color:#92400e;background:#fef3c7}.alert-danger{border-color:var(--danger);color:#991b1b;background:#fee2e2}.alert-info{border-color:var(--secondary);color:#164e63;background:#e0f2fe}.spinner{border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.badge{text-transform:uppercase;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-success{color:#166534;background:#dcfce7}.badge-warning{color:#92400e;background:#fef3c7}.badge-danger{color:#991b1b;background:#fee2e2}.badge-info{color:#164e63;background:#e0f2fe}.progress-bar{background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:4px;height:100%;transition:width .3s}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-col{flex-direction:column}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.container{max-width:1200px;margin:0 auto;padding:0 1rem}@media (width<=768px){.grid-2,.grid-3{grid-template-columns:1fr}button{padding:.6rem 1.2rem;font-size:.9rem}.card{padding:1rem}}.app{background:radial-gradient(circle at top,#7c3aed2e,#0000 45%),radial-gradient(circle at 100% 100%,#2563eb2e,#0000 35%),#020617;min-height:100vh}.auth-container{background:linear-gradient(135deg,#040b1a 0%,#101828 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{background:#0f172a;border:1px solid #94a3b81f;border-radius:16px;width:100%;max-width:420px;padding:3rem;animation:.5s ease-out fadeIn;box-shadow:0 30px 80px #00000073}.auth-card h1{color:var(--primary);margin-bottom:.5rem;font-size:1.9rem}.auth-card p{color:var(--text-light);margin-bottom:2rem;font-size:.95rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-light);margin-bottom:.5rem;font-weight:600;display:block}.form-group input{width:100%;color:var(--text);background:#0b1120;border:2px solid #94a3b829;border-radius:8px;padding:.75rem;font-size:1rem;transition:all .3s}.form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #7c3aed1f}.form-group button{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:1rem;padding:.75rem;font-size:1rem;font-weight:600;transition:all .3s}.form-group button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #7c3aed59}.auth-link{text-align:center;color:var(--text-light);margin-top:1.5rem}.auth-link a{color:var(--primary);font-weight:600;text-decoration:none;transition:color .3s}.auth-link a:hover{color:var(--secondary);text-decoration:underline}.navbar{z-index:100;background:#080f21f2;border-bottom:1px solid #94a3b81f;padding:1rem 2rem;position:sticky;top:0;box-shadow:0 10px 40px #00000059}.navbar-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.navbar-brand{color:var(--primary);align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand:hover{color:var(--secondary)}.navbar-menu{gap:1.5rem;list-style:none;display:flex}.navbar-menu a{color:var(--text-light);font-weight:600;text-decoration:none;transition:color .3s}.navbar-menu a:hover{color:var(--primary)}.navbar-menu a.active{color:var(--secondary);border-bottom:3px solid var(--secondary);padding-bottom:.25rem}.navbar-logout{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .3s}.navbar-logout:hover{background:#dc2626;transform:translateY(-2px)}.dashboard-container{background:linear-gradient(#020617 0%,#101a33 70%,#0b1120 100%);min-height:100vh;padding:2rem 0 4rem}.dashboard-content{max-width:1200px;margin:0 auto;padding:0 1rem}.dashboard-header{color:#fff;margin-bottom:2rem}.dashboard-header h1{margin-bottom:.5rem;font-size:2.75rem}.dashboard-header p{opacity:.85;color:var(--text-light);font-size:1.05rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{background:#ffffff0d;border:1px solid #94a3b824;border-radius:16px;padding:1.75rem;transition:all .3s;animation:.5s ease-out fadeIn;box-shadow:0 15px 40px #00000059}.stat-card:hover{transform:translateY(-8px);box-shadow:0 18px 50px #00000073}.stat-card-title{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.6rem;font-size:.9rem;font-weight:600}.stat-card-value{color:var(--secondary);margin-bottom:.4rem;font-size:2.5rem;font-weight:700}.stat-card-unit{color:var(--text-light);margin-bottom:1rem;font-size:.95rem}.stat-card-change{align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.stat-card-change.positive{color:var(--success)}.stat-card-change.negative{color:var(--danger)}.chart-container{background:#ffffff0a;border:1px solid #94a3b824;border-radius:16px;margin-bottom:2rem;padding:2rem;animation:.5s ease-out .1s both fadeIn;box-shadow:0 15px 40px #00000059}.chart-container h2{color:var(--text);margin-bottom:1.5rem;font-size:1.3rem}.alert-box{border-left:4px solid var(--danger);background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;animation:.3s ease-out slideInLeft}.alert-box.success{border-left-color:var(--success);background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%)}.alert-box.warning{border-left-color:var(--warning);background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}.alert-box h3{color:var(--dark);margin-bottom:.5rem}.alert-box p{color:var(--text);line-height:1.6}.tips-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.tip-card{border-left:4px solid var(--primary);background:#fff;border-radius:8px;padding:1.5rem;transition:all .3s;box-shadow:0 2px 10px #0000000d}.tip-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001a}.tip-card h4{color:var(--primary);margin-bottom:.5rem}.tip-card p{color:var(--text-light);font-size:.9rem}.iot-data{border-left:4px solid var(--secondary);background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.iot-data h3{color:#164e63;margin-bottom:1rem}.iot-metrics{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;display:grid}.iot-metric{text-align:center;background:#fff;border-radius:6px;padding:1rem}.iot-metric-label{color:var(--text-light);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.iot-metric-value{color:var(--secondary);font-size:1.8rem;font-weight:700}.progress-section{margin-top:2rem}.progress-section h3{color:var(--dark);margin-bottom:1rem}.goal-tracker{background:#fff;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.goal-tracker h4{color:var(--primary);margin-bottom:1rem}.progress-bar-container{margin-bottom:1rem}.progress-bar-label{justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;display:flex}.progress{background:var(--border);border-radius:5px;width:100%;height:10px;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--primary), var(--secondary));height:100%;transition:width .5s}.comparison-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem;display:grid}.comparison-card{text-align:center;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 10px #0000000d}.comparison-card h4{color:var(--text-light);margin-bottom:.5rem;font-size:.9rem}.comparison-card .value{color:var(--primary);font-size:2rem;font-weight:700}.comparison-card .unit{color:var(--text-light);font-size:.9rem}.loading{text-align:center;color:#fff;padding:2rem}.error{border-left:4px solid var(--danger);color:#991b1b;background:#fee2e2;border-radius:8px;margin-bottom:1rem;padding:1rem}@media (width<=768px){.navbar-menu{gap:1rem;font-size:.9rem}.dashboard-header h1{font-size:1.8rem}.stat-card-value{font-size:2rem}.comparison-grid{grid-template-columns:1fr}.auth-card{padding:2rem}}.home-hero{background:linear-gradient(135deg,#06122b 0%,#081023 45%,#070b18 100%);padding:5rem 2rem 6rem;position:relative;overflow:hidden}.home-hero:before,.home-hero:after{content:"";filter:blur(80px);opacity:.55;pointer-events:none;border-radius:50%;position:absolute}.home-hero:before{background:radial-gradient(circle,#3b82f647,#0000 55%);width:420px;height:420px;top:-120px;right:-100px}.home-hero:after{background:radial-gradient(circle,#7c3aed3d,#0000 55%);width:340px;height:340px;bottom:-100px;left:-80px}.hero-content{z-index:1;grid-template-columns:1.3fr .95fr;align-items:center;gap:2rem;max-width:1200px;margin:0 auto;display:grid;position:relative}.hero-copy{max-width:640px}.hero-badge{color:#c7d2fe;background:#6366f124;border:1px solid #93c5fd2e;border-radius:999px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-weight:600;display:inline-flex}.hero-title{color:#eef2ff;letter-spacing:-.05em;margin-bottom:1.5rem;font-size:clamp(2.8rem,5vw,4.25rem);line-height:1.02}.hero-text{color:#cbd5e1;max-width:620px;font-size:1.05rem;line-height:1.75}.hero-actions{flex-wrap:wrap;gap:1rem;margin-top:2rem;display:flex}.hero-btn{min-width:170px}.hero-btn-outline{color:#e2e8f0;background:#ffffff14;border:1px solid #94a3b82e}.hero-panel{justify-content:center;display:flex}.hero-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #94a3b824;border-radius:28px;width:100%;max-width:420px;padding:2rem;position:relative;box-shadow:0 25px 60px #00000047}.hero-card-header{color:#cbd5e1;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;font-weight:600;display:flex}.hero-card-pill{color:#dbeafe;background:#7c3aed29;border-radius:999px;padding:.4rem .85rem;font-size:.85rem}.hero-card-value{color:#e0e7ff;margin-bottom:.75rem;font-size:3.25rem;font-weight:800}.hero-card-meta{color:#94a3b8;margin-bottom:1.75rem}.hero-card-stats{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.hero-card-stats div{text-align:left;background:#ffffff0f;border-radius:18px;padding:1rem}.hero-card-stats strong{color:#eef2ff;margin-bottom:.35rem;font-size:1.15rem;display:block}.hero-card-stats span{color:#94a3b8;font-size:.92rem}.home-features{background:#020617;padding:4rem 2rem 6rem}.features-header{text-align:center;margin-bottom:3rem}.features-title{color:#eef2ff;margin-bottom:.75rem;font-size:2.75rem}.features-subtitle{color:#94a3b8;max-width:650px;margin:0 auto;font-size:1.05rem;line-height:1.8}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.75rem;display:grid}.feature-card{cursor:pointer;background:linear-gradient(#ffffff0f,#ffffff05);border:1px solid #94a3b81f;border-radius:24px;padding:2rem;transition:transform .35s,box-shadow .35s;position:relative;overflow:hidden;box-shadow:0 18px 40px #0000003d}.feature-card:hover{transform:translateY(-10px);box-shadow:0 28px 60px #0000004d}.feature-card:before{content:"";pointer-events:none;background:radial-gradient(circle at 0 0,#3b82f624,#0000 25%),radial-gradient(circle at 100% 100%,#7c3aed24,#0000 20%);position:absolute;inset:0}.feature-icon{border-radius:18px;place-items:center;width:64px;height:64px;margin-bottom:1.4rem;font-size:1.9rem;display:grid;box-shadow:0 10px 30px #00000029}.feature-title{margin-bottom:.85rem;font-size:1.35rem;font-weight:700}.feature-description{color:#94a3b8;margin-bottom:1.5rem;line-height:1.75}.feature-action{color:#a5b4fc;background:#7c3aed1f;border:1px solid #7c3aed2e;border-radius:999px;align-items:center;gap:.5rem;padding:.9rem 1.2rem;font-weight:600;transition:transform .3s,background .3s,color .3s;display:inline-flex}.feature-card:hover .feature-action{color:#e0e7ff;background:#7c3aed2e;transform:translate(4px)}.home-footer{text-align:center;color:#94a3b8;background:#020617;border-top:1px solid #94a3b81f;padding:2.5rem 2rem 4rem}.home-footer p{color:#cbd5e1;max-width:720px;margin:0 auto}@media (width<=980px){.hero-content,.hero-card-stats{grid-template-columns:1fr}}@media (width<=640px){.home-hero,.home-features{padding:3rem 1rem 4rem}.hero-title{font-size:2.6rem}.hero-actions{flex-direction:column;align-items:stretch}.feature-card{padding:1.75rem}}
