/* ===== EXCLUSIVE DETAILING — Admin (mobile-first) ===== */
:root{
  --bg:#05070d;
  --bg-2:#080b15;
  --panel:#0c1120;
  --panel-2:#11172a;
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.14);
  --text:#f4f6fb;
  --muted:#6b748a;
  --muted-2:#aab2c5;
  --blue:#2b7bff;
  --blue-2:#5a96ff;
  --blue-3:#86c1ff;
  --blue-soft:rgba(43,123,255,.18);
  --blue-ring:rgba(43,123,255,.35);
  --blue-glow:rgba(43,123,255,.45);
  --green:#5ee07d;
  --red:#ff7676;
  --amber:#f3b945;
  --chrome:linear-gradient(180deg,#f4f6f8 0%,#c2c8d2 35%,#7a8090 65%,#d8dde5 100%);
  --shadow-card:0 1px 0 rgba(255,255,255,.04) inset, 0 30px 60px -30px rgba(0,0,0,.7);
  --radius-sm:10px;
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:24px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(900px 600px at 100% 0%, rgba(43,123,255,.08), transparent 60%),
    radial-gradient(700px 600px at 0% 100%, rgba(43,123,255,.06), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:14.5px;line-height:1.5;
  letter-spacing:-0.005em;
  font-feature-settings:'ss01','cv11';
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* ---------- LAYOUT ---------- */
.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg, var(--panel), var(--bg-2));
  border-right:1px solid var(--line);
  padding:22px 18px;display:flex;flex-direction:column;gap:6px;
  position:sticky;top:0;height:100vh;
}
.sidebar .brand{display:flex;align-items:center;gap:10px;margin-bottom:22px}
.sidebar .brand img{width:36px;height:36px;filter:drop-shadow(0 4px 10px var(--blue-glow))}
.sidebar .brand span{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px}
.sidebar .brand em{font-style:normal;color:var(--blue-2);margin-left:3px}
.nav-link{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-radius:10px;color:var(--muted-2);font-weight:600;font-size:14px;
  transition:background .15s, color .15s;
}
.nav-link svg{width:16px;height:16px;flex-shrink:0;opacity:.8}
.nav-link:hover{background:rgba(255,255,255,.04);color:var(--text)}
.nav-link.active{
  background:linear-gradient(135deg,rgba(43,123,255,.18),rgba(43,123,255,.04));
  color:var(--text);border:1px solid var(--blue-ring);
}
.nav-link.active svg{opacity:1;color:var(--blue-2)}
.sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.sidebar-foot a{display:block;padding:8px 14px;border-radius:10px;color:var(--muted-2)}
.sidebar-foot a:hover{background:rgba(255,255,255,.04);color:var(--text)}

.content{padding:28px 32px 80px;max-width:1280px;width:100%}

/* ---------- TOPBAR ---------- */
.topbar{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.topbar h1{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:1.5px;margin:0;text-transform:uppercase;line-height:1}
.topbar .sub{color:var(--muted-2);font-size:13.5px;margin-top:6px}
.topbar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  padding:11px 16px;border-radius:10px;
  font-weight:600;font-size:13.5px;
  border:1px solid var(--line-strong);background:rgba(255,255,255,.04);color:var(--text);
  transition:background .15s, border-color .15s, transform .12s;
  min-height:42px;
  white-space:nowrap;
}
.btn:hover{background:rgba(255,255,255,.08);border-color:var(--blue-ring)}
.btn:disabled{opacity:.5;pointer-events:none}
.btn.primary{
  background:linear-gradient(135deg,var(--blue),#1850b8);color:#fff;border-color:transparent;
  box-shadow:0 10px 28px -10px var(--blue-glow);
}
.btn.primary:hover{transform:translateY(-1px);background:linear-gradient(135deg,#3a87ff,#1d62db)}
.btn.danger{color:var(--red);border-color:rgba(255,118,118,.35)}
.btn.danger:hover{background:rgba(255,118,118,.08)}
.btn.sm{padding:7px 12px;font-size:12.5px;min-height:34px}
.btn.big{padding:15px 22px;font-size:14.5px;min-height:50px}
.btn.ghost{background:transparent}

/* ---------- KPI CARDS ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:24px}
.kpi{
  padding:22px 22px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);
  box-shadow:var(--shadow-card);
}
.kpi .label{font-size:11.5px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;font-weight:700;margin-bottom:8px}
.kpi .value{font-family:'Bebas Neue',sans-serif;font-size:34px;letter-spacing:1px;color:var(--text);line-height:1}
.kpi .sub{font-size:12.5px;color:var(--muted);margin-top:6px}
.kpi.accent{background:linear-gradient(135deg,rgba(43,123,255,.18),var(--panel-2));border-color:var(--blue-ring)}
.kpi.accent .value{color:var(--blue-2)}
.kpi.green .value{color:var(--green)}
.kpi.amber .value{color:var(--amber)}

/* ---------- PANELS ---------- */
.panel{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:20px 22px;
  margin-bottom:20px;
  box-shadow:var(--shadow-card);
}
.panel h2{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:1.5px;margin:0 0 16px;text-transform:uppercase}
.panel .head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.panel .head h2{margin:0}

/* ---------- TABLE ---------- */
.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.tbl th{
  text-align:left;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line);
}
.tbl td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(255,255,255,.02)}
.tbl .name{font-weight:600;color:var(--text)}
.tbl .muted{color:var(--muted);font-size:12.5px}
.tbl .nowrap{white-space:nowrap}
.tbl-wrap{overflow-x:auto;margin:0 -22px;padding:0 22px;-webkit-overflow-scrolling:touch}

/* ---------- STATUS BADGES ---------- */
.pill{
  display:inline-block;padding:3px 10px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
}
.pill.new{background:rgba(78,160,255,.15);color:var(--blue-3);border:1px solid rgba(78,160,255,.4)}
.pill.confirmed{background:rgba(94,224,125,.13);color:var(--green);border:1px solid rgba(94,224,125,.4)}
.pill.done{background:rgba(170,181,204,.12);color:var(--muted-2);border:1px solid rgba(170,181,204,.3)}
.pill.cancelled{background:rgba(255,118,118,.13);color:var(--red);border:1px solid rgba(255,118,118,.4)}
.pill.paid{background:rgba(94,224,125,.13);color:var(--green);border:1px solid rgba(94,224,125,.4)}
.pill.unpaid{background:rgba(243,185,69,.13);color:var(--amber);border:1px solid rgba(243,185,69,.4)}

/* ---------- INPUTS ---------- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:11px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;font-weight:700}
.field input,.field select,.field textarea{
  background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:10px;
  padding:12px 13px;color:var(--text);font-size:14.5px;font-family:inherit;
  transition:border-color .15s, background .15s;
  min-height:44px;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-2);background:rgba(0,0,0,.55)}

/* ---------- MODAL ---------- */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:120;
  display:flex;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(8px);
}
.modal{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line-strong);border-radius:var(--radius-lg);
  max-width:640px;width:100%;max-height:90vh;overflow-y:auto;padding:28px;
  box-shadow:0 40px 100px -20px rgba(0,0,0,.7);
}
.modal h2{font-family:'Bebas Neue',sans-serif;font-size:26px;margin:0 0 4px;letter-spacing:1.5px;text-transform:uppercase}
.modal .sub{color:var(--muted);font-size:13px;margin-bottom:16px}
.modal .row{display:flex;gap:12px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.modal .row > *{flex:1;min-width:0}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}
.modal-foot .btn{flex:0 0 auto}

/* ---------- LINE ITEMS (invoice editor) ---------- */
.li-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.li-row{
  display:grid;
  grid-template-columns:1fr 130px 38px;
  gap:8px;align-items:center;
}
.li-row input{
  background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:10px;
  padding:11px 12px;color:var(--text);font-size:14px;font-family:inherit;
  min-height:44px;
  transition:border-color .15s, background .15s;
  width:100%;
}
.li-row input:focus{outline:none;border-color:var(--blue-2);background:rgba(0,0,0,.55)}
.li-row .li-amt{position:relative}
.li-row .li-amt::before{
  content:"$";position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:var(--muted);font-weight:600;pointer-events:none;font-size:14px;
}
.li-row .li-amt input{padding-left:24px}
.li-row .li-rm{
  width:38px;height:44px;border-radius:10px;
  background:rgba(255,118,118,.08);border:1px solid rgba(255,118,118,.3);
  color:var(--red);cursor:pointer;font-size:18px;
  display:flex;align-items:center;justify-content:center;
}
.li-row .li-rm:hover{background:rgba(255,118,118,.16)}

.li-preset{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;
}
.li-preset button{
  padding:6px 12px;border-radius:999px;
  background:rgba(43,123,255,.08);border:1px solid var(--blue-ring);
  color:var(--blue-2);font-size:12px;font-weight:600;
  cursor:pointer;transition:background .15s;
}
.li-preset button:hover{background:rgba(43,123,255,.16)}

.inv-totals{
  margin-top:12px;padding:14px;
  border-radius:12px;background:rgba(0,0,0,.3);border:1px solid var(--line);
}
.inv-totals-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:14px}
.inv-totals-row.total{padding-top:10px;border-top:1px solid var(--line);margin-top:6px}
.inv-totals-row.total .v{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--blue-2);letter-spacing:1px}
.inv-totals-row .l{color:var(--muted);font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:700}

@media(max-width:520px){
  .li-row{grid-template-columns:1fr 100px 38px;gap:6px}
  .li-row input{padding:10px 10px;font-size:13.5px}
  .li-row .li-amt input{padding-left:22px}
}

/* ---------- CALENDAR (admin) ---------- */
.acal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.acal-cell{
  min-height:96px;padding:8px;border-radius:10px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;font-size:12px;
  cursor:pointer;transition:border-color .15s, background .15s;
}
.acal-cell:hover:not(.empty){border-color:var(--blue-ring)}
.acal-cell.empty{background:transparent;border-color:transparent;cursor:default}
.acal-cell.today{border-color:var(--blue-ring)}
.acal-cell.blocked{background:rgba(255,118,118,.08);border-color:rgba(255,118,118,.35)}
.acal-cell .num{font-weight:700;font-size:13px}
.acal-cell .bk{
  padding:3px 6px;border-radius:6px;
  background:rgba(43,123,255,.18);color:var(--blue-3);
  font-size:11px;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.acal-cell .blocked-tag{font-size:10.5px;letter-spacing:1px;color:var(--red);font-weight:700;text-transform:uppercase}
.acal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.acal-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;text-align:center;font-weight:700}

/* ---------- CHART ---------- */
.chart-wrap{position:relative;height:240px}

/* ---------- SKELETONS ---------- */
.skel{
  display:inline-block;
  background:linear-gradient(90deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.08) 50%, rgba(255,255,255,.03) 100%);
  background-size:200% 100%;
  border-radius:6px;
  animation:skelShimmer 1.4s ease-in-out infinite;
  height:14px;
}
.skel.lg{height:22px}
.skel.value{height:28px;width:90px}
.skel.full{display:block;width:100%}
.skel-row{display:flex;align-items:center;gap:10px;padding:14px 12px;border-bottom:1px solid var(--line)}
.skel-row:last-child{border-bottom:none}
.skel-row > .skel{flex:1}
.skel-row > .skel.tight{flex:0 0 80px}
@keyframes skelShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Toast for "new bookings" notifications */
.toast{
  position:fixed;left:50%;top:80px;transform:translateX(-50%) translateY(-20px);
  z-index:150;
  padding:11px 18px;border-radius:999px;
  background:linear-gradient(135deg,var(--blue),#1850b8);color:#fff;
  font-size:13px;font-weight:600;
  box-shadow:0 18px 40px -10px var(--blue-glow);
  opacity:0;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:860px){
  .toast{top:auto;bottom:90px;font-size:12.5px;padding:10px 16px;}
}

/* Empty state */
.empty{
  padding:32px 16px;text-align:center;color:var(--muted);font-size:13.5px;
}
.empty strong{display:block;color:var(--text);font-size:15px;margin-bottom:4px;font-weight:600}

/* Live error bar */
.live-err{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-bottom:18px;
  padding:12px 16px;border-radius:12px;
  background:rgba(255,118,118,.08);
  border:1px solid rgba(255,118,118,.35);
  color:var(--text);font-size:13.5px;
}
.live-err strong{color:var(--red)}

/* ---------- MOBILE BOTTOM NAV ---------- */
.mobile-topbar{display:none}
.mobile-bottom-nav{display:none}

/* ===== RESPONSIVE — MOBILE ADMIN ===== */
@media(max-width:860px){
  .layout{grid-template-columns:1fr}
  .sidebar{display:none}

  /* Top app bar */
  .mobile-topbar{
    display:flex;position:sticky;top:0;z-index:60;
    align-items:center;justify-content:space-between;gap:12px;
    padding:12px 16px calc(12px) 16px;
    padding-top:calc(12px + env(safe-area-inset-top));
    background:linear-gradient(180deg,rgba(5,7,13,.95),rgba(5,7,13,.85));
    backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
  }
  .mobile-topbar .brand{display:flex;align-items:center;gap:10px}
  .mobile-topbar .brand img{width:30px;height:30px;filter:drop-shadow(0 4px 10px var(--blue-glow))}
  .mobile-topbar .brand span{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px}
  .mobile-topbar .brand em{font-style:normal;color:var(--blue-2);margin-left:3px}
  .mobile-topbar .actions{display:flex;gap:8px;align-items:center}
  .mobile-topbar a.icon-btn,.mobile-topbar button.icon-btn{
    width:38px;height:38px;border-radius:10px;
    background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--text);
    display:inline-flex;align-items:center;justify-content:center;
  }
  .mobile-topbar a.icon-btn:hover{background:rgba(255,255,255,.1)}

  /* Bottom nav */
  .mobile-bottom-nav{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom)) 8px;
    background:linear-gradient(180deg,rgba(5,7,13,.55),rgba(5,7,13,.95));
    backdrop-filter:blur(16px);
    border-top:1px solid var(--line);
    gap:4px;
  }
  .mobile-bottom-nav a{
    flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
    padding:9px 4px;border-radius:12px;
    color:var(--muted);font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
    transition:color .15s, background .15s;
  }
  .mobile-bottom-nav a svg{width:20px;height:20px;flex-shrink:0;opacity:.8}
  .mobile-bottom-nav a.active{
    color:var(--blue-2);background:rgba(43,123,255,.12);
  }
  .mobile-bottom-nav a.active svg{opacity:1}
  .mobile-bottom-nav a:active{transform:scale(.95)}

  /* Content padding for bars */
  .content{padding:18px 16px 96px;max-width:100%}
  body{padding-bottom:0}

  /* Topbar inside content */
  .topbar{margin-bottom:18px}
  .topbar h1{font-size:30px}
  .topbar-right{width:100%}
  .topbar-right .btn,.topbar-right select{flex:1;min-width:120px}

  /* KPI tighter on mobile */
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi{padding:16px 16px;border-radius:14px}
  .kpi .value{font-size:28px}
  .kpi .label{font-size:10.5px;letter-spacing:1.5px}
  .kpi .sub{font-size:11.5px}

  /* Panels */
  .panel{padding:18px 16px;border-radius:14px}
  .panel h2{font-size:20px}
  .tbl-wrap{margin:0 -16px;padding:0 16px}

  /* Table: keep horizontal scroll but tighten cells */
  .tbl th{padding:8px 10px}
  .tbl td{padding:12px 10px}

  /* Calendar: smaller cells on phones */
  .acal{gap:3px}
  .acal-cell{min-height:62px;padding:5px;font-size:10.5px;border-radius:8px}
  .acal-cell .num{font-size:12px}
  .acal-cell .bk{font-size:9.5px;padding:2px 4px}
  .acal-dows{font-size:9.5px;gap:3px}

  /* Modal: full-screen on small phones */
  .modal-overlay{padding:0;align-items:flex-end}
  .modal{
    max-width:100%;width:100%;max-height:96vh;
    border-radius:18px 18px 0 0;
    padding:22px 18px calc(22px + env(safe-area-inset-bottom));
    animation:sheetUp .25s ease-out;
  }
  @keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .modal h2{font-size:22px}
  .modal-foot{flex-direction:column-reverse;gap:8px}
  .modal-foot .btn{width:100%;flex:1}
}

@media(max-width:420px){
  .kpi-grid{grid-template-columns:1fr 1fr;gap:8px}
  .kpi .value{font-size:24px}
  .acal-cell{min-height:54px}
}

/* ===== LOGIN PAGE ===== */
.login-body{
  min-height:100vh;
  position:relative;overflow:hidden;
}
.login-bg{position:fixed;inset:0;z-index:-1;pointer-events:none}
.login-bg-img{
  position:absolute;inset:0;
  background:url('/assets/truck-hero.png') center/cover no-repeat;
  opacity:.20;filter:blur(2px);
  transform:scale(1.06);
}
.login-bg-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(70% 90% at 50% 30%, rgba(43,123,255,.20), transparent 70%),
    linear-gradient(180deg, rgba(5,7,13,.4) 0%, rgba(5,7,13,.95) 60%, var(--bg) 100%);
}
.login-blob{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;
}
.login-blob.blob-1{
  width:420px;height:420px;left:-120px;top:20%;
  background:radial-gradient(circle, rgba(43,123,255,.5), transparent 70%);
  animation:blobFloat 14s ease-in-out infinite;
}
.login-blob.blob-2{
  width:380px;height:380px;right:-120px;bottom:10%;
  background:radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
  animation:blobFloat 18s ease-in-out infinite reverse;
}
@keyframes blobFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-40px)}}

.login-back{
  position:fixed;top:18px;left:18px;z-index:5;
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:600;letter-spacing:.4px;
  color:var(--muted-2);
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  backdrop-filter:blur(8px);
  transition:color .2s, background .2s, border-color .2s;
}
.login-back:hover{color:var(--text);background:rgba(255,255,255,.08);border-color:var(--blue-ring)}

.login-wrap{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:80px 20px 40px;
  padding-bottom:calc(40px + env(safe-area-inset-bottom));
}
.login-card{
  position:relative;
  max-width:430px;width:100%;
  padding:42px 36px 32px;
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg,rgba(12,17,32,.85),rgba(17,23,42,.85));
  border:1px solid var(--line-strong);
  backdrop-filter:blur(24px);
  box-shadow:0 40px 100px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.03) inset;
  animation:cardIn .5s ease-out both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.login-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--blue-3);font-weight:700;
  padding:6px 14px;border-radius:999px;
  background:rgba(43,123,255,.1);border:1px solid var(--blue-ring);
  margin-bottom:18px;
}
.login-pill .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--blue-2);box-shadow:0 0 12px var(--blue-2);
  animation:dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse{0%,100%{opacity:.5;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}

.login-logo{
  width:120px;margin:0 0 18px;
  filter:drop-shadow(0 16px 40px var(--blue-glow));
}
.login-card h1{
  font-family:'Bebas Neue',sans-serif;
  font-size:36px;letter-spacing:1.5px;
  margin:0 0 8px;text-transform:uppercase;line-height:1;
}
.chrome{
  background:var(--chrome);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 14px rgba(255,255,255,.15));
}
.login-card > p{
  color:var(--muted-2);font-size:14px;margin:0 0 24px;
}
.login-card .field{margin-bottom:18px}
.login-card .field label{font-size:11px}
.login-card .field input{padding:14px 14px;font-size:15px;width:100%}

.pw-wrap{position:relative;display:flex}
.pw-wrap input{flex:1;padding-right:46px}
.pw-toggle{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:8px;
  background:transparent;border:none;color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:color .15s, background .15s;
}
.pw-toggle:hover{color:var(--text);background:rgba(255,255,255,.05)}

.login-card .btn.primary.big{
  width:100%;padding:16px 20px;font-size:15px;
}

.login-err{color:var(--red);font-size:13px;text-align:center;margin-top:12px;min-height:18px;font-weight:500}

.login-foot{
  margin-top:24px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  font-size:12.5px;color:var(--muted);
}
.login-foot a{color:var(--blue-2);font-weight:600}
.login-foot a:hover{color:var(--blue-3)}

@media(max-width:480px){
  .login-card{padding:32px 24px 24px}
  .login-card h1{font-size:30px}
  .login-logo{width:96px}
}
