@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";
:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--bg-gradient-start:#090e1a;--bg-gradient-end:#03050d;--card-bg:#0d142673;--card-border:#ffffff12;--card-border-hover:#ffffff26;--text-primary:#f8fafc;--text-secondary:#b3bdcc;--text-muted:#6b7c94;--primary:#9051f6;--primary-hover:#a26ef7;--primary-glow:#7c3aed59;--secondary:#06bbe0;--secondary-glow:#06b6d440;--accent-pink:#f04299;--success:#22c35d;--success-bg:#10b9811a;--error:#e8304f;--error-bg:#ef44441a;--input-bg:#0a0f1e99;--input-border:#ffffff1a;--input-focus:#9051f6;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-full:9999px;--shadow-sm:0 2px 8px -2px #00000080;--shadow-md:0 10px 30px -10px #000000b3;--shadow-lg:0 20px 50px -15px #000c;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-smooth:.3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;min-height:100vh;font-family:var(--font-sans);background:radial-gradient(circle at 50% 0%, #171f36 0%, var(--bg-gradient-end) 100%);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{z-index:10;flex-direction:column;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2.5rem 1.5rem;display:flex}.navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border);z-index:100;background:#0a0f1e99;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.nav-logo{background:linear-gradient(135deg, var(--text-primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:800;text-decoration:none;display:flex}.nav-links{align-items:center;gap:1.5rem;list-style:none;display:flex}.nav-link{color:var(--text-secondary);transition:var(--transition-fast);border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none}.nav-link:hover{color:var(--text-primary);background:#ffffff0d}.nav-link.active{color:var(--text-primary);background:#7c3aed26;border:1px solid #7c3aed33}.nav-btn{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);box-shadow:0 4px 15px var(--primary-glow);border:none;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600}.nav-btn:hover{box-shadow:0 6px 20px var(--primary-glow);transform:translateY(-2px)}.nav-btn-secondary{color:var(--text-primary);border:1px solid var(--input-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);background:0 0;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500}.nav-btn-secondary:hover{border-color:var(--card-border-hover);background:#ffffff0d}.card{background:var(--card-bg);border:1px solid var(--card-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:var(--transition-smooth);padding:2.5rem;animation:.6s ease-out fadeIn}.card:hover{border-color:var(--card-border-hover);box-shadow:0 25px 60px -10px #000000e6,0 0 20px #7c3aed0d}.card-title{background:linear-gradient(135deg, #fff 30%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:1.8rem;font-weight:700}.card-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.form-input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-fast);outline:none;width:100%;padding:.85rem 1.2rem;font-size:1rem}.form-input:focus{border-color:var(--input-focus);background:#0a0f1ed9;box-shadow:0 0 0 3px #7c3aed40}.form-input::placeholder{color:var(--text-muted)}.btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;width:100%;transition:var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.9rem 1.5rem;font-size:1rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);box-shadow:0 4px 15px var(--primary-glow)}.btn-primary:hover{box-shadow:0 8px 25px var(--primary-glow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--input-border);color:var(--text-primary);background:#ffffff0d}.btn-secondary:hover{border-color:var(--card-border-hover);background:#ffffff1a}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;transform:none!important}.auth-container{justify-content:center;align-items:center;width:100%;min-height:70vh;display:flex}.auth-card{width:100%;max-width:480px}.auth-footer-text{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.9rem}.auth-link{color:var(--secondary);transition:var(--transition-fast);font-weight:600;text-decoration:none}.auth-link:hover{color:var(--text-primary);text-decoration:underline}.alert{border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.95rem;animation:.3s ease-out slideDown;display:flex}.alert-success{background:var(--success-bg);color:#93ecb3;border:1px solid #10b98133}.alert-error{background:var(--error-bg);color:#f28c9d;border:1px solid #ef444433}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dashboard-grid{grid-template-columns:1fr;gap:2rem;width:100%;display:grid}@media (min-width:768px){.dashboard-grid{grid-template-columns:2fr 1fr}}.weather-search-box{gap:1rem;margin-top:1rem;margin-bottom:2rem;display:flex}.weather-info-card{border-radius:var(--radius-lg);background:linear-gradient(135deg,#1e293b99 0%,#0f172acc 100%);border:1px solid #06b6d426;padding:2rem;box-shadow:0 10px 30px #06b6d40d}.weather-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;display:flex}.weather-temp-container{align-items:baseline;gap:.5rem;display:flex}.weather-temp{color:var(--text-primary);font-size:3.5rem;font-weight:800}.weather-unit{color:var(--secondary);font-size:1.5rem;font-weight:600}.weather-details-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;display:grid}.weather-detail-item{border-radius:var(--radius-md);background:#ffffff08;border:1px solid #ffffff0d;flex-direction:column;padding:1rem;display:flex}.weather-detail-label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.weather-detail-value{color:var(--text-secondary);margin-top:.25rem;font-size:1.1rem;font-weight:600}.profile-header{align-items:center;gap:1.5rem;margin-bottom:2rem;display:flex}.profile-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff;border:3px solid #ffffff1a;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:flex}.profile-name-email{flex-direction:column;display:flex}.profile-info-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (min-width:640px){.profile-info-grid{grid-template-columns:repeat(2,1fr)}}.profile-info-item{border-bottom:1px solid #ffffff0d;padding-bottom:1rem}.profile-info-label{color:var(--text-muted);text-transform:uppercase;font-size:.8rem}.profile-info-value{margin-top:.25rem;font-size:1.1rem;font-weight:500}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-loader{justify-content:center;align-items:center;min-height:50vh;display:flex}
