/* ══════════════════════════════════════════════════════════
   VEGO HUB v5 — app.css
   Fonts: Plus Jakarta Sans · Nunito
   ══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@600;700;800&family=Nunito:wght@400;500;600;700&display=swap');

/* ── Variables ─────────────────────────────────────────── */
:root {
  /* ── Brand — derived from Vego logo navy #0d2a6e ── */
  --primary  :#0d2a6e;   /* logo navy — main brand */
  --primary-d:#091f55;   /* darker navy for hover */
  --primary-l:rgba(13,42,110,.10); /* navy tint bg */

  /* ── Accent — sky blue (lighter, energetic) ── */
  --teal  :#1a6fd4;  --teal-d:#1358b0;  --teal-l:rgba(26,111,212,.11);

  /* ── Supporting palette ── */
  --coral :#e8445a;  --coral-l:rgba(232,68,90,.11);
  --violet:#5c3dff;  --viol-l:rgba(92,61,255,.11);
  --amber :#f59e0b;  --amb-l:rgba(245,158,11,.12);
  --navy  :#0d2a6e;

  /* ── Backgrounds ── */
  --bg    :#f0f4fa;  --bg2:#ffffff;  --bg3:#e8edf6;  --card:#ffffff;

  /* ── Borders (navy-tinted) ── */
  --b1:rgba(13,42,110,.07);  --b2:rgba(13,42,110,.13);  --b3:rgba(13,42,110,.22);

  /* ── Status ── */
  --ok:#00b87a;  --ok-l:rgba(0,184,122,.11);
  --warn:#f59e0b;  --warn-l:rgba(245,158,11,.12);  --warning:#f59e0b;
  --err:#e8445a;   --err-l:rgba(232,68,90,.11);
  --inf:#1a6fd4;   --inf-l:rgba(26,111,212,.11);

  /* ── Text ── */
  --t1:#0a1e4a;  --t2:#3d527a;  --t3:#7f95bb;
  --fh:'Plus Jakarta Sans',sans-serif;
  --fb:'Nunito',sans-serif;
  --r:13px;  --rsm:8px;  --rlg:18px;  --rfl:999px;
  --sh:0 1px 8px rgba(30,42,80,.06);
  --sh-md:0 4px 20px rgba(30,42,80,.09);
  --sh-lg:0 12px 40px rgba(30,42,80,.12);
  --hdr:62px;
  --sab:env(safe-area-inset-bottom,0px);
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--t1);font-family:var(--fb);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;padding-bottom:var(--sab)}
html,body{height:100%}
#main{display:block;min-height:calc(100vh - var(--hdr))}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font-family:var(--fb)}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:4px}

/* ── Typography ────────────────────────────────────────── */
h1,h2,h3,h4,h5{font-family:var(--fh);line-height:1.25;color:var(--t1)}
h1{font-size:clamp(1.6rem,4vw,2.8rem);font-weight:800;letter-spacing:-1px}
h2{font-size:clamp(1rem,2vw,1.45rem);font-weight:700}
h3{font-size:.92rem;font-weight:700}
p{color:var(--t2)}
label{font-size:.67rem;font-weight:800;color:var(--t2);text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:.35rem}

/* ── Buttons ───────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.38rem;padding:.55rem 1.1rem;border-radius:var(--rsm);font-size:.85rem;font-weight:700;border:none;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:var(--fb)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-d);box-shadow:0 4px 14px rgba(13,42,110,.28)}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{filter:brightness(1.08)}
.btn-violet{background:var(--violet);color:#fff}
.btn-violet:hover{filter:brightness(1.08)}
.btn-ghost{background:var(--bg3);color:var(--t2);border:1px solid var(--b2)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-d);box-shadow:0 3px 10px rgba(26,111,212,.28)}
.btn-ghost:hover{color:var(--t1);border-color:var(--b3);background:#fff}
.btn-outline{background:transparent;border:1px solid var(--b2);color:var(--t2)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-danger{background:var(--err-l);color:var(--err);border:1px solid rgba(255,82,82,.18)}
.btn-danger:hover{background:rgba(255,82,82,.2)}
.btn-success{background:var(--ok-l);color:var(--ok);border:1px solid rgba(0,200,83,.18)}
.btn-success:hover{background:rgba(0,200,83,.2)}
.btn-warning{background:var(--warn-l);color:var(--warn);border:1px solid rgba(255,171,64,.18)}
.btn-white{background:#fff;color:var(--primary);font-weight:800;box-shadow:0 2px 12px rgba(0,0,0,.09)}
.btn-white:hover{box-shadow:0 5px 20px rgba(0,0,0,.13)}
.btn-wghost{background:rgba(255,255,255,.16);color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.btn-wghost:hover{background:rgba(255,255,255,.26)}
.btn-sm{padding:.3rem .72rem;font-size:.77rem}
.btn-lg{padding:.75rem 1.6rem;font-size:.98rem}
.btn-xl{padding:.85rem 1.9rem;font-size:.98rem}
.btn-block{width:100%;justify-content:center}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center}
.btn:disabled{opacity:.42;pointer-events:none}

/* ── Forms ─────────────────────────────────────────────── */
input,select,textarea{background:var(--bg3);border:1px solid var(--b2);color:var(--t1);padding:.62rem .88rem;border-radius:var(--rsm);font-size:.86rem;width:100%;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px var(--primary-l)}
select option{background:#fff}
textarea{resize:vertical;min-height:76px}
::placeholder{color:var(--t3)}
.fg{display:flex;flex-direction:column;margin-bottom:.85rem}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.fg-3{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.fg-4{display:grid;grid-template-columns:1fr 2fr 1fr 80px;gap:.45rem;align-items:center}
.fg-4 select,.fg-4 input{margin:0}
.form-hint{font-size:.71rem;color:var(--t3);margin-top:.22rem}
input[type="date"],input[type="time"]{min-width:0}

/* ── Cards ─────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r);padding:1.3rem;box-shadow:var(--sh)}
.card-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--b1)}
.card-hdr h3{font-size:.9rem}

/* ── Stat cards ────────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:.75rem;margin-bottom:1.4rem}
.stat-card{background:#fff;border:1px solid var(--b1);border-radius:var(--r);padding:1.1rem 1.2rem;position:relative;overflow:hidden}
.stat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.sc-t::after{background:linear-gradient(90deg,var(--primary),#2a5db0)}
.sc-v::after{background:linear-gradient(90deg,var(--violet),#b388ff)}
.sc-o::after{background:linear-gradient(90deg,var(--coral),var(--amber))}
.sc-g::after{background:linear-gradient(90deg,var(--ok),#69f0ae)}
.sc-r::after{background:linear-gradient(90deg,var(--err),#ff8a80)}
.sc-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.82rem;margin-bottom:.8rem}
.i-t{background:var(--primary-l);color:var(--primary)}
.i-v{background:var(--viol-l);color:var(--violet)}
.i-o{background:var(--coral-l);color:var(--coral)}
.i-g{background:var(--ok-l);color:var(--ok)}
.i-r{background:var(--err-l);color:var(--err)}
.sc-num{font-family:var(--fh);font-size:1.7rem;font-weight:800;line-height:1;color:var(--t1)}
.sc-lbl{font-size:.67rem;color:var(--t2);margin-top:.25rem;font-weight:700}

/* ── Tables ────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--b1);background:#fff}
table{width:100%;border-collapse:collapse}
thead th{background:var(--bg);padding:.65rem .95rem;text-align:left;font-size:.63rem;font-weight:800;color:var(--t2);letter-spacing:.65px;text-transform:uppercase;border-bottom:1px solid var(--b1);white-space:nowrap}
tbody td{padding:.78rem .95rem;border-bottom:1px solid var(--b1);font-size:.83rem;vertical-align:middle;color:var(--t1)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(0,176,155,.04)}
.td-main{font-weight:700}
.td-sub{font-size:.72rem;color:var(--t2);margin-top:.06rem}
.td-email{max-width:155px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--t2)}
.td-acts{display:flex;gap:.28rem;flex-wrap:wrap}

/* ── Badges ────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.18rem;padding:.16rem .58rem;border-radius:var(--rfl);font-size:.63rem;font-weight:800;letter-spacing:.3px;white-space:nowrap}
.bs-pending{background:var(--warn-l);color:var(--warn)}
.bs-ready_for_collection{background:var(--ok-l);color:var(--ok);font-weight:700}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}
.bs-confirmed{background:var(--ok-l);color:var(--ok)}
.bs-in_progress{background:var(--teal-l);color:var(--teal)}
.bs-completed{background:var(--viol-l);color:var(--violet)}
.bs-cancelled{background:var(--err-l);color:var(--err)}
.bs-active{background:var(--ok-l);color:var(--ok)}
.bs-inactive{background:var(--err-l);color:var(--err)}
.bs-verified{background:var(--primary-l);color:var(--primary)}
.tp{font-size:.61rem;font-weight:800;padding:.16rem .5rem;border-radius:var(--rfl);letter-spacing:.3px}
.tp-r{background:var(--viol-l);color:var(--violet)}
.tp-w{background:var(--primary-l);color:var(--primary)}

/* ── Alerts ────────────────────────────────────────────── */
.alert{padding:.75rem .95rem;border-radius:var(--rsm);font-size:.85rem;display:flex;align-items:flex-start;gap:.45rem;border:1px solid transparent}
.al-info{background:var(--inf-l);border-color:rgba(41,121,255,.18);color:var(--inf)}
.al-success{background:var(--ok-l);border-color:rgba(0,200,83,.18);color:var(--ok)}
.al-danger{background:var(--err-l);border-color:rgba(255,82,82,.18);color:var(--err)}
.al-warning{background:var(--warn-l);border-color:rgba(255,171,64,.18);color:#c07800}

/* ── Modals ────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(15,25,55,.42);backdrop-filter:blur(6px);z-index:2000;align-items:flex-start;justify-content:center;padding:1.25rem .75rem 1.25rem;overflow-y:auto;-webkit-overflow-scrolling:touch}
.overlay.open{display:flex;animation:fdIn .15s}
@keyframes fdIn{from{opacity:0}}
/* modal: fills screen width on mobile, scrolls internally, never clips off-screen */
.modal{background:#fff;border:1px solid var(--b1);border-radius:var(--rlg);width:100%;max-width:500px;max-height:calc(var(--real-vh,96svh) - 2.5rem);overflow-y:auto;padding:1.5rem;box-shadow:var(--sh-lg);animation:slUp .2s cubic-bezier(.16,1,.3,1);position:relative;margin:0 auto;flex-shrink:0}
@keyframes slUp{from{opacity:0;transform:translateY(14px) scale(.98)}}
.modal-lg{max-width:680px}
.modal-xl{max-width:900px;max-height:calc(var(--real-vh,96svh) - 2.5rem)}
.m-hdr{display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;background:#fff;margin:-1.5rem -1.5rem 1.3rem;padding:1rem 1.5rem;border-radius:var(--rlg) var(--rlg) 0 0;border-bottom:1px solid var(--b1)}
.m-hdr h2{font-size:1rem}
.m-close{width:27px;height:27px;border-radius:50%;border:1px solid var(--b2);background:var(--bg3);color:var(--t2);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .14s;flex-shrink:0}
.m-close:hover{background:var(--err);color:#fff;border-color:var(--err)}
.modal-tabs{display:flex;border-bottom:1px solid var(--b1);margin:-.25rem -.1rem 1.2rem}
.mtab{flex:1;padding:.52rem .4rem;font-size:.79rem;font-weight:700;text-align:center;cursor:pointer;border:none;background:transparent;color:var(--t2);border-bottom:2px solid transparent;transition:all .14s;font-family:var(--fb)}
.mtab:hover{color:var(--t1);background:var(--bg3)}
.mtab.active{color:var(--coral);border-bottom-color:var(--coral);background:var(--coral-l)}
.mtab-panel{animation:fdIn .14s}

/* ── Steps ─────────────────────────────────────────────── */
.steps{display:flex;align-items:center;margin-bottom:1.2rem;overflow-x:auto;gap:0;padding-bottom:.1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.steps::-webkit-scrollbar{display:none}
.step{display:flex;align-items:center;gap:.32rem;font-size:.72rem;font-weight:700;color:var(--t3);white-space:nowrap}
.step.on{color:var(--t1)}
.step.done{color:var(--ok)}
.step-n{width:21px;height:21px;border-radius:50%;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;flex-shrink:0}
.step.on .step-n{background:var(--primary);border-color:var(--primary);color:#fff}
.step.done .step-n{background:var(--ok);border-color:var(--ok);color:#fff}
.step-sep{flex:1;height:2px;background:var(--b2);min-width:10px;margin:0 5px}

/* ── Misc components ───────────────────────────────────── */
.qbar{background:var(--bg3);border-radius:var(--rfl);height:4px;overflow:hidden;margin:.5rem 0}
.qfill{height:100%;border-radius:var(--rfl);background:linear-gradient(90deg,var(--primary),var(--teal));transition:width .4s}
.qfill.busy{background:linear-gradient(90deg,var(--amber),var(--coral))}
.qfill.full{background:var(--err)}
.drow{display:flex;justify-content:space-between;align-items:center;padding:.55rem 0;border-bottom:1px solid var(--b1);font-size:.86rem}
.drow:last-child{border-bottom:none}
.dlbl{color:var(--t2);font-size:.79rem;font-weight:600}
.divider{height:1px;background:var(--b1);margin:1rem 0}
.empty-state{text-align:center;padding:2.5rem 1.5rem}
.empty-state i{font-size:2rem;opacity:.18;display:block;margin-bottom:.75rem;color:var(--primary)}
.empty-state h3{font-size:.92rem;margin-bottom:.28rem}
.empty-state p{font-size:.83rem}
.page-wrap{max-width:1380px;margin:0 auto;padding:2rem 1.5rem}
.sk{background:linear-gradient(90deg,var(--bg3) 25%,rgba(255,255,255,.8) 50%,var(--bg3) 75%);background-size:200% 100%;animation:sk 1.4s infinite;border-radius:5px}
.sk-card{padding:.75rem;border-radius:var(--r);border:1px solid var(--b1);margin-bottom:.35rem;background:#fff}
@keyframes sk{to{background-position:-200% 0}}
.tag-badge{display:inline-flex;align-items:center;gap:.22rem;padding:.18rem .58rem;border-radius:var(--rfl);font-size:.67rem;font-weight:700;background:var(--bg3);border:1px solid var(--b2);color:var(--t2)}
.inline-edit{display:flex;gap:.38rem;align-items:center}
.inline-edit input{flex:1}
.sw{width:36px;height:20px;border-radius:10px;background:var(--b2);border:none;cursor:pointer;position:relative;transition:background .18s;flex-shrink:0}
.sw::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .16s;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.sw.on{background:var(--primary)}
.sw.on::after{transform:translateX(16px)}

/* ── Toast ─────────────────────────────────────────────── */
#toast{position:fixed;bottom:1.2rem;right:1.2rem;z-index:9999;display:flex;flex-direction:column;gap:.4rem;pointer-events:none;max-width:290px;width:calc(100% - 2.4rem)}
.toast-item{background:#fff;border:1px solid var(--b2);padding:.72rem .9rem;border-radius:var(--r);font-size:.83rem;box-shadow:var(--sh-md);animation:toastIn .18s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:.45rem;pointer-events:all;color:var(--t1)}
@keyframes toastIn{from{opacity:0;transform:translateX(14px)}}
.toast-item.success{border-left:3px solid var(--ok)}
.toast-item.error{border-left:3px solid var(--err)}
.toast-item.info{border-left:3px solid var(--inf)}
.toast-item.warning{border-left:3px solid var(--warn)}

/* ── Row helpers ───────────────────────────────────────── */
.svc-row-del,.del-row-btn{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,82,82,.22);background:var(--err-l);color:var(--err);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .13s;flex-shrink:0}
.svc-row-del:hover,.del-row-btn:hover{background:var(--err);color:#fff}
.form-section{margin-bottom:1.4rem;padding-bottom:1.4rem;border-bottom:1px solid var(--b1)}
.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.form-section-title{font-size:.63rem;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:.8rem}
.cat-row,.country-row{display:flex;align-items:center;gap:.6rem;padding:.62rem .85rem;border-bottom:1px solid var(--b1)}
.cat-row:last-child,.country-row:last-child{border-bottom:none}
.cat-icon-preview{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.82rem}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem 0}
.toggle-wrap{display:flex;align-items:center;gap:.5rem}

/* ══════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════ */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--b1)}
.hdr-inner{max-width:1380px;margin:0 auto;display:flex;align-items:center;height:var(--hdr);padding:0 1.25rem;gap:.5rem}
.logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.logo-img{padding:.2rem 0}
.logo-navy{height:30px;width:auto;display:block}
.logo-white{height:32px;width:auto;display:block}
.logo-footer{padding:.1rem 0}
/* Legacy text logo fallback (portal sidebars still use text) */
.logo-dot{width:29px;height:29px;border-radius:7px;background:linear-gradient(135deg,var(--primary),#1a4499);display:flex;align-items:center;justify-content:center;font-size:.76rem;color:#fff;font-weight:900}
.logo span{color:#0d2a6e}
.hdr-nav{display:flex;gap:.05rem;margin-left:1rem}
.hdr-nav a{color:var(--t2);font-size:.84rem;font-weight:600;padding:.36rem .75rem;border-radius:var(--rsm);transition:all .14s}
.hdr-nav a:hover{color:var(--t1);background:var(--bg3)}
.hdr-nav a.active{color:var(--primary);background:var(--primary-l)}
.hdr-portals{display:flex;gap:.28rem;margin-left:auto}
.hdr-portals a{display:flex;align-items:center;gap:.32rem;font-size:.7rem;font-weight:800;padding:.3rem .7rem;border-radius:var(--rsm);transition:all .14s;border:1px solid transparent}
.hp-my{color:var(--primary);border-color:rgba(13,42,110,.18);background:var(--primary-l)}
.hp-biz{color:var(--violet);border-color:rgba(124,77,255,.22);background:var(--viol-l)}
.hp-admin{color:var(--coral);border-color:rgba(255,82,82,.22);background:var(--coral-l)}
.hdr-portals a:hover{box-shadow:var(--sh)}
.hdr-right{display:flex;align-items:center;gap:.42rem;margin-left:.55rem;flex-shrink:0}
.country-sel{background:var(--bg3);border:1px solid var(--b2);color:var(--t1);padding:.32rem .58rem;border-radius:var(--rsm);font-size:.75rem;width:auto;cursor:pointer}
.user-chip{display:flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--b2);padding:.24rem .65rem .24rem .26rem;border-radius:var(--rfl);cursor:pointer;transition:all .14s}
.user-chip:hover{border-color:var(--primary)}
.user-chip .uname{font-size:.77rem;font-weight:700}
.av{display:inline-flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;border-radius:7px;background:linear-gradient(135deg,var(--primary),#1a4499);color:#fff;flex-shrink:0}
.av-xs{width:23px;height:23px;font-size:.62rem;border-radius:5px}
.av-sm{width:29px;height:29px;font-size:.73rem;border-radius:7px}
.av-md{width:38px;height:38px;font-size:.88rem;border-radius:9px}
.av-lg{width:48px;height:48px;font-size:1.02rem;border-radius:11px}
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:.38rem;border:1px solid var(--b2);border-radius:var(--rsm);background:transparent}
.hamburger span{display:block;width:17px;height:2px;background:var(--t2);border-radius:2px;transition:all .18s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.mob-nav{display:none;position:fixed;inset:0;top:var(--hdr);background:rgba(255,255,255,.99);backdrop-filter:blur(12px);z-index:999;flex-direction:column;padding:.65rem;gap:.18rem;overflow-y:auto;padding-bottom:calc(.65rem + var(--sab))}
.mob-nav.open{display:flex}
.mob-nav a{display:flex;align-items:center;gap:.6rem;padding:.7rem .88rem;border-radius:var(--r);font-size:.88rem;font-weight:600;color:var(--t2);border:1px solid transparent;transition:all .14s}
.mob-nav a:hover,.mob-nav a.active{background:var(--bg3);border-color:var(--b2);color:var(--t1)}
.mob-portal-link{font-weight:800}
.mob-sep{height:1px;background:var(--b1);margin:.18rem 0}

/* ══════════════════════════════════════════════════════════
   HOME
   ══════════════════════════════════════════════════════════ */
.hero{background:linear-gradient(135deg,var(--primary) 0%,#1a4499 55%,#0f3285 100%);border-radius:var(--rlg);padding:3.75rem 3.5rem 2.75rem;margin-bottom:2rem;position:relative;overflow:hidden;box-shadow:0 6px 30px rgba(13,42,110,.25)}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 78% 28%,rgba(255,255,255,.14) 0%,transparent 52%)}
.hero-badge{display:inline-flex;align-items:center;gap:.32rem;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:.63rem;font-weight:800;padding:.28rem .88rem;border-radius:var(--rfl);margin-bottom:1.3rem;letter-spacing:.7px;text-transform:uppercase}
.hero h1{color:#fff;margin-bottom:.95rem}
.hl{position:relative;display:inline-block;color:#fff}
.hl::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:3px;background:rgba(255,255,255,.4);border-radius:2px}
.hero p{color:rgba(255,255,255,.88);font-size:1rem;max-width:450px;margin-bottom:1.85rem;line-height:1.72}
.hero-actions{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:2.2rem}
.hero-floats{display:flex;gap:.7rem;flex-wrap:wrap;padding-top:1.65rem;border-top:1px solid rgba(255,255,255,.2)}
.hf{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);border-radius:11px;padding:.65rem 1rem;display:flex;align-items:center;gap:.55rem;min-width:105px}
.hf-icon{font-size:1.15rem;line-height:1;flex-shrink:0}
.hf-lbl{font-size:.61rem;color:rgba(255,255,255,.7);font-weight:600;letter-spacing:.3px}
.hf-val{font-family:var(--fh);font-size:1rem;font-weight:800;color:#fff;line-height:1.2}
.search-panel{background:#fff;border:1px solid var(--b1);border-radius:var(--r);padding:1.4rem;margin-bottom:2rem}
.search-panel h2{font-size:.92rem;margin-bottom:.95rem}
.search-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.8rem;align-items:end}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:.95rem;margin-top:1rem}
.feat{background:#fff;border:1px solid var(--b1);border-radius:var(--r);padding:1.4rem;transition:border-color .18s,box-shadow .18s}
.feat:hover{border-color:var(--primary);box-shadow:var(--sh-md)}
.feat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.02rem;margin-bottom:.95rem}
.fi-t{background:var(--primary-l);color:var(--primary)}
.fi-v{background:var(--viol-l);color:var(--violet)}
.fi-o{background:var(--coral-l);color:var(--coral)}
.station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:.95rem}
.stn-card{background:#fff;border:1px solid var(--b1);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:border-color .18s,box-shadow .18s}
.stn-card:hover{border-color:var(--primary);box-shadow:var(--sh-md)}
.stn-cover{height:96px;background:linear-gradient(135deg,var(--teal-l),rgba(0,176,155,.04));display:flex;align-items:center;justify-content:center;font-size:2.1rem;position:relative;border-bottom:1px solid var(--b1)}
.stn-avail{position:absolute;top:.45rem;right:.45rem;padding:.14rem .52rem;border-radius:var(--rfl);font-size:.61rem;font-weight:800}
.av-ok{background:var(--ok-l);color:var(--ok)}
.av-busy{background:var(--warn-l);color:var(--warn)}
.av-full{background:var(--err-l);color:var(--err)}
.stn-body{padding:.9rem}
.stn-body h3{font-size:.88rem;margin-bottom:.25rem}
.stn-meta{display:flex;gap:.38rem .8rem;flex-wrap:wrap;color:var(--t2);font-size:.73rem;margin-bottom:.52rem}
.stn-meta span{display:flex;align-items:center;gap:.2rem}
.stn-foot{display:flex;justify-content:space-between;align-items:center;padding-top:.55rem;border-top:1px solid var(--b1)}
.stn-tags{display:flex;gap:.22rem;flex-wrap:wrap}
.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}

/* ══════════════════════════════════════════════════════════
   STATIONS PAGE
   ══════════════════════════════════════════════════════════ */
.sp-wrap{
  display:flex;flex-direction:column;
  /* Height: viewport minus header height */
  height:calc(100vh - var(--hdr));
  height:calc(100svh - var(--hdr));
  height:calc(var(--real-vh, 100vh) - var(--hdr));
  min-height:600px;
  /* overflow visible so content never clips if height calc is wrong */
  overflow:visible;
  padding-bottom:var(--sab);
}
.sp-body{overflow:hidden}
.sp-topbar{display:flex;align-items:center;gap:.5rem;padding:.52rem .95rem;background:#fff;border-bottom:1px solid var(--b1);flex-shrink:0;flex-wrap:wrap}
.sp-ttl{font-family:var(--fh);font-size:.9rem;font-weight:800;white-space:nowrap}
.sp-ttl small{font-family:var(--fb);font-size:.66rem;font-weight:600;color:var(--t2);display:block}
.sp-cats{background:#fff;border-bottom:1px solid var(--b1);overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0}
.sp-cats::-webkit-scrollbar{display:none}
.cats-row{display:flex;gap:.28rem;padding:.42rem .88rem;width:max-content}
.cat-chip{display:flex;align-items:center;gap:.28rem;padding:.28rem .68rem;border-radius:var(--rfl);background:var(--bg3);border:1px solid var(--b1);color:var(--t2);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .14s;font-family:var(--fb)}
.cat-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-l)}
.cat-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}
.sp-body{display:grid;grid-template-columns:340px 1fr;flex:1;min-height:500px;overflow:hidden}
.sp-sidebar{display:flex;flex-direction:column;background:#fff;border-right:1px solid var(--b1);overflow:hidden;min-height:400px}
.sp-srch{display:flex;gap:.38rem;align-items:center;padding:.55rem;border-bottom:1px solid var(--b1);flex-shrink:0}
.sp-srch input{flex:1;font-size:.81rem;padding:.46rem .66rem;background:var(--bg3)}
.sp-locate{display:flex;align-items:center;gap:.22rem;background:var(--primary);color:#fff;padding:.42rem .66rem;border-radius:var(--rsm);font-size:.71rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .16s;font-family:var(--fb);flex-shrink:0;border:none}
.sp-locate:hover{background:var(--primary-d)}

.sp-list{flex:1;overflow-y:auto;padding:.38rem;min-height:0}
.sp-list::-webkit-scrollbar{width:3px}
.sli{background:#fff;border:1px solid var(--b1);border-radius:9px;padding:.7rem .75rem;margin-bottom:.32rem;cursor:pointer;transition:border-color .14s}
.sli:hover{border-color:var(--primary)}
.sli.active{border-color:var(--primary);background:var(--primary-l)}
.sli-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.38rem;margin-bottom:.2rem}
.sli-name{font-family:var(--fh);font-size:.83rem;font-weight:700;flex:1;min-width:0}
.sli-dist{background:var(--viol-l);color:var(--violet);font-size:.63rem;font-weight:800;padding:.12rem .42rem;border-radius:var(--rfl);white-space:nowrap;flex-shrink:0}
.sli-meta{display:flex;flex-wrap:wrap;gap:.16rem .52rem;font-size:.7rem;color:var(--t2);margin-bottom:.35rem}
.sli-foot{display:flex;justify-content:space-between;align-items:center;gap:.32rem}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-g{background:var(--ok)}
.dot-y{background:var(--warn)}
.dot-r{background:var(--err)}
.places-sep{font-size:.63rem;font-weight:800;color:var(--t3);letter-spacing:.7px;text-transform:uppercase;padding:.3rem .46rem;border-top:1px solid var(--b1);margin:.14rem 0 .22rem}
/* Map area */
.sp-maparea{position:relative;overflow:hidden;background:var(--bg3);flex:1}
#googleMap{width:100%;height:100%}
.map-ctrls{position:absolute;top:.65rem;right:.65rem;display:flex;flex-direction:column;gap:.3rem;z-index:10}
.map-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--b2);background:rgba(255,255,255,.97);color:var(--t1);cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .14s;box-shadow:var(--sh)}
.map-btn:hover{border-color:var(--primary);color:var(--primary)}
.map-btn.accent{background:var(--primary);color:#fff;border-color:var(--primary)}
.map-btn.accent:hover{background:var(--primary-d)}
.map-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg3);z-index:5;text-align:center;padding:2rem;gap:.5rem}
/* Station detail sheet */
.ds{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--b1);transform:translateY(100%);transition:transform .26s cubic-bezier(.32,.72,0,1);z-index:30;max-height:65%;overflow-y:auto;border-radius:15px 15px 0 0;box-shadow:0 -4px 24px rgba(26,37,80,.09);padding-bottom:calc(.5rem + var(--sab))}
.ds.open{transform:translateY(0)}
.ds-handle{width:32px;height:3px;background:var(--b2);border-radius:2px;margin:.6rem auto 0}
.ds-inner{padding:.7rem .95rem 1.2rem}
.ds-name{font-family:var(--fh);font-size:.95rem;font-weight:800;margin-bottom:.16rem}
.ds-sub{font-size:.73rem;color:var(--t2);display:flex;flex-wrap:wrap;gap:.3rem .58rem;margin-bottom:.75rem}
.ds-contacts{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;margin-bottom:.72rem}
.ds-con{background:var(--bg3);border:1px solid var(--b1);border-radius:9px;padding:.52rem .38rem;display:flex;flex-direction:column;align-items:center;gap:.22rem;cursor:pointer;transition:all .14s;text-align:center}
.ds-con:hover{border-color:var(--primary);background:var(--primary-l)}
.ds-ci{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.ci-phone{background:var(--ok-l);color:var(--ok)}
.ci-wa{background:rgba(37,211,102,.12);color:#25d366}
.ci-dir{background:var(--viol-l);color:var(--violet)}
.ds-cl{font-size:.6rem;color:var(--t2);font-weight:600}
.ds-cv{font-size:.68rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.ds-acts{display:flex;gap:.4rem;padding-top:.65rem;border-top:1px solid var(--b1);flex-wrap:wrap}
/* Mobile toggle */
.mob-view-toggle{display:none}
.mvt-btn{padding:.28rem .6rem;border-radius:7px;border:none;font-size:.69rem;font-weight:700;cursor:pointer;background:transparent;color:var(--t2);font-family:var(--fb);transition:all .13s}
.mvt-btn.active{background:#fff;color:var(--t1);box-shadow:var(--sh)}
/* Booking choice */
.svc-list{display:flex;flex-direction:column;gap:.4rem}
.svc-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem .88rem;background:var(--bg3);border:1.5px solid var(--b1);border-radius:var(--rsm);cursor:pointer;transition:all .13s;gap:.6rem}
.svc-item:hover,.svc-item.sel{border-color:var(--primary);background:var(--primary-l)}
.svc-name{font-weight:700;font-size:.83rem}
.svc-meta{font-size:.71rem;color:var(--t2);margin-top:.07rem}
.svc-price{font-family:var(--fh);font-weight:800;color:var(--primary);font-size:.86rem;flex-shrink:0}
.book-choice{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.bc{background:var(--bg3);border:1.5px solid var(--b1);border-radius:10px;padding:1rem;cursor:pointer;text-align:center;transition:all .16s}
.bc:hover,.bc.sel{border-color:var(--primary);background:var(--primary-l)}
.bc-icon{font-size:1.5rem;margin-bottom:.38rem}
.bc h4{font-family:var(--fh);font-size:.82rem;font-weight:700;margin-bottom:.14rem}
.bc p{font-size:.72rem;color:var(--t2)}

/* ══════════════════════════════════════════════════════════
   PORTAL
   ══════════════════════════════════════════════════════════ */
.portal-wrap{display:grid;grid-template-columns:248px 1fr;min-height:calc(100svh - var(--hdr));min-height:calc(var(--real-vh, 100svh) - var(--hdr))}
.portal-sb{background:#fff;border-right:1px solid var(--b1);position:sticky;top:var(--hdr);height:calc(100svh - var(--hdr));height:calc(var(--real-vh, 100svh) - var(--hdr));overflow-y:auto;display:flex;flex-direction:column;padding-bottom:var(--sab)}
.portal-sb::-webkit-scrollbar{width:2px}

/* Sidebar logo bar */
.sb-logo-bar{padding:.75rem 1rem .55rem;border-bottom:1px solid var(--b1);display:flex;align-items:center}
.sb-logo-img{height:22px;width:auto;display:block}

.sb-id{padding:.95rem 1rem .85rem;border-bottom:1px solid var(--b1)}
.sb-name{font-family:var(--fh);font-weight:800;font-size:.88rem;line-height:1.25;margin-bottom:.06rem}
.sb-role{font-size:.67rem;color:var(--t2);font-weight:600}
.sb-pill{display:inline-flex;align-items:center;gap:.22rem;padding:.18rem .55rem;border-radius:var(--rsm);font-size:.58rem;font-weight:800;letter-spacing:.4px;text-transform:uppercase;margin-top:.55rem;border:1px solid transparent}
.pill-t{background:var(--primary-l);color:var(--primary);border-color:rgba(13,42,110,.18)}
.pill-v{background:var(--viol-l);color:var(--violet);border-color:rgba(124,77,255,.18)}
.pill-o{background:var(--coral-l);color:var(--coral);border-color:rgba(255,82,82,.18)}
.sb-nav{flex:1;padding:.42rem .42rem}
.sb-section{margin-bottom:.85rem}
.sb-lbl{font-size:.55rem;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;padding:.04rem .5rem;margin-bottom:.14rem}
.sb-item{display:flex;align-items:center;gap:.44rem;padding:.48rem .62rem;border-radius:8px;font-size:.81rem;font-weight:600;color:var(--t2);cursor:pointer;transition:all .13s;border:none;background:transparent;font-family:var(--fb);width:100%;text-align:left;min-height:38px}
.sb-item:hover{background:var(--bg3);color:var(--t1)}
.sb-item.at{background:var(--primary-l);color:var(--primary);font-weight:700}
.sb-item.av{background:var(--viol-l);color:var(--violet);font-weight:700}
.sb-item.ao{background:var(--coral-l);color:var(--coral);font-weight:700}
.sb-item i{width:13px;text-align:center;opacity:.42;flex-shrink:0;font-size:.78rem}
.sb-item.at i,.sb-item.av i,.sb-item.ao i{opacity:1}
.sb-cnt{margin-left:auto;background:var(--err);color:#fff;font-size:.56rem;font-weight:800;padding:.02rem .34rem;border-radius:var(--rfl);min-width:15px;text-align:center}
.sb-foot{padding:.5rem .42rem;border-top:1px solid var(--b1);flex-shrink:0}
.sb-mob-btn{display:none;position:fixed;top:calc(var(--hdr) + 10px);left:10px;z-index:600;background:var(--primary);color:#fff;border:none;width:33px;height:33px;border-radius:var(--rsm);align-items:center;justify-content:center;font-size:.8rem;cursor:pointer}
.portal-main{min-width:0;padding:1.65rem 1.4rem;background:var(--bg)}
.p-section{display:none}
.p-section.active{display:block}
.p-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}
.p-title{font-family:var(--fh);font-size:1.22rem;font-weight:800;letter-spacing:-.35px}
.p-title small{display:block;font-size:.72rem;font-weight:500;color:var(--t2);font-family:var(--fb);margin-top:.06rem;letter-spacing:0}
.veh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:.9rem}
.veh-card{background:#fff;border:1px solid var(--b1);border-radius:var(--r);padding:1.15rem;transition:border-color .16s}
.veh-card:hover{border-color:var(--primary);box-shadow:var(--sh-md)}
.vc-icon{width:42px;height:42px;border-radius:11px;background:var(--teal-l);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:.8rem}
.vc-make{font-family:var(--fh);font-weight:800;font-size:.9rem}
.vc-plate{font-size:.73rem;color:var(--t2);margin-top:.05rem;font-weight:600}
.vc-km{font-family:var(--fh);font-size:1.4rem;font-weight:800;color:var(--primary);margin:.65rem 0 .16rem}
.vc-next{font-size:.71rem;color:var(--t2);font-weight:600}
.vc-acts{display:flex;gap:.35rem;margin-top:.9rem;flex-wrap:wrap}

/* Admin */
.adm-ov-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.95rem;margin-top:1.4rem}
.adm-filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem;padding:.7rem .9rem;background:var(--bg);border:1px solid var(--b1);border-radius:var(--rsm)}
.adm-filter-bar input,.adm-filter-bar select{margin:0;width:auto;flex:1;min-width:130px;max-width:260px;font-size:.82rem;padding:.46rem .72rem}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */
.site-footer{background:var(--navy);margin-top:5rem;padding:3.5rem 0 0}
.ft-inner{max-width:1380px;margin:0 auto;padding:0 1.5rem}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2rem}
.ft-logo{display:flex;align-items:center}
.ft-logo-dot{width:27px;height:27px;border-radius:7px;background:linear-gradient(135deg,var(--primary),#1a4499);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;font-weight:900}
.ft-logo span{color:#4d9fff}
.ft-brand p{color:rgba(255,255,255,.48);font-size:.83rem;line-height:1.7;margin:.8rem 0;max-width:255px}
.ft-flags{display:flex;gap:.32rem;flex-wrap:wrap;margin-top:.55rem}
.flag-pill{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);padding:.14rem .5rem;border-radius:var(--rsm);font-size:.73rem;color:rgba(255,255,255,.5)}
.ft-social{display:flex;gap:.35rem;margin-top:.95rem}
.ft-social a{width:29px;height:29px;border-radius:7px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.48);font-size:.73rem;transition:all .14s}
.ft-social a:hover{color:#4d9fff;border-color:rgba(77,159,255,.35)}
.ft-col h4{font-family:var(--fh);font-size:.83rem;font-weight:700;margin-bottom:.82rem;color:#fff}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.ft-col ul li a{color:rgba(255,255,255,.46);font-size:.81rem;transition:color .14s}
.ft-col ul li a:hover{color:#4d9fff}
.ft-portals{display:flex;flex-direction:column;gap:.32rem}
.fp{display:flex;align-items:center;gap:.48rem;padding:.46rem .76rem;border-radius:var(--rsm);font-size:.76rem;font-weight:700;border:1px solid transparent;transition:all .14s}
.fp-t{background:rgba(255,255,255,.10);color:#7eb8ff;border-color:rgba(126,184,255,.25)}
.fp-v{background:rgba(255,255,255,.08);color:#b39dff;border-color:rgba(179,157,255,.22)}
.fp-o{background:rgba(255,255,255,.08);color:#ff8a9a;border-color:rgba(255,138,154,.22)}
.fp:hover{transform:translateX(3px)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap;gap:.8rem}
.ft-bottom p{font-size:.73rem;color:rgba(255,255,255,.3)}
.ft-btm-links{display:flex;gap:1.2rem}
.ft-btm-links a{font-size:.73rem;color:rgba(255,255,255,.3);transition:color .14s}
.ft-btm-links a:hover{color:rgba(255,255,255,.58)}

/* ═══════════════════════════════════════════════════════════
   BOOKING CARDS — My Vego › Bookings
   ═══════════════════════════════════════════════════════════ */

.bk-card {
  background: #fff;
  border-radius: var(--r);
  border: 1.5px solid var(--b1);
  border-left-width: 3px;
  margin-bottom: .85rem;
  overflow: hidden;
  transition: box-shadow .15s;
}
.bk-card:hover { box-shadow: var(--sh-md); }

.bk-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: .9rem 1rem .65rem;
}
.bk-card-left { flex: 1; min-width: 0; }
.bk-card-right { text-align: right; flex-shrink: 0; }

.bk-ref {
  font-family: var(--fh);
  font-size: .82rem;
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -.01em;
  margin-bottom: .18rem;
}
.bk-station {
  font-weight: 700;
  font-size: .92rem;
  color: var(--t1);
  margin-bottom: .08rem;
}
.bk-station-city { font-size: .75rem; color: var(--t2); }

.bk-amount {
  font-weight: 800;
  font-size: .96rem;
  color: var(--t1);
}
.bk-date {
  font-size: .72rem;
  color: var(--t3);
  margin-top: .2rem;
}

/* ── Journey timeline ── */
.bk-journey {
  display: flex;
  align-items: flex-start;
  gap: 0;
  padding: .6rem 1rem .7rem;
  background: var(--bg);
  border-top: 1px solid var(--b1);
  overflow-x: auto;
  scrollbar-width: none;
}
.bk-journey::-webkit-scrollbar { display: none }

.bk-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 72px;
  position: relative;
  text-align: center;
}
.bk-stage-line {
  position: absolute;
  top: 14px;
  right: 50%;
  width: 100%;
  height: 2px;
  background: var(--b1);
  z-index: 0;
}
.bk-stage.st-done  .bk-stage-line { background: var(--ok); }
.bk-stage.st-active .bk-stage-line { background: var(--stc, var(--primary)); }

.bk-stage-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .68rem;
  border: 2px solid var(--b1);
  background: #fff;
  position: relative;
  z-index: 1;
  transition: all .2s;
  color: var(--t3);
}
.bk-stage.st-done  .bk-stage-dot {
  background: var(--ok);
  border-color: var(--ok);
  color: #fff;
}
.bk-stage.st-active .bk-stage-dot {
  background: var(--stc, var(--primary));
  border-color: var(--stc, var(--primary));
  color: #fff;
  box-shadow: 0 0 0 4px rgba(13,42,110,.12);
  animation: bk-pulse 2s ease-in-out infinite;
}
@keyframes bk-pulse {
  0%,100% { box-shadow: 0 0 0 4px rgba(13,42,110,.12); }
  50%      { box-shadow: 0 0 0 8px rgba(13,42,110,.06); }
}

.bk-stage-info { margin-top: .38rem; }
.bk-stage-label {
  font-size: .67rem;
  font-weight: 800;
  color: var(--t2);
  text-transform: uppercase;
  letter-spacing: .03em;
  white-space: nowrap;
}
.bk-stage.st-done  .bk-stage-label { color: var(--ok); }
.bk-stage.st-active .bk-stage-label { color: var(--stc, var(--primary)); }

.bk-stage-sub {
  font-size: .62rem;
  color: var(--t3);
  margin-top: .1rem;
  white-space: nowrap;
  max-width: 88px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bk-stage.st-active .bk-stage-sub { color: var(--stc, var(--primary)); font-weight: 600; }

/* ── Action strip ── */
.bk-actions {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem 1rem;
  border-top: 1px solid var(--b1);
  flex-wrap: wrap;
}

/* ── Delivery tracking inline message ── */
.bk-delivery-track {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(124,58,237,.07);
  border: 1px solid rgba(124,58,237,.18);
  color: var(--violet, #7c3aed);
  padding: .32rem .8rem;
  border-radius: var(--rsm);
  font-size: .77rem;
  font-weight: 700;
}


/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media (max-width:1100px){
  .portal-wrap{grid-template-columns:215px 1fr}
  .sp-body{grid-template-columns:305px 1fr}
  .ft-grid{grid-template-columns:1fr 1fr 1fr}
  .ft-grid>*:first-child{grid-column:1/-1}
  .adm-ov-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .hdr-nav,.hdr-portals{display:none}
  .hamburger{display:flex}
  .hdr-right .country-sel{display:none}
  .portal-wrap{grid-template-columns:1fr}
  .portal-sb{
    position:fixed;left:0;top:var(--hdr);
    width:248px;
    height:calc(100svh - var(--hdr));
    height:calc(var(--real-vh, 100svh) - var(--hdr));
    transform:translateX(-110%);
    transition:transform .26s cubic-bezier(.22,.68,0,1.2);
    z-index:500;
    box-shadow:6px 0 30px rgba(26,37,80,.1);
    padding-bottom:var(--sab);
  }
  .portal-sb.open{transform:translateX(0)}
  .sb-mob-btn{display:flex}
  .portal-main{padding:1.2rem .9rem}
  .sp-body{grid-template-columns:1fr}
  .sp-maparea{height:290px}
  .features{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:1.65rem}
  .adm-ov-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .page-wrap{padding:.9rem}
  .hero{padding:2rem 1.4rem 1.65rem;border-radius:var(--r)}
  .hero-floats{gap:.42rem}
  .hf{padding:.52rem .78rem;min-width:88px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .search-form{grid-template-columns:1fr}
  .features{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr;gap:.6rem}
  .modal{padding:1rem;border-radius:var(--r);max-height:calc(var(--real-vh,94svh) - 1rem);}
  .m-hdr{margin:-1rem -1rem 1.1rem;padding:.85rem 1rem;border-radius:var(--r) var(--r) 0 0;}
  .modal-lg,.modal-xl{max-width:100%;max-height:calc(var(--real-vh,94svh) - 1rem);}
  .overlay{padding:.5rem .4rem}
  .fg-row,.fg-3{grid-template-columns:1fr}
  .book-choice{grid-template-columns:1fr}
  .td-acts{gap:.2rem;flex-wrap:wrap}
  .td-acts .btn{padding:.26rem .48rem;font-size:.72rem}
  .td-acts .btn-sm{padding:.24rem .44rem;font-size:.7rem}
  thead th{font-size:.6rem;padding:.58rem .72rem}
  tbody td{padding:.68rem .72rem;font-size:.81rem}
  .ft-grid{grid-template-columns:1fr}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:.45rem}
  /* Stations mobile */
  .sp-body{display:flex;flex-direction:column}
  .sp-sidebar{flex:1;min-height:180px}
  .sp-maparea{height:240px;flex-shrink:0}
  .sp-sidebar.mob-hide{display:none!important}
  .sp-maparea.mob-hide{display:none!important}
  .mob-view-toggle{display:flex;background:var(--bg3);border-radius:7px;padding:.14rem}
  .ds{position:fixed;bottom:0;left:0;right:0;max-height:78vh;border-radius:16px 16px 0 0}
  .ds-contacts{grid-template-columns:repeat(2,1fr)}
  /* Portal */
  .p-hdr{flex-direction:column;align-items:flex-start;gap:.6rem;margin-bottom:1.1rem}
  .p-title{font-size:1.08rem}
  .portal-main{padding:.75rem .6rem}
  .veh-grid{grid-template-columns:1fr}
  .adm-ov-grid{grid-template-columns:1fr}
  /* Hours table — stack on tiny screens */
  #hoursModalBody table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  #hoursModalBody td{padding:.25rem .3rem!important}
  #hoursModalBody input[type=time]{min-width:82px!important;font-size:.78rem!important}
  .adm-filter-bar{padding:.58rem .7rem;gap:.38rem}
  .adm-filter-bar input,.adm-filter-bar select{max-width:100%}
  .stat-card{padding:.95rem 1rem}
  .sc-num{font-size:1.5rem}
  .card{padding:1rem}
  /* Toast */
  #toast{bottom:.65rem;right:.65rem;width:calc(100% - 1.3rem)}
  /* Tables mobile: hide less critical columns, keep first 2 + last (actions) */
  .tbl-wrap table th:nth-child(4),.tbl-wrap table td:nth-child(4){display:none}
  .td-acts{flex-wrap:wrap;gap:.2rem}
  .td-acts .btn-sm{padding:.28rem .52rem;font-size:.71rem}
}
@media (max-width:420px){
  .stat-row{grid-template-columns:1fr}
  .hdr-inner{padding:0 .72rem}
  .logo{font-size:1.02rem}
  .logo-dot{width:26px;height:26px}
  .tbl-wrap table th:nth-child(5),.tbl-wrap table td:nth-child(5){display:none}
}

/* ── Notifications ────────────────────────────────────────── */
#notifPanel{display:none}
#notifPanel.open{display:block}
.notif-item{padding:.72rem .85rem;border-bottom:1px solid var(--b1);cursor:pointer;transition:background .12s}
.notif-item:hover{background:var(--bg3)}
.notif-item:last-child{border-bottom:none}
.notif-unread{background:var(--primary-l)}
.notif-unread:hover{background:rgba(13,42,110,.15)}
