*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading{color:#666;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;display:flex}.navbar{color:#fff;background:#1a1a2e;justify-content:space-between;align-items:center;padding:.75rem 2rem;display:flex}.nav-brand{color:#fff;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:700;text-decoration:none;display:flex}.nav-logo{object-fit:cover;border-radius:6px;width:32px;height:32px}.nav-links{align-items:center;gap:1.5rem;display:flex}.nav-links a{color:#a0aec0;text-decoration:none;transition:color .2s}.nav-links a:hover{color:#fff}.nav-user{color:#63b3ed;font-size:.9rem}.btn{cursor:pointer;color:#fff;background:#4361ee;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;transition:background .2s}.btn:hover{background:#3a56d4}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-danger{background:#e63946}.btn-danger:hover{background:#c5303c}.btn-success{background:#2d6a4f}.btn-success:hover{background:#245a42}.login-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{background:#fff;border-radius:12px;flex-direction:column;gap:1rem;width:100%;max-width:400px;padding:2.5rem;display:flex;box-shadow:0 4px 20px #00000014}.login-logo{object-fit:cover;border-radius:12px;width:80px;height:80px;margin:0 auto;display:block}.login-form h1{text-align:center;color:#1a1a2e;margin-bottom:.5rem}input,select{border:1px solid #d1d5db;border-radius:6px;outline:none;padding:.6rem .8rem;font-size:.95rem;transition:border .2s}input:focus,select:focus{border-color:#4361ee}.error{color:#e63946;background:#fef2f2;border-radius:6px;padding:.5rem;font-size:.9rem}.success-msg{color:#2d6a4f;margin-left:1rem;font-size:.9rem}.page{max-width:1200px;margin:0 auto;padding:2rem}.page h2{color:#1a1a2e;margin-bottom:1.5rem}.create-form{background:#fff;border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:2rem;padding:1.5rem;display:flex;box-shadow:0 2px 8px #0000000f}.create-form input{flex:1;min-width:150px}.data-table{border-collapse:collapse;background:#fff;border-radius:10px;width:100%;overflow:hidden;box-shadow:0 2px 8px #0000000f}.data-table th{text-align:left;color:#555;background:#f8f9fa;padding:.75rem 1rem;font-weight:600}.data-table td{border-top:1px solid #eee;padding:.75rem 1rem}.data-table tr:hover td{background:#f8f9ff}.clickable-row{cursor:pointer}.clickable-row:hover td{background:#f0f4ff}.clickable-row.expanded td{background:#f0f4ff;border-bottom:none}.expand-arrow{color:#999;margin-left:.4rem;font-size:.75rem}.avail-row td{background:#f8f9ff;padding:0 1rem 1rem}.avail-loading,.avail-empty{color:#888;padding:.5rem 0;font-size:.9rem}.avail-list{flex-direction:column;gap:.75rem;display:flex}.avail-week{background:#fff;border-radius:8px;padding:.75rem;box-shadow:0 1px 4px #0000000d}.avail-week-header{color:#1a1a2e;margin-bottom:.5rem;font-size:.85rem;font-weight:600}.avail-days{flex-wrap:wrap;gap:.5rem;display:flex}.avail-day{border-radius:6px;flex-direction:column;align-items:center;gap:.15rem;min-width:80px;padding:.4rem .6rem;font-size:.8rem;display:flex}.avail-day.available{color:#065f46;background:#d1fae5}.avail-day.unavailable{color:#991b1b;background:#fee2e2}.avail-day-name{font-weight:600}.avail-day-time{font-size:.75rem}.pending-badge{color:#fff;vertical-align:middle;background:#e63946;border-radius:12px;margin-left:.5rem;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.requests-section{margin-bottom:1rem}.requests-section h4{color:#555;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem;font-size:.85rem}.request-card{background:#fff;border-radius:8px;margin-bottom:.5rem;padding:.75rem;box-shadow:0 1px 4px #0000000d}.request-card.pending{border-left:3px solid #f59e0b}.request-card.approved{opacity:.7;border-left:3px solid #2d6a4f}.request-card.denied{opacity:.7;border-left:3px solid #e63946}.request-card-header{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:flex}.request-date{color:#888;font-size:.8rem;font-weight:400}.request-actions{gap:.4rem;margin-left:auto;display:flex}.request-status{border-radius:10px;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.request-status.pending{color:#92400e;background:#fef3c7}.request-status.approved{color:#065f46;background:#d1fae5}.request-status.denied{color:#991b1b;background:#fee2e2}.my-requests{margin-top:2rem}.my-requests h3{margin-bottom:.75rem;font-size:1.1rem}.default-school-row{background:#fff;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem;display:flex;box-shadow:0 1px 4px #0000000d}.default-school-row label{white-space:nowrap;font-size:.85rem;font-weight:600}.default-school-row select{min-width:180px}.week-picker{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.availability-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:1rem;display:grid;overflow:hidden}.day-card{background:#fff;border-radius:10px;min-width:0;padding:1.25rem;transition:transform .2s;overflow:hidden;box-shadow:0 2px 8px #0000000f}.day-card:hover{transform:translateY(-2px)}.day-card.unavailable{opacity:.5;background:#f8f8f8}.day-header{align-items:center;gap:.5rem;margin-bottom:.75rem;font-weight:600;display:flex}.day-header label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.time-inputs{flex-direction:column;align-items:stretch;gap:.5rem;display:flex}.time-inputs input{width:100%;min-width:0}.roster-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.roster-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.status-badge{text-transform:uppercase;border-radius:20px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.status-badge.draft{color:#92400e;background:#fef3c7}.status-badge.published{color:#065f46;background:#d1fae5}.add-shift-bar{background:#fff;border-radius:10px;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:1rem;display:flex;box-shadow:0 2px 8px #0000000f}.add-shift-bar select{min-width:200px}.roster-grid{grid-template-columns:repeat(5,1fr);gap:1rem;display:grid}.day-column{background:#f0f2f5;border-radius:10px;min-height:300px;padding:1rem}.day-column h3{text-align:center;color:#555;margin-bottom:.75rem;font-size:.95rem}.shifts-container{flex-direction:column;gap:.5rem;display:flex}.shift-card{cursor:grab;background:#fff;border-left:3px solid #4361ee;border-radius:8px;flex-direction:column;gap:.25rem;padding:.75rem;transition:box-shadow .2s;display:flex;position:relative;box-shadow:0 1px 4px #00000014}.shift-card:hover{box-shadow:0 3px 10px #0000001f}.shift-card.dragging{opacity:.8;box-shadow:0 8px 25px #00000026}.shift-card strong{font-size:.9rem}.shift-card span{color:#666;font-size:.8rem}.remove-btn{color:#999;cursor:pointer;background:0 0;border:none;font-size:1rem;line-height:1;position:absolute;top:4px;right:6px}.remove-btn:hover{color:#e63946}.settings-form{background:#fff;border-radius:10px;flex-direction:column;gap:.75rem;max-width:450px;padding:1.5rem;display:flex;box-shadow:0 2px 8px #0000000f}.settings-form label{font-weight:600}.settings-hint{color:#666;margin:0;font-size:.85rem}.operating-hours-inputs{align-items:center;gap:.5rem;display:flex}.operating-hours-inputs input{flex:1}.dropdown{position:relative}.dropdown-menu{z-index:10;background:#fff;border-radius:6px;min-width:200px;margin-top:.25rem;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:0 4px 16px #0000001f}.dropdown-menu button{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:.6rem 1rem;font-size:.9rem;display:block}.dropdown-menu button:hover{background:#f0f2f5}.prompt-bar{background:#fff;border-radius:10px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:1rem;display:flex;box-shadow:0 2px 8px #0000000f}.prompt-bar input{flex:1}.school-tag{color:#4361ee;align-self:flex-start;font-size:.75rem}.day-toggles{gap:.4rem;display:flex}.day-toggle{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:.35rem .7rem;font-size:.85rem;transition:all .2s}.day-toggle.active{color:#fff;background:#4361ee;border-color:#4361ee}.day-schools{flex-wrap:wrap;justify-content:center;gap:.3rem;margin-bottom:.5rem;display:flex}.day-school-label{color:#4361ee;background:#e8ecff;border-radius:4px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}@media (width<=768px){.availability-grid,.roster-grid{grid-template-columns:1fr}.navbar{flex-direction:column;gap:.5rem}.create-form{flex-direction:column}}
