body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1}.loading-container{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-height:100vh}.loading-spinner{text-align:center}.btn{transition:all .3s}.btn-primary{background-color:#3498db}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6}.btn-secondary:hover{background-color:#7f8c8d}.btn-success{background-color:#27ae60}.btn-success:hover{background-color:#229954}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.form-group{margin-bottom:1rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e1e8ed;transition:border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db}.card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1rem;padding:1.5rem}.card-header{border-bottom:1px solid #e1e8ed;margin-bottom:1rem;padding-bottom:1rem}.card-title{color:#2c3e50;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.alert{border-radius:8px;margin-bottom:1rem;padding:1rem}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.alert-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:3rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:3rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}.p-5{padding:3rem}@media (max-width:768px){.container{padding:0 .5rem}.btn{margin-bottom:.5rem;width:100%}}.header{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem 0}.header-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.header-container,.logo{align-items:center;display:flex}.logo{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none}.logo-icon{font-size:1.8rem;margin-right:.5rem}.nav{align-items:center;display:flex;gap:1.5rem}.nav-link{border-radius:4px;color:#fff;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s}.nav-link:hover{background-color:#ffffff1a}.register-btn{background-color:#3498db;color:#fff}.register-btn:hover{background-color:#2980b9}.auth-links,.user-menu{display:flex;gap:1rem}.user-menu{align-items:center}.user-name{font-weight:500}.logout-btn{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background-color .3s}.logout-btn:hover{background-color:#c0392b}@media (max-width:768px){.header-container{flex-direction:column;gap:1rem}.nav{flex-wrap:wrap;justify-content:center}.user-menu{flex-direction:column;gap:.5rem}}.home{min-height:100vh}.hero{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;min-height:60vh;padding:4rem 0}.hero-content{grid-gap:3rem;align-items:center;display:grid;gap:3rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding:0 1rem}.hero-content h1{font-size:3rem;line-height:1.2;margin-bottom:1rem}.hero-content p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.hero-actions{display:flex;gap:1rem}.hero-image{align-items:center;display:flex;justify-content:center}.hero-placeholder{font-size:8rem;opacity:.8;text-align:center}.cta-button{border:2px solid #0000;border-radius:8px;display:inline-block;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s}.cta-button.primary{background-color:#3498db;color:#fff}.cta-button.primary:hover{background-color:#2980b9;transform:translateY(-2px)}.cta-button.secondary{background-color:initial;border-color:#fff;color:#fff}.cta-button.secondary:hover{background-color:#fff;color:#667eea}.features{background-color:#f8f9fa;padding:4rem 0}.features h2{color:#2c3e50;font-size:2.5rem;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem;text-align:center;transition:transform .3s}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1rem}.feature-card p{color:#666;line-height:1.6}.how-it-works{padding:4rem 0}.how-it-works h2{color:#2c3e50;font-size:2.5rem;margin-bottom:3rem;text-align:center}.steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.step{text-align:center}.step-number{align-items:center;background-color:#3498db;border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;margin:0 auto 1rem;width:60px}.step h3{color:#2c3e50;font-size:1.3rem;margin-bottom:.5rem}.step p{color:#666}.cta-section{background-color:#2c3e50;color:#fff;padding:4rem 0;text-align:center}.cta-section h2{font-size:2.5rem;margin-bottom:1rem}.cta-section p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.cta-buttons{display:flex;gap:1rem;justify-content:center}@media (max-width:768px){.hero-content{grid-template-columns:1fr;text-align:center}.hero-content h1{font-size:2rem}.hero-placeholder{font-size:4rem}.hero-actions{justify-content:center}.cta-buttons{align-items:center;flex-direction:column}.cta-section h2,.features h2,.how-it-works h2{font-size:2rem}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:500px;padding:2rem;width:100%}.auth-header{margin-bottom:2rem;text-align:center}.auth-header h1{color:#2c3e50;font-size:2rem;margin-bottom:.5rem}.auth-header p{color:#666;font-size:1rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input,.form-group select{border:2px solid #e1e8ed;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{border-color:#3498db;outline:none}.form-group input::placeholder{color:#999}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{flex:1 1;padding-right:3rem}.password-toggle{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;padding:.25rem;position:absolute;right:.75rem;transition:color .3s}.password-toggle:hover{color:#3498db}.password-toggle:focus{border-radius:4px;outline:2px solid #3498db;outline-offset:2px}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;padding:.75rem}.auth-button{background-color:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem;transition:background-color .3s}.auth-button:hover:not(:disabled){background-color:#2980b9}.auth-button:disabled{background-color:#bdc3c7;cursor:not-allowed}.auth-footer{border-top:1px solid #e1e8ed;margin-top:2rem;padding-top:2rem;text-align:center}.auth-footer p{color:#666;margin:0}.auth-link{color:#3498db;font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}@media (max-width:768px){.auth-container{padding:1rem}.auth-card{padding:1.5rem}.form-row{grid-template-columns:1fr}.auth-header h1{font-size:1.5rem}}.vet-search{background-color:#f8f9fa;min-height:100vh}.search-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 0;text-align:center}.search-header h1{font-size:2.5rem;margin-bottom:.5rem}.search-header p{font-size:1.2rem;opacity:.9}.search-section{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin:-2rem auto 2rem;max-width:800px;padding:2rem}.search-form{display:flex;flex-direction:column;gap:1.5rem}.search-inputs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr}.input-group{display:flex;flex-direction:column}.input-group label{color:#2c3e50;font-weight:600;margin-bottom:.5rem}.input-group input,.input-group select{border:2px solid #e1e8ed;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s}.input-group input:focus,.input-group select:focus{border-color:#3498db;outline:none}.search-button{align-self:center;background-color:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:background-color .3s}.search-button:hover:not(:disabled){background-color:#2980b9}.search-button:disabled{background-color:#bdc3c7;cursor:not-allowed}.results-section{padding:2rem 0}.results-header{margin-bottom:2rem}.results-header h2{color:#2c3e50;font-size:1.5rem}.loading{padding:3rem}.loading-spinner{color:#666;font-size:1.2rem}.vet-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.vet-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:1.5rem;transition:transform .3s,box-shadow .3s}.vet-card:hover{box-shadow:0 8px 15px #00000026;transform:translateY(-2px)}.vet-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.vet-header h3{color:#2c3e50;flex:1 1;font-size:1.3rem;margin:0}.verified-badge{border-radius:4px;font-size:.8rem;font-weight:600;margin-left:1rem;padding:.25rem .5rem}.vet-badges{flex-direction:column;margin-top:.5rem}.vet-rating{margin-bottom:1rem}.stars{display:flex;gap:.1rem}.star.filled,.star.half{color:#f39c12}.star.half{position:relative}.rating-text{color:#666;font-size:.9rem}.vet-info{margin-bottom:1rem}.vet-info p{color:#666;font-size:.9rem;margin:.5rem 0}.vet-info a{color:#3498db;text-decoration:none}.vet-info a:hover{text-decoration:underline}.description{color:#666;line-height:1.5;margin-bottom:1rem}.services{margin-bottom:1.5rem}.services h4{color:#2c3e50;font-size:.9rem;margin-bottom:.5rem}.service-tags{display:flex;flex-wrap:wrap;gap:.5rem}.service-tag{background-color:#ecf0f1;border-radius:4px;font-size:.8rem;padding:.25rem .5rem}.service-tag.more{background-color:#3498db;color:#fff}.vet-actions{display:flex;gap:1rem;margin-top:1.5rem}.book-btn,.view-details-btn{border-radius:8px;flex:1 1;font-weight:600;padding:.75rem;text-align:center;text-decoration:none;transition:all .3s}.view-details-btn{background-color:#ecf0f1;border:2px solid #bdc3c7;color:#2c3e50}.view-details-btn:hover{background-color:#bdc3c7}.book-btn{background-color:#3498db;border:2px solid #3498db;color:#fff}.book-btn:hover{background-color:#2980b9;border-color:#2980b9}.no-results{color:#666;padding:3rem;text-align:center}.no-results h3{color:#2c3e50;margin-bottom:1rem}.demo-banner{align-items:center;background:#fff3;border-radius:8px;display:flex;gap:.5rem;justify-content:center;margin-top:1rem;padding:.5rem 1rem}.demo-badge{background:#e74c3c;border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.search-controls{display:flex;justify-content:center;margin-bottom:1.5rem}.mode-toggle{gap:1rem}.mode-toggle,.toggle-switch{align-items:center;display:flex}.toggle-switch{cursor:pointer;gap:.5rem}.toggle-switch input{-webkit-appearance:none;appearance:none;background:#ccc;border-radius:12px;height:24px;outline:none;position:relative;transition:background .3s;width:50px}.toggle-switch input:checked{background:#3498db}.toggle-switch input:before{background:#fff;border-radius:50%;content:"";height:20px;left:2px;position:absolute;top:2px;transition:transform .3s;width:20px}.toggle-switch input:checked:before{transform:translateX(26px)}.toggle-label{color:#2c3e50;font-weight:600}.demo-indicator{color:#e74c3c;font-size:.9rem;font-weight:400}.welcome-state{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:4rem 2rem;text-align:center}.welcome-content h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1rem}.welcome-content p{color:#666;font-size:1.1rem;margin-bottom:2rem}.welcome-features{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.feature{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:.5rem;padding:1rem}.feature-icon{font-size:1.5rem}.no-results-content{margin:0 auto;max-width:500px}.no-results-suggestions{background:#f8f9fa;border-radius:8px;margin:1.5rem 0;padding:1.5rem;text-align:left}.no-results-suggestions h4{color:#2c3e50;margin-bottom:1rem}.no-results-suggestions ul{margin:0;padding-left:1.5rem}.no-results-suggestions li{color:#666;margin-bottom:.5rem}.demo-suggestion{background:#e8f4fd;border-left:4px solid #3498db;border-radius:8px;margin-top:2rem;padding:1.5rem}.demo-toggle-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .3s}.demo-toggle-btn:hover{background:#2980b9}.business-invitation{background:#e8f5e8;border-left:4px solid #27ae60;border-radius:8px;margin-top:2rem;padding:2rem;text-align:center}.business-invitation h4{color:#27ae60;margin-bottom:1rem}.business-invitation p{color:#2c3e50;margin-bottom:1.5rem}.register-business-btn{background:#27ae60;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .3s}.register-business-btn:hover{background:#219a52}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.pagination{gap:1rem;margin:2rem 0;padding:1rem}.pagination-btn{align-items:center;background-color:#3498db;border:none;color:#fff;display:flex;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .3s}.pagination-btn:hover:not(:disabled){background-color:#2980b9}.pagination-btn:disabled{background-color:#bdc3c7;opacity:.6}.pagination-pages{display:flex;gap:.5rem}.pagination-page{background-color:#ecf0f1;border:2px solid #bdc3c7;border-radius:8px;color:#2c3e50;cursor:pointer;font-weight:600;min-width:3rem;padding:.75rem 1rem;text-align:center;transition:all .3s}.pagination-page:hover:not(:disabled){background-color:#bdc3c7}.pagination-page.active{background-color:#3498db;border-color:#3498db;color:#fff}.pagination-page:disabled{cursor:not-allowed;opacity:.6}.vet-photos{margin:1rem 0}.photo-gallery{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));max-height:120px;overflow:hidden}.photo-item{aspect-ratio:1;background:#f8f9fa;border-radius:8px;overflow:hidden;position:relative}.photo-item img{height:100%;object-fit:cover;transition:transform .3s;width:100%}.photo-item:hover img{transform:scale(1.05)}.photo-item.more-photos{align-items:center;background:#3498db;color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:600;justify-content:center;transition:background-color .3s}.photo-item.more-photos:hover{background:#2980b9}.vet-map{margin:1rem 0}.map-container{border-radius:8px;box-shadow:0 2px 8px #0000001a}.map-overlay{position:absolute;right:10px;top:10px;z-index:10}.directions-btn{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#3498dbe6;border-radius:6px;color:#fff;display:flex;font-size:.85rem;font-weight:600;gap:.25rem;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s}.directions-btn:hover{background:#2980b9f2;text-decoration:none}@media (max-width:768px){.search-header h1{font-size:2rem}.search-inputs{grid-template-columns:1fr}.search-section{margin:-1rem auto 1rem;padding:1.5rem}.vet-grid{grid-template-columns:1fr}.vet-actions,.vet-header{flex-direction:column}.vet-header{gap:.5rem}.verified-badge{align-self:flex-start;margin-left:0}.photo-gallery{grid-template-columns:repeat(3,1fr)}.map-overlay{margin-top:.5rem;position:static;text-align:center}.directions-btn{background:#3498db;display:inline-flex}}.book-appointment,.vet-details{background-color:#f8f9fa;min-height:100vh;padding:2rem 0}.error,.loading{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.error h2{color:#dc3545;margin-bottom:1rem}.booking-header,.unavailable-header,.vet-header{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.booking-header h1,.unavailable-header h1,.vet-header h1{color:#2c3e50;font-size:2.5rem;margin-bottom:.5rem}.booking-header h2,.unavailable-header h2,.vet-header h2{color:#34495e;font-size:1.8rem;font-weight:600;margin-bottom:1rem}.vet-rating{align-items:center;display:flex;gap:.5rem;margin-top:1rem}.rating{color:#f39c12;font-size:1.2rem;font-weight:700}.review-count{color:#7f8c8d;font-size:1rem}.platform-notice{margin-bottom:2rem}.invitation-card,.notice-card{background:linear-gradient(135deg,#3498db,#2980b9);border-radius:12px;box-shadow:0 4px 15px #3498db4d;color:#fff;padding:2rem}.notice-card h3{font-size:1.3rem;margin-bottom:1rem}.notice-card p{line-height:1.6;margin-bottom:1rem}.notice-card p:last-child{margin-bottom:0}.unavailable-notice{margin-bottom:2rem}.unavailable-notice .notice-card{background:linear-gradient(135deg,#e74c3c,#c0392b);text-align:center}.notice-icon{font-size:3rem;margin-bottom:1rem}.vet-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr;margin-bottom:2rem}@media (max-width:768px){.vet-content{grid-template-columns:1fr}}.vet-info{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:2rem}.info-section{margin-bottom:2rem}.info-section:last-child{margin-bottom:0}.info-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem}.contact-details p{line-height:1.6;margin-bottom:.8rem}.contact-details a{color:#3498db;text-decoration:none}.contact-details a:hover{text-decoration:underline}.services-list{flex-wrap:wrap}.service-tag{background:#ecf0f1;border-radius:20px;color:#2c3e50;font-size:.9rem;font-weight:500;padding:.5rem 1rem}.opening-hours p{border-bottom:1px solid #ecf0f1;margin-bottom:.5rem;padding:.3rem 0}.opening-hours p:last-child{border-bottom:none}.vet-images{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:2rem}.vet-images h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1rem}.image-gallery{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.image-gallery img{border-radius:8px;height:120px;object-fit:cover;transition:transform .3s ease;width:100%}.image-gallery img:hover{transform:scale(1.05)}.contact-info{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.contact-info h3{color:#2c3e50;font-size:1.3rem}.contact-info h3,.contact-item{margin-bottom:1.5rem}.contact-item:last-child{margin-bottom:0}.contact-item strong{color:#2c3e50;display:block;font-weight:600;margin-bottom:.5rem}.contact-item p{color:#7f8c8d;margin:0}.contact-item a{color:#3498db;text-decoration:none}.contact-item a:hover{text-decoration:underline}.alternative-actions{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.alternative-actions h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem}.business-invitation{margin-bottom:2rem}.invitation-card{background:linear-gradient(135deg,#27ae60,#229954);text-align:center}.invitation-card h4{font-size:1.2rem;margin-bottom:1rem}.invitation-card p{line-height:1.6;margin-bottom:1.5rem}.action-buttons,.contact-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.external-booking{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:2rem;text-align:center}.booking-notice{color:#7f8c8d;font-size:1.1rem;margin-bottom:1.5rem}.btn{font-weight:600}.btn-primary{background:#3498db}.btn-primary:hover{background:#2980b9;transform:translateY(-2px)}.btn-secondary{background:#95a5a6}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-2px)}.btn-success{background:#27ae60;color:#fff}.btn-success:hover{background:#229954;transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid #3498db;color:#3498db}.btn-outline:hover{background:#3498db;color:#fff}.btn-large{font-size:1.1rem;padding:1rem 2rem}.navigation{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;padding:1.5rem 2rem}@media (max-width:768px){.navigation{flex-direction:column;gap:1rem}}.booking-form{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.form-section h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1rem}.coming-soon{background:#f8f9fa;border:2px dashed #bdc3c7;border-radius:8px;padding:2rem;text-align:center}.coming-soon p{color:#7f8c8d;margin-bottom:1rem}@media (max-width:768px){.book-appointment,.vet-details{padding:1rem 0}.booking-header h1,.unavailable-header h1,.vet-header h1{font-size:2rem}.booking-header h2,.unavailable-header h2,.vet-header h2{font-size:1.5rem}.alternative-actions,.booking-form,.booking-header,.contact-info,.external-booking,.unavailable-header,.vet-header,.vet-images,.vet-info{padding:1.5rem}.action-buttons,.contact-actions{flex-direction:column}.btn{text-align:center;width:100%}.image-gallery{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.image-gallery img{height:100px}}.no-services-notice{background:#f8f9fa;border:2px dashed #bdc3c7;border-radius:8px;padding:1.5rem;text-align:center}.no-services-notice p{color:#7f8c8d;font-style:italic;margin:0}.header-content{display:flex;flex-direction:column;gap:1rem}.vet-badges{display:flex;flex-wrap:wrap;gap:.5rem}.avma-verified-badge{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border:2px solid #1e40af;border-radius:6px;box-shadow:0 2px 4px #1e3a8a4d}.avma-verified-badge,.rcvs-verified-badge{align-items:center;color:#fff;display:inline-flex;font-size:.85rem;font-weight:700;gap:.25rem;padding:.5rem .75rem}.rcvs-verified-badge{background:linear-gradient(135deg,#dc2626,#ef4444);border:2px solid #dc2626;border-radius:6px;box-shadow:0 2px 4px #dc26264d}.verified-badge{align-items:center;background-color:#27ae60;border-radius:6px;color:#fff;display:inline-flex;font-size:.85rem;font-weight:700;gap:.25rem;padding:.5rem .75rem}.image-gallery-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.photo-item-details{aspect-ratio:4/3;background:#f8f9fa;border-radius:12px;box-shadow:0 4px 8px #0000001a;overflow:hidden;position:relative;transition:transform .3s,box-shadow .3s}.photo-item-details:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.photo-item-details img{height:100%;object-fit:cover;transition:transform .3s;width:100%}.photo-item-details:hover img{transform:scale(1.05)}.photo-item-details.more-photos-details{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:center;transition:background .3s}.photo-item-details.more-photos-details:hover{background:linear-gradient(135deg,#2980b9,#1f5f8b)}.map-container{box-shadow:0 4px 12px #00000026;margin-top:1rem;overflow:hidden;position:relative}.map-container,.map-container iframe{border-radius:12px}.map-link{margin-top:1rem;text-align:center}.map-link .btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;box-shadow:0 4px 8px #3498db4d;transition:all .3s}.map-link .btn:hover{box-shadow:0 6px 12px #3498db66;transform:translateY(-2px)}.verification-info{background:#f8f9fa;border-left:4px solid #3498db;border-radius:0 8px 8px 0;margin-top:1rem;padding:1rem}.verification-info p{color:#2c3e50;margin:.5rem 0}.verification-info p:last-child{margin-bottom:0}@media (max-width:768px){.header-content,.vet-badges{align-items:flex-start}.vet-badges{flex-direction:column}.image-gallery-details{grid-template-columns:repeat(2,1fr)}.photo-item-details{aspect-ratio:1}.avma-verified-badge,.rcvs-verified-badge,.verified-badge{font-size:.8rem;padding:.4rem .6rem}}.global-practices-container{background-color:#f8f9fa;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.practices-header{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin-bottom:30px;padding:30px;text-align:center}.practices-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:10px}.practices-header p{color:#7f8c8d;font-size:1.2rem;margin:0}.search-filters{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin-bottom:30px;padding:25px}.search-bar{margin-bottom:20px}.search-input{border:2px solid #e9ecef;border-radius:10px;font-size:1rem;padding:15px 20px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.filters-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-select{background:#fff;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;font-size:.95rem;padding:12px 15px;transition:all .3s ease}.filter-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.practices-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 400px}@media (max-width:1024px){.practices-content{grid-template-columns:1fr}}.practices-list{display:flex;flex-direction:column;gap:20px}.practice-card{background:#fff;border:2px solid #0000;border-radius:15px;box-shadow:0 4px 15px #0000001a;cursor:pointer;padding:25px;transition:all .3s ease}.practice-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.practice-card.selected{border-color:#3498db;box-shadow:0 8px 25px #3498db4d}.practice-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.practice-header h3{color:#2c3e50;font-size:1.4rem;font-weight:600;margin:0}.verification-badges{display:flex;flex-wrap:wrap;gap:8px}.verification-badge{border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:6px 10px;text-transform:uppercase}.avma-badge{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff}.rcvs-badge{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}.eu-badge{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}.practice-info p{color:#555;line-height:1.5;margin:8px 0}.practice-info .website a{color:#3498db;font-weight:500;text-decoration:none}.practice-info .website a:hover{text-decoration:underline}.practice-stats{align-items:center;border-top:1px solid #e9ecef;display:flex;justify-content:space-between;margin-top:15px;padding-top:15px}.avg-price,.service-count{color:#7f8c8d;font-size:.9rem;font-weight:500}.practice-details-sidebar{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;height:-webkit-fit-content;height:fit-content;padding:25px;position:-webkit-sticky;position:sticky;top:20px}.practice-details-header{margin-bottom:20px}.practice-details-header h2{color:#2c3e50;font-size:1.6rem;font-weight:600;margin-bottom:10px}.practice-details-info p{color:#555;line-height:1.6;margin:10px 0}.practice-details-info strong{color:#2c3e50;font-weight:600}.practice-details-info a{color:#3498db;text-decoration:none}.practice-details-info a:hover{text-decoration:underline}.price-statistics{border-top:2px solid #e9ecef;margin-top:25px;padding-top:20px}.price-statistics h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:15px}.stats-grid{grid-gap:12px;gap:12px}.stat-item{align-items:center;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:10px 0}.stat-item:last-child{border-bottom:none}.stat-label{color:#7f8c8d;font-weight:500}.stat-value{color:#2c3e50;font-size:.95rem;font-weight:600}.services-section{border-top:2px solid #e9ecef;margin-top:25px;padding-top:20px}.services-section h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:15px}.category-filter{margin-bottom:20px}.category-select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:.9rem;padding:10px 12px;width:100%}.services-list{max-height:400px;overflow-y:auto}.service-item{border:1px solid #e9ecef;border-radius:10px;margin-bottom:12px;padding:15px;transition:all .3s ease}.service-item:hover{background:#fff;box-shadow:0 2px 8px #0000001a}.service-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.service-category{color:#3498db;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.service-species{background:#fff;border-radius:12px;color:#7f8c8d;font-size:.8rem;font-weight:500;padding:4px 8px}.service-name{color:#2c3e50;font-size:1rem;font-weight:600}.service-name,.service-pricing{margin-bottom:8px}.price-range,.price-single{color:#27ae60;font-size:1.1rem;font-weight:700}.price-unknown{color:#7f8c8d;font-size:.9rem;font-style:italic}.service-notes{margin-bottom:8px}.service-notes small{color:#7f8c8d;line-height:1.4}.service-confidence small{color:#f39c12;font-weight:500}.pagination{align-items:center;display:flex;gap:15px;justify-content:center;margin-top:30px;padding:20px}.pagination-info{color:#7f8c8d;font-weight:500}.pagination-btn{background:#fff;border:2px solid #3498db;border-radius:8px;color:#3498db;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background:#3498db;color:#fff;transform:translateY(-2px)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.loading{color:#7f8c8d;font-size:1.2rem;font-weight:500;padding:50px}@media (max-width:768px){.global-practices-container{padding:15px}.practices-header{padding:20px}.practices-header h1{font-size:2rem}.search-filters{padding:20px}.filters-row,.practices-content{grid-template-columns:1fr}.practices-content{gap:20px}.practice-card{padding:20px}.practice-header{gap:10px}.practice-header,.practice-stats{align-items:flex-start;flex-direction:column}.practice-stats{gap:8px}.practice-details-sidebar{padding:20px}.services-list{max-height:300px}.pagination{flex-direction:column;gap:10px}}.dashboard{background-color:#f8f9fa;min-height:100vh;padding:2rem 0}.dashboard .container{margin:0 auto;max-width:1200px;padding:0 1rem}.dashboard h1{color:#2c3e50;font-size:2.5rem;font-weight:600;margin-bottom:2rem;text-align:center}.dashboard-nav{flex-wrap:wrap;justify-content:center;padding:.5rem}.dashboard-nav button{background:#0000;border:none;border-radius:8px;color:#6c757d;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.dashboard-nav button:hover{background-color:#e9ecef;color:#495057}.dashboard-nav button.active{background-color:#007bff;color:#fff}.error,.loading{font-size:1.2rem;padding:3rem;text-align:center}.error{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;color:#dc3545}.dashboard-content{min-height:500px}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:1rem}.dashboard-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem}.dashboard-card h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.stats{display:flex;gap:1rem;justify-content:space-around}.stat{text-align:center}.stat-number{color:#007bff;display:block;font-size:2.5rem;line-height:1}.stat-label{color:#6c757d;display:block;font-size:.9rem;margin-top:.5rem}.appointment-list,.pet-list{display:flex;flex-direction:column;gap:1rem}.appointment-item,.pet-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.appointment-info,.pet-info{flex:1 1}.appointment-details,.pet-details{color:#6c757d;font-size:.9rem;margin-top:.25rem}.appointment-vet{color:#007bff;font-size:.9rem;margin-top:.25rem}.appointment-status,.status-badge{border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.view-all-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:.5rem;padding:.5rem 1rem}.view-all-btn:hover{background:#0056b3}.tab-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.tab-header h2{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.btn{border-radius:8px;transition:all .3s ease}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d}.btn-secondary:hover{background-color:#545b62}.btn-sm{font-size:.9rem;padding:.5rem 1rem}.btn-icon{padding:.5rem;transition:background-color .3s ease}.btn-icon:hover{background-color:#e9ecef}.appointments-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:1rem}.appointment-card{background:#f8f9fa;border:1px solid #e9ecef}.appointment-header h3{color:#2c3e50;font-size:1.3rem;margin:0}.appointment-body p{color:#495057;margin:.5rem 0}.pets-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:1rem}.pet-card{border:1px solid #e9ecef;border-radius:12px;padding:1.5rem}.pet-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.pet-header h3{color:#2c3e50;font-size:1.3rem;margin:0}.pet-info p{color:#495057;margin:.5rem 0}.medical-notes{background:#fff3cd;border-left:4px solid #ffc107;border-radius:6px;font-size:.9rem;margin-top:.5rem;padding:.75rem}.history-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.history-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;display:flex;gap:1rem;padding:1.5rem}.history-date{color:#6c757d;font-size:.9rem;font-weight:500;min-width:150px}.history-content{align-items:flex-start;display:flex;flex:1 1;gap:1rem;justify-content:space-between}.history-main h4{color:#2c3e50;font-size:1.1rem;margin:0 0 .5rem}.history-main p{color:#495057;margin:.25rem 0}.history-notes{color:#6c757d;font-style:italic}.history-actions{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem}.reviews-list{margin-top:1rem}.review-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem}.review-header{align-items:center}.review-header h4{color:#2c3e50;font-size:1.2rem;margin:0}.review-rating{font-size:1.2rem}.review-date{margin-top:1rem}.modal{padding:1rem}.modal-header{margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.close-btn{border-radius:4px;padding:.5rem}.close-btn:hover{background-color:#e9ecef}.pet-form,.review-form{padding:0 1.5rem 1.5rem}.form-group label{color:#2c3e50;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #ced4da;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 2px #007bff40}.rating-input{display:flex;gap:.25rem}.star{background:none;border:none;border-radius:4px;cursor:pointer;filter:grayscale(100%);font-size:1.5rem;padding:.25rem;transition:all .3s ease}.star.active{filter:grayscale(0)}.star:hover{background-color:#f8f9fa}.empty-state{color:#6c757d;padding:3rem 1rem;text-align:center}.empty-state p{font-size:1.1rem;margin-bottom:1rem}@media (max-width:768px){.dashboard .container{padding:0 .5rem}.dashboard h1{font-size:2rem}.dashboard-nav{align-items:stretch;flex-direction:column}.dashboard-nav button{text-align:center}.dashboard-content{padding:1rem}.appointments-grid,.dashboard-grid,.pets-grid{grid-template-columns:1fr}.tab-header{align-items:stretch;flex-direction:column;text-align:center}.history-item{flex-direction:column;gap:1rem}.history-date{min-width:auto}.history-content{flex-direction:column;gap:1rem}.history-actions{align-items:flex-start}.form-row{grid-template-columns:1fr}.form-actions,.stats{flex-direction:column}.stats{gap:1.5rem}}@media (max-width:480px){.dashboard{padding:1rem 0}.dashboard h1{font-size:1.75rem}.modal{margin:.5rem;max-width:calc(100vw - 1rem)}.appointment-item,.pet-item{align-items:flex-start;flex-direction:column;gap:1rem}.appointment-status{align-self:flex-start}}.pet-profile{background-color:#f8f9fa;min-height:100vh;padding:2rem 0}.pet-profile-loading{align-items:center;color:#666;display:flex;font-size:1.2rem;height:50vh;justify-content:center}.pet-profile-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.pet-profile-header h1{color:#2c3e50;font-size:2.5rem;font-weight:600;margin:0}.pet-profile-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:300px 1fr;min-height:600px}.pet-sidebar{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;height:-webkit-fit-content;height:fit-content;padding:1.5rem}.pet-sidebar h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin:0 0 1rem}.no-pets{color:#666;font-style:italic;padding:2rem 1rem;text-align:center}.pet-list{display:flex;flex-direction:column;gap:.75rem}.pet-card{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;transition:all .2s ease}.pet-card:hover{transform:translateY(-1px)}.pet-card.active,.pet-card:hover{background:#e3f2fd;border-color:#007bff}.pet-card.active{box-shadow:0 2px 8px #007bff33}.pet-info h4{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.pet-info p{color:#666;font-size:.9rem;margin:0}.pet-actions{display:flex;gap:.5rem}.btn-icon{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.1rem;padding:.25rem;transition:background-color .2s ease}.btn-icon:hover{background-color:#0000001a}.btn-icon.delete:hover{background-color:#dc35451a}.pet-details{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.pet-tabs{border-bottom:2px solid #e9ecef;display:flex}.tab{background:#f8f9fa;border:none;color:#666;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:1rem 1.5rem;transition:all .2s ease}.tab:hover{background:#e9ecef;color:#2c3e50}.tab.active{background:#fff;border-bottom:3px solid #007bff;color:#007bff}.tab-content{padding:2rem}.pet-overview h2{color:#2c3e50;font-size:2rem;font-weight:600;margin:0 0 1.5rem}.pet-details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item label{color:#495057;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item span{color:#2c3e50;font-size:1.1rem}.medical-notes{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;padding:1.5rem}.medical-notes label{color:#495057;display:block;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.medical-notes p{color:#2c3e50;line-height:1.6;margin:0}.section-header h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0}.no-records{background:#f8f9fa;border-radius:8px;color:#666;font-style:italic;padding:3rem 1rem;text-align:center}.medical-records{display:flex;flex-direction:column;gap:1rem}.medical-record{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;transition:box-shadow .2s ease}.medical-record:hover{box-shadow:0 2px 8px #0000001a}.record-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.record-header h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0}.record-date{color:#666;font-size:.9rem;font-weight:500}.record-type{margin-bottom:1rem}.type-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.type-badge.checkup{background:#d4edda;color:#155724}.type-badge.illness{background:#f8d7da;color:#721c24}.type-badge.injury{background:#fff3cd;color:#856404}.type-badge.surgery{background:#d1ecf1;color:#0c5460}.type-badge.other{background:#e2e3e5;color:#383d41}.record-description{color:#495057;line-height:1.6;margin:0 0 1rem}.record-details{display:flex;flex-direction:column;gap:.5rem}.record-details .detail{color:#495057;font-size:.95rem}.record-details .detail strong{color:#2c3e50}.record-details .detail.follow-up{background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;padding:.5rem}.vaccination-records{display:flex;flex-direction:column;gap:1rem}.vaccination-record{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;transition:box-shadow .2s ease}.vaccination-record:hover{box-shadow:0 2px 8px #0000001a}.next-due{background:#e3f2fd;border-left:4px solid #007bff;border-radius:4px;color:#0c5460;font-size:.95rem;margin:.75rem 0;padding:.5rem}.modal-overlay{padding:1rem}.modal{max-width:600px;width:100%}.modal-header{border-bottom:1px solid #e9ecef;padding:1.5rem 2rem}.modal-header h3{color:#2c3e50;font-size:1.5rem;font-weight:600}.modal-close{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:background-color .2s ease}.modal-close:hover{background-color:#0000001a}.medical-form,.pet-form,.vaccination-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#495057;display:block;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e9ecef;border-radius:6px;box-sizing:border-box;font-size:1rem;width:100%}.form-group textarea{min-height:80px;resize:vertical}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;gap:.5rem}.checkbox-label input[type=checkbox]{margin:0;width:auto!important}.form-actions{border-top:1px solid #e9ecef;margin-top:2rem;padding-top:1.5rem}.btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s ease}.btn-primary:hover{box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.btn-secondary:hover{box-shadow:0 4px 12px #6c757d4d;transform:translateY(-1px)}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;margin-bottom:1.5rem;padding:1rem}@media (max-width:768px){.pet-profile-content{gap:1rem;grid-template-columns:1fr}.pet-profile-header{align-items:stretch;flex-direction:column;gap:1rem}.pet-profile-header h1{font-size:2rem;text-align:center}.form-row,.pet-details-grid{grid-template-columns:1fr}.record-header{flex-direction:column;gap:.5rem}.section-header{align-items:stretch;flex-direction:column;gap:1rem}.modal{margin:1rem;max-height:calc(100vh - 2rem)}.medical-form,.modal-header,.pet-form,.vaccination-form{padding:1rem}.form-actions{flex-direction:column}}@media (max-width:480px){.pet-profile{padding:1rem 0}.pet-tabs{flex-direction:column}.tab{padding:.75rem 1rem}.tab-content{padding:1rem}.pet-card{align-items:flex-start;flex-direction:column;gap:.75rem}.pet-actions{align-self:flex-end}}.address-autocomplete{position:relative}.address-help-text{margin-bottom:8px}.address-help-text small{background:#f8f9fa;border-left:3px solid #007bff;border-radius:6px;color:#6c757d;display:block;font-size:.85rem;line-height:1.4;padding:8px 12px}.address-input-container{position:relative}.address-input-container input{border:2px solid #e1e5e9;border-radius:8px;font-size:14px;padding:12px;transition:border-color .2s ease;width:100%}.address-input-container input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.address-suggestions{background:#fff;border:1px solid #e1e5e9;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 12px #0000001a;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.address-suggestion{align-items:flex-start;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background-color .2s ease}.address-suggestion:hover{background-color:#f8f9fa}.address-suggestion:last-child{border-bottom:none}.suggestion-main{flex:1 1}.suggestion-name{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.suggestion-address{color:#666;font-size:13px;line-height:1.4}.suggestion-details{align-items:flex-end;display:flex;flex-direction:column;gap:4px;margin-left:12px}.suggestion-rating{color:orange;font-size:12px;font-weight:500}.suggestion-types{font-size:16px}.google-place-info{margin-top:8px}.google-place-info small{align-items:center;color:#28a745;display:flex;font-weight:500;gap:4px}.vet-business-dashboard{background-color:#f8f9fa;min-height:100vh}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-bottom:2rem;padding:2rem 0}.dashboard-header h1{font-size:2.5rem;font-weight:700;margin:0}.dashboard-header p{font-size:1.1rem;margin:.5rem 0 0;opacity:.9}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.dashboard-nav{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;gap:.5rem;margin-bottom:2rem;overflow-x:auto;padding:1rem}.nav-btn{background:#f8f9fa;border:none;border-radius:8px;color:#6c757d;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease;white-space:nowrap}.nav-btn:hover{background:#e9ecef;color:#495057}.nav-btn.active{background:#007bff;color:#fff}.dashboard-content{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;min-height:600px;padding:2rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-left:4px solid #007bff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;gap:1rem;padding:1.5rem}.stat-icon{font-size:2.5rem;opacity:.8}.stat-content h3{color:#6c757d;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.stat-number{color:#333;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-change{color:#28a745;font-size:.8rem;font-weight:500}.quick-actions{margin-bottom:2rem}.quick-actions h3{color:#333;margin-bottom:1rem}.action-buttons{display:flex;flex-wrap:wrap;gap:1rem}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.action-btn.primary{background:#007bff;color:#fff}.action-btn.primary:hover{background:#0056b3}.action-btn.secondary{background:#f8f9fa;border:1px solid #dee2e6;color:#6c757d}.action-btn.secondary:hover{background:#e9ecef;color:#495057}.recent-activity h3{color:#333;margin-bottom:1rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;display:flex;gap:1rem;padding:1rem}.activity-icon{font-size:1.5rem;opacity:.7}.activity-content{flex:1 1}.activity-title{color:#333;font-weight:600;margin-bottom:.25rem}.activity-subtitle{color:#6c757d;font-size:.9rem;margin-bottom:.25rem}.activity-time{color:#6c757d;font-size:.8rem}.profile-section h3{color:#333;margin-bottom:1.5rem}.profile-form{gap:1.5rem}.form-group,.profile-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#333;font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:2px solid #e1e5e9;border-radius:8px;font-size:.9rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.services-list{gap:.5rem}.service-item{align-items:center;gap:.5rem}.service-item input{flex:1 1}.remove-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:.5rem}.remove-btn:hover{background:#c82333}.add-service-btn{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;margin-top:.5rem;padding:.75rem}.add-service-btn:hover{background:#218838}.hours-list{display:flex;flex-direction:column;gap:.5rem}.save-btn{align-self:flex-start;background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem}.save-btn:hover{background:#0056b3}.appointments-section h3{color:#333;margin-bottom:1.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.appointment-filters select{background:#fff;border:2px solid #e1e5e9;border-radius:8px;padding:.5rem 1rem}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-card{align-items:flex-start;background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:1.5rem}.appointment-info{flex:1 1}.appointment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.appointment-header h4{color:#333;margin:0}.status{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.status-pending{background:#fff3cd;color:#856404}.status-confirmed{background:#d4edda;color:#155724}.status-completed{background:#cce5ff;color:#004085}.status-cancelled{background:#f8d7da;color:#721c24}.appointment-details p{color:#6c757d;font-size:.9rem;margin:.25rem 0}.appointment-actions{display:flex;flex-direction:column;gap:.5rem;margin-left:1rem}.appointment-actions button{border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.btn-confirm{background:#28a745;color:#fff}.btn-confirm:hover:not(:disabled){background:#218838}.btn-reschedule{background:#ffc107;color:#212529}.btn-reschedule:hover{background:#e0a800}.btn-cancel{background:#dc3545;color:#fff}.btn-cancel:hover:not(:disabled){background:#c82333}.appointment-actions button:disabled{cursor:not-allowed;opacity:.5}.reviews-section h3{color:#333;margin-bottom:1.5rem}.reviews-list{display:flex;flex-direction:column;gap:1rem}.review-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.review-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.customer-info h4{color:#333;margin:0 0 .5rem}.rating{display:flex;gap:.1rem}.star{color:#ddd;font-size:1.2rem}.star.filled{color:#ffc107}.review-date{color:#6c757d;font-size:.9rem}.review-content p{color:#333;line-height:1.6;margin:0}.review-actions{display:flex;justify-content:flex-end;margin-top:1rem}.respond-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem}.respond-btn:hover{background:#0056b3}.responded-badge{color:#28a745;font-size:.9rem;font-weight:600}.calendar-section h3{color:#333;margin-bottom:1.5rem}.calendar-actions{display:flex;flex-wrap:wrap;gap:1rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;padding:0;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#333;margin:0}.close-btn{align-items:center;background:none;border:none;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;width:30px}.close-btn:hover{color:#333}.category-form,.service-form,.slot-form{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.form-actions{border-top:1px solid #e1e5e9;display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.time-slots-grid{margin-top:2rem}.slots-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.summary-card{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;padding:1rem;text-align:center}.summary-card h4{color:#6c757d;font-size:.9rem;font-weight:600;margin:0 0 .5rem}.summary-number{color:#333;font-size:1.5rem;font-weight:700}.slots-container{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.slot-card{background:#fff;border:1px solid #e1e5e9;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.slot-card.available{border-left:4px solid #28a745}.slot-card.booked{background:#f8f9fa;border-left:4px solid #dc3545}.slot-info{flex:1 1}.slot-date{color:#333;font-weight:600;margin-bottom:.25rem}.slot-time{color:#007bff;font-weight:500;margin-bottom:.25rem}.slot-service{color:#6c757d;font-size:.9rem;margin-bottom:.25rem}.slot-duration{color:#6c757d;font-size:.8rem}.slot-status{margin:.5rem 0}.status-available{color:#28a745;font-size:.8rem;font-weight:600}.status-booked{color:#dc3545;font-size:.8rem;font-weight:600}.slot-actions{display:flex;justify-content:flex-end}.btn-delete{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.25rem;transition:background-color .2s ease}.btn-delete:hover{background:#f8f9fa}.empty-slots{color:#6c757d;padding:2rem;text-align:center}.empty-slots p{margin:.5rem 0}.analytics-section h3{color:#333;margin-bottom:1.5rem}.analytics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.analytics-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.analytics-card h4{color:#333;margin:0 0 1rem}.chart-placeholder{align-items:end;display:flex;gap:.5rem;height:100px;margin-bottom:1rem}.chart-bar{background:#007bff;border-radius:2px 2px 0 0;opacity:.8;width:20px}.revenue-chart{background:linear-gradient(45deg,#007bff,#28a745);border-radius:8px;height:100px;margin-bottom:1rem;overflow:hidden;position:relative}.revenue-line{background:#fff;bottom:0;height:2px;left:0;opacity:.8;position:absolute;right:0}.services-stats{display:flex;flex-direction:column;gap:1rem}.service-stat{align-items:center;display:flex;gap:1rem}.progress-bar{background:#e1e5e9;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress{background:#007bff;border-radius:4px;height:100%}.satisfaction-score{text-align:center}.score-circle{align-items:center;background:#007bff;border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.services-section h3{color:#333;margin-bottom:1.5rem}.services-actions{display:flex;flex-wrap:wrap;gap:1rem}.services-grid{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}.category-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.category-header{justify-content:space-between;margin-bottom:1rem}.category-header,.category-info{align-items:flex-start;display:flex}.category-info{gap:1rem}.category-icon{font-size:2rem}.category-info h4{color:#333;margin:0 0 .5rem}.category-info p{color:#6c757d;font-size:.9rem;margin:0}.category-actions{display:flex;gap:.5rem}.btn-delete,.btn-edit{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.5rem;transition:background-color .2s ease}.btn-edit:hover{background:#e9ecef}.btn-delete:hover{background:#f8d7da}.services-list{display:flex;flex-direction:column;gap:1rem}.service-item{align-items:flex-start;background:#f8f9fa;border:1px solid #e1e5e9;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.service-info{flex:1 1}.service-info h5{color:#333;margin:0 0 .5rem}.service-info p{color:#6c757d;font-size:.9rem;margin:0 0 .5rem}.service-details{display:flex;gap:1rem}.service-price{color:#28a745;font-weight:600}.service-duration{color:#6c757d;font-size:.9rem}.service-actions{display:flex;gap:.5rem;margin-left:1rem}.empty-services{border:2px dashed #e1e5e9;border-radius:8px;color:#6c757d;padding:2rem;text-align:center}.empty-services p{margin:0 0 1rem}.btn-add-service{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.btn-add-service:hover{background:#0056b3}.empty-categories{color:#6c757d;padding:3rem;text-align:center}.empty-state h4{color:#333;margin:0 0 1rem}.empty-state p{line-height:1.6;margin:0 0 2rem}.loading{color:#6c757d;font-size:1.1rem;padding:2rem;text-align:center}@media (max-width:768px){.dashboard-header{padding:1.5rem 0}.dashboard-header h1{font-size:2rem}.dashboard-nav{gap:.25rem;padding:.5rem}.nav-btn{font-size:.8rem;padding:.5rem 1rem}.dashboard-content{padding:1rem}.form-row,.stats-grid{grid-template-columns:1fr}.appointment-card{flex-direction:column;gap:1rem}.appointment-actions{flex-direction:row;margin-left:0}.analytics-grid,.slots-container{grid-template-columns:1fr}.modal{margin:1rem;width:95%}.category-header,.service-item{align-items:flex-start;flex-direction:column;gap:1rem}.service-actions{margin-left:0}}
/*# sourceMappingURL=main.aa343033.css.map*/