*{margin:0;padding:0;box-sizing:border-box}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;min-height:100vh}:root{--blue:#4294e1}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:rgba(255,255,255,0);padding:1.5rem 1.5rem .5rem 2rem;display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:1rem}.app-title{font-size:1.75rem;color:#333;font-weight:700}.admin-toggle{color:white;border:none;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:background .3s}.admin-toggle,.admin-toggle:hover{background:var(--blue)}.admin-panel{background:rgba(255,255,255,.95);padding:1rem 2rem;border-bottom:1px solid #e0e0e0}.admin-info{display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:1rem;width:100%;padding-bottom:1rem;padding-right:1.5rem}.admin-email{color:#333;font-weight:500}.logout-button{background:#dc3545;color:white;border:none;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .3s}.logout-button:hover{background:#c82333}.admin-login{background:rgba(255,255,255,.95);padding:2rem;border-bottom:1px solid #e0e0e0}.login-form{max-width:400px;margin:0 auto}.login-title{font-size:1.5rem;color:#333;margin-bottom:1.5rem;text-align:center}.error-message{background:#f8d7da;color:#721c24;padding:.75rem;border-radius:6px;margin-bottom:1rem;text-align:center}.login-button{width:100%;color:white;border:none;padding:.75rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background .3s}.login-button,.login-button:hover:not(:disabled){background:var(--blue)}.login-button:disabled{opacity:.6;cursor:not-allowed}.app-main{flex:1;padding:1rem}.booking-container{max-width:900px;margin:0 auto;background:white;border-radius:12px;padding:0}.booking-description{text-align:center;color:#666;margin-bottom:2rem;font-size:1.05rem}.calendar-container{width:100%}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.calendar-title{font-size:1.5rem;color:#333;font-weight:600}.nav-button{color:white;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .3s}.nav-button,.nav-button:hover{background:var(--blue)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.day-name{text-align:center;font-weight:600;color:var(--blue);padding:.75rem;font-size:.9rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:1rem;font-weight:500;transition:all .3s}.calendar-day.empty{background:transparent}.calendar-day.active{background:#f8f9fa;cursor:pointer;color:#333}.calendar-day.active:hover{transform:scale(1.05)}.calendar-day.active:hover,.calendar-day.selected{background:var(--blue);color:white}.time-slots-inline{grid-column:1/-1;background:#f8f9fa;border-radius:8px;padding:1.5rem;margin:.5rem 0 1rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.time-slots-inline-header{margin-bottom:1rem}.time-slots-container{margin-top:2rem;padding-top:2rem;border-top:2px solid #f0f0f0}.time-slots-title{font-size:1.25rem;color:#333;margin-bottom:1.5rem;text-align:center}.time-slots-grid{display:grid;gap:1rem}.time-slot-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:white;border-radius:8px;transition:all .3s;border:1px solid #e0e0e0}.time-slot-item:hover{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.1);transform:translateY(-2px)}.admin-section{background:rgba(255,255,255,.95);border-bottom:1px solid #e0e0e0}.admin-panel{padding:0}.admin-nav{display:flex;gap:.5rem;padding:1rem 2rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0;overflow-x:auto}.admin-nav-button{background:white;color:var(--blue);border:2px solid var(--blue);padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .3s;white-space:nowrap}.admin-nav-button:hover{background:#f0f0f0}.admin-nav-button.active{background:var(--blue);color:white}.admin-content{padding:2rem;max-width:1400px;margin:0 auto}.admin-dashboard{width:100%}.dashboard-title{font-size:1.75rem;color:#333;margin-bottom:1.5rem;font-weight:700}.dashboard-controls{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-input{flex:1;min-width:250px;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.search-input:focus{outline:none;border-color:var(--blue)}.filter-select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;cursor:pointer;background:white}.filter-select:focus{outline:none;border-color:var(--blue)}.refresh-button{color:white;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background .3s}.refresh-button,.refresh-button:hover{background:var(--blue)}.bookings-count{color:#666;margin-bottom:1rem;font-size:.95rem}.admin-loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-bottom:1.5rem}.bookings-table{width:100%;border-collapse:collapse;background:white}.bookings-table thead{background:var(--blue);color:white}.bookings-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;white-space:nowrap}.bookings-table td{padding:1rem;border-bottom:1px solid #e0e0e0;font-size:.9rem}.bookings-table tbody tr:hover{background:#f8f9fa}.message-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-bookings{text-align:center;padding:3rem;color:#999}.status-badge{padding:.4rem .8rem;border-radius:4px;border:none;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s}.status-sent{background:#d4edda;color:#155724}.status-sent:hover{background:#c3e6cb}.status-pending{background:#fff3cd;color:#856404}.status-pending:hover{background:#ffeaa7}.delete-button{background:#dc3545;color:white;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.delete-button:hover{background:#c82333}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.5rem}.pagination-button{color:white;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .3s}.pagination-button,.pagination-button:hover:not(:disabled){background:var(--blue)}.pagination-button:disabled{background:#ccc;cursor:not-allowed}.pagination-numbers{display:flex;gap:.25rem}.pagination-number{background:white;color:var(--blue);border:1px solid var(--blue);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s}.pagination-number:hover{background:#f0f0f0}.pagination-number.active{background:var(--blue);color:white}.service-manager,.timeslot-manager{max-width:800px}.section-title{font-size:1.5rem;color:#333;margin-bottom:1.5rem;font-weight:700}.add-service,.add-timeslot{display:flex;gap:1rem;margin-bottom:2rem}.service-input,.timeslot-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.service-input:focus,.timeslot-input:focus{outline:none;border-color:var(--blue)}.add-button{background:#28a745;color:white;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background .3s;white-space:nowrap}.add-button:hover{background:#218838}.services-list,.timeslots-list{display:flex;flex-direction:column;gap:.75rem}.service-item,.timeslot-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:white;border:1px solid #e0e0e0;border-radius:8px;transition:all .3s}.service-item:hover,.timeslot-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}.timeslot-item.disabled{opacity:.6;background:#f8f9fa}.service-name,.timeslot-time{font-size:1rem;color:#333;font-weight:500}.service-actions,.timeslot-actions{display:flex;gap:.5rem}.edit-button,.save-button{background:var(--blue);color:white;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.edit-button:hover,.save-button:hover{background:var(--blue)}.cancel-button-small,.delete-button-small{background:#dc3545;color:white;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.cancel-button-small:hover,.delete-button-small:hover{background:#c82333}.cancel-button-small{background:#6c757d}.cancel-button-small:hover{background:#5a6268}.toggle-button{background:#6c757d;color:white;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.toggle-button.active{background:#28a745}.toggle-button:hover{opacity:.9}.no-slots-message{text-align:center;color:#999;padding:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:white;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-title{font-size:1.5rem;color:#333;font-weight:600}.close-button{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;line-height:1;transition:color .3s}.close-button:hover{color:#333}.booking-info{padding:1.5rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.booking-detail{margin-bottom:.5rem;color:#333;font-size:1rem}.booking-detail:last-child{margin-bottom:0}.booking-form{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group,.form-row{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.95rem}.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-input:focus{outline:none;border-color:var(--blue)}.form-input::placeholder{color:#999}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.cancel-button,.submit-button{flex:1;padding:.75rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.cancel-button{background:#6c757d;color:white}.cancel-button:hover:not(:disabled){background:#5a6268}.submit-button{color:white}.submit-button,.submit-button:hover:not(:disabled){background:var(--blue)}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}.app-footer{background:rgba(255,255,255,.95);padding:1.5rem;text-align:center;color:#666;border-top:1px solid #e0e0e0}.embed-generator{max-width:1000px}.embed-description{color:#666;margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.embed-type-selector{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.embed-type-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:#333}.embed-type-label input[type=radio]{cursor:pointer;width:18px;height:18px}.embed-code-container{position:relative;margin-bottom:2rem}.embed-code{background:#2d2d2d;color:#f8f8f2;padding:1.5rem;border-radius:8px;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;margin:0;white-space:pre-wrap;word-wrap:break-word}.copy-button{position:absolute;top:1rem;right:1rem;color:white;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s}.copy-button,.copy-button:hover{background:var(--blue)}.embed-instructions{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.embed-instructions h4{color:#333;margin-bottom:1rem;font-size:1.1rem}.embed-instructions ol{margin-left:1.5rem;color:#666;line-height:1.8}.embed-instructions li{margin-bottom:.5rem}.embed-note{background:#fff3cd;border-left:4px solid #ffc107;padding:1rem;margin-top:1rem;border-radius:4px;color:#856404;line-height:1.6}.embed-preview-section{margin-bottom:2rem}.embed-preview-section h4{color:#333;margin-bottom:1rem;font-size:1.1rem}.embed-preview{border:1px solid #ddd;border-radius:8px;overflow:hidden;background:#f8f9fa}.embed-tips{background:#e7f3ff;padding:1.5rem;border-radius:8px;border-left:4px solid var(--blue)}.embed-tips h4{color:#333;margin-bottom:1rem;font-size:1.1rem}.embed-tips ul{margin-left:1.5rem;color:#666;line-height:1.8}.embed-tips li{margin-bottom:.75rem}.embed-tips code{background:#2d2d2d;color:#f8f8f2;padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem}.timeslot-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e0e0e0}.tab-button{background:transparent;color:#666;border:none;border-bottom:3px solid transparent;padding:.75rem 1.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s}.tab-button:hover{color:var(--blue)}.tab-button.active{color:var(--blue);border-bottom-color:var(--blue)}.date-specific-section{margin-top:1rem}.date-selector{margin-bottom:1.5rem}.date-selector label{display:block;margin-bottom:.5rem;color:#333;font-weight:600;font-size:1rem}.date-input{width:100%;max-width:300px;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.date-input:focus{outline:none;border-color:var(--blue)}.time-selector{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.selector-label{color:#333;font-weight:600;margin-bottom:1rem;font-size:1rem}.time-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:white;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .3s}.checkbox-label:hover{background:#f0f0f0;border-color:var(--blue)}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.checkbox-label input[type=checkbox]:checked+span{color:var(--blue);font-weight:600}.date-specific-list{margin-top:2rem}.date-specific-list h4{color:#333;margin-bottom:1rem;font-size:1.1rem}.no-data{text-align:center;color:#999;padding:2rem;background:#f8f9fa;border-radius:8px}.date-config-item{background:white;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:.75rem;transition:all .3s}.date-config-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}.date-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.date-config-header strong{color:var(--blue);font-size:1rem}.date-config-times{color:#666;font-size:.9rem;line-height:1.6}@media (max-width:768px){.app-header{padding:1rem}.app-title{font-size:1.25rem}.booking-container{padding:1rem}.calendar-title{font-size:1.25rem}.calendar-grid{gap:.25rem}.calendar-day{font-size:.9rem}.day-name{font-size:.8rem;padding:.5rem}.time-slots-inline{padding:1rem}.time-slots-title{font-size:1.1rem}.form-row{grid-template-columns:1fr}.time-slot-item{flex-direction:column;gap:.75rem;text-align:center}.book-buttonc{width:100%;background:#4294e1!important;padding:0 30px;margin:0;height:42px;font-size:14px;font-weight:700;border-radius:2px;transition:all .1s ease-in-out}.embed-type-selector,.form-actions{flex-direction:column}.embed-type-selector{gap:.75rem}.embed-code{font-size:.85rem}.timeslot-tabs{flex-direction:column;gap:.5rem}.time-checkboxes{grid-template-columns:1fr}}@media (max-width:480px){.app-main{padding:1rem}.modal-content{margin:.5rem}.calendar-day,.embed-code,.embed-tips code{font-size:.8rem}}