/* ===================================================================
   سامانهٔ حسابداری پروژه‌ها — استایل سراسری (RTL، موبایل‌محور)
   فونت: Vazirmatn (محلی) با fallback به IRANSans/Shabnam/Tahoma/Arial
   =================================================================== */
@font-face{font-family:'Vazirmatn';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/Vazirmatn-Regular.woff2') format('woff2')}
@font-face{font-family:'Vazirmatn';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/Vazirmatn-Medium.woff2') format('woff2')}
@font-face{font-family:'Vazirmatn';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/Vazirmatn-Bold.woff2') format('woff2')}
@font-face{font-family:'Vazirmatn';font-style:normal;font-weight:800;font-display:swap;
  src:url('../fonts/Vazirmatn-Black.woff2') format('woff2')}

:root{
  --navy:#1f3864; --navy2:#2e5496; --gold:#c9a227; --gold-soft:#fff4d6;
  --green:#2e7d32; --green-soft:#e6f4ea; --red:#c0392b; --red-soft:#fdecea;
  --yellow:#f1c40f; --yellow-soft:#fff6da; --blue:#1d6fb8; --blue-soft:#e8f1fb;
  --gray:#f3f6fb; --line:#e4e9f2; --txt:#1e2a3a; --muted:#64748b;
  --font:'Vazirmatn','IRANSans','Shabnam',Tahoma,Arial,sans-serif;
  --shadow:0 1px 3px rgba(16,38,76,.06),0 1px 2px rgba(16,38,76,.04);
  --shadow-lg:0 10px 30px rgba(16,38,76,.12);
  --sidebar-w:250px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html,body{max-width:100%;overflow-x:hidden}   /* بدون سرریز افقی صفحه؛ اسکرول جدول داخل .table-wrap باقی می‌ماند */
body{margin:0;font-family:var(--font);background:var(--gray);color:var(--txt);direction:rtl;
  font-size:14px;line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--navy2);text-decoration:none}
a:hover{text-decoration:underline}
.num{direction:ltr;text-align:right;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;unicode-bidi:plaintext}
.muted{color:var(--muted)} .small{font-size:12.5px}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#1a2f57,#1f3864);color:#dce6f7;
  position:fixed;top:0;right:0;bottom:0;overflow-y:auto;z-index:1000;padding-bottom:30px;
  transition:transform .25s ease}
.sidebar .brand{padding:16px;font-weight:700;font-size:15px;color:#fff;display:flex;gap:9px;align-items:center;
  border-bottom:1px solid rgba(255,255,255,.12);position:sticky;top:0;background:#1a2f57;z-index:2}
.sidebar .brand .logo{width:32px;height:32px;border-radius:9px;background:var(--gold);color:#1f3864;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px}
.menu{list-style:none;margin:8px 0;padding:0}
.menu li a{display:flex;align-items:center;gap:11px;padding:11px 16px;color:#cdd9ef;font-size:14px;
  border-right:3px solid transparent;transition:background .15s}
.menu li a i{font-size:17px;width:20px;text-align:center;flex:none}
.menu li a:hover{background:rgba(255,255,255,.07);text-decoration:none;color:#fff}
.menu li a.active{background:rgba(201,162,39,.18);border-right-color:var(--gold);color:#fff;font-weight:700}
.menu .sep{font-size:11px;color:#8aa0c6;padding:14px 16px 5px;letter-spacing:.4px;font-weight:700}
.content{margin-right:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0}
.backdrop{display:none;position:fixed;inset:0;background:rgba(13,25,48,.5);z-index:900}
.backdrop.show{display:block}

/* ---------- Topbar ---------- */
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:10px 18px;display:flex;
  align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;z-index:30;box-shadow:var(--shadow)}
.topbar .title{font-weight:700;color:var(--navy);font-size:16px;display:flex;align-items:center;gap:10px;min-width:0}
.topbar .title .t-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hamburger{display:none;border:1px solid var(--line);background:#fff;border-radius:9px;
  width:40px;height:40px;font-size:20px;color:var(--navy);cursor:pointer;flex:none}
.topbar .user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.topbar .user .uname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.topbar .user .role{background:var(--navy);color:#fff;border-radius:20px;padding:3px 12px;font-size:12px;white-space:nowrap}
.main{padding:20px;flex:1}
@media(max-width:860px){.main{padding:14px}}

/* ---------- KPI cards ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:13px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;
  box-shadow:var(--shadow);border-top:3px solid var(--navy)}
.kpi .label{font-size:12.5px;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.kpi .value{font-size:21px;font-weight:800;color:var(--navy);direction:ltr;text-align:right;
  font-variant-numeric:tabular-nums;unicode-bidi:plaintext;line-height:1.2}
.kpi .sub{font-size:11px;color:var(--muted);margin-top:4px}
.kpi.gold{border-top-color:var(--gold)} .kpi.gold .value{color:#9c6500}
.kpi.green{border-top-color:var(--green)} .kpi.green .value{color:var(--green)}
.kpi.red{border-top-color:var(--red)} .kpi.red .value{color:var(--red)}
.kpi.blue{border-top-color:var(--blue)} .kpi.blue .value{color:var(--blue)}
.kpi.gray{border-top-color:#94a3b8} .kpi.gray .value{color:#475569}

/* ---------- Card ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:18px;box-shadow:var(--shadow)}
.card .head{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;color:var(--navy);
  display:flex;justify-content:flex-start;align-items:center;gap:8px;flex-wrap:wrap;direction:rtl;text-align:right}
/* عنوان اول (سمت راست) و آیکن بعد از آن — هم برای حالت ساده و هم داخل span */
.card .head > i, .card .head > span > i{order:2;flex:0 0 auto;margin:0}
.card .head > span{display:inline-flex;align-items:center;gap:6px;flex:0 1 auto}
.card .head .head-title{flex:0 1 auto}
/* اقدام‌ها/دکمه‌ها در لبهٔ مقابل (چپ) باقی می‌مانند */
.card .head > .toolbar, .card .head > a, .card .head > form{margin-inline-start:auto}
.card .body{padding:16px}
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:stretch}
.grid2>.card{min-width:0;margin-bottom:0;display:flex;flex-direction:column}
.grid2>.card>.body{flex:1}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1100px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:820px){.grid2,.grid3{grid-template-columns:1fr}}

/* ---------- Alert / warning banner ---------- */
.alert{display:flex;gap:10px;align-items:flex-start;padding:13px 16px;border-radius:12px;margin-bottom:16px;font-size:13.5px}
.alert i{font-size:20px;flex:none;margin-top:1px}
.alert-warn{background:var(--yellow-soft);color:#8a6d00;border:1px solid #f3e0a6}
.alert-info{background:var(--blue-soft);color:#114e86;border:1px solid #bfdcf5}
.alert-danger{background:var(--red-soft);color:var(--red);border:1px solid #f3c6c1}
.alert .a-act{margin-right:auto}

/* ---------- Table ---------- */
.table-wrap{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{background:var(--navy);color:#fff;padding:10px;text-align:right;font-weight:600;white-space:nowrap}
table.tbl td{padding:9px 10px;border-bottom:1px solid var(--line);white-space:nowrap;vertical-align:middle}
table.tbl tbody tr:nth-child(even) td{background:#fafbfe}
table.tbl tbody tr:hover td{background:#eef3fb}
table.tbl tfoot td{background:#eef3fb;font-weight:700}
.miss{background:var(--red-soft)!important;color:var(--red);font-weight:600}

/* ---------- Badges ---------- */
.badge{display:inline-block;border-radius:20px;padding:3px 11px;font-size:11.5px;font-weight:700;white-space:nowrap}
.badge-high{background:var(--red-soft);color:var(--red)}
.badge-medium{background:var(--yellow-soft);color:#9c6500}
.badge-low{background:#eef0f3;color:#5b6b7e}
.badge-ok,.badge-done{background:var(--green-soft);color:var(--green)}
.badge-open{background:var(--yellow-soft);color:#9c6500}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:10px;
  padding:9px 15px;font-size:13.5px;cursor:pointer;font-family:inherit;font-weight:500;transition:filter .15s;line-height:1.4}
.btn:hover{filter:brightness(.95);text-decoration:none}
.btn i{font-size:15px}
.btn-primary{background:var(--navy);color:#fff} .btn-primary:hover{color:#fff}
.btn-gold{background:var(--gold);color:#3a2e00} .btn-gold:hover{color:#3a2e00}
.btn-soft{background:#eef1f7;color:var(--navy)}
.btn-danger{background:var(--red);color:#fff} .btn-danger:hover{color:#fff}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--navy)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-block{width:100%}
.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.field label{display:block;font-size:13px;color:#334155;margin-bottom:6px;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);
  border-radius:10px;font-family:inherit;font-size:14px;background:#fff;min-height:44px;color:var(--txt)}
.field textarea{min-height:64px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy2);
  box-shadow:0 0 0 3px rgba(46,84,150,.12)}
.field.req label::after{content:' *';color:var(--red);font-weight:700}
.field .help{font-size:11.5px;color:var(--muted);margin-top:5px;line-height:1.6}
.field .err{color:var(--red);font-size:12px;margin-top:5px;font-weight:500}
.field input.is-invalid,.field select.is-invalid,.field textarea.is-invalid{border-color:var(--red);background:#fff8f7}
.field.focus-target{background:var(--gold-soft);border-radius:12px;padding:10px;margin:-10px;border:1px dashed var(--gold)}
.full{grid-column:1/-1}
.form-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}

/* ---------- Flash ---------- */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:14px;font-size:13.5px;display:flex;align-items:center;gap:9px;font-weight:500}
.flash i{font-size:18px}
.flash.success{background:var(--green-soft);color:var(--green)}
.flash.error{background:var(--red-soft);color:var(--red)}

/* ---------- Filters ---------- */
.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.filters input,.filters select{padding:9px 11px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:13px;min-height:42px;background:#fff;flex:0 1 auto}
.filters input[type=text]{min-width:160px;flex:1 1 200px}

/* ---------- Filter chips ---------- */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:30px;border:1px solid var(--line);
  background:#fff;color:var(--navy);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap}
.chip:hover{background:#eef3fb;text-decoration:none}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.chip.high.active{background:var(--red);border-color:var(--red)}
.chip .c-count{background:rgba(0,0,0,.08);border-radius:20px;padding:0 7px;font-size:11px}
.chip.active .c-count{background:rgba(255,255,255,.22)}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:36px 16px;color:var(--muted)}
.empty i{font-size:44px;color:#c2cede;display:block;margin-bottom:10px}
.empty .t{font-weight:700;color:#475569;margin-bottom:4px}

/* ---------- Pagination ---------- */
.pager{display:flex;gap:6px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.pager a,.pager span{padding:8px 13px;border:1px solid var(--line);border-radius:9px;font-size:13px;
  background:#fff;min-width:40px;text-align:center}
.pager .cur{background:var(--navy);color:#fff;border-color:var(--navy);font-weight:700}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1f3864,#2e5496);padding:16px}
.login-box{background:#fff;border-radius:18px;padding:30px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}
.login-box .blogo{width:54px;height:54px;border-radius:14px;background:var(--gold);color:#1f3864;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:26px;margin-bottom:14px}
.login-box h1{font-size:18px;color:var(--navy);margin:0 0 4px}
.login-box .sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.login-box .field{margin-bottom:14px}
.hint{background:var(--gold-soft);border-radius:11px;padding:11px 13px;font-size:12px;color:#7a5c00;margin-top:16px;line-height:2}

.chart-box{position:relative;height:300px}
@media(max-width:820px){.chart-box{height:260px}}

/* ====================================================================
   موبایل: سایدبار کشویی، کارت‌نما برای جدول‌ها، تک‌ستونی
   ==================================================================== */
@media(max-width:860px){
  .sidebar{transform:translateX(100%);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .content{margin-right:0}
  .hamburger{display:inline-flex;align-items:center;justify-content:center}
  .kpis{grid-template-columns:1fr 1fr;gap:11px}
  .kpi .value{font-size:18px}
  .form-grid{grid-template-columns:1fr}
  .form-actions .btn{flex:1 1 auto}
  .topbar .user .uname{display:none}
}
@media(max-width:430px){
  .kpis{grid-template-columns:1fr}
}

/* کارت‌نمای جدول روی موبایل (فقط جدول‌های دارای کلاس .cards) */
@media(max-width:760px){
  table.tbl.cards,table.tbl.cards tbody,table.tbl.cards tr,table.tbl.cards td{display:block;width:100%}
  table.tbl.cards thead{display:none}
  table.tbl.cards tr{background:#fff;border:1px solid var(--line);border-radius:13px;
    margin-bottom:12px;padding:6px 4px;box-shadow:var(--shadow)}
  table.tbl.cards tbody tr:nth-child(even) td{background:transparent}
  table.tbl.cards tbody tr:hover td{background:transparent}
  table.tbl.cards td{border:none;border-bottom:1px dashed #eef0f5;padding:8px 14px;white-space:normal;
    display:flex;justify-content:space-between;gap:12px;align-items:center;text-align:left}
  table.tbl.cards td:last-child{border-bottom:none}
  table.tbl.cards td::before{content:attr(data-label);font-weight:700;color:var(--muted);
    font-size:12px;text-align:right;flex:none}
  table.tbl.cards td.cell-actions{justify-content:flex-start;flex-wrap:wrap}
  table.tbl.cards td.cell-actions::before{width:100%;margin-bottom:4px}
  table.tbl.cards td.cell-actions .btn{flex:1 1 auto}
  .filters input[type=text]{flex:1 1 100%}
  .filters select{flex:1 1 calc(50% - 4px)}
}

/* ---------- Print ---------- */
@media print{
  .sidebar,.topbar,.backdrop,.no-print,.btn,.hamburger{display:none!important}
  .content{margin:0}
  body{background:#fff;color:#000;font-size:12px}
  .card{box-shadow:none;border:none}
  table.tbl th{background:#1f3864!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  table.tbl,tr,td,th{page-break-inside:avoid}
  @page{size:A4;margin:14mm}
}

/* ============================================================
   انتخاب‌گر هوشمند (Smart Select)
   ============================================================ */
.ss-control{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
  min-height:44px;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;
  font-family:inherit;font-size:14px;cursor:pointer;color:var(--txt);text-align:right}
.ss-control:hover{border-color:var(--navy2)}
.ss-control.empty .ss-val{color:#9aa6b6}
.ss-control .ss-texts{display:flex;flex-direction:column;align-items:flex-start;min-width:0;gap:1px}
.ss-control .ss-val{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.ss-control .ss-sub{font-size:11px;color:var(--muted)}
.ss-control .ss-caret{color:var(--muted);flex:none}
.is-invalid + .ss-control{border-color:var(--red);background:#fff8f7}

.ss-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(13,25,48,.45)}
.ss-overlay.open{display:block}
.ss-panel{background:#fff;display:flex;flex-direction:column;overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.ss-panel.ss-drop{border-radius:12px;max-height:60vh}
.ss-panel.ss-sheet{position:fixed;left:0;right:0;bottom:0;border-radius:18px 18px 0 0;max-height:90vh;
  animation:ssUp .22s ease}
@keyframes ssUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ss-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}
.ss-title{font-weight:700;color:var(--navy);font-size:15px}
.ss-x{border:none;background:none;font-size:26px;line-height:1;color:var(--muted);cursor:pointer;padding:0 4px}
.ss-searchbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);
  position:sticky;top:51px;background:#fff;color:var(--muted)}
.ss-search{flex:1;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-family:inherit;
  font-size:14px;min-height:42px}
.ss-search:focus{outline:none;border-color:var(--navy2)}
.ss-list{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:6px;flex:1}
.ss-panel.ss-drop .ss-list{max-height:42vh}
.ss-panel.ss-sheet .ss-list{max-height:64vh}
.ss-opt{display:flex;align-items:center;gap:10px;width:100%;min-height:46px;padding:9px 12px;
  border:none;background:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:14px;
  text-align:right;color:var(--txt)}
.ss-opt:hover{background:#eef3fb}
.ss-opt.active{background:var(--blue-soft)}
.ss-opt-main{font-weight:500}
.ss-opt-sub{font-size:11.5px;color:var(--muted);margin-right:auto}
.ss-opt-tick{color:var(--green);font-size:18px}
.ss-empty{text-align:center;color:var(--muted);padding:30px 10px}
.ss-empty i{font-size:38px;color:#c2cede;display:block;margin-bottom:8px}
.ss-actions{display:flex;gap:8px;padding:11px 14px;border-top:1px solid var(--line);
  position:sticky;bottom:0;background:#fff}
.ss-actions .btn{flex:1}

/* نوار ذخیره/انصراف چسبان در موبایل */
@media(max-width:860px){
  .sticky-actions{position:sticky;bottom:0;background:rgba(255,255,255,.96);backdrop-filter:blur(4px);
    margin:0 -14px -14px;padding:12px 14px;border-top:1px solid var(--line);z-index:20}
  .sticky-actions .btn{flex:1 1 auto}
}

/* ---------- Project workspace ---------- */
.proj-head{background:linear-gradient(135deg,#1f3864,#2e5496);color:#fff;border-radius:16px;padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow)}
.proj-head .pcode{font-size:20px;font-weight:800;direction:ltr;text-align:right;unicode-bidi:plaintext}
.proj-head .pmeta{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:8px;font-size:13px;color:#cfe0f7}
.proj-head .pmeta b{color:#fff}
.proj-head .pactions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.proj-mini{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.proj-mini .m{background:rgba(255,255,255,.12);border-radius:10px;padding:7px 12px;font-size:12.5px}
.proj-mini .m b{font-size:15px;display:block;direction:ltr;text-align:right;unicode-bidi:plaintext}
.tabs{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;border-bottom:2px solid var(--line);
  margin-bottom:16px;padding-bottom:0}
.tabs a{padding:10px 15px;font-size:13.5px;font-weight:600;color:var(--muted);white-space:nowrap;
  border-bottom:3px solid transparent;border-radius:8px 8px 0 0}
.tabs a:hover{background:#eef3fb;text-decoration:none}
.tabs a.active{color:var(--navy);border-bottom-color:var(--gold);background:#fff}
.sec-title{font-weight:700;color:var(--navy);margin:0 0 10px;display:flex;align-items:center;gap:7px}
.sum-table td{padding:8px 10px}
@media(max-width:860px){.proj-head .pactions .btn{flex:1 1 auto}}

/* ---------- Grouped missing-data (collapsible) ---------- */
.iss-group{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
.iss-group summary{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;background:#fafbfe;list-style:none;font-size:14px}
.iss-group summary::-webkit-details-marker{display:none}
.iss-group summary .c-count{margin-right:auto;color:var(--muted);font-size:12.5px}
.iss-group .ig-caret{transition:transform .2s;color:var(--muted)}
.iss-group[open] .ig-caret{transform:rotate(180deg)}
.ig-body{padding:4px 14px 10px}
.ig-row{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px dashed #eef0f5;flex-wrap:wrap}

/* ---------- Worksheet (Sheet2-style) ---------- */
.ws-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}
.ws-meta>div{background:#f7f9fc;border:1px solid var(--line);border-radius:10px;padding:9px 12px}
.ws-meta span{display:block;font-size:11.5px;color:var(--muted);margin-bottom:3px}
.ws-meta b{font-size:14px;direction:ltr;text-align:right;unicode-bidi:plaintext}
table.tbl tfoot tr td{background:#eef3fb;font-weight:700}

/* ============================================================
   واکنش‌گرایی بخش «هزینه‌های فروش» و «جدول هزینه کل» (grid2)
   ============================================================ */
/* جدول خلاصه: برچسب راست (RTL)، مبلغ چپ (LTR) و بدون شکستن */
.sum-table td:first-child{text-align:right}
.sum-table td:last-child{text-align:left;direction:ltr;white-space:nowrap;font-variant-numeric:tabular-nums;unicode-bidi:plaintext}
/* در جدول‌های کنار هم، ستون متن می‌شکند ولی مبلغ نه */
.grid2 .tbl td{white-space:normal}
.grid2 .tbl td.num,.grid2 .tbl .num{white-space:nowrap}

@media(max-width:820px){
  .grid2{grid-template-columns:1fr;gap:12px}
  .grid2 .card{width:100%;max-width:100%;overflow:hidden}
  .grid2 .card .body{padding:12px}
  /* «جدول هزینه کل» → فهرست خلاصه: برچسب راست، مبلغ چپ، روی یک خط */
  .sum-table{min-width:0!important}
  .sum-table thead{display:none}
  .sum-table tbody,.sum-table tfoot{display:block;width:100%}
  .sum-table tr{display:flex;justify-content:space-between;align-items:center;gap:12px;
    border-bottom:1px solid var(--line);padding:2px 0}
  .sum-table td{display:block;border:none;padding:10px 6px;white-space:normal}
  .sum-table td:first-child{flex:1;text-align:right;color:var(--txt)}
  .sum-table td:last-child{flex:none;text-align:left;direction:ltr;white-space:nowrap;font-weight:600}
  .sum-table tfoot tr{background:#eef3fb;border-radius:10px;border:none;margin-top:6px}
  /* «هزینه‌های فروش» جدول کوچک: ستون شرح می‌شکند، مبلغ خوانا می‌ماند */
  .grid2 .tbl{min-width:0;width:100%}
}

/* ============================================================
   داشبورد مدیریتی مالی
   ============================================================ */
.dash-hero{background:linear-gradient(120deg,#1a2f57,#2e5496);color:#fff;border-radius:18px;
  padding:22px 24px;margin-bottom:18px;display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;flex-wrap:wrap;box-shadow:var(--shadow);-webkit-print-color-adjust:exact;print-color-adjust:exact}
.dash-hero h1{font-size:22px;font-weight:800;margin:0 0 4px}
.dash-hero p{margin:0;color:#cfe0f7;font-size:13.5px}
.dash-hero .dh-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;font-size:12.5px;color:#bcd0ef}
.dash-hero .dh-actions{display:flex;gap:8px;flex-wrap:wrap}

.dash-filters{padding:0}
.dash-filters>summary{padding:13px 16px;font-weight:700;color:var(--navy);cursor:pointer;
  display:flex;align-items:center;gap:8px;list-style:none}
.dash-filters>summary::-webkit-details-marker{display:none}
.dash-filters[open]>summary{border-bottom:1px solid var(--line)}
.dash-filters .filters{margin-bottom:0}

/* KPI grid */
.dash-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:14px;margin-bottom:18px}
.dash-kpi{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;border-top:3px solid var(--navy);
  transition:transform .12s,box-shadow .12s}
.dash-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(16,38,76,.12);text-decoration:none}
.dash-kpi .dk-top{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12.5px;margin-bottom:8px}
.dash-kpi .dk-icon{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:#eef3fb;color:var(--navy);flex:none;font-size:16px}
.dash-kpi .dk-title{font-weight:600;color:#475569}
.dash-kpi .dk-value{font-size:22px;font-weight:800;color:var(--navy);direction:rtl;line-height:1.25}
.dash-kpi .dk-unit{font-size:12px;font-weight:600;color:var(--muted)}
.dash-kpi .dk-desc{font-size:11.5px;color:var(--muted);margin-top:6px;line-height:1.6}
.dash-kpi.gold{border-top-color:var(--gold)} .dash-kpi.gold .dk-value{color:#9c6500} .dash-kpi.gold .dk-icon{background:var(--gold-soft);color:#9c6500}
.dash-kpi.green{border-top-color:var(--green)} .dash-kpi.green .dk-value{color:var(--green)} .dash-kpi.green .dk-icon{background:var(--green-soft);color:var(--green)}
.dash-kpi.red{border-top-color:var(--red)} .dash-kpi.red .dk-value{color:var(--red)} .dash-kpi.red .dk-icon{background:var(--red-soft);color:var(--red)}
.dash-kpi.blue{border-top-color:var(--blue)} .dash-kpi.blue .dk-value{color:var(--blue)} .dash-kpi.blue .dk-icon{background:var(--blue-soft);color:var(--blue)}
.dash-kpi.gray{border-top-color:#94a3b8} .dash-kpi.gray .dk-value{color:#475569}

/* Insights */
.insight-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.insight-list li{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;line-height:1.8}
.insight-list li i{color:var(--gold);font-size:17px;flex:none;margin-top:2px}

/* Readiness + DQ */
.dq-badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.rb{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:30px;font-size:13px;font-weight:700}
.rb-ok{background:var(--green-soft);color:var(--green)} .rb-warn{background:var(--yellow-soft);color:#9c6500} .rb-no{background:var(--red-soft);color:var(--red)}
.dq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dqc{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;border:1px solid var(--line);
  border-radius:12px;background:#fafbfe;text-align:center}
.dqc:hover{background:#eef3fb;text-decoration:none}
.dqc b{font-size:20px;font-weight:800;color:var(--navy)}
.dqc span{font-size:11.5px;color:var(--muted)}
.dqc.red b{color:var(--red)} .dqc.green b{color:var(--green)}

/* Action plan */
.action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.action-item{border:1px solid var(--line);border-radius:12px;padding:13px;background:#fafbfe;display:flex;flex-direction:column;gap:7px}
.action-item .ai-head{display:flex;align-items:center;gap:8px}
.action-item .ai-head b{font-size:13.5px;color:var(--navy)}
.action-item .btn{align-self:flex-start}

@media(max-width:820px){
  .dash-hero{padding:18px}
  .dash-hero h1{font-size:18px}
  .dq-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:430px){
  .dash-kpis{grid-template-columns:1fr 1fr}
  .dash-kpi .dk-value{font-size:18px}
}
@media print{
  .dash-hero{background:#1a2f57!important}
  .dash-filters{display:none!important}
  .dash-kpis{grid-template-columns:repeat(4,1fr)}
  .grid2{grid-template-columns:1fr 1fr}
}
