/* ============================================================
   DASHBOARD CSS
   ============================================================ */

/* ── Twee-kolommen layout ── */
.db-layout {
  display: grid;
  grid-template-columns: 1fr 272px;
  gap: 24px;
  align-items: start;
}
.db-main { min-width: 0; }

/* ── Begroeting ── */
.db-greeting-row { margin-bottom: 28px; }
.db-begroeting {
  font-size: 28px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.7px;
  margin-bottom: 4px;
}
.db-datum-sub { font-size: 14px; color: var(--ink-3); }

/* ── Tabs + filterrij ── */
.db-tabs-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.db-tabs {
  display: flex;
  gap: 2px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 3px;
}

.db-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-3);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.12s;
  white-space: nowrap;
  font-family: var(--font);
}
.db-tab svg { width: 14px; height: 14px; flex-shrink: 0; }
.db-tab:hover { color: var(--ink); background: rgba(28,25,23,0.04); }
.db-tab-actief {
  background: var(--surface) !important;
  color: var(--ink) !important;
  font-weight: 600;
  box-shadow: var(--shadow-sm);
}

/* ── Klas filter ── */
.db-filter-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  padding: 6px 10px;
  background: var(--surface);
  border: 1.5px solid var(--border-2);
  border-radius: var(--radius-sm);
  cursor: pointer;
}
.db-filter-select {
  border: none;
  background: transparent;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2);
  cursor: pointer;
  outline: none;
  font-family: var(--font);
}

/* ── Les lijst ── */
.db-les-lijst {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* ── Les kaart ── */
.db-les-card {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  transition: background 0.1s;
}
.db-les-card:last-child { border-bottom: none; }
.db-les-afgerond { opacity: 0.55; }

/* ── Kaart header (klikbaar) ── */
.db-les-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  user-select: none;
  gap: 12px;
  transition: background 0.12s;
}
.db-les-header:hover { background: var(--surface-2); }

.db-les-header-left {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  flex: 1;
}

/* Gekleurde klas cirkel */
.db-klas-cirkel {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  font-family: var(--font-mono);
  letter-spacing: -0.5px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}

.db-les-tekst { min-width: 0; }

.db-les-naam {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.2px;
}

.db-les-sub {
  font-size: 12px;
  color: var(--ink-3);
  margin-top: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.db-les-header-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

/* ── Status badges ── */
.db-status-badge {
  font-size: 11.5px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.db-status-nog        { background: var(--blue-dim);   color: var(--blue-text); }
.db-status-uitvoering { background: var(--amber-dim);  color: var(--amber-text); }
.db-status-afgerond   { background: var(--accent-dim); color: var(--accent-text); }

/* ── Chevron ── */
.db-chevron {
  width: 18px;
  height: 18px;
  color: var(--ink-4);
  flex-shrink: 0;
  transition: transform 0.22s cubic-bezier(0.16,1,0.3,1);
}

/* ── Uitklapinhoud ── */
.db-les-body {
  padding: 16px 20px 20px 76px; /* 42px cirkel + 14px gap + 20px links */
  border-top: 1px solid var(--border);
  background: var(--surface-2);
}

.db-les-beschrijving {
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.6;
  margin-bottom: 14px;
}

/* ── Materiaal knoppen ── */
.db-les-materialen {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.db-mat-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1.5px solid var(--border-2);
  border-radius: var(--radius-sm);
  background: var(--surface);
  text-decoration: none;
  color: var(--ink);
  cursor: pointer;
  transition: all 0.15s;
  box-shadow: var(--shadow-sm);
  flex: 1;
  min-width: 180px;
}
.db-mat-btn:hover {
  border-color: var(--accent);
  background: var(--accent-dim);
  box-shadow: var(--shadow);
  transform: translateY(-1px);
}
.db-mat-btn > svg:first-child { width: 20px; height: 20px; flex-shrink: 0; color: var(--ink-3); }
.db-mat-label { font-size: 13px; font-weight: 600; }
.db-mat-sub   { font-size: 11.5px; color: var(--ink-3); margin-top: 1px; }
.db-mat-arrow { width: 14px; height: 14px; margin-left: auto; color: var(--ink-4); flex-shrink: 0; }
.db-mat-lesbrief .db-mat-label { color: var(--blue-text); }
.db-mat-lesbrief:hover { border-color: var(--blue); background: var(--blue-dim); }
.db-mat-toets { cursor: default; }
.db-mat-toets:hover { border-color: var(--border-2); background: var(--surface); transform: none; box-shadow: var(--shadow-sm); }

/* ── Actieknoppen in kaart ── */
.db-les-acties {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.db-afronden-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--accent);
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  font-family: var(--font);
  min-height: 42px;
  box-shadow: 0 1px 4px rgba(99,102,241,0.2);
}
.db-afronden-btn svg { width: 15px; height: 15px; }
.db-afronden-btn:hover { background: #4f46e5; border-color: #4f46e5; box-shadow: 0 3px 10px rgba(99,102,241,0.30); }
.db-afronden-klaar { background: var(--accent-dim); color: var(--accent-text); border-color: rgba(99,102,241,0.3); box-shadow: none; }
.db-afronden-klaar:hover { background: var(--accent-dim); border-color: rgba(99,102,241,0.4); box-shadow: none; color: var(--accent-text); }

.db-opmerking-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border-2);
  background: var(--surface);
  color: var(--ink-3);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
  font-family: var(--font);
  min-height: 42px;
  box-shadow: var(--shadow-sm);
}
.db-opmerking-btn svg { width: 15px; height: 15px; }
.db-opmerking-btn:hover { color: var(--ink); background: var(--surface-2); box-shadow: var(--shadow); }

.db-lesbrief-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--blue);
  background: var(--blue);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  font-family: var(--font);
  min-height: 42px;
  box-shadow: 0 1px 4px rgba(37,99,235,0.2);
}
.db-lesbrief-btn svg { width: 15px; height: 15px; }
.db-lesbrief-btn:hover { background: #1D4ED8; border-color: #1D4ED8; box-shadow: 0 3px 10px rgba(37,99,235,0.30); }

.db-les-opmerking {
  margin-top: 14px;
  padding: 10px 14px;
  background: var(--amber-dim);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--amber);
  font-size: 13px;
  color: var(--amber-text);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.5;
}

/* ── Week sectie ── */
.db-week-sectie { margin-bottom: 20px; }
.db-week-label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.db-week-count { font-size: 12px; color: var(--ink-3); }

/* ── Bottom tip ── */
.db-bottom-tip {
  text-align: center;
  font-size: 12px;
  color: var(--ink-4);
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  background: var(--surface);
}

/* ============================================================
   RECHTERPANEEL
   ============================================================ */
.db-right-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: sticky;
  top: 16px;
}

.db-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: var(--shadow-sm);
}

.db-widget-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-4);
  margin-bottom: 16px;
}

/* ── Voortgang donut ── */
.db-voortgang-wrap {
  display: flex;
  align-items: center;
  gap: 18px;
}
.db-donut-wrap { flex-shrink: 0; }
.db-donut { width: 80px; height: 80px; }
.db-voortgang-info { min-width: 0; }
.db-voortgang-getal { font-size: 24px; font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -0.5px; }
.db-voortgang-label { font-size: 12px; color: var(--ink-3); margin: 5px 0 12px; }
.db-voortgang-link {
  display: inline-flex;
  align-items: center;
  background: var(--accent-dim);
  border: none;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent-text);
  cursor: pointer;
  padding: 5px 12px;
  font-family: var(--font);
  transition: background 0.12s;
}
.db-voortgang-link:hover { background: #c7d2fe; }

/* ── Legenda ── */
.db-legenda { display: flex; flex-direction: column; gap: 10px; }
.db-legenda-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--ink-2);
}
.db-legenda-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── Snelle acties ── */
.db-snelle-acties { display: flex; flex-direction: column; gap: 2px; }
.db-snelle-actie {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 10px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: none;
  color: var(--ink-2);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s, color 0.12s;
  font-family: var(--font);
  width: 100%;
}
.db-snelle-actie svg { width: 16px; height: 16px; color: var(--ink-4); flex-shrink: 0; }
.db-snelle-actie:hover { background: var(--surface-2); color: var(--ink); }
.db-snelle-actie:hover svg { color: var(--accent); }

/* ── Mobiele voortgang banner (verborgen op desktop) ── */
.db-mobile-vg { display: none; }

/* ============================================================
   TABLET — rechter paneel verbergen + voortgang banner
   ============================================================ */
@media (max-width: 960px) {
  .db-layout { grid-template-columns: 1fr; }
  .db-right-panel { display: none; }

  /* Voortgang banner */
  .db-mobile-vg {
    display: block;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-bottom: 16px;
  }
  .db-mobile-vg-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
  }
  .db-mobile-vg-label { font-size: 12px; color: var(--ink-3); font-weight: 500; }
  .db-mobile-vg-pct { font-size: 14px; font-weight: 700; color: var(--accent-text); }
  .db-mobile-vg-balk {
    height: 8px;
    background: var(--surface-3, #F0EDE8);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 6px;
  }
  .db-mobile-vg-fill {
    height: 100%;
    background: var(--accent);
    border-radius: 4px;
    transition: width 0.5s ease;
    min-width: 4px;
  }
  .db-mobile-vg-sub { font-size: 11px; color: var(--ink-3); }

  /* Tabs scrollen als ze niet passen */
  .db-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-shrink: 1;
  }
  .db-tabs::-webkit-scrollbar { display: none; }
}

/* ============================================================
   MOBIEL — overrides
   ============================================================ */
@media (max-width: 768px) {
  /* ── Verberg desktop-only views op mobiel ── */
  #view-klassen,
  #view-jaarplanning,
  #view-lesprofielen,
  #view-opdrachten,
  #view-toetsen,
  #view-schooljaren,
  #view-gebruikers,
  #view-vakken,
  #view-lesmodules,
  #view-teamleider,
  #view-werkboekjes {
    display: none !important;
  }

  /* Hamburger en sidebar verborgen op mobiel — bottom nav regelt navigatie */
  .hamburger { display: none; }
  .sidebar .nav-item { display: none; }
  .sidebar .nav-group .nav-label { display: none; }

  /* Login */
  .login-card { padding: 28px 24px; border-radius: var(--radius-lg); margin: 0 8px; }
  .login-heading { font-size: 22px; }
  .login-desc { font-size: 13px; margin-bottom: 20px; }
  .btn-login { padding: 14px; font-size: 15px; min-height: 48px; }
  .form-field input, .form-field select { padding: 13px; font-size: 16px; min-height: 48px; }

  /* Dashboard layout */
  .db-begroeting { font-size: 20px; }
  .db-datum-sub { font-size: 12px; }

  /* Tabs — touch-vriendelijk */
  .db-tabs-row { gap: 6px; flex-wrap: wrap; }
  .db-tab { padding: 8px 12px; font-size: 12px; min-height: 40px; }

  /* Filter — zichtbaar op mobiel, volledige breedte */
  .db-filter-wrap {
    display: flex;
    margin-left: 0;
    width: 100%;
  }
  .db-filter-select { flex: 1; }

  /* Kaartindeling */
  .db-les-header { padding: 14px 16px; min-height: 60px; }
  .db-les-body { padding-left: 16px; padding-right: 16px; }
  .db-klas-cirkel { width: 36px; height: 36px; font-size: 10px; }
  .db-les-naam { font-size: 14px; }
  .db-les-sub { font-size: 11.5px; }
  .db-status-badge { font-size: 11px; padding: 3px 8px; }

  /* Actieknoppen — volledige breedte voor touch */
  .db-les-acties { flex-direction: column; gap: 8px; }
  .db-afronden-btn, .db-opmerking-btn {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    font-size: 14px;
  }

  /* Materiaal knoppen */
  .db-mat-btn { padding: 12px; min-height: 50px; }
  .db-mat-label { font-size: 13px; }
}

@media (max-width: 380px) {
  .db-les-naam { font-size: 13px; }
  .db-tab { padding: 7px 10px; font-size: 11px; }
  .login-card { padding: 24px 16px; }
}

@media (max-width: 768px) {
  .rooster-schema-grid { grid-template-columns: 1fr; }
  .rooster-schema div { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .rooster-table-uren { min-width: 900px; }
  .rooster-uur-grid { grid-template-columns: repeat(4, 32px); }
  .rooster-uur-pill { width:32px; height:32px; }
}

/* ============================================================
   TEACHER DASHBOARD NIEUW
   ============================================================ */
.teacher-dashboard{max-width:1280px;margin:0 auto;padding:24px 8px 40px;color:#111827;}
.td-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px;}
.td-topbar h1{font-size:30px;line-height:1.1;margin:0 0 8px;font-weight:800;letter-spacing:-.04em;color:#111827;}
.td-topbar p{margin:0;color:#4b5563;font-size:14px;}
.td-top-actions{display:flex;gap:10px;align-items:center;}
.td-btn{height:44px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;padding:0 16px;font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.05);font-family:inherit;}
.td-btn svg{width:18px;height:18px;}
.td-btn-primary{background:#6366f1!important;color:#fff!important;border-color:#6366f1!important;box-shadow:0 4px 14px rgba(99,102,241,0.28)!important;}
.td-btn-light{color:#111827;}
.td-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:24px;align-items:start;}
.td-main{min-width:0;}
.td-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:24px;}
.td-stat{background:#fff;border:1px solid #e5e7eb;border-radius:14px;min-height:88px;padding:18px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 6px rgba(15,23,42,.06);}
.td-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.td-stat-icon svg{width:22px;height:22px;}
.td-stat-rood .td-stat-icon{background:#eef2ff;color:#6366f1;}
.td-stat-oranje .td-stat-icon{background:#eef2ff;color:#818cf8;}
.td-stat-blauw .td-stat-icon{background:#eef2ff;color:#6366f1;}
.td-stat-groen .td-stat-icon{background:#eef2ff;color:#4f46e5;}
.td-stat-label{font-size:12px;color:#6b7280;margin-bottom:6px;}.td-stat-value{font-size:22px;font-weight:800;color:#111827;}
.td-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.td-section-head h2{font-size:20px;margin:0;font-weight:800;color:#111827;}
.td-dag-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.td-dag-nav h2{margin:0;}
.td-dag-nav-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;font-size:18px;cursor:pointer;color:#374151;flex-shrink:0;}
.td-dag-nav-btn:hover{background:#f3f4f6;border-color:#d1d5db;}
.td-dag-nav-vandaag{height:34px;padding:0 12px;border-radius:8px;border:1.5px solid #2563eb;background:#eff6ff;color:#2563eb;font-size:12px;font-weight:700;cursor:pointer;}
.td-dag-nav-vandaag:hover{background:#dbeafe;}
.td-view-select{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280;}
.td-view-select select{height:38px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;padding:0 12px;font-weight:600;color:#111827;}
.td-timeline{display:flex;flex-direction:column;gap:8px;}

/* Leskaart — flex kolom: header / kleurlijn / body */
.td-lesson{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;box-shadow:0 1px 3px rgba(15,23,42,.05);overflow:hidden;}
.td-lesson.is-done{opacity:.65;border-left:3px solid #818cf8;}

/* Rij 1: klas-badge | tijd | status rechts */
.td-lesson-toprow{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.td-class{width:34px;height:34px;border-radius:999px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;box-shadow:0 2px 6px rgba(15,23,42,.18);}
.td-time{display:flex;align-items:baseline;gap:6px;color:#111827;font-size:13px;flex:1;}
.td-time strong{font-weight:800;font-size:15px;}
.td-time span{color:#6b7280;font-size:12px;}
.td-time em{font-style:normal;font-weight:700;font-size:11px;color:#374151;background:#f3f4f6;border-radius:999px;padding:2px 7px;margin-left:2px;}
.td-status{flex-shrink:0;display:inline-flex;align-items:center;white-space:nowrap;border-radius:6px;font-weight:700;font-size:11px;padding:4px 9px;background:#f3f4f6;color:#374151;}
.td-status--nu{background:#eef2ff;color:#4338ca;}
.td-status--niet-afgerond{background:#fef2f2;color:#b91c1c;}
.td-status--afgerond{background:#eef2ff;color:#4338ca;}
.td-status--deels{background:#fffbeb;color:#92400e;}
.td-status--vervallen{background:#fef2f2;color:#6b7280;}

/* Rij 2: lestitel */
.td-lesson-titel{margin:0 0 10px;font-size:17px;font-weight:800;color:#111827;line-height:1.2;}

/* Rij 3: horizontale gekleurde streep */
.td-colorbar{width:100%;height:3px;border-radius:999px;margin-bottom:12px;flex-shrink:0;}

/* Body onder de streep */
.td-lesson-body{min-width:0;}
.td-lesson h3{margin:0 0 6px;font-size:16px;line-height:1.25;font-weight:800;color:#111827;}
.td-meta{font-size:12px;color:#6b7280;margin-bottom:8px;display:flex;gap:7px;flex-wrap:wrap;align-items:center;}
.td-lesson p{margin:0 0 12px;color:#374151;font-size:13px;line-height:1.45;}
/* Basis knopstijl — gedeeld door alle actie-containers */
.td-lesson button,.td-lesson a[onclick],.td-acties-hoofd button,.td-acties-hoofd a,.td-acties-extra button,.td-acties-extra a{height:38px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;color:#111827;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;padding:0 14px;box-shadow:0 1px 2px rgba(15,23,42,.04);}
.td-lesson button:hover,.td-lesson a[onclick]:hover{background:#f9fafb;border-color:#cbd5e1;}
.td-finish--todo{background:#6366f1!important;color:#fff!important;border-color:#6366f1!important;box-shadow:0 1px 4px rgba(99,102,241,0.25)!important;}
.td-finish--todo:hover{background:#4f46e5!important;border-color:#4f46e5!important;}
.td-finish--heropenen{border-color:#d1d5db!important;color:#6b7280!important;background:#f9fafb!important;}
.td-finish--deels{background:#d97706!important;color:#fff!important;border-color:#d97706!important;}
.td-lesbrief-ready{border-color:#bfdbfe!important;color:#1d4ed8!important;background:#eff6ff!important;}
.td-opmerking--heeft{border-color:#fde68a!important;color:#92400e!important;background:#fffbeb!important;}
.td-uren--behandeld{border-color:#86efac!important;color:#4338ca!important;background:#f0fdf4!important;}
.td-uren--deels{border-color:#fcd34d!important;color:#92400e!important;background:#fffbeb!important;}
.td-uren--vervallen{border-color:#fca5a5!important;color:#b91c1c!important;background:#fef2f2!important;}
/* Primaire acties (Lesbrief + Les afronden): altijd zichtbaar */
.td-acties-hoofd{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:0;}
.td-acties-hoofd button,.td-acties-hoofd a{flex:1;}
/* Extra acties (Opmerking, Uren etc.) in detail */
.td-acties-extra{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.td-acties-extra button,.td-acties-extra a{flex:1;}
/* Detail-toggle knop: alleen mobiel */
.td-detail-toggle{display:none;}
.td-note{margin-top:10px;border-radius:8px;background:#f8fafc;border:1px solid #e5e7eb;padding:10px;font-size:13px;color:#374151;}

/* Module praktijk sectie */
.td-module-praktijk{margin-top:12px;border-top:1px solid #e5e7eb;padding-top:10px;}
.td-module-stap-naam{font-size:12px;color:#6b7280;margin-bottom:6px;}
.td-module-rij{font-size:12.5px;color:#374151;line-height:1.6;margin-bottom:4px;}
.td-module-link{color:#1d4ed8;font-weight:600;text-decoration:none;}
.td-module-link:hover{text-decoration:underline;}
.td-module-downloads{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.td-module-dl{font-size:12px;font-weight:600;border-radius:8px;padding:6px 10px;text-decoration:none;}
.td-module-dl--wb{color:#15803d;background:#ecfdf5;border:1px solid #c7d2fe;}
.td-module-dl--toets{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;}

/* Gecombineerde kaart (meerdere klassen, zelfde tijdslot) */
.td-lesson--combined{border-color:#e0e7ff;}
.td-combined-colorbar{display:flex;gap:4px;margin-bottom:12px;}
.td-class--sm{width:26px;height:26px;font-size:9px;flex-shrink:0;}
.td-combined-klas-row{display:flex;flex-direction:column;gap:6px;padding:8px 0;border-top:1px solid #f3f4f6;}
.td-combined-klas-row:first-child{border-top:none;padding-top:4px;}
.td-acties-hoofd--inline{display:flex;gap:6px;flex-wrap:wrap;}
.td-acties-hoofd--inline button,.td-acties-hoofd--inline a{flex:1;font-size:12px;}
.td-combined-detail{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}  /* zichtbaar op desktop */

.td-pause{display:flex;align-items:center;gap:12px;padding:0 4px;}
.td-pause-card{height:56px;border:1px solid #e5e7eb;background:#fff;border-radius:10px;padding:0 16px;display:flex;align-items:center;gap:8px;color:#374151;box-shadow:0 1px 3px rgba(15,23,42,.04);}
.td-pause-card span{color:#6b7280;font-size:13px;}
.td-side{display:flex;flex-direction:column;gap:16px;}
.td-widget{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;box-shadow:0 2px 6px rgba(15,23,42,.06);}
.td-widget-title{font-size:16px;font-weight:800;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;color:#111827;}
.td-widget-title span{min-width:24px;height:24px;border-radius:999px;background:#f3f4f6;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#111827;}
.td-widget-title .td-ok{background:#f0fdf4;color:#4338ca;}
.td-task-list,.td-need-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;}
.td-task{display:grid;grid-template-columns:18px 1fr auto;gap:10px;align-items:center;font-size:13px;color:#111827;}
.td-task-check{width:16px;height:16px;border-radius:999px;border:1px solid #d1d5db;background:#fff;cursor:pointer;padding:0;}
.td-task em{font-style:normal;color:#dc2626;font-size:12px;}

/* Benodigd vandaag — accordion per klas */
.td-need-group{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;}
.td-need-klas{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f9fafb;border:0;cursor:pointer;font-family:inherit;text-align:left;}
.td-need-klas:hover{background:#f3f4f6;}
.td-need-klas-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.td-need-klas strong{flex:1;font-size:13px;font-weight:700;color:#111827;}
.td-need-klas em{font-style:normal;font-size:11px;font-weight:600;color:#6b7280;background:#e5e7eb;border-radius:999px;padding:2px 7px;}
.td-need-chevron{width:14px;height:14px;color:#9ca3af;flex-shrink:0;transition:transform .2s;}
.td-need-items{display:none;border-top:1px solid #e5e7eb;padding:8px 0;}
.td-need-group.open .td-need-items{display:block;}
.td-need-group.open .td-need-chevron{transform:rotate(180deg);}
.td-need{display:flex;justify-content:space-between;gap:12px;align-items:center;font-size:13px;color:#111827;padding:5px 12px;}
.td-need:hover{background:#f9fafb;}
.td-need em{font-style:normal;border-radius:999px;background:#f3f4f6;padding:3px 8px;font-size:11px;font-weight:600;color:#374151;white-space:nowrap;}
.td-link{border:0;background:transparent;color:#6366f1;font-weight:700;padding:0;cursor:pointer;font-size:13px;font-family:inherit;}
.td-empty-small{color:#6b7280;font-size:13px;text-align:center;padding:12px 0;}
.td-actions{background:#eef2ff;border-color:#dbeafe;}.td-actions button{width:100%;height:34px;margin-top:8px;text-align:left;border:1px solid #dbeafe;background:#fff;border-radius:7px;padding:0 10px;font-weight:700;color:#111827;cursor:pointer;font-family:inherit;}.td-actions span{float:right;background:#7c3aed;color:#fff;border-radius:999px;padding:2px 6px;font-size:10px;}
.td-tip{border-radius:14px;background:#eef2ff;padding:16px;border:1px solid #c7d2fe;color:#4338ca;}.td-tip p{margin:8px 0 0;font-size:13px;line-height:1.45;color:#3730a3;}

/* ── Desktop kaartopmaak (>760px) ── */
@media (min-width:761px){
  /* Toggle nooit tonen */
  .td-detail-toggle{display:none!important;}
  /* Detail altijd zichtbaar */
  .td-lesson-detail{display:block!important;margin-top:10px;padding-top:10px;border-top:1px solid #f3f4f6;}
  .td-combined-detail{display:flex!important;flex-wrap:wrap;gap:6px;margin-top:6px;}
  /* Knoppen: compact, niet full-width */
  .td-acties-hoofd button,.td-acties-hoofd a{flex:0 1 auto;}
  .td-acties-extra button,.td-acties-extra a{flex:0 1 auto;}
  /* Combined: per-klas rij horizontaal in één lijn */
  .td-combined-klas-row{flex-direction:row;align-items:center;flex-wrap:wrap;gap:8px;}
  .td-combined-klas-row .td-class--sm{flex-shrink:0;}
  .td-acties-hoofd--inline{flex-wrap:nowrap;}
  .td-acties-hoofd--inline button,.td-acties-hoofd--inline a{flex:0 1 auto;white-space:nowrap;}
}

@media (max-width:1100px){.td-layout{grid-template-columns:1fr}.td-side{grid-template-columns:repeat(2,1fr);display:grid}.td-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.teacher-dashboard{padding:16px 0}.td-topbar,.td-section-head{flex-direction:column;align-items:stretch}.td-top-actions{justify-content:stretch}.td-btn{flex:1;justify-content:center}.td-stats{grid-template-columns:1fr}.td-side{display:flex}.td-lesson-titel{white-space:normal}.td-lesson-header{flex-wrap:wrap}.td-time{flex-wrap:wrap}}

/* ── Responsive & utility ── */
.teacher-dashboard,.td-layout,.td-main,.td-side,.td-stats,.td-lesson,.td-lesson-body,.td-module-praktijk{min-width:0;max-width:100%;box-sizing:border-box;}
.teacher-dashboard{width:100%;overflow-x:hidden;}
.td-stats{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));}
.td-module-praktijk a{max-width:100%;white-space:normal;overflow-wrap:anywhere;}

@media (max-width:1200px){.teacher-dashboard{padding-left:0;padding-right:0;}}

@media (max-width:760px){
  .teacher-dashboard{padding:12px 0 84px;}
  .td-topbar{gap:14px;margin-bottom:16px;}
  .td-topbar h1{font-size:28px;line-height:1.08;margin-bottom:6px;}
  .td-topbar p{font-size:14px;line-height:1.35;}
  .td-top-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  .td-btn{height:48px;min-height:48px;padding:0 12px;border-radius:14px;font-size:15px;justify-content:center;}
  .td-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:18px;}
  .td-stat{min-height:92px;padding:12px;border-radius:16px;gap:10px;align-items:center;box-shadow:0 1px 4px rgba(15,23,42,.06);}
  .td-stat-icon{width:38px;height:38px;min-width:38px;font-size:19px;}
  .td-stat-label{font-size:12px;line-height:1.15;margin-bottom:5px;}
  .td-stat-value{font-size:24px;line-height:1.05;letter-spacing:-0.04em;}
  .td-section-head{gap:10px;margin-bottom:10px;}
  .td-section-head h2{font-size:20px;}
  .td-view-select{justify-content:space-between;}
  .td-view-select select{width:auto;min-width:128px;}
  /* Leskaart mobiel */
  .td-lesson{padding:12px 14px;}
  .td-lesson-toprow{gap:8px;}
  .td-lesson-titel{font-size:15px;}
  .td-class{width:30px;height:30px;font-size:10px;}
  .td-time{font-size:12px;}
  .td-time strong{font-size:13px;}

  /* Primaire acties: altijd zichtbaar, groot genoeg om op te tikken */
  .td-acties-hoofd{margin-top:10px;gap:7px;}
  .td-acties-hoofd button,.td-acties-hoofd a{height:46px;font-size:13px;}

  /* Detail: standaard verborgen op mobiel */
  .td-lesson-detail{display:none;margin-top:10px;padding-top:10px;border-top:1px solid #f3f4f6;}
  .td-lesson.is-expanded .td-lesson-detail{display:block;}
  .td-combined-detail{display:none;}
  .td-lesson.is-expanded .td-combined-detail{display:flex;flex-wrap:wrap;gap:6px;}

  /* Detail-toggle knop */
  .td-detail-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:10px;padding:10px;border:1px solid rgba(28,25,23,0.09);border-radius:10px;background:rgba(28,25,23,0.02);color:#6b7280;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background 0.15s,color 0.15s;}
  .td-detail-toggle:hover{background:rgba(99,102,241,0.06);color:#6366f1;border-color:rgba(99,102,241,0.2);}
  .td-lesson.is-expanded .td-detail-chevron{transform:rotate(180deg);}
  .td-detail-chevron{transition:transform 0.2s;}

  /* Verberg desktop-only bedieningselementen op mobiel */
  .td-top-actions { display: none !important; }
  .td-view-select { display: none !important; }

  /* Topbar compacter op mobiel */
  .td-topbar { margin-bottom: 18px; }
  .td-topbar h1 { font-size: 26px; }

  /* Dag nav — pill/capsule stijl */
  .td-section-head { display: block; margin-bottom: 12px; }
  .td-dag-nav {
    background: #fff;
    border: 1.5px solid rgba(28,25,23,0.11);
    border-radius: 14px;
    padding: 6px 8px;
    display: flex;
    align-items: center;
    width: 100%;
    box-shadow: 0 1px 3px rgba(15,23,42,0.04), 0 2px 8px rgba(15,23,42,0.06);
  }
  .td-dag-nav h2 {
    flex: 1;
    text-align: center;
    font-size: 15px;
    letter-spacing: -0.03em;
  }
  .td-dag-nav-btn {
    border: none !important;
    background: rgba(99,102,241,0.08) !important;
    box-shadow: none !important;
    border-radius: 9px !important;
    width: 36px !important;
    height: 36px !important;
    color: #6366f1 !important;
    font-weight: 800;
    flex-shrink: 0;
  }
  .td-dag-nav-btn:hover { background: rgba(99,102,241,0.15) !important; }
  .td-dag-nav-vandaag {
    border-color: #6366f1 !important;
    background: #eef2ff !important;
    color: #6366f1 !important;
    border-radius: 8px;
    font-size: 12px;
  }
  .td-dag-nav-vandaag:hover { background: #e0e7ff !important; }

  /* Primaire actieknop — indigo */
  .td-btn-primary {
    background: #6366f1 !important;
    border-color: #6366f1 !important;
    box-shadow: 0 4px 14px rgba(99,102,241,0.28) !important;
  }
  .td-btn-primary:hover { background: #4f46e5 !important; border-color: #4f46e5 !important; }

  /* Actiebalk hoogte vergroten voor touch */
  .td-acties-hoofd button, .td-acties-hoofd a { height: 46px !important; font-size: 13px !important; border-radius: 10px !important; }

  /* Pauze-kaart compact */
  .td-pause-card { font-size: 13px; }

  /* Dag nav vandaag badge */
  .td-dag-nav-vandaag { height: 30px !important; }
}

@media (max-width:420px){
  .td-stats{gap:8px;}
  .td-stat{min-height:82px;padding:10px;gap:8px;}
  .td-stat-icon{width:34px;height:34px;min-width:34px;font-size:17px;}
  .td-stat-label{font-size:11px;margin-bottom:3px;}
  .td-stat-value{font-size:21px;}
  .td-btn{font-size:14px;height:44px;min-height:44px;}
  .td-lesson{padding:10px 12px;}
}

/* ============================================================
   MOBIEL — TAKEN VIEW
   ============================================================ */
@media (max-width: 768px) {
  #view-taken .page-header { padding: 16px 16px 0; }
  #view-taken .page-header h1 { font-size: 22px; }
  #view-taken .page-header .btn { min-height: 44px; font-size: 14px; }
  #view-taken .alert { margin: 12px 16px; font-size: 13px; }
  #view-taken .card { margin: 12px 16px; border-radius: 14px; }
  #view-taken .card-header { padding: 14px 16px; }
  #view-taken .card-header h2 { font-size: 16px; }

  .taak-rij {
    padding: 14px 16px;
    gap: 12px;
    align-items: flex-start;
  }
  .taak-cirkel { width: 26px; height: 26px; min-width: 26px; margin-top: 2px; }
  .taak-naam { font-size: 15px; }
  .taak-beschrijving { font-size: 13px; }
  .taak-acties { flex-wrap: wrap; gap: 6px; margin-top: 8px; }
  .taak-oppak-btn { min-height: 36px; padding: 0 14px; font-size: 13px; }
  .taak-knoppen { flex-direction: column; gap: 4px; margin-left: auto; }
  .taak-badge { font-size: 11px; padding: 2px 8px; }
}

/* ============================================================
   MOBIEL — ROOSTER VIEW
   ============================================================ */
@media (max-width: 768px) {
  #view-rooster .page-header { padding: 16px 16px 0; }
  #view-rooster .page-header h1 { font-size: 22px; }
  #view-rooster .rr-wrapper { padding: 0 0 24px; }
  #view-rooster .page-header { margin-bottom: 16px; }
  .rr-legenda { flex-direction: column; gap: 8px; padding: 12px 16px; }
  .rr-snelknoppen { padding: 8px 16px; gap: 6px; flex-wrap: wrap; }
  .rr-snelknop { min-height: 40px; padding: 0 14px; font-size: 13px; }
  .rr-klas-kaart { margin: 0 16px 12px; border-radius: 14px; }
  .rr-klas-header { padding: 12px 16px; }
  .rr-klas-naam { font-size: 15px; }
  .rr-uur-grid { gap: 6px; padding: 10px 12px; }
  .rr-uur-pill { min-width: 52px; height: 44px; font-size: 12px; border-radius: 8px; }
  .rr-dag-label { font-size: 12px; margin-bottom: 4px; }
  .rr-preview-sectie { padding: 0 16px; }
  #rr-opslaan-btn { min-height: 44px; }
  .rr-legenda-blok { padding: 10px 12px; border-radius: 10px; }
  .rr-legenda-item { font-size: 12px; }
}

/* ============================================================
   ROOSTER — ACCORDION (mobiel inklapbaar)
   ============================================================ */

/* Dag-samenvatting chips in klas-header */
.rr-dag-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
}
.rr-dag-summary--leeg {
  font-size: 11px;
  color: var(--ink-4, #a09890);
  font-style: italic;
  margin-top: 4px;
}
.rr-dag-chip {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 2px 8px;
  border-radius: 5px;
  background: var(--accent-dim, #eef2ff);
  color: var(--accent-text, #4338ca);
  font-size: 11px;
  font-weight: 600;
}
.rr-dag-chip--vandaag { background: #6366f1; color: #fff; }

/* Chevron */
.rr-klas-chevron {
  flex-shrink: 0;
  color: var(--ink-4, #a09890);
  transition: transform 0.22s cubic-bezier(0.34,1.56,0.64,1);
}
.rr-klas-kaart.is-open .rr-klas-chevron { transform: rotate(180deg); }

/* Klikbare header */
.rr-klas-header { cursor: pointer; user-select: none; }

/* Desktop: dag-lijst altijd zichtbaar, summary/chevron verborgen */
@media (min-width: 769px) {
  .rr-dag-lijst { display: block !important; }
  .rr-dag-summary { display: none; }
  .rr-klas-chevron { display: none; }
  .rr-klas-header { cursor: default; }
}

/* Mobiel: accordion gedrag */
@media (max-width: 768px) {
  .rr-dag-lijst { display: none; }
  .rr-klas-totaal { display: none; }
  .rr-preview-sectie { display: none; }
  .rr-klas-kaart.is-open .rr-dag-lijst { display: block; }
  .rr-klas-header { -webkit-tap-highlight-color: transparent; }
  .rr-klas-header:active { background: var(--surface-2, #f2f1ee); border-radius: 14px 14px 0 0; }
  .rr-klas-kaart.is-open .rr-klas-header:active { border-radius: 14px 14px 0 0; }
}

/* ============================================================
   MOBIEL — LESMATERIALEN VIEW
   ============================================================ */
@media (max-width: 768px) {
  #view-lesmaterialen .page-header { padding: 16px 16px 0; }
  #view-lesmaterialen .page-header h1 { font-size: 22px; }
  #view-lesmaterialen .lm-tabs { padding: 0 16px; gap: 6px; flex-wrap: wrap; }
  #view-lesmaterialen .lm-tab { min-height: 40px; font-size: 13px; padding: 0 14px; }
  #view-lesmaterialen .lm-sectie { padding: 12px 16px; }
  #view-lesmaterialen .lm-grid { grid-template-columns: 1fr; gap: 10px; }
  #view-lesmaterialen .lm-kaart { border-radius: 12px; }
  #view-lesmaterialen .lm-kaart-header { padding: 12px 14px; }
  #view-lesmaterialen .lm-upload-zone { margin: 0 16px 16px; }
  #view-lesmaterialen .btn { min-height: 44px; }

  /* Module-selectie: dropdown op mobiel, tabbar verborgen */
  #view-lesmaterialen .lm-tab-bar { display: none; }
  #view-lesmaterialen .lm-module-select {
    display: block;
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    background: var(--surface);
    color: var(--ink);
    cursor: pointer;
    margin: 8px 0 4px;
  }
}

/* === NIEUW: Werkboekje + Toets card-header met knop === */
@media (max-width: 760px) {
  #view-lesmaterialen .card-header > div {
    flex-wrap: wrap;
    gap: 8px;
  }
  #view-lesmaterialen .card-header h2 {
    font-size: 15px;
    flex: 1 1 100%;
  }
  #view-lesmaterialen .card-header .btn {
    width: 100%;
    justify-content: center;
  }

  /* tw-mat-rij: naam op eigen rij, knoppen eronder */
  #view-lesmaterialen .tw-mat-rij {
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px 16px;
  }
  #view-lesmaterialen .tw-mat-naam {
    width: 100%;
    flex: 1 1 100% !important;
  }
  #view-lesmaterialen .tw-mat-rij .btn,
  #view-lesmaterialen .tw-mat-rij .tw-del-btn {
    flex: 1 1 auto;
    text-align: center;
    justify-content: center;
    min-height: 40px;
  }

  /* Werkboekje wizard: 2-kolom grid → 1 kolom */
  .wb-grid-2 {
    display: flex !important;
    flex-direction: column;
    gap: 12px;
  }
}

/* ============================================================
   MOBIEL — PROFIEL VIEW
   ============================================================ */
.profiel-mobiel {
  padding: 24px 20px;
  max-width: 480px;
  margin: 0 auto;
}
.profiel-avatar {
  width: 72px; height: 72px;
  border-radius: 999px;
  background: #0d1f3c;
  color: #fff;
  font-size: 26px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  letter-spacing: -.5px;
}
.profiel-naam { font-size: 22px; font-weight: 800; color: var(--ink-1); text-align: center; margin-bottom: 4px; }
.profiel-email { font-size: 14px; color: var(--ink-3); text-align: center; margin-bottom: 6px; }
.profiel-rol { display: inline-block; font-size: 12px; font-weight: 600; padding: 3px 12px; border-radius: 999px; background: var(--accent-dim); color: var(--accent-text); margin-bottom: 28px; }
.profiel-sectie {
  background: var(--surface);
  border: 1px solid var(--border-2);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 16px;
}
.profiel-rij {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-2);
  font-size: 15px;
  color: var(--ink-1);
}
.profiel-rij:last-child { border-bottom: none; }
.profiel-rij-label { color: var(--ink-3); font-size: 13px; }
.profiel-uitloggen {
  width: 100%;
  padding: 15px;
  border-radius: 12px;
  border: none;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--font);
  margin-top: 8px;
  -webkit-tap-highlight-color: transparent;
}
.profiel-wijzig-pw {
  width: 100%;
  padding: 15px;
  border-radius: 12px;
  border: 1px solid var(--border-2);
  background: var(--surface);
  color: var(--ink-1);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font);
  margin-bottom: 10px;
  -webkit-tap-highlight-color: transparent;
}

