/* ============================================================
   ميزان — Mizan Design System
   Emerald & mint on warm paper · coral accents · IBM Plex Arabic
   ============================================================ */
:root{
  --bg:#F4F7F6;
  --bg-mesh:radial-gradient(1100px 560px at 85% -10%,rgba(198,40,40,.08),transparent 60%),
            radial-gradient(900px 500px at -10% 0%,rgba(62,111,217,.05),transparent 55%);
  --surface:#FFFFFF;
  --surface-2:#FBFDFC;
  --ink:#17332E;
  --ink-2:#3D5650;
  --muted:#6B837D;
  --line:#E3ECE9;
  --line-2:#D2E0DC;
  --primary:#C62828;
  --primary-deep:#9B1C1C;
  --primary-ink:#7A1515;
  --primary-soft:#FBE3E3;
  --primary-softer:#FDF0F0;
  --mint:#E8A6A6;
  --accent:#E76F51;
  --accent-soft:#FCEAE4;
  --info:#3E6FD9;
  --info-soft:#E8EEFB;
  --warn:#D98E26;
  --warn-soft:#FBF1DF;
  --danger:#D64550;
  --danger-soft:#FBE7E9;
  --violet:#7C5CD6;
  --violet-soft:#EFEAFB;
  --radius:14px;
  --shadow:0 1px 2px rgba(23,51,46,.05),0 10px 30px -12px rgba(23,51,46,.10);
  --shadow-lg:0 24px 70px -20px rgba(110,18,18,.28);
  --sidebar-w:250px;
  --font:'IBM Plex Sans Arabic',system-ui,-apple-system,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{
  font-family:var(--font);color:var(--ink);background:var(--bg);
  background-image:var(--bg-mesh);background-attachment:fixed;
  -webkit-font-smoothing:antialiased;min-height:100vh;
}
b,strong{font-weight:600}
a{color:inherit}
.num{font-variant-numeric:tabular-nums lining-nums}

/* ============ App shell ============ */
.shell{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.view{padding:22px 26px 70px;max-width:1460px;width:100%;margin:0 auto;animation:viewIn .3s ease}
@keyframes viewIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;color:#F7DCDC;
  background:linear-gradient(168deg,#6E1212 0%,#9B1C1C 55%,#C62828 135%);
  z-index:40;
}
.brand{display:flex;align-items:center;gap:11px;padding:20px 18px 14px;text-decoration:none}
.brand-logo{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;
  font-size:21px;font-weight:700;color:#9B1C1C;
  background:linear-gradient(145deg,#FFFFFF,#BFE8D9);box-shadow:0 6px 16px -6px rgba(0,0,0,.4);
}
.brand-name{display:flex;flex-direction:column;line-height:1.25}
.brand-name b{font-size:19px;color:#fff;letter-spacing:.4px}
.brand-name span{font-size:10.5px;color:#E2ABAB}
.nav{flex:1;overflow-y:auto;padding:0 12px 18px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}
.nav-group{margin-top:13px}
.nav-group-title{font-size:10px;font-weight:600;color:#8FBFB0;text-transform:uppercase;letter-spacing:.13em;padding:0 10px 6px}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;
  color:#CDE7DD;font-size:13.5px;cursor:pointer;text-decoration:none;
  transition:background .15s,color .15s;margin-bottom:1px;
}
.nav-item:hover{background:rgba(255,255,255,.09);color:#fff}
.nav-item.active{background:#fff;color:var(--primary-deep);font-weight:600;box-shadow:0 8px 20px -8px rgba(0,0,0,.35)}
.nav-item .ni{width:20px;text-align:center;font-size:14px;opacity:.92}
.sidebar-foot{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(255,255,255,.1)}
.lang-toggle{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;text-decoration:none;
  border-radius:8px;padding:5px 13px;font-family:var(--font);font-weight:600;font-size:12px;cursor:pointer;
}
.lang-toggle:hover{background:rgba(255,255,255,.22)}
.sidebar .version{font-size:10.5px;color:#8FBFB0}

/* Topbar */
.topbar{
  display:flex;align-items:center;gap:13px;padding:11px 26px;position:sticky;top:0;z-index:30;
  background:rgba(244,247,246,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.menu-btn{background:none;border:none;font-size:19px;cursor:pointer;color:var(--ink-2);display:none}
.crumbs{font-size:13px;color:var(--muted)}
.crumbs b{color:var(--ink);font-size:15.5px;font-weight:700}
.topbar-spacer{flex:1}
.gsearch{position:relative}
.gsearch input{
  width:230px;padding:8px 32px 8px 12px;border:1px solid var(--line-2);border-radius:10px;
  font-family:var(--font);font-size:13px;background:var(--surface);color:var(--ink);outline:none;transition:.15s;
}
[dir=ltr] .gsearch input{padding:8px 12px 8px 32px}
.gsearch input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(198,40,40,.14)}
.gsearch .gi{position:absolute;top:7px;inset-inline-start:10px;color:var(--muted);font-size:15px;pointer-events:none}
.gresults{
  position:absolute;top:42px;inset-inline-start:0;width:330px;max-height:380px;overflow:auto;display:none;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);z-index:60;
}
.gresults.open{display:block}
.gresults a{padding:9px 13px;cursor:pointer;display:flex;justify-content:space-between;gap:8px;font-size:13px;border-bottom:1px solid var(--line);text-decoration:none}
.gresults a:last-child{border-bottom:none}
.gresults a:hover{background:var(--primary-softer)}
.gresults .gk{font-size:11px;color:var(--muted)}
.user-chip{display:flex;align-items:center;gap:9px}
.avatar{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:14px;
  background:linear-gradient(140deg,var(--primary),#3E6FD9);flex-shrink:0;
}
.uc-info{display:flex;flex-direction:column;line-height:1.25}
.uc-info b{font-size:12.5px}
.uc-info span{font-size:10.5px;color:var(--muted)}
.trial-chip{background:var(--warn-soft);color:#7A5414;font-size:11.5px;font-weight:600;padding:5px 12px;border-radius:99px;text-decoration:none}
.trial-chip:hover{filter:brightness(.97)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:10px;cursor:pointer;
  font-family:var(--font);font-weight:600;font-size:13.5px;padding:9px 18px;transition:.16s;text-decoration:none;line-height:1.4;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 16px -6px rgba(198,40,40,.5)}
.btn-primary:hover{background:var(--primary-deep);transform:translateY(-1px)}
.btn-outline{background:var(--surface);color:var(--primary-deep);border:1px solid var(--line-2)}
.btn-outline:hover{border-color:var(--primary);background:var(--primary-softer)}
.btn-ghost{background:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--primary-softer);color:var(--primary-deep)}
.btn-danger{background:var(--danger-soft);color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 6px 16px -6px rgba(231,111,81,.5)}
.btn-accent:hover{filter:brightness(.94);transform:translateY(-1px)}
.btn-sm{padding:6px 13px;font-size:12.5px;border-radius:8px}
.btn-lg{padding:13px 30px;font-size:15.5px;border-radius:12px}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.btn-block{width:100%}

/* Page head & cards */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-title h1{font-size:21px;font-weight:700}
.page-title p{font-size:13px;color:var(--muted);margin-top:3px}
.page-actions{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:18px 20px}
.card-title{font-size:14.5px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-title .sub{font-size:12px;color:var(--muted);font-weight:400}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:16px}
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.kpi::after{content:'';position:absolute;inset-inline-end:-32px;top:-32px;width:110px;height:110px;border-radius:50%;background:var(--tint,var(--primary-softer));opacity:.6}
.kpi-label{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px;position:relative;z-index:1}
.kpi-icon{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:14px;background:var(--tint,var(--primary-soft))}
.kpi-value{font-size:23px;font-weight:700;margin-top:9px;letter-spacing:-.01em;position:relative;z-index:1;font-variant-numeric:tabular-nums}
.kpi-value small{font-size:12px;color:var(--muted);font-weight:500}
.kpi-delta{font-size:11.5px;margin-top:5px;font-weight:600;position:relative;z-index:1}
.kpi-delta.up{color:var(--primary)}
.kpi-delta.down{color:var(--danger)}
.kpi-delta span{color:var(--muted);font-weight:400}

/* Tables */
.table-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--surface)}
table.data thead th{
  text-align:start;padding:11px 14px;font-size:11px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-2);
  background:var(--surface-2);white-space:nowrap;
}
table.data tbody td{padding:10.5px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tbody tr{transition:background .12s}
table.data tbody tr:hover{background:var(--primary-softer)}
table.data tbody tr:last-child td{border-bottom:none}
table.data td.num,table.data th.num{text-align:end;direction:ltr;font-variant-numeric:tabular-nums;white-space:nowrap}
[dir=rtl] table.data td.num,[dir=rtl] table.data th.num{text-align:left}
table.data tfoot td{padding:11px 14px;font-weight:700;background:var(--surface-2);border-top:2px solid var(--line-2)}
.row-link{text-decoration:none;color:var(--primary-deep);font-weight:600}
.row-link:hover{text-decoration:underline}
.row-actions{display:flex;gap:4px;justify-content:flex-end}
.row-actions a,.row-actions button{
  background:var(--surface);border:1px solid var(--line-2);width:28px;height:28px;border-radius:7px;text-decoration:none;
  cursor:pointer;font-size:13px;color:var(--ink-2);display:grid;place-items:center;
}
.row-actions a:hover,.row-actions button:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}
.empty-state{padding:56px 20px;text-align:center;color:var(--muted)}
.empty-state .ei{font-size:42px;margin-bottom:12px;opacity:.5}
.empty-state h3{font-size:16px;color:var(--ink-2);margin-bottom:6px}
.empty-state p{font-size:13px;margin-bottom:16px}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:99px;font-size:11.5px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.draft{background:#EEF1F0;color:#5C7470}
.badge.sent,.badge.ordered{background:var(--info-soft);color:var(--info)}
.badge.approved,.badge.active,.badge.accepted,.badge.open,.badge.posted,.badge.paid,.badge.done,.badge.received,.badge.invoiced,.badge.trial-ok{background:var(--primary-soft);color:var(--primary-deep)}
.badge.partial,.badge.trial{background:var(--warn-soft);color:var(--warn)}
.badge.overdue,.badge.void,.badge.rejected,.badge.low,.badge.expired,.badge.inactive{background:var(--danger-soft);color:var(--danger)}
.badge.neutral{background:var(--violet-soft);color:var(--violet)}

/* Toolbar / filters */
.list-toolbar{display:flex;gap:10px;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.list-toolbar .lt-search{position:relative;flex:1;min-width:170px;max-width:300px}
.list-toolbar .lt-search input{
  width:100%;padding:8px 32px 8px 12px;border:1px solid var(--line-2);border-radius:9px;font-family:var(--font);
  font-size:13px;outline:none;background:var(--surface-2);
}
[dir=ltr] .list-toolbar .lt-search input{padding:8px 12px 8px 32px}
.list-toolbar .lt-search input:focus{border-color:var(--primary)}
.list-toolbar .lt-search span{position:absolute;inset-inline-start:10px;top:8px;color:var(--muted)}
.list-toolbar select,.list-toolbar input[type=date],.list-toolbar input[type=number]{
  border:1px solid var(--line-2);border-radius:9px;padding:7.5px 10px;font-family:var(--font);font-size:12.5px;
  background:var(--surface);color:var(--ink-2);outline:none;
}
.summary-chips{display:flex;gap:10px;padding:12px 16px;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.summary-chip{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:7px 14px;font-size:12px;color:var(--muted)}
.summary-chip b{color:var(--ink);font-size:13.5px;display:block;font-variant-numeric:tabular-nums}

/* Pagination */
.pagination-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;justify-content:space-between;font-size:12.5px;color:var(--muted);flex-wrap:wrap}
.pagination-bar .pages{display:flex;gap:5px}
.pagination-bar a,.pagination-bar span.pg{
  border:1px solid var(--line-2);background:var(--surface);border-radius:7px;min-width:30px;height:30px;padding:0 8px;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12.5px;color:var(--ink-2);text-decoration:none;
}
.pagination-bar span.pg.cur{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination-bar span.pg.dis{opacity:.4}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.field label .req{color:var(--danger)}
.field input,.field select,.field textarea{
  border:1.5px solid var(--line-2);border-radius:10px;padding:9px 12px;font-family:var(--font);font-size:13.5px;
  color:var(--ink);background:var(--surface);outline:none;transition:.15s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(198,40,40,.13)}
.field textarea{resize:vertical;min-height:64px}
.field .hint{font-size:11.5px;color:var(--muted)}
.err-text{color:var(--danger);font-size:12px;margin-top:3px}
.checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;user-select:none}
.checkbox-row input{width:16px;height:16px;accent-color:var(--primary)}
.form-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:18px;flex-wrap:wrap}
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line-2);border-radius:10px;padding:3px;gap:2px}
.seg button,.seg a{border:none;background:transparent;padding:6px 15px;border-radius:8px;font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;text-decoration:none}
.seg .on{background:var(--surface);color:var(--primary-deep);box-shadow:0 1px 4px rgba(0,0,0,.08)}

/* Document line editor */
.doc-lines{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.doc-lines th{text-align:start;font-size:10.5px;color:var(--muted);font-weight:600;padding:7px 8px;border-bottom:1.5px solid var(--line-2);text-transform:uppercase;letter-spacing:.05em}
.doc-lines td{padding:4px;border-bottom:1px solid var(--line);vertical-align:middle}
.doc-lines input,.doc-lines select{
  width:100%;border:1px solid transparent;background:transparent;border-radius:7px;padding:7px 8px;
  font-family:var(--font);font-size:13px;outline:none;color:var(--ink);
}
.doc-lines input:hover,.doc-lines select:hover{background:var(--surface-2)}
.doc-lines input:focus,.doc-lines select:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 2px rgba(198,40,40,.12)}
.doc-lines .n input{text-align:end;direction:ltr}
.dl-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:4px 7px;border-radius:6px}
.dl-remove:hover{color:var(--danger);background:var(--danger-soft)}
.doc-totals{
  margin-top:14px;margin-inline-start:auto;width:300px;max-width:100%;background:var(--surface-2);
  border:1px solid var(--line);border-radius:12px;padding:13px 16px;font-size:13.5px;
}
.doc-totals .row{display:flex;justify-content:space-between;align-items:center;padding:4.5px 0;color:var(--ink-2);gap:8px}
.doc-totals .row.grand{border-top:1.5px solid var(--line-2);margin-top:6px;padding-top:9px;font-size:16.5px;font-weight:700;color:var(--primary-deep)}
.doc-totals .num{font-variant-numeric:tabular-nums;direction:ltr}
.add-line-btn{margin-top:9px;background:var(--primary-softer);color:var(--primary-deep);border:1px dashed var(--mint);border-radius:9px;padding:8px 16px;font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer;width:100%}
.add-line-btn:hover{background:var(--primary-soft)}

/* Doc view */
.doc-head-grid{display:grid;grid-template-columns:1fr auto;gap:18px;margin-bottom:16px}
@media(max-width:760px){.doc-head-grid{grid-template-columns:1fr}}
.dv-meta{display:grid;grid-template-columns:auto 1fr;gap:5px 20px;font-size:13px;align-content:start}
.dv-meta dt{color:var(--muted)}
.dv-meta dd{font-weight:600}
.status-strip{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:1.5px solid var(--line-2);margin-bottom:18px;overflow-x:auto}
.tabs a,.tabs button{
  border:none;background:none;padding:10px 17px;font-family:var(--font);font-size:13.5px;font-weight:600;text-decoration:none;
  color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1.5px;white-space:nowrap;
}
.tabs .on{color:var(--primary-deep);border-bottom-color:var(--primary)}
.tabs a:hover,.tabs button:hover{color:var(--primary)}

/* Account tree */
.acc-tree{font-size:13.5px}
.acc-node{display:flex;align-items:center;gap:9px;padding:7.5px 12px;border-radius:9px}
.acc-node:hover{background:var(--primary-softer)}
.acc-node .code{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;min-width:50px;direction:ltr}
.acc-node .bal{margin-inline-start:auto;font-variant-numeric:tabular-nums;direction:ltr;font-weight:600;font-size:12.5px;white-space:nowrap}
.acc-children{margin-inline-start:20px;border-inline-start:1.5px dashed var(--line-2);padding-inline-start:6px}
.type-chip{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:600}
.type-asset{background:var(--info-soft);color:var(--info)}
.type-liability{background:var(--accent-soft);color:var(--accent)}
.type-equity{background:var(--violet-soft);color:var(--violet)}
.type-income{background:var(--primary-soft);color:var(--primary-deep)}
.type-expense{background:var(--warn-soft);color:var(--warn)}

/* POS */
.pos-layout{display:grid;grid-template-columns:1fr 390px;gap:16px;align-items:start}
@media(max-width:1000px){.pos-layout{grid-template-columns:1fr}}
.pos-cats{display:flex;gap:7px;overflow-x:auto;padding-bottom:10px}
.pos-cats button{border:1px solid var(--line-2);background:var(--surface);border-radius:99px;padding:6px 16px;font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--ink-2);cursor:pointer;white-space:nowrap}
.pos-cats button.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:11px;max-height:calc(100vh - 280px);overflow-y:auto;padding:4px 2px 16px}
.pos-card{
  background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:12px;cursor:pointer;
  transition:.15s;display:flex;flex-direction:column;gap:5px;box-shadow:var(--shadow);text-align:start;font-family:var(--font);
}
.pos-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 12px 28px -10px rgba(198,40,40,.3)}
.pos-card .pe{font-size:25px}
.pos-card .pn{font-size:12.5px;font-weight:600;line-height:1.35;color:var(--ink)}
.pos-card .pp{font-size:13px;color:var(--primary-deep);font-weight:700;font-variant-numeric:tabular-nums}
.pos-card .ps{font-size:10.5px;color:var(--muted)}
.pos-cart{position:sticky;top:76px}
.pos-cart-lines{max-height:300px;overflow-y:auto}
.pos-line{display:flex;align-items:center;gap:9px;padding:9px 14px;border-bottom:1px solid var(--line);font-size:13px}
.pos-line .pl-n{flex:1;font-weight:600;line-height:1.3}
.pos-line .pl-n small{display:block;color:var(--muted);font-weight:400;font-size:11px}
.pos-qty{display:flex;align-items:center;gap:6px}
.pos-qty button{width:25px;height:25px;border-radius:7px;border:1px solid var(--line-2);background:var(--surface);cursor:pointer;font-weight:700;color:var(--primary-deep);font-size:14px}
.pos-pay{padding:14px;border-top:1.5px solid var(--line-2);background:var(--surface-2);border-radius:0 0 var(--radius) var(--radius)}
.pos-trow{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;color:var(--ink-2)}
.pos-trow.grand{font-size:19px;font-weight:700;color:var(--primary-deep);padding:8px 0}
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}
.pay-methods button{padding:11px;border-radius:11px;border:1.5px solid var(--line-2);background:var(--surface);font-family:var(--font);font-weight:600;font-size:13px;cursor:pointer}
.pay-methods button.on{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-deep)}

/* Toast & alerts */
.toast-root{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:9px;align-items:center}
.toast{
  background:var(--primary-ink);color:#fff;padding:11px 22px;border-radius:12px;font-size:13.5px;font-weight:500;
  box-shadow:var(--shadow-lg);animation:toastIn .25s cubic-bezier(.2,.9,.3,1.3);
}
.toast.err{background:#7E2A31}
@keyframes toastIn{from{opacity:0;transform:translateY(14px) scale(.95)}to{opacity:1;transform:none}}
.alert{padding:12px 16px;border-radius:11px;font-size:13px;display:flex;gap:10px;align-items:flex-start;margin-bottom:14px}
.alert.warn{background:var(--warn-soft);color:#7A5414;border:1px solid #F0DDB8}
.alert.info{background:var(--info-soft);color:#27488F;border:1px solid #CBD9F5}
.alert.danger{background:var(--danger-soft);color:#8F2C34;border:1px solid #F2C7CB}
.alert ul{margin:0;padding-inline-start:18px}

/* Reports */
.report-head{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.report-title-block{text-align:center;margin-bottom:16px}
.report-title-block h2{font-size:19px;font-weight:700}
.report-title-block p{font-size:12.5px;color:var(--muted)}
table.report{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface)}
table.report th{background:var(--primary-deep);color:#fff;padding:10px 13px;text-align:start;font-size:12px;font-weight:600}
table.report th.num{text-align:end}
table.report td{padding:8px 13px;border-bottom:1px solid var(--line)}
table.report td.num{text-align:end;direction:ltr;font-variant-numeric:tabular-nums;white-space:nowrap}
table.report tr.section td{background:var(--primary-softer);font-weight:700;color:var(--primary-deep)}
table.report tr.subtotal td{font-weight:700;border-top:1.5px solid var(--line-2);background:var(--surface-2)}
table.report tr.grand td{font-weight:700;font-size:14px;background:var(--primary-soft);color:var(--primary-ink);border-top:2px solid var(--primary)}
table.report tr.indent td:first-child{padding-inline-start:32px}
.report-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:14px}
.report-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;transition:.16s;box-shadow:var(--shadow);text-decoration:none;display:block}
.report-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 34px -12px rgba(198,40,40,.3)}
.report-card .ri{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:19px;background:var(--tint,var(--primary-soft));margin-bottom:12px}
.report-card h3{font-size:14.5px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.report-card p{font-size:12px;color:var(--muted);line-height:1.55}

/* Settings */
.settings-grid{display:grid;grid-template-columns:215px 1fr;gap:18px;align-items:start}
@media(max-width:860px){.settings-grid{grid-template-columns:1fr}}
.settings-nav{display:flex;flex-direction:column;gap:3px;position:sticky;top:80px}
.settings-nav a{
  text-align:start;border:none;background:none;padding:9px 14px;border-radius:9px;font-family:var(--font);text-decoration:none;
  font-size:13.5px;color:var(--ink-2);cursor:pointer;font-weight:500;
}
.settings-nav a.on{background:var(--primary-soft);color:var(--primary-deep);font-weight:700}
.perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;margin-top:8px}

/* Misc */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.grid-21{display:grid;grid-template-columns:2fr 1fr;gap:14px}
@media(max-width:950px){.grid-2,.grid-3,.grid-21{grid-template-columns:1fr}}
.mt{margin-top:14px}.mb{margin-bottom:14px}
.muted{color:var(--muted);font-size:12.5px}
.link{color:var(--primary);cursor:pointer;font-weight:600;text-decoration:none}
.link:hover{text-decoration:underline}
.divider{height:1px;background:var(--line);margin:16px 0}
.pill-bar{height:7px;border-radius:99px;background:var(--line);overflow:hidden}
.pill-bar i{display:block;height:100%;border-radius:99px;background:var(--primary)}
.pill-bar i.over{background:var(--danger)}
.code{font-family:ui-monospace,Consolas,monospace;background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:12px;direction:ltr;display:inline-block;word-break:break-all}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-2);margin-top:10px}
.legend .li{display:flex;align-items:center;gap:6px}
.legend .ld{width:9px;height:9px;border-radius:3px}
.chart-wrap{width:100%;overflow-x:auto}
.timeline{border-inline-start:2px solid var(--line-2);padding-inline-start:18px;margin-top:8px}
.timeline .tl{position:relative;padding-bottom:13px;font-size:12.5px}
.timeline .tl::before{content:'';position:absolute;inset-inline-start:-24.5px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--primary);border:2px solid var(--surface)}
.timeline .tl span{color:var(--muted);display:block;font-size:11px}

/* ============ Landing page ============ */
.land{overflow-x:hidden}
.land-nav{
  display:flex;align-items:center;gap:22px;padding:16px 6vw;position:sticky;top:0;z-index:50;
  background:rgba(244,247,246,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.land-nav .links{display:flex;gap:20px;font-size:13.5px;font-weight:500;color:var(--ink-2)}
.land-nav .links a{text-decoration:none;color:inherit}
.land-nav .links a:hover{color:var(--primary)}
.land-nav .spacer{flex:1}
.land-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.land-brand .lg{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:20px;font-weight:700;color:#fff;background:linear-gradient(145deg,#C62828,#9B1C1C);box-shadow:0 6px 14px -5px rgba(198,40,40,.5)}
.land-brand b{font-size:19px;color:var(--primary-ink)}
.hero{position:relative;padding:70px 6vw 60px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
@media(max-width:980px){.hero{grid-template-columns:1fr;padding-top:48px}}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--primary-soft);color:var(--primary-deep);font-size:12.5px;font-weight:600;padding:7px 16px;border-radius:99px;margin-bottom:20px}
.hero h1{font-size:clamp(30px,4.6vw,52px);font-weight:700;line-height:1.25;letter-spacing:-.01em}
.hero h1 .hl{color:var(--primary);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:'';position:absolute;bottom:4px;inset-inline:0;height:10px;background:var(--mint);opacity:.45;z-index:-1;border-radius:4px}
.hero p.lead{font-size:16.5px;color:var(--ink-2);line-height:1.85;margin:18px 0 28px;max-width:540px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-note{font-size:12px;color:var(--muted);margin-top:14px}
.hero-stats{display:flex;gap:34px;margin-top:38px;flex-wrap:wrap}
.hero-stats .hs b{font-size:23px;color:var(--primary-deep);display:block;font-variant-numeric:tabular-nums}
.hero-stats .hs span{font-size:12px;color:var(--muted)}
.hero-visual{position:relative;min-height:380px}
.hv-card{position:absolute;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:16px 18px;animation:floatIn .8s ease backwards}
.hv-main{inset-inline-end:0;top:10px;width:min(420px,92%);animation-delay:.1s}
.hv-kpi{inset-inline-start:0;top:200px;width:200px;animation-delay:.35s}
.hv-pay{inset-inline-end:30px;bottom:-20px;width:240px;animation-delay:.55s}
@keyframes floatIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.hv-title{font-size:12px;color:var(--muted);margin-bottom:10px;display:flex;justify-content:space-between}
.hv-num{font-size:21px;font-weight:700;color:var(--primary-deep);font-variant-numeric:tabular-nums}
.hv-bar{display:flex;align-items:flex-end;gap:7px;height:90px;margin-top:10px}
.hv-bar i{flex:1;border-radius:6px 6px 2px 2px;background:linear-gradient(180deg,var(--mint),var(--primary));opacity:.85;animation:grow 1s ease backwards}
@keyframes grow{from{height:0!important}}
.hv-row{display:flex;justify-content:space-between;font-size:12px;padding:7px 0;border-bottom:1px dashed var(--line)}
.hv-row:last-child{border-bottom:none}
.hv-row b{font-variant-numeric:tabular-nums}
.sect{padding:64px 6vw}
.sect-head{text-align:center;max-width:640px;margin:0 auto 44px}
.sect-head .chip{display:inline-block;background:var(--primary-soft);color:var(--primary-deep);font-size:12.5px;font-weight:600;padding:6px 16px;border-radius:99px;margin-bottom:14px}
.sect-head h2{font-size:clamp(24px,3.2vw,34px);font-weight:700;line-height:1.4}
.sect-head p{font-size:14.5px;color:var(--muted);margin-top:10px;line-height:1.8}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.feat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow);transition:.18s}
.feat:hover{transform:translateY(-4px);box-shadow:0 18px 40px -14px rgba(198,40,40,.25);border-color:var(--mint)}
.feat .fi{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:21px;background:var(--tint,var(--primary-soft));margin-bottom:14px}
.feat h3{font-size:15.5px;font-weight:700;margin-bottom:7px}
.feat p{font-size:13px;color:var(--muted);line-height:1.75}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;counter-reset:step}
.step{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;position:relative;box-shadow:var(--shadow)}
.step .sn{position:absolute;top:-16px;inset-inline-end:20px;width:34px;height:34px;border-radius:10px;background:var(--primary-deep);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;box-shadow:0 8px 16px -6px rgba(155,28,28,.5)}
.step h3{font-size:15.5px;font-weight:700;margin-bottom:7px}
.step p{font-size:13px;color:var(--muted);line-height:1.75}
.pricing-toggle{display:flex;justify-content:center;margin-bottom:30px}
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:18px;max-width:1020px;margin:0 auto}
.plan{background:var(--surface);border:1.5px solid var(--line);border-radius:18px;padding:28px;position:relative;box-shadow:var(--shadow);display:flex;flex-direction:column}
.plan.featured{border-color:var(--primary);box-shadow:0 24px 56px -18px rgba(198,40,40,.35)}
.plan .pop{position:absolute;top:-13px;inset-inline-start:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:11.5px;font-weight:700;padding:5px 16px;border-radius:99px;white-space:nowrap}
[dir=rtl] .plan .pop{transform:translateX(50%)}
.plan h3{font-size:17px;font-weight:700}
.plan .pdesc{font-size:12.5px;color:var(--muted);margin:5px 0 18px}
.plan .price{font-size:36px;font-weight:700;color:var(--primary-deep);font-variant-numeric:tabular-nums}
.plan .price small{font-size:13px;color:var(--muted);font-weight:500}
.plan ul{list-style:none;margin:20px 0;flex:1;display:flex;flex-direction:column;gap:9px}
.plan ul li{font-size:13px;color:var(--ink-2);display:flex;gap:9px;align-items:flex-start}
.plan ul li::before{content:'✓';color:var(--primary);font-weight:700;flex-shrink:0}
.faq{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:16px 20px;box-shadow:var(--shadow)}
.faq summary{font-size:14.5px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:'+';font-size:20px;color:var(--primary);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{font-size:13.5px;color:var(--muted);line-height:1.85;margin-top:10px}
.cta-band{
  margin:30px 6vw 70px;border-radius:24px;padding:54px 7vw;text-align:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#6E1212,#C62828 70%,#15947B);box-shadow:var(--shadow-lg);
}
.cta-band::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.07);top:-120px;inset-inline-end:-60px}
.cta-band::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05);bottom:-90px;inset-inline-start:-40px}
.cta-band h2{font-size:clamp(22px,3vw,32px);font-weight:700;margin-bottom:12px;position:relative;z-index:1}
.cta-band p{font-size:14.5px;color:#BFE8D9;margin-bottom:26px;position:relative;z-index:1}
.land-footer{padding:36px 6vw;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:12.5px;color:var(--muted)}

/* ============ Auth pages ============ */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
@media(max-width:880px){.auth-wrap{grid-template-columns:1fr}.auth-side{display:none}}
.auth-side{
  background:linear-gradient(160deg,#6E1212,#9B1C1C 60%,#C62828);color:#fff;padding:7vh 5vw;
  display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
}
.auth-side::after{content:'';position:absolute;width:420px;height:420px;border-radius:50%;background:rgba(255,255,255,.05);bottom:-180px;inset-inline-end:-120px}
.auth-side h2{font-size:clamp(22px,2.6vw,32px);line-height:1.5;font-weight:700;max-width:420px}
.auth-side .pts{display:flex;flex-direction:column;gap:13px;margin-top:30px}
.auth-side .pt{display:flex;gap:11px;font-size:13.5px;color:#CDE7DD;align-items:flex-start}
.auth-side .pt::before{content:'✓';background:rgba(255,255,255,.15);border-radius:50%;width:21px;height:21px;display:grid;place-items:center;font-size:11px;flex-shrink:0}
.auth-main{display:flex;align-items:center;justify-content:center;padding:5vh 5vw}
.auth-card{width:100%;max-width:430px}
.auth-card h1{font-size:23px;font-weight:700;margin-bottom:6px}
.auth-card .sub{font-size:13.5px;color:var(--muted);margin-bottom:26px}
.auth-card .field{margin-bottom:14px}

/* ============ Print ============ */
@media print{
  body{background:#fff!important;background-image:none!important}
  .no-print{display:none!important}
  @page{margin:11mm}
}
.print-page{font-family:var(--font);color:#1A2E2A;font-size:12.5px;max-width:790px;margin:0 auto;background:#fff;padding:20px}
.print-bar{display:flex;gap:10px;justify-content:center;padding:14px;background:var(--surface-2);border-bottom:1px solid var(--line);position:sticky;top:0}
.ip-band{height:7px;border-radius:99px;background:linear-gradient(90deg,#C62828,#E8A6A6 60%,#3E6FD9);margin-bottom:18px}
.ip-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}
.ip-co{display:flex;gap:13px;align-items:center}
.ip-logo{width:58px;height:58px;border-radius:14px;background:#C62828;color:#fff;display:grid;place-items:center;font-size:27px;font-weight:700;flex-shrink:0;overflow:hidden}
.ip-logo img{width:100%;height:100%;object-fit:contain;background:#fff}
.ip-co h2{font-size:18px;margin:0 0 3px}
.ip-co p{margin:0;font-size:10.5px;color:#5C7470;line-height:1.7}
.ip-doc{text-align:end}
.ip-doc h1{font-size:20px;margin:0;color:#9B1C1C}
.ip-doc .n{font-size:13px;font-weight:700;direction:ltr}
.ip-doc p{margin:2px 0;font-size:11px;color:#5C7470}
.ip-parties{display:flex;gap:14px;margin-bottom:16px}
.ip-party{flex:1;border:1px solid #E3ECE9;border-radius:11px;padding:11px 14px}
.ip-party h4{margin:0 0 6px;font-size:10px;color:#C62828;text-transform:uppercase;letter-spacing:.08em}
.ip-party b{font-size:13px}
.ip-party p{margin:2px 0;font-size:10.5px;color:#5C7470}
table.ip-lines{width:100%;border-collapse:collapse;font-size:11.5px;margin-bottom:14px}
table.ip-lines th{background:#9B1C1C;color:#fff;padding:8px 10px;text-align:start;font-size:10px;font-weight:600}
table.ip-lines th.num,table.ip-lines td.num{text-align:end;direction:ltr;font-variant-numeric:tabular-nums}
table.ip-lines td{padding:7px 10px;border-bottom:1px solid #E3ECE9}
table.ip-lines tbody tr:nth-child(even){background:#F7FBF9}
.ip-bottom{display:flex;gap:18px;align-items:flex-start}
.ip-qr{text-align:center;font-size:9.5px;color:#5C7470}
.ip-qr img{border:1px solid #E3ECE9;border-radius:9px;padding:5px;background:#fff}
.ip-notes{flex:1;font-size:10.5px;color:#5C7470;line-height:1.7}
.ip-notes h5{margin:0 0 4px;font-size:10.5px;color:#1A2E2A}
.ip-totals{width:265px;font-size:12px}
.ip-totals .row{display:flex;justify-content:space-between;padding:4.5px 10px}
.ip-totals .row .num{direction:ltr;font-variant-numeric:tabular-nums}
.ip-totals .row.grand{background:#9B1C1C;color:#fff;border-radius:9px;font-weight:700;font-size:14px;padding:9px 12px;margin-top:5px}
.ip-foot{margin-top:26px;padding-top:12px;border-top:1.5px solid #E3ECE9;display:flex;justify-content:space-between;font-size:10px;color:#8AA39C}
.ip-sign{display:flex;gap:40px;margin-top:34px}
.ip-sign div{flex:1;text-align:center;font-size:11px;color:#5C7470}
.ip-sign div span{display:block;border-top:1.5px dashed #D2E0DC;margin-top:36px;padding-top:6px}
.receipt-80{width:75mm;margin:0 auto;font-size:11px;color:#000;background:#fff;padding:6px}
.receipt-80 h3{text-align:center;font-size:14px;margin:4px 0}
.receipt-80 .c{text-align:center;font-size:10px;color:#333}
.receipt-80 hr{border:none;border-top:1px dashed #999;margin:7px 0}
.receipt-80 table{width:100%;border-collapse:collapse;font-size:10.5px}
.receipt-80 td{padding:2.5px 2px;vertical-align:top}
.receipt-80 td.num{text-align:end;direction:ltr;white-space:nowrap}
.receipt-80 .tot{font-size:13px;font-weight:700}

/* Responsive shell */
@media(max-width:1100px){.gsearch input{width:150px}}
@media(max-width:880px){
  /* kill any horizontal page scroll on mobile */
  html,body{overflow-x:hidden;max-width:100%}
  .shell{max-width:100%;overflow-x:hidden}
  .main{max-width:100%;overflow-x:hidden}

  /* off-canvas sidebar via transform (never widens the viewport) */
  .sidebar{
    position:fixed;top:0;inset-inline-start:0;height:100dvh;
    transform:translateX(-100%);transition:transform .25s ease;will-change:transform;
  }
  [dir=rtl] .sidebar{transform:translateX(100%)}
  .sidebar.open{transform:translateX(0)!important;box-shadow:var(--shadow-lg)}

  /* dim backdrop when the menu is open */
  .sidebar.open::after{
    content:'';position:fixed;inset:0;inset-inline-start:var(--sidebar-w);
    background:rgba(110,18,18,.4);z-index:-1;
  }

  .menu-btn{display:block}
  .view{padding:16px 12px 70px;max-width:100%}
  .topbar{padding:10px 12px}
  .uc-info{display:none}
  .gsearch{display:none}

  /* every card/section stays inside the screen */
  .card,.kpi,.feat,.report-card,.alert,.doc-totals{max-width:100%}
  .page-head,.page-actions{max-width:100%}

  /* wide tables scroll inside themselves, not the page */
  .table-wrap{max-width:100%;-webkit-overflow-scrolling:touch}
  table.report{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .chart-wrap svg{min-width:480px}

  /* document editor + totals fit narrow screens */
  .doc-totals{width:100%}
  .doc-lines{display:block;overflow-x:auto;white-space:nowrap}
  .settings-nav{position:static}
  .acc-children{margin-inline-start:12px}

  /* tighten typography a touch */
  .page-title h1{font-size:19px}
  .kpi-value{font-size:21px}
}
@media(max-width:480px){
  .view{padding:14px 10px 64px}
  .kpi-grid{gap:10px}
  .btn{padding:9px 14px}
  .page-actions .btn{flex:1;justify-content:center}
}

/* ---- Landing page (public) on mobile ---- */
@media(max-width:880px){
  .land{overflow-x:hidden}
  .land-nav{gap:8px;padding:12px 16px;flex-wrap:nowrap}
  .land-nav .links{display:none}            /* collapse center menu */
  .land-nav .spacer{flex:1}
  .land-nav .btn{padding:7px 11px;font-size:12px;white-space:nowrap}
  .land-brand b{font-size:17px}

  .hero{padding:30px 18px 36px;gap:26px;text-align:start}
  .hero h1{font-size:clamp(25px,7.5vw,34px)}
  .hero p.lead{font-size:14.5px;margin:14px 0 22px}
  .hero-ctas{gap:10px}
  .hero-ctas .btn{flex:1 1 auto;justify-content:center}
  .hero-stats{gap:20px;margin-top:28px}
  .hero-stats .hs b{font-size:20px}

  /* hero visual: drop the floating decoration, keep one clean card */
  .hero-visual{min-height:auto}
  .hv-card{position:static!important;inset:auto!important;width:auto!important;animation:none}
  .hv-kpi,.hv-pay{display:none}

  .sect{padding:44px 18px}
  .sect-head{margin-bottom:30px}
  .sect-head h2{font-size:clamp(22px,6vw,30px)}
  .steps .step .sn{inset-inline-end:18px}
  .pricing-toggle .seg{flex-wrap:wrap;justify-content:center}

  .cta-band{margin:24px 16px 46px;padding:38px 22px}
  .land-footer{padding:26px 18px;flex-direction:column;gap:8px;text-align:center}
}
@media(max-width:380px){
  .land-nav .lang-toggle{display:none}      /* tightest screens: keep only login + try-free */
}

/* ===== تعديلات مخصّصة: خانات مدوّرة + صورة اللوجن ===== */
.auth-card .field input{border-radius:999px !important;padding-inline:20px}
.auth-card .btn-block{border-radius:999px !important}
.auth-card .checkbox-row{padding-inline:6px}
.auth-photo{display:block;width:112px;height:112px;border-radius:50%;object-fit:cover;margin:0 auto 16px;border:4px solid var(--primary);box-shadow:0 10px 26px -8px rgba(198,40,40,.5)}

/* ===== نوافذ منبثقة (modals) ===== */
[x-cloak]{display:none!important}
.modal-overlay{position:fixed;inset:0;background:rgba(23,51,46,.55);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;backdrop-filter:blur(2px)}
.modal-box{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:460px;padding:24px;max-height:90vh;overflow:auto;animation:viewIn .2s ease}
.modal-box h3{margin-bottom:16px;font-size:18px;color:var(--ink)}
