/* Mantis web UI kit overrides — pulls tokens from colors_and_type.css */
html,body{margin:0;background:#fafafa;font-family:var(--font-sans);color:#262626;-webkit-font-smoothing:antialiased}
*{box-sizing:border-box}

/* ===================== Shell ===================== */
.app{min-height:100vh;display:flex;background:#fafafa}
.app-main{flex:1;min-width:0;display:flex;flex-direction:column}
.app-content{flex:1;padding:24px;min-width:0}

/* ===================== Sidebar ===================== */
.sb{width:260px;flex-shrink:0;background:#fff;border-right:1px solid #f0f0f0;display:flex;flex-direction:column;height:100vh;position:sticky;top:0}
.sb-brand{display:flex;align-items:center;gap:8px;padding:18px 20px;height:60px;border-bottom:1px solid #f0f0f0}
.sb-brand img{width:28px;height:28px}
.sb-brand .name{font:700 22px/1 var(--font-sans);color:#262626;letter-spacing:-.4px}
.sb-nav{flex:1;overflow-y:auto;padding:14px 12px 20px}
.sb-section{font-size:11px;color:#8c8c8c;letter-spacing:.04em;text-transform:uppercase;padding:14px 12px 6px}
.sb-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:4px;font:500 14px/22px var(--font-sans);color:#595959;cursor:pointer;margin:2px 0;transition:.15s}
.sb-item:hover{background:#fafafa;color:#262626}
.sb-item.active{background:#e6f4ff;color:#1677ff}
.sb-item .ic{width:18px;height:18px;flex-shrink:0;color:currentColor}
.sb-item .arrow{margin-left:auto;font-size:10px;color:#bfbfbf}
.sb-sub{margin-left:28px}
.sb-sub .sb-item{padding:6px 12px;font-weight:400}
.sb-support{margin:14px 12px;padding:16px;background:#fafafa;border:1px solid #f0f0f0;border-radius:8px;text-align:center}
.sb-support .ill{width:64px;height:64px;border-radius:6px;background:linear-gradient(135deg,#bae0ff,#91caff);margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:30px}
.sb-support .t{font-weight:500;color:#262626;font-size:14px;margin-bottom:2px}
.sb-support .s{font-size:12px;color:#8c8c8c;margin-bottom:12px}
.sb-user{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid #f0f0f0}
.sb-user .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#69b1ff,#1677ff);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}
.sb-user .name{font:500 14px/1 var(--font-sans);color:#262626}
.sb-user .role{font-size:12px;color:#8c8c8c;margin-top:2px}

/* ===================== Header ===================== */
.hd{height:60px;background:#fff;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:5}
.hd-burger{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#595959;cursor:pointer;border-radius:4px}
.hd-burger:hover{background:#fafafa}
.hd-tag{display:flex;align-items:center;gap:8px;padding:4px 10px;background:#fafafa;border:1px solid #f0f0f0;border-radius:6px;font-size:13px}
.hd-tag .pill{background:#e6f4ff;color:#1677ff;font-size:11px;padding:1px 6px;border-radius:2px;font-weight:500}
.hd-search{flex:1;max-width:280px;display:flex;align-items:center;gap:8px;padding:6px 10px;background:#fafafa;border:1px solid #f0f0f0;border-radius:6px;color:#bfbfbf;font-size:13px;cursor:pointer}
.hd-search .kbd{margin-left:auto;font-family:var(--font-mono);font-size:11px;background:#fff;border:1px solid #d9d9d9;border-radius:3px;padding:0 5px;color:#595959}
.hd-spacer{flex:1}
.hd-icons{display:flex;align-items:center;gap:4px}
.hd-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#595959;cursor:pointer;position:relative;background:#fafafa;border:1px solid #f0f0f0}
.hd-icon:hover{color:#1677ff;border-color:#91caff}
.hd-icon .badge{position:absolute;top:0;right:0;min-width:14px;height:14px;border-radius:7px;background:#f5222d;color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #fff}

/* ===================== Breadcrumb + page title ===================== */
.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:#8c8c8c}
.crumbs a{color:#1677ff;text-decoration:none}
.crumbs .sep{color:#bfbfbf}
.crumbs .cur{color:#262626}
.page-title{font:600 24px/32px var(--font-sans);color:#262626;margin:6px 0 20px}

/* ===================== Welcome banner (Mantis: 5-stop diagonal) ===================== */
.welcome{background:linear-gradient(250.38deg,#e6f4ff 2.39%,#69b1ff 34.42%,#1677ff 60.95%,#0958d9 84.83%,#002c8c 104.37%);border-radius:8px;padding:27px;color:#fff;margin-bottom:0;position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;min-height:220px}
.welcome h2{font:600 30px/1.27 var(--font-sans);margin-bottom:0}
.welcome p{font:400 14px/1.57 var(--font-sans);max-width:480px;opacity:.92;margin:0}
.welcome .cta{display:inline-flex;align-items:center;justify-content:center;padding:6px 18px;border:1px solid #fff;border-radius:4px;color:#fff;font:400 14px/22px var(--font-sans);background:transparent;cursor:pointer;transition:.2s;text-transform:capitalize;align-self:flex-start}
.welcome .cta:hover{background:#1677ff;border-color:#fff}
.welcome .deco{position:relative;height:100%;display:flex;align-items:center;justify-content:flex-end}
.welcome .deco svg{width:240px;height:auto;opacity:.9}

/* ===================== Grids ===================== */
.section-label{font:400 14px/22px var(--font-sans);color:#262626;margin:6px 0 12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}
.grid-2-3{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:24px}

/* ===================== Card ===================== */
.card{background:#fff;border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}
.card-head{padding:16px 20px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}
.card-head .t{font:500 16px/24px var(--font-sans);color:#262626}
.card-head .more{color:#8c8c8c;cursor:pointer;letter-spacing:2px;font-size:14px}
.card-body{padding:20px}

/* stat card (Mantis AnalyticsDataCard) */
.stat-card{background:#fff;border:1px solid #f0f0f0;border-radius:8px;display:flex;flex-direction:column;gap:0;min-height:140px;justify-content:space-between;overflow:hidden}
.stat-card .body{padding:18px;display:flex;flex-direction:column;gap:4px}
.stat-card .l{font:400 14px/1.57 var(--font-sans);color:#8c8c8c}
.stat-card .row{display:flex;align-items:center;gap:10px}
.stat-card .v{font:600 20px/1.4 var(--font-sans);color:#262626}
.stat-card .trend{display:inline-flex;align-items:center;gap:4px;background:rgba(82,196,26,.15);color:#52c41a;border-radius:4px;padding:2px 8px;font:500 12px/20px var(--font-sans);height:20px}
.stat-card .trend.dn{background:rgba(245,34,45,.15);color:#f5222d}
.stat-card .trend.warn{background:rgba(250,173,20,.18);color:#faad14}
.stat-card .spark{height:48px;overflow:hidden;background:transparent}

/* ===================== Buttons ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:4px;font:400 14px/22px var(--font-sans);text-transform:capitalize;cursor:pointer;transition:all .2s var(--easing-base);border:1px solid transparent;background:transparent;color:inherit;position:relative}
.btn.sm{height:24px;padding:0 10px;font-size:12px}
.btn.md{height:32px;padding:0 14px}
.btn-primary{background:#1677ff;color:#fff;box-shadow:0 14px 12px rgba(22,119,255,0)}
.btn-primary:hover{background:#0958d9}
.btn-primary:active{background:#003eb3}
.btn-shadow{background:#1677ff;color:#fff;box-shadow:0 14px 12px rgba(22,119,255,0.2)}
.btn-shadow:hover{background:#0958d9;box-shadow:none}
.btn-default{background:#fff;color:#262626;border-color:#d9d9d9;box-shadow:0 2px #0000000b}
.btn-default:hover{color:#0958d9;border-color:#0958d9}
.btn-text{background:transparent;color:#595959}
.btn-text:hover{color:#1677ff;background:#fafafa}
.btn-link{background:transparent;color:#1677ff;padding:0 4px;height:auto}

/* ===================== Inputs ===================== */
.input{height:40px;border:1px solid #d9d9d9;border-radius:4px;background:#fff;padding:0 12px;font:400 14px/22px var(--font-sans);color:#262626;outline:none;transition:.2s;width:100%}
.input::placeholder{color:#bfbfbf}
.input:focus{border-color:#1677ff;box-shadow:0 0 0 2px rgba(22,119,255,.1)}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field .lbl{font:500 13px/20px var(--font-sans);color:#262626}
.field .lbl .req{color:#f5222d;margin-left:2px}

/* ===================== Tag ===================== */
.tag{display:inline-flex;align-items:center;gap:6px;padding:1px 8px;border-radius:2px;font:400 12px/20px var(--font-sans);border:1px solid;background:#fff}
.tag-success{color:#52c41a;border-color:#b7eb8f;background:#f6ffed}
.tag-pending{color:#faad14;border-color:#ffe58f;background:#fffbe6}
.tag-error  {color:#f5222d;border-color:#ffa39e;background:#fff1f0}
.tag-blue   {color:#1677ff;border-color:#91caff;background:#e6f4ff}
.tag-default{color:#595959;border-color:#d9d9d9;background:#fafafa}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block}

/* ===================== Table ===================== */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl thead th{font:500 13px/20px var(--font-sans);color:#262626;background:#fafafa;text-align:left;padding:12px 16px;border-bottom:1px solid #f0f0f0;white-space:nowrap}
.tbl tbody td{padding:14px 16px;border-bottom:1px solid #f0f0f0;color:#595959}
.tbl tbody tr:hover{background:#fafafa}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .o-id{color:#1677ff;font-weight:500}

/* ===================== Transaction list ===================== */
.tx-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f0f0f0}
.tx-row:last-child{border-bottom:0}
.tx-row .av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.tx-row .body{flex:1;min-width:0}
.tx-row .body .t{font:500 14px/22px var(--font-sans);color:#262626}
.tx-row .body .m{font:400 12px/20px var(--font-sans);color:#8c8c8c}
.tx-row .amount{font:500 14px/22px var(--font-sans);text-align:right}
.tx-row .amount.up{color:#52c41a}
.tx-row .amount.dn{color:#f5222d}
.tx-row .amount .pct{display:block;font-size:11px;color:#8c8c8c;font-weight:400}

/* ===================== Progress ===================== */
.prog{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}
.prog .bar{height:100%;background:#1677ff;border-radius:3px;transition:.3s}

/* ===================== Menu / dropdown ===================== */
.menu{background:#fff;border-radius:8px;box-shadow:0 1px 2px -2px rgba(0,0,0,.16),0 3px 6px 0 rgba(0,0,0,.12),0 5px 12px 4px rgba(0,0,0,.09);padding:6px;min-width:180px;border:1px solid #f0f0f0}
.menu-item{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:4px;cursor:pointer;font:400 14px/22px var(--font-sans);color:#262626}
.menu-item:hover{background:#f5f5f5}
.menu-item.danger{color:#f5222d}
.menu-divider{height:1px;background:#f0f0f0;margin:6px 0}

/* ===================== Auth screen ===================== */
.auth{min-height:100vh;background:#fafafa;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:32px}
.auth-deco{position:absolute;left:-200px;top:-100px;width:1100px;height:1400px;pointer-events:none}
.auth-card{position:relative;background:#fff;border:1px solid #f0f0f0;border-radius:4px;box-shadow:0 8px 25px rgba(0,0,0,0.05);padding:40px;width:475px;display:flex;flex-direction:column;gap:30px}
.auth-brand{position:absolute;left:30px;top:30px;display:flex;align-items:center;gap:6px}
.auth-brand img{width:34px;height:34px}
.auth-brand span{font:700 20px/1 var(--font-sans);color:#262626}
.auth-head{display:flex;justify-content:space-between;align-items:center}
.auth-head .t{font:700 20px/28px var(--font-sans)}
.oauth{display:flex;gap:12px}
.oauth button{flex:1;height:36px;border:1px solid #d9d9d9;border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}
.divider{display:flex;align-items:center;gap:12px;color:#8c8c8c;font-size:12px;margin:8px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:#f0f0f0}

/* ===================== Mail layout ===================== */
.mail{display:flex;gap:16px;min-height:calc(100vh - 60px - 48px)}
.mail-folders{width:200px;flex-shrink:0;background:#fff;border:1px solid #f0f0f0;border-radius:8px;padding:12px}
.mail-list{width:340px;flex-shrink:0;background:#fff;border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}
.mail-preview{flex:1;background:#fff;border:1px solid #f0f0f0;border-radius:8px;padding:24px}
.mail-item{padding:14px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;flex-direction:column;gap:4px}
.mail-item:hover{background:#fafafa}
.mail-item.active{background:#e6f4ff;border-left:3px solid #1677ff;padding-left:13px}
.mail-item .from{font:500 14px/22px var(--font-sans);color:#262626;display:flex;justify-content:space-between}
.mail-item .from .time{color:#8c8c8c;font-weight:400;font-size:12px}
.mail-item .subj{font:400 13px/20px var(--font-sans);color:#262626}
.mail-item .prev{font:400 12px/18px var(--font-sans);color:#8c8c8c;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

/* ===================== Misc ===================== */
.divider-h{height:1px;background:#f0f0f0;margin:14px 0}
.muted{color:#8c8c8c}
.small{font-size:12px;line-height:20px}
