/* ══════════════════════════════════════
   MEDIFLOW — STYLESHEET
   css/style.css
══════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary:      #0e7490; /* Professional Teal */
  --primary-dark: #0891b2;
  --bg-main:      #f8fafc;
  --bg-card:      #ffffff;
  --bg-sidebar:   #ffffff;
  --text-main:    #0f172a;
  --text-muted:   #64748b;
  --text-on-dark: #ffffff;
  --border:       #e2e8f0;
  --teal:         #0ea5e9;
  --gold:         #f59e0b;
  --danger:       #ef4444;
  --success:      #10b981;
  --warn:         #f59e0b;
  --card-shadow:  0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --sidebar-active: #eff6ff;
}

html, body { height: 100%; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg-main);
  color: var(--text-main);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}


/* ── PAGE TRANSITIONS ── */
.page { display: none; min-height: 100vh; }
.page.active { display: flex; }

/* ══════════════════════════════════════
   LOGIN
══════════════════════════════════════ */
#login-page {
  position: relative;
  align-items: stretch;
  overflow: hidden;
  background: #ffffff;
}

.login-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 80px;
  position: relative;
  z-index: 2;
  background: #ffffff;
  color: var(--text-main);
}


.login-right {
  width: 480px;
  flex-shrink: 0;
  background: #ffffff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 50px;
  position: relative;
  z-index: 2;
  border-left: 1px solid var(--border);
}

.bg-grid {
  position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(37,99,235,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
}



.bg-orbs { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.orb { position: absolute; border-radius: 50%; filter: blur(120px); opacity: 0.15; }
.orb-1 { width:600px; height:600px; background:var(--primary); top:-200px; left:-100px; }
.orb-2 { width:400px; height:400px; background:var(--teal); bottom:-100px; left:40%; }


.brand-logo { display:flex; align-items:center; gap:16px; margin-bottom:48px; }
.brand-icon {
  width:52px; height:52px;
  background: var(--primary);
  color: #ffffff;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 15px -3px rgba(14,116,144,0.2);
}
.brand-icon svg { width: 32px; height: 32px; fill: none; stroke: currentColor; stroke-width: 2.5; }

.brand-name { font-family: 'DM Sans', sans-serif; font-weight: 800; font-size: 32px; letter-spacing: -1px; color: #0f172a; text-transform: uppercase; }
.brand-name span { color: var(--primary); font-weight: 500; }


.login-headline { font-family:'DM Serif Display',serif; font-size:52px; line-height:1.1; margin-bottom:16px; color: var(--text-main); }
.login-headline em { color: var(--primary); opacity: 1; font-style: italic; text-decoration: none; }
.login-sub { font-size:16px; color:var(--text-muted); line-height:1.7; max-width:460px; margin-bottom:48px; }



.feature-pills { display:flex; gap:10px; flex-wrap:wrap; }
.pill {
  display:flex; align-items:center; gap:8px;
  background: #eff6ff; border: 1px solid #dbeafe;
  border-radius: 100px; padding: 8px 16px; font-size:13px; color:var(--primary);
  font-weight: 500;
}
.pill svg { width:14px; height:14px; }


.form-title { font-family:'DM Serif Display',serif; font-size:32px; margin-bottom:8px; color: var(--text-main); }
.form-sub { font-size:14px; color:var(--text-muted); margin-bottom:36px; }

.form-group { margin-bottom: 20px; }
.form-label {
  display:block; font-size:12px; font-weight:600;
  letter-spacing:0.04em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px;
}
.form-control {
  width:100%; background:#fcfcfc; border:1px solid var(--border);
  border-radius:8px; padding:12px 14px; color:var(--text-main);
  font-family:'DM Sans',sans-serif; font-size:15px; outline:none;
  transition: all 0.2s;
}
.form-control:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(37,99,235,0.1); background: #fff; }
.form-control option { background: #fff; color: var(--text-main); }

.btn-login {
  width:100%; background: var(--primary);
  color:#fff; border:none; border-radius:8px; padding:14px;
  font-family:'DM Sans',sans-serif; font-size:15px; font-weight:600; cursor:pointer;
  margin-top:8px; transition: all 0.2s;
  box-shadow: 0 4px 6px -1px rgba(37,99,235,0.2);
}
.btn-login:hover { background: var(--primary-dark); transform:translateY(-1px); box-shadow: 0 10px 15px -3px rgba(37,99,235,0.3); }
.btn-login:active { transform:translateY(0); }


.forgot-link {
  font-size: 11px;
  color: var(--text-muted);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.15s;
}
.forgot-link:hover {
  color: var(--primary);
}


.alert-msg {
  background:#fef2f2; border:1px solid #fee2e2;
  border-radius:8px; padding:12px 14px; font-size:13px;
  color:#991b1b; margin-bottom:16px; display:none;
}

/* ══════════════════════════════════════
   APP LAYOUT
   ══════════════════════════════════════ */
#app-page { flex-direction:row; min-height:100vh; background: var(--bg-main); }

.sidebar {
  width:260px; flex-shrink:0;
  background:var(--bg-sidebar); border-right:1px solid var(--border);
  display:flex; flex-direction:column; padding:24px 0;
  position:fixed; top:0; left:0; bottom:0; z-index:100;
}
.sidebar-brand {
  display:flex; align-items:center; gap:12px;
  padding:0 24px 28px;
}
.sidebar-brand .brand-icon { width:38px; height:38px; font-size:18px; border-radius:10px; background: var(--primary); color:#fff; }
.sidebar-brand .brand-name { font-size:20px; color: var(--text-main); }
.sidebar-brand .brand-name span { color: var(--primary); }

.sidebar-nav { flex:1; padding:20px 12px; overflow-y:auto; }
.nav-section-label {
  font-size:10px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--text-muted);
  padding:0 12px; margin:24px 0 8px;
}
.nav-section-label:first-child { margin-top:0; }
.nav-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:8px;
  font-size:14px; font-weight:500; cursor:pointer;
  transition: all 0.15s;
  color:var(--text-muted); margin-bottom:2px;
}
.nav-item:hover { background:var(--bg-main); color:var(--primary); }
.nav-item.active { background:var(--sidebar-active); color:var(--primary); font-weight: 600; }
.nav-item svg { width:18px; height:18px; flex-shrink:0; }
.nav-badge {
  margin-left:auto; background:var(--primary); color:#fff;
  font-size:10px; font-weight:700; border-radius:100px; padding:2px 7px;
}

.sidebar-user { padding:20px 24px; border-top:1px solid var(--border); background: var(--bg-sidebar); }
.user-card { display:flex; align-items:center; gap:12px; }
.user-avatar {
  width:38px; height:38px; border-radius:10px;
  background: var(--bg-main);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:var(--primary); flex-shrink:0;
  border: 1px solid var(--border);
}
.user-name { font-size:13px; font-weight:600; color: var(--text-main); }
.user-role { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.04em; }
.logout-btn {
  color:var(--muted); cursor:pointer; padding:6px;
  border-radius:8px; transition: color 0.15s, background 0.15s;
}
.logout-btn:hover { color:var(--danger); background:rgba(224,92,92,0.1); }

.main-content { margin-left:260px; flex:1; display:flex; flex-direction:column; min-height:100vh; }

.topbar {
  height:72px; display:flex; align-items:center; padding:0 32px; gap:16px;
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,0.8); backdrop-filter:blur(12px);
  position:sticky; top:0; z-index:50;
}
.topbar-title { font-family:'DM Serif Display',serif; font-size:24px; flex:1; color: var(--text-main); }
.topbar-search {
  display:flex; align-items:center; gap:10px;
  background:#f1f5f9; border:1px solid var(--border);
  border-radius:10px; padding:8px 14px; width:280px;
}
.topbar-search input {
  background:none; border:none; outline:none;
  color:var(--text-main); font-family:'DM Sans',sans-serif; font-size:13px; flex:1;
}
.topbar-search svg { color:var(--text-muted); width:15px; height:15px; flex-shrink:0; }
.topbar-actions { display:flex; gap:10px; }
.icon-btn {
  width:40px; height:40px; border-radius:10px;
  background:#fff; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--text-muted); transition:all 0.15s; position:relative;
}
.icon-btn:hover { color:var(--primary); border-color:var(--primary); background:var(--sidebar-active); }
.icon-btn svg { width:18px; height:18px; }
.notif-dot {
  position:absolute; top:8px; right:8px;
  width:8px; height:8px; border-radius:50%;
  background:var(--danger); border:2px solid #ffffff;
}


.content-area { flex:1; padding:32px; overflow-y:auto; }

.panel { display:none; }
.panel.active { display:block; animation: fadeIn 0.25s ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }

/* ── STATS ── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; margin-bottom:28px; }
.stat-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:16px; padding:22px;
  position:relative; overflow:hidden; transition: all 0.2s;
  box-shadow: var(--card-shadow);
}
.stat-card:hover { transform:translateY(-2px); box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1); }
.stat-card::before {
  content:''; position:absolute; top:0; right:0; width:80px; height:80px;
  border-radius:0 16px 0 80px; opacity:0.08;
}
.stat-card.teal::before { background:var(--teal); }
.stat-card.gold::before { background:var(--gold); }
.stat-card.danger::before { background:var(--danger); }
.stat-card.purple::before { background:#8b5cf6; }
.stat-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; overflow:hidden; }
.stat-card.teal .stat-icon   { background:rgba(14,165,233,0.1); }
.stat-card.gold .stat-icon   { background:rgba(245,158,11,0.1); }
.stat-card.danger .stat-icon { background:rgba(239,68,68,0.1); }
.stat-card.purple .stat-icon { background:rgba(139,92,246,0.1); }
.stat-img { width:100%; height:100%; object-fit:cover; }
.stat-icon svg { width:22px; height:22px; stroke-width:2.2; color:inherit; }
.stat-value { font-family:'DM Sans',serif; font-weight: 700; font-size:32px; line-height:1; margin-bottom:4px; color: var(--text-main); }
.stat-label { font-size:12px; color:var(--text-muted); font-weight:600; text-transform: uppercase; letter-spacing: 0.05em; }
.stat-change { font-size:11px; margin-top:8px; font-weight: 500; }
.stat-change.up { color:var(--success); }
.stat-change.down { color:var(--danger); }


/* ── SECTION HEADERS ── */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.section-title { font-family:'DM Sans',sans-serif; font-weight: 700; font-size:20px; color: var(--text-main); }
.section-actions { display:flex; gap:10px; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:10px; border:none;
  font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600;
  cursor:pointer; transition:all 0.15s;
}
.btn svg { width:15px; height:15px; }
.btn-primary { background:var(--primary); color:#ffffff; box-shadow: 0 4px 6px -1px rgba(37,99,235,0.2); }
.btn-primary:hover { background:var(--primary-dark); transform: translateY(-1px); box-shadow: 0 10px 15px -3px rgba(37,99,235,0.2); }
.btn-outline { background:#ffffff; color:var(--text-main); border:1px solid var(--border); }
.btn-outline:hover { background:var(--bg-main); border-color: var(--text-muted); color: var(--primary); }
.btn-danger { background:#fef2f2; color:var(--danger); border:1px solid #fee2e2; }
.btn-danger:hover { background:#fee2e2; }
.btn-sm { padding:6px 14px; font-size:12px; }


/* ── TABLES ── */
.table-card { background:var(--bg-card); border:1px solid var(--border); border-radius:16px; overflow:hidden; box-shadow: var(--card-shadow); }
table { width:100%; border-collapse:collapse; }
thead th {
  padding:16px 20px; text-align:left;
  font-size:11px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color:var(--text-muted);
  background:#f8fafc; border-bottom:1px solid var(--border);
}
tbody tr { border-bottom:1px solid var(--border); transition:background 0.15s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:var(--bg-main); }
tbody td { padding:16px 20px; font-size:14px; color: var(--text-main); }

/* ── BADGES ── */
.badge { display:inline-block; padding:4px 12px; border-radius:100px; font-size:11px; font-weight:600; border: 1px solid transparent; }
.badge-success { background:#ecfdf5; color:#059669; border-color: #d1fae5; }
.badge-warning { background:#fffbeb; color:#d97706; border-color: #fef3c7; }
.badge-danger  { background:#fef2f2;  color:#dc2626; border-color: #fee2e2; }
.badge-info    { background:#eff6ff;  color:#2563eb; border-color: #dbeafe; }
.badge-muted   { background:#f1f5f9; color:var(--text-muted); border-color: #e2e8f0; }

.avatar-cell { display:flex; align-items:center; gap:10px; }
.mini-avatar {
  width:32px; height:32px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; color:#ffffff; flex-shrink:0;
}


/* ── MODALS ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(15, 23, 42, 0.4); backdrop-filter:blur(4px);
  z-index:200; display:none; align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:#ffffff; border:1px solid var(--border);
  border-radius:24px; width:600px; max-width:95vw; max-height:90vh;
  overflow-y:auto; animation: modalIn 0.2s ease-out;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}
@keyframes modalIn { from{opacity:0;transform:scale(0.98) translateY(10px)} to{opacity:1;transform:scale(1) translateY(0)} }
.modal-header {
  padding:28px 32px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.modal-title { font-family:'DM Sans',sans-serif; font-weight: 700; font-size:24px; color: var(--text-main); }
.modal-close {
  width:36px; height:36px; border-radius:10px;
  background:#f1f5f9; border:none;
  color:var(--text-muted); font-size:18px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all 0.15s;
}
.modal-close:hover { background:#fee2e2; color:#ef4444; }
.modal-body { padding:32px; }
.modal-footer { padding:24px 32px; border-top:1px solid var(--border); background:#f8fafc; display:flex; gap:12px; justify-content:flex-end; border-radius: 0 0 24px 24px; }


.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full { grid-column:1 / -1; }

/* ── MEDICATION SCHEDULE ── */
.schedule-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; }
.shift-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:14px; padding:18px; position:relative;
  box-shadow: var(--card-shadow);
}
.shift-card.active-shift { border-color:rgba(37,99,235,0.4); background: #f0f9ff; }
.shift-card.active-shift::after {
  content:'CURRENT SHIFT'; position:absolute; top:12px; right:12px;
  background:var(--primary); color:#fff;
  font-size:9px; font-weight:700; letter-spacing:0.1em; padding:3px 8px; border-radius:100px;
}
.shift-time { font-size:13px; font-weight:700; color:var(--primary); margin-bottom:12px; }
.shift-patients { display:flex; flex-direction:column; gap:10px; }
.shift-patient {
  display:flex; align-items:center; justify-content:space-between;
  background:#f8fafc; border: 1px solid var(--border); border-radius:10px; padding:10px 12px;
}
.shift-patient-name { font-size:13px; font-weight:600; color: var(--text-main); }
.shift-patient-drug { font-size:11px; color:var(--text-muted); margin-top:2px; }
.check-btn {
  width:28px; height:28px; border-radius:50%; border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:14px; transition:all 0.15s;
}
.check-btn.pending { background:#fffbeb; color:#d97706; }
.check-btn.done    { background:#ecfdf5;  color:#059669; }


/* ── AUDIT LOG ── */
.audit-list { display:flex; flex-direction:column; gap:2px; }
.audit-item {
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 18px; border-radius:10px; font-size:13px; transition:background 0.15s;
}
.audit-item:hover { background:var(--bg-main); }
.audit-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:5px; }
.audit-dot.create { background:var(--success); }
.audit-dot.update { background:var(--teal); }
.audit-dot.delete { background:var(--danger); }
.audit-dot.login  { background:var(--primary); }
.audit-text { flex:1; line-height:1.5; color: var(--text-main); }
.audit-text strong { font-weight:600; color:var(--text-main); }
.audit-time { font-size:11px; color:var(--text-muted); flex-shrink:0; white-space:nowrap; }

/* ── INFO CARD ── */
.info-card { background:var(--bg-card); border:1px solid var(--border); border-radius:14px; padding:20px; box-shadow: var(--card-shadow); }
.info-card-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-muted); margin-bottom:14px; }


.nurse-status-list { display:flex; flex-direction:column; gap:10px; }
.nurse-status-item { display:flex; align-items:center; gap:10px; }
.status-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.status-dot.active { background:var(--success); box-shadow:0 0 6px var(--success); }
.status-dot.off { background:var(--muted); }
.nurse-status-name { font-size:13px; flex:1; }
.nurse-status-shift { font-size:11px; color:var(--muted); }

/* ── GRID HELPERS ── */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; }

/* ── GLOBAL SEARCH OVERLAY ── */
.topbar-search { position:relative; }
.search-results-overlay {
  position:absolute; top:calc(100% + 8px); left:0; right:0;
  background:#ffffff; border:1px solid var(--border);
  border-radius:12px; box-shadow:0 20px 25px -5px rgba(0, 0, 0, 0.1);
  max-height:400px; overflow-y:auto; z-index:1000; display:none;
}
.search-results-overlay.open { display:block; animation: fadeIn 0.15s ease; }
.search-group-label {
  padding:12px 16px 6px; font-size:10px; font-weight:700;
  text-transform:uppercase; color:var(--primary); letter-spacing:0.1em;
}
.search-item {
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  cursor:pointer; transition:background 0.15s; border-bottom:1px solid var(--border);
}
.search-item:hover { background:var(--bg-main); }
.search-item:last-child { border-bottom:none; }
.search-item-info { flex:1; }
.search-item-name { font-size:13px; font-weight:600; color: var(--text-main); }
.search-item-meta { font-size:11px; color:var(--text-muted); }

/* ── NOTIFICATION SIDEBAR ── */
.notif-panel {
  position:fixed; top:0; right:-320px; width:320px; bottom:0;
  background:#ffffff; border-left:1px solid var(--border);
  z-index:1100; box-shadow:-10px 0 40px rgba(0,0,0,0.05);
  display:flex; flex-direction:column; transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.notif-panel.open { transform: translateX(-320px); }
.notif-header {
  padding:24px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.notif-list { flex:1; overflow-y:auto; padding:10px; }
.notif-item {
  padding:14px; border-radius:10px; margin-bottom:8px;
  background:#f8fafc; border:1px solid var(--border);
  transition:all 0.15s;
}
.notif-item:hover { border-color:var(--primary); background:#fff; }
.notif-title { font-size:13px; font-weight:700; color: var(--text-main); margin-bottom:4px; }
.notif-text { font-size:12px; color:var(--text-muted); line-height:1.5; }
.notif-time { font-size:10px; color:var(--text-muted); margin-top:8px; display:block; }

.panel-overlay {
  position:fixed; inset:0; background:rgba(15, 23, 42, 0.4); backdrop-filter:blur(4px);
  z-index:1050; display:none;
}
.panel-overlay.open { display:block; }


/* ── BUTTON OVERRIDES ── */
.btn-xs { padding:4px 10px; font-size:10px; }
.topbar-search input:focus + .search-results-overlay { display:block; }

/* ── PROFILE VIEW MODAL ── */
.profile-view-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 8px 0;
}
.profile-view-item {
  border-bottom: 1px solid #f1f5f9;
  padding-bottom: 8px;
}
.profile-view-item strong {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}
.profile-view-item div {
  font-size: 14px;
  color: var(--text-main);
  font-weight: 500;
}
.profile-view-item.full {
  grid-column: span 2;
}

/* ── TOAST NOTIFICATIONS ── */
.toast-container {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.toast {
  background: #ffffff;
  color: var(--text-main);
  padding: 12px 20px;
  border-radius: 12px;
  box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 500;
  border-left: 4px solid var(--primary);
  animation: toastIn 0.3s ease forwards;
  min-width: 280px;
}
.toast.success { border-left-color: var(--success); }
.toast.error   { border-left-color: var(--danger); }
.toast.info    { border-left-color: var(--teal); }

@keyframes toastIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes toastOut {
  from { opacity: 1; transform: translateX(0); }
  to { opacity: 0; transform: translateX(20px); }
}

/* ══════════════════════════════════════
   RESPONSIVE DESIGN (MOBILE & TABLET)
   ══════════════════════════════════════ */

@media (max-width: 1024px) {
  /* Login Page */
  #login-page { flex-direction: column; overflow-y: auto; align-items: center; }
  .login-left {
    flex: none; width: 100%; padding: 40px 24px;
    text-align: center; align-items: center;
  }
  .login-right {
    width: 100%; max-width: 500px; padding: 40px 24px;
    border-left: none; border-top: 1px solid var(--border);
    margin-bottom: 40px; border-radius: 20px;
    box-shadow: 0 -10px 25px -5px rgba(0,0,0,0.05);
  }
  .login-headline { font-size: 36px; }
  .login-sub { margin-left: auto; margin-right: auto; font-size: 14px; }
  .feature-pills { justify-content: center; }

  /* Dashboard Sidebar */
  .sidebar {
    left: -280px;
    z-index: 1100;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 10px 0 40px rgba(0,0,0,0.1);
  }
  .sidebar.mobile-open { transform: translateX(280px); }
  .main-content { margin-left: 0; }

  /* Topbar */
  .topbar { padding: 0 16px; border-bottom: 1px solid var(--border); }
  .hamburger { display: flex !important; margin-right: 8px; border-color: var(--border); }
  .topbar-search { width: 40px; padding: 0; justify-content: center; background: none; border: none; }
  .topbar-search input { display: none; }
  .topbar-search.expand { position: absolute; left: 16px; right: 100px; width: auto; background: #fff; display: flex; padding: 8px 14px; border: 1px solid var(--border); z-index: 10; }
  .topbar-search.expand input { display: block; }
}

@media (max-width: 768px) {
  .stats-grid { grid-template-columns: 1fr; }
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .section-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .section-actions { width: 100%; }
  .btn { width: 100%; justify-content: center; }

  .table-card { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { min-width: 600px; }

  .modal { width: 95vw; border-radius: 16px; }
  .form-grid { grid-template-columns: 1fr; }

  .content-area { padding: 20px 16px; }

  .stat-card { padding: 18px; }
  .stat-value { font-size: 28px; }
}

/* Hamburger helper */
.hamburger {
  display: none; align-items: center; justify-content: center;
  width: 40px; height: 40px; cursor: pointer; color: var(--text-muted);
  border: 1px solid var(--border); border-radius: 10px;
  background: #fff;
}
.hamburger:hover { color: var(--primary); border-color: var(--primary); }

/* Ensure background grid covers tutto */
#login-page .bg-grid, #login-page .bg-orbs { position: fixed; pointer-events: none; }

