:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#213547;background-color:#f9f9f9;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}#root{width:100%}.app-container{text-align:center;background:#fff;border-radius:12px;max-width:600px;margin:0 auto;padding:2rem;box-shadow:0 4px 20px #00000014}.pin-display{justify-content:center;gap:15px;margin:2rem 0;display:flex}.pin-dot{border:2px solid #ccc;border-radius:50%;width:20px;height:20px;transition:all .2s}.pin-dot.filled{background-color:#4a90e2;border-color:#4a90e2;transform:scale(1.1)}.pin-grid{grid-template-columns:repeat(3,1fr);gap:15px;max-width:300px;margin:0 auto;display:grid}.pin-btn{cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;padding:1.5rem;font-size:1.5rem;transition:background .2s}.pin-btn:active{background:#e0e0e0}.clear-btn{color:#d0021b;background:#ffeded}.error-message{color:#d0021b;margin-bottom:1rem}.status-indicator{border-radius:8px;margin:1rem 0;padding:1rem;font-weight:700}.status-indicator.in{color:#2e7d32;background:#e6f7e9}.status-indicator.out{color:#ed6c02;background:#fff4e5}.main-action-btn{cursor:pointer;color:#fff;border:none;border-radius:8px;width:100%;margin:1rem 0;padding:1.5rem;font-size:1.25rem}.main-action-btn.in{background:#4caf50}.main-action-btn.out{background:#f44336}.logout-btn{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:4px;padding:.5rem 1rem}.reports-container{text-align:left}.reports-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid #eee;padding:12px}th{background:#f8f8f8}.view-reports-btn{color:#4a90e2;cursor:pointer;background:0 0;border:none;margin-top:2rem;text-decoration:underline}.back-btn{cursor:pointer;background:#eee;border:none;border-radius:4px;padding:.5rem 1rem}.admin-link-btn{color:#999;cursor:pointer;background:0 0;border:none;margin-top:2rem;font-size:.8rem;text-decoration:underline}.admin-login-container form{flex-direction:column;gap:1rem;max-width:300px;margin:0 auto;display:flex}.admin-login-container input{border:1px solid #ddd;border-radius:4px;padding:.8rem}.admin-login-container .login-btn{color:#fff;cursor:pointer;background:#4a90e2;border:none;border-radius:4px;padding:.8rem}.admin-header{border-bottom:2px solid #eee;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.admin-tabs{gap:10px;margin-bottom:2rem;display:flex}.admin-tabs button{cursor:pointer;background:#f9f9f9;border:1px solid #ddd;border-radius:4px;flex:1;padding:.8rem}.admin-tabs button.active{color:#fff;background:#4a90e2;border-color:#4a90e2}.add-volunteer-form.vertical{flex-direction:column;align-items:stretch}.form-row{gap:10px;margin-bottom:10px;display:flex}.form-row input{flex:1}.actions-cell{justify-content:center;gap:8px;display:flex}.shift-btn{color:#fff;cursor:pointer;background:#2196f3;border:none;border-radius:4px;padding:.4rem .8rem}.manager-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.add-shift-form{background:#f8f8f8;border-radius:8px;align-items:center;gap:10px;margin-bottom:2rem;padding:1rem;display:flex}.add-shift-form select,.add-shift-form input{border:1px solid #ddd;border-radius:4px;padding:.5rem}.add-shift-form button{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:4px;padding:.5rem 1rem}.delete-btn{color:#fff;cursor:pointer;background:#f44336;border:none;border-radius:4px;padding:.4rem .8rem}.admin-dashboard .reports-header h2{display:none}.max-width-extend{max-width:900px!important}.date-range-picker .btn-group{gap:5px;display:flex}.date-range-picker .btn-group button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:.5rem .8rem;font-size:.9rem}.date-range-picker .btn-group button:hover{background:#f5f5f5}.date-range-picker .custom-range input[type=date]{border:1px solid #ddd;border-radius:4px;padding:.4rem}.summary-cards{gap:20px;margin-bottom:2rem;display:flex}.summary-cards .card{background:#f8f9fa;border-radius:8px;flex:1;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.summary-cards h4{color:#666;margin:0 0 .5rem;font-size:.9rem}.summary-cards p{color:#333;margin:0;font-size:1.8rem;font-weight:700}.summary-cards p.warning{color:#d0021b}.text-danger{color:#d0021b;font-weight:700}.bold{font-weight:700}.badge{border-radius:12px;margin-right:5px;padding:4px 8px;font-size:.75rem;font-weight:700}.badge.late{color:#c62828;background:#ffebee}.badge.early{color:#ef6c00;background:#fff3e0}.badge.on-time{color:#2e7d32;background:#e8f5e9}.coverage-calendar-container{text-align:left;gap:30px;display:flex}.calendar-wrapper{flex:1}.react-calendar{border-radius:8px;padding:10px;box-shadow:0 4px 12px #0000001a;border:none!important;width:100%!important}.calendar-indicator{justify-content:center;margin-top:4px;display:flex}.calendar-indicator .dot{background:#2196f3;border-radius:50%;width:6px;height:6px}.coverage-details{background:#fff;border:1px solid #eee;border-radius:8px;flex:1;max-height:500px;padding:1.5rem;overflow-y:auto}.hourly-grid{flex-direction:column;gap:8px;display:flex}.hour-slot{color:#999;background:#f5f5f5;border-radius:4px;justify-content:space-between;padding:8px 12px;display:flex}.hour-slot.active{color:#1976d2;background:#e3f2fd;font-weight:700}.hour-slot .time{font-family:monospace}.coverage-controls{background:#f8f9fa;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;display:flex}.nav-group{align-items:center;gap:10px;display:flex}.nav-group button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:.5rem 1rem;transition:background .2s}.nav-group button:hover{background:#f0f0f0}.nav-group input[type=date]{border:1px solid #ddd;border-radius:4px;padding:.5rem}.coverage-controls h3{color:#333;margin:0;font-size:1.1rem}.coverage-table{border-collapse:collapse;width:100%;font-size:.85rem}.coverage-table th,.coverage-table td{text-align:center;border:1px solid #ddd;padding:8px}.coverage-table th{background:#f4f4f4;font-weight:700}.hour-label{background:#fafafa;width:80px;font-weight:700}.coverage-cell.active{color:#1976d2;font-weight:700}.print-btn{color:#fff;cursor:pointer;background:#607d8b;border:none;border-radius:4px;padding:.6rem 1.2rem}.print-only{display:none}@media print{.no-print{display:none!important}.print-only{display:block!important}body{color:#000;background:#fff;margin:0;padding:0}.app-container{box-shadow:none;width:100%;margin:0;padding:0;max-width:100%!important}.admin-dashboard{padding:0;max-width:100%!important}.admin-tabs,.admin-header,.logout-btn,.back-btn,.report-controls{display:none!important}.summary-cards{gap:10px;margin-bottom:1rem}.summary-cards .card{box-shadow:none;border:1px solid #ddd;padding:1rem}table{border-collapse:collapse;width:100%}th,td{border:1px solid #ddd!important}.coverage-table{font-size:9pt}.coverage-cell{-webkit-print-color-adjust:exact;print-color-adjust:exact}.badge{border:1px solid #ccc}}.attendance-report .week-section{text-align:left;margin-bottom:3rem}.attendance-report h4{background:#f0f4f8;border-left:4px solid #4a90e2;border-radius:6px;margin-bottom:1rem;padding:10px 15px}.badge.unscheduled{color:#999;background:#f5f5f5}.volunteer-view{text-align:left}.volunteer-view h1{text-align:center}.action-buttons{flex-direction:column;gap:10px;display:flex}.volunteer-info-grid{grid-template-columns:1fr;gap:2rem;margin-top:2rem;display:grid}@media (width>=768px){.volunteer-info-grid{grid-template-columns:1fr 1fr}}.info-section{background:#f8f9fa;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.info-section h3{border-bottom:2px solid #eee;margin-top:0;margin-bottom:1rem;padding-bottom:.5rem}.shift-list{padding:0;list-style:none}.shift-list li{border-bottom:1px solid #eee;padding:8px 0}.history-table{width:100%;font-size:.9rem}.history-table th{text-align:left;background:0 0;padding:8px 4px}.history-table td{padding:8px 4px}
