/* =====================================================================
   Toyota Fleet Management Portal — Mockup design system
   Static, no-backend prototype. Visual only.
   ===================================================================== */
:root{
  --toyota-red:#EB0A1E;
  --toyota-red-dark:#C30815;
  --navy:#13294B;
  --navy-2:#1A3A5C;
  --navy-3:#24507c;
  --ink:#1f2733;
  --muted:#6b7785;
  --line:#e4e8ee;
  --line-2:#eef1f5;
  --bg:#f4f6f9;
  --card:#ffffff;
  --green:#1f9d57;
  --green-bg:#e6f6ee;
  --amber:#c98a00;
  --amber-bg:#fdf3df;
  --red-bg:#fdeaec;
  --blue:#2563eb;
  --blue-bg:#e8f0fe;
  --purple:#6d28d9;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 1px 2px rgba(16,28,48,.06),0 6px 20px rgba(16,28,48,.06);
  --shadow-lg:0 12px 40px rgba(16,28,48,.16);
  --sidebar-w:248px;
  --font:'Segoe UI',Roboto,-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{margin:0;font-weight:700;color:var(--ink);letter-spacing:-.01em}
p{margin:0 0 12px}
small{font-size:12px}
.muted{color:var(--muted)}
.mono{font-family:'Consolas','SFMono-Regular',Menlo,monospace}
.center{text-align:center}
.nowrap{white-space:nowrap}
.hidden{display:none!important}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;border-radius:8px;
  padding:9px 16px;font-size:13.5px;font-weight:600;cursor:pointer;background:#fff;color:var(--ink);
  transition:.15s ease;font-family:inherit;line-height:1}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--toyota-red);color:#fff}
.btn-primary:hover{background:var(--toyota-red-dark)}
.btn-navy{background:var(--navy-2);color:#fff}
.btn-navy:hover{background:var(--navy)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:#f7f9fc;border-color:#cfd6e0}
.btn-soft{background:var(--bg);color:var(--ink);border-color:transparent}
.btn-soft:hover{background:#e9edf3}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-lg{padding:13px 22px;font-size:15px;width:100%;justify-content:center}
.btn-block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ---------- App shell ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--navy);color:#cdd7e5;position:fixed;inset:0 auto 0 0;
  display:flex;flex-direction:column;z-index:40}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .brand .logo{width:38px;height:38px;border-radius:9px;background:#fff;display:grid;place-items:center;flex:none}
.sidebar .brand .logo svg{width:26px;height:26px}
.sidebar .brand b{color:#fff;font-size:14.5px;display:block;line-height:1.15}
.sidebar .brand span{font-size:11px;color:#8ea3bd}
.nav{padding:12px 12px;overflow-y:auto;flex:1}
.nav .group{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:#6f87a6;margin:16px 12px 6px;font-weight:700}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:#c2cfdf;font-weight:500;font-size:13.5px;margin-bottom:2px;position:relative}
.nav a svg{width:18px;height:18px;flex:none;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a.active{background:var(--toyota-red);color:#fff}
.nav a.active svg{opacity:1}
.nav a .badge{margin-left:auto}
.sidebar .side-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:11.5px;color:#7e93af}

.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}
.topbar{height:62px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:16px;padding:0 26px;position:sticky;top:0;z-index:30}
.topbar .menu-btn{display:none}
.topbar .search{flex:1;max-width:420px;position:relative}
.topbar .search input{width:100%;border:1px solid var(--line);background:var(--bg);border-radius:9px;
  padding:9px 12px 9px 36px;font-size:13.5px;font-family:inherit}
.topbar .search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted)}
.topbar .sp{flex:1}
.icon-btn{position:relative;width:40px;height:40px;border-radius:9px;border:1px solid var(--line);background:#fff;
  display:grid;place-items:center;cursor:pointer;color:var(--ink)}
.icon-btn:hover{background:var(--bg)}
.icon-btn svg{width:19px;height:19px}
.icon-btn .dot{position:absolute;top:7px;right:8px;width:8px;height:8px;background:var(--toyota-red);border-radius:50%;border:2px solid #fff}
.userchip{display:flex;align-items:center;gap:10px;cursor:pointer;padding:4px 6px 4px 4px;border-radius:30px}
.userchip:hover{background:var(--bg)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--navy-2);color:#fff;display:grid;place-items:center;
  font-weight:700;font-size:13px;flex:none}
.userchip .who{line-height:1.1}
.userchip .who b{font-size:13px}
.userchip .who span{font-size:11.5px;color:var(--muted)}

.content{padding:26px;max-width:1280px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head .ph-text{flex:1;min-width:240px}
.page-head h1{font-size:23px}
.page-head .sub{color:var(--muted);margin-top:4px}
.page-head .actions{display:flex;gap:10px;flex-wrap:wrap}
.crumbs{font-size:12.5px;color:var(--muted);margin-bottom:10px;display:flex;gap:7px;align-items:center}
.crumbs a:hover{color:var(--toyota-red)}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:20px}
.card-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-2)}
.card-head h3{font-size:15px}
.card-head .sp{flex:1}
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.row{display:flex;gap:18px;flex-wrap:wrap}
.col{flex:1;min-width:0}
@media(max-width:1080px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:1fr}}
@media(max-width:760px){.g-2,.g-4{grid-template-columns:1fr}}

/* ---------- Stat cards ---------- */
.stat{display:flex;flex-direction:column;gap:6px}
.stat .lab{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px}
.stat .val{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1}
.stat .delta{font-size:12px;font-weight:600}
.stat .ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none}
.stat-top{display:flex;justify-content:space-between;align-items:flex-start}
.up{color:var(--green)}.down{color:var(--toyota-red)}

/* ---------- Badges / pills ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:30px;font-size:11.5px;font-weight:700;line-height:1.4;white-space:nowrap}
.badge .d{width:7px;height:7px;border-radius:50%;background:currentColor}
.b-green{background:var(--green-bg);color:#15824a}
.b-amber{background:var(--amber-bg);color:#9a6a00}
.b-red{background:var(--red-bg);color:#c30815}
.b-blue{background:var(--blue-bg);color:#1d4ed8}
.b-grey{background:#eef1f5;color:#5b6878}
.b-purple{background:#f1e9fd;color:#6d28d9}
.b-navy{background:#e7eef7;color:#1A3A5C}
.count{display:inline-grid;place-items:center;min-width:19px;height:19px;padding:0 6px;border-radius:30px;background:var(--toyota-red);color:#fff;font-size:11px;font-weight:700}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  font-weight:700;padding:11px 16px;border-bottom:1px solid var(--line);background:#fafbfd}
.table td{padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.table tbody tr{cursor:pointer;transition:.12s}
.table tbody tr:hover{background:#f8fafc}
.table tbody tr:last-child td{border-bottom:none}
.table .jid{font-weight:700;color:var(--navy-2)}
.table-wrap{overflow-x:auto}
.checkcol{width:38px}
input[type=checkbox]{width:16px;height:16px;accent-color:var(--toyota-red);cursor:pointer}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.field label .req{color:var(--toyota-red)}
.field .hint{font-size:12px;color:var(--muted);margin-top:5px}
.input,select.input,textarea.input{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;
  font-size:13.5px;font-family:inherit;background:#fff;color:var(--ink);transition:.15s}
.input:focus,textarea.input:focus,select.input:focus{outline:none;border-color:var(--toyota-red);box-shadow:0 0 0 3px rgba(235,10,30,.12)}
textarea.input{resize:vertical;min-height:90px}
.input.ok{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,157,87,.1)}
.input.err{border-color:var(--toyota-red);box-shadow:0 0 0 3px rgba(235,10,30,.1)}
.field-row{display:flex;gap:16px;flex-wrap:wrap}
.field-row>.field{flex:1;min-width:180px}

/* ---------- Steps / wizard ---------- */
.steps{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.steps .step{display:flex;align-items:center;gap:10px;flex:1;min-width:160px}
.steps .num{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;
  background:#fff;border:2px solid var(--line);color:var(--muted);flex:none}
.steps .step.done .num{background:var(--green);border-color:var(--green);color:#fff}
.steps .step.active .num{background:var(--toyota-red);border-color:var(--toyota-red);color:#fff}
.steps .step .t{font-size:13px;font-weight:600;color:var(--muted)}
.steps .step.active .t,.steps .step.done .t{color:var(--ink)}
.steps .bar{flex:1;height:2px;background:var(--line);min-width:20px}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-left:6px}
.tl-item{position:relative;padding:0 0 22px 28px;border-left:2px solid var(--line)}
.tl-item:last-child{border-left-color:transparent;padding-bottom:0}
.tl-dot{position:absolute;left:-9px;top:0;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--muted)}
.tl-item.green .tl-dot{border-color:var(--green)}
.tl-item.red .tl-dot{border-color:var(--toyota-red)}
.tl-item.blue .tl-dot{border-color:var(--blue)}
.tl-item.amber .tl-dot{border-color:var(--amber)}
.tl-item .tl-t{font-weight:600;font-size:13.5px}
.tl-item .tl-m{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ---------- Comments / conversation ---------- */
.thread{display:flex;flex-direction:column;gap:18px}
.msg{display:flex;gap:12px}
.msg .avatar{flex:none}
.msg .bubble{flex:1}
.msg .bubble .meta{display:flex;align-items:center;gap:9px;margin-bottom:4px;flex-wrap:wrap}
.msg .bubble .meta b{font-size:13.5px}
.msg .bubble .meta .time{font-size:11.5px;color:var(--muted)}
.msg .bubble .body{background:var(--bg);border:1px solid var(--line-2);border-radius:0 10px 10px 10px;padding:11px 14px;font-size:13.5px}
.msg.me .bubble .body{background:#fdeef0;border-color:#f8d6db}
.msg .body .tag{color:var(--blue);font-weight:600}
.composer{border:1px solid var(--line);border-radius:10px;padding:10px;margin-top:4px}
.composer textarea{width:100%;border:none;resize:vertical;min-height:60px;font-family:inherit;font-size:13.5px;outline:none}
.composer .tools{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--line-2)}
.mention-pop{position:absolute;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);
  width:260px;overflow:hidden;z-index:50}
.mention-pop .mi{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer}
.mention-pop .mi:hover{background:var(--bg)}

/* ---------- Status grid (website health) ---------- */
.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.site{border:1px solid var(--line);border-radius:12px;background:#fff;padding:16px;cursor:pointer;transition:.15s;position:relative;overflow:hidden}
.site:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.site .strip{position:absolute;left:0;top:0;bottom:0;width:4px}
.site.healthy .strip{background:var(--green)}
.site.issue .strip{background:var(--toyota-red)}
.site.warn .strip{background:var(--amber)}
.site .name{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.site .url{font-size:12px;color:var(--muted);margin:3px 0 12px}
.site .metric{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-top:1px dashed var(--line-2)}
.heart{display:inline-flex;width:120px;height:30px;align-items:flex-end;gap:2px}
.heart i{flex:1;background:var(--green);border-radius:2px;opacity:.7}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line-2);margin:18px 0}
.alert{display:flex;gap:12px;padding:13px 16px;border-radius:10px;font-size:13.5px;align-items:flex-start}
.alert svg{width:19px;height:19px;flex:none;margin-top:1px}
.alert-info{background:var(--blue-bg);color:#1d4ed8}
.alert-warn{background:var(--amber-bg);color:#8a5a00}
.alert-success{background:var(--green-bg);color:#15824a}
.alert-danger{background:var(--red-bg);color:#c30815}
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted)}
.kv .v{font-weight:600}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:30px;background:var(--bg);
  border:1px solid var(--line);font-size:12.5px;font-weight:600;cursor:pointer}
.chip.on{background:var(--navy-2);color:#fff;border-color:var(--navy-2)}
.progress{height:8px;background:var(--line);border-radius:30px;overflow:hidden}
.progress i{display:block;height:100%;background:var(--toyota-red);border-radius:30px}
.ring{position:relative;width:130px;height:130px}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:20px}
.tabs .tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs .tab:hover{color:var(--ink)}
.tabs .tab.active{color:var(--toyota-red);border-bottom-color:var(--toyota-red)}
.tab-pane{display:none}
.tab-pane.active{display:block}
.countdown{display:flex;gap:8px}
.countdown .seg{background:var(--navy);color:#fff;border-radius:8px;padding:8px 0;text-align:center;min-width:52px}
.countdown .seg b{font-size:20px;font-weight:800;display:block;line-height:1}
.countdown .seg span{font-size:10px;text-transform:uppercase;letter-spacing:.05em;opacity:.7}
.dot-list{list-style:none;padding:0;margin:0}
.dot-list li{display:flex;gap:10px;padding:8px 0;font-size:13.5px;align-items:flex-start}
.dot-list li svg{width:17px;height:17px;flex:none;margin-top:1px;color:var(--green)}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;right:22px;bottom:22px;display:flex;flex-direction:column;gap:10px;z-index:99}
.toast{background:var(--navy);color:#fff;padding:13px 16px;border-radius:10px;box-shadow:var(--shadow-lg);
  font-size:13.5px;display:flex;align-items:center;gap:10px;animation:slidein .25s ease}
.toast svg{width:18px;height:18px;color:#6ee7a8}
@keyframes slidein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;background:rgba(15,25,45,.5);display:none;place-items:center;z-index:60;padding:20px}
.modal-back.open{display:grid}
.modal{background:#fff;border-radius:14px;max-width:480px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden}
.modal .m-head{padding:18px 22px;border-bottom:1px solid var(--line-2);display:flex;align-items:center}
.modal .m-body{padding:22px}
.modal .m-foot{padding:16px 22px;border-top:1px solid var(--line-2);display:flex;gap:10px;justify-content:flex-end}

/* ---------- Auth pages ---------- */
.auth{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.auth .promo{background:linear-gradient(150deg,var(--navy) 0%,#0d1c33 100%);color:#fff;padding:54px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.auth .promo:after{content:"";position:absolute;right:-120px;bottom:-120px;width:380px;height:380px;border-radius:50%;background:var(--toyota-red);opacity:.16}
.auth .promo .brand{display:flex;align-items:center;gap:12px;margin-bottom:auto}
.auth .promo .logo{width:46px;height:46px;border-radius:11px;background:#fff;display:grid;place-items:center}
.auth .promo h2{color:#fff;font-size:30px;line-height:1.2;margin-bottom:14px;max-width:440px}
.auth .promo p{color:#aebfd6;max-width:420px;font-size:15px}
.auth .promo .feat{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.auth .promo .feat .fi{display:flex;gap:12px;align-items:center;font-size:14px;color:#d6e1f0}
.auth .promo .feat .fi .fic{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex:none}
.auth .formside{display:grid;place-items:center;padding:40px;background:#fff}
.auth .formbox{width:100%;max-width:380px}
.auth .formbox h1{font-size:24px;margin-bottom:6px}
.auth .formbox .lead{color:var(--muted);margin-bottom:26px}
.otp{display:flex;gap:10px;justify-content:space-between;margin:8px 0 4px}
.otp input{width:52px;height:60px;text-align:center;font-size:24px;font-weight:700;border:1.5px solid var(--line);border-radius:11px;font-family:inherit}
.otp input:focus{outline:none;border-color:var(--toyota-red);box-shadow:0 0 0 3px rgba(235,10,30,.12)}
@media(max-width:880px){.auth{grid-template-columns:1fr}.auth .promo{display:none}}

/* ---------- Responsive shell ---------- */
@media(max-width:980px){
  .sidebar{transform:translateX(-100%);transition:.25s}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .topbar .menu-btn{display:grid}
  .topbar .search{display:none}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35;display:none}
  .scrim.show{display:block}
}
