/* ===== Airport Unified App — departure-board inspired theme ===== */
:root{
  --navy-900:#06305E; --navy-700:#0A4FA0; --navy-600:#1565C0;   /* Dubai blues */
  --signal:#FFC72C;            /* Dubai gold-yellow accent */
  --signal-soft:#FFEDB3;
  --bg:#F4F7FB; --surface:#FFFFFF;
  --ink:#0F1B2D; --muted:#5B6B82; --line:#E3EAF3;
  --ok:#15803D; --ok-bg:#DCFCE7;
  --warn:#B45309; --warn-bg:#FEF3C7;
  --bad:#B91C1C; --bad-bg:#FEE2E2;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --r:14px; --shadow:0 1px 2px rgba(15,27,45,.06),0 8px 24px rgba(15,27,45,.06);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
.ico{width:20px;height:20px;flex:0 0 auto}

/* ---------- shared components ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;margin-bottom:12px;box-shadow:var(--shadow)}
.card h3{margin:0 0 4px;font-size:15px;font-weight:700}
.row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.muted{color:var(--muted);font-size:13px;line-height:1.5}
.mono{font-family:var(--mono);font-weight:700;letter-spacing:.5px}
.tag{font-size:11px;background:var(--navy-900);color:#fff;padding:2px 8px;border-radius:6px;font-weight:700;letter-spacing:.4px}
.flight .tag{background:var(--navy-700)}
.pill{font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;white-space:nowrap;letter-spacing:.3px;text-transform:uppercase}
.pill.ontime,.pill.resolved,.pill.landed{background:var(--ok-bg);color:var(--ok)}
.pill.boarding,.pill.progress{background:var(--warn-bg);color:var(--warn)}
.pill.delayed,.pill.submitted{background:var(--bad-bg);color:var(--bad)}
label{display:block;font-size:13px;font-weight:600;margin:12px 0 5px;color:var(--ink)}
input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#fff;font-family:inherit;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy-600);box-shadow:0 0 0 3px rgba(27,63,115,.12)}
textarea{min-height:84px;resize:vertical}
.btn{width:100%;background:var(--navy-700);color:#fff;border:0;padding:13px;border-radius:11px;font-size:15px;font-weight:700;margin-top:14px;cursor:pointer;transition:background .15s,transform .05s}
.btn:hover{background:var(--navy-900)}
.btn:active{transform:translateY(1px)}
.btn.sec{background:var(--bg);color:var(--navy-700);border:1px solid var(--line)}
.btn.sec:hover{background:#eef2f8}
.btn.sm{width:auto;padding:8px 13px;font-size:13px;margin:0}
.btn.amber{background:var(--signal);color:#3a2a00}
.btn.amber:hover{background:#d99700}
.err{background:var(--bad-bg);color:var(--bad);padding:10px 12px;border-radius:10px;font-size:13px;margin-top:10px;font-weight:600}
.empty{text-align:center;color:var(--muted);padding:34px 12px;font-size:14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.seg{display:flex;gap:8px}
.seg button{flex:1;background:var(--surface);border:1px solid var(--line);padding:9px;border-radius:10px;font-weight:600;color:var(--navy-700);cursor:pointer}
.seg button.active{background:var(--navy-700);color:#fff;border-color:var(--navy-700)}

/* ---------- auth screen ---------- */
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px;
  background:radial-gradient(1200px 500px at 50% -10%,rgba(27,63,115,.12),transparent 60%),var(--bg)}
.auth{width:100%;max-width:380px}
.auth .brand{text-align:center;margin-bottom:18px}
.auth .brand .logo{width:58px;height:58px;border-radius:16px;background:linear-gradient(160deg,var(--navy-700),var(--navy-900));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px;box-shadow:var(--shadow)}
.auth h2{text-align:center;margin:0 0 2px}
.seg-tabs{display:flex;gap:8px;margin-bottom:6px}
.seg-tabs button{flex:1;background:var(--bg);border:1px solid var(--line);padding:9px;border-radius:10px;font-weight:700;color:var(--navy-700);cursor:pointer}
.seg-tabs button.active{background:var(--navy-700);color:#fff;border-color:var(--navy-700)}

/* ---------- console layout (staff/manager/admin) ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{width:232px;flex:0 0 232px;background:var(--surface);
  color:var(--ink);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid var(--line)}
.side-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 12px;flex-shrink:0;border-bottom:1px solid var(--line)}
.side-brand .mark{width:34px;height:34px;border-radius:10px;background:var(--navy-900);display:flex;align-items:center;justify-content:center}
.side-brand .mark .ico{color:var(--signal)}
.side-brand b{display:block;font-size:15px;letter-spacing:.2px;color:var(--navy-900)}
.side-brand small{display:block;font-size:11px;color:var(--muted)}
.side-nav{display:flex;flex-direction:column;gap:1px;padding:8px 10px;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}
.side-nav::-webkit-scrollbar{width:8px}
.side-nav::-webkit-scrollbar-thumb{background:rgba(11,37,69,.14);border-radius:8px}
.side-nav::-webkit-scrollbar-thumb:hover{background:rgba(11,37,69,.26)}
.side-link{display:flex;align-items:center;gap:11px;padding:8px 11px;border:0;background:transparent;color:var(--muted);flex-shrink:0;
  border-radius:9px;font-size:13.5px;font-weight:600;cursor:pointer;text-align:left;border-left:3px solid transparent;transition:background .15s,color .15s}
.side-link .ico{width:18px;height:18px;color:var(--muted);flex-shrink:0}
.side-link:hover{background:var(--bg);color:var(--ink)}
.side-link:hover .ico{color:var(--navy-700)}
.side-link.active{background:#e9f0fa;color:var(--navy-900);border-left-color:var(--signal);font-weight:700}
.side-link.active .ico{color:var(--navy-700)}
.side-foot{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--line);flex-shrink:0}
.side-foot .avatar{width:34px;height:34px;border-radius:50%;background:var(--signal);color:var(--navy-900);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.side-foot .who b{font-size:13px;display:block;color:var(--navy-900)}
.side-foot .who small{font-size:11px;color:var(--muted);text-transform:capitalize}
.side-foot .who{flex:1;min-width:0}
.icon-btn{background:var(--bg);border:1px solid var(--line);color:var(--ink);width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.icon-btn:hover{background:#eef2f7}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 26px;
  background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar h2{margin:0;font-size:19px;font-weight:800}
.status{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--muted)}
.status .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px var(--ok-bg)}
.content{padding:22px 26px;max-width:none;width:100%}

/* console: narrow screens collapse the sidebar to icons */
@media (max-width:860px){
  .sidebar{width:64px;flex-basis:64px}
  .side-brand b,.side-brand small,.side-link span,.side-foot .who{display:none}
  .side-brand{justify-content:center;padding:14px 0}
  .side-link{justify-content:center;border-left:0;border-bottom:3px solid transparent;padding:10px 0}
  .side-link.active{border-left:0;border-bottom-color:var(--signal)}
  .side-foot{flex-direction:column;gap:8px}
  .content,.topbar{padding-left:14px;padding-right:14px}
}

/* ---------- passenger mobile frame (mobile view only) ---------- */
.phone-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:0;
  background:radial-gradient(900px 420px at 50% -10%,rgba(27,63,115,.14),transparent 60%),var(--bg)}
.phone{width:100%;max-width:430px;height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}
.m-appbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;
  background:linear-gradient(160deg,var(--navy-700),var(--navy-900));color:#fff;
  padding-top:calc(16px + env(safe-area-inset-top))}
.m-brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:17px}
.m-brand .ico{color:var(--signal)}
.m-logout{background:rgba(255,255,255,.14);border:0;color:#fff;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.m-content{flex:1;overflow-y:auto;padding:16px 14px;-webkit-overflow-scrolling:touch}
.m-bottomnav{display:flex;background:var(--surface);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom)}
.m-nav{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px 12px;
  background:transparent;border:0;color:var(--muted);font-size:11px;font-weight:700;cursor:pointer;border-top:2px solid transparent}
.m-nav.active{color:var(--navy-900);border-top-color:var(--signal)}
.m-nav.active .ico{color:var(--navy-900)}

/* desktop: show the passenger app inside a device frame */
@media (min-width:480px){
  .phone{height:min(880px,calc(100vh - 36px));margin:18px auto;border-radius:30px;
    border:1px solid var(--line);box-shadow:0 24px 60px rgba(11,37,69,.22)}
  .m-appbar{border-radius:30px 30px 0 0}
}

@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---------- flight detail (P1-01) ---------- */
.tappable{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .05s}
.tappable:hover{border-color:var(--navy-600);box-shadow:0 4px 16px rgba(15,27,45,.1)}
.tappable:active{transform:translateY(1px)}
.back{display:inline-flex;align-items:center;gap:7px;background:none;border:0;color:var(--navy-700);
  font-weight:700;font-size:14px;cursor:pointer;padding:4px 0;margin-bottom:12px}
.back .ico{width:18px;height:18px;transform:rotate(180deg)}
.detail .d-flight{font-size:30px;font-weight:800;letter-spacing:1px;color:var(--ink)}
.route{display:flex;align-items:center;gap:12px;margin:18px 0;padding:16px;border-radius:12px;
  background:linear-gradient(160deg,var(--navy-900),var(--navy-700));color:#fff}
.route .r-end{flex:1}
.route .r-city{font-size:16px;font-weight:700}
.route .r-end .muted{color:rgba(255,255,255,.65)}
.route .r-line{color:var(--signal);display:flex;align-items:center}
.route .r-line .ico{width:26px;height:26px}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.field{background:var(--surface);padding:13px 15px}
.f-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;margin-bottom:3px}
.f-value{font-size:16px;font-weight:600;color:var(--ink)}
.f-value.mono{font-family:var(--mono);font-weight:700}

/* ---------- notifications / tracking (P1-02) ---------- */
.top-actions{display:flex;align-items:center;gap:14px}
.m-actions{display:flex;align-items:center;gap:8px}
.bell{position:relative;background:transparent;border:0;color:inherit;cursor:pointer;padding:6px;border-radius:9px;display:flex}
.topbar .bell{color:var(--navy-700)}
.topbar .bell:hover{background:var(--bg)}
.m-appbar .bell{background:rgba(255,255,255,.14);color:#fff;width:38px;height:38px;align-items:center;justify-content:center}
.badge{position:absolute;top:-2px;right:-2px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
  background:var(--bad);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.m-appbar .badge{border-color:var(--navy-900)}
.notif{border-left:3px solid transparent}
.notif.unread{border-left-color:var(--signal);background:#fffdf6}
.ok-msg{background:var(--ok-bg);color:var(--ok);padding:10px 12px;border-radius:10px;font-size:13px;font-weight:700;margin-top:10px}

/* ---------- wallet (P1-03) ---------- */
.pass{padding:0;overflow:hidden}
.pass-top{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;
  background:linear-gradient(160deg,var(--navy-700),var(--navy-900));color:#fff}
.pass-top .ico{color:var(--signal)}
.pass-air{font-size:12px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.5px}
.pass-flight{font-size:24px;font-weight:800;letter-spacing:1px}
.pass-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px 16px}
.pass-grid span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700}
.pass-grid b{font-size:15px}
.pass-foot{display:flex;align-items:center;gap:14px;padding:12px 16px;border-top:1px dashed var(--line)}
.pass-code{font-size:12px;color:var(--muted);letter-spacing:1px}
.qr{display:grid;grid-template-columns:repeat(var(--n),1fr);grid-auto-rows:1fr;width:88px;height:88px;gap:0;
  border:4px solid #fff;background:#fff;box-shadow:0 0 0 1px var(--line)}
.qr i{background:#fff}
.qr i.on{background:var(--ink)}
.link-del{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:var(--bad);
  font-size:12px;font-weight:700;cursor:pointer;padding:8px 16px}
.link-del .ico{width:15px;height:15px}

/* ---------- wallet uploads (P1-03 follow-up) ---------- */
.uploader{display:flex;gap:8px;margin-top:4px}
.up-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;
  background:var(--navy-700);color:#fff;border-radius:10px;padding:11px;font-size:14px;font-weight:700}
.up-btn.sec{background:var(--bg);color:var(--navy-700);border:1px solid var(--line)}
.up-btn .ico{width:18px;height:18px}
.up-prev{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:13px;color:var(--muted)}
.up-prev:empty{display:none}
.up-thumb{width:54px;height:54px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.up-clear{margin-left:auto;background:none;border:0;color:var(--bad);font-weight:700;cursor:pointer;font-size:13px}
.file-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);
  border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;color:var(--navy-700)}
.pass-img{width:84px;height:84px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.doc-media{margin-top:10px}
.doc-thumb{max-width:140px;max-height:120px;border-radius:10px;border:1px solid var(--line)}

/* ---------- map / navigation (P1-04) ---------- */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.chip{background:var(--bg);border:1px solid var(--line);color:var(--navy-700);border-radius:18px;
  padding:7px 13px;font-size:13px;font-weight:600;cursor:pointer}
.chip.active{background:var(--navy-700);color:#fff;border-color:var(--navy-700)}
.map-wrap{padding:10px}
.map-svg{width:100%;height:auto;display:block;background:#fff;border-radius:10px}
.m-area{fill:#EEF4FA;stroke:#D9E2EE;stroke-width:.6}
.m-cap{fill:#8aa0b8;font-size:3px;text-anchor:middle;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.m-lbl{fill:#0F1B2D;font-size:3.4px;text-anchor:middle;font-weight:700;paint-order:stroke;stroke:#fff;stroke-width:1.1}
.m-lbl.you{fill:#1B3F73}
.poi h3{display:flex;align-items:center;gap:8px}
.poi-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex:0 0 auto}
.poi.nearest{border-color:var(--signal);box-shadow:0 0 0 1px var(--signal) inset}
.dist{font-size:14px;font-weight:800;color:var(--navy-700)}
.tag.amber{background:var(--signal);color:#3a2a00}

/* ---------- admin settings ---------- */
.note{background:var(--warn-bg);color:var(--warn);padding:9px 12px;border-radius:9px;font-size:13px;font-weight:600;margin-bottom:10px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.btn-row .btn{margin-top:0}
.chk{display:flex;align-items:center;gap:8px;font-weight:600;margin:12px 0 4px}
.chk input{width:auto}
button[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- media viewer (lightbox) ---------- */
.view{cursor:pointer}
.lightbox{position:fixed;inset:0;background:rgba(8,16,30,.88);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.lightbox img{max-width:94%;max-height:90%;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:absolute;top:16px;right:20px;background:rgba(255,255,255,.15);color:#fff;border:0;
  width:42px;height:42px;border-radius:50%;font-size:26px;line-height:1;cursor:pointer}
.lb-close:hover{background:rgba(255,255,255,.3)}

/* ---------- queues (P1-05) ---------- */
.qgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.qcard{text-align:center}
.q-type{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.q-wait{font-size:38px;font-weight:800;color:var(--navy-900);line-height:1.1;margin:6px 0 8px}
.q-wait span{font-size:14px;color:var(--muted);font-weight:700;margin-left:4px}
.q-edit{display:flex;gap:6px;margin-top:12px}
.q-edit input{width:64px}
.q-edit .btn{margin-top:0}
.slot.mine{border-color:var(--signal);box-shadow:0 0 0 1px var(--signal) inset}

/* ---------- more menu + parking (P1-06) ---------- */
.note.ok{background:var(--ok-bg);color:var(--ok)}
.more-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.more-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:26px 12px;cursor:pointer;
  font-weight:700;color:var(--navy-900);box-shadow:var(--shadow)}
.more-card .ico{width:28px;height:28px;color:var(--navy-700)}
.more-card:hover{border-color:var(--navy-600)}
.park-mine{border-color:var(--signal);box-shadow:0 0 0 1px var(--signal) inset}
.pm-head{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.4px}
.pm-head .ico{width:18px;height:18px;color:var(--navy-700)}
.pm-spot{font-size:30px;font-weight:800;letter-spacing:1px;margin:4px 0 2px;color:var(--ink)}
.park-stats{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);margin-top:8px}
.park-stats .ok{color:var(--ok);font-weight:700}
.park-stats .bad{color:var(--bad);font-weight:700}
.park-stats .ev{margin-left:auto;display:inline-flex;align-items:center;gap:4px;color:var(--warn);font-weight:700}
.park-stats .ev .ico{width:14px;height:14px}
.bar{height:7px;background:var(--bg);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-top:8px}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--ok),#5cb85c)}

/* ---------- feedback & ratings (P1-07) ---------- */
.rate .stars{display:flex;gap:4px;margin:10px 0}
.stars .star{background:none;border:0;cursor:pointer;color:#cbd5e1;padding:2px;line-height:0}
.stars .star .ico{width:26px;height:26px;fill:currentColor;stroke:currentColor}
.stars .star.on{color:var(--signal)}
.rate-actions{display:flex;gap:8px;align-items:center}
.rate-actions .rate-cmt{flex:1;margin:0}
.rate-actions .btn{margin-top:0;white-space:nowrap}

/* ---------- emergency / SOS (P1-08) ---------- */
.sos-intro b{display:block;margin-bottom:4px}
.sos-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.sos-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:var(--c);color:#fff;border:0;border-radius:16px;padding:28px 12px;font-size:16px;font-weight:800;cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.18)}
.sos-btn .ico{width:30px;height:30px}
.sos-btn:active{transform:scale(.98)}
.sos-active{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok) inset}
.sos-active b{display:flex;align-items:center;gap:8px;color:var(--ok)}
.sos-card.open{border-color:var(--bad);box-shadow:0 0 0 1px var(--bad) inset}
.sos-tag{color:#fff;padding:3px 10px;border-radius:8px;font-size:13px;font-weight:800}

/* ---------- wifi + weather (P1-09) ---------- */
.inline-row{display:flex;gap:8px;align-items:center}
.inline-row input{margin:0;flex:1}
.inline-row .btn{margin-top:0;white-space:nowrap}
.wifi-head{display:flex;align-items:center;gap:8px;font-size:18px}
.wifi-head .ico{width:22px;height:22px;color:var(--navy-700)}
.voucher-label{margin-top:12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
.voucher{font-size:26px;font-weight:800;letter-spacing:3px;color:var(--ink);margin:2px 0 8px;
  background:var(--bg);border:1px dashed var(--line);border-radius:10px;padding:10px;text-align:center}
.wx-main{display:flex;align-items:center;gap:14px}
.wx-main .ico{width:46px;height:46px;color:var(--signal)}
.wx-temp{font-size:34px;font-weight:800;line-height:1}
.wx-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px}
.wx-meta span:not(.pill):not(.tag){font-size:13px;color:var(--muted);font-weight:600}

/* ---------- AI assistant (P1-10) ---------- */
.asst-intro b{margin-left:6px}
.asst-intro .ico{width:20px;height:20px;color:var(--signal);vertical-align:-4px}
.asst-chat{display:flex;flex-direction:column;gap:8px;margin:12px 0;max-height:46vh;overflow-y:auto}
.bubble{max-width:85%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.45}
.bubble.user{align-self:flex-end;background:var(--navy-700);color:#fff;border-bottom-right-radius:4px}
.bubble.bot{align-self:flex-start;background:var(--surface);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}
.asst-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-size:13px;cursor:pointer;color:var(--navy-900);font-weight:600}
.chip:hover{border-color:var(--navy-600)}
.asst-input{position:sticky;bottom:0}

/* ---------- shopping marketplace (P2-01) ---------- */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.cart-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;
  background:var(--signal);color:#fff;border-radius:999px;font-size:11px;font-weight:800;margin-left:4px}
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.prod{display:flex;flex-direction:column;gap:4px}
.prod h3{font-size:15px;margin:2px 0}
.prod-cat{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:800}
.prod-loc{display:flex;align-items:center;gap:4px;font-size:11px;margin-top:2px}
.prod-loc .ico{width:12px;height:12px}
.prod-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:8px}
.prod-foot .price{font-size:18px;font-weight:800;color:var(--ink)}
.prod-foot .btn{margin-top:0}
.cart-row{display:flex;align-items:center;justify-content:space-between}
.qty{display:flex;align-items:center;gap:12px}
.qty button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--surface);font-size:18px;cursor:pointer;line-height:1}
.qty span{min-width:18px;text-align:center;font-weight:700}
.cart-total{display:flex;align-items:center;justify-content:space-between;font-size:17px}
.order .order-total{margin-top:6px;font-weight:700}
.order.open,.order.order-new{border-color:var(--signal);box-shadow:0 0 0 1px var(--signal) inset}
@media(min-width:560px){.prod-grid{grid-template-columns:1fr 1fr 1fr}}

/* ---------- food ordering (P2-02) ---------- */
.outlet h3{margin:0 0 2px}
.menu-item{display:flex;align-items:center;justify-content:space-between;gap:10px}
.menu-foot{display:flex;align-items:center;gap:10px;white-space:nowrap}
.menu-foot .price{font-size:16px;font-weight:800;color:var(--ink)}
.menu-foot .btn{margin-top:0}
.veg{font-size:10px;font-weight:800;color:#15803d;border:1px solid #15803d;border-radius:4px;padding:0 4px;vertical-align:1px;text-transform:uppercase}
#dest-wrap{margin-top:6px}

/* ---------- lounges (P2-03) ---------- */
.lounge-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.lounge-foot .btn{margin-top:0}
.lounge-pass.used{opacity:.7}
.pass-qr{display:flex;justify-content:center;margin:12px 0 6px}

/* ---------- POI master-data manager ---------- */
.poi-cat-head{font-weight:800;color:var(--navy-900);margin:14px 2px 6px;font-size:13px;text-transform:uppercase;letter-spacing:.4px}
.poi-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.poi-row .btn-row{margin:0;white-space:nowrap}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--danger,#b91c1c)}

/* ---------- loyalty & rewards (P2-04) ---------- */
.loy-hero{text-align:center;border-top:3px solid var(--tier)}
.loy-tier{display:flex;align-items:center;justify-content:center;gap:6px;font-weight:800;color:var(--tier)}
.loy-tier .ico{width:18px;height:18px}
.loy-points{font-size:40px;font-weight:800;color:var(--ink);line-height:1.1;margin:6px 0}
.loy-points small{font-size:15px;font-weight:600;color:var(--muted)}
.loy-h{margin:18px 2px 8px;font-size:15px}
.reward{display:flex;align-items:center;justify-content:space-between;gap:10px}
.reward-foot{display:flex;align-items:center;gap:10px;white-space:nowrap}
.reward-foot .cost{font-weight:800}
.reward-foot .cost.short{color:var(--muted)}
.reward-foot .btn{margin-top:0}
.loy-txn{display:flex;align-items:center;justify-content:space-between}
.loy-txn .delta{font-weight:800;font-size:16px}
.loy-txn .delta.plus{color:#15803d}
.loy-txn .delta.minus{color:#b91c1c}

/* ---------- admin RBAC + master data ---------- */
.u-actions{display:flex;gap:6px;align-items:flex-start;white-space:nowrap}
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;margin-top:6px}
.perm{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.perm input{width:auto;margin:0}
@media(max-width:560px){.perm-grid{grid-template-columns:1fr}}

/* ---------- dashboard ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.kpi{border-radius:16px;padding:18px;color:var(--navy-900);position:relative;overflow:hidden;min-height:104px;display:flex;flex-direction:column;justify-content:space-between}
.kpi-ico{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center}
.kpi-ico .ico{width:18px;height:18px}
.kpi-val{font-size:30px;font-weight:800;line-height:1}
.kpi-label{font-size:12px;font-weight:700;opacity:.75}
.k-blue{background:#dbeafe}.k-rose{background:#fce7f3}.k-amber{background:#fef3c7}.k-red{background:#fee2e2}.k-teal{background:#cffafe}.k-green{background:#dcfce7}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.dash-panel h3{margin:0 0 12px;font-size:15px}
.split-bar{display:flex;height:16px;border-radius:8px;overflow:hidden;background:var(--line)}
.split-bar .dep{background:var(--navy-600)}.split-bar .arr{background:var(--signal)}
.split-legend{display:flex;gap:18px;margin-top:10px;font-size:13px;color:var(--muted)}
.split-legend .dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:0}
.split-legend .dot.dep{background:var(--navy-600)}.split-legend .dot.arr{background:var(--signal)}
.mini-stat{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line);font-size:14px}
.mini-stat.total{border-bottom:0;font-weight:700;margin-top:4px}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.dash-row{grid-template-columns:1fr}}
@media(max-width:560px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- role actions matrix ---------- */
.mx-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;margin-top:6px}
.mx-table{border-collapse:collapse;width:100%;font-size:13px;min-width:620px}
.mx-table th,.mx-table td{padding:10px 8px;text-align:center;border-bottom:1px solid var(--line)}
.mx-table thead th{background:var(--navy-900);color:#fff;font-weight:700;position:sticky;top:0}
.mx-table th:first-child,.mx-table td.mx-mod{text-align:left;font-weight:700;color:var(--navy-900);white-space:nowrap}
.mx-table tbody tr:nth-child(even){background:rgba(11,37,69,.025)}
.mx-table input{width:18px;height:18px;cursor:pointer;accent-color:var(--navy-700)}
.mx-table td.cell-off{background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(11,37,69,.05) 5px,rgba(11,37,69,.05) 10px)}

/* ---------- ERP data grid ---------- */
.grid-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.grid-head h2{margin:0;font-size:20px}
.total-badge{background:#e9f0fa;color:var(--navy-900);border:1px solid var(--line);border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:800;white-space:nowrap}
.grid-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.grid-search{flex:1;min-width:200px;margin:0}
.gfilter{margin:0;width:auto;min-width:150px}
.tb-actions{display:flex;gap:8px;margin-left:auto}
.gbtn{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);color:var(--navy-900);
  border-radius:9px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}
.gbtn:hover:not(:disabled){border-color:var(--navy-600);background:#fff}
.gbtn:disabled{opacity:.45;cursor:not-allowed}
.gbtn .ico{width:15px;height:15px}
.gbtn.icon-only{padding:9px 10px}
.grid-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.dgrid{border-collapse:collapse;width:100%;font-size:13px;min-width:640px;table-layout:auto}
.dgrid thead th{background:#eef2f7;color:var(--navy-900);font-weight:700;text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0}
.dgrid th.sortable{cursor:pointer;user-select:none}
.dgrid .sort-ind{margin-left:5px;font-size:10px;color:var(--navy-600)}
.dgrid .sort-ind.dim{opacity:.3}
.dgrid tbody td{padding:11px 14px;border-bottom:1px solid var(--line)}
.dgrid tbody tr{cursor:pointer}
.dgrid tbody tr:hover{background:rgba(11,37,69,.03)}
.dgrid tbody tr.sel{background:#d9f2e4}
.dgrid tbody tr.sel:hover{background:#cfeedd}
.dgrid .sel-col{width:38px;text-align:center}
.dgrid .sel-col input{accent-color:var(--navy-700);cursor:pointer}
.grid-empty{text-align:center;color:var(--muted);padding:28px}
.grid-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}
.pager{display:flex;align-items:center;gap:6px}
.pager .muted{margin:0 6px}
/* record header (ERP view) */
.record-card{margin-top:14px}
.record-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}

/* ---------- grid row actions + assign-users panel ---------- */
.act-col{text-align:right;white-space:nowrap}
.row-actions{display:flex;gap:6px;justify-content:flex-end}
.rowact{display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--line);color:var(--navy-900);
  border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}
.rowact:hover{border-color:var(--navy-600);background:#fff}
.rowact .ico{width:14px;height:14px}
.rowact.danger{color:#b91c1c;border-color:#f3c6c6}
.rowact.danger:hover{background:#fef2f2;border-color:#e57373}
.assign-list{max-height:340px;overflow-y:auto;border:1px solid var(--line);border-radius:10px}
.assign-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--line);cursor:pointer}
.assign-row:last-child{border-bottom:0}
.assign-row:hover{background:rgba(11,37,69,.03)}
.assign-row input{width:auto;margin:0;accent-color:var(--navy-700)}

/* ---------- passenger home (mobile app feel) ---------- */
.home-hero{background:linear-gradient(135deg,#13315C 0%,#1B3F73 55%,#2D6CB5 100%);color:#fff;border-radius:18px;padding:20px 18px;margin-bottom:18px;box-shadow:0 10px 24px rgba(11,37,69,.22)}
.hero-greet{font-size:22px;font-weight:800;letter-spacing:.2px}
.hero-sub{font-size:13px;opacity:.85;margin-top:3px}
.home-section{margin-bottom:18px}
.home-h{display:flex;align-items:center;justify-content:space-between;margin:0 2px 10px}
.home-h h3{margin:0;font-size:16px}
.link-btn{background:none;border:0;color:var(--navy-600);font-weight:700;font-size:13px;cursor:pointer;padding:4px}
.muted2{color:var(--muted);font-size:12.5px;margin-top:3px}
.bp-route{font-weight:600;color:var(--ink);margin-top:2px}
.empty-cta{display:flex;flex-direction:column;gap:10px;align-items:flex-start;color:var(--muted)}
.boarding-grad{border-left:4px solid var(--signal)}
/* wallet cards */
.wallet-card{background:linear-gradient(135deg,#0B2545,#1B3F73);color:#fff;border:0;border-radius:16px;padding:16px;box-shadow:0 10px 24px rgba(11,37,69,.25)}
.wc-top{display:flex;justify-content:space-between;font-size:11px;letter-spacing:1.5px;opacity:.8;font-weight:700}
.wc-main{display:flex;gap:18px;margin:14px 0}
.wc-label{font-size:10px;opacity:.7;letter-spacing:.6px}
.wc-val{font-size:17px;font-weight:800;margin-top:2px}
.wc-barcode{background:#fff;border-radius:8px;padding:8px;display:flex;justify-content:center}
.wallet-tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.tile{display:flex;align-items:center;gap:10px;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:13px;cursor:pointer;box-shadow:var(--shadow)}
.tile:hover{border-color:var(--navy-600)}
.tile b{display:block;font-size:13.5px}
.tile small{color:var(--muted);font-size:11.5px}
.tile-ico{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tile-nav .tile-ico{background:#dbeafe;color:#1B3F73}
.tile-doc .tile-ico{background:var(--signal-soft);color:#92600a}
.tile-ico .ico{width:18px;height:18px}

/* ---------- profile chip + menu + modal ---------- */
.avatar.sm{width:30px;height:30px;border-radius:50%;background:var(--signal);color:var(--navy-900);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}
.profile-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 10px 5px 5px;cursor:pointer;font-weight:700;color:var(--ink)}
.profile-chip:hover{border-color:var(--navy-600)}
.profile-chip .pc-name{font-size:13px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-chip .ico{width:15px;height:15px;color:var(--muted)}
.m-profile{background:transparent;border:0;cursor:pointer;padding:0}
.pop-layer{position:fixed;inset:0;z-index:60}
.menu-pop{position:fixed;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 32px rgba(15,27,45,.18);min-width:230px;overflow:hidden;padding:6px}
.mp-head{display:flex;align-items:center;gap:10px;padding:10px 10px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.mp-head b{font-size:13.5px;display:block}
.mp-head small{font-size:11.5px;color:var(--muted)}
.mp-item{display:flex;align-items:center;gap:11px;width:100%;background:none;border:0;padding:11px 10px;border-radius:9px;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink);text-align:left}
.mp-item:hover{background:var(--bg)}
.mp-item .ico{width:17px;height:17px;color:var(--muted)}
.mp-item.danger{color:var(--bad)}
.mp-item.danger .ico{color:var(--bad)}
.modal-layer{position:fixed;inset:0;z-index:70;background:rgba(11,37,69,.45);display:flex;align-items:center;justify-content:center;padding:20px}
.modal-card{background:#fff;border-radius:16px;padding:22px;width:100%;max-width:380px;box-shadow:0 20px 50px rgba(15,27,45,.3)}
.prof-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.prof-row:last-of-type{border-bottom:0}
.prof-row span{color:var(--muted)}
.cp-msg{margin-top:10px;font-size:13px;font-weight:600}
.cp-msg.err{color:var(--bad)}
.cp-msg.ok{color:var(--ok)}

/* status pills for Users grid */
.pill.active{background:var(--ok-bg);color:var(--ok)}
.pill.inactive{background:#eef2f7;color:var(--muted)}

/* ---------- payments (P2-05) ---------- */
.order-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;flex-wrap:wrap}
.pay-btn{display:inline-flex;align-items:center;gap:6px}
.pay-btn .ico{width:15px;height:15px}
.paid-badge{display:inline-flex;align-items:center;gap:5px;background:var(--ok-bg);color:var(--ok);font-weight:800;font-size:12px;padding:5px 10px;border-radius:8px}
.paid-badge .ico{width:14px;height:14px}
.paid-badge.sm{padding:2px 7px;font-size:11px;margin-top:3px}
.pay-methods{display:flex;flex-direction:column;gap:8px;margin:6px 0 12px}
.pay-card{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;padding:11px 12px;cursor:pointer;font-weight:600;font-size:14px}
.pay-card:has(input:checked){border-color:var(--navy-600);background:#f3f7fc}
.pay-card input{width:auto;margin:0;accent-color:var(--navy-700)}
.chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-top:8px}
.chk input{width:auto;margin:0;accent-color:var(--navy-700)}
.pay-demo{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:12px;margin-top:12px}
.pay-demo .ico{width:14px;height:14px}
.pm-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
/* receipt */
.receipt{text-align:center}
.rc-check{width:54px;height:54px;border-radius:50%;background:var(--ok-bg);color:var(--ok);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.rc-check .ico{width:28px;height:28px}
.receipt h3{margin:0 0 4px}
.rc-amt{font-size:28px;font-weight:800;margin-bottom:14px}
.rc-rows{text-align:left;border:1px solid var(--line);border-radius:12px;padding:6px 12px;margin-bottom:14px}
.rc-rows div{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.rc-rows div:last-child{border-bottom:0}
.rc-rows span{color:var(--muted)}

/* ---------- baggage tracking (P2-06) ---------- */
.bag-trackform{display:flex;gap:8px}
.bag-trackform input{flex:1;margin:0}
.bag-card .bag-track{margin-top:10px}
.bag-track{position:relative;margin:6px 0 4px;padding-left:4px}
.bag-step{position:relative;display:flex;gap:12px;padding:0 0 14px 26px}
.bag-step::before{content:'';position:absolute;left:9px;top:18px;bottom:-2px;width:2px;background:var(--line)}
.bag-step:last-child::before{display:none}
.bag-dot{position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;border:2px solid var(--line);background:var(--surface);display:flex;align-items:center;justify-content:center}
.bag-dot .ico{width:12px;height:12px;color:#fff}
.bag-step.done .bag-dot{background:var(--ok);border-color:var(--ok)}
.bag-step.done::before{background:var(--ok)}
.bag-step.current .bag-dot{background:var(--signal);border-color:var(--signal);box-shadow:0 0 0 4px var(--signal-soft)}
.bag-step.future .bag-info b{color:var(--muted)}
.bag-info b{font-size:14px}

/* ---------- currency exchange (P2-07) ---------- */
.fx-row{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}
.fx-row > div{flex:1;min-width:70px}
.fx-row .fx-amt{flex:1.4}
.fx-row select,.fx-row input{margin:0}
.fx-swap{flex:0 0 auto;width:38px;height:42px;border:1px solid var(--line);background:var(--bg);border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--navy-700)}
.fx-swap:hover{background:#eef2f7}
.fx-swap .ico{width:18px;height:18px}
.fx-result{margin-top:12px;background:#f3f7fc;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:13px;color:var(--muted)}
.fx-get{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.fx-get b{font-size:24px;color:var(--navy-900)}
.fx-order .link-del{margin-top:8px}

/* ---------- hotels (P2-08) ---------- */
.hotel-amen{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.hotel-amen span{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:11.5px;color:var(--muted);font-weight:600}
.hotel-rooms{margin-top:8px;border-top:1px solid var(--line)}
.room-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.room-row:last-child{border-bottom:0}
.room-buy{text-align:right;flex-shrink:0}
.room-price{font-weight:800;font-size:15px;color:var(--navy-900)}
.room-price small{font-weight:600;color:var(--muted);font-size:11px}
.pill.paid{background:var(--ok-bg);color:var(--ok)}
.pill.unpaid{background:var(--warn-bg);color:var(--warn)}
.pill.checkedin{background:var(--warn-bg);color:var(--warn)}

/* ---------- ground transport (P2-09) ---------- */
.tr-card{display:flex;gap:14px;align-items:flex-start}
.tr-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#e9f0fa;color:var(--navy-700)}
.tr-ico .ico{width:22px;height:22px}
.tr-metro{background:#dbeafe;color:#1d4ed8}.tr-bus{background:#dcfce7;color:#15803d}
.tr-taxi{background:#fef3c7;color:#a16207}.tr-ride{background:#ede9fe;color:#6d28d9}
.tr-rental{background:#ffe4e6;color:#be123c}.tr-shuttle{background:#cffafe;color:#0e7490}
.tr-main{flex:1;min-width:0}
.tr-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.tr-top b{font-size:15px}
.tr-price{font-weight:800;color:var(--navy-900);white-space:nowrap}
.tr-info{margin-top:7px;font-size:13px;color:var(--ink);background:var(--bg);border-radius:9px;padding:8px 10px}
.tr-main .muted2 .ico{width:13px;height:13px;vertical-align:-2px}

/* ---------- airport assistance (P2-10) ---------- */
.as-card{display:flex;gap:14px;align-items:flex-start}
.as-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#e9f0fa;color:var(--navy-700)}
.as-ico .ico{width:22px;height:22px}
.as-main{flex:1;min-width:0}
.as-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.as-top b{font-size:15px}
.as-price{font-weight:800;color:var(--navy-900);white-space:nowrap}
.as-main .btn.sm{margin-top:10px}
.free-badge{background:var(--ok-bg);color:var(--ok);font-weight:800;font-size:12px;padding:3px 10px;border-radius:999px}
.as-req .order-foot{margin-top:10px}

/* ---------- branding / logo ---------- */
.brand-logo{height:34px;width:34px;border-radius:9px;object-fit:contain;background:#fff;padding:2px}
.brand-logo.sm{height:26px;width:26px;border-radius:7px}
.auth-logo{height:64px;max-width:160px;object-fit:contain;margin:0 auto 6px;display:block}
.m-brand .brand-logo{background:rgba(255,255,255,.12)}
.brand-upload{display:flex;align-items:center;gap:14px;margin:6px 0 12px}
.brand-preview{width:72px;height:72px;border:1px dashed var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden;flex-shrink:0}
.brand-preview img{max-width:100%;max-height:100%;object-fit:contain}
.brand-upload-btns{display:flex;flex-direction:column;gap:8px}

/* ---------- lost & found (P2-11) ---------- */
.lf-note{margin-top:8px;background:var(--signal-soft);border-radius:9px;padding:8px 10px;font-size:13px;color:#7a5b00}
.lf-note .ico{width:13px;height:13px;vertical-align:-2px}
.lf-req .link-del{margin-top:8px}
