:root{--primary:#2563eb;--primary-hover:#1d4ed8;--bg:#f8fafc;--card-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--blocked:#94a3b8}body{background-color:var(--bg);color:var(--text-main);margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}#app{flex-direction:column;min-height:100vh;display:flex}.auth-card{background:var(--card-bg);border-radius:1rem;width:100%;max-width:400px;margin:auto;padding:2.5rem;box-shadow:0 10px 15px -3px #0000001a}.auth-card h2{text-align:center;margin-top:0;margin-bottom:.5rem}.auth-card .subtitle{color:var(--text-muted);text-align:center;margin-bottom:2rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-group input{border:1px solid var(--border);box-sizing:border-box;border-radius:.5rem;width:100%;padding:.75rem;font-size:1rem}.auth-switch{text-align:center;margin-top:1.5rem;font-size:.875rem}.auth-switch a{color:var(--primary);font-weight:500;text-decoration:none}header{background:var(--card-bg);border-bottom:1px solid var(--border);padding:1rem 2rem}.header-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}header h1{color:var(--primary);margin:0;font-size:1.5rem}.user-nav{align-items:center;gap:1rem;display:flex}.user-email{color:var(--text-muted);font-size:.875rem}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.5rem;width:100%;padding:.75rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:.375rem;padding:.5rem 1rem}.btn-text{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.btn-text:hover{color:var(--text-main)}.btn-text-danger{color:var(--danger);cursor:pointer;background:0 0;border:none;font-size:.75rem}.status-selector{flex-direction:column;align-items:center;gap:.5rem;display:flex}.status-selector label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem;font-weight:600}.status-btns{gap:.5rem;display:flex}.status-select-btn{cursor:pointer;color:#fff;border:2px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;min-width:100px;height:44px;padding:.5rem 1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000000d}.status-select-btn.btn-avail{background:var(--success);border-color:var(--success);opacity:.7}.status-select-btn.btn-maybe{background:var(--warning);border-color:var(--warning);opacity:.7}.status-select-btn.btn-unavail{background:var(--danger);border-color:var(--danger);opacity:.7}.status-select-btn.active{opacity:1;transform:scale(1.05);box-shadow:0 4px 6px -1px #0000001a}.status-select-btn.btn-avail.active{background:var(--success);border-color:var(--success)}.status-select-btn.btn-maybe.active{background:var(--warning);border-color:var(--warning)}.status-select-btn.btn-unavail.active{background:var(--danger);border-color:var(--danger)}main{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:2rem}.calendar-container{background:var(--card-bg);border-radius:1rem;padding:2rem;box-shadow:0 4px 6px -1px #0000001a}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.month-nav{align-items:center;gap:1.5rem;display:flex}.month-nav h2{text-align:center;min-width:200px;margin:0}.btn-icon{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:.5rem;padding:.5rem .75rem;font-size:1.25rem;transition:all .2s}.btn-icon:hover{background:var(--bg);border-color:var(--primary)}.calendar-grid{background:var(--border);border:1px solid var(--border);border-radius:.5rem;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.weekday{background:var(--bg);text-align:center;text-transform:uppercase;color:var(--text-muted);padding:1rem;font-size:.75rem;font-weight:600}.day{background:var(--card-bg);box-sizing:border-box;flex-direction:column;height:120px;min-height:120px;padding:1rem;transition:background .2s;display:flex;position:relative;overflow:hidden}.day:not(.empty):not(.blocked):hover{background:#f8fafc}.day.empty{cursor:default;background:#f8fafc}.day-number{font-size:1.125rem;font-weight:600}.day-status{text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;border-radius:.25rem;width:fit-content;max-width:100%;margin-top:.25rem;padding:.15rem .4rem;font-size:.65rem;font-weight:700;display:inline-block;overflow:hidden}.day.Available .day-status{color:var(--success);background:#f0fdf4}.day.Maybe .day-status{color:var(--warning);background:#fffbeb}.day.Unavailable .day-status{color:var(--danger);background:#fef2f2}.day.blocked{cursor:not-allowed;opacity:.7;background:#f1f5f9}.day.blocked .day-status{color:var(--text-muted);background:#e2e8f0}.day.painting{box-shadow:inset 0 0 0 2px var(--primary);z-index:10}.btn-avail{background:var(--success)}.btn-maybe{background:var(--warning)}.btn-unavail{background:var(--danger)}.admin-grid-layout{grid-template-columns:350px 1fr;align-items:start;gap:2rem;display:grid}@media (width<=1024px){.admin-grid-layout{grid-template-columns:1fr}}.admin-day{cursor:pointer;height:120px;min-height:120px}.admin-day:hover{background:#f8fafc}.admin-stats{flex-direction:column;gap:2px;margin-top:.5rem;display:flex}.stat{border-radius:3px;padding:1px 4px;font-size:.7rem;font-weight:600}.stat.avail{color:var(--success);background:#f0fdf4}.stat.maybe{color:var(--warning);background:#fffbeb}.stat.unavail{color:var(--danger);background:#fef2f2}.stat.blocked-label{color:var(--text-muted);text-transform:uppercase;background:#e2e8f0;font-size:.6rem}@media (width<=768px){header{padding:1rem}.header-content{text-align:center;flex-direction:column;gap:1rem}.user-nav{flex-wrap:wrap;justify-content:center}main,.calendar-container{padding:1rem}.calendar-header{flex-direction:column;gap:1.5rem}.month-nav h2{min-width:auto}.status-selector{order:-1;width:100%}.status-btns{width:100%}.status-select-btn{flex:1;min-width:auto;padding:.75rem .25rem;font-size:.75rem}.calendar-grid{grid-template-columns:repeat(7,1fr)}.weekday{padding:.5rem .25rem;font-size:.6rem}.day{height:80px;min-height:80px;padding:.5rem}.day-number{font-size:.9rem}.day-status{padding:.1rem .2rem;font-size:.5rem}.admin-grid-layout{grid-template-columns:1fr}.admin-card{padding:1rem}.admin-day{height:80px;min-height:80px}.stat{font-size:.6rem}}@media (width<=480px){.calendar-grid{grid-template-columns:repeat(7,1fr);gap:1px}.weekday{padding:.5rem .1rem;font-size:.6rem}.day{flex-direction:column;align-items:center;height:auto;min-height:100px;padding:.5rem .25rem;display:flex}.day-number{margin-bottom:4px;font-size:.9rem}.day-status{margin-bottom:8px;padding:.1rem .2rem;font-size:.5rem}}.modal{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:1rem;width:90%;max-width:500px;max-height:80vh;padding:2rem;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}@media (width<=480px){.modal-content{width:95%;padding:1rem}.modal-table{font-size:.8rem}.modal-header h3{font-size:1.1rem}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.modal-header h3{margin:0}.modal-alert{color:var(--danger);background:#fef2f2;border-radius:.5rem;margin-bottom:1rem;padding:1rem;font-size:.875rem}.modal-table{border-collapse:collapse;width:100%}.modal-table th,.modal-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem}.modal-table th{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.admin-card{background:var(--card-bg);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a}.admin-sub-section{border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.admin-sub-section h4{color:var(--text-muted);text-transform:uppercase;margin-top:0;margin-bottom:1rem;font-size:.875rem}.reset-pw-section{border-bottom:none;margin-top:2rem;padding-bottom:0}.reset-pw-section .form-row{align-items:stretch}.reset-pw-section .form-input{flex:1}.help-text{color:var(--text-muted);margin-top:.5rem;font-size:.75rem;font-style:italic}.form-input{border:1px solid var(--border);background:#fff;border-radius:.375rem;width:100%;padding:.5rem;font-size:.875rem}.admin-manual-selector{background:var(--bg);border-radius:.5rem;margin-top:1rem;padding:1rem}.user-entry-indicator{border-radius:50%;width:8px;height:8px;position:absolute;bottom:8px;right:8px;box-shadow:0 0 0 2px #fff}.user-entry-indicator.Available{background:var(--success)}.user-entry-indicator.Maybe{background:var(--warning)}.user-entry-indicator.Unavailable{background:var(--danger)}.admin-day.Available{border-left:4px solid var(--success)}.admin-day.Maybe{border-left:4px solid var(--warning)}.admin-day.Unavailable{border-left:4px solid var(--danger)}.block-form{flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1;margin-bottom:0}.block-form input{border:1px solid var(--border);border-radius:.375rem;padding:.5rem}.blocked-list ul{margin:0;padding:0;list-style:none}.blocked-list li{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 0;font-size:.875rem;display:flex}.table-container{overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{border-bottom:2px solid var(--border);color:var(--text-muted);padding:1rem;font-size:.875rem}td{border-bottom:1px solid var(--border);padding:1rem}.badge{text-transform:uppercase;border-radius:9999px;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.badge.Available{color:#166534;background:#dcfce7}.badge.Maybe{color:#92400e;background:#fef3c7}.badge.Unavailable{color:#991b1b;background:#fee2e2}
