:root{--pr:#3a4fb8;--pr-d:#2b3d92;--pr-l:#eaecf7;--acc:#0e8fb0;--grn:#16a34a;--red:#dc2626;--org:#ea580c;
--bg:#f7f8fc;--sur:#fff;--sur2:#f1f3f9;--bdr:#e4e7f0;--bdr2:#cbd2e1;
--tx:#262b3a;--tx2:#525a6e;--tx3:#98a0b0;
--font-head:'Poppins','Inter',sans-serif;
--sh:0 1px 3px rgba(0,0,0,.1);--sh-lg:0 10px 15px -3px rgba(0,0,0,.1);
--r:12px;--rs:8px}
/* Attractive headings (Poppins); body stays Inter */
h1,h2,h3,h4,.pg-t,.auth-logo,.nav-logo,.section h3,.adm-title,.seg-banner-name,.seg-card-name,
.pkg-name,.place-name,.trip-route,.ride-route,.stat-val,.hero h1{font-family:var(--font-head);letter-spacing:-.01em;line-height:1.25}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--tx);font-size:15px;line-height:1.6;letter-spacing:.05px}
a{color:var(--pr);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px;text-decoration-color:color-mix(in srgb,var(--pr) 38%,transparent);transition:text-decoration-color .15s}
a:hover{text-decoration-color:var(--pr)}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}img{max-width:100%}
.hidden{display:none!important}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.text-center{text-align:center}
.text-sm{font-size:13px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-semibold{font-weight:600}
.text-muted{color:var(--tx2)}.text-danger{color:var(--red)}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;
  border-radius:var(--rs);border:none;font-size:14px;font-weight:600;transition:all .15s;cursor:pointer}
.btn-pr{background:var(--pr);color:#fff}.btn-pr:hover{background:var(--pr-d)}
.btn-out{background:transparent;color:var(--pr);border:1.5px solid var(--pr)}.btn-out:hover{background:var(--pr-l)}
.btn-ghost{background:transparent;color:var(--tx2);border:1.5px solid var(--bdr)}.btn-ghost:hover{background:var(--sur2)}
.btn-red{background:var(--red);color:#fff}.btn-grn{background:var(--grn);color:#fff}
.btn-sm{padding:6px 14px;font-size:12px}.btn-lg{padding:13px 28px;font-size:16px;border-radius:var(--r)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* Forms */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fg label{font-size:12px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.4px}
.fc{width:100%;padding:10px 12px;border:1.5px solid var(--bdr);border-radius:var(--rs);
  font-size:14px;background:var(--sur);color:var(--tx);transition:border-color .15s}
.fc:focus{outline:none;border-color:var(--pr)}.fc::placeholder{color:var(--tx3)}
select.fc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2394a3b8' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;appearance:none}

/* Cards / Sections */
.card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh)}
.card-b{padding:24px}
.section{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;margin-bottom:18px}
.section h3{font-size:15px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}

/* Alerts */
.al{padding:10px 14px;border-radius:var(--rs);font-size:13px;font-weight:500}
.al-err{background:#fef2f2;color:var(--red);border:1px solid #fecaca}
.al-ok{background:#f0fdf4;color:var(--grn);border:1px solid #bbf7d0}
.al-info{background:var(--pr-l);color:var(--pr-d);border:1px solid #bfdbfe}
.al-warn{background:#fff7ed;color:var(--org);border:1px solid #fed7aa}

/* Badges */
.bdg{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700}
.bdg-bl{background:var(--pr-l);color:var(--pr)}.bdg-gn{background:#dcfce7;color:var(--grn)}
.bdg-rd{background:#fef2f2;color:var(--red)}.bdg-og{background:#fff7ed;color:var(--org)}
.bdg-gr{background:var(--sur2);color:var(--tx2)}.bdg-pu{background:#f3e8ff;color:#7c3aed}

/* Topnav */
#topnav{position:fixed;top:0;left:0;right:0;z-index:100;background:#fff;
  border-bottom:1px solid #e5e7eb;height:68px;display:flex;align-items:center;
  padding:0 32px;justify-content:space-between;box-shadow:0 1px 8px rgba(0,0,0,.06)}
.nav-logo{font-size:22px;font-weight:900;color:var(--tx);letter-spacing:-1px}
.nav-logo span{color:var(--pr)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links .btn-ghost{border:none;color:#444;font-weight:500;font-size:15px;padding:8px 14px;border-radius:8px}
.nav-links .btn-ghost:hover{background:#f3f4f6;color:#111}
.nav-av{width:38px;height:38px;border-radius:50%;background:var(--pr);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;cursor:pointer;
  box-shadow:0 2px 8px rgba(37,99,235,.35)}
.nav-av img{width:38px;height:38px;border-radius:50%;object-fit:cover}
#nav-auth-btn{background:#111;color:#fff;border-radius:99px;padding:10px 22px;font-size:14px;font-weight:700;border:none}
#nav-auth-btn:hover{background:#333}

/* Pages */
.page{padding-top:68px;min-height:100vh}
.pg{max-width:920px;margin:0 auto;padding:28px 16px}
.pg-t{font-size:23px;font-weight:800;margin-bottom:6px}
.pg-s{color:var(--tx2);margin-bottom:26px;font-size:14px;line-height:1.55}

/* Auth */
#pg-auth{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#0f2027,#203a43,#2c5364);padding-top:0!important}
.auth-box{background:var(--sur);border-radius:20px;padding:36px;width:100%;max-width:480px;
  box-shadow:0 25px 50px rgba(0,0,0,.4)}
.signup-title{font-size:18px;font-weight:800;color:var(--tx);margin-bottom:14px;text-align:center}
.auth-or{display:flex;align-items:center;text-align:center;color:var(--tx3);font-size:12px;margin:14px 0}
.auth-or::before,.auth-or::after{content:'';flex:1;height:1px;background:var(--bdr);margin:0 10px}
.auth-logo{font-size:26px;font-weight:800;color:var(--pr);text-align:center;margin-bottom:2px}
.auth-tagline{text-align:center;color:var(--tx2);font-size:13px;margin-bottom:24px}
.auth-tabs{display:flex;background:var(--sur2);border-radius:var(--rs);padding:4px;margin-bottom:22px}
.auth-tab{flex:1;padding:8px;text-align:center;border-radius:6px;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--tx2);border:none;background:transparent;transition:all .15s}
.auth-tab.active{background:var(--sur);color:var(--pr);box-shadow:var(--sh)}

/* Signup role selector */
.role-seg{display:flex;gap:8px}
.role-opt{flex:1;padding:11px;border-radius:var(--rs);border:1.5px solid var(--bdr);
  background:var(--sur);color:var(--tx2);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}
.role-opt:hover{border-color:var(--bdr2)}
.role-opt.active{border-color:var(--pr);background:var(--pr-l);color:var(--pr-d)}
.chk-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2);margin:6px 0 4px;cursor:pointer}
.chk-row input{width:16px;height:16px}

/* Verify */
#pg-verify{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#0f2027,#203a43,#2c5364);padding-top:0!important}
.verify-box{background:var(--sur);border-radius:20px;padding:40px;width:100%;max-width:400px;
  text-align:center;box-shadow:0 25px 50px rgba(0,0,0,.4)}
.verify-icon{font-size:56px;margin-bottom:16px}

/* Hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;
  background:url('https://images.unsplash.com/photo-1692792284356-f80113facd09?w=1600&q=80') center/cover no-repeat,linear-gradient(135deg,#1e3a5f,#3f7d62)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.38) 60%,rgba(0,0,0,.1) 100%)}
.hero-in{position:relative;max-width:1100px;margin:0 auto;padding:80px 32px 60px;width:100%;
  display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:center}
.hero-text{}
.hero h1{font-size:52px;font-weight:900;color:#fff;line-height:1.08;margin-bottom:16px;letter-spacing:-1.5px}
.hero h1 span{color:#93c5fd}
.hero p{color:rgba(255,255,255,.75);font-size:17px;margin-bottom:32px;max-width:440px;line-height:1.6}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:99px;
  padding:7px 14px;font-size:13px;color:#fff;font-weight:500}
/* Booking widget */
.bw{background:#fff;border-radius:20px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.bw h3{font-size:17px;font-weight:800;margin-bottom:18px;color:var(--tx)}
.bw-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bw .fc{border-radius:10px;padding:12px 14px;border:1.5px solid #e5e7eb;font-size:14px}
.bw .fc:focus{border-color:var(--pr)}
.bw .fg label{color:#666;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.bw-divider{height:1px;background:#f3f4f6;margin:4px 0 14px}
.ac-wrap{position:relative}
.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;
  border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:50;max-height:200px;overflow-y:auto}
.ac-item{padding:11px 14px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px;color:#333}
.ac-item:hover,.ac-item.ac-active{background:var(--pr-l)}
@media(max-width:900px){.hero-in{grid-template-columns:1fr}.hero h1{font-size:36px}.bw{max-width:100%}}

/* Packages */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.pkg-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pkg-grid{grid-template-columns:1fr}}
.pkg-card{border-radius:16px;overflow:hidden;background:#fff;border:1px solid #f0f0f0;
  cursor:pointer;transition:all .2s;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.pkg-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.12)}
.pkg-img{height:180px;object-fit:cover;width:100%;display:block}
.pkg-body{padding:16px}
.pkg-name{font-size:15px;font-weight:800;margin-bottom:3px;color:var(--tx)}
.pkg-route{font-size:12px;color:#888;margin-bottom:10px;display:flex;gap:8px}
.pkg-prices{display:flex;gap:6px;flex-wrap:wrap}
.pkg-pr{padding:4px 10px;background:#f0f5ff;color:var(--pr);border-radius:99px;font-size:11px;font-weight:700}

/* Rides */
.ride-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);
  padding:18px;margin-bottom:14px;transition:box-shadow .15s}
.ride-card:hover{box-shadow:var(--sh-lg)}
.ride-route{font-size:17px;font-weight:700;margin-bottom:6px}
.ride-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--tx2);font-size:13px;margin-bottom:14px}
.car-opts{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.car-opt{border:1.5px solid var(--bdr);border-radius:var(--rs);padding:12px;
  cursor:pointer;transition:all .15s;text-align:center}
.car-opt:hover,.car-opt.sel{border-color:var(--pr);background:var(--pr-l)}
.car-opt-name{font-weight:700;font-size:13px}
.car-opt-price{color:var(--pr);font-weight:800;font-size:15px}
.car-opt-seats{color:var(--tx2);font-size:11px;margin-top:2px}
.gp-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;
  border-radius:99px;font-size:12px;font-weight:600}
.gp-w{background:#fdf4ff;color:#a21caf;border:1px solid #e9d5ff}
.gp-a{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}

/* Seat map */
.seat-wrap{background:var(--sur2);border-radius:var(--r);padding:20px;margin:16px 0}
.seat-legend{display:flex;gap:14px;margin-bottom:14px;font-size:12px;font-weight:600;flex-wrap:wrap}
.leg-item{display:flex;align-items:center;gap:5px}
.seat-grid{display:flex;flex-direction:column;gap:8px;align-items:center}
.seat-row{display:flex;gap:8px;align-items:center}
.seat-aisle{width:20px}
.seat{width:40px;height:40px;border-radius:8px 8px 4px 4px;border:2px solid transparent;
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;
  cursor:pointer;transition:all .15s;position:relative;flex-shrink:0}
.s-av{background:#dcfce7;border-color:#86efac;color:var(--grn)}
.s-av:hover{background:#bbf7d0;transform:scale(1.08)}
.s-bm{background:#dbeafe;border-color:#93c5fd;color:var(--pr);cursor:default}
.s-bf{background:#fdf4ff;border-color:#e9d5ff;color:#a21caf;cursor:default}
.s-sel{background:var(--pr);border-color:var(--pr-d);color:#fff;transform:scale(1.08)}
.s-drv{background:#f1f5f9;border-color:var(--bdr2);color:var(--tx3);cursor:default;font-size:16px}
.s-tip{position:absolute;bottom:110%;left:50%;transform:translateX(-50%);background:#0f172a;
  color:#fff;padding:3px 7px;border-radius:4px;font-size:10px;white-space:nowrap;
  pointer-events:none;opacity:0;transition:opacity .15s;z-index:10}
.seat:hover .s-tip{opacity:1}

/* Driver registration wizard */
.req{color:var(--red);font-weight:700}
.dreg-bar{background:var(--pr-l);color:var(--pr-d);font-weight:700;font-size:13px;
  padding:9px 14px;border-radius:var(--rs);margin:10px 0 8px}
.dreg-prog{height:6px;background:var(--bdr);border-radius:4px;margin:0 0 16px;overflow:hidden}
.dreg-prog-fill{height:100%;background:var(--pr);transition:width .25s}
.car-entry{border:1px solid var(--bdr);border-radius:var(--r);padding:12px 14px;margin-bottom:10px;background:var(--sur2)}
.car-prev{display:flex;align-items:center;gap:10px;background:var(--sur);border:1px solid var(--bdr);border-radius:var(--rs);padding:8px 12px;margin-bottom:10px}
.car-prev-emoji{font-size:30px;line-height:1}
.car-prev-label{font-weight:700;font-size:13px;color:var(--tx2)}
/* Rider car-model chooser */
.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:6px}
.model-card{display:flex;flex-direction:column;text-align:left;background:var(--sur);border:2px solid var(--bdr);border-radius:var(--rs);padding:0;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.model-card:hover{border-color:var(--pr)}
.model-card.sel{border-color:var(--pr);box-shadow:0 0 0 3px color-mix(in srgb,var(--pr) 25%,transparent)}
.model-img{width:100%;height:84px;object-fit:cover;display:block}
.model-img.model-ph{display:flex;align-items:center;justify-content:center;font-size:38px;background:var(--bg2,#f1f3f5)}
.model-name{font-weight:700;font-size:13px;padding:7px 9px 0;line-height:1.2}
.model-avail{font-size:11px;color:var(--ok,#1a8f4c);font-weight:700;padding:2px 9px 9px}
/* Image-upload field preview */
.img-cur{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.img-cur-thumb{width:84px;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--bdr)}
/* Admin day calendar */
.cal-wrap{margin-top:10px;border:1px solid var(--bdr);border-radius:var(--rs);overflow:hidden}
.cal-hr{display:grid;grid-template-columns:64px 1fr;border-top:1px solid var(--bdr)}
.cal-hr:first-child{border-top:0}
.cal-hr-lbl{padding:8px 8px;font-size:12px;font-weight:700;color:var(--tx2);background:var(--bg2,#f6f7f9);border-right:1px solid var(--bdr)}
.cal-hr-body{padding:6px;display:flex;flex-direction:column;gap:6px;min-height:34px}
.cal-empty{min-height:18px}
.cal-ride{display:flex;align-items:center;gap:10px;background:var(--sur);border:1px solid var(--bdr);border-left:3px solid var(--pr);border-radius:8px;padding:8px 10px;cursor:pointer;transition:background .12s}
.cal-ride:hover{background:var(--bg2,#f1f5ff)}
.cal-ride-t{font-weight:800;font-size:13px;min-width:52px}
.cal-ride-main{flex:1;font-size:13px;line-height:1.3}
.cal-ride-sub{font-size:11px;color:var(--tx2)}
/* Fill-first "leaving soon" cab option */
.car-opt{position:relative}
.car-opt-soon{border-color:var(--pr);box-shadow:0 0 0 2px color-mix(in srgb,var(--pr) 22%,transparent)}
.car-opt-badge{font-size:10px;font-weight:800;color:#b34700;margin-top:3px}
/* Segment banner + car-model option rows in rider search */
.seg-block{margin-top:12px}
.seg-banner{display:flex;align-items:center;gap:8px;background:var(--bg2,#eef2f7);border-radius:8px;padding:8px 11px;margin-bottom:7px}
.seg-banner-emoji{font-size:20px;line-height:1}
.seg-banner-name{flex:1;font-weight:800;font-size:15px}
.seg-banner-rate{font-weight:800;color:var(--pr);font-size:14px}
.seg-opt{display:flex;align-items:center;gap:11px;border:1px solid var(--bdr);border-radius:10px;padding:8px 10px;margin:0 0 6px 6px;cursor:pointer;transition:background .12s,border-color .12s}
.seg-opt:hover{border-color:var(--pr);background:var(--bg2,#f3f7ff)}
.seg-opt-img{width:64px;height:42px;object-fit:cover;border-radius:6px;flex-shrink:0;background:#eef1f4}
.seg-opt-main{flex:1;min-width:0}
.seg-opt-name{font-weight:700;font-size:14px}
.seg-soon{font-size:10px;font-weight:800;color:#b34700}
.seg-opt-sub{font-size:12px;color:var(--tx2);margin-top:1px}
/* #51 — car-model "playing cards" under each segment banner (shadow, like packages) */
.seg-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px;margin:0 0 6px 0}
.seg-card{position:relative;background:var(--sur);border:1px solid var(--bdr);border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.08);transition:transform .14s ease,box-shadow .14s ease}
.seg-card:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.15)}
.seg-card-img{width:100%;height:98px;object-fit:cover;display:block;background:#eef1f4}
.seg-card-body{padding:9px 11px 11px}
.seg-card-name{font-weight:700;font-size:13.5px;line-height:1.2}
.seg-card-rate{font-weight:800;font-size:17px;color:var(--pr);margin:4px 0 1px}
.seg-card-rate span{font-size:11px;font-weight:600;color:var(--tx2)}
.seg-card-meta{font-size:11px;color:var(--tx2);margin-bottom:8px}
.seg-card-badge{position:absolute;top:7px;left:7px;background:#fff3e0;color:#b34700;font-size:10px;font-weight:800;padding:2px 8px;border-radius:11px;z-index:1;box-shadow:0 1px 3px rgba(0,0,0,.15)}
/* #52 — Book now / Schedule for later toggle on the home search */
.when-tabs{display:flex;gap:8px;margin-bottom:10px}
.when-tab{flex:1;padding:11px 8px;border:1.5px solid var(--bdr);border-radius:12px;background:#fff;font-weight:700;font-size:14px;cursor:pointer;color:var(--tx2);transition:border-color .12s,background .12s,color .12s}
.when-tab.active{border-color:var(--pr);background:color-mix(in srgb,var(--pr) 9%,#fff);color:var(--pr)}
/* Destination photo gallery + package stop chips */
.place-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:2px 0 10px}
.place-gallery img{width:100%;height:92px;object-fit:cover;border-radius:8px;cursor:pointer;border:1px solid var(--bdr)}
.pkg-stops{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}
.pkg-stop{background:var(--sur);border:1px solid var(--bdr);border-radius:20px;padding:6px 13px;font-size:13px;font-weight:600;cursor:pointer;color:var(--tx2);transition:border-color .12s,color .12s}
.pkg-stop:hover{border-color:var(--pr);color:var(--pr)}
.terms-body{white-space:pre-wrap;font-size:13.5px;line-height:1.6;color:var(--tx2);
  background:var(--sur2);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;max-height:62vh;overflow-y:auto}

/* Maps (#17/#18) */
.place-map{width:100%;height:260px;border-radius:var(--r);border:1px solid var(--bdr);margin-top:4px}
.dm-map{width:100%;height:220px;border-radius:var(--rs);border:1px solid var(--bdr);margin-bottom:8px;background:var(--sur2)}

/* Places & package detail pages (#33, #34) */
.place-hero{width:100%;height:240px;object-fit:cover;border-radius:var(--r)}
.itin{border-left:2px solid var(--bdr);margin:6px 0 4px;padding-left:14px}
.itin-row{display:flex;gap:12px;padding:7px 0;font-size:14px;color:var(--tx2)}
.itin-time{min-width:74px;font-weight:700;color:var(--pr)}

/* New-user walkthrough (#21) */
.wt-overlay{position:fixed;inset:0;z-index:9500;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;padding:20px}
.wt-card{background:var(--sur);border-radius:20px;padding:30px 26px;width:100%;max-width:420px;text-align:center;box-shadow:0 25px 50px rgba(0,0,0,.4)}
.wt-emoji{font-size:44px;margin-bottom:8px}
.wt-title{font-size:20px;font-weight:800;margin-bottom:8px}
.wt-body{font-size:14px;color:var(--tx2);line-height:1.6;min-height:66px}
.wt-dots{display:flex;gap:6px;justify-content:center;margin:14px 0}
.wt-dot{width:7px;height:7px;border-radius:50%;background:var(--bdr2)}
.wt-dot.on{background:var(--pr);width:18px;border-radius:4px}
.wt-actions{display:flex;justify-content:space-between;align-items:center;margin-top:6px}

/* Driver availability calendar (#41) */
.dcal-workhours{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--pr-l);color:var(--pr-d);
  border-radius:var(--rs);padding:8px 12px;font-size:13px;margin-bottom:10px}
.dcal-workhours .fc{width:auto;padding:6px 8px}
.dc-block{display:flex;align-items:center;gap:8px;margin:6px 0;font-size:13px}
.dc-block .fc{width:auto;padding:6px 8px}
.dcal-head{display:flex;align-items:center;justify-content:space-between;margin:4px 0 8px}
.dcal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;font-size:11px;font-weight:700;color:var(--tx3);text-align:center;margin-bottom:4px}
.dcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.dcal-cell{min-height:54px;border:1px solid var(--bdr);border-radius:8px;padding:4px;cursor:pointer;font-size:11px;transition:background .12s}
.dcal-cell:hover{background:var(--sur2)}
.dcal-empty{border:none;cursor:default;background:transparent}
.dcal-d{font-weight:700;font-size:12px}
.dcal-today{outline:2px solid var(--pr)}
.dcal-trips{color:var(--pr);font-weight:700;margin-top:2px}
.dcal-tag{font-size:9px;font-weight:700;text-transform:uppercase;margin-top:2px}
.dcal-off{background:#fef2f2}.dcal-off .dcal-tag{color:var(--red)}
.dcal-busy{background:#fff7ed}.dcal-busy .dcal-tag{color:var(--org)}
.dcal-work{background:#f0fdf4}.dcal-work .dcal-tag{color:var(--grn)}
.dcal-legend{display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-size:11px;color:var(--tx2);margin-top:8px}
.dcal-k{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:middle;margin-right:2px}
.dcal-k.dcal-off{background:#fecaca}.dcal-k.dcal-busy{background:#fed7aa}.dcal-k.dcal-work{background:#bbf7d0}
.dcal-trips-k{color:var(--pr);background:none;width:auto}

/* Admin search bar */
.adm-searchbar{max-width:1100px;margin:0 auto;padding:12px 16px 0;display:flex;align-items:center;gap:10px}
.adm-searchbar .fc{max-width:520px}
.adm-search-count{font-size:12px;color:var(--tx2);white-space:nowrap}

/* Admin full detail view (#28) */
.doc-thumb{width:92px;height:62px;object-fit:cover;border-radius:8px;border:1px solid var(--bdr);vertical-align:middle}
.doc-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--bdr);flex-wrap:wrap}
.doc-lbl{font-weight:700;font-size:13px;min-width:110px}
.udetail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:13px}
.udetail h4{font-size:14px;font-weight:800}

/* #31 — no text caret/selection on clickable chrome */
.nav-logo,.auth-tab,.role-opt,.home-tog-opt,.adm-sb-item,.tg-wrap,.btn{user-select:none}

/* #32 — global page loader (slow networks) */
.page-loader{position:fixed;inset:0;background:rgba(248,250,252,.65);display:flex;align-items:center;justify-content:center;z-index:8000}
.page-loader .spin{width:38px;height:38px}

/* Star rating widget */
.star-row{display:flex;gap:4px}
.star{font-size:28px;line-height:1;color:var(--bdr2);cursor:pointer;transition:color .1s,transform .1s}
.star:hover{transform:scale(1.15)}
.star.on{color:#f59e0b}

/* Live trip viewpoints + banner */
.vp-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--bdr)}
.vp-thumb{width:54px;height:54px;border-radius:10px;object-fit:cover;flex-shrink:0}
.vp-thumb-ph{display:flex;align-items:center;justify-content:center;background:var(--sur2);font-size:22px}
.vp-info{flex:1;min-width:0}
.vp-name{font-weight:700;font-size:14px}
.vp-desc{font-size:12px;color:var(--tx2);line-height:1.4}
.vp-dist{font-size:12px;font-weight:700;color:var(--pr);white-space:nowrap}
.live-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--pr);color:#fff;
  padding:11px 16px;text-align:center;font-weight:700;font-size:14px;box-shadow:var(--sh-lg)}

/* Home booking-widget toggle (Packages / Pickup-Drop) */
.home-toggle{display:flex;gap:6px;background:var(--sur2);border-radius:var(--rs);padding:4px;margin-bottom:16px}
.home-tog-opt{flex:1;padding:9px;border:none;background:transparent;border-radius:6px;
  font-size:13px;font-weight:700;color:var(--tx2);cursor:pointer;transition:all .15s}
.home-tog-opt.active{background:var(--sur);color:var(--pr);box-shadow:var(--sh)}

/* Realistic in-car seat layout */
.car-body{max-width:300px;margin:10px auto 4px;background:linear-gradient(180deg,#eef2f7,#e2e8f0);
  border:3px solid var(--bdr2);border-radius:64px 64px 22px 22px;padding:14px 18px 18px;
  position:relative;box-shadow:var(--sh-lg)}
.car-body::before,.car-body::after{content:'';position:absolute;top:82px;width:7px;height:28px;
  background:var(--bdr2);border-radius:4px}                 /* side mirrors */
.car-body::before{left:-9px}
.car-body::after{right:-9px}
.car-windshield{height:26px;border-radius:42px 42px 8px 8px;background:rgba(148,163,184,.22);
  border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:var(--tx2);margin-bottom:14px}
.car-row{display:flex;justify-content:space-between;gap:10px;margin-bottom:12px;padding:0 2px}
.car-row-front{margin-bottom:18px}
.car-trunk{height:9px;border-radius:6px;background:rgba(148,163,184,.22);margin-top:4px}
.steer{width:26px;height:26px;border-radius:50%;border:3px solid var(--tx3);position:relative;display:inline-block}
.steer::before{content:'';position:absolute;inset:7px;border-radius:50%;background:var(--tx3)}
.steer::after{content:'';position:absolute;top:50%;left:1px;right:1px;height:3px;background:var(--tx3);transform:translateY(-50%)}

/* Fellow passengers */
.fp-card{display:flex;align-items:center;gap:12px;padding:14px;
  border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:10px;background:var(--sur)}
.fp-av{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--pr);
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px}
.fp-info{flex:1;min-width:0}
.fp-name{font-weight:700;font-size:14px}
.fp-meta{font-size:12px;color:var(--tx2)}

/* Profile */
.prof-hdr{display:flex;align-items:center;gap:18px;margin-bottom:20px;
  background:var(--sur);border-radius:var(--r);padding:20px;border:1px solid var(--bdr)}
.prof-av{width:76px;height:76px;border-radius:50%;background:var(--pr);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;
  border:3px solid var(--pr-l);overflow:hidden;flex-shrink:0}
.prof-av img{width:76px;height:76px;object-fit:cover}
.prof-name{font-size:21px;font-weight:800}

/* Toggle */
.tg-wrap{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:8px 0}
.tg{width:44px;height:24px;border-radius:99px;background:var(--bdr);
  position:relative;transition:background .2s;flex-shrink:0;margin-top:2px}
.tg.on{background:var(--pr)}
.tg::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;
  background:#fff;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.tg.on::after{left:23px}

/* Trips */
.trip-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);
  padding:18px;margin-bottom:14px}
.trip-route{font-size:16px;font-weight:700}
.trip-meta{font-size:13px;color:var(--tx2);margin-top:4px;display:flex;gap:14px;flex-wrap:wrap}

/* Chat */
.chat-win{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;margin-top:16px}
.chat-hdr{padding:12px 16px;border-bottom:1px solid var(--bdr);font-weight:700;
  display:flex;align-items:center;gap:10px}
.chat-msgs{padding:14px;height:260px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.chat-msg{max-width:72%;padding:9px 13px;border-radius:12px;font-size:14px}
.cm-me{align-self:flex-end;background:var(--pr);color:#fff;border-bottom-right-radius:3px}
.cm-th{align-self:flex-start;background:var(--sur2);border-bottom-left-radius:3px}
.cm-t{font-size:10px;opacity:.6;margin-top:3px}
.chat-in-row{display:flex;gap:8px;padding:10px;border-top:1px solid var(--bdr)}
.chat-in{flex:1;padding:9px 14px;border:1.5px solid var(--bdr);border-radius:99px;font-size:14px;outline:none}
.chat-in:focus{border-color:var(--pr)}

/* Admin */
#pg-admin{padding-top:60px;min-height:100vh}
.adm-layout{display:flex;min-height:calc(100vh - 60px)}
.adm-sb{width:210px;background:var(--sur);border-right:1px solid var(--bdr);
  padding:14px 0;flex-shrink:0;position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto}
.adm-sb-sec{font-size:10px;font-weight:700;color:var(--tx3);text-transform:uppercase;
  letter-spacing:.8px;padding:12px 18px 4px}
.adm-sb-item{display:flex;align-items:center;gap:9px;padding:10px 18px;cursor:pointer;
  font-size:14px;font-weight:500;color:var(--tx2);border-left:3px solid transparent;transition:all .1s}
.adm-sb-item:hover{background:var(--sur2);color:var(--tx)}
.adm-sb-item.active{color:var(--pr);background:var(--pr-l);border-left-color:var(--pr);font-weight:700}
.adm-body{flex:1;padding:24px;overflow-y:auto;max-width:100%}
.adm-title{font-size:21px;font-weight:800;margin-bottom:20px}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:22px}
.stat-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);padding:16px}
.stat-val{font-size:28px;font-weight:800;color:var(--pr)}.stat-lbl{font-size:12px;color:var(--tx2);margin-top:3px}
.tbl-wrap{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{text-align:left;padding:10px 12px;background:var(--sur2);font-weight:700;
  color:var(--tx2);border-bottom:1px solid var(--bdr)}
table.tbl td{padding:10px 12px;border-bottom:1px solid var(--bdr);vertical-align:middle}
table.tbl tr:last-child td{border-bottom:none}
table.tbl tr:hover td{background:var(--sur2)}
.adm-bar{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap}

/* Modal */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;
  display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--sur);border-radius:18px;padding:26px;width:100%;
  max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.3)}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.modal-t{font-size:17px;font-weight:800}
.modal-x{background:none;border:none;font-size:20px;cursor:pointer;color:var(--tx2);padding:4px;line-height:1}

/* Toast */
#toast-ct{position:fixed;bottom:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px}
.toast{padding:11px 16px;border-radius:var(--rs);font-size:14px;font-weight:600;
  box-shadow:var(--sh-lg);animation:tSlide .2s ease;max-width:300px}
.t-ok{background:#16a34a;color:#fff}.t-err{background:#dc2626;color:#fff}.t-info{background:var(--pr);color:#fff}
@keyframes tSlide{from{transform:translateX(110%);opacity:0}to{transform:none;opacity:1}}

/* Loader */
.spin{width:38px;height:38px;border:3px solid var(--bdr);border-top-color:var(--pr);
  border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}
@keyframes spin{to{transform:rotate(360deg)}}
/* Small inline spinner for buttons (e.g. KYC "Uploading…") */
.spin-sm{display:inline-block;width:15px;height:15px;border-width:2px;margin:0 6px -2px 0;
  border-color:rgba(255,255,255,.45);border-top-color:#fff;vertical-align:middle}
.pg-load{text-align:center;padding:50px}

/* Grid helpers */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:580px){.g2,.bw-row,.car-opts{grid-template-columns:1fr}
  .hero h1{font-size:26px}.adm-sb{display:none}}
