/* ============================================================
   TaxiManager — design system (matches approved mockups)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  --ink:#14161C; --ink2:#1E2230; --slate:#6A7282; --mute:#9AA3B2;
  --line:#ECEFF3; --bg:#ECEFF5; --card:#FFFFFF;
  --yel:#FFC107; --yeld:#241B00; --yeldk:#F4A300;
  --green:#0FA968; --greenbg:#E4F6EE;
  --red:#F04438; --redbg:#FDECEA;
  --blue:#2F6BFF; --bluebg:#E9F0FF;
  --purp:#7A5CFF; --purpbg:#EEEAFF;
  --teal:#0FB5C9; --tealbg:#E2F7FA;
  --r:18px; --shadow:0 10px 24px rgba(20,30,60,.06);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased}
body{font-family:'Manrope',sans-serif;color:var(--ink);background:var(--bg);line-height:1.45}
a{color:inherit;text-decoration:none}
h1,h2,h3,.disp{font-family:'Sora',sans-serif;letter-spacing:-.02em}

/* ---------- generic ui ---------- */
.muted{color:var(--slate)}
.sec{font-family:'Manrope';font-weight:700;font-size:12px;letter-spacing:.13em;color:var(--mute);text-transform:uppercase;margin-bottom:11px}
.card{background:var(--card);border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.chip{display:inline-block;font-weight:700;font-size:12px;padding:6px 11px;border-radius:9px}
.chip.green{background:var(--greenbg);color:var(--green)} .chip.red{background:var(--redbg);color:var(--red)}
.chip.blue{background:var(--bluebg);color:var(--blue)} .chip.yel{background:#FFF3D6;color:var(--yeldk)}
.row{display:flex;align-items:center} .sp{justify-content:space-between} .wrap{flex-wrap:wrap}

.btn{display:inline-block;text-align:center;background:var(--yel);color:var(--yeld);font-family:'Sora';font-weight:700;
  font-size:15px;padding:14px 18px;border-radius:14px;border:0;cursor:pointer;box-shadow:0 8px 20px rgba(255,170,0,.32)}
.btn:hover{filter:brightness(.97)}
.btn.block{display:block;width:100%}
.btn.dark{background:var(--ink);color:#fff;box-shadow:0 8px 20px rgba(20,22,28,.25)}
.btn.ghost{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn.sm{padding:10px 14px;font-size:13px;border-radius:12px}

/* ---------- forms ---------- */
label{display:block;font-family:'Manrope';font-weight:600;font-size:11px;color:var(--mute);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.input,select,textarea{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:14px;
  padding:13px 15px;font-family:'Manrope';font-weight:600;font-size:15px;color:var(--ink);outline:none}
.input:focus,select:focus,textarea:focus{border-color:var(--yel);box-shadow:0 0 0 3px rgba(255,193,7,.16)}
.field{margin-bottom:14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.toggle{position:relative;width:46px;height:26px;background:#D7DCE5;border-radius:20px;display:inline-block;transition:.2s}
.toggle.on{background:var(--yel)}
.toggle b{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s}
.toggle.on b{left:23px}

/* ---------- flash ---------- */
.alert{border-radius:14px;padding:13px 16px;font-weight:600;font-size:14px;margin-bottom:16px}
.alert.ok{background:var(--greenbg);color:var(--green)}
.alert.err{background:var(--redbg);color:var(--red)}

/* ============================================================
   ADMIN LAYOUT (desktop) — mockup 01/02
   ============================================================ */
.admin{display:flex;min-height:100vh}
.side{width:240px;background:var(--ink);padding:24px 18px;position:sticky;top:0;height:100vh;flex-shrink:0}
.brand{display:flex;align-items:center;margin-bottom:30px}
.brand .mk{width:38px;height:38px;border-radius:11px;background:var(--yel);display:flex;align-items:center;
  justify-content:center;font-family:'Sora';font-weight:800;color:var(--yeld);font-size:18px;margin-right:11px}
.brand b{font-family:'Sora';font-weight:700;color:#fff;font-size:18px}
.nav a{display:flex;align-items:center;color:#9AA6BC;font-weight:600;font-size:14px;padding:12px 14px;border-radius:12px;margin-bottom:5px}
.nav a:hover{color:#fff;background:rgba(255,255,255,.05)}
.nav a.on{background:rgba(255,193,7,.12);color:var(--yel)}
.nav a .dot{width:8px;height:8px;border-radius:50%;background:currentColor;margin-right:12px;display:inline-block}
.side .note{margin-top:26px;background:rgba(255,193,7,.10);border:1px solid rgba(255,193,7,.25);border-radius:14px;padding:15px}
.side .note .l{font-weight:600;font-size:12px;color:#9AA6BC}
.side .note .n{font-family:'Sora';font-weight:800;color:var(--yel);font-size:22px;margin-top:4px}
.main{flex:1;padding:30px 34px;max-width:1180px}
.h1{font-family:'Sora';font-weight:800;font-size:27px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0}
.kpi{background:#fff;border-radius:18px;padding:20px;box-shadow:var(--shadow)}
.kpi .n{font-family:'Sora';font-weight:800;font-size:30px}
.kpi .l{font-weight:600;font-size:13px;color:var(--slate);margin-top:4px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-weight:700;font-size:11px;letter-spacing:.1em;color:var(--mute);text-transform:uppercase;padding:0 0 14px}
td{padding:15px 0;border-top:1px solid var(--line);font-weight:600;font-size:14px}
.tav{width:34px;height:34px;border-radius:10px;background:var(--ink);color:#fff;display:flex;align-items:center;
  justify-content:center;font-family:'Sora';font-weight:700;font-size:13px;margin-right:12px}

/* ============================================================
   CLIENT APP (mobile-first) — mockups 03–10
   ============================================================ */
.app{max-width:440px;margin:0 auto;min-height:100vh;background:var(--bg);padding-bottom:90px}
.apphead{display:flex;align-items:center;justify-content:space-between;padding:20px 18px 14px}
.apphead .hi{font-size:13px;color:var(--slate)}
.apphead .nm{font-family:'Sora';font-weight:700;font-size:20px;margin-top:2px}
.av{width:42px;height:42px;border-radius:14px;background:var(--yel);display:flex;align-items:center;
  justify-content:center;font-family:'Sora';font-weight:700;color:var(--yeld);font-size:16px;
  overflow:hidden;flex-shrink:0}
.pad{padding:0 18px}
.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:440px;margin:0 auto;background:#fff;
  border-top:1px solid var(--line);display:flex;padding:10px 6px;box-shadow:0 -6px 20px rgba(0,0,0,.04)}
.tabbar a{flex:1;text-align:center;font-weight:600;font-size:11px;color:var(--mute);padding:4px}
.tabbar a.on{color:var(--ink)}
.tabbar a .ic{display:block;width:22px;height:22px;margin:0 auto 4px}

/* auth */
.auth{max-width:420px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:30px 26px}
.auth .logo{width:66px;height:66px;border-radius:20px;background:var(--yel);display:flex;align-items:center;
  justify-content:center;margin:0 auto;box-shadow:0 12px 28px rgba(255,170,0,.4)}
.auth h2{text-align:center;font-family:'Sora';font-weight:800;font-size:24px;margin-top:18px}
.auth .credit{text-align:center;font-size:12px;color:var(--mute);margin-top:28px}

/* utility */
.mt8{margin-top:8px}.mt16{margin-top:16px}.mb14{margin-bottom:14px}.mb20{margin-bottom:20px}
.right{text-align:right}.center{text-align:center}

@media(max-width:820px){
  .admin{flex-direction:column}
  .side{width:100%;height:auto;position:static;display:flex;align-items:center;justify-content:space-between;padding:16px}
  .nav{display:none}.side .note{display:none}.main{padding:20px}
  .kpis{grid-template-columns:1fr 1fr}
}

/* ---------- segmented (estimate/invoice) ---------- */
.seg{flex:1;position:relative;cursor:pointer}
.seg input{position:absolute;opacity:0}
.seg span{display:block;text-align:center;padding:13px;border-radius:14px;background:#fff;
  border:1.5px solid var(--line);font-family:'Sora';font-weight:700;font-size:14px;color:var(--slate)}
.seg input:checked + span{background:var(--ink);color:#fff;border-color:var(--ink)}
textarea{resize:vertical;font-family:'Manrope'}
input[type=file]{font-family:'Manrope';font-weight:600;font-size:13px}

/* ============================================================
   INVOICE / ESTIMATE DOCUMENT
   ============================================================ */
.docbody{background:#E7EAF0;padding:18px}
.doc{max-width:760px;margin:0 auto}
.docpaper{background:#fff;border-radius:14px;padding:34px 36px;box-shadow:var(--shadow)}
.dochead{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--ink);padding-bottom:20px}
.doclogo{width:60px;height:60px;border-radius:14px;object-fit:cover}
.doclogo.ph{background:var(--yel);display:flex;align-items:center;justify-content:center;font-family:'Sora';font-weight:800;color:var(--yeld);font-size:20px}
.docco{font-family:'Sora';font-weight:800;font-size:22px;line-height:1.1}
.docmeta{font-size:12.5px;color:var(--slate);margin-top:4px;line-height:1.5}
.doctitle{font-family:'Sora';font-weight:800;font-size:22px;letter-spacing:.04em;color:var(--ink)}
.docto{margin:22px 0}
.docname{font-family:'Sora';font-weight:700;font-size:17px;margin-top:2px}
.doctable{width:100%;border-collapse:collapse;margin-top:8px}
.doctable th{background:var(--ink);color:#fff;text-align:left;font-size:11px;letter-spacing:.08em;padding:11px 14px}
.doctable th.r,.doctable td.r{text-align:right}
.doctable td{padding:14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
.doctotals{margin-left:auto;width:300px;margin-top:18px}
.doctotals .row{padding:7px 0;font-size:14px;color:var(--slate)}
.doctotals .row span:last-child{color:var(--ink);font-weight:600}
.doctotals .grand{border-top:2px solid var(--ink);margin-top:6px;padding-top:12px}
.doctotals .grand span{font-family:'Sora';font-weight:800;font-size:18px;color:var(--ink)!important}
.docwords{margin-top:22px;background:var(--bg);border-radius:10px;padding:12px 14px;font-size:13px}
.docfoot{margin-top:26px;border-top:1px solid var(--line);padding-top:14px;display:flex;justify-content:space-between;align-items:center}
.docfoot .credit{margin:0;font-size:12px}

@media print{
  .noprint{display:none!important}
  .docbody{background:#fff;padding:0}
  .docpaper{box-shadow:none;border-radius:0;padding:10px 4px}
  @page{margin:14mm}
}

/* ---------- renewal alert banner (client) ---------- */
.renewbar{background:#FFF3D6;border:1.5px solid #F4C430;color:#7a5a00;border-radius:14px;padding:13px 15px;margin-bottom:16px}
.renewbar b{color:#5a4200}

/* ---------- app footer + install sheet ---------- */
.appfoot{text-align:center;color:var(--mute);font-size:12px;font-weight:600;padding:26px 0 8px}
.appfoot b{color:var(--slate)}
.sheet{display:none;position:fixed;inset:0;background:rgba(10,12,18,.5);z-index:50;align-items:flex-end;justify-content:center}
.sheetcard{background:#fff;width:100%;max-width:440px;border-radius:22px 22px 0 0;padding:24px 22px 30px;box-shadow:0 -10px 40px rgba(0,0,0,.2)}

/* ---------- customer autocomplete ---------- */
.acList{display:none;position:absolute;left:0;right:0;top:100%;z-index:30;background:#fff;
  border:1.5px solid var(--line);border-radius:14px;margin-top:4px;box-shadow:var(--shadow);overflow:hidden}
.acItem{padding:11px 14px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--line)}
.acItem:last-child{border-bottom:0}
.acItem:hover{background:var(--bg)}
.acItem span{color:var(--mute);font-size:12px;font-weight:600}

/* logo image inside header avatar */
.av img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}

/* clickable vendor rows */
table tr[onclick]:hover{background:var(--bg)}
