
/* v3.200 CSS architecture: extracted shared component and page styles.
   Keep PHP pages markup-only; add new visual rules here instead of inline <style> blocks. */

/* Extracted utility classes replacing static inline style attributes */
.u-style-002535c2{margin-top:12px;}
.u-style-027c3dd9{margin-top:18px;overflow:auto;}
.u-style-0318d9b9{max-width:560px;margin:auto;}
.u-style-062d4a88{margin-top:24px;}
.u-style-0998cfa6{margin:0 0 10px;}
.u-style-0a73f89f{max-width:1160px;margin:auto;}
.u-style-1386d503{margin:0;}
.u-style-142c2aaa{max-width:620px;margin:auto;}
.u-style-174422e8{margin:18px 0;}
.u-style-1755cc39{max-width:100%;border-radius:12px;}
.u-style-1ae69e31{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px;}
.u-style-1b9b41ec{grid-column:1/-1;}
.u-style-1de90078{grid-template-columns:310px 1fr;}
.u-style-1e2cc36f{align-items:center;}
.u-style-200a92a0{text-align:left;}
.u-style-26530834{display:flex;flex-wrap:wrap;gap:10px;}
.u-style-26e40fae{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.u-style-292f4a1a{display:block;margin-bottom:8px;}
.u-style-2937bfc9{margin-bottom:6px;}
.u-style-29ea06c8{min-height:130px;}
.u-style-2d58a12e{font-size:13px;margin-top:6px;}
.u-style-34229ee6{display:flex;gap:8px;align-items:end;flex-wrap:wrap;}
.u-style-39b4e4ff{display:inline-flex;gap:6px;margin:4px 8px 4px 0;}
.u-style-3ae1f62a{margin-top:20px;}
.u-style-418f8448{border-bottom:1px solid #e5e7eb;padding:12px 0;}
.u-style-44145aaf{display:inline-flex;align-items:center;gap:6px;background:#f1f5f9;border-radius:999px;padding:6px 8px;}
.u-style-44b98a59{font-size:12px;color:#64748b;}
.u-style-4a909ea7{margin-top:18px;}
.u-style-4ad06f01{display:flex;gap:10px;flex-wrap:wrap;}
.u-style-4ddbe905{white-space:nowrap;}
.u-style-4e94087a{margin:24px;padding:18px;border:1px solid #fecaca;background:#fff1f2;color:#991b1b;border-radius:12px;font-family:Arial,sans-serif;}
.u-style-4f15898a{width:auto;}
.u-style-5371db16{margin-top:10px;}
.u-style-53896af7{margin-top:0;}
.u-style-553a645f{margin-top:14px;}
.u-style-5677b988{display:inline;}
.u-style-57f0deb6{border-radius:16px;padding:16px 18px;margin-bottom:16px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;}
.u-style-59619dde{max-width:1000px;margin:auto;}
.u-style-5980152a{background:#f8fafc;margin-top:14px;}
.u-style-5da8ae98{margin-top:12px;border-top:1px solid #e5e7eb;padding-top:10px;}
.u-style-6004e8e7{border-bottom:1px solid #eee;padding:12px 0;}
.u-style-6179637e{margin-bottom:14px;}
.u-style-6261b32b{display:grid;gap:6px;min-width:220px;}
.u-style-63a53d13{display:inline-block;margin-top:8px;}
.u-style-66e076fd{max-width:520px;margin:auto;}
.u-style-6a19fc17{display:inline-block;}
.u-style-6d5cc046{white-space:pre-wrap;max-height:70vh;overflow:auto;}
.u-style-6db57b4d{max-width:800px;margin:auto;}
.u-style-6eefa148{white-space:pre-wrap;background:#fff;padding:12px;border-radius:8px;}
.u-style-710d661f{border:none;border-top:1px solid #e5e7eb;margin:28px 0;}
.u-style-717fdce6{max-width:300px;word-break:break-all;}
.u-style-724f357c{padding:0 8px;color:#94a3b8;}
.u-style-725d934d{max-width:100%;max-height:100%;}
.u-style-7a11f0a8{min-height:180px;}
.u-style-7b310105{border-bottom:1px solid #eee;padding:16px 0;}
.u-style-7c4b6b49{display:inline-flex;gap:6px;align-items:center;}
.u-style-7c88c4b5{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;}
.u-style-84d656b1{white-space:pre-wrap;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:12px;}
.u-style-84d73ea4{max-width:900px;margin:auto;}
.u-style-8512ad77{margin-top:18px;grid-template-columns:2fr 1fr;}
.u-style-886e325e{margin-top:15px;}
.u-style-890603a9{max-width:920px;margin:auto;}
.u-style-8a9a2811{border-top:2px solid currentColor;padding-top:8px;}
.u-style-8ae9c1d1{padding-top:10px;}
.u-style-8b685211{font-size:11px;}
.u-style-8cbb0658{display:flex;justify-content:space-between;margin-top:18px;gap:10px;}
.u-style-909cf2fb{color:#666;}
.u-style-91294d29{display:flex;gap:6px;}
.u-style-91bd79db{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;border-top:1px solid #e5e7eb;padding-top:16px;}
.u-style-923e958f{min-width:180px;}
.u-style-94d4ab6f{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.u-style-9e3c4ccb{margin-top:6px;}
.u-style-a13eaeb9{display:none;background:#f8fafc;margin-top:14px;}
.u-style-a4c604db{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.u-style-a671bb48{margin-top:12px;display:flex;align-items:center;gap:8px;}
.u-style-a7409f75{margin-bottom:10px;}
.u-style-ae8fa21f{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;}
.u-style-b0043ef4{margin-top:16px;}
.u-style-b1121646{margin:4px 0 0;}
.u-style-b493c786{margin:6px 0;}
.u-style-b55f8cb2{background:#f8fafc;}
.u-style-b7aa8dac{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap;}
.u-style-bb1a72ac{word-break:break-all;}
.u-style-bbe59ab1{align-self:end;}
.u-style-bc4cf127{margin-top:16px;border-color:#fecaca;}
.u-style-be08a3fa{overflow:auto;}
.u-style-be254048{margin-bottom:18px;}
.u-style-bf83cf1c{font-size:18px;}
.u-style-c6aeebd4{display:inline;font-weight:600;}
.u-style-cb458930{display:none;}
.u-style-d4316970{margin-top:8px;}
.u-style-d8c7293a{overflow:auto;max-width:100%;}
.u-style-dced6f91{border-bottom:1px solid #e5e7eb;padding:16px 0;}
.u-style-dd3cda6f{max-width:1120px;margin:auto;}
.u-style-df74e8d8{overflow-x:auto;}
.u-style-e0e9ec07{display:flex;gap:8px;flex-wrap:wrap;}
.u-style-e3e611cc{min-height:220px;}
.u-style-e542fead{max-width:720px;margin:auto;}
.u-style-e5e6f834{font-size:20px;}
.u-style-e857d713{margin-top:4px;color:#92400e;}
.u-style-ed2f1750{margin-top:15px;width:100%;}
.u-style-ede87484{align-items:end;}
.u-style-f1acf571{border-color:#f59e0b;}
.u-style-f322cfc1{margin-top:12px;width:100%;}
.u-style-f60339f0{display:flex;gap:6px;align-items:center;}
.u-style-f6e3d7fe{text-align:right;}
.u-style-f7fd6343{margin-top:18px;align-items:start;}
.u-style-fa078b22{margin-top:10px;white-space:pre-wrap;}
.u-style-fa3e1c7d{margin-bottom:12px;}
.u-style-faaa794c{display:flex;gap:8px;align-items:center;}
.u-style-fb1142f9{min-height:260px;}
.u-style-fc4f3d10{width:100%;height:100%;object-fit:cover;}
.u-style-ff78c236{padding-top:31px;}

/* Extracted page-specific styles */

/* Source: index.php */
.course-card-link{display:block;color:inherit;text-decoration:none;cursor:pointer}
.course-title-link{color:inherit;text-decoration:none}
.course-title-link:hover{text-decoration:underline}
.course-cover.course-card-link:hover img{transform:scale(1.02)}
.course-cover img{transition:transform .18s ease}

/* Source: staff_worktime.php */
.worktime-hero{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start;margin-bottom:18px}
.worktime-hero h1{margin:0 0 6px;font-size:28px}.worktime-hero p{margin:0;color:#64748b}
.wt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.wt-stat{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px}.wt-stat strong{display:block;font-size:22px}.wt-stat span{color:#64748b;font-size:13px}.wt-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.wt-tabs a{padding:9px 13px;border:1px solid #dbe3ea;border-radius:999px;text-decoration:none;color:#334155;font-weight:800;background:#fff}.wt-section{scroll-margin-top:90px}.wt-timer{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.wt-table td{vertical-align:top}.wt-badge{display:inline-flex;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:800}.wt-ok{background:#dcfce7;color:#166534}.wt-warn{background:#fef3c7;color:#92400e}.wt-bad{background:#fee2e2;color:#991b1b}.wt-muted{color:#64748b}.wt-small{font-size:12px}.wt-days{display:flex;gap:8px;flex-wrap:wrap}.wt-days label{display:inline-flex;gap:5px;align-items:center;border:1px solid #e5e7eb;border-radius:999px;padding:6px 9px;background:#fff}.wt-days input{width:auto}.wt-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;align-items:end}.wt-card-soft{background:#f8fafc;border:1px solid #e5e7eb}.wt-entry-edit summary{cursor:pointer;font-weight:800;color:#0f766e}.wt-entry-edit-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;min-width:360px;max-width:620px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:10px;margin-top:8px}.wt-entry-edit-form input{min-height:34px;padding:6px 8px}.wt-entry-edit-form label{font-size:11px;color:#64748b}

/* Source: admin_integrations.php */
.integrations-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px}
.integrations-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}
.integrations-stat{padding:16px;border-radius:14px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 8px 24px rgba(15,23,42,.05)}
.integrations-stat b{display:block;font-size:26px;margin-top:6px}
.endpoint-list code{white-space:normal;word-break:break-all}

/* Source: activity_edit.php */
.activity-field{margin-top:10px}.activity-type-form [data-show-for]{transition:opacity .12s ease}

/* Source: admin_reports.php */
.report-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:12px 0 18px}
.report-toolbar .btn{white-space:nowrap}
.report-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.report-summary .card strong{display:block;font-size:26px}
.report-group{margin-top:22px}
.report-group-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.report-group-head h2{margin:0}
.report-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
.report-table{width:100%;border-collapse:collapse;min-width:900px}
.report-table th,.report-table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;white-space:nowrap}
.report-table th{font-size:12px;text-transform:uppercase;color:#64748b;background:#f8fafc}
.report-table tr:last-child td{border-bottom:0}
.report-symbol{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;font-weight:900}
.report-symbol.green{background:#dcfce7;color:#166534}
.report-symbol.red{background:#fee2e2;color:#991b1b}
.report-symbol.orange{background:#ffedd5;color:#9a3412}
.report-symbol.gray{background:#f1f5f9;color:#475569}
.report-group-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:5px}
.report-group-meta span{display:inline-flex;padding:4px 8px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:700}
.report-percent{min-width:100px}
.student-name-btn{border:0;background:transparent;padding:0;margin:0;color:inherit;font:inherit;font-weight:800;cursor:pointer;text-align:left}
.student-name-btn:hover{text-decoration:underline}
.student-row-late{background:#fff8ed}
.student-row-late td:first-child{border-left:4px solid #f59e0b}
.student-row-note td:first-child{border-left:4px solid var(--primary)}
.late-pill,.note-pill{display:inline-flex;align-items:center;gap:5px;margin-top:5px;margin-right:4px;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:800}
.late-pill{background:#ffedd5;color:#9a3412}
.note-pill{background:#e0f2fe;color:#075985}
.student-modal-holder td{padding:0!important;border:0!important;height:0!important;line-height:0!important}
.student-modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:3000;display:none;align-items:center;justify-content:center;padding:18px}
.student-modal-overlay.open{display:flex}
.student-modal{width:min(760px,100%);max-height:88vh;overflow:auto;background:#fff;border-radius:18px;border:1px solid var(--line);box-shadow:0 24px 80px rgba(15,23,42,.28)}
.student-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line);background:#f8fafc}
.student-modal-head h3{margin:0}
.student-modal-close{border:1px solid var(--line);background:#fff;border-radius:10px;width:36px;height:36px;font-size:22px;line-height:1;cursor:pointer}
.student-modal-body{padding:18px 20px}
.student-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:12px 0}
.student-info-card{border:1px solid var(--line);border-radius:12px;background:#fbfcfd;padding:10px}
.student-info-card b{display:block;font-size:18px;color:#1f2937}
.detail-section-title{margin:14px 0 8px;font-size:14px;color:#334155}
.late-detail-list{display:grid;gap:8px}
.late-detail-item{display:grid;grid-template-columns:150px 90px 1fr;gap:10px;align-items:start;padding:9px 10px;border:1px solid #e5edf5;background:#fff;border-radius:10px}
.late-detail-item strong{color:#9a3412}
.note-detail-item{padding:10px;border:1px solid #e5edf5;background:#fbfcfd;border-radius:10px;margin-bottom:8px}
@media(max-width:700px){.late-detail-item{grid-template-columns:1fr}.student-modal-body{padding:14px}.student-modal-head{padding:14px}}
@media(max-width:900px){.report-summary{grid-template-columns:1fr 1fr}.report-group-head{flex-direction:column}.report-toolbar .btn{flex:1}}
@media(max-width:520px){.report-summary{grid-template-columns:1fr}}

/* v3.116 clean student popup UI */
.note-pill{
  display:inline-flex;
  vertical-align:middle;
  margin-left:6px;
  margin-top:0;
  padding:2px 6px;
  border-radius:999px;
  background:#e0f2fe;
  color:#075985;
  font-size:10.5px;
  font-weight:800;
  line-height:1.2;
}
.late-pill{
  display:inline-flex;
  margin-top:5px;
  padding:3px 8px;
  border-radius:999px;
  background:#ffedd5;
  color:#9a3412;
  font-size:11px;
  font-weight:800;
  line-height:1.2;
}
.student-modal-holder,
.student-modal-holder td{
  padding:0!important;
  border:0!important;
  height:0!important;
  line-height:0!important;
  overflow:visible!important;
}
.student-modal-overlay{
  position:fixed!important;
  inset:0!important;
  width:100vw!important;
  height:100vh!important;
  background:rgba(15,23,42,.48)!important;
  z-index:99999!important;
  display:none!important;
  align-items:center!important;
  justify-content:center!important;
  padding:24px!important;
  line-height:1.45!important;
}
.student-modal-overlay.open{
  display:flex!important;
}
.student-modal{
  width:min(780px,calc(100vw - 32px))!important;
  max-height:calc(100vh - 48px)!important;
  overflow:auto!important;
  background:#fff!important;
  border-radius:18px!important;
  border:1px solid #e2e8f0!important;
  box-shadow:0 30px 90px rgba(15,23,42,.34)!important;
  line-height:1.45!important;
}
.student-modal *{
  line-height:1.45;
  white-space:normal;
}
.student-modal-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:16px!important;
  padding:18px 22px!important;
  border-bottom:1px solid #e5e7eb!important;
  background:#f8fafc!important;
  position:sticky;
  top:0;
  z-index:2;
}
.student-modal-head h3{
  margin:0 0 4px!important;
  font-size:22px!important;
  line-height:1.2!important;
  color:#111827!important;
  word-break:break-word;
}
.student-modal-close{
  flex:0 0 auto!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:38px!important;
  height:38px!important;
  border:1px solid #dbe2ea!important;
  background:#fff!important;
  border-radius:10px!important;
  color:#111827!important;
  font-size:22px!important;
  cursor:pointer!important;
}
.student-modal-body{
  padding:20px 22px!important;
}
.student-info-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;
  gap:12px!important;
  margin:0 0 18px!important;
}
.student-info-card{
  border:1px solid #e5e7eb!important;
  border-radius:12px!important;
  background:#fbfcfd!important;
  padding:12px!important;
  min-width:0!important;
}
.student-info-card span{
  display:block!important;
  font-size:12px!important;
  color:#64748b!important;
  margin-bottom:4px!important;
}
.student-info-card b{
  display:block!important;
  font-size:18px!important;
  line-height:1.25!important;
  color:#111827!important;
}
.student-info-card small{
  display:block!important;
  margin-top:4px!important;
  color:#64748b!important;
  font-size:12px!important;
}
.detail-section-title{
  margin:18px 0 10px!important;
  font-size:14px!important;
  color:#334155!important;
}
.late-detail-list{
  display:grid!important;
  gap:10px!important;
}
.late-detail-item{
  display:grid!important;
  grid-template-columns:160px 100px minmax(0,1fr)!important;
  gap:12px!important;
  align-items:start!important;
  padding:12px!important;
  border:1px solid #fde7c7!important;
  background:#fffaf5!important;
  border-radius:12px!important;
}
.late-detail-item strong{
  color:#9a3412!important;
}
.note-detail-item{
  padding:12px!important;
  border:1px solid #e0edf8!important;
  background:#f8fbff!important;
  border-radius:12px!important;
  margin-bottom:10px!important;
}
.note-detail-item strong{
  display:block!important;
  margin-bottom:4px!important;
  color:#334155!important;
}
@media(max-width:700px){
  .student-modal-overlay{padding:12px!important}
  .student-modal{width:calc(100vw - 24px)!important;max-height:calc(100vh - 24px)!important;border-radius:14px!important}
  .student-modal-head{padding:14px!important}
  .student-modal-head h3{font-size:19px!important}
  .student-modal-body{padding:14px!important}
  .student-info-grid{grid-template-columns:1fr!important}
  .late-detail-item{grid-template-columns:1fr!important}
}

/* v4.121 Admin Reports student modal: detach-safe popup rendering */
.student-modal-overlay.open{
  display:flex!important;
  visibility:visible!important;
  opacity:1!important;
}
.student-modal-overlay.open .student-modal{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  transform:none!important;
}
.student-modal-overlay[aria-hidden="true"]{display:none!important;}
.student-modal-overlay[aria-hidden="false"].open{display:flex!important;}

/* Source: attendance.php */
.teacher-weekly-meta{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px}
.teacher-weekly-meta span{display:inline-flex;padding:5px 9px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:800}
.teacher-weekly-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
.teacher-weekly-table{width:100%;border-collapse:collapse;min-width:900px}
.teacher-weekly-table th,.teacher-weekly-table td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;white-space:nowrap}
.teacher-weekly-table th{font-size:12px;text-transform:uppercase;color:#64748b;background:#f8fafc}
.teacher-weekly-table tr:last-child td{border-bottom:0}
.teacher-symbol{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;font-weight:900}
.teacher-symbol.green{background:#dcfce7;color:#166534}
.teacher-symbol.red{background:#fee2e2;color:#991b1b}
.teacher-symbol.orange{background:#ffedd5;color:#9a3412}
.teacher-symbol.gray{background:#f1f5f9;color:#475569}
.teacher-row-late{background:#fff8ed}
.teacher-row-late td:first-child{border-left:4px solid #f59e0b}
.teacher-late-pill{display:inline-flex;margin-left:6px;padding:2px 7px;border-radius:999px;background:#ffedd5;color:#9a3412;font-size:11px;font-weight:800}
.teacher-percent{min-width:110px}

/* Source: admin_users.php */
.student-name-button{border:0;background:transparent;color:#005486;font-weight:800;cursor:pointer;padding:0;text-align:left}
.student-name-button:hover{text-decoration:underline}.student-modal{display:none!important;position:fixed;inset:0;z-index:9999;background:rgba(15,23,42,.52);padding:28px 14px;overflow:auto}.student-modal.is-open{display:block!important}.student-modal-head{display:flex;justify-content:space-between;gap:16px;align-items:center;max-width:1120px;margin:0 auto;background:#fff;padding:18px 22px;border-bottom:1px solid #e5e7eb;border-radius:18px 18px 0 0}.student-modal-body{max-width:1120px;margin:0 auto 32px;background:#fff;padding:22px;max-height:none;overflow:visible;border-radius:0 0 18px 18px;box-shadow:0 24px 70px rgba(15,23,42,.28)}.body-modal-open{overflow:hidden}.student-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.student-metric{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:12px}.note-item{border:1px solid #e5e7eb;border-radius:14px;padding:12px;background:#fff;margin:10px 0}.note-meta{font-size:12px;color:#64748b}.danger-zone{border-color:#fecaca;background:#fff7f7}.student-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.search-panel{padding:14px 16px;border-radius:16px;background:#fbfdff}.search-panel h2{font-size:16px;margin:0 0 10px}.search-panel .grid-4{gap:10px}.search-panel label{font-size:12px;margin-bottom:4px;color:#64748b}.search-panel input,.search-panel select{min-height:38px;padding:8px 10px;font-size:13px;border-radius:10px}.search-panel details{margin-top:8px}.search-panel summary{cursor:pointer;font-weight:700;font-size:13px;color:#334155}.search-panel p{margin:12px 0 0}.search-panel .btn{padding:8px 12px;font-size:13px}.table td{vertical-align:top}
.student-modal-head{position:sticky;top:0;z-index:2}.student-modal-layout{display:grid;grid-template-columns:240px 1fr;gap:18px}.student-profile-nav{position:sticky;top:86px;align-self:start;background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:10px}.student-profile-tab{width:100%;border:0;background:transparent;border-radius:12px;padding:11px 12px;text-align:left;font-weight:800;color:#475569;cursor:pointer;margin:2px 0}.student-profile-tab:hover{background:#eef7f6}.student-profile-tab.is-active{background:#0f766e;color:#fff}.student-profile-panel{display:none}.student-profile-panel.is-active{display:block}.student-panel-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.comments-compose-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:14px;margin-top:16px}.comments-list{max-height:420px;overflow:auto;padding-right:4px}.comment-item{border:1px solid #e5e7eb;border-radius:16px;background:#fff;padding:14px;margin:12px 0}.comment-item.is-highlight{border-color:#0f766e;box-shadow:0 0 0 4px rgba(15,118,110,.12)}.comment-meta{font-size:12px;color:#64748b;margin-bottom:8px}.mention-pill{display:inline-flex;align-items:center;gap:4px;border:1px solid #c6ebe3;background:#e7f6f3;color:#0f5149;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:800;margin:4px 4px 0 0}.mention-editor-wrap{position:relative}.mention-suggest-menu{display:none;position:absolute;left:0;right:0;top:100%;z-index:10060;background:#fff;border:1px solid #dbe3ea;border-radius:12px;box-shadow:0 18px 44px rgba(15,23,42,.16);max-height:230px;overflow:auto;padding:6px;margin-top:4px}.mention-suggest-menu.is-open{display:block}.mention-suggest-option{display:flex;width:100%;border:0;background:#fff;text-align:left;gap:8px;align-items:flex-start;padding:9px 10px;border-radius:10px;cursor:pointer}.mention-suggest-option:hover,.mention-suggest-option.is-active{background:#e7f6f3}.mention-suggest-name{font-weight:800;color:#0f172a}.mention-suggest-meta{font-size:12px;color:#64748b}.mention-selected-list{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 0}.mention-selected-chip{display:inline-flex;gap:6px;align-items:center;background:#e7f6f3;border:1px solid #c6ebe3;color:#0f5149;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}.mention-selected-chip button{border:0;background:transparent;cursor:pointer;font-weight:900;color:#334155}.mention-help{font-size:12px;color:#64748b;margin-top:6px}.comment-inline-message{font-size:13px;font-weight:800;margin-top:10px}.comment-inline-message.is-error{color:#b91c1c}.comment-inline-message.is-success{color:#0f766e}.custom-field-inline-message{font-size:13px;font-weight:800;margin-top:10px}.custom-field-inline-message.is-error{color:#b91c1c}.custom-field-inline-message.is-success{color:#0f766e}.custom-field-inline-message.is-saving{color:#64748b}.custom-field-list{display:grid;gap:12px}.custom-field-row{border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:12px}.custom-field-row-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.custom-field-meta{font-size:12px;color:#64748b}.stars-display{font-size:18px;letter-spacing:1px;color:#92400e}.inline-check{display:inline-flex;gap:8px;align-items:center}.inline-check input{width:auto}.custom-field-create{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:14px;margin-top:18px}.custom-field-admin-settings{margin-top:10px;border-top:1px dashed #e5e7eb;padding-top:10px}.custom-field-admin-settings summary{cursor:pointer;font-weight:800;color:#0f766e}.custom-field-settings-form{margin-top:10px}@media(max-width:900px){.student-modal-layout{grid-template-columns:1fr}.student-profile-nav{position:static;display:flex;overflow:auto}.student-profile-tab{white-space:nowrap}}
.user-toolbar{display:flex;gap:14px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;margin-bottom:16px}.user-toolbar-copy{display:flex;flex-direction:column;gap:4px}.user-toolbar-title-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.user-toolbar-title-line h2{margin:0;font-size:28px;line-height:1.15}.user-toolbar-help{font-size:13px;font-weight:800;color:#64748b}.user-toolbar-subtle{margin:0;color:#64748b;font-size:13px}.users-search-shell{padding:16px 18px;border-radius:18px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 8px 28px rgba(15,23,42,.04)}.users-search-head{display:flex;gap:18px;align-items:center;border-bottom:1px solid #edf2f7;padding-bottom:12px;margin-bottom:14px}.users-search-tab{border:0;background:transparent;padding:0 0 10px;font-size:14px;font-weight:800;color:#64748b;cursor:pointer;border-bottom:2px solid transparent}.users-search-tab.is-active{color:#0f172a;border-bottom-color:#0f766e}.users-search-form{display:grid;gap:12px}.users-search-row{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(150px,1fr)) auto;gap:10px;align-items:center}.users-search-row.users-search-advanced-row{grid-template-columns:repeat(4,minmax(150px,1fr));align-items:start}.users-search-field{display:flex;flex-direction:column;gap:5px;min-width:0}.users-search-field label{font-size:11px;font-weight:700;color:#94a3b8;margin:0 2px}.users-search-field input,.users-search-field select{width:100%;min-height:40px;border:1px solid #dbe3ea;border-radius:12px;background:#fbfcfe;padding:9px 12px;font-size:13px;box-shadow:none}.users-search-field input:focus,.users-search-field select:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 3px rgba(15,118,110,.10);background:#fff}.users-search-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex-wrap:wrap}.users-search-actions .btn{padding:8px 12px;font-size:13px}.users-filter-toggle{padding:8px 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:#0f766e;font-weight:800;cursor:pointer}.users-search-advanced{display:none;padding-top:2px}.users-search-advanced.is-open{display:block}.users-search-tip{font-size:12px;color:#94a3b8}.create-drawer{display:none!important;position:fixed;inset:0;z-index:10000;background:rgba(15,23,42,.50)}@media(max-width:1080px){.users-search-row{grid-template-columns:repeat(2,minmax(180px,1fr))}.users-search-actions{grid-column:1 / -1;justify-content:flex-start}.users-search-row.users-search-advanced-row{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media(max-width:640px){.users-search-shell{padding:14px}.users-search-head{gap:14px;flex-wrap:wrap}.users-search-row,.users-search-row.users-search-advanced-row{grid-template-columns:1fr}.user-toolbar-title-line h2{font-size:24px}}.create-drawer.is-open{display:block!important}.create-drawer-panel{position:absolute;right:0;top:0;bottom:0;width:min(820px,100%);background:#fff;box-shadow:-18px 0 55px rgba(15,23,42,.25);display:flex;flex-direction:column}.create-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.create-drawer-body{display:grid;grid-template-columns:280px 1fr;min-height:0;overflow:auto}.create-drawer-info{background:#f8fafc;padding:22px;border-right:1px solid #e5e7eb}.create-drawer-form{padding:22px}.create-tabs{display:flex;gap:10px;border-bottom:1px solid #dbe3ea;margin-bottom:18px}.create-tab{border:0;background:transparent;padding:12px 14px;font-weight:800;color:#64748b;cursor:pointer;border-bottom:2px solid transparent}.create-tab.is-active{color:#0f766e;border-bottom-color:#0f766e}.create-tab-panel{display:none}.create-tab-panel.is-active{display:block}.course-picker{border:1px solid #e5e7eb;border-radius:14px;max-height:340px;overflow:auto;background:#fff}.course-choice{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border-bottom:1px solid #f1f5f9}.course-choice:last-child{border-bottom:0}.course-choice input{width:auto;margin-top:4px}.course-choice-title{font-weight:800}.combo-multiselect{position:relative}.combo-box{min-height:50px;border:1px solid #dbe3ea;border-radius:12px;background:#fff;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 40px 8px 10px;cursor:text}.combo-box:after{content:'⌄';position:absolute;right:14px;top:13px;color:#64748b;font-weight:800}.combo-box:focus-within{border-color:#0f766e;box-shadow:0 0 0 3px rgba(15,118,110,.10)}.combo-input{border:0!important;outline:0!important;box-shadow:none!important;flex:1;min-width:180px;padding:8px!important;background:transparent!important}.combo-chip{display:inline-flex;align-items:center;gap:6px;background:#e7f6f3;border:1px solid #c6ebe3;border-radius:8px;padding:6px 9px;font-size:13px;font-weight:700;color:#0f5149}.combo-chip button{border:0;background:transparent;cursor:pointer;font-size:16px;line-height:1;color:#334155}.combo-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:10050;background:#fff;border:1px solid #dbe3ea;border-radius:12px;box-shadow:0 18px 44px rgba(15,23,42,.16);max-height:260px;overflow:auto;padding:6px}.combo-multiselect.is-open .combo-menu{display:block}.combo-option{display:flex;gap:10px;align-items:flex-start;padding:10px;border-radius:10px;cursor:pointer}.combo-option:hover,.combo-option.is-selected{background:#e7f6f3}.combo-option input{width:auto;margin-top:3px}.combo-option-title{font-weight:800}.combo-empty{display:none;color:#64748b;padding:12px}.drawer-muted-box{border:1px solid #e5e7eb;border-radius:14px;background:#fff;padding:14px;margin-bottom:18px}@media(max-width:800px){.create-drawer-body{grid-template-columns:1fr}.create-drawer-info{border-right:0;border-bottom:1px solid #e5e7eb}.create-drawer-panel{width:100%}}

.student-filter{display:<?= $viewType==='students'?'block':'none' ?>}.staff-filter{display:<?= $viewType==='staff'?'block':'none' ?>}

.users-topbar{padding:0 0 18px;margin:0}
.users-title-block{display:block}
.users-title-line{display:flex;align-items:center;gap:6px;margin:0 0 5px}
.users-title-line h2{font-size:20px;line-height:1.1;margin:0;color:#444;font-weight:800}
.users-help-dot{width:16px;height:16px;border:2px solid #5f6368;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:#5f6368}
.users-learn{font-size:13px;color:#444;font-weight:700}
.users-title-block p{margin:0;color:#555;font-size:14px;line-height:1.35}
.users-top-actions{display:flex;align-items:center;gap:18px;margin-top:16px}
.users-top-actions .btn{padding:9px 14px;border-radius:3px;font-size:14px;font-weight:800}
.users-text-action{border:0;background:transparent;color:#444;font-size:14px;font-weight:700;padding:7px 0;opacity:.95}
.users-search-area{background:#f3f3f3;border-top:1px solid #e1e1e1;margin:0 -32px 20px;padding:16px 32px}
.users-search-shell{width:min(1298px,100%);background:#fff;border:0;border-radius:2px;padding:0;box-shadow:none}
.users-search-head{display:flex;align-items:flex-end;gap:0;height:48px;border-bottom:1px solid #e0e0e0;padding:0 12px;margin:0}
.users-search-tab{height:48px;border:0;background:transparent;padding:0 13px;margin:0;color:#6b7280;font-size:13px;font-weight:800;border-bottom:2px solid transparent;cursor:pointer}
.users-search-tab.is-active{color:#222;border-bottom-color:#009681}
.users-search-form{padding:12px 12px 12px;display:block}
.users-search-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.users-search-field{position:relative;display:block;min-width:0}
.users-search-field input,.users-search-field select{height:32px;min-height:32px;border:1px solid #c9c9c9;border-radius:4px;background:#fff;color:#555;font-size:13px;line-height:30px;padding:0 11px;box-shadow:none}
.users-search-field input:focus,.users-search-field select:focus{outline:none;border-color:#009681;box-shadow:0 0 0 2px rgba(0,150,129,.10)}
.users-search-main input{width:200px;padding-right:34px}
.users-search-field select{width:168px}
.users-search-field input[type=date]{width:168px}
.users-search-icon{position:absolute;right:10px;top:6px;color:#777;font-size:16px;pointer-events:none}
.users-hidden-submit{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.users-filter-line{display:flex;align-items:center;gap:10px;margin-top:12px}
.users-tag-filter{height:23px;border:1px solid #009681;background:#fff;color:#009681;border-radius:3px;padding:0 10px;font-size:13px;font-weight:800;cursor:pointer}
.users-reset-link{font-size:12px;color:#64748b;text-decoration:none}
.users-search-advanced{display:none;margin-top:10px;border-top:1px solid #f0f0f0;padding-top:10px}
.users-search-advanced.is-open{display:block}
.users-search-advanced-row{gap:8px}
.users-search-actions{display:flex;gap:8px;align-items:center}
.users-search-actions .btn{height:32px;padding:6px 12px;font-size:13px}
@media(max-width:900px){
  .users-search-area{margin:0 -16px 18px;padding:14px 16px}
  .users-search-shell{width:100%}
  .users-search-row{align-items:stretch}
  .users-search-main input,.users-search-field select,.users-search-field input[type=date]{width:100%}
  .users-search-field{flex:1 1 170px}
}


/* v3.143: prevent horizontal page overflow in the compact Users search */
html,body{max-width:100%;overflow-x:hidden}
.users-search-area,.users-search-shell,.users-search-form,.users-search-row,.users-search-field{box-sizing:border-box;max-width:100%}
.users-search-area{margin-left:0!important;margin-right:0!important;width:100%!important;overflow:hidden}
.users-search-shell{width:100%!important;max-width:1298px!important;overflow:hidden}
.users-search-row{width:100%;min-width:0;overflow:visible}
.users-search-field{flex:0 1 auto}
.users-search-main{flex:0 1 200px}
.users-search-main input{max-width:100%}
.users-search-field select,.users-search-field input[type=date]{max-width:100%}
.student-filter{display:<?= $viewType==='students'?'block':'none' ?>!important}
.staff-filter{display:<?= $viewType==='staff'?'block':'none' ?>!important}
.users-search-row .student-filter{display:<?= $viewType==='students'?'block':'none' ?>!important}
.users-search-row .staff-filter{display:<?= $viewType==='staff'?'block':'none' ?>!important}
.users-search-head .student-filter{display:<?= $viewType==='students'?'inline-flex':'none' ?>!important}
.users-filter-line.student-filter{display:<?= $viewType==='students'?'flex':'none' ?>!important}
.users-search-advanced.student-filter{display:none!important}
.users-search-advanced.student-filter.is-open{display:<?= $viewType==='students'?'block':'none' ?>!important}
@media(max-width:900px){
  .users-search-area{padding-left:12px!important;padding-right:12px!important}
  .users-search-field{flex:1 1 170px}
}


/* v3.144: align compact search white box width with the student table/card width */
.users-search-area{padding-left:24px!important;padding-right:24px!important}
.users-search-shell{width:100%!important;max-width:none!important}
@media(max-width:900px){
  .users-search-area{padding-left:12px!important;padding-right:12px!important}
}

/* Source: learn.php */
.learn-course-top{display:flex;align-items:center;gap:14px;margin:0 0 18px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#f8fafc,#ecfeff)}
.learn-teacher-avatar{width:76px;height:76px;border-radius:999px;object-fit:cover;object-position:center;border:4px solid #fff;box-shadow:0 12px 30px rgba(15,23,42,.14);flex:0 0 auto}
.learn-teacher-default{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#ccfbf1);color:#0f766e;font-weight:900;font-size:24px}
.learn-course-top .teacher-kicker{display:block;text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:900;color:#0f766e}
.learn-course-top strong{display:block;font-size:18px}.learn-course-top p{margin:3px 0 0}
.learn-substitute-notice{display:flex;align-items:center;gap:12px;margin:0 0 18px;padding:13px 16px;border:1px solid #bfdbfe;border-radius:18px;background:linear-gradient(135deg,#eff6ff,#f0fdfa)}
.learn-substitute-notice .sub-kicker{display:block;text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:900;color:#1d4ed8}
.learn-substitute-notice strong{display:block;font-size:17px}.learn-substitute-notice p{margin:3px 0 0}
.learn-substitute-avatar{width:56px;height:56px;border-radius:999px;object-fit:cover;object-position:center;border:3px solid #fff;box-shadow:0 10px 24px rgba(15,23,42,.14);flex:0 0 auto}
.learn-substitute-default{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#ccfbf1);color:#1d4ed8;font-weight:900;font-size:21px}
@media(max-width:680px){.learn-course-top{align-items:flex-start}.learn-teacher-avatar{width:62px;height:62px}}

/* Source: community.php */
.community-course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:18px}.community-course-card{display:block;text-decoration:none;color:inherit}.community-layout{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:18px;align-items:start}.community-sidebar .course-link{display:block;padding:12px;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:8px;text-decoration:none;color:inherit;background:#fff}.community-sidebar .course-link.active{border-color:#009688;background:#ecfdf5}.community-post-meta,.community-comment-meta{color:#64748b;font-size:13px}.community-comments{margin-top:16px;border-top:1px solid #e5e7eb;padding-top:12px}.community-comment{position:relative;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;margin:8px 0}.community-comment-form textarea{min-height:70px}.community-actions{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.community-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:999px;border:1px solid #dbe3ef;background:#f8fafc;color:#334155;font-size:12px}.community-chip.warn{border-color:#fde68a;background:#fffbeb}.community-chip.danger{border-color:#fecaca;background:#fef2f2}.community-chip.ok{border-color:#bbf7d0;background:#f0fdf4}.community-attachments a{display:inline-flex;margin:4px 6px 4px 0}.community-poll-option{display:grid;grid-template-columns:1fr auto;gap:8px;border:1px solid #e5e7eb;border-radius:10px;padding:9px;margin:7px 0}.community-inline-form{display:inline}.community-inline-form button{margin:0}.community-edit-box{display:none;border:1px dashed #cbd5e1;border-radius:12px;padding:12px;margin-top:10px;background:#fbfdff}.community-modal{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:50;display:none;align-items:center;justify-content:center;padding:18px}.community-modal:target{display:flex}.community-modal-card{background:#fff;border-radius:18px;max-width:760px;width:100%;padding:18px;box-shadow:0 22px 80px rgba(0,0,0,.25);max-height:90vh;overflow:auto}.mention-help{font-size:12px;color:#64748b;margin-top:-6px}
.community-post-card{position:relative;overflow:visible}.community-post-card:hover{box-shadow:0 14px 35px rgba(15,23,42,.09)}.community-post-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding-right:44px}.community-more{position:absolute;top:14px;right:14px;z-index:5}.community-more-toggle{width:34px;height:34px;border-radius:999px;border:1px solid #dbe3ef;background:#fff;cursor:pointer;font-weight:700;color:#334155}.community-more-menu{display:none;position:absolute;right:0;top:38px;min-width:180px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 16px 45px rgba(15,23,42,.16);padding:6px}.community-more:hover .community-more-menu,.community-more:focus-within .community-more-menu{display:block}.community-more-menu button,.community-more-menu a{display:block;width:100%;text-align:left;border:0;background:#fff;color:#111827;padding:9px 10px;border-radius:9px;text-decoration:none;font:inherit;cursor:pointer}.community-more-menu button:hover,.community-more-menu a:hover{background:#f1f5f9}.community-more-menu .danger{color:#b91c1c}.community-reactions{display:flex;align-items:center;gap:6px;margin:12px 0 6px;opacity:.72;transition:opacity .15s ease}.community-post-card:hover .community-reactions{opacity:1}.community-reaction-button{border:0;background:#f1f5f9;border-radius:999px;padding:7px 10px;cursor:pointer;color:#334155}.community-reaction-button:hover{background:#e0f2f1;color:#00796b}.community-moderation-row{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0;opacity:0;max-height:0;overflow:hidden;transition:.15s ease}.community-post-card:hover .community-moderation-row,.community-post-card:focus-within .community-moderation-row{opacity:1;max-height:80px}.community-comment-tools{position:absolute;right:10px;top:8px;display:flex;gap:6px;opacity:0;transition:.15s ease}.community-comment:hover .community-comment-tools,.community-comment:focus-within .community-comment-tools{opacity:1}.community-icon-btn{border:1px solid #dbe3ef;background:#fff;border-radius:8px;padding:4px 7px;font-size:12px;cursor:pointer;text-decoration:none;color:#334155}.community-icon-btn.danger{color:#b91c1c}.community-file-help{font-size:12px;color:#64748b;margin-top:4px}.community-ajax-busy{opacity:.55;pointer-events:none}.community-inline-error{margin:8px 0;color:#b91c1c;font-size:13px}.community-comment-body{padding-right:90px}@media(max-width:900px){.community-layout{grid-template-columns:1fr}.community-moderation-row,.community-comment-tools{opacity:1;max-height:none}.community-reactions{opacity:1}}

/* Source: course_builder.php */
.builder-drag-note{margin-bottom:14px}.builder-section{transition:box-shadow .16s ease,opacity .16s ease,border-color .16s ease}.builder-section.dragging,.builder-activity.dragging{opacity:.45}.builder-section.drag-over{box-shadow:0 0 0 3px rgba(0,152,121,.14)}.builder-section-side{display:flex;flex-direction:column;align-items:center;gap:8px}.builder-section-titlebar{cursor:grab}.builder-section-titlebar:active{cursor:grabbing}.builder-section-heading-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.quick-section-status-form{display:flex;align-items:center;gap:8px;margin-top:2px;white-space:nowrap}.quick-section-status-form select{min-width:130px;padding:7px 10px}.section-status-label{font-size:12px;color:#667085;margin:0}.inline-drag-hint,.inline-material-drag-hint{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;min-width:24px;height:24px;border-radius:8px;background:#eef2f6;color:#475467;font-weight:800;font-size:13px;vertical-align:middle}.builder-activity{cursor:grab}.builder-activity:active{cursor:grabbing}.activity-dropzone{min-height:44px;border-radius:12px;padding:4px;transition:background .15s ease,outline-color .15s ease}.activity-dropzone:empty{border:1px dashed #cfd8e3;background:#f8fafc}.activity-dropzone:empty:before{content:'Drop materials here';display:block;color:#98a2b3;padding:12px}.activity-dropzone.drag-over{outline:2px dashed #009879;background:#eefbf7}.type-help{margin:12px 0;padding:10px 12px;border-radius:12px;background:#eefbf7;color:#0f766e;border:1px solid #b7eadb}.add-activity-card .activity-field{margin-top:10px}.auto-order-status{position:fixed;right:18px;bottom:18px;z-index:9999;padding:10px 14px;border-radius:12px;background:#0f172a;color:#fff;box-shadow:0 10px 30px rgba(15,23,42,.18);opacity:0;transform:translateY(10px);transition:opacity .18s ease,transform .18s ease;pointer-events:none}.auto-order-status.show{opacity:1;transform:translateY(0)}.auto-order-status.error{background:#9f1239}.auto-order-status.success{background:#047857}@media(max-width:800px){.builder-section-side{align-items:flex-start}.builder-activity{align-items:flex-start}.builder-section-heading-row{display:block}.quick-section-status-form{margin-top:8px}.inline-drag-hint,.inline-material-drag-hint{display:none}}

/* Source: course_builder.php */
.att-week-toolbar{display:flex;gap:10px;align-items:end;justify-content:space-between;flex-wrap:wrap;margin:0 0 14px}
.att-week-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.att-single-nav{padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#f8fafc}.att-week-table-wrap{overflow-x:auto}.att-week-table th,.att-week-table td{text-align:center;vertical-align:middle;min-width:96px}.att-week-table th:first-child,.att-week-table td:first-child{text-align:left;min-width:210px;position:sticky;left:0;background:#fff;z-index:1}.att-cell{display:flex;flex-direction:column;gap:4px;align-items:center}.att-status-dot{display:inline-flex;align-items:center;justify-content:center;min-width:74px;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:800}.att-present{background:#dcfce7;color:#166534}.att-late{background:#fef3c7;color:#92400e}.att-absent{background:#fee2e2;color:#991b1b}.att-excused,.att-vacation{background:#e0f2fe;color:#075985}.att-empty{background:#f1f5f9;color:#64748b}.att-note-small{font-size:11px;color:#64748b;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.att-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-top:12px}.att-summary-box{padding:12px;border:1px solid var(--line);border-radius:14px;background:#f8fafc}.att-summary-box b{display:block;font-size:22px}.att-percent-pill{display:inline-flex;align-items:center;justify-content:center;min-width:76px;padding:6px 12px;border-radius:999px;font-weight:900;font-size:13px}.att-percent-good{background:#dcfce7;color:#166534}.att-percent-mid{background:#fef3c7;color:#92400e}.att-percent-bad{background:#fee2e2;color:#991b1b}.att-week-table th.att-percent-col,.att-week-table td.att-percent-col{min-width:110px;background:#f8fafc}

/* Source: profile.php */
.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.profile-card h2{margin-top:0}
.profile-meta{display:grid;gap:8px;margin:12px 0}
.profile-meta-row{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#f8fafc}
.profile-meta-row span:first-child{color:#64748b}
.profile-help{font-size:13px;color:#64748b;margin-top:8px}
.teacher-photo-row{display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:center}
.teacher-avatar-preview{width:88px;height:88px;border-radius:999px;object-fit:cover;object-position:center;border:4px solid #fff;box-shadow:0 12px 30px rgba(15,23,42,.16);background:linear-gradient(135deg,#e0f2fe,#ccfbf1);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:900;color:#0f766e}
@media(max-width:680px){.teacher-photo-row{grid-template-columns:1fr}.teacher-avatar-preview{width:82px;height:82px}}

/* Source: courses.php */
.course-card-link{display:block;color:inherit;text-decoration:none;cursor:pointer}
.course-title-link{color:inherit;text-decoration:none}
.course-title-link:hover{text-decoration:underline}
.course-cover.course-card-link:hover img{transform:scale(1.02)}
.course-cover img{transition:transform .18s ease}

/* Source: admin_attendance.php */
.attendance-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.attendance-kpis .card strong{font-size:26px;display:block}
.attendance-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.attendance-tabs a{padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;font-weight:700}
.attendance-tabs a.active{background:var(--primary);color:#fff}
.attendance-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:end}
.attendance-row-vacation{background:#f8fafc}
@media(max-width:900px){.attendance-kpis{grid-template-columns:1fr 1fr}.attendance-actions{display:grid}.attendance-actions .btn{width:100%}}
@media(max-width:520px){.attendance-kpis{grid-template-columns:1fr}}

/* Source: admin_substitute_teachers.php */
.sub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.sub-status{display:inline-flex;padding:4px 9px;border-radius:999px;font-size:12px;font-weight:800}.sub-now{background:#dcfce7;color:#166534}.sub-future{background:#dbeafe;color:#1d4ed8}.sub-expired{background:#f1f5f9;color:#475569}.sub-cancelled{background:#fee2e2;color:#991b1b}.sub-note{max-width:340px;white-space:pre-wrap}.sub-card-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin-top:10px}.sub-card-info div{padding:10px;border:1px solid var(--line);border-radius:12px;background:#f8fafc}#subOriginalTeacher[readonly]{background:#f8fafc;color:#0f766e;font-weight:800}

/* Source: admin_marketing.php */
.marketing-editor textarea{min-height:220px;font-family:ui-monospace,Consolas,monospace}.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px}.marketing-help code{background:#f1f5f9;padding:2px 6px;border-radius:6px}.campaign-actions{display:flex;gap:6px;flex-wrap:wrap}

/* Source: course.php */
.course-teacher-strip{display:inline-flex;align-items:center;gap:12px;margin:12px 0 18px;padding:10px 14px;border:1px solid rgba(255,255,255,.28);border-radius:999px;background:rgba(255,255,255,.16);backdrop-filter:blur(10px)}
.course-teacher-avatar{width:64px;height:64px;border-radius:999px;object-fit:cover;object-position:center;border:3px solid rgba(255,255,255,.9);box-shadow:0 10px 22px rgba(15,23,42,.22)}
.course-teacher-default{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#ccfbf1);color:#0f766e;font-weight:900;font-size:21px}
.course-teacher-strip strong{display:block;font-size:17px}.course-teacher-strip small,.course-teacher-label{display:block;color:rgba(15,23,42,.72);font-size:12px}.course-teacher-label{text-transform:uppercase;letter-spacing:.06em;font-weight:800}

/* Source: admin_branding.php */
.branding-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.branding-tabs a{display:inline-flex;align-items:center;gap:7px;padding:10px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;color:#334155;font-weight:800}
.branding-tabs a.active{background:var(--primary);border-color:var(--primary);color:#fff}
.branding-panel{display:none}
.branding-panel.active{display:block}
.branding-savebar{position:sticky;bottom:14px;z-index:20;margin-top:18px;padding:12px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);box-shadow:0 14px 34px rgba(15,23,42,.10);display:flex;gap:10px;justify-content:flex-end;align-items:center}.branding-code-area{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;line-height:1.45}.branding-linked-note{background:#ecfeff;border:1px solid #a5f3fc;color:#155e75;border-radius:12px;padding:10px 12px;margin:10px 0}.branding-preview-actions{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 12px}
@media(max-width:700px){.branding-tabs{display:grid;grid-template-columns:1fr 1fr}.branding-tabs a{justify-content:center}.branding-savebar{justify-content:stretch}.branding-savebar .btn{width:100%}}

/* Source: verify-certificate.php */
body{background:#f6f8fb}.public-cert-wrap{max-width:1180px;margin:30px auto;padding:0 16px}.verify-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.05)}@media print{.no-print{display:none}.verify-card{border:0;box-shadow:none}.public-cert-wrap{margin:0;max-width:none}}

/* Source: admin_media.php */
.media-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.media-thumb{max-width:72px;max-height:54px;border-radius:8px;border:1px solid #e5e7eb;object-fit:cover}.media-modal{position:fixed;inset:0;background:rgba(15,23,42,.48);z-index:9999;display:none;align-items:center;justify-content:center;padding:18px}.media-modal.is-open{display:flex}.media-modal-card{width:min(680px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(15,23,42,.24);border:1px solid #e5e7eb}.media-modal-head{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:18px 20px;border-bottom:1px solid #eef2f7}.media-modal-head h2{margin:0;font-size:20px}.media-modal-body{padding:20px}.media-modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.media-modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:18px}.media-close{border:0;background:#f1f5f9;border-radius:999px;width:34px;height:34px;font-size:22px;line-height:1;cursor:pointer}.media-close:hover{background:#e2e8f0}


/* Additional extracted utility classes */
.u-style-b121cdae{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;}
.u-style-d78b9562{border-bottom:1px solid #e5e7eb;padding:14px 0;}

/* v3.200 dynamic-state utility classes */
.u-hidden{display:none!important;}
.u-invisible-soft{opacity:.72;}
.u-grid-full{grid-column:1/-1;}
.u-float-right{float:right;}
.u-bg-feedback-new{background:#f0fdf4;}
.u-link-inherit{text-decoration:none;color:inherit;}
.u-media-full{width:100%;}
.u-media-preview{max-width:100%;height:auto;border-radius:14px;}
.cert-generated-inner{position:absolute;pointer-events:none;}
.cert-generated-box{position:absolute;display:flex;align-items:center;overflow:hidden;white-space:normal;}
.cert-generated-qr{justify-content:center;background:#fff;border:1px solid rgba(15,23,42,.12);border-radius:10px;padding:6px;}
.cert-generated-signature{flex-direction:column;justify-content:flex-end;font-family:Georgia,serif;}
.cert-generated-text{line-height:1.15;}
.cert-signature-line{width:100%;border-top:2px solid currentColor;padding-top:8px;}

.branded-login-page{max-width:980px;margin:auto;}
.staff-permissions-box.is-hidden,.calendar-target-course-box.is-hidden,.quiz-step.is-hidden{display:none!important;}
/* Manually named utility classes from dynamic-template cleanup */
.u-style-b8d14e3f{margin-top:14px;}
.u-style-aee2f5ca{margin-bottom:12px;}

/* Course builder section delete control */
.section-number-wrap{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;line-height:1}.section-edit-menu-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;z-index:8}.section-edit-menu-wrap::after{content:"";position:absolute;left:20px;top:-12px;width:34px;height:54px;background:transparent;z-index:1;pointer-events:auto}.section-menu-button{position:relative;z-index:4;width:26px;height:26px;border:0;border-radius:7px;background:#1f2937;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;line-height:1;cursor:pointer;box-shadow:0 5px 14px rgba(15,23,42,.16);transition:background .16s ease,transform .16s ease,box-shadow .16s ease}.section-menu-button:hover,.section-edit-menu-wrap:hover .section-menu-button,.section-edit-menu-wrap:focus-within .section-menu-button{background:#111827;transform:translateY(-1px);box-shadow:0 9px 20px rgba(15,23,42,.22)}.section-edit-menu{position:absolute;z-index:5;left:24px;top:-3px;display:flex;align-items:center;gap:4px;padding:4px;border-radius:8px;background:#fff;border:1px solid #d9e2ec;box-shadow:0 14px 34px rgba(15,23,42,.16);opacity:0;visibility:hidden;transform:translateX(-6px);pointer-events:none;transition:opacity .15s ease,visibility .15s ease,transform .15s ease;white-space:nowrap}.section-edit-menu:hover,.section-edit-menu-wrap:hover .section-edit-menu,.section-edit-menu-wrap:focus-within .section-edit-menu{opacity:1;visibility:visible;transform:translateX(0);pointer-events:auto}.section-menu-form{display:inline-flex;margin:0;padding:0}.section-menu-item{width:26px;height:26px;border:0;border-radius:6px;background:#f8fafc;color:#111827;display:inline-flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;line-height:1;cursor:pointer;box-shadow:none;transition:background .15s ease,color .15s ease,transform .15s ease}.section-menu-item:hover,.section-menu-item:focus-visible{background:#009879;color:#fff;transform:translateY(-1px);outline:0}.section-menu-danger{color:#991b1b}.section-menu-danger:hover,.section-menu-danger:focus-visible{background:#dc2626;color:#fff}@media(max-width:800px){.section-number-wrap{align-items:flex-start;justify-content:flex-start}.section-edit-menu{left:24px}.section-edit-menu-wrap::after{left:18px;width:40px;height:58px}.section-menu-button{width:28px;height:28px}.section-menu-item{width:28px;height:28px}}

/* Course Builder activity picker modal */
.builder-add-activity-row{margin-top:10px;display:flex;justify-content:flex-start;align-items:center}.builder-add-activity-trigger{border-radius:10px;padding:10px 16px;font-size:14px;line-height:1.1;font-weight:800;min-height:38px;box-shadow:0 10px 24px rgba(0,152,121,.16)}.builder-add-activity-trigger:hover{box-shadow:0 14px 30px rgba(0,152,121,.22);transform:translateY(-1px)}.activity-modal-open{overflow:hidden}.activity-modal-backdrop{position:fixed;inset:0;z-index:10050;background:rgba(15,23,42,.32);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px}.activity-modal-backdrop[hidden]{display:none}.activity-modal{width:min(1180px,calc(100vw - 48px));max-height:calc(100vh - 56px);background:#fff;border:1px solid #d9e4ea;border-radius:20px;box-shadow:0 28px 80px rgba(15,23,42,.22);overflow:hidden;display:flex;flex-direction:column}.activity-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:20px 22px;border-bottom:1px solid #e7edf2;background:linear-gradient(135deg,#ffffff 0%,#f6fbfa 100%)}.activity-modal-header h2{margin:0;font-size:24px}.activity-modal-header p{margin:5px 0 0}.activity-modal-section-target{margin-top:8px;font-size:13px;color:#5f6c7b}.activity-modal-header-actions{display:flex;align-items:center;gap:10px}.activity-modal-search{width:260px;min-height:38px;border-radius:12px;background:#f6f8fb;border:1px solid #dbe3ea;padding:8px 12px}.activity-modal-close{width:38px;height:38px;border:0;border-radius:12px;background:#f2f5f8;color:#344054;font-size:24px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .16s ease,transform .16s ease}.activity-modal-close:hover{background:#e8eef3;transform:translateY(-1px)}.activity-modal-body{display:grid;grid-template-columns:230px 1fr;min-height:0;overflow:hidden}.activity-modal-categories{padding:18px 14px;border-right:1px solid #e7edf2;background:#fbfcfd;display:flex;flex-direction:column;gap:7px;overflow:auto}.activity-category-tab{border:0;background:transparent;color:#344054;text-align:left;border-radius:12px;padding:11px 13px;font-weight:800;cursor:pointer;text-decoration:none}.activity-category-tab:hover,.activity-category-tab.active{background:#eefbf7;color:#007f69}.activity-category-link{display:block}.activity-modal-content{padding:18px 20px 22px;overflow:auto}.activity-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px}.activity-choice-card{border:1px solid #e1e8ef;border-radius:16px;background:#fff;display:flex;gap:13px;align-items:flex-start;text-align:left;padding:14px;cursor:pointer;color:#101828;text-decoration:none;transition:box-shadow .16s ease,border-color .16s ease,transform .16s ease,background .16s ease}.activity-choice-card:hover,.activity-choice-card.active{border-color:#9bdccd;background:#f3fbf9;box-shadow:0 14px 30px rgba(15,23,42,.09);transform:translateY(-1px)}.activity-choice-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#009879,#0f766e);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;flex:0 0 auto}.activity-choice-copy{display:flex;flex-direction:column;gap:4px}.activity-choice-copy strong{font-size:16px}.activity-choice-copy small{color:#667085;line-height:1.45}.activity-choice-card-link .activity-choice-icon{background:linear-gradient(135deg,#64748b,#334155)}.activity-modal-form{border:1px solid #e1e8ef;border-radius:18px;background:#fbfcfd;padding:16px;box-shadow:0 10px 30px rgba(15,23,42,.04)}.activity-selected-panel{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 14px;border-radius:14px;background:#eefbf7;border:1px solid #c9eee5}.activity-selected-panel h3{margin:3px 0 0;font-size:18px}.activity-modal-form .activity-field{margin-top:12px}.activity-modal-submit-row{display:flex;align-items:center;gap:10px;margin-top:14px}.activity-modal-submit-row .btn{box-shadow:0 8px 20px rgba(0,152,121,.13)}@media(max-width:900px){.activity-modal-backdrop{align-items:flex-start;padding:12px}.activity-modal{width:100%;max-height:calc(100vh - 24px);border-radius:16px}.activity-modal-header{display:block;padding:16px}.activity-modal-header-actions{margin-top:12px}.activity-modal-search{width:100%;flex:1}.activity-modal-body{grid-template-columns:1fr}.activity-modal-categories{border-right:0;border-bottom:1px solid #e7edf2;flex-direction:row;overflow:auto;padding:10px}.activity-category-tab{white-space:nowrap}.activity-modal-content{padding:14px}.activity-choice-grid{grid-template-columns:1fr}.activity-modal-form .grid-3,.activity-modal-form .grid-4{grid-template-columns:1fr}}
.quiz-picker-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:10px}.quiz-picker-head label{margin:0}.quiz-picker-head .muted{margin:4px 0 0}.quiz-picker-select{margin-bottom:12px;background:#fff}.quiz-picker-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}.quiz-picker-card{border:1px solid #dbe7ec;background:#fff;border-radius:14px;padding:12px 13px;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;box-shadow:0 8px 20px rgba(15,23,42,.04);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease,background .16s ease}.quiz-picker-card:hover{border-color:#9bdccd;background:#f6fcfa;box-shadow:0 14px 28px rgba(15,23,42,.08);transform:translateY(-1px)}.quiz-picker-card.active{border-color:#009879;background:#eefbf7;box-shadow:0 16px 30px rgba(0,152,121,.13)}.quiz-picker-card.disabled{opacity:.55;cursor:not-allowed;background:#f7f8fa;transform:none}.quiz-picker-card-main{display:flex;flex-direction:column;gap:3px;min-width:0}.quiz-picker-card-main b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-picker-card-main small{color:#667085}.quiz-picker-card-status{flex:0 0 auto;border-radius:999px;background:#eef2f6;color:#475467;padding:4px 8px;font-size:12px;font-weight:800}.quiz-picker-card.active .quiz-picker-card-status{background:#009879;color:#fff}.quiz-picker-empty{display:flex;flex-direction:column;gap:8px;border:1px dashed #c9d8e0;background:#fbfcfd;border-radius:14px;padding:13px 14px;color:#344054}.quiz-picker-empty span{color:#667085}.quiz-picker-empty[hidden],.quiz-picker-card[hidden]{display:none!important}@media(max-width:900px){.quiz-picker-head{display:block}.quiz-picker-head .btn{margin-top:10px}.quiz-picker-list{grid-template-columns:1fr}}
.activity-quick-quiz-panel{border:1px solid #cfe8e1;background:#f6fcfa;border-radius:18px;padding:15px;margin:0 0 16px;box-shadow:0 14px 34px rgba(15,23,42,.06)}
.activity-quick-quiz-panel[hidden]{display:none!important}.quick-quiz-picker-list{margin-top:4px}.activity-quick-quiz-panel .quiz-picker-card{background:#fff}.activity-quick-quiz-panel .quiz-picker-card.active{border-color:#009879;background:#ecfbf7}.activity-quick-quiz-panel .quiz-picker-empty{background:#fff}
@media(max-width:900px){.activity-quick-quiz-panel{padding:12px;border-radius:14px}}


.section-title-edit-button{appearance:none;border:0;background:transparent;color:inherit;font:inherit;font-weight:800;letter-spacing:inherit;text-align:left;padding:0;margin:0;cursor:pointer;border-radius:10px;line-height:1.2;transition:color .15s ease,background .15s ease,box-shadow .15s ease}.section-title-edit-button:hover,.section-title-edit-button:focus-visible{color:#007f6d;background:rgba(0,152,121,.07);box-shadow:0 0 0 6px rgba(0,152,121,.07);outline:0}.section-settings-modal-backdrop{position:fixed;inset:0;z-index:10020;background:rgba(15,23,42,.34);display:flex;align-items:center;justify-content:center;padding:22px;overflow:hidden}.section-settings-modal-backdrop[hidden]{display:none!important}.section-settings-modal{width:min(460px,100%);max-height:calc(100vh - 44px);background:#fff;border:1px solid #dbe5ee;border-radius:20px;box-shadow:0 24px 70px rgba(15,23,42,.22);overflow:hidden;display:flex;flex-direction:column}.section-settings-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:20px 22px;border-bottom:1px solid #edf2f7;background:linear-gradient(135deg,#ffffff,#f4fbf9);flex:0 0 auto}.section-settings-modal-header h3{margin:0 0 4px;font-size:20px}.section-settings-close{width:34px;height:34px;border:0;border-radius:10px;background:#eef2f6;color:#0f172a;font-size:22px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.section-settings-close:hover{background:#e2e8f0}.section-settings-form{display:grid;gap:10px;padding:20px 22px;overflow-y:auto;overscroll-behavior:contain;min-height:0}.section-settings-form label{font-size:12px;font-weight:800;color:#344054;text-transform:uppercase;letter-spacing:.04em}.section-settings-form input,.section-settings-form select{width:100%;border:1px solid #d5dee8;border-radius:12px;padding:11px 12px;background:#fff;color:#111827}.section-settings-form input:focus,.section-settings-form select:focus{outline:0;border-color:#009879;box-shadow:0 0 0 4px rgba(0,152,121,.12)}.section-settings-actions{display:flex;justify-content:flex-end;gap:10px;margin:8px -22px -20px;padding:14px 22px;background:rgba(255,255,255,.96);border-top:1px solid #edf2f7;position:sticky;bottom:-20px;z-index:3;box-shadow:0 -10px 24px rgba(15,23,42,.06)}@media(max-width:640px){.section-settings-modal-backdrop{align-items:flex-end;padding:12px;overflow:hidden}.section-settings-modal{max-height:calc(100vh - 24px);border-radius:18px}.section-settings-actions{flex-direction:column-reverse}.section-settings-actions .btn{width:100%}}

/* v3.221 Course builder activity hover menu near material title */
.builder-activity{position:relative;border-radius:14px;padding:10px 14px;margin:2px 0;transition:background .16s ease,box-shadow .16s ease;overflow:visible;justify-content:flex-start;}
.builder-activity:hover,.builder-activity:focus-within{background:#f8fafc;box-shadow:0 8px 24px rgba(15,23,42,.06);}
.builder-activity .activity-main{position:relative;display:inline-flex;align-items:center;gap:6px;min-width:0;width:auto;max-width:100%;padding-right:0;}
.builder-activity .activity-main > b{white-space:nowrap;}
.builder-activity .activity-hover-menu{position:absolute;left:calc(100% + 6px);right:auto;top:50%;z-index:30;display:flex;align-items:center;gap:4px;padding:5px;border-radius:12px;background:#263238;box-shadow:0 16px 38px rgba(15,23,42,.22);opacity:0;visibility:hidden;pointer-events:none;transform:translate(-4px,-50%);transition:opacity .14s ease,visibility .14s ease,transform .14s ease;white-space:nowrap;}
.builder-activity .activity-hover-menu:before{content:'';position:absolute;right:100%;top:0;width:8px;height:100%;}
.builder-activity:hover .activity-hover-menu,.builder-activity:focus-within .activity-hover-menu,.builder-activity .activity-hover-menu:hover{opacity:1;visibility:visible;pointer-events:auto;transform:translate(0,-50%);}
.builder-activity .activity-menu-action{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:7px 10px;border:0;border-radius:8px;background:transparent;color:#fff;font:inherit;font-size:12px;font-weight:800;line-height:1;text-decoration:none;cursor:pointer;white-space:nowrap;}
.builder-activity .activity-menu-action:hover,.builder-activity .activity-menu-action:focus{background:rgba(255,255,255,.13);outline:none;}
.builder-activity .activity-menu-action.danger{color:#fecaca;}
.builder-activity .activity-menu-action.danger:hover,.builder-activity .activity-menu-action.danger:focus{background:rgba(248,113,113,.18);color:#fff;}
.builder-activity .activity-hover-menu .inline-form{display:inline-flex;margin:0;}
@media(max-width:1100px){.builder-activity .activity-hover-menu{left:0;right:auto;top:calc(100% + 6px);transform:translateY(-4px)}.builder-activity:hover .activity-hover-menu,.builder-activity:focus-within .activity-hover-menu,.builder-activity .activity-hover-menu:hover{transform:translateY(0)}.builder-activity .activity-hover-menu:before{right:auto;left:0;top:auto;bottom:100%;width:100%;height:8px}}
@media(max-width:800px){.builder-activity{padding:10px 0}.builder-activity .activity-main{display:flex;flex-wrap:wrap;width:100%}.builder-activity .activity-hover-menu{position:static;opacity:1;visibility:visible;pointer-events:auto;transform:none;margin-top:8px;background:transparent;box-shadow:none;padding:0;flex-wrap:wrap;white-space:normal}.builder-activity:hover .activity-hover-menu,.builder-activity:focus-within .activity-hover-menu{transform:none}.builder-activity .activity-menu-action{background:#edf2f7;color:#263238}.builder-activity .activity-menu-action.danger{background:#fee2e2;color:#991b1b}}


/* v3.222 Keep course-builder activity hover actions horizontal beside the activity title */
.builder-activity .activity-hover-menu{
  display:inline-flex!important;
  flex-direction:row!important;
  flex-wrap:nowrap!important;
  align-items:center!important;
  width:max-content;
  max-width:calc(100vw - 40px);
  white-space:nowrap!important;
}
.builder-activity .activity-hover-menu .inline-form{
  display:inline-flex!important;
  flex:0 0 auto!important;
  margin:0!important;
}
.builder-activity .activity-menu-action{
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
@media(min-width:801px){
  .builder-activity .activity-hover-menu{
    left:calc(100% + 6px)!important;
    right:auto!important;
    top:50%!important;
    transform:translate(-4px,-50%)!important;
    overflow:visible!important;
  }
  .builder-activity:hover .activity-hover-menu,
  .builder-activity:focus-within .activity-hover-menu,
  .builder-activity .activity-hover-menu:hover{
    transform:translate(0,-50%)!important;
  }
  .builder-activity .activity-hover-menu:before{
    right:100%!important;
    left:auto!important;
    top:0!important;
    bottom:auto!important;
    width:8px!important;
    height:100%!important;
  }
}
@media(max-width:800px){
  .builder-activity .activity-hover-menu{
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:wrap!important;
    align-items:center!important;
  }
}

/* Activity modal step flow: first choose a type, then configure it while keeping the category sidebar visible. */
.activity-details-view[hidden], .activity-choice-grid[hidden]{display:none!important}
.activity-details-view{display:block}
.activity-modal-content.is-choosing-activity .activity-modal-form,
.activity-modal-content.is-choosing-activity [data-activity-quick-quiz-panel]{display:none!important}
.activity-selected-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.activity-selected-actions .btn-small{padding:7px 10px;border-radius:10px;font-size:12px;box-shadow:none!important}
@media(max-width:900px){.activity-selected-panel{align-items:flex-start;flex-direction:column}.activity-selected-actions{justify-content:flex-start}}


/* v3.226 Fix course builder section markup/layout after section settings modal. */
.builder-section-content{min-width:0;}
.builder-section-content > .activity-dropzone{display:block;clear:both;}
.builder-section-content > .builder-add-activity-row{position:static!important;display:flex;clear:both;margin-top:14px;margin-left:0;z-index:auto;}
.builder-section-content > .builder-add-activity-row .builder-add-activity-trigger{position:relative;z-index:1;}

/* v4.06 SSO login buttons */
.sso-login-options{display:grid;gap:.75rem;margin:1rem 0 1.25rem}
.sso-login-btn{width:100%;justify-content:center;border:1px solid var(--border,#d7dde8);background:#fff;color:var(--text,#1f2937)}
.sso-login-btn.sso-style-google::before{content:'G';font-weight:700;margin-inline-end:.5rem}
.sso-login-btn.sso-style-microsoft::before{content:'□';font-weight:700;margin-inline-end:.5rem}
.sso-login-btn.sso-style-school::before{content:'↗';font-weight:700;margin-inline-end:.5rem}

/* v4.29 Facebook-style course community feed */
.community-layout{grid-template-columns:minmax(230px,280px) minmax(0,760px)!important;justify-content:center;gap:22px;align-items:start;background:linear-gradient(180deg,#eef5f5 0,#f7fafc 420px,transparent 421px);padding:10px 0 28px}
.community-layout > main{min-width:0;width:100%}
.community-sidebar{position:sticky;top:18px}.community-sidebar .card{border:0;box-shadow:0 10px 32px rgba(15,23,42,.07);border-radius:18px}.community-sidebar .course-link{border-radius:14px;background:#f8fafc;border-color:#e8edf3;transition:.16s ease}.community-sidebar .course-link:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(15,23,42,.08)}.community-sidebar .course-link.active{background:#eaf4ff;border-color:#b8d9ff;color:#064e8a}
.community-feed-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;border:0;border-radius:20px;background:rgba(255,255,255,.88);box-shadow:0 12px 35px rgba(15,23,42,.07);backdrop-filter:blur(10px)}.community-feed-hero h2{margin:4px 0 4px;font-size:24px}.community-feed-eyebrow{display:inline-flex;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#0067b8;background:#eaf4ff;border:1px solid #cfe8ff;border-radius:999px;padding:5px 9px}
.community-composer{border:0;border-radius:20px;box-shadow:0 14px 38px rgba(15,23,42,.09);overflow:hidden;background:#fff}.community-composer-form{display:block}.community-composer-top{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:13px;padding-bottom:12px}.community-avatar{width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:14px;font-weight:800;color:#516170;background:linear-gradient(135deg,#eef2f6,#d9e1ea);border:1px solid rgba(15,23,42,.05);text-transform:uppercase}.community-avatar-lg{width:50px;height:50px;font-size:16px}.community-avatar-sm{width:34px;height:34px;font-size:12px}.community-composer-input{min-height:46px!important;max-height:220px;border:0!important;outline:0!important;resize:none;border-radius:18px!important;background:#f2f4f7!important;padding:13px 16px!important;font-size:15px;line-height:1.45;box-shadow:none!important}.community-composer-input:focus{background:#fff!important;box-shadow:inset 0 0 0 2px #d7e9ff!important}.community-composer-advanced{display:none;border-top:1px solid #eef2f6;margin-top:4px;padding:14px 0 4px}.community-composer.is-expanded .community-composer-advanced{display:block}.community-composer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.community-composer-grid label,.community-inline-panel label{font-size:12px;font-weight:700;color:#526071}.community-composer-grid input,.community-composer-grid select,.community-inline-panel input,.community-inline-panel textarea{margin-top:5px}.community-inline-panel{display:none;margin-top:10px;border:1px solid #e8edf3;border-radius:15px;padding:12px;background:#fbfdff}.community-composer-flags{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px}.community-check{display:inline-flex!important;align-items:center;gap:7px;font-weight:600!important;color:#475569!important}.community-file-input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}.community-selected-files{display:flex;gap:7px;flex-wrap:wrap;margin:4px 0 8px}.community-selected-file{display:inline-flex;align-items:center;max-width:100%;border:1px solid #dbeafe;background:#eff6ff;color:#075985;border-radius:999px;padding:5px 9px;font-size:12px}.community-composer-toolbar{display:flex;align-items:center;gap:12px;border-top:1px solid #eef2f6;padding-top:11px}.community-tool-button{width:34px;height:34px;border:0;background:#fff;color:#005a9c;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;cursor:pointer;text-decoration:none;font-size:16px}.community-tool-button:hover{background:#eef6ff;color:#003f73}.community-share-button{margin-left:auto;border-radius:9px!important;padding:9px 20px!important;min-width:86px;background:#8fb6cf!important;border-color:#8fb6cf!important;color:#fff!important}.community-share-button:hover{filter:brightness(.96)}
.community-feed-post{border:0;border-radius:20px;background:#fff;box-shadow:0 12px 34px rgba(15,23,42,.08);padding:18px!important}.community-feed-post+.community-feed-post{margin-top:16px}.community-post-top{display:flex!important;align-items:flex-start;justify-content:space-between;gap:14px;padding-right:44px!important}.community-post-author{display:flex;gap:11px;align-items:flex-start;min-width:0}.community-post-author h2{font-size:17px;margin:0 0 3px;line-height:1.25}.community-post-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.community-post-body{font-size:15px;line-height:1.65;color:#1f2937;margin:14px 0;white-space:normal}.community-post-stats{display:flex;justify-content:space-between;color:#64748b;font-size:13px;border-top:1px solid #eef2f6;padding-top:10px;margin-top:12px}.community-reactions{opacity:1!important;margin:0!important;padding:6px 0;border-bottom:1px solid #eef2f6}.community-react-form{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;width:100%}.community-reaction-button{width:100%;border-radius:10px!important;background:#fff!important;color:#445568!important;padding:9px 7px!important;font-weight:700}.community-reaction-button:hover{background:#f0f6ff!important;color:#005a9c!important}.community-more-toggle{border:0!important;background:#f3f6f9!important}.community-more-toggle:hover{background:#e8edf3!important}.community-poll-card{border:1px solid #e8edf3;border-radius:18px;padding:14px;margin:12px 0;background:#fbfdff}.community-poll-card h3{margin-top:0}
.community-attachment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin:12px 0}.community-image-attachment{display:block;border-radius:15px;overflow:hidden;background:#eef2f6;min-height:120px}.community-image-attachment img{display:block;width:100%;height:100%;max-height:340px;object-fit:cover}.community-file-attachment{display:flex!important;align-items:center;gap:9px;text-decoration:none;border:1px solid #e2e8f0!important;border-radius:14px!important;background:#f8fafc!important;color:#334155!important;padding:11px!important;margin:0!important}.community-file-attachment span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:32px;border-radius:9px;background:#eaf4ff;color:#005a9c;font-size:11px;font-weight:900}.community-comment-attachments a{display:inline-flex;margin:5px 6px 0 0;border:1px solid #dbeafe;border-radius:999px;padding:4px 8px;background:#eff6ff;text-decoration:none;color:#075985;font-size:12px}
.community-comments{border-top:0!important;margin-top:10px!important;padding-top:8px!important}.community-comments h3{font-size:14px;margin:8px 0;color:#475569}.community-comment{display:flex!important;gap:8px;align-items:flex-start;background:transparent!important;border:0!important;border-radius:0!important;padding:6px 0!important;margin:2px 0!important}.community-comment-content{min-width:0;flex:1;position:relative}.community-comment-bubble{display:inline-block;max-width:100%;background:#f0f2f5;border-radius:17px;padding:9px 12px}.community-comment-body{padding-right:0!important;color:#1f2937}.community-comment-tools{position:static!important;display:flex!important;gap:6px;margin:4px 0 0 10px;opacity:0;transition:.15s ease}.community-comment:hover .community-comment-tools,.community-comment:focus-within .community-comment-tools{opacity:1}.community-comment-composer{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:start;margin-top:8px}.community-comment-form textarea{min-height:42px!important;border-radius:16px!important;background:#f2f4f7!important;border:0!important;resize:vertical}.community-comment-form input[type=file]{margin:8px 0 4px}.community-comment-pending .community-comment-bubble{background:#fff7ed;border:1px dashed #fdba74}.community-inline-error{border:1px solid #fecaca;background:#fef2f2;border-radius:12px;padding:8px 10px;color:#b91c1c}
@media(max-width:1000px){.community-layout{grid-template-columns:1fr!important;padding-inline:0}.community-sidebar{position:static;max-width:none!important}.community-composer-grid{grid-template-columns:1fr}.community-feed-hero{align-items:flex-start;flex-direction:column}.community-react-form{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.community-composer-toolbar{gap:5px}.community-tool-button{width:30px;height:30px;font-size:14px}.community-share-button{min-width:auto;padding:8px 13px!important}.community-post-top{flex-direction:column;padding-right:36px!important}.community-post-badges{justify-content:flex-start}.community-react-form{grid-template-columns:1fr 1fr}.community-attachment-grid{grid-template-columns:1fr}.community-avatar-lg{width:44px;height:44px}}

/* v4.33 Facebook-style community composer and emoji picker fix
   Keeps advanced post options hidden by default and styles the composer like a social feed input. */
.community-layout{
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  grid-template-columns:minmax(260px,320px) minmax(0,1fr)!important;
  justify-content:stretch!important;
  align-items:start!important;
  gap:24px!important;
  padding:10px 0 32px!important;
  background:linear-gradient(180deg,#eaf4f2 0,#f7fbfb 390px,transparent 391px)!important;
}
.community-layout>main{width:100%!important;max-width:none!important;min-width:0!important;}
.community-sidebar{width:100%!important;max-width:320px!important;}
.community-sidebar .card{width:100%!important;}
@media(min-width:1200px){.community-layout{grid-template-columns:minmax(280px,340px) minmax(0,1fr)!important;}}
.community-feed-hero{display:none!important;}
.community-composer.card{
  padding:16px 20px 12px!important;
  margin:0 0 26px!important;
  border:1px solid #e6eef0!important;
  border-radius:7px!important;
  background:#fff!important;
  box-shadow:0 1px 2px rgba(15,23,42,.035)!important;
  overflow:visible!important;
}
.community-composer-form{display:block!important;margin:0!important;}
.community-composer-top{
  display:grid!important;
  grid-template-columns:44px minmax(0,1fr)!important;
  gap:14px!important;
  align-items:center!important;
  padding:0 0 12px!important;
  margin:0!important;
}
.community-avatar{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:999px!important;
  color:#75808a!important;
  background:linear-gradient(135deg,#eef0f2,#d8dde2)!important;
  border:0!important;
  box-shadow:none!important;
  text-transform:uppercase!important;
}
.community-avatar-lg{width:42px!important;height:42px!important;font-size:15px!important;}
.community-avatar-sm{width:32px!important;height:32px!important;font-size:12px!important;}
.community-composer-input{
  display:block!important;
  width:100%!important;
  min-height:42px!important;
  height:auto!important;
  max-height:none!important;
  resize:none!important;
  overflow:hidden!important;
  border:0!important;
  outline:0!important;
  border-radius:6px!important;
  background:#f3f3f3!important;
  color:#1f2937!important;
  padding:11px 14px!important;
  font-size:15px!important;
  line-height:20px!important;
  box-shadow:none!important;
  transition:min-height .15s ease, height .15s ease, background .15s ease!important;
}
.community-composer-input::placeholder{color:#9aa1aa!important;opacity:1!important;}
.community-composer-input:focus{background:#f7f8f9!important;box-shadow:inset 0 0 0 1px #d7e5ed!important;}
.community-composer-advanced{
  display:none!important;
  margin:0 0 12px 56px!important;
  padding:12px!important;
  border:1px solid #e7edf2!important;
  border-radius:12px!important;
  background:#fbfdff!important;
}
.community-composer-form.is-expanded .community-composer-advanced,
.community-composer.is-expanded .community-composer-advanced{display:block!important;}
.community-composer-grid{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:10px!important;}
.community-composer-grid label,
.community-inline-panel label{display:block!important;margin:0!important;font-size:12px!important;font-weight:700!important;color:#475569!important;}
.community-composer-grid input,
.community-composer-grid select,
.community-inline-panel input,
.community-inline-panel textarea{
  width:100%!important;
  margin-top:6px!important;
  border:1px solid #dbe3ea!important;
  border-radius:9px!important;
  background:#fff!important;
  padding:9px 10px!important;
}
.community-inline-panel{margin-top:10px!important;border:1px solid #e8edf3!important;border-radius:12px!important;padding:11px!important;background:#fff!important;}
.community-composer-flags{display:flex!important;gap:18px!important;align-items:center!important;flex-wrap:wrap!important;margin-top:11px!important;}
.community-check{display:inline-flex!important;align-items:center!important;gap:7px!important;margin:0!important;color:#475569!important;font-weight:600!important;}
.community-check input{width:auto!important;margin:0!important;}
.mention-help{display:block!important;margin:10px 0 0!important;font-size:12px!important;line-height:1.4!important;color:#64748b!important;}
.community-file-input{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
  opacity:0!important;
  pointer-events:none!important;
}
.community-selected-files{display:flex!important;gap:7px!important;flex-wrap:wrap!important;margin:0 0 9px 56px!important;}
.community-selected-file{display:inline-flex!important;align-items:center!important;border:1px solid #dceafe!important;background:#eff6ff!important;color:#075985!important;border-radius:999px!important;padding:5px 9px!important;font-size:12px!important;}
.community-composer-toolbar{
  display:flex!important;
  align-items:center!important;
  gap:13px!important;
  border-top:0!important;
  padding:0 0 0 4px!important;
  margin:0!important;
}
.community-tool-button{
  width:26px!important;
  height:26px!important;
  min-width:26px!important;
  padding:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border:0!important;
  border-radius:6px!important;
  background:transparent!important;
  color:#005a9c!important;
  font-size:17px!important;
  line-height:1!important;
  font-weight:700!important;
  text-decoration:none!important;
  cursor:pointer!important;
  appearance:none!important;
}
.community-tool-button:hover,.community-tool-button:focus{background:#eef6ff!important;color:#003f73!important;outline:none!important;}
.community-emoji-wrap{position:relative!important;display:inline-flex!important;align-items:center!important;}
.community-emoji-picker{position:absolute!important;left:0!important;top:34px!important;bottom:auto!important;width:min(340px,calc(100vw - 48px))!important;max-height:260px!important;overflow:auto!important;z-index:120!important;display:grid!important;grid-template-columns:repeat(8,1fr)!important;gap:4px!important;padding:10px!important;border:1px solid #dbe3ea!important;border-radius:14px!important;background:#fff!important;box-shadow:0 18px 45px rgba(15,23,42,.18)!important;}
.community-emoji-picker[hidden]{display:none!important;}
.community-emoji-item{width:34px!important;height:34px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border:0!important;border-radius:9px!important;background:#fff!important;font-size:21px!important;line-height:1!important;cursor:pointer!important;padding:0!important;}
.community-emoji-item:hover,.community-emoji-item:focus{background:#eef6ff!important;outline:none!important;}
.community-share-button{
  margin-left:auto!important;
  min-width:82px!important;
  height:36px!important;
  padding:0 18px!important;
  border-radius:6px!important;
  background:#a6bfd0!important;
  border:0!important;
  color:#fff!important;
  font-weight:800!important;
  font-size:14px!important;
  box-shadow:none!important;
}
.community-share-button:hover{filter:brightness(.96)!important;transform:none!important;}
.community-empty-state{
  text-align:center!important;
  padding:2px 16px 52px!important;
  color:#005a9c!important;
}
.community-empty-state h2{margin:0 0 10px!important;font-size:20px!important;line-height:1.3!important;color:#005a9c!important;font-weight:800!important;}
.community-empty-state p{margin:0!important;font-size:17px!important;line-height:1.5!important;color:#005a9c!important;}
@media(max-width:1000px){
  .community-layout{grid-template-columns:1fr!important;max-width:none!important;padding-inline:0!important;}
  .community-layout>main{max-width:100%!important;}
  .community-composer-grid{grid-template-columns:1fr!important;}
  .community-composer-advanced,.community-selected-files{margin-left:0!important;}
}
@media(max-width:560px){
  .community-composer.card{padding:14px 14px 11px!important;}
  .community-composer-top{grid-template-columns:38px 1fr!important;gap:10px!important;}
  .community-avatar-lg{width:38px!important;height:38px!important;}
  .community-composer-toolbar{gap:8px!important;padding-left:0!important;}
  .community-tool-button{width:24px!important;height:24px!important;min-width:24px!important;font-size:15px!important;}
  .community-share-button{min-width:72px!important;height:34px!important;padding:0 12px!important;}
  .community-emoji-picker{grid-template-columns:repeat(6,1fr)!important;width:min(292px,calc(100vw - 30px))!important;left:-4px!important;}
}


/* v4.36 Messages mailbox folders and archive actions */
.messages-folder-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}.messages-folder-bar p{margin:4px 0 0}.messages-folder-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.messages-layout{display:grid;grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:18px;align-items:start}.messages-sidebar-stack{display:grid;gap:18px;align-items:start}.messages-sidebar-folders h2{margin-top:0}.messages-sidebar-links{display:grid;gap:8px}.messages-sidebar-links a{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #e5e7eb;border-radius:12px;padding:11px 12px;background:#f8fafc;text-decoration:none;color:#334155}.messages-sidebar-links a:hover,.messages-sidebar-links a.active{border-color:#99d8d1;background:#eefbf9;color:#00796b}.messages-sidebar-links strong{display:inline-flex;min-width:28px;height:24px;align-items:center;justify-content:center;border-radius:999px;background:#fff;border:1px solid #e5e7eb;font-size:12px}
.messages-box{min-width:0}
.messages-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.messages-head h2{margin:0 0 4px}
.messages-head p{margin:0}
.messages-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.messages-list{display:grid;gap:12px}
.message-card{border:1px solid #e5e7eb;border-radius:14px;padding:14px;background:#fff;box-shadow:0 1px 2px rgba(15,23,42,.035)}
.message-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.message-card h3{margin:8px 0 0;font-size:17px;line-height:1.3;color:#111827}
.message-meta{font-size:13px;margin:8px 0 10px}
.message-body{line-height:1.55;white-space:normal;color:#1f2937}
.message-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.message-actions form{margin:0}.messages-empty-state{border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:18px;text-align:center}.messages-empty-state p{margin:0 0 10px}
@media(max-width:980px){.messages-folder-bar{flex-direction:column;align-items:flex-start}.messages-folder-buttons{justify-content:flex-start}.messages-layout{grid-template-columns:1fr}.messages-head{flex-direction:column}.messages-tabs{justify-content:flex-start}.message-card-top{flex-direction:column}.message-actions{justify-content:flex-start}}

/* v4.37 Professional multilingual content editor */
.i18n-editor-card{
  margin:18px 0;
  padding:18px;
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  box-shadow:0 12px 30px rgba(15,23,42,.06);
}
.i18n-editor-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.i18n-editor-head strong{font-size:1.05rem;color:#0f172a}
.i18n-editor-head .muted{margin:4px 0 0;max-width:760px}
.i18n-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px;border-bottom:1px solid rgba(15,23,42,.08);padding-bottom:10px}
.i18n-tab{border:1px solid rgba(15,23,42,.12);background:#fff;border-radius:999px;padding:8px 14px;font-weight:700;cursor:pointer;color:#334155;box-shadow:0 2px 8px rgba(15,23,42,.04)}
.i18n-tab.active{background:#0f766e;color:#fff;border-color:#0f766e;box-shadow:0 8px 20px rgba(15,118,110,.22)}
.i18n-pane{display:none}
.i18n-pane.active{display:block}
.i18n-pane label{display:block;margin-top:12px;font-weight:700;color:#1f2937}
.i18n-pane input,.i18n-pane textarea{width:100%;margin-top:6px;border:1px solid rgba(15,23,42,.14);border-radius:12px;background:#fff;padding:10px 12px;box-shadow:inset 0 1px 2px rgba(15,23,42,.03)}
.i18n-pane textarea{min-height:110px;resize:vertical}
.dir-rtl .i18n-editor-card,.dir-rtl .i18n-pane input,.dir-rtl .i18n-pane textarea{direction:rtl;text-align:right}
.dir-rtl .i18n-editor-head{direction:rtl}

/* v4.38 Language-specific content save controls */
.i18n-language-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 8px}
.i18n-language-toolbar-label{font-size:.86rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#475569}
.i18n-language-toolbar .i18n-tabs{margin:0;border:0;padding:0}
.i18n-active-hint{margin:8px 0 14px;padding:10px 12px;border:1px solid rgba(15,118,110,.18);border-radius:12px;background:#ecfdf5;color:#334155;font-size:.92rem;line-height:1.45}
.dir-rtl .i18n-language-toolbar{direction:rtl}

/* v4.43 Sequential learning builder controls */
.sequential-badge{background:#eef2ff!important;color:#3730a3!important;border:1px solid #c7d2fe!important}.sequential-admin-notice{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:14px;padding:12px;font-size:13px;line-height:1.45}.sequential-admin-notice code{background:rgba(154,52,18,.08);padding:2px 5px;border-radius:6px}.sequential-settings-box{border:1px solid #dbe5ee;border-radius:16px;background:#fbfdff;overflow:hidden;margin-top:4px}.sequential-settings-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px;background:linear-gradient(135deg,#fff,#f5fbff);border-bottom:1px solid #edf2f7}.sequential-settings-head strong{display:block;color:#0f172a;font-size:14px}.sequential-settings-head span{display:block;color:#667085;font-size:12px;line-height:1.45;margin-top:3px}.sequential-switch{white-space:nowrap;margin-top:0}.sequential-settings-grid{display:grid;gap:10px;padding:14px}.sequential-settings-grid.disabled{opacity:.55}.sequential-settings-grid textarea{width:100%;border:1px solid #d5dee8;border-radius:12px;padding:11px 12px;background:#fff;color:#111827;resize:vertical}.sequential-settings-grid textarea:focus{outline:0;border-color:#009879;box-shadow:0 0 0 4px rgba(0,152,121,.12)}.sequential-check{display:flex!important;align-items:flex-start!important;gap:9px;padding:9px 10px;border:1px solid #e6edf4;border-radius:12px;background:#fff;text-transform:none!important;letter-spacing:0!important;color:#475467!important;font-weight:600!important}.sequential-check input{width:auto!important;margin-top:2px}.sequential-hint{margin:0!important;font-size:12px!important}.section-settings-modal{width:min(620px,100%)}
.sequential-switch input{width:auto!important;margin:0 6px 0 0}.sequential-switch{display:flex!important;align-items:center!important;gap:6px;text-transform:none!important;letter-spacing:0!important;font-weight:700!important;color:#334155!important}.sequential-switch span{display:inline!important;margin:0!important;color:#334155!important;font-size:13px!important}

body.section-settings-modal-open{overflow:hidden}

/* v4.43.1: hard fix for long Section Settings modal.
   The modal now has a real scroll area and a non-scrolling footer, so Save/Cancel
   stay visible even when Sequential Learning fields make the form long. */
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop{
  align-items:center!important;
  justify-content:center!important;
  padding:16px!important;
  overflow:hidden!important;
}
.section-settings-modal{
  width:min(620px,calc(100vw - 32px))!important;
  height:min(820px,calc(100dvh - 32px))!important;
  max-height:calc(100dvh - 32px)!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.section-settings-modal-header{
  flex:0 0 auto!important;
}
.section-settings-form{
  flex:1 1 auto!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  padding:0!important;
  gap:0!important;
  overflow:hidden!important;
}
.section-settings-scroll{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
  padding:20px 22px 16px!important;
  display:grid!important;
  gap:10px!important;
}
.section-settings-actions{
  flex:0 0 auto!important;
  position:static!important;
  bottom:auto!important;
  z-index:5!important;
  margin:0!important;
  padding:14px 22px calc(14px + env(safe-area-inset-bottom))!important;
  display:flex!important;
  justify-content:flex-end!important;
  gap:10px!important;
  background:#fff!important;
  border-top:1px solid #edf2f7!important;
  box-shadow:0 -12px 28px rgba(15,23,42,.08)!important;
}
@media(max-width:640px){
  .section-settings-modal-backdrop{
    align-items:flex-end!important;
    padding:10px!important;
  }
  .section-settings-modal{
    width:100%!important;
    height:calc(100dvh - 20px)!important;
    max-height:calc(100dvh - 20px)!important;
    border-radius:18px!important;
  }
  .section-settings-scroll{
    padding:16px!important;
  }
  .section-settings-actions{
    flex-direction:column-reverse!important;
    padding:12px 16px calc(12px + env(safe-area-inset-bottom))!important;
  }
  .section-settings-actions .btn{
    width:100%!important;
  }
}
@supports not (height:100dvh){
  .section-settings-modal{
    height:min(820px,calc(100vh - 32px))!important;
    max-height:calc(100vh - 32px)!important;
  }
  @media(max-width:640px){
    .section-settings-modal{
      height:calc(100vh - 20px)!important;
      max-height:calc(100vh - 20px)!important;
    }
  }
}

/* v4.43.2: extra-safe Section Settings modal viewport fix.
   Keep the action footer clearly above browser/toolbars/taskbars on shorter screens. */
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop{
  position:fixed!important;
  inset:0!important;
  display:flex!important;
  align-items:flex-start!important;
  justify-content:center!important;
  padding:32px 16px 96px!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
}
.section-settings-modal{
  width:min(620px,calc(100vw - 32px))!important;
  height:min(720px,calc(100svh - 128px))!important;
  max-height:calc(100svh - 128px)!important;
  min-height:0!important;
  margin:0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
}
.section-settings-modal-header{
  flex:0 0 auto!important;
}
.section-settings-form{
  flex:1 1 auto!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  gap:0!important;
}
.section-settings-scroll{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
  padding:18px 22px 18px!important;
  display:grid!important;
  gap:10px!important;
}
.section-settings-actions{
  flex:0 0 auto!important;
  position:relative!important;
  bottom:auto!important;
  left:auto!important;
  right:auto!important;
  z-index:30!important;
  margin:0!important;
  padding:14px 22px!important;
  min-height:64px!important;
  box-sizing:border-box!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  background:#fff!important;
  border-top:1px solid #edf2f7!important;
  box-shadow:0 -14px 30px rgba(15,23,42,.10)!important;
}
.section-settings-actions .btn{
  flex:0 0 auto!important;
  min-height:42px!important;
}
@supports not (height:100svh){
  .section-settings-modal{
    height:min(720px,calc(100vh - 128px))!important;
    max-height:calc(100vh - 128px)!important;
  }
}
@media(max-width:640px){
  .section-settings-modal-backdrop{
    align-items:flex-start!important;
    padding:18px 10px 90px!important;
  }
  .section-settings-modal{
    width:100%!important;
    height:calc(100svh - 108px)!important;
    max-height:calc(100svh - 108px)!important;
    border-radius:18px!important;
  }
  .section-settings-scroll{
    padding:14px 14px 16px!important;
  }
  .section-settings-actions{
    flex-direction:column-reverse!important;
    align-items:stretch!important;
    padding:12px 14px!important;
    min-height:112px!important;
  }
  .section-settings-actions .btn{
    width:100%!important;
  }
  @supports not (height:100svh){
    .section-settings-modal{
      height:calc(100vh - 108px)!important;
      max-height:calc(100vh - 108px)!important;
    }
  }
}


/* v4.43.3 ROOT FIX: Section Settings modal must never reach the bottom of the viewport.
   This overrides all older modal rules by positioning the modal with a fixed bottom gap.
   Only the form body scrolls; the Save/Cancel footer is always visible inside the modal. */
html:has(body.section-settings-modal-open),
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop[data-section-settings-modal]{
  position:fixed!important;
  inset:0!important;
  z-index:10020!important;
  display:block!important;
  padding:0!important;
  margin:0!important;
  overflow:hidden!important;
  background:rgba(15,23,42,.34)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
  position:fixed!important;
  top:18px!important;
  bottom:86px!important;
  left:50%!important;
  transform:translateX(-50%)!important;
  width:min(620px,calc(100vw - 28px))!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  margin:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  border-radius:20px!important;
  background:#fff!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
  flex:0 0 auto!important;
  min-height:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-form{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  gap:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
  padding:18px 22px 24px!important;
  display:grid!important;
  gap:10px!important;
  box-sizing:border-box!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
  flex:0 0 auto!important;
  position:static!important;
  inset:auto!important;
  transform:none!important;
  z-index:50!important;
  margin:0!important;
  padding:14px 22px!important;
  min-height:70px!important;
  box-sizing:border-box!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  background:#fff!important;
  border-top:1px solid #edf2f7!important;
  box-shadow:0 -14px 30px rgba(15,23,42,.10)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
  flex:0 0 auto!important;
  min-height:42px!important;
  white-space:nowrap!important;
}
@media (max-height:760px){
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    top:10px!important;
    bottom:74px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding-top:12px!important;
    padding-bottom:12px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding-top:12px!important;
    padding-bottom:14px!important;
    gap:8px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    min-height:62px!important;
    padding-top:10px!important;
    padding-bottom:10px!important;
  }
}
@media (max-width:640px){
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    top:8px!important;
    bottom:86px!important;
    width:calc(100vw - 16px)!important;
    border-radius:18px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:14px 14px 18px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    flex-direction:column-reverse!important;
    align-items:stretch!important;
    min-height:106px!important;
    padding:12px 14px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
    width:100%!important;
  }
}


/* v4.43.4 PROFESSIONAL SECTION SETTINGS MODAL RESET
   Root cause fix: the modal is a real flex dialog again, not a fixed element pinned to the viewport.
   Header and footer are fixed inside the card; ONLY the body scrolls. The footer never overlays fields. */
html:has(body.section-settings-modal-open),
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop[data-section-settings-modal]{
  position:fixed!important;
  inset:0!important;
  z-index:10020!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:18px 18px 86px!important; /* bottom safety for Windows/browser toolbars */
  margin:0!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  background:rgba(15,23,42,.42)!important;
  backdrop-filter:blur(2px)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
  position:relative!important;
  top:auto!important;
  right:auto!important;
  bottom:auto!important;
  left:auto!important;
  transform:none!important;
  width:min(760px,calc(100vw - 36px))!important;
  height:auto!important;
  min-height:0!important;
  max-height:calc(100svh - 112px)!important;
  margin:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  border-radius:22px!important;
  background:#fff!important;
  border:1px solid rgba(203,213,225,.95)!important;
  box-shadow:0 30px 90px rgba(15,23,42,.30)!important;
}
@supports not (height:100svh){
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    max-height:calc(100vh - 112px)!important;
  }
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
  flex:0 0 auto!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:14px!important;
  padding:16px 20px!important;
  min-height:0!important;
  border-bottom:1px solid #e8eef5!important;
  background:linear-gradient(135deg,#ffffff 0%,#f7fbff 100%)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header h3{
  margin:0 0 3px!important;
  font-size:19px!important;
  line-height:1.25!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header .muted{
  margin:0!important;
  font-size:12.5px!important;
  line-height:1.35!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-close{
  flex:0 0 auto!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-form{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  gap:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  padding:18px 20px 22px!important;
  box-sizing:border-box!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
  scrollbar-gutter:stable both-edges!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll > label{
  margin:2px 0 -2px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll input,
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll select,
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll textarea{
  min-height:44px!important;
  box-sizing:border-box!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-box{
  margin-top:2px!important;
  border-radius:18px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
  padding:12px 14px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid{
  display:grid!important;
  grid-template-columns:190px minmax(0,1fr)!important;
  gap:11px 14px!important;
  align-items:center!important;
  padding:14px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > label:not(.sequential-check){
  margin:0!important;
  align-self:center!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > select,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > input,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > textarea{
  margin:0!important;
  width:100%!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
  grid-column:1 / -1!important;
  display:grid;
  grid-template-columns:190px minmax(0,1fr);
  gap:11px 14px;
  align-items:center;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > label{
  margin:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-check,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-hint{
  grid-column:1 / -1!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid textarea[name="locked_message"]{
  min-height:84px!important;
  resize:vertical!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
  flex:0 0 auto!important;
  position:relative!important;
  inset:auto!important;
  transform:none!important;
  z-index:10!important;
  margin:0!important;
  padding:14px 20px!important;
  min-height:70px!important;
  box-sizing:border-box!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  background:#fff!important;
  border-top:1px solid #e8eef5!important;
  box-shadow:0 -10px 28px rgba(15,23,42,.08)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
  flex:0 0 auto!important;
  min-height:42px!important;
  white-space:nowrap!important;
}
@media (max-height:760px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    align-items:flex-start!important;
    padding:10px 14px 76px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    max-height:calc(100svh - 90px)!important;
  }
  @supports not (height:100svh){
    .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
      max-height:calc(100vh - 90px)!important;
    }
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding:11px 18px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:12px 18px 14px!important;
    gap:8px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
    padding:10px 12px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid{
    padding:12px!important;
    gap:9px 12px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    min-height:62px!important;
    padding:10px 18px!important;
  }
}
@media (max-width:760px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    align-items:flex-start!important;
    padding:10px 10px 78px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    width:calc(100vw - 20px)!important;
    max-height:calc(100svh - 88px)!important;
    border-radius:18px!important;
  }
  @supports not (height:100svh){
    .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
      max-height:calc(100vh - 88px)!important;
    }
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:14px 14px 16px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
    align-items:flex-start!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    flex-direction:column-reverse!important;
    align-items:stretch!important;
    min-height:104px!important;
    padding:12px 14px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
    width:100%!important;
  }
}

/* v4.43.5 HARD RESET - Professional Section Settings modal
   The dialog uses a real fixed viewport-sized card: header + scrollable body + footer.
   The footer never overlays the fields, and the body always scrolls vertically. */
html:has(body.section-settings-modal-open),
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop[data-section-settings-modal]{
  position:fixed!important;
  inset:0!important;
  z-index:10020!important;
  display:grid!important;
  place-items:center!important;
  padding:24px!important;
  margin:0!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  background:rgba(15,23,42,.46)!important;
  backdrop-filter:blur(2px)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
  position:relative!important;
  inset:auto!important;
  transform:none!important;
  width:min(860px,calc(100vw - 48px))!important;
  height:calc(100vh - 48px)!important;
  max-height:760px!important;
  min-height:360px!important;
  margin:0!important;
  padding:0!important;
  box-sizing:border-box!important;
  display:grid!important;
  grid-template-rows:auto minmax(0,1fr)!important;
  overflow:hidden!important;
  border-radius:22px!important;
  border:1px solid rgba(203,213,225,.95)!important;
  background:#fff!important;
  box-shadow:0 30px 90px rgba(15,23,42,.30)!important;
}
@supports (height:100dvh){
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    height:calc(100dvh - 48px)!important;
    max-height:min(760px,calc(100dvh - 48px))!important;
  }
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
  grid-row:1!important;
  flex:none!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:14px!important;
  min-height:0!important;
  padding:16px 22px!important;
  box-sizing:border-box!important;
  border-bottom:1px solid #e8eef5!important;
  background:linear-gradient(135deg,#ffffff 0%,#f7fbff 100%)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-form{
  grid-row:2!important;
  min-height:0!important;
  height:100%!important;
  width:100%!important;
  max-height:none!important;
  display:grid!important;
  grid-template-rows:minmax(0,1fr) auto!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
  gap:0!important;
  box-sizing:border-box!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
  grid-row:1!important;
  min-height:0!important;
  height:100%!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  scrollbar-width:thin!important;
  scrollbar-gutter:stable!important;
  padding:18px 22px 34px!important;
  margin:0!important;
  box-sizing:border-box!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:11px!important;
  background:#fff!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
  grid-row:2!important;
  flex:none!important;
  position:static!important;
  inset:auto!important;
  transform:none!important;
  z-index:1!important;
  min-height:0!important;
  height:auto!important;
  margin:0!important;
  padding:14px 22px!important;
  box-sizing:border-box!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  background:#fff!important;
  border-top:1px solid #e8eef5!important;
  box-shadow:0 -12px 28px rgba(15,23,42,.08)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
  width:auto!important;
  min-width:112px!important;
  min-height:42px!important;
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid{
  display:grid!important;
  grid-template-columns:210px minmax(0,1fr)!important;
  gap:12px 16px!important;
  align-items:center!important;
  padding:16px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
  grid-column:1 / -1!important;
  display:grid!important;
  grid-template-columns:210px minmax(0,1fr)!important;
  gap:12px 16px!important;
  align-items:center!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-check,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-hint{
  grid-column:1 / -1!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid textarea[name="locked_message"]{
  min-height:110px!important;
  resize:vertical!important;
}
@media (max-width:760px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    padding:10px!important;
    place-items:stretch!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    width:100%!important;
    height:calc(100vh - 20px)!important;
    max-height:none!important;
    border-radius:18px!important;
  }
  @supports (height:100dvh){
    .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
      height:calc(100dvh - 20px)!important;
      max-height:none!important;
    }
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding:12px 14px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:14px 14px 26px!important;
    gap:9px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
    flex-direction:column!important;
    align-items:stretch!important;
    gap:10px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    flex-direction:column-reverse!important;
    align-items:stretch!important;
    padding:12px 14px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
    width:100%!important;
  }
}
@media (max-height:560px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    padding:8px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    height:calc(100vh - 16px)!important;
    max-height:none!important;
    min-height:0!important;
  }
  @supports (height:100dvh){
    .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
      height:calc(100dvh - 16px)!important;
      max-height:none!important;
    }
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding:8px 12px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header .muted{
    display:none!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:10px 12px 18px!important;
    gap:7px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    padding:8px 12px!important;
  }
}

/* v4.43.6 FINAL ROOT FIX - Section settings modal
   The overlay itself scrolls. No ancestor clips the form or native select menus.
   Save footer is sticky but the form has safe padding so fields are never hidden behind it. */
html:has(body.section-settings-modal-open),
body.section-settings-modal-open{
  overflow:hidden!important;
}
.section-settings-modal-backdrop[data-section-settings-modal]{
  position:fixed!important;
  inset:0!important;
  z-index:10020!important;
  display:block!important;
  width:100vw!important;
  height:100vh!important;
  max-height:none!important;
  padding:28px 24px 96px!important;
  margin:0!important;
  box-sizing:border-box!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  touch-action:pan-y!important;
  background:rgba(15,23,42,.48)!important;
  backdrop-filter:blur(2px)!important;
}
@supports (height:100dvh){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    height:100dvh!important;
  }
}
.section-settings-modal-backdrop[data-section-settings-modal][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
  position:relative!important;
  inset:auto!important;
  transform:none!important;
  display:block!important;
  width:min(900px,100%)!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  margin:0 auto!important;
  padding:0!important;
  overflow:visible!important;
  box-sizing:border-box!important;
  border-radius:22px!important;
  border:1px solid rgba(203,213,225,.98)!important;
  background:#fff!important;
  box-shadow:0 30px 90px rgba(15,23,42,.30)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
  position:sticky!important;
  top:0!important;
  z-index:30!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:16px!important;
  padding:18px 24px!important;
  margin:0!important;
  box-sizing:border-box!important;
  border-bottom:1px solid #e8eef5!important;
  border-radius:22px 22px 0 0!important;
  background:linear-gradient(135deg,#ffffff 0%,#f7fbff 100%)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-form{
  display:block!important;
  width:100%!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  padding:0!important;
  margin:0!important;
  overflow:visible!important;
  box-sizing:border-box!important;
  background:#fff!important;
  border-radius:0 0 22px 22px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:12px!important;
  width:100%!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  padding:20px 24px 110px!important;
  margin:0!important;
  overflow:visible!important;
  box-sizing:border-box!important;
  background:#fff!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
  position:sticky!important;
  bottom:0!important;
  z-index:40!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:12px!important;
  width:100%!important;
  min-height:76px!important;
  height:auto!important;
  padding:16px 24px!important;
  margin:-86px 0 0!important;
  box-sizing:border-box!important;
  border-top:1px solid #e8eef5!important;
  border-radius:0 0 22px 22px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.94),#fff 34%)!important;
  box-shadow:0 -18px 30px rgba(15,23,42,.08)!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
  width:auto!important;
  min-width:112px!important;
  min-height:44px!important;
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll > label{
  margin:0!important;
  font-size:12px!important;
  line-height:1.35!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll input,
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll select,
.section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll textarea{
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
  overflow:visible!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-box{
  overflow:visible!important;
  margin-top:4px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:14px!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid{
  display:grid!important;
  grid-template-columns:230px minmax(0,1fr)!important;
  gap:14px 18px!important;
  align-items:center!important;
  padding:18px!important;
  overflow:visible!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > label:not(.sequential-check){
  grid-column:1!important;
  margin:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > select,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > input,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > textarea{
  grid-column:2!important;
  min-width:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
  grid-column:1 / -1!important;
  display:grid!important;
  grid-template-columns:230px minmax(0,1fr)!important;
  gap:14px 18px!important;
  align-items:center!important;
  overflow:visible!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target][hidden]{
  display:none!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > label{
  grid-column:1!important;
  margin:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > select,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > input,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > textarea{
  grid-column:2!important;
  min-width:0!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-check,
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-hint{
  grid-column:1 / -1!important;
}
.section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid textarea[name="locked_message"]{
  min-height:118px!important;
  resize:vertical!important;
}
@media (max-width:760px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    padding:12px 10px 86px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] > .section-settings-modal{
    width:100%!important;
    border-radius:18px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding:14px 16px!important;
    border-radius:18px 18px 0 0!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:16px 16px 118px!important;
    gap:10px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-head{
    flex-direction:column!important;
    align-items:stretch!important;
    gap:10px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target]{
    grid-template-columns:1fr!important;
    gap:9px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > label:not(.sequential-check),
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > select,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > input,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > textarea,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > label,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > select,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > input,
  .section-settings-modal-backdrop[data-section-settings-modal] .sequential-settings-grid > [data-seq-target] > textarea{
    grid-column:1!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions{
    min-height:auto!important;
    margin:-92px 0 0!important;
    padding:14px 16px!important;
    flex-direction:column-reverse!important;
    align-items:stretch!important;
    border-radius:0 0 18px 18px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-actions .btn{
    width:100%!important;
  }
}
@media (max-height:560px){
  .section-settings-modal-backdrop[data-section-settings-modal]{
    padding-top:8px!important;
    padding-bottom:80px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header{
    padding:10px 14px!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-modal-header .muted{
    display:none!important;
  }
  .section-settings-modal-backdrop[data-section-settings-modal] .section-settings-scroll{
    padding:12px 14px 114px!important;
    gap:8px!important;
  }
}

/* RTL-safe section hover action menu: open away from the sidebar and never under it. */
.dir-rtl .section-edit-menu{
  left:auto;
  right:24px;
  direction:ltr;
  flex-direction:row-reverse;
  transform:translateX(6px);
}
.dir-rtl .section-edit-menu:hover,
.dir-rtl .section-edit-menu-wrap:hover .section-edit-menu,
.dir-rtl .section-edit-menu-wrap:focus-within .section-edit-menu{
  transform:translateX(0);
}
.dir-rtl .section-edit-menu-wrap::after{
  left:auto;
  right:18px;
}
.dir-rtl .section-menu-form{
  direction:ltr;
}
@media(max-width:800px){
  .dir-rtl .section-edit-menu{
    left:auto;
    right:24px;
  }
  .dir-rtl .section-edit-menu-wrap::after{
    left:auto;
    right:18px;
  }
}
