:root{
  --indigo:#0A1F26; --indigo2:#1E5466;
  --cream:#FAF6F0; --cream2:#F4ECDE;
  --gold:#F59E0B; --gold-d:#d4880a;
  --green:#10B981; --green-d:#059669; --red:#EF4444; --orange:#F97316; --blue:#3B82F6;
  --surface:#fff; --soft:#F9FAFB;
  --line:#F0F1F3; --line2:#E5E7EB;
  --text:#1F2937; --muted:#6B7280; --muted2:#9CA3AF;
  --green-bg:#DCF8E8; --red-bg:#FECACA; --amber-bg:#FEF0D9; --amber-tx:#D97706; --gray-bg:#F1F3F5;
  --shadow:0 1px 2px rgba(0,0,0,.04),0 4px 14px rgba(49,46,129,.06);
  --r-card:18px; --r-btn:14px; --r-sheet:28px;
  --tb:56px; --top:52px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
[hidden]{display:none!important;}
html,body{margin:0;height:100%;}
body{
  background:var(--cream); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text",Inter,system-ui,sans-serif;
  font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;
}
b{font-weight:800;}
code{font-family:ui-monospace,Menlo,monospace;font-size:12px;word-break:break-all;color:var(--indigo);}
button{font-family:inherit;}

/* ---------- LOGIN ---------- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:max(28px,env(safe-area-inset-top)) 22px max(28px,env(safe-area-inset-bottom));}
.login-card{width:100%;max-width:360px;text-align:center;background:var(--surface);
  border-radius:26px;box-shadow:var(--shadow);padding:34px 26px 28px;border:1px solid var(--line);}
.brand{width:80px;height:80px;border-radius:22px;margin:0 auto 18px;
  background:linear-gradient(150deg,var(--gold),var(--gold-d));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:25px;color:#3a2600;letter-spacing:-1px;
  box-shadow:0 12px 30px rgba(245,158,11,.34);}
.login h1{margin:0 0 4px;font-size:23px;letter-spacing:.4px;color:var(--indigo);}
.login h1 b{color:var(--gold-d);}
.login-tag{color:var(--muted);margin:0 0 24px;font-size:13.5px;}
#login-form{display:flex;flex-direction:column;gap:11px;text-align:left;}
.login-err{color:var(--red);font-size:13px;margin:2px 2px 0;text-align:center;}

/* ---------- FIELDS / BUTTONS ---------- */
.field{width:100%;background:var(--soft);border:1px solid var(--line);border-radius:var(--r-btn);
  color:var(--text);padding:13px 15px;font-size:16px;outline:none;transition:border-color .18s,background .15s;}
.field:focus{border-color:var(--indigo);background:var(--surface);}
.field::placeholder{color:var(--muted2);}
.btn{border:none;border-radius:var(--r-btn);padding:13px 16px;font-size:15px;font-weight:700;
  cursor:pointer;transition:opacity .12s,filter .15s;display:inline-flex;align-items:center;justify-content:center;gap:7px;}
.btn:active{opacity:.88;}
.btn:disabled{opacity:.5;}
.btn-primary{background:var(--green);color:#fff;}
.btn-ghost{background:var(--surface);color:var(--indigo);border:1px solid var(--line2);}
.btn.danger{color:var(--red);border:1px solid var(--red-bg);background:#fff;}
.btn.btn-primary.danger{background:var(--red);color:#fff;border:none;}
.btn.block{width:100%;}

/* ---------- APP CHROME ---------- */
.app{min-height:100vh;}
#topbar{position:fixed;top:0;left:0;right:0;height:calc(var(--top) + env(safe-area-inset-top));
  padding:env(safe-area-inset-top) 12px 0;display:flex;align-items:center;gap:8px;
  background:var(--indigo);z-index:30;}
.tb-title{flex:1;text-align:center;font-size:17px;letter-spacing:.3px;font-weight:800;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tb-btn{width:36px;height:36px;flex-shrink:0;border-radius:50%;border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;}
.tb-btn:active{background:rgba(255,255,255,.16);}
.tb-btn svg{width:19px;height:19px;}

#pager-wrap{position:fixed;left:0;right:0;
  top:calc(var(--top) + env(safe-area-inset-top));
  bottom:calc(var(--tb) + env(safe-area-inset-bottom));
  overflow:hidden;background:var(--cream);}
#pager{position:absolute;inset:0;display:flex;will-change:transform;}
.pane{flex:0 0 100%;width:100%;height:100%;overflow:hidden;}
.pane-scroll{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:14px;}

#tabbar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tb) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);display:flex;background:var(--surface);
  box-shadow:0 -8px 24px rgba(49,46,129,.07);z-index:30;overflow:hidden;}
.tab{flex:1;background:none;border:none;color:var(--muted2);position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:3px;font-size:10.5px;font-weight:600;padding:5px 0;}
.tab .ti{display:flex;align-items:center;justify-content:center;line-height:1;}
.tab .ti svg{width:22px;height:22px;}
.tab.on{color:var(--indigo);}
.tab.on .ti svg{stroke-width:2.3;}
#nav-indicator{position:absolute;top:0;left:0;width:30px;height:3px;border-radius:0 0 4px 4px;
  background:var(--indigo);transform:translate3d(0,0,0);pointer-events:none;}

.screen-pad{padding:16px;}

/* ---------- DASHBOARD ---------- */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:14px;box-shadow:var(--shadow);}
.stat-accent{background:linear-gradient(150deg,#ECFDF5,#F0FDF4);border-color:var(--green-bg);}
.stat-accent .stat-val{color:var(--green-d);}
.stat-val{font-size:20px;font-weight:800;letter-spacing:-.3px;color:var(--text);}
.stat-label{color:var(--muted);font-size:12.5px;margin-top:3px;}
.stat-sub{color:var(--muted2);font-size:11.5px;margin-top:2px;}
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:11px;}
.mini{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:11px 6px;text-align:center;box-shadow:var(--shadow);}
.mini b{display:block;font-size:18px;color:var(--text);}
.mini b.live{color:var(--green);}
.mini span{color:var(--muted2);font-size:10.5px;}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);margin-top:14px;overflow:hidden;box-shadow:var(--shadow);}
.panel-head{padding:13px 15px;font-weight:700;font-size:14px;border-bottom:1px solid var(--line);color:var(--text);}
.bars{display:flex;align-items:flex-end;gap:4px;height:96px;padding:14px 15px;}
.bar-col{flex:1;display:flex;align-items:flex-end;height:100%;}
.bar{width:100%;background:linear-gradient(180deg,var(--green),var(--green-d));border-radius:4px 4px 0 0;min-height:3px;}

/* ---------- LIST / ROWS ---------- */
.list{display:flex;flex-direction:column;}
.row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-bottom:1px solid var(--line);}
.row:last-child{border-bottom:none;}
.row-main{flex:1;min-width:0;}
.row-title{font-weight:600;font-size:14.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.row-sub{color:var(--muted);font-size:12.5px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.row-right{font-weight:800;color:var(--text);white-space:nowrap;}
.row-right.small{font-size:11.5px;color:var(--muted2);font-weight:500;}

/* ---------- CARDS ---------- */
.list.cards{gap:11px;padding:0;}
.card{display:block;width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-card);padding:14px;color:var(--text);box-shadow:var(--shadow);}
.card:active{background:var(--soft);}
.card.static:active{background:var(--surface);}
.card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.card-title{font-weight:700;font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-sub{color:var(--muted);font-size:13px;margin-top:5px;}
.card-sub.mono{font-family:ui-monospace,Menlo,monospace;font-size:11.5px;color:var(--indigo2);letter-spacing:.3px;}
.card-sub.clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:9px;color:var(--muted2);font-size:12px;}
.card-foot b{color:var(--text);font-size:14px;}
.dev-mini{display:flex;align-items:center;gap:5px;}

/* ---------- BADGES ---------- */
.badge{font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;white-space:nowrap;}
.badge-green{background:var(--green-bg);color:var(--green-d);}
.badge-red{background:var(--red-bg);color:var(--red);}
.badge-amber{background:var(--amber-bg);color:var(--amber-tx);}
.badge-gray{background:var(--gray-bg);color:var(--muted);}

i.live{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 3px var(--green-bg);margin-right:5px;vertical-align:middle;}

/* ---------- FILTER / SEARCH ---------- */
.filterbar{position:sticky;top:0;z-index:10;
  display:flex;gap:8px;padding:12px 16px;overflow-x:auto;background:var(--cream);
  border-bottom:1px solid var(--line);-ms-overflow-style:none;scrollbar-width:none;}
.filterbar::-webkit-scrollbar{display:none;}
.chip{background:var(--surface);border:1px solid var(--line2);color:var(--muted);
  border-radius:999px;padding:8px 15px;font-size:13px;font-weight:600;white-space:nowrap;}
.chip.on{background:var(--indigo);border-color:var(--indigo);color:#fff;}
.searchbar{position:sticky;top:0;z-index:10;
  padding:12px 16px;background:var(--cream);border-bottom:1px solid var(--line);}
.searchbar .field{padding:11px 14px;font-size:15px;}

/* ---------- STATES ---------- */
.state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:54px 24px;text-align:center;color:var(--muted);}
.state-ico{width:46px;height:46px;border-radius:50%;background:var(--gray-bg);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--muted2);}
.state small{color:var(--muted2);font-size:12.5px;}
.spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(49,46,129,.12);border-top-color:var(--indigo);
  animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------- KV ---------- */
.kv{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-btn);overflow:hidden;background:var(--surface);}
.kv-row{display:flex;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);}
.kv-row:last-child{border-bottom:none;}
.kv-k{color:var(--muted);font-size:13px;width:96px;flex-shrink:0;}
.kv-v{flex:1;font-size:13.5px;text-align:right;word-break:break-word;color:var(--text);}

/* ---------- SHEET ---------- */
.sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:50;display:flex;align-items:flex-end;
  opacity:0;transition:opacity .2s;}
.sheet-backdrop.show{opacity:1;}
.sheet{width:100%;max-height:90vh;background:var(--surface);border-radius:var(--r-sheet) var(--r-sheet) 0 0;
  padding:8px 18px calc(20px + env(safe-area-inset-bottom));transform:translateY(100%);
  transition:transform .24s cubic-bezier(.3,.8,.4,1);overflow-y:auto;}
.sheet-backdrop.show .sheet{transform:translateY(0);}
.sheet-grab{width:40px;height:4px;border-radius:99px;background:rgba(0,0,0,.12);margin:6px auto 12px;}
.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.sheet-head h3{margin:0;font-size:17px;color:var(--text);}
.sheet-x{background:var(--gray-bg);border:none;color:var(--muted);width:32px;height:32px;border-radius:50%;font-size:14px;}
.sheet-body .field{margin-bottom:10px;}
.field-hint{color:var(--muted2);font-size:12px;margin:-4px 2px 10px;}
.confirm-msg{font-size:14.5px;line-height:1.5;color:var(--text);margin:0 2px 18px;}
.sheet-actions{display:flex;gap:10px;margin-top:16px;}
.sheet-actions .btn{flex:1;}
.sheet-actions.col{flex-direction:column;}
.sheet-actions.grid2{display:grid;grid-template-columns:1fr 1fr;}
.sheet-actions.grid2 .btn{width:100%;}

/* ---------- TOAST ---------- */
#toast-root{position:fixed;left:0;right:0;bottom:calc(var(--tb) + env(safe-area-inset-bottom) + 14px);
  z-index:80;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 20px;}
.toast{background:var(--indigo);color:#fff;padding:11px 18px;border-radius:999px;
  font-size:13.5px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.22);opacity:0;transform:translateY(10px);
  transition:opacity .22s,transform .22s;max-width:90%;text-align:center;}
.toast.show{opacity:1;transform:translateY(0);}
.toast-success{background:var(--green);}
.toast-error{background:var(--red);}

/* ---------- CHAT ---------- */
.list.convs{padding:4px 0;}
.conv{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:none;
  color:var(--text);padding:11px 16px;border-bottom:1px solid var(--line);}
.conv:active{background:var(--soft);}
.conv-av{width:44px;height:44px;border-radius:50%;background:#EAF0F2;color:var(--indigo);
  display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;font-size:16px;}
.conv-main{flex:1;min-width:0;}
.conv-top{display:flex;justify-content:space-between;gap:8px;}
.conv-name{font-weight:700;font-size:14.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.conv-time{color:var(--muted2);font-size:11.5px;flex-shrink:0;}
.conv-last{color:var(--muted);font-size:13px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.unread{background:var(--green);color:#fff;font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0;}

.chat{position:fixed;inset:0;z-index:40;
  display:flex;flex-direction:column;background:var(--cream);}
.chat-head{display:flex;align-items:center;gap:8px;padding:calc(9px + env(safe-area-inset-top)) 14px 9px;border-bottom:1px solid var(--line);background:var(--surface);}
.chat-back{background:none;border:none;color:var(--indigo);font-size:30px;line-height:1;width:34px;}
.chat-name{font-weight:700;font-size:15px;color:var(--text);}
.chat-sub{color:var(--muted2);font-size:11.5px;}
.chat-scroll{flex:1;overflow-y:auto;padding:14px 14px 6px;display:flex;flex-direction:column;gap:8px;}
.bubble-row{display:flex;}
.bubble-row.me{justify-content:flex-end;}
.bubble{max-width:78%;padding:9px 13px 18px;border-radius:18px;font-size:14px;line-height:1.4;position:relative;word-break:break-word;box-shadow:var(--shadow);}
.bubble-row.them .bubble{background:var(--surface);color:var(--text);border:1px solid var(--line);border-bottom-left-radius:6px;}
.bubble-row.me .bubble{background:var(--indigo);color:#fff;border-bottom-right-radius:6px;}
.bubble-time{position:absolute;right:11px;bottom:5px;font-size:9.5px;opacity:.55;}
.chat-compose{display:flex;gap:9px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line);background:var(--surface);}
.chat-compose .field{flex:1;padding:11px 14px;}
.chat-compose .btn{padding:11px 18px;}

/* ---------- DRAWER ---------- */
#drawer{position:fixed;inset:0;z-index:60;pointer-events:none;}
.dw-scrim{position:absolute;inset:0;background:rgba(10,31,38,.42);opacity:0;}
.drawer-panel{position:absolute;top:0;bottom:0;left:0;width:84%;max-width:340px;
  background:var(--surface);display:flex;flex-direction:column;
  transform:translateX(calc(-100% - 40px));border-radius:0 24px 24px 0;
  box-shadow:6px 0 24px rgba(0,0,0,.22);overflow:hidden;
  padding-bottom:env(safe-area-inset-bottom);}
.drawer-head{display:flex;align-items:center;gap:13px;
  padding:calc(22px + env(safe-area-inset-top)) 20px 18px;background:var(--indigo);color:#fff;}
.dw-avatar{width:50px;height:50px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(150deg,var(--gold),var(--gold-d));
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:20px;color:#3a2600;}
.dw-id{min-width:0;}
.dw-name{font-weight:800;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dw-email{font-size:12.5px;opacity:.72;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.drawer-body{flex:1;overflow-y:auto;padding:8px 0;}
.dw-item{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:none;border:none;
  padding:14px 20px;font-size:15px;color:var(--text);font-weight:600;}
.dw-item:active{background:var(--soft);}
.dw-ico{font-size:17px;width:22px;text-align:center;color:var(--muted);flex-shrink:0;}
.dw-item.danger{color:var(--red);}
.dw-item.danger .dw-ico{color:var(--red);}
.dw-sub{margin-left:auto;font-size:12.5px;color:var(--muted2);font-weight:600;}
.dw-foot{padding:14px 20px;color:var(--muted2);font-size:11.5px;border-top:1px solid var(--line);}

/* ---------- FACE GATE ---------- */
#facegate .login-tag{margin-bottom:22px;}
#facegate .btn.block + .btn.block{margin-top:10px;}
#facegate .login-err{margin-top:14px;}
