:root{
  --ink:#1c2336;--ink-2:#404a63;--paper:#f6f1e7;--paper-2:#fbf8f1;--card:#fff;
  --brass:#a87b35;--brass-dark:#8a6326;--line:#e4dccb;--green:#3f7d5b;--green-bg:#e7f0ea;
  --red:#9e3b3b;--red-bg:#f5e6e3;--amber:#b07a1f;--amber-bg:#f6ecd6;--muted:#7b7466;
  --shadow:0 1px 2px rgba(28,35,54,.04),0 8px 24px rgba(28,35,54,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'IBM Plex Sans Arabic',sans-serif;background:
  radial-gradient(1200px 500px at 100% -10%,rgba(168,123,53,.07),transparent 60%),
  radial-gradient(900px 500px at -10% 0%,rgba(28,35,54,.05),transparent 55%),var(--paper);
  color:var(--ink);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
.wrap{max-width:1120px;margin:0 auto;padding:0 20px 80px}

/* Header */
header{padding:30px 0 20px;border-bottom:1px solid var(--line);margin-bottom:24px;display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:16px}
.seal{width:54px;height:54px;border-radius:12px;flex:none;background:linear-gradient(145deg,var(--ink),#2c3650);display:grid;place-items:center;color:var(--brass);box-shadow:inset 0 0 0 1px rgba(168,123,53,.5),var(--shadow);font-family:'Amiri',serif;font-size:30px;font-weight:700}
.brand-logo{width:68px;height:68px;border-radius:14px;object-fit:contain;flex:none;background:#fff;padding:6px;box-shadow:inset 0 0 0 1px rgba(168,123,53,.3),var(--shadow)}
.login-logo{width:120px;height:120px;border-radius:18px;object-fit:contain;background:#fff;padding:10px;margin:0 auto 18px;display:block;box-shadow:inset 0 0 0 1px rgba(168,123,53,.3),var(--shadow)}
.brand h1{font-family:'Amiri',serif;font-size:28px;font-weight:700}
.brand p{color:var(--muted);font-size:13px;margin-top:2px}
.head-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.user-chip{font-size:13px;color:var(--muted)}.user-chip b{color:var(--ink)}
.add-btn{background:linear-gradient(180deg,var(--brass),var(--brass-dark));color:#fff;border:none;border-radius:11px;padding:13px 22px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 14px rgba(168,123,53,.32);transition:.15s;display:flex;align-items:center;gap:8px}
.add-btn:hover{transform:translateY(-1px)}
.link-btn{background:none;border:none;color:var(--muted);font-family:inherit;font-size:13px;cursor:pointer;text-decoration:underline}
.link-btn:hover{color:var(--red)}

/* Tabs */
.tabs{display:flex;gap:6px;margin-bottom:24px;flex-wrap:wrap}
.tab{background:transparent;border:none;border-radius:10px;padding:9px 18px;font-family:inherit;font-size:14.5px;font-weight:500;color:var(--muted);cursor:pointer;transition:.18s}
.tab:hover{color:var(--ink);background:rgba(28,35,54,.04)}
.tab.active{background:var(--ink);color:var(--paper-2);box-shadow:var(--shadow)}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--brass)}
.stat.green::before{background:var(--green)}.stat.red::before{background:var(--red)}.stat.amber::before{background:var(--amber)}
.stat .lbl{font-size:13px;color:var(--muted);font-weight:500}
.stat .val{font-family:'Amiri',serif;font-size:30px;font-weight:700;margin-top:6px;line-height:1}
.stat .val .cur{font-family:'IBM Plex Sans Arabic';font-size:15px;font-weight:600;color:var(--muted);margin-inline-start:4px}
.stat .sub{font-size:12px;color:var(--muted);margin-top:7px}

.sec-head{display:flex;align-items:center;justify-content:space-between;margin:24px 0 14px;gap:12px;flex-wrap:wrap}
.sec-head h2{font-family:'Amiri',serif;font-size:21px;font-weight:700}
.sec-head .count{font-size:13px;color:var(--muted)}

.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.row{display:grid;grid-template-columns:1.4fr 1fr .8fr .9fr auto;gap:14px;align-items:center;padding:15px 20px;border-bottom:1px solid var(--line);transition:background .15s}
.row:last-child{border-bottom:none}.row:hover{background:#faf7f0}
.row .who{font-weight:600;font-size:15px}
.row .who small{display:block;font-weight:400;color:var(--muted);font-size:12.5px;margin-top:1px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:4px 11px;border-radius:20px;white-space:nowrap;background:var(--paper);color:var(--ink-2);border:1px solid var(--line)}
.pay{font-size:12.5px;font-weight:600;padding:4px 11px;border-radius:20px;white-space:nowrap;display:inline-block}
.pay.paid{background:var(--green-bg);color:var(--green)}.pay.unpaid{background:var(--red-bg);color:var(--red)}.pay.partial{background:var(--amber-bg);color:var(--amber)}
.amt{font-family:'Amiri',serif;font-weight:700;font-size:17px}
.amt small{font-family:'IBM Plex Sans Arabic';font-size:11px;color:var(--muted);font-weight:500}
.acts{display:flex;gap:6px;justify-content:flex-end}
.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;color:var(--muted);font-size:14px;display:grid;place-items:center;transition:.15s;text-decoration:none}
.icon-btn:hover{color:var(--ink);border-color:var(--brass)}
.icon-btn.del:hover{color:var(--red);border-color:var(--red)}
.due{font-size:12.5px;color:var(--muted)}.due b{color:var(--ink);font-weight:600}
.due.soon b{color:var(--red)}.due.today b{color:var(--amber)}

.filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.filters input,.filters select{font-family:inherit;font-size:14px;padding:9px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.filters input{flex:1;min-width:180px}
.filters input:focus,.filters select:focus{outline:none;border-color:var(--brass)}

.empty{text-align:center;padding:56px 20px;color:var(--muted)}
.empty .big{font-family:'Amiri',serif;font-size:22px;color:var(--ink-2);margin-bottom:6px}

.task{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:15px 20px;border-bottom:1px solid var(--line)}
.task:last-child{border-bottom:none}
.task .cal{width:48px;height:54px;border-radius:10px;border:1px solid var(--line);overflow:hidden;text-align:center;flex:none}
.task .cal .m{background:var(--ink);color:var(--paper-2);font-size:11px;padding:3px 0;font-weight:600}
.task .cal .d{font-family:'Amiri',serif;font-size:22px;font-weight:700;padding:4px 0}
.task .tt{font-weight:600}.task .tt small{display:block;color:var(--muted);font-weight:400;font-size:13px;margin-top:1px}
.check{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line);background:#fff;cursor:pointer;color:transparent;display:grid;place-items:center;transition:.15s;font-size:15px}
.check:hover{border-color:var(--green);color:var(--green)}

/* Modal */
.overlay{position:fixed;inset:0;background:rgba(28,35,54,.45);backdrop-filter:blur(3px);display:none;z-index:50;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.overlay.show{display:flex}
.modal{background:var(--paper-2);width:100%;max-width:560px;border-radius:20px;box-shadow:0 30px 80px rgba(28,35,54,.35);border:1px solid var(--line);animation:pop .22s ease}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{padding:22px 26px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-head h3{font-family:'Amiri',serif;font-size:22px;font-weight:700}
.modal-body{padding:22px 26px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:14.5px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.field textarea{resize:vertical;min-height:64px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(168,123,53,.12)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:12px;color:var(--muted);margin-top:5px}
.modal-foot{padding:16px 26px 24px;display:flex;gap:10px}
.btn-primary{background:linear-gradient(180deg,var(--brass),var(--brass-dark));color:#fff;border:none;border-radius:10px;padding:12px 26px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink-2);border-radius:10px;padding:12px 22px;font-family:inherit;font-size:15px;font-weight:500;cursor:pointer}
.btn-ghost:hover{background:#fff}
.dashed-sep{border-top:1px dashed var(--line);padding-top:16px;margin-top:4px}

.toast{position:fixed;bottom:24px;right:24px;background:var(--ink);color:var(--paper-2);padding:13px 20px;border-radius:12px;font-size:14px;box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;transform:translateY(10px);transition:.25s;z-index:60;pointer-events:none}
.toast.show{opacity:1;transform:none}

/* ===== التقويم العدلي (الجلسات) ===== */
.sub-head{color:var(--muted);font-size:14px;font-weight:600;margin:6px 2px 16px;padding-inline-start:12px;border-inline-start:3px solid var(--green)}
.cal-toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:13.5px;color:var(--ink-2);user-select:none}
.cal-toggle input{display:none}
.cal-slider{width:44px;height:24px;border-radius:20px;background:#cfc7b6;position:relative;transition:.2s;flex:none}
.cal-slider::before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;right:3px;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.cal-toggle input:checked + .cal-slider{background:var(--green)}
.cal-toggle input:checked + .cal-slider::before{transform:translateX(-20px)}
.s-card{display:flex;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px;margin-bottom:14px;align-items:flex-start}
.s-badge{flex:none;width:88px;border:1px solid var(--line);border-radius:14px;text-align:center;padding:12px 6px 10px;background:var(--paper-2);position:relative}
.s-badge::before{content:"";position:absolute;top:-1px;left:24px;right:24px;height:4px;background:var(--green);border-radius:0 0 5px 5px}
.s-badge .d{font-family:'Amiri',serif;font-size:32px;font-weight:700;line-height:1;color:var(--ink)}
.s-badge .mn{font-size:13px;color:var(--ink);margin-top:5px;font-weight:600}
.s-badge .yr{font-size:12px;color:var(--muted);margin-top:3px}
.s-body{flex:1;text-align:right;min-width:0}
.s-case{font-weight:700;font-size:15.5px;color:var(--ink)}
.s-type{color:var(--muted);font-size:14px;margin:5px 0 8px}
.s-meta{font-size:13.5px;color:var(--ink-2);margin-top:3px;display:flex;gap:7px;align-items:center;justify-content:flex-end;direction:rtl}
.s-parties{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.7}
.s-parties span{color:var(--brass);font-weight:700;margin:0 4px}
.s-btn{display:block;text-align:center;margin-top:14px;background:var(--green);color:#fff;text-decoration:none;padding:12px;border-radius:12px;font-weight:600;font-size:14.5px;transition:.15s}
.s-btn:hover{background:#356b4d}
@media(max-width:760px){.s-badge{width:72px}.s-badge .d{font-size:26px}}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:42px 40px;width:100%;max-width:400px;text-align:center}
.login-card .seal{margin:0 auto 18px}
.login-card h1{font-family:'Amiri',serif;font-size:26px;margin-bottom:4px}
.login-card p{color:var(--muted);font-size:14px;margin-bottom:26px}
.login-card .field{text-align:right}
.login-card .btn-primary{width:100%;margin-top:6px}
.login-err{color:var(--red);font-size:13.5px;margin-top:14px;min-height:18px}

@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}.row{grid-template-columns:1fr auto;row-gap:8px}.row .col-type,.row .col-pay{grid-column:1}.row .acts{grid-column:2;grid-row:1}.grid2{grid-template-columns:1fr}.brand h1{font-size:20px}.brand-logo{width:54px;height:54px}.login-logo{width:100px;height:100px}}
