/* TekFinoTax — Dashboard Theme (Paytm Royal Blue + Mobile Responsive) */
:root{
  --red:#012B72;       --red-d:#001A4D;     --red-l:#E6F0FF;
  --yellow:#F5C800;    --gold:#E8A800;
  --danger:#D93025;    --danger-l:#FCE8E6;

  --ink:#1A1A1A; --mid:#3D3D3D; --gray:#717478; --muted:#9CA0A4;
  --line:#E8EEF4; --hair:#D7DDE5; --bg:#F4F8FB; --surface:#FFFFFF;
  --green:#06A85B; --green-l:#E1F7E8;
  --orange:#FF6F00; --orange-l:#FFF1E0;
  --blue:#0073E6; --blue-l:#E6F0FF;
  --purple:#7B3FB8; --purple-l:#F0E6FF;
  --pink:#E91E63; --pink-l:#FFEAF0;

  --side-w:248px;
  --side-w-collapsed:68px;
  --topbar-h:60px;
  --safe-t:env(safe-area-inset-top,0);
  --safe-b:env(safe-area-inset-bottom,0);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{font-family:'Inter','Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
html{-webkit-text-size-adjust:100%}
body{overflow-x:hidden;min-height:100vh}
button,input,textarea,select{font-family:inherit;font-size:inherit;outline:none}
button{cursor:pointer;background:none;border:none;color:inherit}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ════════════════ LAYOUT ════════════════ */
.layout{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh;transition:grid-template-columns .25s cubic-bezier(.16,1,.3,1)}
.layout.collapsed{grid-template-columns:var(--side-w-collapsed) 1fr}

/* Backdrop (mobile only when sidebar open) */
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(2px)}
.sidebar-backdrop.on{opacity:1;pointer-events:auto}

/* ════════════════ SIDEBAR ════════════════ */
.sidebar{
  background:linear-gradient(180deg,#012B72 0%,#001A4D 100%);
  color:#fff;
  padding:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  position:sticky;
  top:0;
  height:100vh;
  z-index:100;
  transition:transform .28s cubic-bezier(.16,1,.3,1), width .25s;
}
.sidebar-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 10px 18px;display:flex;flex-direction:column;gap:3px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}
.sidebar-scroll::-webkit-scrollbar{width:4px}
.sidebar-scroll::-webkit-scrollbar-track{background:transparent}
.sidebar-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:50px}

/* Brand */
.brand{display:flex;align-items:center;gap:10px;padding:14px 14px 14px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;min-height:60px;position:relative}
.brand-logo{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-text{min-width:0;flex:1;overflow:hidden;transition:opacity .15s}
.brand-name{font-weight:800;font-size:14px;line-height:1;white-space:nowrap}
.brand-sub{font-size:9px;color:rgba(255,255,255,.6);font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-top:2px;white-space:nowrap}

/* Collapse toggle (desktop only) */
.collapse-btn{
  width:28px;height:28px;border-radius:7px;background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.7);display:none;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;transition:all .15s
}
.collapse-btn:hover{background:rgba(255,255,255,.15);color:#fff}
@media(min-width:841px){.collapse-btn{display:flex}}

/* Nav groups */
.nav-grp{font-size:10px;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1px;padding:14px 14px 6px;white-space:nowrap;transition:opacity .15s}

/* Nav item */
.nav{
  display:flex;align-items:center;gap:13px;
  padding:10px 14px;border-radius:9px;
  color:rgba(255,255,255,.85);font-size:13.5px;font-weight:500;
  transition:all .15s;white-space:nowrap;
  position:relative;
}
.nav:hover{background:rgba(255,255,255,.08);color:#fff}
.nav.on{background:var(--yellow);color:var(--ink);font-weight:700}
.nav .ic{font-size:18px;flex-shrink:0;width:22px;text-align:center;line-height:1}
.nav-label{flex:1;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s}
.nav .badge{
  background:var(--yellow);color:var(--ink);
  font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:50px;
  min-width:20px;text-align:center;flex-shrink:0;
}
.nav.on .badge{background:var(--ink);color:var(--yellow)}

/* Footer of sidebar */
.side-foot{
  border-top:1px solid rgba(255,255,255,.08);
  padding:12px 10px;
  flex-shrink:0;
  background:rgba(0,0,0,.15);
}
.side-user{
  display:flex;align-items:center;gap:11px;
  padding:8px 10px;border-radius:9px;
  font-size:12.5px;color:rgba(255,255,255,.9);
  transition:background .15s;
}
.side-user:hover{background:rgba(255,255,255,.08)}
.side-user-av{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,#0746A8,#012B72);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:#fff;flex-shrink:0;
  border:2px solid rgba(255,255,255,.1);
}
.side-user-info{flex:1;min-width:0;overflow:hidden;transition:opacity .15s}
.side-user-name{font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-user-role{font-size:10.5px;color:rgba(255,255,255,.6);margin-top:2px;white-space:nowrap}
.signout{
  display:flex;align-items:center;gap:13px;
  padding:8px 14px;margin-top:4px;border-radius:9px;
  color:rgba(255,255,255,.5);font-size:12.5px;
  transition:all .15s;
}
.signout:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8)}

/* ════════════════ COLLAPSED STATE (desktop only) ════════════════ */
@media(min-width:841px){
  .layout.collapsed .brand-text,
  .layout.collapsed .nav-label,
  .layout.collapsed .nav-grp,
  .layout.collapsed .nav .badge,
  .layout.collapsed .side-user-info,
  .layout.collapsed .signout span:not(.ic){
    opacity:0;visibility:hidden;width:0;
  }
  .layout.collapsed .nav,
  .layout.collapsed .side-user{justify-content:center;padding:10px}
  .layout.collapsed .brand{justify-content:center;padding:14px 0}
  .layout.collapsed .nav-grp{padding:8px 0;height:1px;visibility:hidden}
  .layout.collapsed .nav{position:relative}
  /* Tooltip-style label on hover when collapsed */
  .layout.collapsed .nav:hover::after{
    content:attr(data-tooltip);
    position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);
    background:#1A1A1A;color:#fff;padding:6px 12px;border-radius:6px;
    font-size:12px;font-weight:500;white-space:nowrap;z-index:200;
    box-shadow:0 4px 14px rgba(0,0,0,.2);pointer-events:none;
  }
}

/* ════════════════ MOBILE: SIDEBAR DRAWER ════════════════ */
@media(max-width:840px){
  .layout{grid-template-columns:1fr !important}
  .sidebar{
    position:fixed;
    top:0;left:0;bottom:0;
    width:280px;max-width:85vw;
    height:100vh;
    transform:translateX(-100%);
    box-shadow:6px 0 30px rgba(0,0,0,.25);
  }
  .sidebar.on{transform:translateX(0)}
  .collapse-btn{display:none !important}
}

/* ════════════════ MAIN AREA ════════════════ */
.main{display:flex;flex-direction:column;min-width:0;min-height:100vh}

/* Topbar */
.topbar{
  background:#fff;
  padding:0 22px;
  height:var(--topbar-h);
  display:flex;align-items:center;gap:14px;
  border-bottom:0.5px solid var(--line);
  position:sticky;top:0;z-index:50;
}
@media(max-width:840px){.topbar{padding:0 14px;padding-top:var(--safe-t)}}

.menu-btn{
  display:none;
  width:38px;height:38px;border-radius:9px;
  background:var(--bg);
  align-items:center;justify-content:center;
  font-size:18px;color:var(--mid);
  transition:background .15s;
}
.menu-btn:hover,.menu-btn:active{background:var(--line)}
@media(max-width:840px){.menu-btn{display:flex}}

.page-title{
  font-size:17px;font-weight:700;letter-spacing:-.3px;flex:1;
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
@media(max-width:480px){.page-title{font-size:15px}}

.tb-search{
  flex:1;max-width:340px;background:var(--bg);
  border:1px solid var(--line);border-radius:10px;
  padding:8px 14px;display:flex;align-items:center;gap:8px;
}
.tb-search input{background:none;border:none;flex:1;font-size:13px;color:var(--ink)}
@media(max-width:840px){.tb-search{display:none}}

.tb-ic{
  width:38px;height:38px;border-radius:50%;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;color:var(--mid);
  position:relative;cursor:pointer;
  transition:all .15s;flex-shrink:0;
}
.tb-ic:hover,.tb-ic:active{background:var(--line)}
.tb-ic-dot{position:absolute;top:7px;right:7px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid #fff}

/* ════════════════ CONTENT ════════════════ */
.content{padding:22px;flex:1;min-width:0;width:100%}
@media(max-width:840px){.content{padding:16px}}
@media(max-width:480px){.content{padding:12px}}

/* ════════════════ STAT CARDS ════════════════ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
@media(max-width:480px){.stats{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}}
.stat{background:#fff;border:0.5px solid var(--line);border-radius:14px;padding:16px 18px}
@media(max-width:480px){.stat{padding:12px 14px;border-radius:11px}}
.stat-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.stat-l{font-size:11.5px;color:var(--gray);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
@media(max-width:480px){.stat-l{font-size:10px}}
.stat-ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
@media(max-width:480px){.stat-ic{width:28px;height:28px;font-size:14px}}
.stat-v{font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1}
@media(max-width:480px){.stat-v{font-size:19px}}
.stat-d{font-size:11px;color:var(--gray);margin-top:5px}
.stat-d.up{color:var(--green)}.stat-d.down{color:var(--danger)}

/* ════════════════ CARD ════════════════ */
.card{background:#fff;border:0.5px solid var(--line);border-radius:14px;margin-bottom:18px;overflow:hidden}
@media(max-width:480px){.card{margin-bottom:12px;border-radius:11px}}
.card-h{padding:14px 18px;border-bottom:0.5px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
@media(max-width:480px){.card-h{padding:12px 14px}}
.card-t{font-size:14.5px;font-weight:700;letter-spacing:-.2px}
.card-sub{font-size:11.5px;color:var(--gray);margin-top:2px}
.card-b{padding:18px}
@media(max-width:480px){.card-b{padding:14px}}

/* ════════════════ TABLE (horizontal scroll on mobile) ════════════════ */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}
.tbl th{text-align:left;padding:11px 16px;font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;background:#FAFBFD;border-bottom:0.5px solid var(--line);white-space:nowrap}
.tbl td{padding:13px 16px;border-bottom:0.5px solid var(--line);vertical-align:middle}
.tbl tr:hover td{background:#FAFBFD}
.tbl tr:last-child td{border:none}
@media(max-width:480px){.tbl th,.tbl td{padding:10px 12px;font-size:12px}}

/* ════════════════ PILLS ════════════════ */
.pill{display:inline-block;font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:50px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.pill-new{background:var(--blue-l);color:var(--blue)}
.pill-pending{background:var(--orange-l);color:var(--orange)}
.pill-progress{background:var(--purple-l);color:var(--purple)}
.pill-action{background:#FEF6CC;color:#B58800}
.pill-done{background:var(--green-l);color:var(--green)}
.pill-cancel{background:#F0F4F8;color:var(--gray)}
.pill-urgent{background:var(--danger-l);color:var(--danger)}

/* ════════════════ BUTTONS ════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-pri{background:var(--red);color:#fff}
.btn-pri:hover{background:var(--red-d)}
.btn-out{background:#fff;color:var(--red);border:1.5px solid var(--red)}
.btn-out:hover{background:var(--red-l)}
.btn-sec{background:var(--bg);color:var(--ink);border:0.5px solid var(--line)}
.btn-sec:hover{background:var(--line)}
.btn-y{background:var(--yellow);color:var(--ink)}
.btn-sm{padding:6px 12px;font-size:11.5px;border-radius:7px}
.btn-icon{padding:8px;width:34px;height:34px;border-radius:8px}
@media(max-width:480px){.btn{padding:8px 14px;font-size:12.5px}.btn-sm{padding:5px 10px;font-size:11px}}

/* ════════════════ FORMS ════════════════ */
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}
.input,.select,.textarea{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:10px 13px;font-size:13.5px;color:var(--ink);transition:border-color .15s}
.input:focus,.select:focus,.textarea:focus{border-color:var(--red)}
.textarea{resize:vertical;min-height:80px}
.hint{font-size:11px;color:var(--gray);margin-top:4px}

/* ════════════════ ALERTS ════════════════ */
.alert{padding:11px 14px;border-radius:10px;margin-bottom:14px;font-size:13px;display:flex;align-items:flex-start;gap:8px}
.alert-ok{background:var(--green-l);color:#0a5e2f;border-left:4px solid var(--green)}
.alert-err{background:var(--danger-l);color:#7d2226;border-left:4px solid var(--danger)}
.alert-info{background:var(--blue-l);color:#003a73;border-left:4px solid var(--blue)}
.alert-warn{background:#FEF6CC;color:#7a5800;border-left:4px solid #B58800}

/* ════════════════ EMPTY STATE ════════════════ */
.empty{text-align:center;padding:48px 24px;color:var(--gray)}
.empty-ic{font-size:54px;margin-bottom:14px;opacity:.6}
.empty-t{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px}
.empty-s{font-size:12.5px;line-height:1.6;max-width:300px;margin:0 auto 18px}

/* ════════════════ DOC TILES ════════════════ */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
@media(max-width:480px){.doc-grid{grid-template-columns:repeat(2,1fr);gap:9px}}
.doc-tile{background:#fff;border:0.5px solid var(--line);border-radius:11px;padding:12px;text-align:center;position:relative}
.doc-ic{width:50px;height:50px;border-radius:11px;background:var(--red-l);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 8px}
.doc-n{font-size:11.5px;font-weight:700;line-height:1.3;margin-bottom:3px}
.doc-s{font-size:10px;color:var(--gray);line-height:1.4}
.doc-pill{position:absolute;top:8px;right:8px;font-size:8.5px;font-weight:800;padding:2px 6px;border-radius:5px;letter-spacing:.3px}

/* ════════════════ DROPZONE ════════════════ */
.dropzone{border:2px dashed var(--line);border-radius:11px;padding:24px;text-align:center;cursor:pointer;transition:all .15s;background:#fff}
.dropzone:hover,.dropzone.drag{border-color:var(--red);background:var(--red-l)}
.dropzone-ic{font-size:38px;margin-bottom:8px;color:var(--red)}
.dropzone-t{font-size:13.5px;font-weight:700;margin-bottom:3px}
.dropzone-s{font-size:11px;color:var(--gray)}
.dropzone input[type=file]{display:none}

/* ════════════════ CHAT ════════════════ */
.chat-wrap{display:grid;grid-template-columns:280px 1fr;gap:0;height:calc(100vh - var(--topbar-h) - 44px);background:#fff;border:0.5px solid var(--line);border-radius:14px;overflow:hidden}
@media(max-width:740px){.chat-wrap{grid-template-columns:1fr;height:calc(100vh - var(--topbar-h) - 32px)}.chat-sidebar.thread-open{display:none}.chat-area{display:none}.chat-area.thread-open{display:flex}}
.chat-sidebar{border-right:0.5px solid var(--line);background:#FAFBFD;display:flex;flex-direction:column;overflow:hidden}
.chat-sidebar-h{padding:14px 16px;border-bottom:0.5px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.chat-sidebar-list{flex:1;overflow-y:auto}
.chat-thread{padding:11px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;border-bottom:0.5px solid var(--line);transition:background .12s}
.chat-thread:hover{background:#fff}
.chat-thread.on{background:#fff;border-left:3px solid var(--red)}
.chat-thread-av{width:36px;height:36px;border-radius:50%;background:var(--red-l);color:var(--red);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.chat-thread-info{flex:1;min-width:0}
.chat-thread-n{font-size:12.5px;font-weight:600;color:var(--ink);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-s{font-size:10.5px;color:var(--gray);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-badge{background:var(--red);color:#fff;font-size:9px;font-weight:800;padding:1.5px 6px;border-radius:50px;flex-shrink:0}
.chat-area{display:flex;flex-direction:column;overflow:hidden;background:#fff}
.chat-head{padding:14px 18px;border-bottom:0.5px solid var(--line);display:flex;align-items:center;gap:10px}
.chat-back{display:none;font-size:18px;color:var(--mid);cursor:pointer}
@media(max-width:740px){.chat-back{display:block}}
.chat-msgs{flex:1;overflow-y:auto;padding:18px;background:#FAFBFD;display:flex;flex-direction:column;gap:10px}
.msg{max-width:75%;display:flex;flex-direction:column;gap:3px}
.msg.me{align-self:flex-end;align-items:flex-end}
.msg-bub{padding:9px 14px;border-radius:14px;font-size:13px;line-height:1.45;background:#fff;border:0.5px solid var(--line);word-wrap:break-word}
.msg.me .msg-bub{background:var(--red);color:#fff;border-color:var(--red)}
.msg-meta{font-size:9.5px;color:var(--muted);padding:0 4px}
.msg.system{align-self:center;max-width:90%}
.msg.system .msg-bub{background:#F0F4F8;color:var(--gray);font-size:11.5px;text-align:center;border-radius:50px;padding:5px 14px}
.chat-input{padding:12px 16px;border-top:0.5px solid var(--line);display:flex;gap:9px;align-items:center;background:#fff}
.chat-input input{flex:1;background:var(--bg);border:0.5px solid var(--line);border-radius:50px;padding:10px 16px;font-size:13.5px}
.chat-input input:focus{border-color:var(--red);background:#fff}
.chat-send{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.chat-empty{text-align:center;padding:60px 24px;color:var(--gray)}

/* ════════════════ LOGIN ════════════════ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#012B72 0%,#001A4D 100%)}
.login-card{background:#fff;border-radius:18px;padding:32px;max-width:380px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
@media(max-width:480px){.login-card{padding:24px 20px;border-radius:14px}}
.login-logo{display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.login-h{font-size:22px;font-weight:800;text-align:center;letter-spacing:-.4px}
.login-s{font-size:13px;color:var(--gray);text-align:center;margin-top:4px;margin-bottom:24px}
.login-foot{text-align:center;font-size:11.5px;color:var(--gray);margin-top:18px}
.login-foot a{color:var(--red);font-weight:600}

/* ════════════════ TABS ════════════════ */
.tabs{display:flex;gap:4px;padding:0 18px;border-bottom:0.5px solid var(--line);background:#fff;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:13px 14px;font-size:13px;font-weight:600;color:var(--gray);border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:8px;transition:color .15s;text-decoration:none;flex-shrink:0}
.tab:hover{color:var(--mid)}
.tab.on{color:var(--red);border-bottom-color:var(--red)}
.tab-count{background:var(--bg);color:var(--gray);font-size:10px;font-weight:800;padding:2px 7px;border-radius:50px;min-width:20px;text-align:center}
.tab.on .tab-count{background:var(--red);color:#fff}

/* ════════════════ TIMELINE ════════════════ */
.timeline{padding:18px}
.tl-item{display:flex;gap:14px;padding-bottom:18px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:13px;top:30px;bottom:0;width:2px;background:var(--line)}
.tl-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--bg);color:var(--gray);flex-shrink:0;z-index:1;border:2px solid #fff}
.tl-dot.done{background:var(--green-l);color:var(--green)}
.tl-dot.now{background:var(--red);color:#fff;box-shadow:0 0 0 4px var(--red-l)}
.tl-info{flex:1;min-width:0}
.tl-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.3}
.tl-time{font-size:11px;color:var(--gray);margin-top:2px}
.tl-desc{font-size:12.5px;color:var(--mid);margin-top:5px;line-height:1.5}

/* ════════════════ UTILITIES ════════════════ */
.row{display:flex;align-items:center;gap:14px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:740px){.grid-2,.grid-3{grid-template-columns:1fr}}
.text-c{text-align:center}.text-r{text-align:right}.text-mid{color:var(--mid)}.text-gray{color:var(--gray)}
.text-red{color:var(--red)}.text-green{color:var(--green)}
.fw-7{font-weight:700}.fw-8{font-weight:800}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.hidden{display:none !important}

/* Prevent body scroll when mobile drawer open */
body.no-scroll{overflow:hidden}
