:root{
  /* Shout palette (single, consistent — no inDrive lime). Coral = primary CTA, indigo = brand. */
  --bg:#f5f7fa; --ink:#17152b; --muted:#6b6880; --line:#e8e7f0;
  --brand:#ff6b57; --brand-ink:#ffffff; --branddk:#f0563f;   /* coral CTA */
  --accent:#5b3df5; --danger:#f0455e; --ok:#16b981; --card:#fff;
  --pink:#5b3df5; --shadow:0 8px 30px rgba(26,23,51,.12);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;background:#0b0b0f;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink)}
#phone{position:relative;max-width:430px;margin:0 auto;min-height:100dvh;background:var(--bg);overflow:hidden;display:flex;flex-direction:column}
#statusbar{display:flex;justify-content:space-between;align-items:center;padding:10px 18px 8px;font-size:12px;font-weight:700;color:#fff;background:#0b0b0f}
#sb-right{font-weight:600;opacity:.8;font-size:11px}
#sb-conn{color:var(--brand)}
#app{flex:1;position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* generic */
h1,h2,h3{margin:0}
.muted{color:var(--muted)}
.center{text-align:center}
.row{display:flex;align-items:center;gap:12px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}
.wrap{padding:20px}
.stack>*+*{margin-top:12px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}
.pill.green{background:#eafbef;color:var(--ok)}
.pill.violet{background:#efeaff;color:var(--accent)}
.pill.grey{background:#eef0f3;color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:0;border-radius:16px;
  padding:16px;font-size:16px;font-weight:800;cursor:pointer;background:var(--brand);color:var(--brand-ink);transition:transform .05s}
.btn:active{transform:scale(.985)}
.btn[disabled]{opacity:.5;pointer-events:none}
.btn.dark{background:var(--ink);color:#fff}
.btn.ghost{background:#eef0f3;color:var(--ink)}
.btn.danger{background:#ffe1e7;color:var(--danger)}
.btn.sm{padding:11px 14px;font-size:14px;border-radius:12px;width:auto}
.btn.block{width:100%}
.split{display:flex;gap:10px}
.split>.btn{flex:1}

/* inputs */
.field{width:100%;border:1.5px solid var(--line);border-radius:14px;padding:15px 16px;font-size:16px;background:#fff;outline:none;font-family:inherit}
.field:focus{border-color:var(--ink)}
label.lbl{font-size:13px;font-weight:700;color:var(--muted);margin:0 0 6px 2px;display:block}
textarea.field{resize:none;min-height:84px}

/* cards */
.card{background:var(--card);border-radius:18px;padding:16px;box-shadow:var(--shadow)}
.sheet{background:#fff;border-radius:24px 24px 0 0;box-shadow:0 -10px 40px rgba(0,0,0,.14);padding:18px 18px 26px}
.grip{width:42px;height:5px;border-radius:3px;background:#d7dae0;margin:0 auto 14px}

/* map */
.map{position:relative;height:100%;min-height:340px;background:
  radial-gradient(circle at 30% 20%, #dfe7f5 0, #eef1f6 40%, #e9edf3 100%);overflow:hidden}
.map .grid{position:absolute;inset:0;background-image:
  linear-gradient(#ffffff55 1px,transparent 1px),linear-gradient(90deg,#ffffff55 1px,transparent 1px);
  background-size:46px 46px}
.map .river{position:absolute;top:-10%;left:55%;width:120px;height:140%;background:#bfe0ef;transform:rotate(24deg);filter:blur(.3px);opacity:.8}
.map .pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-100%);z-index:3}
.map .pin .head{width:42px;height:42px;border-radius:12px;background:var(--ink);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;box-shadow:var(--shadow)}
.map .pin .stem{width:3px;height:16px;background:var(--ink);margin:0 auto}
.map .blip{position:absolute;width:30px;height:30px;font-size:20px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.2));animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.map .label{position:absolute;font-size:12px;font-weight:700;color:#8a6;display:flex;align-items:center;gap:4px}
.locbtn{position:absolute;right:14px;bottom:14px;width:46px;height:46px;border-radius:50%;background:#fff;border:0;box-shadow:var(--shadow);font-size:18px}

.screen{display:flex;flex-direction:column;min-height:100%}
.screen.map-screen{position:relative}
.bottom{position:relative;margin-top:auto}

/* avatar */
.av{width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;flex:0 0 auto;overflow:hidden}
.av.lg{width:60px;height:60px;font-size:22px}
.av img{width:100%;height:100%;object-fit:cover}

/* topbar */
.topbar{display:flex;align-items:center;gap:12px;padding:14px 16px}
.iconbtn{width:42px;height:42px;border-radius:50%;background:#fff;border:0;box-shadow:var(--shadow);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer}

/* category grid */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cat{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:12px 6px;text-align:center;cursor:pointer;font-size:11px;font-weight:700;color:var(--ink)}
.cat .emoji{font-size:24px;display:block;margin-bottom:5px}
.cat:active{border-color:var(--ink)}

/* offer / artisan card (inDrive choose-a-driver) */
.offer{background:#fff;border-radius:20px;box-shadow:var(--shadow);padding:14px 14px 12px;margin-bottom:12px}
.offer .top{display:flex;align-items:center;gap:12px}
.offer .name{font-weight:800;font-size:16px}
.offer .meta{font-size:13px;color:var(--muted);margin-top:1px}
.offer .eta{margin-left:auto;text-align:right}
.offer .eta .km{font-weight:800;font-size:16px}
.offer .eta .min{font-size:12px;color:var(--muted)}
.offer .acts{display:flex;gap:10px;margin-top:12px}
.offer .acts .btn{flex:1}
.offer .accept{position:relative;overflow:hidden;background:var(--brand);color:var(--brand-ink)}
.stars{color:#f5a623;font-weight:800}

.toparc{padding:18px 18px 6px}
.h-title{font-size:26px;font-weight:850;letter-spacing:-.5px}
.list-item{display:flex;align-items:center;gap:14px;padding:14px 4px;border-bottom:1px solid var(--line)}
.list-item .ic{width:34px;height:34px;border-radius:50%;background:#eef0f3;display:flex;align-items:center;justify-content:center}

/* toast */
#toast-wrap{position:absolute;left:0;right:0;bottom:24px;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;z-index:50}
.toast{background:#0b0b0f;color:#fff;padding:12px 18px;border-radius:14px;font-size:14px;font-weight:600;box-shadow:var(--shadow);max-width:88%;animation:rise .25s}
.toast.err{background:#3a0d16;color:#ffd6de}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1}}

/* spinner */
.spin{width:30px;height:30px;border:3px solid #d9dde3;border-top-color:var(--ink);border-radius:50%;animation:rot 1s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.searching{display:flex;flex-direction:column;align-items:center;gap:14px;padding:26px}
.viewers{display:flex;align-items:center}
.viewers .av{width:30px;height:30px;font-size:12px;margin-left:-8px;border:2px solid #fff}

.progress{height:5px;background:#e9ebf0;border-radius:3px;overflow:hidden}
.progress>i{display:block;height:100%;background:var(--ink);transition:width 1s linear}

/* menu drawer */
#scrim{position:absolute;inset:0;background:rgba(0,0,0,.4);z-index:40;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.drawer{position:absolute;top:0;left:0;bottom:0;width:80%;max-width:330px;background:#fff;z-index:41;box-shadow:var(--shadow);padding:22px 20px;animation:slide .22s;overflow-y:auto}
@keyframes slide{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.drawer h2{font-size:22px;margin-bottom:2px}
.menu-item{display:flex;align-items:center;gap:12px;padding:14px 6px;font-weight:700;cursor:pointer;border-radius:12px}
.menu-item:active{background:#f2f3f6}
.acct{display:flex;align-items:center;gap:10px;padding:10px;border:1.5px solid var(--line);border-radius:14px;cursor:pointer;margin-bottom:8px}
.acct.active{border-color:var(--ink);background:#fafbfc}

.tag{font-size:11px;font-weight:800;padding:3px 8px;border-radius:8px;background:#eef0f3;color:var(--muted)}
.tag.live{background:#eafbef;color:var(--ok)}
.badge-v{color:var(--accent);font-weight:800}
.big-amt{font-size:30px;font-weight:850;letter-spacing:-1px}
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.kv:last-child{border:0}
.hint{font-size:12px;color:var(--muted);text-align:center;padding:8px 16px}
.empty{padding:40px 20px;text-align:center;color:var(--muted)}
a{color:var(--accent)}
