:root{--school-purple:#6D28D9;--school-purple-dark:#4C1D95;--school-yellow:#FACC15;--school-yellow-dark:#CA8A04;--school-bg:#F8F7FC;--text:#111827;--muted:#6B7280;--line:#E5E7EB;--card:#FFFFFF}
*{box-sizing:border-box}
html{font-family:Sarabun,Tahoma,sans-serif}
body{margin:0;background:var(--school-bg);color:var(--text);font-family:Sarabun,Tahoma,sans-serif;font-size:16px;line-height:1.55}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer;border:0}
table{border-collapse:collapse;width:100%}
th,td{vertical-align:middle}
.icon{width:1.15rem;height:1.15rem;flex:0 0 auto}
.brand-logo{width:46px;height:46px;border-radius:8px;object-fit:cover;background:var(--school-yellow);box-shadow:0 0 0 2px rgba(255,255,255,.22)}
.login-logo{width:82px;height:82px;border-radius:16px;object-fit:cover;margin:0 auto .9rem;background:var(--school-yellow);box-shadow:0 12px 28px rgba(76,29,149,.18)}
.nav-link,.icon-button,.section-title,.stat-card{display:flex;align-items:center;gap:.7rem}
.nav-link{font-weight:600;color:rgba(255,255,255,.94)}
.nav-link .icon{opacity:.9}
.icon-button{justify-content:center}
.section-title{font-weight:700;font-size:1.05rem}
.stat-card{justify-content:flex-start}
.stat-icon{width:48px;height:48px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto}
.stat-icon .icon{width:24px;height:24px}
.stat-icon.purple{background:#F3E8FF;color:var(--school-purple)}
.stat-icon.yellow{background:#FEF3C7;color:#A16207}
.stat-icon.slate{background:#E0F2FE;color:#0369A1}
.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .6rem;font-size:.78rem;font-weight:700}
.status-planned{background:#ede9fe;color:#5b21b6}.status-approved{background:#dcfce7;color:#166534}.status-in_progress{background:#fef3c7;color:#92400e}.status-completed{background:#dbeafe;color:#1d4ed8}.status-cancelled{background:#fee2e2;color:#991b1b}
.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.w-full{width:100%}.w-32{width:8rem}.h-10{height:2.5rem}.w-10{width:2.5rem}.h-16{height:4rem}.w-16{width:4rem}.max-w-xl{max-width:36rem}
.grid{display:grid}.flex{display:flex}.inline-flex{display:inline-flex}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}
.place-items-center{place-items:center}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.flex-1{flex:1 1 0%}.flex-wrap{flex-wrap:wrap}.text-right{text-align:right}.text-left{text-align:left}.text-center{text-align:center}
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}
.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}
.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-8{padding:2rem}
.rounded{border-radius:8px}.rounded-lg{border-radius:10px}.border{border:1px solid var(--line)}.border-t{border-top:1px solid var(--line)}.border-b{border-bottom:1px solid var(--line)}.border-white\/10{border-color:rgba(255,255,255,.1)}.border-green-200{border-color:#BBF7D0}.border-red-200{border-color:#FECACA}
.bg-white{background:#fff}.bg-gray-50{background:#F9FAFB}.bg-gray-200{background:#E5E7EB}.bg-gray-900{background:#111827}.bg-green-50{background:#F0FDF4}.bg-red-50{background:#FEF2F2}.bg-red-600{background:#DC2626}.bg-green-700{background:#15803D}.bg-school-purple{background:var(--school-purple)}.bg-school-purpleDark{background:var(--school-purple-dark)}.bg-school-yellow{background:var(--school-yellow)}
.text-white{color:#fff}.text-gray-500{color:#6B7280}.text-gray-600{color:#4B5563}.text-gray-900{color:#111827}.text-green-800{color:#166534}.text-red-800{color:#991B1B}.text-school-purple{color:var(--school-purple)}.text-school-purpleDark{color:var(--school-purple-dark)}.text-white\/70{color:rgba(255,255,255,.7)}
.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.leading-tight{line-height:1.25}.whitespace-pre-line{white-space:pre-line}
.shadow{box-shadow:0 1px 2px rgba(17,24,39,.06),0 1px 8px rgba(17,24,39,.05)}.overflow-x-auto{overflow-x:auto}.min-w-full{min-width:100%}
input,select,textarea{width:100%;border:1px solid #D1D5DB;border-radius:8px;background:#fff;color:var(--text);padding:.5rem .75rem;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--school-purple);box-shadow:0 0 0 3px rgba(109,40,217,.13)}
button,.button{border-radius:8px;transition:background .15s ease,transform .15s ease}
button:hover,.button:hover{transform:translateY(-1px)}
.hover\:bg-white\/10:hover{background:rgba(255,255,255,.1)}.hover\:bg-school-purpleDark:hover{background:var(--school-purple-dark)}
@media (min-width:640px){.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}
@media (min-width:1024px){.lg\:flex{display:flex}.lg\:w-72{width:18rem}.lg\:min-h-screen{min-height:100vh}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:col-span-2{grid-column:span 2/span 2}}
@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:900px){aside{position:relative}.brand-logo{width:40px;height:40px}.text-2xl{font-size:1.25rem}}

/* Reference-style school dashboard */
.app-shell{min-height:100vh;display:grid;grid-template-columns:240px minmax(0,1fr);background:#F7F6FE}
.app-sidebar{background:#fff;border-right:1px solid #ECEAF6;display:flex;flex-direction:column;min-height:100vh;box-shadow:8px 0 30px rgba(76,29,149,.04);overflow:hidden}
.sidebar-brand{display:flex;gap:.8rem;align-items:center;padding:1.35rem 1rem 1.25rem;border-bottom:1px solid #F0EEF8;min-height:104px}
.brand-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;background:#FACC15;box-shadow:0 8px 22px rgba(76,29,149,.16)}
.brand-name{font-size:.92rem;font-weight:700;color:#1F2937;line-height:1.25}
.brand-subtitle{font-size:.72rem;color:#6B7280;line-height:1.3;margin-top:.12rem}
.sidebar-nav{padding:1rem .75rem;display:grid;gap:.38rem;flex:1;align-content:start;grid-auto-rows:min-content}
.side-item{display:flex;align-items:center;gap:.75rem;min-height:44px;padding:.68rem .85rem;border-radius:12px;color:#5B6071;font-weight:600;font-size:.9rem;line-height:1.25}
.side-item:hover{background:#F5F3FF;color:#5B21B6}
.side-item.active{background:#F0EDFF;color:#5B21B6;box-shadow:inset 3px 0 0 #6D74FF}
.side-item .icon{width:18px;height:18px}
.sidebar-logout{padding:1rem .9rem;margin-top:auto}
.sidebar-logout button{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;background:linear-gradient(135deg,#818CF8,#6366F1);color:#fff;padding:.8rem 1rem;border-radius:14px;font-weight:700;box-shadow:0 12px 22px rgba(91,110,245,.22)}
.app-main{min-width:0;display:flex;flex-direction:column;min-height:100vh}
.app-header{height:86px;background:#fff;border-bottom:1px solid #ECEAF6;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.6rem}
.app-header h1{margin:0;font-size:1.45rem;color:#1F2937;font-weight:700}
.app-header p{margin:.22rem 0 0;color:#6B7280;font-size:.9rem}
.header-actions{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;justify-content:flex-end}
.toolbar-button{display:flex;align-items:center;gap:.42rem;color:#fff;font-size:.78rem;font-weight:700;padding:.55rem .75rem;border-radius:8px;box-shadow:0 6px 14px rgba(31,41,55,.08)}
.toolbar-button.blue{background:#5B6EF5}.toolbar-button.green{background:#22B86A}.toolbar-button.red{background:#EF5B5B}.toolbar-button.amber{background:#E5A529}
.toolbar-button .icon{width:15px;height:15px}
.user-chip{display:flex;align-items:center;gap:.55rem;margin-left:.4rem}
.user-chip img{width:34px;height:34px;border-radius:50%;object-fit:cover}
.user-chip strong{display:block;font-size:.84rem}.user-chip span{display:block;color:#6B7280;font-size:.75rem}
.app-content{padding:1.45rem 1.6rem 2rem;flex:1}
.app-footer{height:38px;display:flex;align-items:center;justify-content:space-between;background:#5B6EF5;color:#fff;font-size:.78rem;padding:0 1.6rem}
.analytics-grid{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:1.1rem}
.chart-card,.table-card{background:#fff;border:1px solid #ECEAF6;border-radius:14px;box-shadow:0 10px 28px rgba(31,41,55,.05);padding:1.25rem}
.chart-card.wide{min-height:318px}
.card-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.card-heading h2{margin:0;font-size:1rem;font-weight:700;color:#1F2937}
.card-heading p{margin:.18rem 0 0;font-size:.8rem;color:#7B8190}
.icon.muted{color:#A3A8B8}
.bar-chart{height:230px;display:flex;align-items:end;justify-content:center;gap:1.2rem;padding:.8rem .5rem 0;border-bottom:1px solid #ECEAF6}
.bar-item{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:end;gap:.55rem;min-width:46px}
.bar-track{height:178px;width:34px;border-radius:10px;background:#F2F4FA;display:flex;align-items:end;overflow:hidden}
.bar-fill{width:100%;border-radius:10px 10px 0 0;min-height:8px;transition:height .2s ease}
.bar-item strong{font-size:.78rem;color:#7B8190}
.pie-wrap,.donut-wrap{display:grid;place-items:center;min-height:154px}
.pie-chart,.donut-chart{width:150px;height:150px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(255,255,255,.75)}
.donut-chart{position:relative}
.donut-chart::after{content:"";position:absolute;inset:34px;background:#fff;border-radius:50%;box-shadow:0 0 0 1px #EEF0F6}
.pie-chart.empty,.donut-chart.empty{background:#EEF0F6}
.legend-list{display:grid;gap:.45rem;margin-top:.6rem}
.legend-list div{display:grid;grid-template-columns:12px minmax(0,1fr) auto;align-items:center;gap:.45rem;font-size:.76rem;color:#5B6071}
.legend-list span{width:10px;height:10px;border-radius:3px}.legend-list b{font-size:.72rem;color:#1F2937}.legend-list.compact div{font-size:.72rem}
.empty-chart{align-self:center;color:#9CA3AF;font-weight:600}
.summary-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin:1.15rem 0}
.mini-stat{background:#fff;border:1px solid #ECEAF6;border-radius:14px;padding:1rem;display:grid;grid-template-columns:42px 1fr;align-items:center;column-gap:.85rem;box-shadow:0 10px 28px rgba(31,41,55,.045)}
.mini-stat .icon{grid-row:span 2;width:42px;height:42px;padding:10px;background:#F0EDFF;border-radius:12px;color:#5B6EF5}
.mini-stat span{font-size:.78rem;color:#6B7280}.mini-stat strong{font-size:1.15rem;color:#1F2937}
.table-card table th{font-weight:700;color:#566074;background:#F8F8FC}.table-card table th,.table-card table td{padding:.78rem;border-bottom:1px solid #EEF0F6}
.audit-json{white-space:pre-wrap;max-width:560px;max-height:180px;overflow:auto;background:#F8F8FC;border:1px solid #EEF0F6;border-radius:8px;padding:.65rem;margin:.45rem 0 0;font-size:.78rem;color:#4B5563}
@media (max-width:1180px){.analytics-grid{grid-template-columns:1fr}.app-header{height:auto;align-items:flex-start;padding:1rem}.header-actions{justify-content:flex-start}.app-content{padding:1rem}.app-footer{display:none}}
@media (max-width:820px){.app-shell{grid-template-columns:1fr}.app-sidebar{min-height:auto}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar-logout{display:none}.summary-row{grid-template-columns:1fr}.toolbar-button span{display:none}.user-chip{display:none}}

.rich-text-field,.upload-panel,.attachment-sort-panel{display:grid;gap:.65rem;border:1px solid #EEF0F6;background:#FBFBFE;border-radius:12px;padding:1rem}
.logo-setting-preview{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:.85rem}
.logo-setting-preview img{width:74px;height:74px;border-radius:12px;object-fit:contain;background:#FACC15}
.logo-placeholder{width:74px;height:74px;border-radius:12px;display:grid;place-items:center;background:#FACC15;color:#4C1D95;font-weight:800;font-size:1.35rem}
.rich-toolbar{display:flex;flex-wrap:wrap;gap:.4rem}
.rich-toolbar button{background:#fff;border:1px solid #DDE2F1;color:#374151;border-radius:8px;padding:.4rem .65rem;font-weight:700}
.rich-toolbar button:hover{background:#F0EDFF;color:#5B21B6}
.rich-editor{min-height:180px;background:#fff;border:1px solid #D1D5DB;border-radius:10px;padding:1rem;outline:none}
.rich-editor:focus{border-color:var(--school-purple);box-shadow:0 0 0 3px rgba(109,40,217,.13)}
.project-description{background:#fff;border-top:1px solid #EEF0F6;padding-top:1rem;color:#374151}
.project-description p{margin:.4rem 0}.project-description ul,.project-description ol{margin:.4rem 0 .4rem 1.4rem}.project-description blockquote{border-left:4px solid #C4B5FD;margin:.8rem 0;padding:.4rem .8rem;background:#F5F3FF;border-radius:8px}
.attachment-stack{display:grid;gap:1rem;margin-top:1rem}
.attachment-card{border:1px solid #E5E7EB;border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 10px 24px rgba(31,41,55,.045)}
.attachment-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border-bottom:1px solid #EEF0F6}
.attachment-card-header h4{margin:.15rem 0 0;font-size:.98rem}
.attachment-type{display:inline-flex;background:#F0EDFF;color:#5B21B6;border-radius:999px;padding:.18rem .55rem;font-size:.74rem;font-weight:700}
.attachment-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.attachment-actions a,.attachment-actions button{border:1px solid #DDE2F1;background:#fff;color:#4F46E5;border-radius:8px;padding:.42rem .65rem;font-size:.8rem;font-weight:700}
.attachment-preview{height:520px;background:#F8F8FC}
.attachment-preview iframe,.attachment-full-frame iframe{width:100%;height:100%;border:0;background:#fff}
.attachment-preview img{display:block;max-width:100%;max-height:100%;height:100%;margin:auto;object-fit:contain}
.attachment-card.is-collapsed .attachment-preview{display:none}
.attachment-placeholder,.attachment-download-panel{height:100%;display:grid;place-items:center;text-align:center;color:#6B7280;padding:2rem}
.attachment-placeholder strong,.attachment-download-panel strong{font-size:1.4rem;color:#4F46E5}
.attachment-sort-list{display:grid;gap:.55rem}
.attachment-sort-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:.65rem .8rem}
.attachment-sort-item span{font-weight:600;color:#374151}.attachment-sort-item button{border:1px solid #DDE2F1;background:#F8F8FC;color:#374151;border-radius:8px;padding:.35rem .6rem}
.attachment-view-body{background:#111827;color:#fff}
.attachment-full{min-height:100vh;display:grid;grid-template-rows:auto 1fr}
.attachment-full-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;color:#111827}
.attachment-full-header h1{margin:.2rem 0;font-size:1.1rem}.attachment-full-header p{margin:0;color:#6B7280}.attachment-full-header a:first-child{color:#4F46E5;font-weight:700}
.attachment-full-frame{min-height:0;background:#111827;display:grid;place-items:center}
.attachment-full-frame img{max-width:100%;max-height:calc(100vh - 86px);object-fit:contain}
#project-edit-modal {
  backdrop-filter: blur(4px);
}

.modal-content-container {
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.scroll-thin {
  scrollbar-width: thin;
  scrollbar-color: var(--school-purple) transparent;
}

.scroll-thin::-webkit-scrollbar {
  width: 6px;
}

.scroll-thin::-webkit-scrollbar-thumb {
  background-color: var(--school-purple);
  border-radius: 10px;
}

.overflow-hidden {
  overflow: hidden;
}

.edit-project-container {
  height: calc(100vh - 120px); /* Adjust based on header/footer height */
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--school-purple) transparent;
}

.edit-project-container::-webkit-scrollbar {
  width: 6px;
}

.edit-project-container::-webkit-scrollbar-thumb {
  background-color: var(--school-purple);
  border-radius: 10px;
}

#staged-attachments:not(:empty){border:1px dashed #D1D5DB;padding:.75rem;border-radius:12px;background:#fff}
.staged-file-item{animation:slideIn 0.3s ease-out}
.animate-slideIn{animation:slideIn 0.3s ease-out}
@keyframes slideIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}


.project-present{min-height:100vh;background:#F5F3FF;color:#111827;padding:2rem}
.present-hero{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1.5rem;align-items:stretch;background:linear-gradient(135deg,#4C1D95,#6D28D9);border-radius:24px;padding:2rem;color:#fff;box-shadow:0 24px 60px rgba(76,29,149,.24)}
.present-back{display:inline-flex;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.25);padding:.42rem .8rem;border-radius:999px;font-size:.85rem;font-weight:700;margin-bottom:1.3rem}
.present-kicker{margin:0 0 .35rem;color:#FDE68A;font-weight:700}
.present-hero h1{margin:0;font-size:2.4rem;line-height:1.18;letter-spacing:0;max-width:980px}
.present-meta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.2rem}
.present-meta span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:.42rem .75rem}
.present-budget{background:#fff;color:#111827;border-radius:20px;padding:1.4rem;display:grid;align-content:center;box-shadow:0 18px 45px rgba(17,24,39,.14)}
.present-budget span{color:#6B7280;font-weight:700}.present-budget strong{font-size:2rem;color:#6D28D9}.present-budget small{color:#4B5563}
.present-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:1.4rem;margin:1.4rem 0}
.present-card{background:#fff;border:1px solid #E8E3FF;border-radius:20px;padding:1.4rem;box-shadow:0 18px 45px rgba(76,29,149,.08)}
.present-card h2{margin:0 0 1rem;font-size:1.25rem}
.present-facts{display:grid;gap:.8rem;margin:0}.present-facts div{border-bottom:1px solid #EEF0F6;padding-bottom:.75rem}.present-facts dt{color:#6B7280;font-size:.84rem}.present-facts dd{margin:.2rem 0 0;font-weight:700;color:#1F2937}
.present-attachments{display:grid;gap:1.2rem}
.present-file{border:1px solid #E5E7EB;border-radius:16px;overflow:hidden;background:#fff}
.present-file header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid #EEF0F6}
.present-file header span{display:inline-flex;background:#F0EDFF;color:#5B21B6;border-radius:999px;padding:.18rem .55rem;font-size:.75rem;font-weight:700}.present-file h3{margin:.2rem 0 0;font-size:1rem}.present-file a{color:#4F46E5;font-weight:700}
.present-file-preview{height:640px;background:#F8F8FC;display:grid;place-items:center}
.present-file-preview iframe{width:100%;height:100%;border:0;background:#fff}.present-file-preview img{max-width:100%;max-height:100%;object-fit:contain}
@media print{.present-back,.present-file a{display:none}.project-present{padding:0;background:#fff}.present-card,.present-hero{box-shadow:none;break-inside:avoid}.present-file{break-inside:avoid}}
@media (max-w-960px){.project-present{padding:1rem}.present-hero,.present-grid{grid-template-columns:1fr}.present-hero h1{font-size:1.8rem}.present-file-preview{height:420px}}

/* Modal positioning and layouts */
.fixed { position: fixed; }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }
.bg-black\/60 { background-color: rgba(0, 0, 0, 0.6); }
.bg-black\/50 { background-color: rgba(0, 0, 0, 0.5); }
.z-\[110\] { z-index: 110; }
.z-\[100\] { z-index: 100; }
.rounded-3xl { border-radius: 1.5rem; }
.rounded-2xl { border-radius: 1rem; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-full { border-radius: 9999px; }
.max-w-4xl { max-width: 56rem; }
.max-w-sm { max-width: 24rem; }
.max-h-full { max-height: 100%; }
.flex-col { flex-direction: column; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.p-2 { padding: 0.5rem; }
.p-6 { padding: 1.5rem; }
.py-2\.5 { padding-top: 0.625rem; padding-bottom: 0.625rem; }
.hover\:bg-gray-100:hover { background-color: #f3f4f6; }
.hover\:bg-gray-200:hover { background-color: #e5e7eb; }
.hover\:bg-red-700:hover { background-color: #b91c1c; }
.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.w-6 { width: 1.5rem; }
.h-6 { height: 1.5rem; }
.overflow-y-auto { overflow-y: auto; }
.font-bold { font-weight: 700; }
.animate-spin {
  animation: spin 1s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.border-b-2 { border-bottom-width: 2px; }
.border-school-purple { border-color: var(--school-purple); }
.shadow-2xl {
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}
