:root{--primary:#1b3a52;--primary-dark:#132a3d;--primary-light:#2d4e68;--primary-pale:#e8edf2;--secondary:#d4af7a;--secondary-dark:#b8975f;--secondary-light:#e3c99a;--accent:#b85f5f;--accent-light:#d17777;--cream:#efe4d1;--bg-main:#f8f7f5;--bg-card:#fff;--bg-hover:#f0efe8;--bg-light:#fafaf8;--bg-secondary:#e8edf2;--text-primary:#1b3a52;--text-secondary:#4a5f73;--text-muted:#7a8b9a;--text-light:#efe4d1;--border:#d4af7a33;--border-light:#1b3a5215;--border-color:#e5ded0;--shadow-sm:0 1px 2px 0 #1b3a520d;--shadow-md:0 4px 6px -1px #1b3a5214,0 2px 4px -1px #1b3a520a;--shadow-lg:0 10px 15px -3px #1b3a521a,0 4px 6px -2px #1b3a520d;--shadow-xl:0 20px 25px -5px #1b3a521f,0 10px 10px -5px #1b3a520a;--shadow-warm:0 4px 12px #d4af7a26;--gradient-primary:linear-gradient(135deg,#1b3a52,#2d4e68);--gradient-secondary:linear-gradient(135deg,#d4af7a,#e3c99a);--gradient-warm:linear-gradient(135deg,#d4af7a,#b85f5f);--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);--transition-fast:all 0.15s ease}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;background-color:#f8f7f5;background-color:var(--bg-main);background-image:radial-gradient(circle at 20% 30%,#d4af7a14 0,#0000 50%),radial-gradient(circle at 80% 70%,#1b3a520d 0,#0000 50%),url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 40q10-10 20 0t20 0 20 0' stroke='%23D4AF7A' stroke-width='2' fill='none' opacity='.15'/%3E%3C/svg%3E");background-position:0 0,0 0,0 0;background-size:100% 100%,100% 100%,200px 200px;color:#1b3a52;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow-x:hidden;position:relative}body:before{animation:pawMove 20s linear infinite;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ctext x='10' y='40' font-size='30' opacity='.03'%3E🐾%3C/text%3E%3C/svg%3E");background-position:0 0;background-size:120px 120px;bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{color:#1b3a52;color:var(--text-primary);font-weight:600;line-height:1.2}button,input,select,textarea{font-family:inherit}.login-container{align-items:center;animation:pawMove 25s linear infinite;background:linear-gradient(135deg,#1b3a52,#2d4e68 50%,#1b3a52);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='80' height='80' xmlns='http://www.w3.org/2000/svg'%3E%3Ctext x='20' y='50' font-size='40' opacity='.08'%3E🐾%3C/text%3E%3C/svg%3E");background-position:0 0;background-size:150px 150px;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-container:before{animation:pulse 4s ease-in-out infinite;background:radial-gradient(circle,#d4af7a26 0,#0000 70%);height:500px;right:-10%;top:-50%;width:500px}.login-container:after,.login-container:before{border-radius:50%;content:"";pointer-events:none;position:absolute;z-index:0}.login-container:after{animation:pulse 4s ease-in-out 2s infinite;background:radial-gradient(circle,#d4af7a1f 0,#0000 70%);bottom:-30%;height:400px;left:-5%;width:400px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes pawMove{0%{background-position:0 0}to{background-position:150px 150px}}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:460px;overflow:hidden;position:relative;width:100%;z-index:1}.login-header{background:linear-gradient(135deg,#d4af7a14,#efe4d11f);border-bottom:1px solid var(--border-color);padding:48px 32px 32px;text-align:center}.logo{align-items:center;display:flex;flex-direction:column;gap:16px}.logo-image{animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(212,175,122,.3));height:80px;object-fit:contain;transition:var(--transition);width:auto}.logo-image:hover{filter:drop-shadow(0 6px 16px rgba(212,175,122,.5))}.logo-text h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0}.logo-text p{color:var(--text-secondary);font-size:14px;font-weight:500;margin:4px 0 0}.login-content{padding:40px 32px 48px}.login-content h2{color:var(--text-primary);font-size:26px;font-weight:700;letter-spacing:-.3px;margin:0 0 8px}.login-subtitle{color:var(--text-secondary);font-size:15px;line-height:1.5;margin:0 0 32px}.login-form{gap:24px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:10px}.form-group label{letter-spacing:-.1px}.form-input{padding:14px 16px}.form-input:focus{border-color:var(--secondary);box-shadow:0 0 0 4px #d4af7a26}.user-type-selector{display:flex;flex-direction:column;gap:12px}.user-type-selector label{color:var(--text-primary);font-size:14px;font-weight:600;letter-spacing:-.1px}.type-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.type-btn{align-items:center;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:14px 12px;transition:var(--transition)}.type-btn:hover{background:var(--bg-hover);border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.type-btn.active{border-color:var(--secondary)}.btn-primary,.type-btn.active{background:var(--gradient-secondary);box-shadow:var(--shadow-warm);color:var(--primary);font-weight:700}.btn-primary{font-size:16px;letter-spacing:.3px;padding:16px 24px}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.login-btn{margin-top:8px}.register-options{border-top:1px solid var(--border-light);margin-top:32px;padding-top:32px;text-align:center}.register-options p{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:16px}.register-buttons{display:flex;flex-direction:column;gap:12px}.btn-secondary{background:var(--bg-hover);border:2px solid var(--primary);border-radius:var(--radius-md);color:var(--primary);cursor:pointer;font-size:15px;font-weight:600;padding:14px 20px;transition:var(--transition)}.btn-secondary:hover{background:var(--gradient-secondary);border-color:var(--secondary);box-shadow:var(--shadow-warm);color:var(--primary);transform:translateY(-2px)}.back-to-login{margin-top:24px;text-align:center}.btn-text{background:none;border:none;color:var(--primary);cursor:pointer;font-size:14px;font-weight:600;padding:8px;transition:var(--transition)}.btn-text:hover{color:var(--primary-dark);transform:translateX(-4px)}.error-message{animation:slideIn .3s ease;background:linear-gradient(135deg,#fee,#ffebee);border-left:4px solid #dc2626;border-radius:var(--radius-md);color:#dc2626;font-size:14px;font-weight:500;margin-bottom:20px;padding:14px 16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.login-card{margin:20px;padding:24px}.logo-image{height:60px}.logo-text h1{font-size:24px}.logo-text p{font-size:13px}.login-content,.login-header{padding:24px 20px}h2{font-size:22px}.type-buttons{flex-direction:column}.type-btn{font-size:14px;width:100%}}@media (max-width:480px){.login-card{margin:10px;padding:20px}.logo-image{height:50px}.logo-text h1{font-size:20px}.logo-text p{font-size:12px}}.modal-overlay{animation:fadeIn .2s ease;background:#0009;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;border-radius:var(--radius-xl);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-content.large-modal{max-width:700px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#d4af7a0d,#efe4d114);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:24px;font-weight:700}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;transition:var(--transition);width:36px}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-form{padding:32px}.form-group{margin-bottom:24px}.form-group label{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:15px;padding:12px 16px;transition:var(--transition);width:100%}.form-input::placeholder{color:var(--text-muted)}.form-input:hover{border-color:var(--primary-light)}.form-input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 4px #667eea14;outline:none}textarea.form-input{min-height:80px;resize:vertical}select.form-input{cursor:pointer}.form-row{grid-gap:16px;gap:16px}.checkbox-group{margin-top:8px}.checkbox-label{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-weight:500;gap:10px}.checkbox-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;height:20px;width:20px}.checkbox-label span{font-size:14px}.info-box{background:var(--primary-pale);border-left:4px solid var(--primary);border-radius:var(--radius-md);margin:20px 0;padding:16px}.info-box p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.info-box strong{color:var(--text-primary)}.info-box.mild{background:#f0fdf4;border-color:#22c55e}.info-box.moderate{background:#fffbeb;border-color:#f59e0b}.info-box.severe{background:#fef2f2;border-color:#ef4444}.severity-info{margin-bottom:20px}.modal-actions{border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px}.modal-actions .btn-primary,.modal-actions .btn-secondary{border:none;border-radius:var(--radius-md);cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:var(--transition)}.modal-actions .btn-primary{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);box-shadow:var(--shadow-md);color:#fff}.modal-actions .btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.modal-actions .btn-secondary{background:var(--bg-hover);border:2px solid var(--border);color:var(--text-secondary)}.modal-actions .btn-secondary:hover{background:var(--bg-card);border-color:var(--primary-light);color:var(--primary)}@media (max-width:768px){.modal-content{max-height:95vh;max-width:95vw}.modal-header{padding:20px 24px}.modal-header h2{font-size:20px}.modal-form{padding:24px}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%}}.pet-profile-view{background:var(--bg-main);min-height:100vh;padding:20px;position:relative;z-index:1}.pet-profile-view:before{background-image:radial-gradient(circle at 15% 25%,#d4af7a0f 0,#0000 40%),radial-gradient(circle at 85% 75%,#1b3a520a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.profile-header{align-items:center;display:flex;gap:15px;justify-content:space-between;margin:0 auto 20px;max-width:1200px}.btn-back{background:#fff;border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:var(--transition)}.btn-back:hover{border-color:var(--primary);color:var(--primary);transform:translateX(-4px)}.btn-edit{background:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:var(--transition)}.btn-edit:hover{background:var(--primary-dark);box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.pet-info-card{align-items:flex-start;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#efe4d11a);border:2px solid #d4af7a33;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;gap:40px;margin:0 auto 30px;max-width:1200px;overflow:hidden;padding:40px;position:relative}.pet-info-card:before{animation:floatIcon 4s ease-in-out infinite;content:"🐾";font-size:60px;opacity:.05;pointer-events:none;position:absolute;right:20px;top:20px;transform:rotate(-15deg);z-index:0}@keyframes floatIcon{0%,to{transform:rotate(-15deg) translateY(0)}50%{transform:rotate(-10deg) translateY(-10px)}}.pet-photo-large{align-items:center;background:var(--primary-pale);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;flex-shrink:0;height:200px;justify-content:center;overflow:hidden;width:200px}.pet-photo-img-large,.pet-photo-large img{height:100%;object-fit:cover;width:100%}.pet-photo-placeholder,.pet-photo-placeholder-large{filter:drop-shadow(0 4px 12px rgba(102,126,234,.2));font-size:100px}.pet-details{flex:1 1}.pet-details h1{color:var(--text-primary);font-size:36px;font-weight:700;margin:0 0 8px}.pet-species{color:var(--text-secondary);font-weight:500;margin:0 0 24px}.pet-info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{gap:6px}.info-label{color:var(--text-muted);font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{color:var(--text-primary);font-size:16px;font-weight:600}.status-badge{border-radius:var(--radius-sm);display:inline-block;font-size:14px}.status-badge.healthy{background:#d1fae5;color:#065f46}.profile-tabs{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:12px;margin:0 auto 30px;max-width:1200px;padding:12px}.tab{background:#0000;border:2px solid #0000;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:16px 24px;transition:var(--transition)}.tab:hover{background:var(--bg-hover);color:var(--primary)}.tab.active{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);box-shadow:var(--shadow-md);color:#fff}.tab-content{margin:0 auto;max-width:1200px}.emergency-tab,.info-tab,.medical-tab{display:flex;flex-direction:column;gap:24px}.section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#f8f7f5fa);border:1px solid #d4af7a26;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:32px;position:relative;transition:var(--transition)}.section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.section h3{color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 20px}.empty-state{background:var(--bg-hover);border:2px dashed var(--border);border-radius:var(--radius-md);padding:40px 20px;text-align:center}.empty-state p{color:var(--text-secondary);font-size:15px;margin:0 0 20px}.btn-primary{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px 24px;transition:var(--transition)}.btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.qr-section{padding:40px 20px}.qr-section p{font-size:16px;margin:0 0 20px}.data-list{display:flex;flex-direction:column;gap:16px}.data-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;transition:var(--transition)}.data-item:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}.data-item-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.data-item-header>div{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.data-item-header strong{color:var(--text-primary);font-size:16px}.btn-delete{background:#0000;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:20px;opacity:.6;padding:4px 8px;transition:var(--transition)}.btn-delete:hover{background:#fee2e2;opacity:1;transform:scale(1.1)}.data-item p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:8px 0}.data-item p.notes{background:var(--bg-hover);border-radius:var(--radius-sm);font-style:italic;margin-top:12px;padding:12px}.data-item p.date{color:var(--text-muted);font-size:13px;margin-top:12px}.badge{padding:4px 12px;text-transform:uppercase}.badge.primary{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff}.badge.active,.badge.severity-mild{background:#dcfce7;color:#16a34a}.badge.severity-moderate{background:#fef3c7;color:#d97706}.badge.severity-severe{background:#fee2e2;color:#dc2626}.data-item.allergy-severe{border-left:4px solid #dc2626}.data-item.allergy-moderate{border-left:4px solid #d97706}.data-item.allergy-mild{border-left:4px solid #16a34a}.data-list .btn-secondary{margin-top:8px;width:100%}@media (max-width:768px){.pet-info-card{flex-direction:column;padding:24px}.pet-photo-large{height:150px;margin:0 auto;width:150px}.pet-details h1{font-size:28px}.pet-details h1,.pet-species{text-align:center}.pet-info-grid{grid-template-columns:1fr}.profile-tabs{flex-direction:column}.section{padding:20px}}.qr-section{padding:24px;text-align:center}.qr-section p{color:var(--text-secondary);line-height:1.6;margin-bottom:20px}.qr-preview-info{background:var(--bg-hover);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:12px;margin:20px 0;padding:20px}.qr-info-item{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:12px}.qr-icon{font-size:20px}.btn-large{font-size:16px;padding:16px 32px}.calendar-modal{max-height:90vh;max-width:800px!important}.calendar-container{padding:24px}.calendar-navigation{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.nav-btn{background:var(--bg-hover);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--primary);cursor:pointer;font-weight:600;padding:8px 16px;transition:var(--transition)}.nav-btn:hover{background:var(--primary);color:#fff;transform:scale(1.05)}.current-month{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.today-btn{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;margin-bottom:16px;padding:10px;transition:var(--transition);width:100%}.today-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.weekday{color:var(--text-secondary);font-size:12px;font-weight:600;padding:8px 4px;text-align:center}.calendar-days{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:24px}.calendar-day{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;min-height:80px;overflow:hidden;padding:6px;position:relative;transition:var(--transition)}.calendar-day.empty{background:#0000;border:none;cursor:default}.calendar-day:not(.empty):hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm);transform:scale(1.02)}.calendar-day.today{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px solid var(--primary);font-weight:700}.calendar-day.past{opacity:.5}.calendar-day.has-reminders{border-left:4px solid var(--primary)}.day-number{color:var(--text-primary);font-size:13px;font-weight:600;margin-bottom:4px}.day-reminders{display:flex;flex-direction:column;gap:3px;margin-top:4px}.reminder-dot{align-items:center;border-radius:4px;display:flex;font-size:10px;font-weight:500;gap:4px;overflow:hidden;padding:3px 4px;text-overflow:ellipsis;white-space:nowrap}.reminder-icon{flex-shrink:0;font-size:12px}.reminder-text{font-size:9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reminder-dot.deworming{background:#fef3c7;color:#92400e}.reminder-dot.vaccine{background:#dbeafe;color:#1e40af}.reminder-dot.checkup{background:#dcfce7;color:#166534}.calendar-legend{background:var(--bg-hover);border-radius:var(--radius-md);margin-bottom:20px;padding:16px}.calendar-legend h4{color:var(--text-primary);font-size:14px;margin:0 0 12px}.legend-items{display:flex;flex-wrap:wrap;gap:20px}.legend-item{align-items:center;color:var(--text-secondary);display:flex;font-size:13px;gap:8px}.legend-dot{font-size:18px}.reminders-summary{background:var(--primary-pale);border-left:4px solid var(--primary);border-radius:var(--radius-md);padding:16px}.reminders-summary h4{color:var(--text-primary);font-size:14px;margin:0 0 12px}.summary-item{align-items:center;background:#fff;border-radius:var(--radius-sm);display:flex;gap:10px;margin-bottom:8px;padding:8px 12px;transition:var(--transition)}.summary-item:hover{box-shadow:var(--shadow-sm);transform:translateX(4px)}.summary-icon{font-size:18px}.summary-text{color:var(--text-primary);flex:1 1;font-size:13px;font-weight:500}.summary-date{color:var(--text-secondary);font-size:12px;font-weight:600}.no-reminders{color:var(--text-secondary);font-size:14px;padding:20px;text-align:center}@media (max-width:768px){.calendar-modal{max-width:95vw}.calendar-container{padding:16px}.calendar-navigation{flex-direction:column;gap:12px}.current-month{font-size:18px}.calendar-day{min-height:60px;padding:4px}.day-number{font-size:11px}.reminder-text{display:none}.legend-items{flex-direction:column;gap:8px}}.add-pet-modal{max-height:90vh;max-width:600px;overflow-y:auto;padding:0;width:95%}.modal-header{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-bottom:1px solid var(--border-light);justify-content:space-between;padding:24px 32px}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{color:var(--text-primary);font-size:22px;gap:8px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:var(--transition);width:32px}.close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pet-form{display:flex;flex-direction:column;gap:24px;padding:32px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:16px}.photo-upload-section{margin-bottom:8px;width:100%}.photo-upload-container{align-items:center;background:var(--bg-light);border:2px dashed var(--border-light);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px;transition:var(--transition)}.photo-upload-container:hover{background:#667eea05;border-color:var(--primary-color)}.photo-preview{border-radius:50%;box-shadow:var(--shadow-md);height:150px;overflow:hidden;position:relative;width:150px}.photo-preview img{height:100%;object-fit:cover;width:100%}.remove-photo-btn{align-items:center;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:28px;justify-content:center;position:absolute;right:8px;top:8px;transition:var(--transition);width:28px}.remove-photo-btn:hover{background:#dc2626;transform:scale(1.1)}.photo-placeholder{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:50%;display:flex;flex-direction:column;gap:8px;height:150px;justify-content:center;width:150px}.photo-icon{font-size:40px;opacity:.5}.photo-text{color:var(--text-muted);font-size:13px;font-weight:500}.photo-input{display:none}.photo-input-label{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;text-align:center;transition:var(--transition)}.photo-input-label:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (max-width:640px){.form-row{grid-template-columns:1fr}.pet-form{padding:24px}.photo-placeholder,.photo-preview{height:120px;width:120px}.photo-icon{font-size:32px}}.owner-dashboard{background:var(--bg-main);min-height:100vh;position:relative;z-index:1}.owner-dashboard:after{background-image:radial-gradient(circle at 10% 20%,#d4af7a0f 0,#0000 40%),radial-gradient(circle at 90% 80%,#1b3a520a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.error-indicator,.loading-indicator{background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin:16px 0;padding:16px 24px;text-align:center}.loading-indicator{background:var(--primary-pale);border:2px solid var(--primary);color:var(--primary);font-weight:600}.error-indicator{background:#fef2f2;border:2px solid #dc2626;color:#dc2626;font-weight:600}.dashboard-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffffa,#f8f7f5fa);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.dashboard-header:before{animation:shimmer 3s ease-in-out infinite;background:linear-gradient(90deg,var(--secondary) 0,var(--primary) 50%,var(--secondary) 100%);background-size:200% 100%;content:"";height:3px;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}@keyframes shimmer{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:20px 24px;position:relative;z-index:2}.header-content,.user-info{align-items:center;display:flex}.user-info{gap:16px}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-radius:50%;display:flex;font-size:24px;height:48px;justify-content:center;width:48px}.user-details h2{color:var(--text-primary);font-size:18px;margin:0}.user-details p{color:var(--text-secondary);font-size:14px;margin:0}.btn-logout{background:#fff;border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-weight:600;padding:10px 20px;transition:var(--transition)}.btn-logout:hover{border-color:var(--primary);color:var(--primary)}.dashboard-main{margin:0 auto;max-width:1200px;padding:32px 24px}.container{display:flex;flex-direction:column;gap:32px}.notification-bell{align-items:center;background:var(--bg-hover);border:2px solid var(--border);border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;transition:var(--transition);width:40px}.notification-bell:hover{background:var(--primary);border-color:var(--primary);transform:scale(1.05)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:500px;padding:32px;text-align:center;width:90%}.modal-content h3{color:var(--text-primary);margin:0 0 16px}.modal-content p{color:var(--text-secondary);margin:0 0 24px}.pet-profile-view{padding:24px}.no-pets{background:linear-gradient(135deg,#ffffffe6,#efe4d133);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:32px 0;overflow:hidden;padding:80px 32px;position:relative;text-align:center}.no-pets:before{animation:bounce 2s ease-in-out infinite;left:20px;top:20px}.no-pets:after,.no-pets:before{content:"🐾";font-size:40px;opacity:.1;pointer-events:none;position:absolute;z-index:0}.no-pets:after{animation:bounce 2s ease-in-out 1s infinite;bottom:20px;right:20px}@keyframes bounce{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(10deg)}}.no-pets-icon{filter:drop-shadow(0 4px 12px rgba(102,126,234,.15));font-size:80px;margin-bottom:24px}.no-pets h3{color:var(--text-primary);font-size:24px;margin:0 0 12px}.no-pets p{color:var(--text-secondary);font-size:16px;line-height:1.6;margin:0 auto 32px;max-width:500px}.no-pets .btn-primary{font-size:16px;padding:16px 32px}.info-banner{background:linear-gradient(135deg,#d4af7a14,#efe4d11f);border:2px solid var(--primary-pale);border-radius:var(--radius-lg);padding:24px 32px}.banner-content{align-items:center;display:flex;gap:20px}.banner-icon{flex-shrink:0;font-size:40px}.banner-text h4{color:var(--text-primary);font-size:18px;margin:0 0 8px}.banner-text p{color:var(--text-secondary);font-size:14px;margin:0}.reminders-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:32px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-header h3{color:var(--text-primary);font-size:20px;margin:0}.pets-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#f8f7f5fa);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;padding:32px;position:relative}.pets-section:before{animation:float 6s ease-in-out infinite;background:radial-gradient(circle,#d4af7a1a 0,#0000 70%);border-radius:50%;content:"";height:300px;pointer-events:none;position:absolute;right:-100px;top:-100px;width:300px;z-index:0}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-20px,20px) scale(1.1)}}.pets-section h3{color:var(--text-primary);font-size:20px;margin:0 0 24px}.pets-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.pet-card{background:linear-gradient(135deg,#ffffffe6,#f8f7f5f2);border:2px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;padding:24px;position:relative;transition:var(--transition)}.pet-card>*{position:relative;z-index:1}.pet-card:before{background:radial-gradient(circle,#d4af7a0d 0,#0000 70%);content:"";height:200%;opacity:0;right:-50%;top:-50%;transition:opacity .3s ease;width:200%}.pet-card:after,.pet-card:before{pointer-events:none;position:absolute;z-index:0}.pet-card:after{bottom:10px;content:"🐾";font-size:20px;opacity:.1;right:10px;transform:rotate(-15deg);transition:var(--transition)}.pet-card:hover:before{opacity:1}.pet-card:hover{background:linear-gradient(135deg,#fff,#efe4d14d);border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-6px) scale(1.02)}.pet-card:hover:after{opacity:.2;transform:rotate(0deg) scale(1.2)}.pet-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px;position:relative}.pet-header-right{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.pet-photo{align-items:center;background:var(--bg-light);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #667eea33;display:flex;height:80px;justify-content:center;overflow:hidden;width:80px}.pet-photo-img{height:100%;object-fit:cover;width:100%}.pet-photo-placeholder{align-items:center;display:flex;font-size:40px;justify-content:center}.status-badge{border-radius:20px;font-size:12px;font-weight:600;padding:6px 12px}.status-badge.healthy{background:#dcfce7;color:#166534}.status-badge.new{background:var(--primary-pale);color:var(--primary)}.pet-delete-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#00000080;cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;line-height:1;opacity:.65;padding:0;transition:all .2s ease;width:24px}.pet-delete-btn:hover{background:#dc26261a;color:#dc2626;opacity:1;transform:scale(1.1)}.pet-card:hover .pet-delete-btn{opacity:.8}.pet-info h4{color:var(--text-primary);font-size:20px;margin:0 0 4px}.pet-breed{font-size:14px;margin:0 0 12px}.pet-breed,.pet-details{color:var(--text-secondary)}.pet-details{display:flex;flex-wrap:wrap;font-size:13px;gap:12px}.pet-details span{background:#fff;border-radius:var(--radius-sm);padding:6px 12px}.pet-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.pet-actions .btn-primary,.pet-actions .btn-secondary{text-align:center;width:100%}.reminders-compact{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.reminder-item-compact{align-items:center;background:#fff;border-left:3px solid var(--border);border-radius:var(--radius-sm);display:flex;gap:12px;padding:12px;transition:var(--transition)}.reminder-item-compact:hover{box-shadow:var(--shadow-sm);transform:translateX(2px)}.reminder-item-compact.urgent{background:#fef2f2;border-left-color:#dc2626}.reminder-item-compact.warning{background:#fffbeb;border-left-color:#f59e0b}.reminder-item-compact.info{background:var(--primary-pale);border-left-color:var(--primary)}.reminder-item-compact.normal{background:#f0fdf4;border-left-color:#10b981}.reminder-icon-compact{flex-shrink:0;font-size:20px}.reminder-info-compact{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.reminder-title-compact{color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reminder-time-compact{color:var(--text-secondary);font-size:11px;font-weight:500}.no-reminders-compact{color:var(--text-secondary);grid-column:1/-1;padding:24px;text-align:center}.no-reminders-compact p{font-size:14px;margin:0}@media (max-width:768px){.header-content{flex-direction:column;gap:16px}.header-left{gap:16px;justify-content:space-between;width:100%}.dashboard-logo{height:40px}.header-right{justify-content:space-between;width:100%}.user-info{gap:12px}.user-avatar{font-size:20px;height:40px;width:40px}.user-details h2{font-size:16px}.user-details p{font-size:13px}.pets-grid{gap:16px;grid-template-columns:1fr}.section-header{align-items:flex-start;flex-direction:column;gap:16px}.pets-section{padding:20px}.pets-section:before{height:200px;width:200px}.pet-card{padding:20px}.no-pets{padding:60px 20px}.no-pets:after,.no-pets:before{font-size:30px}}@media (max-width:480px){.dashboard-main{padding:20px 16px}.pet-card,.pets-section{padding:16px}.pet-card:after{bottom:8px;font-size:16px;right:8px}}.emergency-view{background:var(--gradient-primary);min-height:100vh;padding:20px}.emergency-view.error,.emergency-view.loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.emergency-header{margin:0 auto 20px;max-width:800px}.emergency-logo{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:15px;padding:20px}.emergency-logo .logo-icon{font-size:48px}.emergency-logo .logo-text h1{color:var(--secondary);font-size:28px;margin:0}.emergency-logo .logo-text p{color:#666;font-size:14px;margin:5px 0 0}.emergency-content{margin:0 auto;max-width:800px}.emergency-card{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;overflow:hidden}.pet-header-section{background:var(--gradient-secondary);color:#fff;padding:40px;text-align:center}.pet-photo-emergency{align-items:center;display:flex;justify-content:center;margin-bottom:20px}.emergency-pet-img{background:#fff;border:6px solid #ffffff4d;border-radius:50%;box-shadow:0 8px 24px #0003;height:180px;object-fit:cover;width:180px}.pet-icon-large{font-size:80px;margin-bottom:20px}.pet-basic-info h2{color:var(--primary);font-size:36px;margin:0 0 10px;text-shadow:0 2px 4px #0000001a}.pet-species{font-size:18px;margin:0 0 5px;opacity:.9}.pet-breed{font-size:16px;margin:0;opacity:.8}.info-sections{padding:30px}.info-section{background:var(--bg-light);border-left:4px solid var(--secondary);border-radius:12px;margin-bottom:30px;padding:20px}.info-section h3{color:#2d3748;font-size:20px;margin:0 0 15px}.info-section.emergency-contact{background:#fef3c7;border-left-color:#f59e0b}.info-section.allergies{background:#fee2e2;border-left-color:#ef4444}.info-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{display:flex;flex-direction:column;gap:5px}.info-item .label{color:#666;font-size:12px;font-weight:600}.info-item .value{color:#2d3748;font-size:16px}.contact-card,.vet-card{background:#fff;border-radius:8px;padding:15px}.contact-name,.vet-name{align-items:center;display:flex;font-size:18px;gap:10px;margin:0 0 10px}.contact-phone,.vet-phone{font-size:20px;font-weight:600;margin:10px 0}.contact-phone a,.vet-phone a{color:#f59e0b;text-decoration:none}.contact-relationship{color:#666;font-size:14px;margin:5px 0 0}.allergies-list{display:flex;flex-direction:column;gap:15px}.allergy-item{background:#fff;border-left:4px solid #ef4444;border-radius:8px;padding:15px}.allergy-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.severity-badge{border-radius:20px;font-size:12px;font-weight:600;padding:4px 12px}.severity-badge.severe{background:#fee2e2;color:#991b1b}.severity-badge.moderate{background:#fef3c7;color:#92400e}.severity-badge.mild{background:#d1fae5;color:#065f46}.allergy-desc{color:#666;font-size:14px;margin:5px 0 0}.badge{background:var(--primary);border-radius:12px;color:var(--text-light);font-size:12px;font-weight:600;padding:4px 10px}.emergency-footer{background:#f8f9fa;border-top:2px solid #e2e8f0;padding:20px 30px}.footer-info{margin-bottom:15px;text-align:center}.footer-info p:first-child{color:#dc2626;font-size:18px;margin:0 0 10px}.footer-info p:last-child{color:#666;margin:0}.powered-by{border-top:1px solid #e2e8f0;padding-top:15px;text-align:center}.powered-by p{color:#999;font-size:13px;margin:0}@media (max-width:768px){.emergency-view{padding:10px}.pet-header-section{padding:30px 20px}.emergency-pet-img{border:4px solid #ffffff4d;height:140px;width:140px}.pet-icon-large{font-size:60px}.pet-basic-info h2{font-size:28px}.info-sections{padding:20px}.info-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.2f3b0da1.css.map*/