:root{--sidebar-width:280px;--bg-body:#f7f8fa;--bg-body-top:#fff;--bg-body-bottom:#eef1f6;--bg-body-gradient:linear-gradient(to bottom, var(--bg-body-top) 0%, var(--bg-body-bottom) 100%);--bg-surface:#fff;--bg-surface-subtle:#f1f3f8;--bg-input:#fff;--surface-hover:#eef2fb;--surface-active:#dbe4ff;--border-color:#d3d8e1;--border-input:#c0c6d2;--divider-color:#22222214;--text-body:#222;--text-muted:#6b7280;--color-primary:#007bff;--color-primary-hover:#0069d9;--color-primary-contrast:#fff;--color-primary-rgb:0, 123, 255;--color-accent:#fc0;--color-accent-hover:#e6b800;--color-accent-contrast:#1f1f1f;--color-accent-rgb:255, 204, 0;--color-link:var(--color-primary);--color-link-hover:#0056b3;--focus-ring:rgba(var(--color-primary-rgb), .28);--shadow-soft:#0f172a14;--shadow-medium:#0f172a24;--shadow-strong:#0f172a33;--bs-body-bg:var(--bg-body);--bs-body-color:var(--text-body);--bs-border-color:var(--border-color);--bs-card-bg:var(--bg-surface);--bs-card-border-color:var(--border-color);--bs-tertiary-bg:var(--bg-surface-subtle);--bs-link-color:var(--color-link);--bs-link-hover-color:var(--color-link-hover);--bs-primary:var(--color-primary);--bs-primary-rgb:var(--color-primary-rgb)}body{min-height:100vh;color:var(--text-body);background-color:var(--bg-body);background-image:var(--bg-body-gradient);background-repeat:no-repeat}.navbar{min-height:64px}.portal-navbar{background:var(--bg-surface);border-bottom:1px solid var(--border-color);box-shadow:0 12px 26px -22px var(--shadow-strong)}.portal-brand-logo{object-fit:contain;border-radius:.25rem;width:128px;height:44px}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);z-index:1020;position:fixed;top:64px;bottom:0;overflow-y:auto}.sidebar-group{color:var(--bs-secondary-color);letter-spacing:.08em;text-transform:uppercase;margin:1rem .75rem .35rem;font-size:.72rem;font-weight:700}.sidebar .nav-link{color:var(--bs-body-color);border-radius:.55rem}.sidebar .nav-link:hover{background:var(--bs-secondary-bg)}.sidebar .nav-link.active{color:var(--color-primary-contrast);background:var(--color-primary)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;padding-top:64px}.portal-map{background:var(--bs-secondary-bg);min-height:calc(100vh - 180px)}.vehicle-marker-icon.leaflet-div-icon{background:0 0;border:none}.vehicle-marker{text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;gap:.25rem;display:flex}.vehicle-marker__label{color:#fff;letter-spacing:.03em;white-space:nowrap;background:#212529d9;border-radius:999px;min-width:2.5rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;box-shadow:0 4px 10px #00000040}.vehicle-marker__icon{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;font-size:1.3rem;display:flex;position:relative;box-shadow:0 10px 18px -8px #00000080}.vehicle-marker__icon i{transform:rotate(var(--vehicle-heading,0deg));transform-origin:50%;line-height:1;transition:transform .15s ease-in-out;display:block}.vehicle-marker--has-heading .vehicle-marker__icon:after{content:"";filter:drop-shadow(0 1px 1px #00000059);width:0;height:0;transform:translateX(-50%) rotate(var(--vehicle-heading,0deg));transform-origin:50% 1.02rem;border-bottom:.54rem solid #fffffff2;border-left:.24rem solid #0000;border-right:.24rem solid #0000;position:absolute;top:.18rem;left:50%}.vehicle-marker--app.vehicle-marker--status-default .vehicle-marker__label,.vehicle-marker--app.vehicle-marker--status-default .vehicle-marker__icon{color:#212529;background:#fff;border:1px solid #dee2e6}.vehicle-marker--app.vehicle-marker--status-1 .vehicle-marker__label,.vehicle-marker--app.vehicle-marker--status-1 .vehicle-marker__icon{color:#fff;background:#1b5e20;border:none}.vehicle-marker--app.vehicle-marker--status-2 .vehicle-marker__label,.vehicle-marker--app.vehicle-marker--status-2 .vehicle-marker__icon{color:#fff;background:#f4a261;border:none}.vehicle-marker--app.vehicle-marker--status-3 .vehicle-marker__label,.vehicle-marker--app.vehicle-marker--status-3 .vehicle-marker__icon{color:#fff;background:#d55c5c;border:none}.btn-primary{--bs-btn-bg:var(--color-primary);--bs-btn-border-color:var(--color-primary);--bs-btn-hover-bg:var(--color-primary-hover);--bs-btn-hover-border-color:var(--color-primary-hover);--bs-btn-color:var(--color-primary-contrast);--bs-btn-hover-color:var(--color-primary-contrast)}.btn-outline-primary{--bs-btn-color:var(--color-primary);--bs-btn-border-color:color-mix(in srgb, var(--color-primary) 45%, var(--border-color));--bs-btn-hover-bg:var(--color-primary);--bs-btn-hover-border-color:var(--color-primary);--bs-btn-hover-color:#fff}.form-control,.form-select,.input-group-text,.btn{min-height:42px}.form-control,.input-group-text{color:var(--text-body);background:var(--bg-input);border-color:var(--border-input)}.form-control:focus,.form-select:focus,.btn:focus-visible{border-color:var(--color-primary);box-shadow:0 0 0 .2rem var(--focus-ring)}.login-page{background-color:var(--bg-body);background-image:var(--bg-body-gradient);place-items:center;min-height:100vh;display:grid}.login-card{background:var(--bg-surface);border-radius:1rem;box-shadow:0 24px 54px -34px var(--shadow-strong)!important}.login-logo{object-fit:contain;max-height:110px}.gold-divider{background:var(--color-accent);width:86px;height:3px;box-shadow:0 0 0 4px rgba(var(--color-accent-rgb), .12);border-radius:999px}.login-title{color:var(--text-body);font-weight:700}.customer-login-page{color:#17202a;background:#020b10;min-height:100vh}.customer-login-shell{min-height:100vh}.customer-login-stage{background-color:#020b10;background-image:radial-gradient(circle at 50% 42%,#00b4b033,#0000 18rem),linear-gradient(#000c1242,#000508db),url(/assets/customer/moviq-background.png),url(/assets/customer/login-hero.svg);background-position:50%,50%,50%,50%;background-size:cover,cover,cover,cover;place-items:center;min-height:100vh;padding:3rem 1rem 4.5rem;display:grid;position:relative;overflow:hidden}.customer-login-stage:before{content:"";pointer-events:none;background:radial-gradient(circle at 50% 46%,#00000014,#00000085 58%,#000000d6 100%);position:absolute;inset:0}.customer-login-stage:after{content:"";pointer-events:none;background:linear-gradient(#04101647 0%,#0410160a 35%,#0000007a 100%);position:absolute;inset:0}.customer-login-card{z-index:1;color:#1f2937;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;border:1px solid #ffffffbd;border-radius:1rem;width:min(100%,430px);padding:2rem;position:relative;box-shadow:0 28px 80px -38px #000000b8}.customer-login-brand{justify-content:center;margin-bottom:1.25rem;display:flex}.customer-login-logo{object-fit:contain;border-radius:.5rem;width:172px;height:auto}.customer-login-heading{text-align:center;margin-bottom:1.35rem}.customer-login-kicker{color:#0f9f9a;letter-spacing:.08em;text-transform:uppercase;margin:0 0 .5rem;font-size:.78rem;font-weight:850}.customer-login-title{color:#1f2937;letter-spacing:0;margin:0;font-size:2rem;font-weight:850;line-height:1.08}.customer-login-subtitle{color:#687385;max-width:23rem;margin:.75rem auto 0;font-size:.95rem;line-height:1.55}.customer-login-form .form-label{color:#3d4755;font-size:.84rem;font-weight:750}.customer-login-form .input-group{border-radius:.7rem;box-shadow:0 12px 30px -28px #0f172a61}.customer-login-form .form-control,.customer-login-form .input-group-text{background:#fbfcfe;border-color:#d8dee8;min-height:48px}.customer-login-form .input-group-text{color:#7a8494}.customer-login-form .form-control:focus{background:#fff}.customer-login-form .btn-primary{background:linear-gradient(135deg,#079b99,#07b7a8);border:0;border-radius:.72rem;min-height:52px;font-weight:850;box-shadow:0 16px 34px -22px #079b99e6}.customer-login-form .btn-primary:hover{background:linear-gradient(135deg,#068d8b,#079f93)}.customer-login-divider{color:#9aa3af;text-align:center;text-transform:uppercase;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem;margin:1.35rem 0 .85rem;font-size:.72rem;font-weight:850;display:grid}.customer-login-divider:before,.customer-login-divider:after{content:"";background:#e3e7ee;height:1px}.customer-login-note{color:#7b8493;text-align:center;margin:0;font-size:.84rem;line-height:1.45}.customer-login-register{color:#5f6978;text-align:center;margin:1rem 0 0;font-size:.92rem;font-weight:650}.customer-login-register a{color:#079b99;font-weight:850;text-decoration:none}.customer-login-register a:hover{color:#057f7c;text-decoration:underline}.customer-register-card{z-index:1;color:#1f2937;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;border:1px solid #ffffffbd;border-radius:1rem;width:min(100%,760px);padding:2rem;position:relative;box-shadow:0 28px 80px -38px #000000b8}.customer-register-form .form-control{min-height:46px}.customer-register-billing{color:#23615f;background:#079b9914;border:1px solid #079b9929;border-radius:.8rem;align-items:center;gap:.65rem;margin-top:1rem;padding:.85rem;font-size:.92rem;font-weight:700;display:flex}.customer-register-billing i{color:#079b99;font-size:1.2rem}.customer-login-trust{z-index:1;flex-wrap:wrap;justify-content:center;gap:.6rem;width:min(100% - 2rem,680px);margin-top:1rem;display:flex;position:relative}.customer-login-trust span{color:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#040e1470;border:1px solid #ffffff29;border-radius:999px;align-items:center;gap:.45rem;min-height:38px;padding:.4rem .75rem;font-size:.86rem;font-weight:700;display:inline-flex;box-shadow:0 18px 50px -34px #000000b8}.customer-login-trust i{color:#23d2c6}.customer-login-footer{z-index:1;color:#ffffffc2;flex-wrap:wrap;justify-content:center;gap:.85rem;font-size:.82rem;display:flex;position:absolute;bottom:1.2rem;left:1.5rem;right:1.5rem}.customer-login-footer a{color:#fffc;text-decoration:none}.customer-login-footer a:hover{color:#fff;text-decoration:underline}th{white-space:nowrap;text-transform:capitalize}td{overflow-wrap:anywhere;max-width:360px}@media (width<=991.98px){.sidebar{top:0}.main-content{margin-left:0}}@media (width<=575.98px){.portal-navbar .navbar-brand span{display:none}.portal-brand-logo{width:112px}}.customer-shell{--customer-max-width:1320px;background:radial-gradient(circle at 12% 8%,#ffcc001f,#0000 26rem),linear-gradient(#fff 0%,#f4f7fb 42%,#eef3f4 100%)}.customer-navbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;border-bottom:1px solid #0f172a14;min-height:72px}.customer-brand-logo{object-fit:contain;border-radius:.35rem;width:124px;height:42px}.customer-main{min-height:100vh;padding-top:72px}.customer-container{max-width:var(--customer-max-width);padding:1.25rem}.customer-nav{align-items:center;gap:.25rem;display:flex}.customer-nav--stacked{gap:.5rem;display:grid}.customer-nav-link{min-height:42px;color:var(--text-body);border-radius:.75rem;align-items:center;gap:.45rem;padding:.55rem .75rem;font-weight:600;text-decoration:none;display:inline-flex}.customer-nav-link:hover{color:var(--color-primary);background:var(--surface-hover)}.customer-nav-link.active{color:var(--color-primary);background:rgba(var(--color-primary-rgb), .1)}.customer-hero{box-shadow:0 24px 60px -46px var(--shadow-strong);background:#ffffffc7;border:1px solid #0f172a14;border-radius:1.25rem;grid-template-columns:minmax(0,1fr) minmax(320px,460px);align-items:stretch;gap:1.5rem;padding:clamp(1.25rem,3vw,2rem);display:grid}.customer-kicker{color:#087f5b;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;font-weight:800}.customer-title{letter-spacing:0;max-width:780px;font-size:clamp(2rem,4vw,3.7rem);font-weight:800;line-height:1.02}.next-trip-card,.customer-card,.review-panel{box-shadow:0 18px 46px -38px var(--shadow-strong);background:#fff;border:1px solid #0f172a14;border-radius:1rem}.next-trip-card{padding:1.25rem}.next-trip-meta,.trip-meta{color:var(--text-muted);flex-wrap:wrap;gap:.65rem;font-size:.92rem;display:flex}.next-trip-meta span,.trip-meta span{align-items:center;gap:.4rem;display:inline-flex}.section-heading{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.section-heading h2{margin:0;font-size:1.15rem;font-weight:800}.customer-action-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.mobility-action{min-height:136px;color:var(--text-body);box-shadow:0 16px 38px -34px var(--shadow-strong);background:#fff;border:1px solid #0f172a14;border-radius:1rem;align-items:flex-start;gap:1rem;padding:1.15rem;text-decoration:none;transition:transform .16s,box-shadow .16s,border-color .16s;display:flex}.mobility-action:hover{border-color:rgba(var(--color-primary-rgb), .25);box-shadow:0 24px 54px -38px var(--shadow-strong);transform:translateY(-2px)}.mobility-action--primary{color:#fff;background:linear-gradient(135deg, var(--color-primary), #0b7285)}.mobility-action--primary small{color:#ffffffd1}.mobility-action-icon,.card-icon{width:2.7rem;height:2.7rem;color:var(--color-primary);background:rgba(var(--color-primary-rgb), .1);border-radius:.8rem;flex:none;justify-content:center;align-items:center;font-size:1.25rem;display:inline-flex}.mobility-action--primary .mobility-action-icon{color:#16202a;background:#ffcc00eb}.mobility-action strong,.mobility-action small{display:block}.mobility-action strong{margin-bottom:.35rem;font-size:1.05rem}.mobility-action small{color:var(--text-muted);line-height:1.4}.customer-timeline{gap:.85rem;display:grid}.timeline-item{grid-template-columns:1.25rem minmax(0,1fr);gap:.85rem;display:grid;position:relative}.timeline-dot{background:#087f5b;border:3px solid #fff;border-radius:50%;width:.8rem;height:.8rem;margin-top:.55rem;box-shadow:0 0 0 3px #087f5b24}.timeline-content{background:#ffffffe6;border:1px solid #0f172a14;border-radius:1rem;padding:1rem}.page-intro{padding:.5rem 0}.customer-card,.review-panel{padding:1.25rem}.smart-input{resize:vertical;min-height:180px;font-size:1.05rem}.recognized-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.recognized-item{background:var(--bg-surface-subtle);border-radius:.85rem;padding:.9rem}.recognized-item span,.profile-list dt{color:var(--text-muted);text-transform:uppercase;font-size:.78rem;font-weight:700;display:block}.recognized-item strong{overflow-wrap:anywhere;margin-top:.35rem;display:block}.status-pill{color:#0b3b2e;background:#087f5b1f;border-radius:999px;align-items:center;min-height:28px;padding:.2rem .65rem;font-size:.78rem;font-weight:800;display:inline-flex}.status-pill--active{color:#084298;background:rgba(var(--color-primary-rgb), .12)}.status-pill--completed{color:#0f5132;background:#19875424}.status-pill--cancelled{color:#842029;background:#dc35451f}.customer-tabs{gap:.5rem}.customer-tabs .nav-link{color:var(--text-body);background:#fff;border:1px solid #0f172a14}.customer-tabs .nav-link.active{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.trip-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.trip-card{box-shadow:0 16px 38px -34px var(--shadow-strong);background:#fff;border:1px solid #0f172a14;border-radius:1rem;padding:1.15rem}.trip-route{gap:.65rem;display:grid}.trip-route div{grid-template-columns:1.5rem minmax(0,1fr);align-items:start;gap:.5rem;display:grid}.trip-route i{color:var(--color-primary)}.empty-state{min-height:160px;color:var(--text-muted);background:#ffffffa6;border:1px dashed #0f172a2e;border-radius:1rem;grid-column:1/-1;justify-content:center;align-items:center;gap:.75rem;display:flex}.invoice-list{gap:.75rem;display:grid}.invoice-item{background:var(--bg-surface-subtle);border-radius:1rem;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;display:flex}.invoice-summary{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.65rem;display:flex}.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.profile-list{gap:.85rem;margin:0;display:grid}.profile-list div{gap:.2rem;display:grid}.profile-list dd{overflow-wrap:anywhere;margin:0;font-weight:650}.profile-person{border-top:1px solid #0f172a14;align-items:flex-start;gap:.8rem;padding:.85rem 0;display:flex}.profile-person:first-of-type{border-top:0;padding-top:0}.profile-person i{color:var(--color-primary);font-size:1.4rem}.profile-person strong,.profile-person span,.profile-person small{display:block}.profile-person span,.profile-person small{color:var(--text-muted)}.chip-list{flex-wrap:wrap;gap:.55rem;display:flex}.chip{color:#253142;background:var(--bg-surface-subtle);border-radius:999px;align-items:center;min-height:34px;padding:.35rem .75rem;font-weight:650;display:inline-flex}@media (width<=1199.98px){.customer-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.customer-hero{grid-template-columns:1fr}}@media (width<=991.98px){.customer-container{padding:1rem}.trip-grid,.profile-grid{grid-template-columns:1fr}.recognized-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=767.98px){.customer-login-stage{background-image:radial-gradient(circle at 50% 22%,#00b4b02e,#0000 14rem),linear-gradient(#00080d70,#000407e6),url(/assets/customer/moviq-background.png),url(/assets/customer/login-hero.svg);place-items:start center;min-height:100svh;padding:1.25rem 1rem 4.75rem}.customer-login-card,.customer-register-card{width:min(100%,430px);padding:1.35rem}.customer-login-trust{grid-template-columns:repeat(2,minmax(0,auto));width:min(100%,430px);display:grid}.customer-login-trust span{justify-content:center}.customer-login-footer{margin-top:1.5rem;position:relative;bottom:auto;left:auto;right:auto}}@media (width<=575.98px){.customer-navbar .navbar-brand span{display:none}.customer-action-grid,.recognized-grid{grid-template-columns:1fr}.mobility-action{min-height:118px}.invoice-item{flex-direction:column;align-items:flex-start}.invoice-summary{justify-content:flex-start}.customer-title{font-size:2rem}.customer-login-title{font-size:1.8rem}.customer-login-subtitle{font-size:1rem}.customer-login-trust{grid-template-columns:1fr}}@media (width<=389.98px){.customer-login-stage{padding:1rem .75rem 4rem}.customer-login-card,.customer-register-card{padding:1rem}.customer-login-logo{width:138px}.customer-login-title{font-size:1.6rem}.customer-login-subtitle{font-size:.9rem}.customer-login-form .form-control,.customer-login-form .input-group-text{min-height:46px}}
