/* public/assets/css/app.css */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700&display=swap');

:root{
  --primary:#2563EB;
  --secondary:#0F172A;
  --accent:#F59E0B;
  --bg:#F8FAFC;
  --text:#0F172A;
  --muted:#64748B;
  --card:#FFFFFF;
  --border:#E2E8F0;
  --danger:#DC2626;
  --success:#16A34A;
  --warning:#D97706;
  --radius:16px;
  --shadow:0 10px 30px rgba(2,6,23,.08);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Cairo', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  direction:rtl;
}
a{color:inherit;text-decoration:none}
.container{width:min(1100px,92%);margin:0 auto}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.05rem;border-radius:14px;
  border:1px solid var(--border);background:var(--card);
  cursor:pointer;font-weight:700;
  transition:.15s transform,.15s box-shadow,.15s border-color;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:#cbd5e1}
.btn.primary{background:var(--primary);color:#fff;border-color:transparent}
.btn.primary:hover{border-color:transparent}
.btn.danger{background:var(--danger);color:#fff;border-color:transparent}
.btn.ghost{background:transparent}
.input, select, textarea{
  width:100%;padding:.8rem .9rem;border-radius:14px;
  border:1px solid var(--border);background:#fff;outline:none;
}
textarea{min-height:120px;resize:vertical}
.label{font-weight:700;margin:0 0 .35rem;display:block}
.grid{display:grid;gap:16px}
.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:0 1px 0 rgba(2,6,23,.03);
}
.card .card-h{padding:16px 18px;border-bottom:1px solid var(--border)}
.card .card-b{padding:18px}
.badge{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:999px;font-weight:700;font-size:.85rem;border:1px solid var(--border);background:#fff}
.badge.success{border-color:rgba(22,163,74,.25);color:var(--success);background:rgba(22,163,74,.06)}
.badge.warning{border-color:rgba(217,119,6,.25);color:var(--warning);background:rgba(217,119,6,.06)}
.badge.danger{border-color:rgba(220,38,38,.25);color:var(--danger);background:rgba(220,38,38,.06)}
.badge.gray{color:var(--muted);background:#f8fafc}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:12px 12px;border-bottom:1px solid var(--border);text-align:right;vertical-align:top}
.table th{font-size:.9rem;color:var(--muted);font-weight:800;background:#f8fafc}
.table tr:hover td{background:#fbfdff}
.kbd{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;font-size:.85rem;padding:.1rem .35rem;border-radius:8px;border:1px solid var(--border);background:#fff}
.alert{padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;margin:12px 0;font-weight:700}
.alert.success{border-color:rgba(22,163,74,.25);background:rgba(22,163,74,.06)}
.alert.warning{border-color:rgba(217,119,6,.25);background:rgba(217,119,6,.06)}
.alert.danger{border-color:rgba(220,38,38,.25);background:rgba(220,38,38,.06)}
.alert.info{border-color:rgba(37,99,235,.25);background:rgba(37,99,235,.06)}
.small{color:var(--muted);font-size:.92rem}

.badge.info{
  border-color:rgba(37,99,235,.25);
  color:var(--primary);
  background:rgba(37,99,235,.06);
}


/* Public landing */
.hero{
  padding:56px 0;
  background:
    radial-gradient(800px 400px at 15% 20%, rgba(37,99,235,.22), transparent 60%),
    radial-gradient(700px 350px at 85% 10%, rgba(245,158,11,.20), transparent 60%);
}
.hero .wrap{display:grid;gap:22px;align-items:center}
@media(min-width:900px){.hero .wrap{grid-template-columns:1.1fr .9fr}}
.h-title{font-size:clamp(26px,3.6vw,42px);line-height:1.2;margin:0;font-weight:900}
.h-sub{margin:0;color:var(--muted);font-size:1.05rem;line-height:1.8}
.hero-card{padding:18px;border-radius:24px;box-shadow:var(--shadow)}
.feature{display:flex;gap:12px;align-items:flex-start}
.feature i{font-size:1.2rem;color:var(--primary)}
.features{padding:26px 0 60px}
.features .grid{grid-template-columns:repeat(1,minmax(0,1fr))}
@media(min-width:820px){.features .grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
footer{padding:24px 0;color:var(--muted)}

/* Dashboard */
.dash{
  display:grid;min-height:100vh;
  grid-template-columns:280px 1fr;
}
@media(max-width:980px){.dash{grid-template-columns:1fr}}
.sidebar{
  position:sticky;top:0;align-self:start;height:100vh;
  background:linear-gradient(180deg, rgba(15,23,42,.96), rgba(15,23,42,.90));
  color:#fff;padding:18px;border-left:1px solid rgba(255,255,255,.08);
}
@media(max-width:980px){
  .sidebar{position:relative;height:auto;border-left:none;border-bottom:1px solid rgba(255,255,255,.08)}
}
.sb-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.sb-brand img{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.12);padding:6px}
.sb-brand .name{font-weight:900}
.sb-nav a{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;
  color:rgba(255,255,255,.9);margin:6px 0;font-weight:800;
}
.sb-nav a:hover{background:rgba(255,255,255,.08)}
.sb-nav a.active{background:rgba(37,99,235,.35)}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 18px;border-bottom:1px solid var(--border);background:rgba(248,250,252,.9);
  position:sticky;top:0;backdrop-filter:blur(10px);z-index:5;
}
.content{padding:18px}
.kpis{display:grid;gap:16px;grid-template-columns:repeat(1,minmax(0,1fr))}
@media(min-width:900px){.kpis{grid-template-columns:repeat(4,minmax(0,1fr))}}
.kpi{padding:14px 16px}
.kpi .n{font-size:1.65rem;font-weight:900}
.kpi .t{color:var(--muted);font-weight:800}
.form-row{display:grid;gap:14px}
@media(min-width:900px){.form-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
.img-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(min-width:900px){.img-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
.img-card{border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#fff}
.img-card img{width:100%;height:140px;object-fit:cover;display:block}
.img-card .p{padding:10px;display:flex;gap:8px;justify-content:space-between;align-items:center}
