:root{--color-primary: #8b5cf6;--color-primary-dark: #7c3aed;--color-primary-light: #a78bfa;--color-secondary: #ec4899;--color-accent: #14b8a6;--color-bg: #f8fafc;--color-surface: #ffffff;--color-text-main: #1e293b;--color-text-sub: #64748b;--color-border: #e2e8f0;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--radius-md: .5rem;--radius-lg: 1rem;--radius-full: 9999px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--header-height: 60px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text-main);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden;height:100vh}.layout-wrapper{display:flex;flex-direction:column;height:100vh}.app-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;padding:0 1rem;align-items:center;justify-content:space-between;z-index:2000;position:relative}.map-full-container{flex:1;position:relative;overflow:hidden}.glass-panel{background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);box-shadow:var(--shadow-lg)}.glass-input{background:#fff9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--color-border);transition:all .2s}.glass-input:focus{background:#fff;border-color:var(--color-primary);outline:none}.bottom-sheet{position:absolute;bottom:0;left:0;right:0;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);z-index:1000;max-height:50%;display:flex;flex-direction:column;overflow-y:auto}@media(min-width:768px){.bottom-sheet{bottom:1rem;left:1rem;width:400px;height:auto;right:auto;border-radius:var(--radius-lg);max-height:80%}}.driver-radar-panel{width:100%;position:absolute;inset:auto 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;z-index:1000;overflow:hidden;max-height:60vh}@media(min-width:768px){.driver-radar-panel{width:350px;top:1rem;right:1rem;bottom:1rem;left:auto;border-radius:var(--radius-lg);max-height:none}}@media(max-width:640px){.bottom-sheet{max-height:72%}.user-profile .text-sm{display:none}}.auth-container{width:100%;padding:1rem;display:flex;align-items:center;justify-content:center;height:100vh;overflow-y:auto}.auth-card{width:100%;max-width:400px;padding:2rem;border-radius:var(--radius-lg);border:1px solid rgba(139,92,246,.18)}.auth-card-wide{max-width:560px}.auth-brand-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.25rem}.auth-brand-badge{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));box-shadow:0 8px 20px #8b5cf659}.auth-input{width:100%;padding:.75rem;border-radius:var(--radius-md);border:1px solid var(--color-border)}.auth-submit-btn{width:100%;padding:.85rem;margin-top:1rem;font-weight:700}.auth-error{color:var(--color-error);text-align:center;margin-bottom:1rem;background:#ef444414;border:1px solid rgba(239,68,68,.22);border-radius:var(--radius-md);padding:.6rem .75rem}.auth-footer-link a{color:var(--color-primary);font-weight:600;text-decoration:none}@media(max-width:640px){.auth-card{padding:1.5rem;box-shadow:none;background:transparent;border:none;-webkit-backdrop-filter:none;backdrop-filter:none}.auth-card-wide{max-width:100%}.auth-container{background:var(--color-surface);align-items:flex-start;padding-top:2rem}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1rem;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-main)}.btn-outline:hover{background:var(--color-surface);border-color:var(--color-primary)}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem;font-weight:600}.text-sub{color:var(--color-text-sub)}.mb-4{margin-bottom:1rem}.p-4{padding:1rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes ping{75%,to{transform:scale(2);opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.btn-link{background:none;border:none;color:var(--color-primary);text-decoration:underline;padding:0;height:auto;font-size:.875rem}.btn-link:hover{color:var(--color-primary-dark)}.btn-ghost{background:transparent;color:var(--color-text-sub)}.btn-ghost:hover{background:#0000000d;color:var(--color-text-main)}.btn-sm{padding:.25rem .75rem;font-size:.875rem;height:32px}.btn-icon{padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.location-form{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem 0;display:flex;flex-direction:column}.location-input-row{display:flex;align-items:center;position:relative;min-height:48px}.location-icon-col{width:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;height:100%}.location-line{position:absolute;top:60%;bottom:-40%;left:50%;transform:translate(-50%);width:2px;background-color:var(--color-border);z-index:1}.location-input-col{flex:1;padding:0 .5rem}.location-input-clean{width:100%;padding:.75rem 0;border:none;background:transparent;font-size:1rem;outline:none;color:var(--color-text-main);font-weight:500}.location-input-clean::placeholder{color:var(--color-text-sub);font-weight:400}.location-divider{height:1px;background:var(--color-border);margin-left:48px}
