@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root,:root[data-theme=dark]{--bg-primary:#0c0c14;--bg-secondary:#13131f;--bg-card:#1a1a2e;--bg-card-hover:#20203a;--bg-input:#0f0f1a;--text-primary:#e8e8f4;--text-secondary:#9090b8;--text-muted:#5c5c80;--accent:#7c6dfa;--accent-hover:#9d8fff;--accent-soft:#7c6dfa1f;--success:#4ade80;--success-soft:#4ade801f;--error:#f87171;--error-soft:#f871711f;--border:#ffffff14;--border-hover:#ffffff29;--shadow:0 8px 32px #0006;--shadow-sm:0 2px 8px #0000004d;--glass-bg:#1a1a2ecc;--glass-border:#ffffff1a;--sidebar-width:240px}:root[data-theme=light]{--bg-primary:#f0f0f8;--bg-secondary:#fafaff;--bg-card:#fff;--bg-card-hover:#f5f5ff;--bg-input:#f8f8ff;--text-primary:#1a1a2e;--text-secondary:#5050a0;--text-muted:#9090c0;--accent:#6055e0;--accent-hover:#4845c8;--accent-soft:#6055e01a;--success:#16a34a;--success-soft:#16a34a1a;--error:#dc2626;--error-soft:#dc26261a;--border:#0000001a;--border-hover:#0003;--shadow:0 8px 32px #0000001f;--shadow-sm:0 2px 8px #00000014;--glass-bg:#ffffffd9;--glass-border:#0000001a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;transition:background-color .3s,color .3s}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 16px #7c6dfa4d}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #7c6dfa66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.btn-danger{background:var(--error-soft);color:var(--error);border:1px solid #0000}.btn-danger:hover:not(:disabled){background:var(--error);color:#fff}.btn-lg{border-radius:12px;padding:.875rem 2rem;font-size:1rem}.btn-full{width:100%}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.form-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-input.error{border-color:var(--error);box-shadow:0 0 0 3px var(--error-soft)}.alert{border-radius:10px;align-items:flex-start;gap:.5rem;padding:.875rem 1rem;font-size:.875rem;line-height:1.5;display:flex}.alert-error{background:var(--error-soft);color:var(--error);border:1px solid #f8717133}.alert-success{background:var(--success-soft);color:var(--success);border:1px solid #4ade8033}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .2s}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:.4s forwards fadeIn}.text-center{text-align:center}.text-muted{color:var(--text-muted);font-size:.85rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.navbar{z-index:100;background:var(--glass-bg);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);align-items:center;height:60px;padding:0 1.5rem;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand-icon{background:var(--accent);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex;box-shadow:0 4px 12px #7c6dfa59}.navbar-spacer{flex:1}.navbar-actions{align-items:center;gap:.5rem;display:flex}.theme-toggle{border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;gap:.25rem;padding:1.25rem .75rem;transition:background-color .3s;display:flex;position:fixed;top:60px;bottom:0;left:0;overflow-y:auto}.sidebar-section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-top:.5rem;padding:.5rem .75rem .25rem;font-size:.7rem;font-weight:600}.sidebar-section-title:first-child{margin-top:0}.sidebar-link{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.625rem;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:.9rem;font-weight:400;text-decoration:none;transition:all .15s;display:flex}.sidebar-link:hover{background:var(--accent-soft);color:var(--accent)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.sidebar-link-icon{text-align:center;flex-shrink:0;width:20px;font-size:1rem}.sidebar-spacer{flex:1}.sidebar-user{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.875rem}.sidebar-user-info{align-items:center;gap:.625rem;padding:.5rem .75rem;display:flex}.sidebar-avatar{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:600;display:flex}.sidebar-username{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:500;overflow:hidden}.dashboard-layout{min-height:100vh;padding-top:60px;display:flex}.dashboard-main{margin-left:var(--sidebar-width);flex:1;min-height:calc(100vh - 60px);padding:2rem 2.5rem;overflow-y:auto}.dashboard-header{margin-bottom:2rem}.dashboard-welcome{color:var(--text-primary);margin-bottom:.375rem;font-size:1.75rem;font-weight:700}.dashboard-welcome span{background:linear-gradient(135deg, var(--accent), #c084fc);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.dashboard-subtitle{color:var(--text-secondary);font-size:.9rem}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.dashboard-feature-callout{background:radial-gradient(circle at top right, #7c6dfa33, transparent 38%), var(--bg-card);justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2rem;display:flex}.dashboard-feature-label{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;font-size:.75rem;font-weight:700}.dashboard-feature-title{margin-bottom:.5rem;font-size:1.25rem}.dashboard-feature-text{color:var(--text-secondary);max-width:56ch}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:all .2s;display:flex}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.stat-icon{background:var(--accent-soft);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.stat-info{overflow:hidden}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem;font-size:.75rem;font-weight:500}.stat-value{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;overflow:hidden}.section-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1rem;font-weight:600;display:flex}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.tool-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;color:inherit;border-radius:14px;flex-direction:column;gap:.75rem;padding:1.5rem;text-decoration:none;transition:all .2s;display:flex;position:relative;overflow:hidden}.tool-card:before{content:"";background:linear-gradient(90deg, var(--accent), #c084fc);opacity:0;height:2px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.tool-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #7c6dfa26}.tool-card:hover:before{opacity:1}.tool-card-coming{opacity:.5;cursor:default}.tool-card-coming:hover{border-color:var(--border);box-shadow:none;transform:none}.tool-card-coming:hover:before{opacity:0}.tool-card-icon{font-size:1.75rem}.tool-card-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.tool-card-desc{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.tool-badge{background:var(--accent-soft);color:var(--accent);letter-spacing:.05em;text-transform:uppercase;border-radius:100px;align-self:flex-start;padding:.2rem .5rem;font-size:.65rem;font-weight:600;display:inline-block}@media (width<=768px){.dashboard-main{margin-left:0;padding:1.25rem}.dashboard-feature-callout{flex-direction:column;align-items:flex-start}.sidebar{display:none}}.commute-page{flex-direction:column;gap:1.5rem;display:flex}.commute-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.commute-eyebrow{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem;font-size:.75rem;font-weight:700}.commute-title{margin-bottom:.5rem;font-size:2rem}.commute-description{color:var(--text-secondary);max-width:72ch}.commute-grid{grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:1rem;display:grid}.commute-card{flex-direction:column;gap:1rem;display:flex}.commute-card-header h2,.commute-notes h2,.route-links h3{margin-bottom:.35rem;font-size:1.1rem}.commute-card-header p,.commute-notes li,.status-item p{color:var(--text-secondary)}.commute-form,.commute-status{flex-direction:column;gap:1rem;display:flex}.status-summary{background:var(--bg-input);border:1px solid var(--border);border-radius:14px;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem;display:flex}.status-route{align-items:center;gap:.5rem;font-size:1.1rem;display:flex}.status-meta,.status-timestamp{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}.status-banner{border:1px solid var(--border);background:var(--bg-input);border-radius:14px;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.status-banner.is-active{background:#4ade8014;border-color:#4ade8040}.status-banner.is-muted{background:#f8717114;border-color:#f8717133}.status-list{gap:.75rem;display:grid}.status-item{background:var(--bg-input);border:1px solid var(--border);border-radius:14px;padding:1rem}.status-item-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.status-item small{color:var(--text-muted)}.route-links{flex-direction:column;gap:.75rem;display:flex}.route-links-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;display:grid}.route-link-card{border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);border-radius:14px;flex-direction:column;gap:.35rem;padding:1rem;text-decoration:none;transition:border-color .2s,transform .2s;display:flex}.route-link-card:hover{border-color:var(--accent);transform:translateY(-2px)}.route-link-card strong{color:var(--accent)}.commute-notes ul{flex-direction:column;gap:.65rem;padding-left:1.2rem;display:flex}@media (width<=1024px){.commute-grid{grid-template-columns:1fr}}@media (width<=768px){.commute-header,.status-summary,.status-item-header{flex-direction:column}.commute-title{font-size:1.6rem}}.landing{flex-direction:column;min-height:100vh;display:flex}.landing-hero{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:6rem 1.5rem 4rem;display:flex;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#7c6dfa26 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-55%)}.landing-badge{background:var(--accent-soft);color:var(--accent);border:1px solid #7c6dfa40;border-radius:100px;align-items:center;gap:.375rem;margin-bottom:1.5rem;padding:.375rem .875rem;font-size:.8rem;font-weight:500;display:inline-flex}.landing-title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:1rem;font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.15}.landing-title-accent{background:linear-gradient(135deg, var(--accent) 0%, #c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-description{color:var(--text-secondary);max-width:480px;margin:0 auto 2.5rem;font-size:1.1rem;line-height:1.7}.landing-actions{flex-wrap:wrap;justify-content:center;gap:.875rem;display:flex}.landing-features{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;width:100%;max-width:900px;margin:0 auto;padding:3rem 1.5rem 5rem;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .25s}.feature-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #7c6dfa26}.feature-icon{margin-bottom:.875rem;font-size:2rem;display:block}.feature-title{color:var(--text-primary);margin-bottom:.375rem;font-size:1rem;font-weight:600}.feature-desc{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.landing-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);padding:1.5rem;font-size:.8rem}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.auth-page:before,.auth-page:after{content:"";pointer-events:none;border-radius:50%;position:absolute}.auth-page:before{background:radial-gradient(circle,#7c6dfa1f 0%,#0000 70%);width:500px;height:500px;top:-100px;right:-100px}.auth-page:after{background:radial-gradient(circle,#c084fc14 0%,#0000 70%);width:400px;height:400px;bottom:-80px;left:-80px}.auth-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow);z-index:1;border-radius:20px;padding:2.5rem;animation:.4s fadeIn;position:relative}.auth-logo{justify-content:center;align-items:center;gap:.5rem;margin-bottom:2rem;display:flex}.auth-logo-icon{background:var(--accent);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4rem;display:flex;box-shadow:0 8px 20px #7c6dfa59}.auth-logo-name{color:var(--text-primary);font-size:1.4rem;font-weight:700}.auth-title{color:var(--text-primary);margin-bottom:.375rem;font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.875rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:.5rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-footer-text{text-align:center;color:var(--text-secondary);margin-top:1.25rem;font-size:.875rem}.auth-theme-toggle{border:1px solid var(--border);background:var(--bg-card);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;z-index:10;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex;position:fixed;top:1rem;right:1rem}.auth-theme-toggle:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.password-strength{gap:4px;margin-top:.375rem;display:flex}.password-strength-bar{background:var(--border);border-radius:2px;flex:1;height:3px;transition:background .3s}.password-strength-bar.filled-weak{background:var(--error)}.password-strength-bar.filled-medium{background:#f59e0b}.password-strength-bar.filled-strong{background:var(--success)}
