/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width: 1200px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .dash-grid { grid-template-columns: 1fr; }
  .board-columns { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.mobile-open { transform: translateX(0); }
  .main { margin-left: 0; }
  #sidebar-toggle { display: flex; }
  .matter-detail-grid { grid-template-columns: 1fr; }
  .library-layout { grid-template-columns: 1fr; }
  .editor-layout { grid-template-columns: 1fr; }
  .recorder-layout { grid-template-columns: 1fr; }
  .cal-grid { grid-template-columns: 1fr; }
  .settings-layout { grid-template-columns: 1fr; }
  .form-row-2 { grid-template-columns: 1fr; }
  .lex-panel { width: calc(100vw - 2rem); right: -0.5rem; }
}

@media (max-width: 600px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .board-columns { grid-template-columns: 1fr; }
  .module { padding: 1rem; }
  .topbar { padding: 0 1rem; }
  .auth-box { padding: 1.75rem; }
  .modal { padding: 1.25rem; }
}

/* ================================================================
   SIDEBAR OVERLAY (mobile)
================================================================ */
#sidebar-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 99;
  background: rgba(15,15,13,0.5);
}
#sidebar-overlay.visible { display: block; }
