/* =====================================================================
   أليف — Aliif clinical UI  (v2 redesign)
   Teal + coral palette, Cairo type, light/dark themes.
   Covers the new dashboard shell AND every existing page component.
   ===================================================================== */
:root{
  --teal:#0F9E8E; --teal-d:#0B7A6E; --teal-soft:#E6F6F3;
  --coral:#FF6B5A; --coral-soft:#FFEDEA;
  --ink:#15262B; --muted:#6C8781; --faint:#98ACA7;
  --bg:#F3F7F5; --white:#fff; --line:#E4EDEA; --line-2:#EEF3F1;
  --green:#16A34A; --green-s:#E7F6EC; --amber:#E08600; --amber-s:#FDF2E1;
  --red:#E23B3B; --red-s:#FCE9E9; --blue:#2F6FED; --blue-s:#E9F0FE;
  --ai:#7C5CFF; --ai-s:#F0ECFF; --ai-line:#E7E0FF; --ai-grad:#B49BFF;
  --scroll:#CDD9D5; --shadow:rgba(21,38,43,.25); --active-txt:#fff;
  --board-bg:var(--bg); --dash:var(--line);
  --radius:16px; --radius-sm:11px;
}
[data-theme="dark"]{
  --teal:#1EBFAC; --teal-d:#16A896; --teal-soft:rgba(30,191,172,.15);
  --coral:#FF7A6B; --coral-soft:rgba(255,122,107,.15);
  --ink:#E9F1EE; --muted:#93A7A1; --faint:#6E827C;
  --bg:#0D1513; --white:#151F1C; --line:#243330; --line-2:#1C2825;
  --green:#3DD07E; --green-s:rgba(61,208,126,.14); --amber:#F0A93B; --amber-s:rgba(240,169,59,.15);
  --red:#FF6B6B; --red-s:rgba(255,107,107,.14); --blue:#5B93FF; --blue-s:rgba(91,147,255,.14);
  --ai:#9B82FF; --ai-s:rgba(155,130,255,.12); --ai-line:rgba(155,130,255,.28); --ai-grad:#7C5CFF;
  --scroll:#2C3D38; --shadow:rgba(0,0,0,.5); --active-txt:#07110F;
  --board-bg:#101A17; --dash:#2A3934;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Cairo',system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--ink);
  min-height:100vh;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;
  transition:background .3s,color .3s}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--scroll);border-radius:9px}
a{color:var(--teal-d);text-decoration:none}a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .3em;font-weight:800}

/* ===== Auth screen ===== */
.auth-wrap{min-height:100vh;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--teal),var(--teal-d));padding:24px}
.auth-card{background:var(--white);width:100%;max-width:410px;border-radius:20px;padding:38px 34px;
  box-shadow:0 24px 70px rgba(0,0,0,.28)}
.auth-brand{display:flex;align-items:center;gap:11px;margin-bottom:4px}
.auth-brand .logo{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--teal),var(--teal-d));
  display:grid;place-items:center;box-shadow:0 6px 16px -6px rgba(15,158,142,.6)}
.auth-brand .logo svg{width:26px;height:26px;stroke:#fff}
.auth-card h1{font-size:1.5rem;font-weight:900;margin:0}
.auth-card .sub{color:var(--muted);font-size:.9rem;margin-bottom:26px;font-weight:600}

/* ===== App shell ===== */
.app{display:grid;grid-template-columns:256px 1fr;min-height:100vh}
.side{background:var(--white);border-inline-start:1px solid var(--line);display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;transition:background .3s,border-color .3s}
.side .head{padding:20px 18px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--line-2)}
.side .head .logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--teal),var(--teal-d));
  display:grid;place-items:center;flex-shrink:0;box-shadow:0 6px 14px -6px rgba(15,158,142,.6)}
.side .head .logo svg{width:24px;height:24px;stroke:#fff}
.side .head b{font-size:19px;font-weight:900;display:block;line-height:1.1}
.side .head span{display:block;font-size:11px;color:var(--muted);font-weight:600}
.side nav{padding:12px 12px 24px}
.grp{font-size:10.5px;font-weight:800;color:var(--faint);letter-spacing:.4px;padding:16px 10px 7px}
.side a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);
  font-weight:700;font-size:13.5px;transition:.16s;margin-bottom:2px}
.side a:hover{background:var(--teal-soft);color:var(--teal-d);text-decoration:none}
.side a.active{background:var(--teal);color:var(--active-txt)}
.side a.active svg{stroke:var(--active-txt)}
.side a svg{width:19px;height:19px;stroke:var(--muted);flex:none;fill:none;stroke-width:1.9}
.side a:hover svg{stroke:var(--teal-d)}
.side a .num{margin-inline-start:auto;font-size:11px;font-weight:800;background:var(--line);color:var(--muted);
  padding:2px 8px;border-radius:99px}
.side a.active .num{background:rgba(255,255,255,.22);color:var(--active-txt)}
.side a.ai-link{color:var(--ai)} .side a.ai-link svg{stroke:var(--ai)} .side a.ai-link:hover{background:var(--ai-s)}

.main{display:flex;flex-direction:column;min-height:100vh;min-width:0}
.topbar{background:var(--white);border-bottom:1px solid var(--line);padding:12px 26px;display:flex;
  align-items:center;gap:14px;position:sticky;top:0;z-index:20;transition:background .3s,border-color .3s}
.gsearch{flex:1;max-width:420px;background:var(--bg);border:1px solid var(--line);border-radius:11px;
  padding:9px 14px;display:flex;align-items:center;gap:9px}
.gsearch svg{width:16px;height:16px;stroke:var(--faint);fill:none;stroke-width:2}
.gsearch input{border:0;outline:0;background:transparent;font-family:inherit;font-weight:600;width:100%;
  font-size:13.5px;color:var(--ink)}
.gsearch input::placeholder{color:var(--faint)}
.tspace{margin-inline-start:auto}
.lang{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;font-weight:800;font-size:12.5px}
.lang b{padding:8px 12px;cursor:pointer;color:var(--muted)}
.lang b.on{background:var(--ink);color:var(--white)}
.tbtn{width:42px;height:42px;border:1px solid var(--line);border-radius:11px;display:grid;place-items:center;
  cursor:pointer;position:relative;background:var(--white);color:var(--ink);font-size:17px}
.tbtn:hover{border-color:var(--teal);background:var(--teal-soft)}
.tbtn .badge{position:absolute;top:-5px;inset-inline-end:-5px;min-width:19px;height:19px;padding:0 5px;
  background:var(--coral);color:#fff;border-radius:99px;font-size:10.5px;font-weight:800;display:grid;
  place-items:center;border:2px solid var(--white)}
.uchip{display:flex;align-items:center;gap:9px;padding:5px 12px 5px 6px;border:1px solid var(--line);border-radius:11px;cursor:pointer}
.uchip .av{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--teal),var(--teal-d));
  display:grid;place-items:center;color:#fff;font-size:14px;font-weight:800}
.uchip b{font-size:13px}.uchip span{font-size:11px;color:var(--muted);display:block}

.content{padding:22px 26px 34px;flex:1}

/* ===== Page title ===== */
.pagettl,.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.pagettl h1,.page-head h1{font-size:22px;font-weight:900}
.pagettl p{color:var(--muted);font-weight:600;font-size:13.5px;margin-top:2px}
.acts{display:flex;gap:9px}

/* ===== Buttons (support .btn.primary and .btn-primary) ===== */
.btn{border:1px solid transparent;padding:10px 16px;border-radius:11px;font-family:inherit;font-weight:800;
  font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:.16s;text-decoration:none}
.btn:hover{text-decoration:none}
.btn.primary,.btn-primary{background:var(--teal);color:var(--active-txt)}
.btn.primary:hover,.btn-primary:hover{background:var(--teal-d);color:var(--active-txt)}
.btn.ghost,.btn-ghost{background:var(--white);color:var(--ink);border-color:var(--line)}
.btn.ghost:hover,.btn-ghost:hover{border-color:var(--teal);color:var(--teal-d)}
.btn-accent{background:var(--coral);color:#fff}
.btn-danger{background:transparent;border-color:var(--red);color:var(--red)}
.btn-danger:hover{background:var(--red-s)}
.btn-sm{padding:6px 11px;font-size:12px;border-radius:9px}
.btn svg{width:16px;height:16px}

/* ===== KPI cards ===== */
.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:13px;margin-bottom:22px}
.kpi{background:var(--white);border:1px solid var(--line);border-radius:15px;padding:15px;transition:.18s}
.kpi:hover{transform:translateY(-2px);box-shadow:0 10px 22px -14px var(--shadow)}
.kpi .em{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:19px;margin-bottom:10px}
.kpi .num{font-size:24px;font-weight:900;line-height:1;font-variant-numeric:tabular-nums}
.kpi .lbl{color:var(--muted);font-weight:700;font-size:12px;margin-top:5px}
.kpi .sub{font-size:11px;font-weight:800;margin-top:6px;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:7px}

/* ===== Split + cards ===== */
.split{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}
.card{background:var(--white);border:1px solid var(--line);border-radius:16px;margin-bottom:20px;
  transition:background .3s,border-color .3s;overflow:hidden}
.card .ch,.card-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;
  border-bottom:1px solid var(--line-2)}
.card .ch h3,.card-head{font-size:15px;font-weight:900;display:flex;align-items:center;gap:8px}
.card .ch .link{font-size:12.5px;color:var(--teal);font-weight:800}
.card .cb,.card-body{padding:16px 18px}

/* ===== Reception board (signature) ===== */
.board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.lane{background:var(--board-bg);border:1px solid var(--line-2);border-radius:13px;padding:12px}
.lane .lh{display:flex;align-items:center;gap:8px;font-weight:800;font-size:12.5px;margin-bottom:11px;padding:0 2px}
.lane .lh .cd{margin-inline-start:auto;background:var(--white);border:1px solid var(--line);border-radius:99px;padding:1px 8px;font-size:11px}
.lane .lh .dt{width:8px;height:8px;border-radius:50%}
.lane.wait .dt{background:var(--amber)}.lane.exam .dt{background:var(--teal)}.lane.done .dt{background:var(--green)}
.qcard{background:var(--white);border:1px solid var(--line);border-radius:11px;padding:11px;margin-bottom:9px;transition:.16s;position:relative}
.qcard:hover{border-color:var(--teal);box-shadow:0 6px 14px -10px rgba(15,158,142,.5)}
.qcard:last-child{margin-bottom:0}
.qcard .r1{display:flex;align-items:center;gap:9px}
.qcard .pf{width:36px;height:36px;border-radius:9px;background:var(--teal-soft);display:grid;place-items:center;font-size:19px;flex-shrink:0}
.qcard .nm{font-weight:800;font-size:13.5px;line-height:1.2}
.qcard .ow{font-size:11px;color:var(--muted);font-weight:600}
.qcard .tm{margin-inline-start:auto;font-size:11px;color:var(--faint);font-weight:700;text-align:start}
.qcard .r2{display:flex;align-items:center;gap:6px;margin-top:9px;padding-top:9px;border-top:1px dashed var(--dash);flex-wrap:wrap}
.tagx{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:7px}
.tagx.doc{background:var(--blue-s);color:var(--blue)}
.tagx.new{background:var(--coral-soft);color:var(--coral)}
.tagx.wait{background:var(--amber-s);color:var(--amber)}
.qcard.live{border-color:var(--teal)}
.qcard.live::before{content:"";position:absolute;top:11px;inset-inline-end:11px;width:8px;height:8px;border-radius:50%;background:var(--teal);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(15,158,142,.5)}70%{box-shadow:0 0 0 7px rgba(15,158,142,0)}100%{box-shadow:0 0 0 0 rgba(15,158,142,0)}}

/* ===== Schedule / mini rows ===== */
.trow{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.trow:last-child{border:0;padding-bottom:0}
.trow .time{width:58px;text-align:center;font-weight:800;font-size:13px;color:var(--teal-d);font-variant-numeric:tabular-nums}
.trow .pf{width:36px;height:36px;border-radius:9px;background:var(--teal-soft);display:grid;place-items:center;font-size:18px}
.trow .info{flex:1;min-width:0}.trow .info b{font-size:13.5px;font-weight:800}
.trow .info span{font-size:11.5px;color:var(--muted);font-weight:600;display:block}
.mrow{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.mrow:last-child{border:0;padding-bottom:0}
.mrow .mi{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:17px;flex-shrink:0}
.mrow .mt{flex:1;min-width:0}.mrow .mt b{font-size:13px;font-weight:800}
.mrow .mt span{font-size:11.5px;color:var(--muted);font-weight:600;display:block}
.wa{border:0;background:#25D366;color:#fff;font-family:inherit;font-weight:800;font-size:11.5px;padding:6px 11px;
  border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;text-decoration:none}
.wa:hover{filter:brightness(.95);text-decoration:none}

/* ===== AI panel ===== */
.ai{border:1px solid var(--ai-line);border-radius:16px;background:linear-gradient(180deg,var(--ai-s),var(--white));margin-bottom:20px;overflow:hidden}
.ai .ah{padding:15px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--ai-line)}
.ai .ah .sp{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--ai),var(--ai-grad));display:grid;place-items:center;font-size:18px}
.ai .ah b{font-size:14.5px;font-weight:900}.ai .ah span{font-size:11px;color:var(--ai);font-weight:700;display:block}
.ai .ab{padding:14px 18px}
.aitip{background:var(--white);border:1px solid var(--ai-line);border-radius:11px;padding:12px;font-size:12.5px;font-weight:600;color:var(--muted);line-height:1.7;margin-bottom:11px}
.aitip b{color:var(--ink)}
.aiacts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.aibtn{background:var(--white);border:1px solid var(--ai-line);color:var(--ai);border-radius:10px;padding:9px;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:.16s}
.aibtn:hover{background:var(--ai);color:#fff}

/* ===== Mini spark chart ===== */
.spark{display:flex;align-items:flex-end;gap:7px;height:96px;padding-top:6px}
.spark .c{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.spark .c i{width:100%;max-width:22px;border-radius:6px 6px 3px 3px;background:linear-gradient(180deg,var(--teal),#5FC8BB);animation:gw .8s ease backwards;min-height:3px}
.spark .c.hot i{background:linear-gradient(180deg,var(--coral),#FF9A8D)}
@keyframes gw{from{height:0!important}}
.spark .c span{font-size:10.5px;color:var(--muted);font-weight:700}
.legendrow{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:12.5px;font-weight:700}
.legendrow:last-child{border:0}.legendrow .l{display:flex;align-items:center;gap:8px}
.legendrow .d{width:9px;height:9px;border-radius:3px}.legendrow b{font-variant-numeric:tabular-nums}

/* ===== Pills (design + legacy names) ===== */
.pill{font-size:11px;font-weight:800;padding:4px 10px;border-radius:8px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.pill.g,.pill-ok{background:var(--green-s);color:var(--green)}
.pill.a,.pill-warn{background:var(--amber-s);color:var(--amber)}
.pill.b{background:var(--blue-s);color:var(--blue)}
.pill.r,.pill-danger{background:var(--red-s);color:var(--red)}
.pill-muted{background:var(--line);color:var(--muted)}

/* ===== Tables ===== */
table{width:100%;border-collapse:collapse}
thead th{text-align:start;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);
  font-weight:800;padding:12px 16px;border-bottom:1px solid var(--line-2);background:var(--board-bg)}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line-2);font-size:13px;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--teal-soft)}
.t-empty{padding:34px;text-align:center;color:var(--muted);font-weight:600}
tfoot td{padding:12px 16px}

/* ===== Forms ===== */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid .full{grid-column:1/-1}
.field label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:6px;font-weight:700}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);
  border-radius:10px;font-family:inherit;font-size:13.5px;background:var(--white);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.field textarea{resize:vertical;min-height:88px}
.field .err{color:var(--red);font-size:11.5px;margin-top:5px;font-weight:600}
.field.invalid input,.field.invalid select{border-color:var(--red)}
.form-actions{display:flex;gap:10px;margin-top:22px}
.checkbox{display:flex;align-items:center;gap:9px}.checkbox input{width:auto}

/* ===== Detail / misc content ===== */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--white);border:1px solid var(--line);border-radius:15px;padding:16px 18px}
.stat .label{color:var(--muted);font-size:12px;margin-bottom:6px;font-weight:700}
.stat .value{font-size:1.6rem;font-weight:900}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kv{padding:12px 14px;background:var(--board-bg);border:1px solid var(--line);border-radius:11px}
.kv .k{font-size:11.5px;color:var(--muted);margin-bottom:3px;font-weight:700}.kv .v{font-weight:800}
.section-title{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:26px 0 12px;font-weight:800}
.soap{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.soap .box{border:1px solid var(--line);border-radius:11px;padding:14px}
.soap .box h4{margin:0 0 6px;font-size:11px;color:var(--coral);text-transform:uppercase;letter-spacing:.04em}
.totals{margin-inline-start:auto;width:280px}
.totals .row{display:flex;justify-content:space-between;padding:7px 0;font-size:13.5px}
.totals .row.grand{border-top:2px solid var(--ink);margin-top:6px;padding-top:12px;font-size:1.1rem;font-weight:900}
.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.search-box{display:flex;gap:8px}
.search-box input{padding:9px 12px;border:1px solid var(--line);border-radius:10px;min-width:220px;font-family:inherit;background:var(--white);color:var(--ink)}
.lang-toggle{border:1px solid var(--line);border-radius:20px;padding:6px 13px;font-size:12.5px;color:var(--muted);font-weight:700}

/* ===== Flash ===== */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:18px;font-size:13px;font-weight:700}
.flash-ok{background:var(--green-s);color:var(--green);border:1px solid rgba(22,163,74,.25)}
.flash-err{background:var(--red-s);color:var(--red);border:1px solid rgba(226,59,59,.25)}

/* ===== Responsive ===== */
@media(max-width:1180px){.kpis{grid-template-columns:repeat(3,1fr)}.split{grid-template-columns:1fr}.board{grid-template-columns:1fr}}
@media(max-width:860px){
  .app{grid-template-columns:1fr}.side{display:none}.gsearch{display:none}
  .kpis{grid-template-columns:1fr 1fr}.form-grid,.soap,.detail-grid{grid-template-columns:1fr}
  .content{padding:16px}
}
:focus-visible{outline:2px solid var(--coral);outline-offset:2px}
