*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #14b8a6;--primary-dark: #0d9488;--primary-light: #99f6e4;--success: #16a34a;--warning: #ca8a04;--danger: #dc2626;--sidebar-bg: #1e293b;--sidebar-active: #334155;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:var(--gray-900);line-height:1.5}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.login-card{background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 4px 24px #00000014;width:100%;max-width:360px;text-align:center}.login-card h1{font-size:1.75rem;margin-bottom:.5rem;color:var(--gray-800);display:flex;align-items:center;justify-content:center;gap:.5rem}.login-card h1:before{content:"🐾"}.login-card p{color:var(--gray-500);margin-bottom:2rem;font-size:.875rem}.login-card input{width:100%;padding:.875rem 1rem;border:1px solid var(--gray-200);border-radius:10px;font-size:1rem;margin-bottom:1rem;background:var(--gray-50)}.login-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #14b8a626;background:#fff}.login-error{color:var(--danger);font-size:.875rem;margin-bottom:1rem;padding:.75rem;background:#fef2f2;border-radius:8px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;border:none;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;gap:.5rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:var(--danger);color:#fff}.btn-full{width:100%}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--sidebar-bg);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:50}.sidebar-logo{padding:1.5rem;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo .paw-icon{font-size:1.5rem}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;color:#ffffffb3;cursor:pointer;transition:all .2s;font-size:.9rem;border:none;background:none;width:100%;text-align:left}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{background:var(--primary);color:#fff}.nav-item .nav-icon{width:20px;text-align:center;font-size:1rem}.nav-item .nav-badge{margin-left:auto;background:#fff3;padding:.125rem .5rem;border-radius:10px;font-size:.75rem}.nav-item.active .nav-badge{background:#ffffff4d}.main-content{flex:1;margin-left:220px;min-height:100vh}.top-header{display:flex;justify-content:flex-end;align-items:center;padding:1rem 2rem;gap:1rem}.logout-btn{background:none;border:none;color:var(--gray-500);cursor:pointer;font-size:.875rem;padding:.5rem}.logout-btn:hover{color:var(--gray-700)}.add-booking-btn{background:var(--primary);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.add-booking-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.stats-row{display:flex;gap:1rem;padding:0 2rem;margin-bottom:1.5rem}.stat-card{background:#fff;padding:.75rem 1.25rem;border-radius:50px;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000000d;border:1px solid var(--gray-100)}.stat-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}.stat-icon.pets{background:var(--primary-light);color:var(--primary-dark)}.stat-icon.earnings{background:#dcfce7;color:#16a34a}.stat-icon.reviews{background:#fef3c7;color:#ca8a04}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.75rem;color:var(--gray-500)}.stat-value{font-size:1rem;font-weight:600;color:var(--gray-800)}.bookings-container{padding:0 2rem 2rem}.bookings-grid{display:flex;flex-direction:column;gap:1rem}.booking-card{background:#fff;border-radius:16px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000000d;border:1px solid var(--gray-100);display:flex;align-items:center;gap:1.25rem;transition:all .2s}.booking-card:hover{box-shadow:0 4px 12px #00000014}.booking-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;flex-shrink:0}.booking-avatar.boarding{background:#e0f2fe;color:#0369a1}.booking-avatar.sitting{background:#f3e8ff;color:#7c3aed}.booking-avatar.training{background:#ffedd5;color:#c2410c}.booking-main{flex:1;min-width:0}.booking-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.booking-dog-name{font-size:1.25rem;font-weight:600;color:var(--gray-800)}.booking-menu-btn{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--gray-400);font-size:1.25rem;line-height:1}.booking-menu-btn:hover{color:var(--gray-600)}.booking-owner-service{font-size:.875rem;color:var(--gray-500);margin-bottom:.75rem}.booking-dates-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.booking-date{font-size:.8rem;color:var(--gray-600);min-width:50px}.booking-progress-container{flex:1;position:relative}.booking-progress-bar{height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden}.booking-progress-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .3s}.booking-status-row{display:flex;align-items:center;gap:.75rem}.payment-dot{display:flex;align-items:center;gap:.375rem;font-size:.75rem}.payment-dot:before{content:"";width:8px;height:8px;border-radius:50%}.payment-dot.partial:before{background:#f59e0b}.payment-dot.partial{color:#b45309}.payment-dot.unpaid:before{background:#ef4444}.payment-dot.unpaid{color:#dc2626}.payment-dot.paid:before{background:#22c55e}.payment-dot.paid{color:#16a34a}.booking-actions-dropdown{position:relative}.booking-dropdown-menu{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid var(--gray-200);min-width:150px;z-index:100;padding:.5rem 0}.dropdown-item{display:block;width:100%;padding:.5rem 1rem;text-align:left;background:none;border:none;font-size:.875rem;cursor:pointer;color:var(--gray-700)}.dropdown-item:hover{background:var(--gray-50)}.dropdown-item.danger{color:var(--danger)}.status-booked{background:#dbeafe;color:#1e40af}.status-active{background:#dcfce7;color:#166534}.status-completed{background:var(--gray-200);color:var(--gray-700)}.payment-unpaid{background:#fee2e2;color:#991b1b}.payment-partial{background:#fef3c7;color:#92400e}.payment-paid{background:#dcfce7;color:#166534}.service-sitting{background:#f3e8ff;color:#6b21a8}.service-training{background:#ffedd5;color:#9a3412}.service-boarding{background:#cffafe;color:#0e7490}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-400);line-height:1;padding:.25rem;border-radius:6px}.modal-close:hover{color:var(--gray-600);background:var(--gray-100)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:.75rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-200);border-radius:8px;font-size:.875rem;background:var(--gray-50)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #14b8a626;background:#fff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state p{margin-bottom:1.5rem;font-size:1rem}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:8px;box-shadow:0 4px 12px #00000026;list-style:none;margin-top:4px;max-height:200px;overflow-y:auto;z-index:100}.autocomplete-dropdown li{padding:.75rem 1rem;cursor:pointer;font-size:.875rem}.autocomplete-dropdown li:hover{background:var(--gray-50)}.autocomplete-hint{color:var(--gray-500);font-weight:400}.filters{display:flex;flex-wrap:wrap;gap:.5rem;padding:0 2rem 1rem;align-items:center}.filter-group{display:flex;gap:.25rem}.filter-chip{padding:.375rem .75rem;font-size:.75rem;font-weight:500;border:1px solid var(--gray-200);border-radius:20px;background:#fff;cursor:pointer;transition:all .15s;opacity:.7}.filter-chip:hover{opacity:1}.filter-chip.active{opacity:1;background:var(--primary);color:#fff;border-color:var(--primary)}.filter-clear{padding:.375rem .625rem;font-size:.75rem;color:var(--gray-500);background:none;border:none;cursor:pointer;text-decoration:underline}.filter-clear:hover{color:var(--gray-700)}.form-section-label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-top:1rem;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--gray-200)}.calendar-container{background:#fff;border-radius:16px;border:1px solid var(--gray-100);overflow:hidden;box-shadow:0 1px 3px #0000000d}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid var(--gray-200);gap:.5rem}.calendar-title{font-size:1.125rem;font-weight:600;flex:1;text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day-header{padding:.75rem .5rem;text-align:center;font-size:.75rem;font-weight:600;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.calendar-day{min-height:100px;padding:.5rem;border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);background:#fff}.calendar-day:nth-child(7n){border-right:none}.calendar-day.empty{background:var(--gray-50)}.calendar-day.today{background:#f0fdfa}.calendar-day-number{font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:.25rem}.calendar-day.today .calendar-day-number{color:var(--primary);font-weight:700}.calendar-day-bookings{display:flex;flex-direction:column;gap:2px}.calendar-booking{padding:2px 6px;border-radius:4px;font-size:.7rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s}.calendar-booking:hover{opacity:.8}.calendar-booking.card-boarding{background:#e0f2fe;color:#0369a1}.calendar-booking.card-sitting{background:#f3e8ff;color:#7c3aed}.calendar-booking.card-training{background:#ffedd5;color:#c2410c}.calendar-booking-name{font-weight:500}.calendar-more{font-size:.65rem;color:var(--primary);padding:2px 4px;cursor:pointer;font-weight:500}.calendar-more:hover{text-decoration:underline}.calendar-day.has-bookings .calendar-day-number{cursor:pointer}.calendar-day.has-bookings .calendar-day-number:hover{color:var(--primary)}.calendar-day-count{display:inline-flex;align-items:center;justify-content:center;background:var(--gray-200);color:var(--gray-700);font-size:.65rem;font-weight:600;min-width:18px;height:18px;border-radius:9px;margin-left:4px}.day-detail-modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.day-detail-content{padding:1rem 1.5rem 1.5rem;overflow-y:auto;flex:1}.day-detail-count{font-size:.875rem;color:var(--gray-500);margin-bottom:1rem}.day-detail-list{display:flex;flex-direction:column;gap:.5rem}.day-detail-booking{padding:.75rem;border-radius:10px;cursor:pointer;transition:opacity .15s}.day-detail-booking.card-boarding{background:#f0f9ff}.day-detail-booking.card-sitting{background:#faf5ff}.day-detail-booking.card-training{background:#fff7ed}.day-detail-booking:hover{opacity:.85}.day-detail-booking-main{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.day-detail-dog{font-weight:600;font-size:1rem}.day-detail-owner{color:var(--gray-600);font-size:.875rem}.day-detail-booking-meta{display:flex;gap:.5rem;flex-wrap:wrap}.day-detail-booking-meta span{padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.loading{text-align:center;padding:3rem;color:var(--gray-500);display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-link{display:inline-flex;align-items:center;padding:.125rem .375rem;font-size:.625rem;font-weight:600;color:var(--primary-dark);background:var(--primary-light);border-radius:4px;text-decoration:none;white-space:nowrap}.map-link:hover{background:#5eead4}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--sidebar-bg);color:#fff}.mobile-header h1{font-size:1.125rem;display:flex;align-items:center;gap:.5rem}.stats-row{padding:0 1rem;flex-wrap:wrap}.stat-card{flex:1;min-width:140px}.bookings-container,.filters{padding:0 1rem 1rem}.booking-card{flex-direction:column;align-items:flex-start;gap:1rem}.booking-avatar{width:48px;height:48px;font-size:1.25rem}.form-row{grid-template-columns:1fr}.calendar-header{flex-wrap:wrap;padding:.75rem}.calendar-title{font-size:1rem;order:-1;width:100%;margin-bottom:.5rem}.calendar-day{min-height:70px;padding:.25rem}.calendar-day-number{font-size:.75rem}.calendar-booking{font-size:.6rem;padding:1px 4px}.calendar-day-header{font-size:.65rem;padding:.5rem .25rem}}.feedback-btn,.view-feedback-btn{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--gray-300);background:#fff;color:var(--gray-600);font-size:.875rem;cursor:pointer;transition:all .15s}.feedback-btn:hover,.view-feedback-btn:hover{background:var(--gray-100);border-color:var(--gray-400)}.view-feedback-btn{padding:.5rem .75rem}.feedback-modal{max-width:450px}.feedback-modal textarea{resize:vertical;min-height:100px}.feedback-viewer-modal{max-width:600px;width:95%}.feedback-list{display:flex;flex-direction:column;gap:1rem}.feedback-item{background:var(--gray-50);border-radius:10px;padding:1rem;border:1px solid var(--gray-200)}.feedback-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.feedback-type{font-size:.75rem;font-weight:600;text-transform:uppercase;padding:.25rem .5rem;border-radius:4px;background:var(--gray-200)}.feedback-type-bug{background:#fef2f2;color:#dc2626}.feedback-type-feature{background:#f0fdf4;color:#16a34a}.feedback-type-other{background:#eff6ff;color:#2563eb}.feedback-date{font-size:.75rem;color:var(--gray-500)}.feedback-message{color:var(--gray-700);font-size:.9rem;line-height:1.5;margin-bottom:.75rem;white-space:pre-wrap}.feedback-item-footer{display:flex;justify-content:flex-end}.feedback-item-footer select{padding:.35rem .5rem;border-radius:6px;font-size:.75rem;border:1px solid var(--gray-300);background:#fff;cursor:pointer}
