:root{
  --bg:#071A16;
  --panel:#10231F;
  --panel2:#0B1D19;
  --text:#F3F4F6;
  --muted:#A7B3AF;
  --green:#22c55e;
  --green2:#86efac;
  --border:rgba(255,255,255,.08);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Tajawal',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.8;
}
.dashboard-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:280px 1fr;
}
.sidebar{
  position:sticky;
  top:0;
  height:100vh;
  background:rgba(16,35,31,.92);
  border-left:1px solid var(--border);
  padding:22px;
  overflow:auto;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:24px;
  color:var(--text);
  text-decoration:none;
}
.brand img{width:42px;height:42px;object-fit:contain}
.brand strong{font-size:20px}
.nav-section-title{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  margin:18px 0 8px;
}
.nav-link{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--text);
  text-decoration:none;
  padding:11px 12px;
  border-radius:14px;
  margin-bottom:6px;
  border:1px solid transparent;
}
.nav-link:hover{
  background:rgba(34,197,94,.08);
  border-color:rgba(34,197,94,.15);
  color:var(--green2);
}
.content{
  padding:28px;
  max-width:1280px;
  width:100%;
}
.topbar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:26px;
}
.eyebrow{
  display:inline-flex;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(34,197,94,.10);
  border:1px solid rgba(34,197,94,.18);
  color:var(--green2);
  font-size:12px;
  font-weight:900;
}
h1{font-size:clamp(30px,4vw,48px);line-height:1.2;margin:12px 0 8px}
.lead{color:var(--muted);max-width:760px}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
  margin-top:20px;
}
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:24px;
  padding:20px;
  min-height:150px;
}
.card h3{margin:10px 0 6px;font-size:20px}
.card p{color:var(--muted);margin:0}
.card a{
  color:var(--green2);
  font-weight:900;
  text-decoration:none;
  display:inline-block;
  margin-top:14px;
}
.icon{
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(34,197,94,.10);
  border:1px solid rgba(34,197,94,.18);
  border-radius:16px;
  font-size:22px;
}
.notice{
  margin-top:22px;
  background:var(--panel2);
  border:1px dashed var(--border);
  border-radius:22px;
  padding:18px;
  color:var(--muted);
}
@media(max-width:900px){
  .dashboard-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto}
  .content{padding:20px}
  .topbar{flex-direction:column}
}


/* UX refactor: optional dashboard without a long vertical sidebar */
.dashboard-shell-no-sidebar{display:block;min-height:100vh;}
.dashboard-shell-no-sidebar .content{max-width:1180px;margin:0 auto;padding:24px;}
.dashboard-shell-no-sidebar .topbar{position:sticky;top:0;z-index:20;align-items:center;background:rgba(7,26,22,.86);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:0 0 24px 24px;padding:16px 18px;margin:-24px -8px 26px;}
.dashboard-shell-no-sidebar .top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.dashboard-shell-no-sidebar .top-link{display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text);text-decoration:none;font-weight:900;font-size:13px;}
.dashboard-shell-no-sidebar .dashboard-groups{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:24px;}
.dashboard-shell-no-sidebar .dashboard-group{grid-column:span 6;background:linear-gradient(135deg,rgba(16,35,31,.96),rgba(11,29,25,.96));border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 46px rgba(0,0,0,.14);}
.dashboard-shell-no-sidebar .dashboard-group:first-child{grid-column:span 12;}
.dashboard-shell-no-sidebar .group-card{justify-content:space-between;background:rgba(255,255,255,.035);}
.dashboard-shell-no-sidebar .group-card:hover{transform:translateY(-2px);}
@media(max-width:900px){.dashboard-shell-no-sidebar .content{padding:18px}.dashboard-shell-no-sidebar .topbar{position:sticky;margin:-18px -6px 20px;align-items:flex-start}.dashboard-shell-no-sidebar .dashboard-groups{grid-template-columns:1fr}.dashboard-shell-no-sidebar .dashboard-group,.dashboard-shell-no-sidebar .dashboard-group:first-child{grid-column:auto}.dashboard-shell-no-sidebar .top-actions{width:100%;justify-content:flex-start}}

/* ══ Parent Dashboard — Modern Bento Layout ══ */
:root{--nav-h:58px}
.topnav{position:fixed;top:0;right:0;left:0;z-index:100;height:var(--nav-h);background:rgba(255,255,255,.95);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--border);transition:background .18s}
body.dark .topnav{background:rgba(24,24,21,.95)}
.tn-pill{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;background:var(--gray-50);border:1px solid var(--border);color:var(--text-muted);transition:all .18s;text-decoration:none;cursor:pointer}
.tn-pill:hover{background:var(--green-l);border-color:var(--green);color:var(--green)}
.tn-user-chip{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:99px;border:1px solid var(--border);background:var(--white);cursor:pointer;transition:all .18s}
.tn-user-chip:hover{border-color:var(--green)}
.tn-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--green),#1D9E75);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
.tn-uname{font-size:12.5px;font-weight:700;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tn-logout-btn{font-size:11.5px;color:var(--text-muted);padding:4px 10px;border-radius:8px;background:var(--gray-50);border:1px solid var(--border);transition:all .18s;cursor:pointer;font-family:Tajawal,sans-serif}
.tn-logout-btn:hover{background:var(--coral-l,#FAE9E4);border-color:var(--coral);color:var(--coral)}

/* Welcome */
.pd-welcome{background:linear-gradient(135deg,var(--green-d,#064A38) 0%,var(--green) 70%,#1D9E75 100%);color:#fff;border-radius:20px;padding:22px 24px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:relative;overflow:hidden}
.pd-welcome::before{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06);top:-80px;left:-50px}
body.dark .pd-welcome{background:linear-gradient(135deg,#040E0B 0%,#0A2E22 100%);border:1px solid rgba(34,199,122,.15)}
.pd-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.18);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;margin-bottom:8px}
.pd-title{font-size:clamp(17px,3vw,22px);font-weight:900;margin-bottom:3px}
.pd-sub{font-size:13px;opacity:.85}
.pd-wb-stats{display:flex;gap:20px;flex-shrink:0;align-items:center}
.pd-wb-stat{text-align:center}
.pd-wb-num{font-size:24px;font-weight:900;line-height:1}
.pd-wb-label{font-size:10.5px;opacity:.7;margin-top:2px}
.pd-wb-div{width:1px;height:36px;background:rgba(255,255,255,.2)}

/* Children strip */
.pd-children-strip{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.pd-children-strip::-webkit-scrollbar{display:none}
.pd-child-pill{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:99px;border:1.5px solid var(--border);background:var(--white);cursor:pointer;transition:all .18s;white-space:nowrap;flex-shrink:0;font-family:Tajawal,sans-serif}
.pd-child-pill:hover,.pd-child-pill.active{border-color:var(--green);background:var(--green-xl,#F2FAF6);box-shadow:0 2px 8px rgba(15,123,95,.12)}
.pd-child-av{width:32px;height:32px;border-radius:50%;background:var(--green-l);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.pd-child-name{font-size:13px;font-weight:700;color:var(--text-primary);text-align:right}
.pd-child-grade{font-size:11px;color:var(--text-muted);text-align:right}
.pd-add-pill{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:99px;border:2px dashed var(--border);background:transparent;cursor:pointer;transition:all .18s;white-space:nowrap;flex-shrink:0;font-size:13px;color:var(--text-muted);font-family:Tajawal,sans-serif}
.pd-add-pill:hover{border-color:var(--green);color:var(--green)}

/* Bento */
.pd-bento{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;margin-bottom:24px}
.pd-bc{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.05);transition:box-shadow .18s,transform .18s}
.pd-bc:hover{box-shadow:0 4px 14px rgba(0,0,0,.09);transform:translateY(-1px)}
.pd-bc-8{grid-column:span 8}
.pd-bc-6{grid-column:span 6}
.pd-bc-4{grid-column:span 4}
.pd-bc-full{grid-column:1/-1}
.pd-bc-label{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}

/* KPIs */
.pd-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pd-kpi{background:var(--gray-50);border-radius:12px;padding:14px;text-align:center;border:1px solid var(--border-2,rgba(0,0,0,.04));transition:background .18s}
.pd-kpi:hover{background:var(--green-xl,#F2FAF6)}
.pd-kpi-icon{font-size:22px;margin-bottom:5px}
.pd-kpi-num{font-size:26px;font-weight:900;color:var(--green);line-height:1;letter-spacing:-.5px}
.pd-kpi-lbl{font-size:11px;color:var(--text-muted);margin-top:3px;font-weight:600}

/* Quick actions */
.pd-qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pd-qa{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:12px;border:1.5px solid var(--border);background:var(--white);cursor:pointer;transition:all .18s;text-decoration:none;font-family:Tajawal,sans-serif}
.pd-qa:hover{border-color:var(--green);background:var(--green-xl,#F2FAF6);transform:translateY(-2px);box-shadow:0 2px 8px rgba(15,123,95,.12)}
.pd-qa span:first-child{font-size:22px}
.pd-qa span:last-child{font-size:12px;font-weight:700;color:var(--text-primary);text-align:center;line-height:1.3}

/* Progress */
.pd-progress-wrap{display:flex;align-items:center;gap:20px;margin-top:12px}
.pd-arc-pct{font-size:26px;font-weight:900;color:var(--green);line-height:1;letter-spacing:-.5px}

/* Games */
.pd-game-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--gray-50);border:1px solid rgba(0,0,0,.04);margin-bottom:6px;transition:background .18s}
.pd-game-row:hover{background:var(--green-xl,#F2FAF6)}
.pd-game-row:last-child{margin-bottom:0}

/* CTA */
.pd-cta-card{background:linear-gradient(135deg,var(--green-d,#064A38),var(--green));color:#fff;padding:20px;height:100%;text-align:center;border-radius:16px}
body.dark .pd-cta-card{background:linear-gradient(135deg,#040E0B,#0A2E22);border:1px solid rgba(34,199,122,.15)}
.pd-cta-btn{display:inline-block;background:rgba(255,255,255,.2);color:#fff;padding:9px 20px;border-radius:10px;font-size:13px;font-weight:700;border:1.5px solid rgba(255,255,255,.4);transition:background .18s;text-decoration:none}
.pd-cta-btn:hover{background:rgba(255,255,255,.35)}

/* Assessments */
.pd-assess-card{padding:12px 14px;border-radius:10px;background:var(--gray-50);border:1px solid rgba(0,0,0,.04);border-right:3px solid var(--green);margin-bottom:6px}
.pd-assess-card:last-child{margin-bottom:0}
.pd-assess-date{font-size:11px;color:var(--text-muted);margin-bottom:6px}
.pd-chip{font-size:10.5px;padding:2px 8px;border-radius:100px;font-weight:700;background:var(--green-l);color:var(--green)}

/* Recommendations */
.pd-rec-card{display:flex;gap:12px;padding:12px 14px;border-radius:10px;background:var(--gray-50);border:1px solid rgba(0,0,0,.04);margin-bottom:6px;transition:background .18s;cursor:pointer}
.pd-rec-card:hover{background:var(--green-xl,#F2FAF6)}
.pd-rec-card:last-child{margin-bottom:0}

/* IEP stages */
.pd-iep-stages{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pd-stage{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:12px;background:var(--gray-50);border:1px solid rgba(0,0,0,.04)}
.pd-stage-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;color:#fff}
.pd-stage-done{background:var(--green)}
.pd-stage-current{background:var(--amber)}
.pd-stage-pending{background:var(--gray-200);color:var(--text-muted)}

/* Modal */
.pd-modal-bg{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:16px}
.pd-modal-bg.open{display:flex}
.pd-modal{background:var(--white);border-radius:20px;padding:24px;max-width:400px;width:100%;position:relative;box-shadow:0 8px 32px rgba(0,0,0,.15);animation:mpop .25s cubic-bezier(.16,1,.3,1) both}
@keyframes mpop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.pd-modal-close{position:absolute;top:14px;left:14px;width:28px;height:28px;border-radius:50%;background:var(--gray-100);border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .18s}
.pd-modal-close:hover{background:var(--gray-200)}
.pd-modal-title{font-size:16px;font-weight:800;color:var(--text-primary);margin-bottom:16px}

/* Shared */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(80px);z-index:500;background:var(--gray-800);color:#fff;padding:10px 20px;border-radius:99px;font-size:13px;font-weight:600;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;font-family:Tajawal,sans-serif}
body.dark .toast{background:#E8E6DE;color:#1A1A17}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.pd-loading{text-align:center;padding:20px;color:var(--text-muted);font-size:13px}
.pd-empty{text-align:center;padding:20px 14px}
.pd-empty-icon{font-size:32px;margin-bottom:8px}

/* Responsive */
@media(max-width:1024px){.pd-bc-8{grid-column:span 12}.pd-bc-6{grid-column:span 12}.pd-bc-4{grid-column:span 6}}
@media(max-width:768px){.tn-uname{display:none}.pd-wb-stats{display:none}.pd-iep-stages{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.pd-bento{grid-template-columns:1fr 1fr;gap:10px}.pd-bc-8,.pd-bc-6,.pd-bc-4,.pd-bc-full{grid-column:span 2}.pd-bc{padding:12px}.pd-kpi-row{grid-template-columns:repeat(3,1fr)}.pd-iep-stages{grid-template-columns:1fr}.tn-logout-btn{display:none}}
@media(max-width:480px){.pd-qa-grid{grid-template-columns:1fr 1fr}}


/* ══════════════════════════════════════════
   Teacher Dashboard — UX Enhancements
   Matches parent dashboard quality
══════════════════════════════════════════ */

/* Teacher KPI 4-col grid on desktop */
.td-kpi-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
@media(max-width:640px){ .td-kpi-4 { grid-template-columns:1fr 1fr; } }

/* Student card hover */
.td-student-row { cursor:pointer; }
.td-student-row:hover .td-student-name { color:var(--td-accent,#A86210); }

/* Search highlight */
.td-search-wrap {
  display:flex; align-items:center; gap:8px;
  background:var(--sf-input,#fff); border:1.5px solid var(--bd-1,rgba(0,0,0,.12));
  border-radius:99px; padding:7px 14px; transition:border-color .18s;
}
.td-search-wrap:focus-within {
  border-color: var(--td-accent,#A86210);
  box-shadow: 0 0 0 3px rgba(168,98,16,.1);
}
body.dark .td-search-wrap {
  background: var(--sf-input,#2C2C28);
  border-color: var(--bd-1,rgba(255,255,255,.12));
}
.td-search-input {
  background:none; border:none; outline:none;
  font-size:13px; color:var(--tx-1,#1A1A17);
  font-family:Tajawal,sans-serif; width:100%;
}
body.dark .td-search-input { color:var(--tx-1,#EEECe4); }
.td-search-input::placeholder { color:var(--tx-ph,#8A8980); }

/* IEP progress animate */
.td-iep-fill { animation: iepFill .8s ease forwards; }
@keyframes iepFill { from { width:0; } }

/* Alert amber */
.td-alert {
  background: var(--td-accent-l, #FDF3E0) !important;
  border-color: rgba(168,98,16,.2) !important;
}
body.dark .td-alert {
  background: rgba(168,98,16,.12) !important;
  border-color: rgba(168,98,16,.25) !important;
}
.td-alert-text { color:var(--tx-1,#1A1A17) !important; }
body.dark .td-alert-text { color:var(--tx-1,#EEECe4) !important; }

/* Tool hover */
.td-tool { transition: all .18s ease; }
.td-tool span:last-child { color: var(--tx-1,#1A1A17) !important; }
body.dark .td-tool span:last-child { color: var(--tx-1,#EEECe4) !important; }

/* Session row */
.td-session-name { color:var(--tx-1,#1A1A17) !important; }
body.dark .td-session-name { color:var(--tx-1,#EEECe4) !important; }
.td-session-sub { color:var(--tx-3,#5A5955) !important; }
body.dark .td-session-sub { color:var(--tx-3,#A8A79F) !important; }

/* Welcome bar stats responsive */
@media(max-width:600px){
  .td-wb { flex-direction:column; align-items:flex-start; }
  .td-wb > div:last-child { display:none; }
}

/* Bento for teacher */
body.dark .pd-bc { border-color:var(--bd-1,rgba(255,255,255,.12)) !important; }
body.dark .td-student-row { background:var(--sf-card,#252520); border-color:var(--bd-2,rgba(255,255,255,.07)); }
body.dark .td-session-row { background:var(--sf-card,#252520); border-color:var(--bd-2,rgba(255,255,255,.07)); }
body.dark .td-iep-item { border-color:var(--bd-2,rgba(255,255,255,.07)); }
body.dark .td-tool { background:var(--sf-card,#252520); border-color:var(--bd-1,rgba(255,255,255,.12)); }
body.dark .td-student-badge { background:rgba(251,191,36,.15); color:#FBBF24; }
body.dark .td-iep-pct { color:var(--tx-3,#A8A79F); }
body.dark .td-iep-bar { background:rgba(255,255,255,.1); }
body.dark .pd-kpi { background:rgba(255,255,255,.05); }
body.dark .pd-kpi-num { color:var(--green,#22C55E); }

/* ── Form controls — accessible ── */
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-group label {
  font-size:13px; font-weight:700;
  color:var(--tx-2,#3D3C38);
  display:block;
}
body.dark .form-group label { color:var(--tx-2,#C8C6BE); }
.form-input, .form-select {
  width:100%; padding:11px 14px;
  font-size:14px; font-family:Tajawal,sans-serif;
  border:1.5px solid var(--bd-1,rgba(0,0,0,.12));
  border-radius:10px;
  background:var(--sf-input,#fff);
  color:var(--tx-1,#1A1A17);
  direction:rtl; transition:border-color .18s;
}
body.dark .form-input,
body.dark .form-select {
  background:var(--sf-input,#2C2C28);
  color:var(--tx-1,#EEECe4);
  border-color:var(--bd-1,rgba(255,255,255,.12));
}
.form-input:focus, .form-select:focus {
  outline:none;
  border-color:var(--green,#0F7B5F);
  box-shadow:0 0 0 3px rgba(15,123,95,.1);
}
.form-input::placeholder { color:var(--tx-ph,#8A8980); }
body.dark .form-input::placeholder { color:var(--tx-ph,#7A7971); }


/* iOS Safari AI Assistant Zoom Fix */
.ai-assistant input,
.ai-assistant textarea,
.ai-chat-input,
.ai-assistant-panel textarea,
.ai-widget-panel textarea {
  font-size: 16px !important;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .ai-assistant-panel,
  .ai-chat-panel,
  .ai-widget-panel {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    left: 12px !important;
    right: auto !important;
    transform: none !important;
    overflow-x: hidden !important;
  }

  .ai-assistant-panel * {
    max-width: 100%;
    box-sizing: border-box;
  }
}
