.app{min-height:100vh;background-color:#f3f4f6}.header{background-color:#fff;padding:1rem;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;align-items:center}.header h1{font-size:1.5rem;color:#1f2937}.header-buttons{display:flex;gap:.5rem;align-items:center}.btn-help{background-color:#3b82f6;color:#fff;font-size:1rem;font-weight:700;width:2rem;height:2rem;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center}.btn-help:hover{background-color:#2563eb}.btn-export{background-color:#6b7280;color:#fff;font-size:.875rem}.btn-export:hover{background-color:#4b5563}.month-selector{padding:1rem;display:flex;gap:1rem;align-items:center;background-color:#fff;border-bottom:1px solid #e5e7eb}.month-select{flex:1;padding:.75rem;font-size:1.125rem;font-weight:500}.btn-add{background-color:#3b82f6;color:#fff;font-weight:500}.btn-add:hover{background-color:#2563eb}.selector-buttons{display:flex;gap:.5rem}.btn-select{background-color:#6b7280;color:#fff;font-weight:500}.btn-select:hover{background-color:#4b5563}.btn-select.active{background-color:#dc2626}.bulk-actions{padding:.75rem 1rem;background-color:#1f2937;color:#fff;display:flex;justify-content:space-between;align-items:center}.btn-delete-bulk{background-color:#ef4444;color:#fff}.btn-delete-bulk:hover{background-color:#dc2626}.visits-container{padding:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.visits-table{width:100%;background-color:#fff;border-collapse:collapse;font-size:.875rem;border:1px solid #e5e7eb}.visits-table th,.visits-table td{padding:.625rem .375rem;text-align:center;border-bottom:1px solid #e5e7eb;border-right:1px solid #f3f4f6}.visits-table th:last-child,.visits-table td:last-child{border-right:none}.visits-table th{background-color:#f9fafb;font-weight:600;color:#374151;font-size:.75rem;text-transform:uppercase;text-align:center;position:sticky;top:0;z-index:10}.th-checkbox{width:2.5rem}.th-actions{width:5rem;text-align:center}.td-date{vertical-align:middle;text-align:center}.date-day{font-weight:600;font-size:.875rem;color:#1f2937}.date-num{font-size:.8125rem;color:#6b7280;margin-top:.125rem}.td-time{vertical-align:middle;text-align:center;color:#4b5563;font-size:.8125rem}.td-time div{line-height:1.3}.td-hours{font-weight:500;text-align:center;vertical-align:middle}.td-details{vertical-align:middle;text-align:center}.detail-location{font-size:.875rem;color:#1f2937;font-weight:500}.detail-carer{font-size:.8125rem;color:#6b7280;margin-top:.125rem}.td-comment{vertical-align:middle;text-align:center;max-width:150px}.comment-text{font-size:.75rem;color:#6b7280;font-style:italic;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.td-actions{text-align:center;white-space:nowrap}.td-actions .btn-icon{font-size:1.125rem;width:1.75rem;height:1.75rem;padding:0;margin:0 .125rem;border-radius:.25rem;display:inline-flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid transparent;transition:all .2s}.td-actions .btn-icon.edit{color:#3b82f6}.td-actions .btn-icon.edit:hover{background-color:#eff6ff;border-color:#3b82f6}.td-actions .btn-icon.delete{color:#ef4444}.td-actions .btn-icon.delete:hover{background-color:#fef2f2;border-color:#ef4444}.visits-table tbody tr.cancelled{opacity:.6}.visits-table tbody tr.selectable{cursor:pointer}.visits-table tbody tr.selected{background-color:#dbeafe}.visits-table tbody tr:hover{background-color:#f9fafb}.empty,.loading{text-align:center;padding:3rem 1rem;color:#6b7280}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000}.modal{background-color:#fff;border-radius:.75rem .75rem 0 0;width:100%;max-width:500px;max-height:calc(80vh - env(safe-area-inset-top));display:flex;flex-direction:column;margin:0 auto}.modal-header{padding:.75rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.modal-header h2{margin:0;font-size:1rem;color:#1f2937}.modal-content{flex:1;overflow-y:auto;padding:.75rem .75rem .5rem}.modal-actions{padding:.75rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));border-top:1px solid #e5e7eb;display:flex;gap:.5rem;background-color:#f9fafb;flex-shrink:0}.modal-actions button{flex:1}.form-group{margin-bottom:.5rem}.form-group label{display:block;margin-bottom:.25rem;font-weight:500;color:#374151;font-size:.8125rem}.form-group input[type=date],.form-group input[type=time],.form-group input[type=number],.form-group input[type=text],.form-group select,.form-group textarea{font-size:16px;-webkit-appearance:none}.time-inputs{display:flex;align-items:center;gap:.5rem}.time-inputs input[type=time]{flex:1}.time-separator{color:#6b7280;font-size:.875rem}.hours-input-wrapper{display:flex;align-items:center;gap:.5rem}.hours-input-wrapper input[type=number]{flex:1}.manual-checkbox{display:flex;align-items:center;font-weight:400;margin-bottom:0;cursor:pointer;font-size:.75rem}.manual-checkbox input[type=checkbox]{width:auto;margin-right:.125rem}.manual-checkbox span{font-size:.75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-three{display:grid;grid-template-columns:1fr 1.5fr 1.5fr;gap:.75rem}.readonly{background-color:#f3f4f6;cursor:not-allowed}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-cancel{background-color:#e5e7eb;color:#374151}.btn-cancel:hover{background-color:#d1d5db}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-form{background-color:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 4px 6px #0000001a;width:100%;max-width:320px;text-align:center}.auth-form h1{margin-bottom:1.5rem;color:#1f2937}.auth-form input{margin-bottom:1rem;text-align:center;font-size:1.25rem;letter-spacing:.1em}@media (max-width: 640px){.header h1{font-size:1.25rem}.month-selector{flex-direction:column}.month-select{font-size:1rem}.btn-add{width:100%}.visit-card{padding:.75rem}.form-row{grid-template-columns:1fr}.form-row-three{grid-template-columns:.8fr 1fr 1fr;gap:.5rem}.form-row-three .form-group label{font-size:.75rem}.form-row-three input,.form-row-three select{padding:.375rem .25rem;font-size:.875rem}.visits-table{font-size:.8125rem}.visits-table th,.visits-table td{padding:.5rem .25rem}.td-comment{max-width:100px}.td-actions .btn-icon{font-size:1rem;width:1.5rem;height:1.5rem;margin:0 .0625rem}.form-group:last-child{margin-bottom:2rem}.visit-date-time{font-size:.9375rem}.hours-badge{font-size:.8125rem;padding:.125rem .375rem}.btn-icon{font-size:1rem}}.form-group label input[type=checkbox]{width:auto;margin-left:.5rem;margin-right:.25rem}@media (display-mode: standalone){.header{padding-top:calc(env(safe-area-inset-top) + 1rem)}.app{padding-bottom:env(safe-area-inset-bottom)}}.app{min-height:100vh;min-height:-webkit-fill-available;padding-bottom:env(safe-area-inset-bottom)}.header{padding-top:max(1rem,env(safe-area-inset-top))}.form-actions{padding-bottom:max(1rem,env(safe-area-inset-bottom))}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{display:block;width:100%;height:100%;position:absolute;top:0;left:0;color:transparent;background:transparent}.help-backdrop{align-items:center}.help-modal{max-height:70vh;border-radius:.75rem;margin:1rem}.modal-header{display:flex;justify-content:space-between;align-items:center}.btn-close{background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1}.btn-close:hover{color:#1f2937}.help-section{margin-bottom:1.5rem}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.help-section ul{list-style:none;padding-left:0}.help-section li{padding:.25rem 0 .25rem 1.25rem;position:relative;color:#4b5563;font-size:.875rem}.help-section li:before{content:"•";position:absolute;left:0;color:#3b82f6;font-weight:700}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f4f6;color:#1f2937}button{cursor:pointer;border:none;border-radius:.375rem;font-size:1rem;padding:.5rem 1rem;transition:all .2s}input,select,textarea{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:1rem;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}
