:root{font-family:system-ui,-apple-system,Segoe UI,sans-serif;color:#111827;background:#f4f6f8;line-height:1.5}*{box-sizing:border-box}body{margin:0}a{color:inherit}.public-shell{min-height:100vh}.public-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e5e7eb}.brand{text-decoration:none;font-size:1.35rem;font-weight:800;letter-spacing:-.03em}.brand-logo{display:inline-flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.brand-logo-stack{flex-direction:column;align-items:flex-start}.brand-logo-compact .brand-text{font-size:1.2rem;font-weight:800;letter-spacing:-.03em}.brand-logo-full{height:72px;width:auto}.brand-logo-mark{height:48px;width:auto;max-width:180px;object-fit:contain}.brand-ride{color:#16a34a}.brand-memet,.brand-connect{color:#2563eb}.public-nav{display:flex;flex-wrap:wrap;gap:.75rem 1rem}.public-nav a{color:#374151;text-decoration:none;font-weight:600;font-size:.95rem}.public-nav a:hover{color:#2563eb}.public-main{max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem}.page-intro h1{margin:0 0 .35rem;font-size:2rem}.page-intro p{margin:0 0 1.5rem;color:#6b7280}.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.choice-card{display:block;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.25rem;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}.choice-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #11182714}.choice-card h2{margin:0 0 .5rem}.choice-card p{margin:0 0 1rem;color:#4b5563}.choice-action{color:#2563eb;font-weight:700}.choice-card.rider{border-top:4px solid #111827}.choice-card.contact{border-top:4px solid #2563eb}.choice-card.track{border-top:4px solid #16a34a}.auth-card,.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem}.auth-card{max-width:420px;display:flex;flex-direction:column;gap:.85rem}.auth-card.wide{max-width:520px}label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;color:#374151}input,select,textarea{font:inherit;padding:.75rem .85rem;border:1px solid #d1d5db;border-radius:10px}.btn{border:none;border-radius:10px;padding:.85rem 1rem;font:inherit;font-weight:700;cursor:pointer}.btn.primary{background:#111827;color:#fff}.btn.primary.contact{background:#2563eb}.btn.secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn:disabled{opacity:.6;cursor:not-allowed}.form-error{color:#dc2626;margin:0}.form-links{text-align:center;margin:0}.form-links a{color:#2563eb;text-decoration:none;font-weight:600}.test-hint,.hint,.dev-otp{color:#6b7280;font-size:.875rem}.center-hint{text-align:center;margin-top:1.5rem}.dev-otp{background:#fef3c7;padding:.75rem;border-radius:8px}.dashboard-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.dashboard-sidebar{background:#111827;color:#fff;padding:1.5rem}.compact-brand{display:inline-block;margin-bottom:.5rem}.sidebar-label{color:#9ca3af;margin:0 0 1rem;font-size:.875rem}.dashboard-sidebar nav{display:flex;flex-direction:column;gap:.35rem}.dashboard-sidebar nav a{color:#e5e7eb;text-decoration:none;padding:.55rem .75rem;border-radius:8px}.dashboard-sidebar nav a:hover{background:#1f2937}.link-btn{margin-top:2rem;background:none;border:none;color:#fca5a5;font:inherit;font-weight:700;cursor:pointer;padding:0}.dashboard-main{padding:2rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.page-header h2{margin:0}.cards,.live-grid{display:grid;gap:1rem}.cards{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1rem}.live-grid{grid-template-columns:1.2fr .8fr}.card h3,.card h4{margin-top:0}.card.highlight{border-color:#86efac;background:#f0fdf4}.card.info{background:#eff6ff;border-color:#bfdbfe}.link-card{display:block;text-decoration:none;margin-bottom:.75rem}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.mono.big{font-size:1.5rem;color:#2563eb}.section-title{margin:0 0 .75rem}.inline-btn{display:inline-block;margin-top:1rem;text-decoration:none;text-align:center}.loading{color:#6b7280}.dashboard-loading{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:2rem}.dashboard-loading .brand-logo-full{height:min(42vw,180px);width:auto}.dashboard-loading-message{margin:0;color:#6b7280;font-weight:600}.dashboard-loading-spinner{width:28px;height:28px;border:3px solid #e5e7eb;border-radius:50%;animation:dashboard-spin .8s linear infinite}.dashboard-loading-spinner-rider{border-top-color:#16a34a}.dashboard-loading-spinner-contact{border-top-color:#2563eb}@keyframes dashboard-spin{to{transform:rotate(360deg)}}.track-map-wrap{position:relative;margin:1rem 0}.track-map-wrap:fullscreen{background:#fff;padding:1rem;display:flex;flex-direction:column}.track-map-wrap:fullscreen .track-map{flex:1;height:auto;min-height:0;margin:0;border-radius:0}.track-map-expand{position:absolute;top:.75rem;right:.75rem;border:1px solid #e5e7eb;background:#fffffff0;color:#111827;border-radius:999px;padding:.45rem .85rem;font-size:.85rem;font-weight:600;cursor:pointer}.track-map-expand:hover{background:#fff}.live-tracking-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin:.75rem 0 .25rem}.live-tracking-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:999px;background:#ecfdf5;border:1px solid #a7f3d0;color:#047857;font-weight:700;font-size:.85rem}.rider-connection-badge{display:inline-flex;align-items:center;padding:.4rem .75rem;border-radius:999px;border:1px solid transparent;font-weight:700;font-size:.85rem}.rider-connection-badge--online{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.rider-connection-badge--offline{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.tracking-contact-info{margin:.75rem 0;padding:.75rem 1rem;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.tracking-contact-info-title{margin:0 0 .35rem;font-weight:700;color:#0f172a}.live-tracking-dot{width:.55rem;height:.55rem;border-radius:999px;background:#10b981}.live-tracking-note{color:#6b7280;font-weight:500}.live-tracking-footer{margin-top:.75rem}.track-map{width:100%;height:320px;border:0;border-radius:12px;margin:1rem 0}.message-thread{display:flex;flex-direction:column;gap:.75rem;max-height:320px;overflow:auto;margin:1rem 0}.message{border-radius:10px;padding:.75rem;border:1px solid #e5e7eb}.message.rider{background:#f9fafb}.message.contact{background:#eff6ff;border-color:#bfdbfe}.message-meta{margin:0 0 .25rem;font-size:.8rem;color:#6b7280}.message p:last-child{margin:0}.message-form{display:grid;grid-template-columns:1fr auto;gap:.5rem}.notifications-section{margin-bottom:1.25rem}.notifications-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.notifications-header h3{margin:0;display:flex;align-items:center;gap:.5rem}.notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .4rem;border-radius:999px;background:#dc2626;color:#fff;font-size:.75rem;font-weight:800}.notifications-empty h3{margin-top:0}.notification-card.pending{border-color:#fcd34d;background:#fffbeb}.notification-type{margin:0 0 .35rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#2563eb}.notification-headline{margin:0 0 .35rem;font-weight:700;font-size:1rem}.scheduled-tracking-banner{margin:.75rem 0;padding:.85rem 1rem;border-radius:.75rem;border:1px solid #bfdbfe;background:#eff6ff}.scheduled-tracking-title{margin:0 0 .35rem;font-weight:700;color:#1e40af}.notification-actions{display:flex;gap:.5rem;margin-top:.85rem}.notification-actions .btn{flex:1}.tracking-help{margin-top:1.25rem;padding:1rem 1.1rem;border-radius:.85rem;border:1px solid #dbeafe;background:#f8fbff}.tracking-help-wide{margin-top:2rem}.tracking-help h3{margin:0 0 .65rem;font-size:1rem}.tracking-help-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.tracking-help-label{margin:0 0 .35rem;font-size:.85rem;font-weight:700;color:#1d4ed8}.tracking-steps,.tracking-bullets{margin:0;padding-left:1.2rem}.tracking-steps li,.tracking-bullets li{margin-bottom:.45rem}@media(max-width:800px){.dashboard-shell{grid-template-columns:1fr}.dashboard-sidebar{padding:1rem 1.25rem}.dashboard-sidebar nav{flex-direction:row;flex-wrap:wrap}.live-grid{grid-template-columns:1fr}.public-header{flex-direction:column;align-items:flex-start}.tracking-help-grid{grid-template-columns:1fr}}
