:root{--color-orange-50: #fff7ed;--color-orange-100: #ffedd5;--color-orange-200: #fed7aa;--color-orange-300: #fdba74;--color-orange-400: #fb923c;--color-orange-500: #f97316;--color-orange-600: #ea580c;--color-orange-700: #c2410c;--color-orange-800: #9a3412;--color-orange-900: #7c2d12;--color-orange-950: #431407;--color-cream-50: #fefdfb;--color-cream-100: #fdf9f3;--color-cream-200: #faf3e6;--color-cream-300: #f5e8d3;--color-cream-400: #edd5b3;--color-cream-500: #e4c193;--color-cream-600: #d4a574;--color-cream-700: #b8875a;--color-cream-800: #96694a;--color-cream-900: #7a553e;--color-cream-950: #412b1e;--color-ginger-50: #fdf6f3;--color-ginger-100: #fceae3;--color-ginger-200: #fad4c6;--color-ginger-300: #f5b59f;--color-ginger-400: #ee8b6b;--color-ginger-500: #e46a45;--color-ginger-600: #d14f2c;--color-ginger-700: #ae3e22;--color-ginger-800: #8f3520;--color-ginger-900: #752f1f;--color-ginger-950: #3f150c;--color-gray-50: #fafaf9;--color-gray-100: #f5f5f4;--color-gray-200: #e7e5e4;--color-gray-300: #d6d3d1;--color-gray-400: #a8a29e;--color-gray-500: #78716c;--color-gray-600: #57534e;--color-gray-700: #44403c;--color-gray-800: #292524;--color-gray-900: #1c1917;--color-gray-950: #0c0a09;--color-success: #16a34a;--color-success-light: #bbf7d0;--color-success-dark: #15803d;--color-warning: #d97706;--color-warning-light: #fde68a;--color-warning-dark: #b45309;--color-error: #dc2626;--color-error-light: #fecaca;--color-error-dark: #b91c1c;--color-info: #0284c7;--color-info-light: #bae6fd;--color-info-dark: #0369a1;--color-status-overdue: #fef2f2;--color-border-overdue: #ef4444;--color-status-urgent: #fffbeb;--color-border-urgent: #f59e0b;--color-status-stable: #fefdfb;--color-border-stable: #e4c193;--color-chip-taken: #dcfce7;--color-chip-taken-icon: #16a34a;--color-chip-missed: #f3f4f6;--color-chip-missed-icon: #6b7280}:root{--font-family-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-none: 1;--line-height-tight: 1.25;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em}:root{--spacing-0: 0;--spacing-px: 1px;--spacing-0_5: .125rem;--spacing-1: .25rem;--spacing-1_5: .375rem;--spacing-2: .5rem;--spacing-2_5: .625rem;--spacing-3: .75rem;--spacing-3_5: .875rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-7: 1.75rem;--spacing-8: 2rem;--spacing-9: 2.25rem;--spacing-10: 2.5rem;--spacing-11: 2.75rem;--spacing-12: 3rem;--spacing-14: 3.5rem;--spacing-16: 4rem;--spacing-20: 5rem;--spacing-24: 6rem;--spacing-xs: var(--spacing-1);--spacing-sm: var(--spacing-2);--spacing-md: var(--spacing-4);--spacing-lg: var(--spacing-6);--spacing-xl: var(--spacing-8);--spacing-2xl: var(--spacing-12)}:root{--radius-none: 0;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--radius-card: 1rem;--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-warm-md: 0 4px 16px -4px rgb(180 120 80 / .12);--shadow-warm-lg: 0 8px 24px -6px rgb(180 120 80 / .15);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05);--shadow-none: 0 0 #0000;--ring-color: var(--color-orange-500);--ring-width: 3px;--ring-offset: 2px;--focus-ring: 0 0 0 var(--ring-width) rgb(249 115 22 / .2);--transition-fast: .1s;--transition-normal: .15s;--transition-slow: .3s;--transition-slower: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800}:root{--color-primary: var(--color-orange-500);--color-primary-hover: var(--color-orange-600);--color-primary-active: var(--color-orange-700);--color-primary-light: var(--color-orange-100);--color-primary-dark: var(--color-orange-700);--color-secondary: var(--color-cream-500);--color-secondary-hover: var(--color-cream-600);--color-secondary-light: var(--color-cream-100);--color-accent: var(--color-ginger-500);--color-accent-hover: var(--color-ginger-600);--color-accent-light: var(--color-ginger-100);--color-bg-body: var(--color-cream-100);--color-bg-surface: #ffffff;--color-bg-muted: var(--color-gray-100);--color-bg-subtle: var(--color-cream-50);--color-bg-inverse: var(--color-gray-900);--color-text-primary: var(--color-gray-900);--color-text-secondary: var(--color-gray-600);--color-text-muted: var(--color-gray-500);--color-text-inverse: #ffffff;--color-text-link: var(--color-orange-600);--color-text-link-hover: var(--color-orange-700);--color-border-default: var(--color-gray-200);--color-border-muted: var(--color-gray-100);--color-border-emphasis: var(--color-gray-300);--color-border-primary: var(--color-orange-500);--color-status-success-bg: #f0fdf4;--color-status-success-border: #22c55e;--color-status-success-text: #166534;--color-status-warning-bg: #fffbeb;--color-status-warning-border: #f59e0b;--color-status-warning-text: #92400e;--color-status-error-bg: #fef2f2;--color-status-error-border: #ef4444;--color-status-error-text: #991b1b;--color-status-info-bg: #eff6ff;--color-status-info-border: #3b82f6;--color-status-info-text: #1e40af;--color-status-neutral-bg: var(--color-gray-50);--color-status-neutral-border: var(--color-gray-300);--color-status-neutral-text: var(--color-gray-700);--font-family: var(--font-family-sans)}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{min-height:100vh;min-height:100dvh;line-height:var(--line-height-normal);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-body)}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:var(--line-height-tight);text-wrap:balance}a{color:var(--color-text-link);text-decoration:none;text-decoration-skip-ink:auto}a:hover{color:var(--color-text-link-hover);text-decoration:underline}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit;color:inherit}button{background:none;border:none;cursor:pointer}textarea:not([rows]){min-height:10em}:target{scroll-margin-block:5ex}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}body{background-image:url(../assets/mosaic-pattern.svg);background-repeat:repeat;background-size:200px 200px}.container{width:100%;max-width:640px;margin:0 auto;padding:0 var(--spacing-md)}.container-lg{max-width:900px}.container-xl{max-width:1200px}.layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.main{flex:1;padding:var(--spacing-lg);max-width:1200px;margin:0 auto;width:100%;background-color:var(--color-bg-surface)}.page{max-width:900px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.page-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.page-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.page-header-actions{display:flex;gap:var(--spacing-sm)}.section{margin-bottom:var(--spacing-xl)}.section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md)}.section-header h2{margin-bottom:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-grow{flex-grow:1}.flex-shrink-0{flex-shrink:0}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.gap-5{gap:var(--spacing-xl)}.space-y-1>*+*{margin-top:var(--spacing-xs)}.space-y-2>*+*{margin-top:var(--spacing-sm)}.space-y-3>*+*{margin-top:var(--spacing-md)}.space-y-4>*+*{margin-top:var(--spacing-lg)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.px-2{padding-left:var(--spacing-sm);padding-right:var(--spacing-sm)}.px-3{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.px-4{padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}.py-2{padding-top:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.py-3{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.py-4{padding-top:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.text-muted{color:var(--color-text-muted);font-size:var(--font-size-sm)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.w-full{width:100%}.min-h-screen{min-height:100vh;min-height:100dvh}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);min-height:40px;font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-normal) var(--ease-default);cursor:pointer;border:none;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-active)}.btn-primary:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn-secondary{background-color:var(--color-bg-surface);color:var(--color-gray-700);border:1px solid var(--color-border-default)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-border-emphasis)}.btn-ghost{background:none;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100)}.btn-danger{background-color:var(--color-error);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background-color:var(--color-error-dark)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);min-height:32px}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg);min-height:48px}.btn-full{width:100%}.btn-loading{opacity:.8;cursor:wait}.btn-spinner{animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form{display:flex;flex-direction:column;gap:var(--spacing-md);max-width:500px}.form-group{display:flex;flex-direction:column}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md)}.label,.form-group label,.form-field label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);margin-bottom:var(--spacing-xs)}.form-field-error label{color:var(--color-error)}.input,.form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border-default);border-radius:var(--radius-md);background-color:var(--color-bg-surface);font-size:var(--font-size-base);transition:border-color var(--transition-normal) var(--ease-default),box-shadow var(--transition-normal) var(--ease-default)}.input:focus,.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--focus-ring)}.input-error,.form-control-error{border-color:var(--color-error)}.input-error:focus,.form-control-error:focus{box-shadow:0 0 0 3px #dc262633}.form-control-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.input-wrapper{position:relative}.input-with-icon input{padding-left:2.5rem}.input-icon{position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);color:var(--color-gray-400);pointer-events:none}.form-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.error-message{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.success-message{color:var(--color-success);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.auth-logo{text-align:center;margin-bottom:var(--spacing-lg)}.auth-logo__image{width:80px;height:80px;margin:0 auto var(--spacing-md)}.auth-logo__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0}.auth-logo__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--spacing-xs) 0 0}.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.auth-container{width:100%;max-width:400px;background-color:var(--color-bg-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.auth-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.auth-subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.invite-form-card{margin-bottom:var(--spacing-lg)}.invite-form{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.card{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);border:1px solid var(--color-border-default);padding:var(--spacing-lg)}.card-clickable{cursor:pointer;transition:box-shadow var(--transition-normal) var(--ease-default)}.card-clickable:hover{box-shadow:var(--shadow-md)}.card-header{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-muted);margin-bottom:var(--spacing-md)}.card-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.card-header-row{display:flex;justify-content:space-between;align-items:center}.card-footer{padding-top:var(--spacing-md);border-top:1px solid var(--color-border-muted);margin-top:var(--spacing-md)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.pets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.pet-card-link{text-decoration:none;color:inherit}.pet-card{display:flex;align-items:center;gap:var(--spacing-md)}.pet-card-avatar{width:64px;height:64px;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pet-card-avatar img{width:100%;height:100%;object-fit:cover}.pet-card-avatar-placeholder{font-size:2rem}.pet-card-info{flex:1;min-width:0}.pet-card-name{font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.pet-card-breed,.pet-card-weight{font-size:var(--font-size-sm);color:var(--color-text-muted)}.pet-header{display:flex;align-items:center;gap:var(--spacing-md)}.pet-avatar{width:80px;height:80px;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-muted);display:flex;align-items:center;justify-content:center}.pet-avatar img{width:100%;height:100%;object-fit:cover}.pet-avatar-placeholder{font-size:2.5rem}.pet-breed{color:var(--color-text-muted)}.pet-info-grid{display:grid;gap:var(--spacing-lg)}.members-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.member-card .card-content{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.member-info{display:flex;align-items:center;gap:var(--spacing-md)}.member-avatar{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold)}.member-name{font-weight:var(--font-weight-medium)}.member-email{font-size:var(--font-size-sm);color:var(--color-text-muted)}.member-actions{display:flex;gap:var(--spacing-sm)}.invitations-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.invitation-card .card-content{display:flex;justify-content:space-between;align-items:center}.invitation-info{display:flex;align-items:center;gap:var(--spacing-md)}.invitation-email{font-weight:var(--font-weight-medium)}.invitation-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.profile-cards{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:500px}.skeleton-card{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-default)}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-md);flex-shrink:0}.skeleton-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-title{height:1rem;width:60%}.skeleton-subtitle{height:.875rem;width:40%}.pet-card-enhanced{display:flex;gap:var(--spacing-md)}.pet-card-enhanced__avatar{width:80px;height:80px;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(135deg,var(--color-orange-100) 0%,var(--color-cream-200) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid var(--color-orange-200)}.pet-card-enhanced__avatar img{width:100%;height:100%;object-fit:cover}.pet-card-enhanced__avatar-placeholder{font-size:2.5rem}.pet-card-enhanced__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.pet-card-enhanced__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.pet-card-enhanced__name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pet-card-enhanced__species{color:var(--color-primary);flex-shrink:0}.pet-card-enhanced__breed{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.pet-card-enhanced__details{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-xs)}.pet-card-enhanced__detail{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted)}.pet-card-enhanced__detail svg{color:var(--color-gray-400)}.pet-card-enhanced__footer{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);margin-top:auto;padding-top:var(--spacing-xs)}.pet-card-enhanced__medical{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-warning);background-color:var(--color-warning-light);padding:2px var(--spacing-sm);border-radius:var(--radius-full)}.pet-card-enhanced__medical svg{flex-shrink:0}.pet-header-enhanced{display:flex;align-items:center;gap:var(--spacing-lg)}.pet-avatar-enhanced{width:100px;height:100px;border-radius:var(--radius-xl);overflow:hidden;background:linear-gradient(135deg,var(--color-orange-100) 0%,var(--color-cream-200) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:3px solid var(--color-orange-300);box-shadow:var(--shadow-md)}.pet-avatar-enhanced img{width:100%;height:100%;object-fit:cover}.pet-avatar-enhanced__placeholder{color:var(--color-primary)}.pet-header-enhanced__info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.pet-header-enhanced__info h1{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.pet-header-enhanced__breed{margin:0;font-size:var(--font-size-base);color:var(--color-text-secondary)}.pet-header-enhanced__stats{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-xs)}.pet-header-enhanced__stat{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted);background-color:var(--color-bg-muted);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full)}.pet-header-enhanced__stat svg{color:var(--color-primary)}.pets-list-page{max-width:1000px;margin:0 auto}.pets-list{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (min-width: 768px){.pets-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}}.pets-list .pet-card-link{display:block;text-decoration:none;color:inherit}.pets-list .pet-list-card{height:100%;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.pets-list .pet-list-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-warm-lg)}.pet-list-card__info{flex:1;min-width:0}.pet-list-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.pet-list-card__alert{display:flex;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-warning-bg);color:var(--color-warning-text);border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.pet-list-card__alert svg{flex-shrink:0;margin-top:2px}.medication-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.medication-card{padding:var(--spacing-md)}.medication-card__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary);flex-shrink:0}.medication-card__info{flex:1;min-width:0}.medication-card__badges{display:flex;gap:var(--spacing-xs);flex-shrink:0}.medication-card__instructions{margin:0;padding:var(--spacing-sm);background:var(--color-surface-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.checkup-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.checkup-card{padding:var(--spacing-md)}.checkup-card__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-info-light);color:var(--color-info);flex-shrink:0}.checkup-card__info{flex:1;min-width:0}.checkup-card__badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);flex-shrink:0}.checkup-card__diagnosis{margin:0;padding:var(--spacing-sm);background:var(--color-surface-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.vaccine-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.vaccine-card{padding:var(--spacing-md)}.vaccine-card__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-success-light);color:var(--color-success);flex-shrink:0}.vaccine-card__info{flex:1;min-width:0}.vaccine-card__badges{display:flex;gap:var(--spacing-xs);flex-shrink:0}.header{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default);padding:var(--spacing-sm) var(--spacing-md);position:sticky;top:0;z-index:var(--z-sticky)}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-primary);text-decoration:none}.logo:hover{text-decoration:none}.logo-icon{width:32px;height:32px}.nav{display:flex;gap:var(--spacing-md)}.nav a{color:var(--color-gray-600);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);text-decoration:none;transition:color var(--transition-fast) var(--ease-default),background-color var(--transition-fast) var(--ease-default)}.nav a:hover,.nav a.active{color:var(--color-primary);background-color:var(--color-primary-light)}.user-menu{display:flex;align-items:center;gap:var(--spacing-sm)}.user-name{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.menu-toggle{display:none;padding:var(--spacing-xs);color:var(--color-gray-600)}.nav-mobile{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-surface);z-index:var(--z-modal);flex-direction:column;padding:var(--spacing-lg)}.nav-mobile.open{display:flex}.nav-mobile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.nav-mobile-links{display:flex;flex-direction:column;gap:var(--spacing-sm)}.nav-mobile-links a{padding:var(--spacing-md);font-size:var(--font-size-lg);color:var(--color-gray-700);border-radius:var(--radius-md);text-decoration:none}.nav-mobile-links a:hover,.nav-mobile-links a.active{background-color:var(--color-primary-light);color:var(--color-primary)}.tabs{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--color-border-default);margin-bottom:var(--spacing-lg);overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-gray-600);border-bottom:2px solid transparent;white-space:nowrap;cursor:pointer;transition:color var(--transition-fast) var(--ease-default),border-color var(--transition-fast) var(--ease-default)}.tab:hover{color:var(--color-primary)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-section{margin-bottom:var(--spacing-xl)}@media (max-width: 640px){.header-content{flex-wrap:nowrap}.nav{display:none}.menu-toggle{display:block}.tabs{margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.alert-error{background-color:var(--color-error-light);color:var(--color-error);border:1px solid var(--color-error)}.alert-success{background-color:var(--color-success-light);color:var(--color-success-dark);border:1px solid var(--color-success)}.alert-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark);border:1px solid var(--color-warning)}.alert-info{background-color:var(--color-info-light);color:var(--color-info-dark);border:1px solid var(--color-info)}.alert-dismiss{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.5;transition:opacity var(--transition-fast) var(--ease-default)}.alert-dismiss:hover{opacity:1}.toast-container{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%;max-width:400px;padding:0 var(--spacing-md)}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:toast-in .2s var(--ease-out)}@keyframes toast-in{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.toast-success{background-color:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toast-error{background-color:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast-warning{background-color:#fffbeb;color:#92400e;border:1px solid #fde68a}.toast-info{background-color:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.toast-icon{flex-shrink:0}.toast-message{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.toast-dismiss{flex-shrink:0;padding:var(--spacing-xs);border-radius:var(--radius-sm);opacity:.6;transition:opacity var(--transition-fast) var(--ease-default)}.toast-dismiss:hover{opacity:1;background-color:#0000001a}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);background-color:var(--color-bg-muted);color:var(--color-gray-600)}.badge-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.badge-secondary{background-color:var(--color-gray-200);color:var(--color-gray-700)}.badge-success{background-color:var(--color-success);color:var(--color-text-inverse)}.badge-warning{background-color:var(--color-warning);color:var(--color-text-inverse)}.badge-error{background-color:var(--color-error);color:var(--color-text-inverse)}.spinner{width:1.25rem;height:1.25rem;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.page-loader{display:flex;align-items:center;justify-content:center;min-height:200px}.loading-text{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted);font-size:var(--font-size-sm)}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-line{height:1rem}.skeleton-line-short{width:60%}.skeleton-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:var(--spacing-sm)}.empty-state-description{margin-bottom:var(--spacing-lg)}.offline-indicator{position:fixed;bottom:0;left:0;right:0;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-warning);color:var(--color-text-inverse);text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);z-index:var(--z-toast);display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}@media (max-width: 640px){.toast-container{bottom:var(--spacing-md);left:var(--spacing-md);right:var(--spacing-md);transform:none;max-width:none;padding:0}}.modal{border:none;border-radius:var(--radius-lg);padding:0;max-width:90vw;box-shadow:var(--shadow-xl)}.modal::backdrop{background-color:#00000080}.modal-sm{width:360px}.modal-md{width:480px}.modal-lg{width:640px}.modal-content{display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-default)}.modal-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.modal-close{padding:var(--spacing-xs);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default),color var(--transition-fast) var(--ease-default)}.modal-close:hover{background-color:var(--color-bg-muted);color:var(--color-gray-700)}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border-default)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}@media (max-width: 640px){.modal{margin:var(--spacing-md);max-height:calc(100vh - 2 * var(--spacing-md))}.modal-sm,.modal-md,.modal-lg{width:auto}}.list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.list-item-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.list-item-header h3{font-weight:var(--font-weight-semibold)}.list-item-badges{display:flex;gap:var(--spacing-xs)}.list-item-actions{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border-muted)}.info-list{display:grid;gap:var(--spacing-sm)}.info-item{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border-muted)}.info-item:last-child{border-bottom:none}.info-item dt{color:var(--color-text-muted);font-size:var(--font-size-sm)}.info-item dd{font-weight:var(--font-weight-medium)}.timeline{display:flex;flex-direction:column;gap:var(--spacing-md)}.timeline-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm)}.timeline-icon{font-size:1.5rem;margin-left:-1.5rem;background:var(--color-bg-surface)}.timeline-content{flex:1}.timeline-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.timeline-description{font-weight:var(--font-weight-medium)}.timeline-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header h2{margin:0}.clinical-form-card{margin-bottom:var(--spacing-lg)}.clinical-event-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.clinical-event-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}@media (max-width: 640px){.clinical-event-form .form-row{grid-template-columns:1fr}}.clinical-event-form .form-hint{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.pets-summary{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.pet-summary-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-muted);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:background-color var(--transition-fast) var(--ease-default)}.pet-summary-item:hover{background-color:var(--color-gray-200)}.pet-summary-icon{font-size:1.25rem}.pet-summary-name{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.pet-summary-more{padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-primary);font-size:var(--font-size-sm)}.pets-summary--mobile{display:flex}.pets-summary--desktop{display:none}@media (min-width: 768px){.pets-summary--mobile{display:none}.pets-summary--desktop{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}}.pet-card-desktop{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);background:linear-gradient(135deg,var(--color-bg-subtle) 0%,var(--color-bg-surface) 100%);border:1px solid var(--color-border-muted);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all var(--transition-fast) var(--ease-default)}.pet-card-desktop:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.pet-card-desktop__avatar{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;background:linear-gradient(135deg,var(--color-orange-100) 0%,var(--color-cream-200) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid var(--color-orange-200)}.pet-card-desktop__avatar img{width:100%;height:100%;object-fit:cover}.pet-card-desktop__avatar-placeholder{font-size:1.75rem}.pet-card-desktop__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.pet-card-desktop__header{display:flex;align-items:center;gap:var(--spacing-xs)}.pet-card-desktop__name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-default)}.pet-card-desktop__medical{color:var(--color-warning);display:flex;align-items:center;flex-shrink:0}.pet-card-desktop__breed{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pet-card-desktop__details{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.pet-card-desktop__detail{display:inline-flex;align-items:center;gap:3px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.pet-card-desktop__detail svg{color:var(--color-primary)}.pet-summary-more-desktop{display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background-color:var(--color-bg-muted);border:1px dashed var(--color-border-default);border-radius:var(--radius-lg);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:all var(--transition-fast) var(--ease-default)}.pet-summary-more-desktop:hover{background-color:var(--color-primary-light);border-color:var(--color-primary)}.pending-list,.upcoming-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pending-item,.upcoming-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--color-bg-subtle);border-radius:var(--radius-md)}.pending-item-icon,.upcoming-item-icon{font-size:1.25rem}.pending-item-content,.upcoming-item-content{flex:1;min-width:0}.pending-item-title,.upcoming-item-title{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.pending-item-subtitle,.upcoming-item-subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted)}.pending-item-time,.upcoming-item-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.pending-list-grouped{display:flex;flex-direction:column;gap:var(--spacing-md)}.pending-group{background-color:var(--color-bg-subtle);border-radius:var(--radius-md);overflow:hidden}.pending-group-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-light);text-decoration:none;color:inherit;transition:background-color var(--transition-fast) var(--ease-default)}.pending-group-header:hover{background-color:var(--color-orange-200)}.pending-group-icon{font-size:1.25rem}.pending-group-avatar{width:2rem;height:2rem;border-radius:var(--radius-full);object-fit:cover}.pending-group-name{flex:1;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.pending-group-count{background-color:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);padding:2px 8px;border-radius:var(--radius-full);min-width:1.5rem;text-align:center}.pending-group-items{padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.pending-item-compact{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-surface);border-radius:var(--radius-sm)}.pending-item-compact .pending-item-icon{font-size:1rem}.pending-item-compact .pending-item-title{flex:1;font-size:var(--font-size-sm)}.pending-item-compact .pending-item-time{font-size:var(--font-size-xs)}.notification-settings{display:flex;flex-direction:column;gap:var(--spacing-md)}.notification-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.pending-item-relative{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.pending-item-compact.dose-overdue{background-color:var(--color-error-light, #fef2f2)}.pending-item-compact.dose-overdue .pending-item-relative{color:var(--color-error);font-weight:var(--font-weight-medium)}.pending-item-compact.dose-urgent{background-color:var(--color-warning-light, #fffbeb)}.pending-item-compact.dose-urgent .pending-item-relative{color:var(--color-warning-dark, #92400e);font-weight:var(--font-weight-medium)}.pending-item-compact.dose-soon{background-color:var(--color-primary-light)}.audit-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.audit-item{transition:transform var(--transition-fast) var(--ease-default)}.audit-item:hover{transform:translate(2px)}.audit-item-header{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.audit-icon{font-size:1.5rem;flex-shrink:0}.audit-main{flex:1;min-width:0}.audit-action-line{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.audit-entity-type{color:var(--color-text-muted);font-size:var(--font-size-sm)}.audit-entity-name{font-weight:var(--font-weight-medium);color:var(--color-text-default)}.audit-pet{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.audit-pet-icon{font-size:.875rem}.audit-detail{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--spacing-xs) 0 0 0;line-height:1.5}.audit-changes{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface-tertiary);border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.audit-changes-title{font-weight:var(--font-weight-medium);color:var(--color-text-default);margin-bottom:var(--spacing-xs)}.audit-change-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;border-bottom:1px solid var(--color-border-muted)}.audit-change-item:last-child{border-bottom:none}.audit-change-field{font-weight:var(--font-weight-medium);color:var(--color-text-default);min-width:100px}.audit-change-from{color:var(--color-danger);text-decoration:line-through}.audit-change-arrow{color:var(--color-text-muted)}.audit-change-to{color:var(--color-success)}.audit-item-expandable{cursor:pointer}.audit-expand-btn{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;padding:var(--spacing-xs) 0;margin-top:var(--spacing-xs)}.audit-expand-btn:hover{text-decoration:underline}.audit-meta{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border-muted);font-size:var(--font-size-xs);color:var(--color-text-muted)}.audit-user{font-weight:var(--font-weight-medium);color:var(--color-text-default)}.audit-time{font-size:var(--font-size-xs)}.filters-card{margin-bottom:var(--spacing-lg)}.filters-row{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:flex-end}.filters-row .form-group{flex:1;min-width:150px}.filter-actions{display:flex;gap:var(--spacing-sm);flex:none!important;min-width:auto!important}@media (max-width: 640px){.filters-row{flex-direction:column}.filters-row .form-group{width:100%}.filter-actions{width:100%;justify-content:flex-end}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) 0}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-muted)}.results-count{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-sm)}.page-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.image-upload{display:flex;flex-direction:column;gap:var(--spacing-sm)}.image-upload__input{display:none}.image-upload__area{position:relative;border:2px dashed var(--color-border-default);border-radius:var(--radius-lg);background-color:var(--color-bg-subtle);cursor:pointer;transition:border-color var(--transition-fast) var(--ease-default),background-color var(--transition-fast) var(--ease-default);overflow:hidden}.image-upload__area:hover{border-color:var(--color-primary);background-color:var(--color-primary-light)}.image-upload__area:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--focus-ring)}.image-upload__area--uploading{pointer-events:none;opacity:.7}.image-upload--sm .image-upload__area{width:80px;height:80px}.image-upload--md .image-upload__area{width:120px;height:120px}.image-upload--lg .image-upload__area{width:160px;height:160px}.image-upload__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);gap:var(--spacing-xs);padding:var(--spacing-md);text-align:center}.image-upload__placeholder span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.image-upload__hint{font-size:var(--font-size-xs)!important;color:var(--color-text-muted)!important;font-weight:var(--font-weight-normal)!important}.image-upload__preview{position:relative;width:100%;height:100%}.image-upload__preview img{width:100%;height:100%;object-fit:cover}.image-upload__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);background-color:#00000080;color:#fff;opacity:0;transition:opacity var(--transition-fast) var(--ease-default)}.image-upload__overlay span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.image-upload__preview:hover .image-upload__overlay{opacity:1}.image-upload__remove{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background-color:var(--color-error);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;opacity:0;transition:opacity var(--transition-fast) var(--ease-default);z-index:1}.image-upload__remove:hover{background-color:var(--color-error-dark)}.image-upload__preview:hover .image-upload__remove{opacity:1}.image-upload__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-primary);gap:var(--spacing-sm)}.image-upload__loading span{font-size:var(--font-size-sm)}.image-upload__spinner{animation:spin 1s linear infinite}.image-upload__error{color:var(--color-error);font-size:var(--font-size-sm)}.dashboard-page{max-width:800px;margin:0 auto}.pet-card-v2{background:var(--color-status-stable);border-radius:var(--radius-card);border-left:5px solid var(--color-border-stable);box-shadow:var(--shadow-warm-md);padding:var(--spacing-lg);transition:transform .15s ease,box-shadow .15s ease}.pet-card-v2:hover{transform:translateY(-2px);box-shadow:var(--shadow-warm-lg)}.pet-card-v2--overdue{background:var(--color-status-overdue);border-left-color:var(--color-border-overdue)}.pet-card-v2--urgent{background:var(--color-status-urgent);border-left-color:var(--color-border-urgent)}.pet-card-v2--stable{background:var(--color-status-stable);border-left-color:var(--color-border-stable)}.pet-card-v2__header{display:flex;align-items:center;gap:var(--spacing-md);text-decoration:none;color:inherit;padding-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:var(--spacing-md)}.pet-card-v2__header:hover{opacity:.9}.pet-card-v2__avatar{width:72px;height:72px;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--color-orange-100),var(--color-cream-200));display:flex;align-items:center;justify-content:center;border:3px solid white;box-shadow:0 2px 8px #0000001a}.pet-card-v2__avatar img{width:100%;height:100%;object-fit:cover}.pet-card-v2__avatar-placeholder{font-size:2rem}.pet-card-v2__info{flex:1;min-width:0}.pet-card-v2__name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-xs);color:var(--color-text)}.pet-card-v2__next-action{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pet-card-v2__weight-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:#fffc;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);flex-shrink:0}.pet-card-v2__alerts{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.pet-card-v2__alert{display:flex;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-warning-bg);color:var(--color-warning-text);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.pet-card-v2__alert svg{flex-shrink:0;margin-top:2px}.pet-card-v2__timeline{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pet-card-v2__section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(0,0,0,.06)}.pet-card-v2__empty{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-md);margin:0}.timeline-batch{background:#fff9;border-radius:var(--radius-lg);overflow:hidden}.timeline-batch--expanded{box-shadow:0 2px 8px #00000014}.timeline-batch__header{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#ffffff80;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s ease}.timeline-batch__header:hover:not(:disabled){background:#fffc}.timeline-batch__header:disabled{cursor:default}.timeline-batch__time-icon{font-size:1rem}.timeline-batch__time-range{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.timeline-batch__chevron{color:var(--color-text-muted);display:flex;align-items:center}.timeline-batch__items{padding:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.timeline-batch__details{padding:var(--spacing-sm) var(--spacing-md);background:#fff6;border-top:1px solid rgba(0,0,0,.04);display:flex;flex-direction:column;gap:var(--spacing-xs)}.timeline-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);background:#ffffff80;transition:background .15s ease}.timeline-item:hover{background:#fffc}.timeline-item--dose.timeline-item--overdue{background:#ef44441a}.timeline-item--dose.timeline-item--urgent{background:#f59e0b1a}.timeline-item--dose.timeline-item--soon{background:#f59e0b0d}.timeline-item__icon{font-size:1.1rem;flex-shrink:0}.timeline-item__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.timeline-item__name{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text)}.timeline-item__subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted)}.timeline-item__time{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0}.timeline-item-detail{display:flex;flex-direction:column;gap:2px;font-size:var(--font-size-sm)}.timeline-item-detail__label{font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.timeline-item-detail__text{color:var(--color-text);padding-left:var(--spacing-sm)}.dose-action-chips{display:flex;gap:var(--spacing-xs);flex-shrink:0}.dose-action-chip{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .15s ease}.dose-action-chip:disabled{opacity:.5;cursor:not-allowed}.dose-action-chip--taken{background:var(--color-chip-taken);color:var(--color-chip-taken-icon)}.dose-action-chip--taken:hover:not(:disabled){background:#bbf7d0;transform:scale(1.1)}.dose-action-chip--missed{background:var(--color-chip-missed);color:var(--color-chip-missed-icon)}.dose-action-chip--missed:hover:not(:disabled){background:#e5e7eb;transform:scale(1.1)}.later-items-chip-container{margin-top:var(--spacing-xs)}.later-items-chip{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#ffffff80;border:1px dashed rgba(0,0,0,.1);border-radius:var(--radius-lg);cursor:pointer;font-family:inherit;transition:all .15s ease}.later-items-chip:hover{background:#fffc;border-color:#0003}.later-items-chip__text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:left}.later-items-chip__chevron{color:var(--color-text-muted);display:flex;align-items:center}.later-items-chip__expanded{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:#fff9;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--spacing-xs)}.dashboard-page .page-header{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}@media (min-width: 640px){.dashboard-page .page-header{flex-direction:row;justify-content:space-between;align-items:center}}.dashboard-sort{display:flex;align-items:center;gap:var(--spacing-sm)}.dashboard-sort label{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap}.dashboard-sort .form-control{width:auto;min-width:140px}.dashboard-pet-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.pet-task-card__avatar-link{display:block;flex-shrink:0}.pet-task-card__info{flex:1;min-width:0}.pet-task-card__meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.pet-task-card-legacy{border-left:4px solid var(--color-primary)}.pet-task-header{display:flex;align-items:center;gap:var(--spacing-md);text-decoration:none;color:inherit;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-sm)}.pet-task-header:hover{opacity:.8}.pet-task-avatar{width:48px;height:48px;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0;background:var(--color-surface-secondary);display:flex;align-items:center;justify-content:center}.pet-task-avatar img{width:100%;height:100%;object-fit:cover}.pet-task-avatar-placeholder{font-size:1.5rem}.pet-task-info{flex:1;min-width:0}.pet-task-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0;color:var(--color-text)}.pet-task-weight{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-muted)}.pet-task-alerts{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.pet-task-alert{display:flex;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-warning-bg);color:var(--color-warning-text);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.pet-task-alert svg{flex-shrink:0;margin-top:2px}.pet-task-section{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.pet-task-section:first-of-type{border-top:none;padding-top:0}.pet-task-empty{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-md)}.pending-dose-item{display:flex;flex-direction:column;padding:var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-surface-secondary);margin-bottom:var(--spacing-xs)}.pending-dose-item:last-child{margin-bottom:0}.pending-dose-item.dose-overdue{background:var(--color-danger-bg)}.pending-dose-item.dose-urgent{background:var(--color-warning-bg)}.pending-dose-item.dose-normal{background:var(--color-surface-secondary)}.pending-dose-item.expanded{box-shadow:0 2px 8px #0000001a}.pending-dose-row{display:flex;flex-direction:column;gap:var(--spacing-xs)}@media (min-width: 480px){.pending-dose-row{flex-direction:row;align-items:center;justify-content:space-between}}.pending-dose-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0;background:none;border:none;padding:0;cursor:pointer;text-align:left;color:inherit;font-family:inherit}.pending-dose-info:hover{opacity:.8}.pending-dose-icon{font-size:1.25rem;flex-shrink:0}.pending-dose-details{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.pending-dose-name{font-weight:var(--font-weight-medium);color:var(--color-text)}.pending-dose-time{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-muted)}.pending-dose-relative{margin-left:var(--spacing-xs);font-style:italic}.pending-dose-info-icon{flex-shrink:0;color:var(--color-primary);opacity:.7}.pending-dose-expanded{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.dose-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.dose-detail-item{display:flex;flex-direction:column;gap:2px}.dose-detail-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.dose-detail-value{font-weight:var(--font-weight-medium);color:var(--color-text)}.dose-instructions{margin-bottom:var(--spacing-sm)}.dose-instructions-text{margin:var(--spacing-xs) 0 0;padding:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-sm);font-size:var(--font-size-sm);line-height:1.5;white-space:pre-wrap}.dose-edit-link{display:inline-flex;align-items:center;gap:4px;color:var(--color-primary);font-size:var(--font-size-sm);text-decoration:none}.dose-edit-link:hover{text-decoration:underline}.dose-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.dose-action-btn{display:inline-flex;align-items:center;gap:4px;padding:var(--spacing-xs) var(--spacing-sm);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s ease}.dose-action-btn:disabled{opacity:.5;cursor:not-allowed}.dose-action-btn--taken{background:var(--color-success);color:#fff}.dose-action-btn--taken:hover:not(:disabled){background:var(--color-success-dark)}.dose-action-btn--missed{background:var(--color-warning);color:var(--color-warning-text)}.dose-action-btn--missed:hover:not(:disabled){opacity:.9}.additional-doses-toggle{display:inline-flex;align-items:center;gap:4px;margin-top:var(--spacing-xs);padding:var(--spacing-xs) 0;background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer}.additional-doses-toggle:hover{text-decoration:underline}.additional-doses-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.recent-activity{background:var(--color-surface-tertiary);border-radius:var(--radius-sm);overflow:hidden}.recent-activity-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-sm);background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer}.recent-activity-header:hover{background:var(--color-surface-secondary)}.recent-activity-title{font-weight:var(--font-weight-medium)}.recent-activity-list{padding:0 var(--spacing-sm) var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.recent-dose-item{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xs);background:var(--color-surface)}.recent-dose-item--taken{border-left:2px solid var(--color-success)}.recent-dose-item--skipped,.recent-dose-item--missed{border-left:2px solid var(--color-warning)}.recent-dose-header{display:flex;align-items:center;gap:var(--spacing-xs)}.recent-dose-icon{display:flex;align-items:center}.recent-dose-icon .icon-success{color:var(--color-success)}.recent-dose-icon .icon-warning{color:var(--color-warning)}.recent-dose-medication{flex:1;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.recent-dose-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.recent-dose-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:2px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.recent-dose-notes{margin-top:var(--spacing-xs);padding-left:var(--spacing-sm)}.recent-dose-notes blockquote{margin:0;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-warning-bg);border-left:2px solid var(--color-warning);border-radius:var(--radius-xs);font-size:var(--font-size-sm);font-style:italic;color:var(--color-text)}.upcoming-appointments{display:flex;flex-direction:column;gap:var(--spacing-xs)}.upcoming-appointment-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.upcoming-appointment-icon{font-size:1.25rem;flex-shrink:0}.upcoming-appointment-details{flex:1;min-width:0}.upcoming-appointment-motivo{display:block;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.upcoming-appointment-vet{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted)}.upcoming-appointment-date{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0}.missed-dose-modal{max-width:480px}.missed-dose-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:var(--color-surface-secondary);border-radius:var(--radius-sm);text-align:center}.missed-dose-modal .form-help{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.missed-dose-modal .btn-warning{background:var(--color-warning);color:var(--color-warning-text)}.pet-list-card{cursor:pointer}.pet-list-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.pet-list-card__name-row{display:flex;align-items:center;gap:var(--spacing-sm)}.pet-list-card__appointment{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.pet-list-card__date-badge{display:inline-flex;align-items:center;gap:4px}.pet-list-card__date-badge svg{flex-shrink:0}.pet-list-card__description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pet-list-card__time-badge{display:inline-flex;align-items:center;gap:4px}.pet-list-card__time-badge svg{flex-shrink:0}.pet-list-card__meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.dashboard-pet-list--compact{display:flex;flex-direction:column;gap:var(--spacing-sm)}.dashboard-pet-list--compact .pet-list-card{padding:var(--spacing-sm) var(--spacing-md)}.pet-detail-panel{padding:var(--spacing-lg);height:100%;overflow-y:auto}.pet-detail-panel__header{display:flex;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-md)}.pet-detail-panel__info{flex:1;min-width:0}.pet-detail-panel__name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-xs);color:var(--color-text)}.pet-detail-panel__meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.pet-detail-panel__status-indicators{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.pet-detail-panel__status-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pet-detail-panel__status-item svg{flex-shrink:0;color:var(--color-primary)}.pet-detail-panel__link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-surface-secondary);color:var(--color-text-secondary);transition:all .15s ease}.pet-detail-panel__link:hover{background:var(--color-primary-light);color:var(--color-primary)}.pet-detail-panel__alerts{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.pet-detail-panel__quick-actions{margin-bottom:var(--spacing-md)}.pet-detail-panel__stats{margin-bottom:var(--spacing-lg)}.pet-detail-panel__section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--spacing-sm)}.pet-detail-panel__timeline{margin-bottom:var(--spacing-lg)}.pet-detail-panel__recent{padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.pet-detail__dose-content,.pet-detail__appointment-content{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.pet-detail__dose-content svg,.pet-detail__appointment-content svg{flex-shrink:0;color:var(--color-text-muted)}.status-card{position:relative;background:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-normal) var(--ease-default),border-color var(--transition-normal) var(--ease-default)}.status-card--success{background:var(--color-status-success-bg)}.status-card--warning{background:var(--color-status-warning-bg)}.status-card--error{background:var(--color-status-error-bg)}.status-card--info{background:var(--color-status-info-bg)}.status-card--neutral{background:var(--color-status-neutral-bg)}.status-card--stripe{border-left:6px solid var(--color-gray-300)}.status-card--stripe.status-card--neutral{border-left-color:var(--color-gray-300)}.status-card--stripe.status-card--success{border-left-color:var(--color-status-success-border)}.status-card--stripe.status-card--warning{border-left-color:var(--color-status-warning-border)}.status-card--stripe.status-card--error{border-left-color:var(--color-status-error-border)}.status-card--stripe.status-card--info{border-left-color:var(--color-status-info-border)}.status-card--stripe-icon{display:flex;flex-direction:row;border-left:none}.status-card__stripe{display:flex;flex-direction:column;align-items:center;width:48px;min-width:48px;padding:var(--spacing-3) var(--spacing-2);background:var(--color-gray-200);border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.status-card__stripe-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:#fff;opacity:.9}.status-card__stripe-icon svg{width:24px;height:24px}.status-card__body{flex:1;min-width:0}.status-card__stripe--perro{background:var(--color-primary, #f97316)!important}.status-card__stripe--gato{background:var(--color-status-info-border, #0ea5e9)!important}.status-card__stripe--otro{background:var(--color-gray-400, #9ca3af)!important}.status-card--expandable,.status-card--selectable{cursor:pointer}.status-card--expandable:hover,.status-card--selectable:hover{box-shadow:var(--shadow-md)}.status-card--expandable:focus,.status-card--selectable:focus{outline:none;box-shadow:var(--focus-ring)}.status-card--selected{border:2px solid var(--color-primary);box-shadow:var(--shadow-md)}.status-card__header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4)}.status-card__title{flex:1;margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.status-card__subtitle{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.status-card__expand-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default),color var(--transition-fast) var(--ease-default)}.status-card__expand-btn:hover{background:var(--color-bg-muted);color:var(--color-text-primary)}.status-card__expand-btn:focus{outline:none;box-shadow:var(--focus-ring)}.status-card:not(.status-card--expandable) .status-card__expand-btn{display:none}.status-card__content{padding:0 var(--spacing-4) var(--spacing-4);animation:statusCardContentEnter var(--transition-normal) var(--ease-out)}@keyframes statusCardContentEnter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.status-card__actions{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);border-top:1px solid var(--color-border-default);background:var(--color-bg-subtle)}.avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-full);background:var(--color-cream-100);overflow:visible}.avatar--sm{width:32px;height:32px;font-size:var(--font-size-sm)}.avatar--md{width:48px;height:48px;font-size:var(--font-size-lg)}.avatar--lg{width:64px;height:64px;font-size:var(--font-size-2xl)}.avatar__image{width:100%;height:100%;object-fit:cover;border-radius:inherit}.avatar__fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;-webkit-user-select:none;user-select:none}.avatar--ring{box-shadow:0 0 0 2px var(--color-status-neutral-border)}.avatar--ring-success{box-shadow:0 0 0 2px var(--color-status-success-border)}.avatar--ring-warning{box-shadow:0 0 0 2px var(--color-status-warning-border)}.avatar--ring-error{box-shadow:0 0 0 2px var(--color-status-error-border)}.avatar--ring-info{box-shadow:0 0 0 2px var(--color-status-info-border)}.avatar__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-status-error-border);border-radius:var(--radius-full);border:2px solid var(--color-bg-surface);line-height:1}.avatar--lg .avatar__badge{min-width:22px;height:22px;font-size:12px;top:-2px;right:-2px}.badge{display:inline-flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;white-space:nowrap}.badge--status{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.badge--status.badge--success{background:var(--color-status-success-bg);color:var(--color-status-success-text)}.badge--status.badge--warning{background:var(--color-status-warning-bg);color:var(--color-status-warning-text)}.badge--status.badge--error{background:var(--color-status-error-bg);color:var(--color-status-error-text)}.badge--status.badge--info{background:var(--color-status-info-bg);color:var(--color-status-info-text)}.badge--status.badge--neutral{background:var(--color-status-neutral-bg);color:var(--color-status-neutral-text)}.badge--counter{min-width:20px;height:20px;padding:0 var(--spacing-1);border-radius:var(--radius-full);background:var(--color-status-error-border);color:#fff;font-weight:var(--font-weight-semibold)}.badge--pill{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);background:var(--color-gray-100);color:var(--color-gray-600)}.badge--time{padding:var(--spacing-1) var(--spacing-2_5);border-radius:var(--radius-full);font-weight:var(--font-weight-semibold)}.badge--time.badge--success{background:var(--color-status-success-bg);color:var(--color-status-success-text)}.badge--time.badge--warning{background:var(--color-status-warning-bg);color:var(--color-status-warning-text)}.badge--time.badge--error{background:var(--color-status-error-bg);color:var(--color-status-error-text)}.badge--time.badge--info{background:var(--color-status-info-bg);color:var(--color-status-info-text)}.badge--time.badge--neutral{background:var(--color-gray-100);color:var(--color-gray-700)}.action-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);font-family:inherit;font-weight:var(--font-weight-medium);text-decoration:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default),color var(--transition-fast) var(--ease-default),box-shadow var(--transition-fast) var(--ease-default),opacity var(--transition-fast) var(--ease-default)}.action-button--sm{height:28px;padding:0 var(--spacing-2_5);font-size:var(--font-size-xs);gap:var(--spacing-1)}.action-button--md{height:36px;padding:0 var(--spacing-4);font-size:var(--font-size-sm)}.action-button--lg{height:44px;padding:0 var(--spacing-5);font-size:var(--font-size-base)}.action-button--primary{background:var(--color-primary);color:#fff}.action-button--primary:hover:not(:disabled){background:var(--color-primary-hover)}.action-button--primary:active:not(:disabled){background:var(--color-primary-active)}.action-button--secondary{background:var(--color-bg-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-default)}.action-button--secondary:hover:not(:disabled){background:var(--color-bg-muted);color:var(--color-text-primary)}.action-button--danger{background:var(--color-status-error-border);color:#fff}.action-button--danger:hover:not(:disabled){background:var(--color-error-dark)}.action-button--ghost{background:transparent;color:var(--color-text-secondary)}.action-button--ghost:hover:not(:disabled){background:var(--color-bg-muted);color:var(--color-text-primary)}.action-button:focus{outline:none;box-shadow:var(--focus-ring)}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-button--loading{cursor:wait}.action-button__spinner{animation:actionButtonSpin 1s linear infinite}@keyframes actionButtonSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.timeline-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.timeline-list__empty{text-align:center;color:var(--color-text-muted);padding:var(--spacing-6)}.timeline-group{display:flex;flex-direction:column}.timeline-group__header{padding:var(--spacing-2) 0;border-bottom:1px solid var(--color-border-default);margin-bottom:var(--spacing-2)}.timeline-group__time{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.timeline-group__items{display:flex;flex-direction:column;gap:var(--spacing-2)}.timeline-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-surface);border-radius:var(--radius-md);transition:background-color var(--transition-fast) var(--ease-default)}.timeline-item:hover{background:var(--color-bg-subtle)}.timeline-item__icon{flex-shrink:0;color:var(--color-text-muted)}.timeline-item__icon--completed{color:var(--color-status-success-border)}.timeline-item__icon--missed{color:var(--color-status-error-border)}.timeline-item__icon--pending{color:var(--color-status-warning-border)}.timeline-item__content{flex:1;min-width:0;font-size:var(--font-size-sm);color:var(--color-text-primary)}.timeline-item--completed .timeline-item__content{color:var(--color-text-muted);text-decoration:line-through}.timeline-item__actions{display:flex;gap:var(--spacing-2);flex-shrink:0}@media (max-width: 480px){.timeline-item{flex-wrap:wrap}.timeline-item__content{flex-basis:calc(100% - 40px)}.timeline-item__actions{flex-basis:100%;margin-top:var(--spacing-2);justify-content:flex-end}}.stat-grid{display:grid;gap:var(--spacing-2)}.stat-grid--cols-2{grid-template-columns:repeat(2,1fr)}.stat-grid--cols-3{grid-template-columns:repeat(3,1fr)}.stat-grid--cols-4{grid-template-columns:repeat(4,1fr)}.stat-grid__item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);text-align:center}.stat-grid__label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.stat-grid__value{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.stat-grid__value--success{color:var(--color-status-success-text)}.stat-grid__value--warning{color:var(--color-status-warning-text)}.stat-grid__value--error{color:var(--color-status-error-text)}.stat-grid__value--info{color:var(--color-status-info-text)}.quick-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}@media (max-width: 400px){.quick-actions{flex-direction:column}.quick-actions>*{width:100%}}.alert-banner{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md)}.alert-banner--success{background:var(--color-status-success-bg);color:var(--color-status-success-text)}.alert-banner--warning{background:var(--color-status-warning-bg);color:var(--color-status-warning-text)}.alert-banner--error{background:var(--color-status-error-bg);color:var(--color-status-error-text)}.alert-banner--info{background:var(--color-status-info-bg);color:var(--color-status-info-text)}.alert-banner--neutral{background:var(--color-status-neutral-bg);color:var(--color-status-neutral-text)}.alert-banner__icon{flex-shrink:0;display:flex;align-items:center}.alert-banner__content{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.alert-banner__action{flex-shrink:0}.alert-banner__dismiss{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:inherit;opacity:.7;cursor:pointer;transition:opacity var(--transition-fast) var(--ease-default),background-color var(--transition-fast) var(--ease-default)}.alert-banner__dismiss:hover{opacity:1;background:#0000001a}.alert-banner__dismiss:focus{outline:none;box-shadow:var(--focus-ring)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;height:64px;background:var(--color-bg-surface);border-top:1px solid var(--color-border-default);padding-bottom:env(safe-area-inset-bottom);z-index:var(--z-fixed)}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-1);padding:var(--spacing-2);text-decoration:none;color:var(--color-text-muted);transition:color var(--transition-fast) var(--ease-default)}.bottom-nav__item:hover{color:var(--color-text-secondary)}.bottom-nav__item--active{color:var(--color-primary)}.bottom-nav__icon{flex-shrink:0}.bottom-nav__label{font-size:10px;font-weight:var(--font-weight-medium)}.sidebar{display:flex;flex-direction:column;width:240px;height:100vh;position:fixed;left:0;top:0;background:var(--color-primary);color:#fff;z-index:var(--z-fixed)}.sidebar__header{padding:var(--spacing-5)}.sidebar__logo{display:flex;align-items:center;gap:var(--spacing-2);text-decoration:none;color:#fff}.sidebar__logo-icon{width:32px;height:32px;filter:brightness(0) invert(1)}.sidebar__logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.sidebar__nav{flex:1;display:flex;flex-direction:column;gap:var(--spacing-1);padding:var(--spacing-2)}.sidebar__nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);text-decoration:none;color:#fffc;font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast) var(--ease-default),color var(--transition-fast) var(--ease-default)}.sidebar__nav-item:hover{background:#ffffff1a;color:#fff}.sidebar__nav-item--active,.sidebar__nav-item--active:hover{background:#fff;color:var(--color-primary)}.sidebar__footer{padding:var(--spacing-4);border-top:1px solid rgba(255,255,255,.2)}.sidebar__user{display:block;font-size:var(--font-size-sm);color:#ffffffb3;margin-bottom:var(--spacing-2)}.sidebar__logout{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);background:transparent;border:none;border-radius:var(--radius-md);color:#fffc;font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default)}.sidebar__logout:hover{background:#ffffff1a}.mobile-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--color-bg-body)}.mobile-layout__header{position:sticky;top:0;display:flex;align-items:center;gap:var(--spacing-3);height:56px;padding:0 var(--spacing-4);background:var(--color-primary);color:#fff;z-index:var(--z-sticky)}.mobile-layout__logo{display:flex;align-items:center;gap:var(--spacing-2);text-decoration:none;color:#fff}.mobile-layout__logo-icon{width:28px;height:28px;filter:brightness(0) invert(1)}.mobile-layout__logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.mobile-layout__title{flex:1;margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-align:center}.mobile-layout__actions{display:flex;align-items:center;gap:var(--spacing-2)}.mobile-layout__content{flex:1;padding:var(--spacing-4);padding-bottom:calc(var(--spacing-4) + 64px + env(safe-area-inset-bottom))}.desktop-layout{display:flex;min-height:100vh;background:var(--color-bg-body)}.desktop-layout__main{flex:1;display:flex;flex-direction:column;margin-left:240px}.desktop-layout__header{position:sticky;top:0;height:56px;background:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default);z-index:var(--z-sticky)}.desktop-layout__header-content{display:flex;align-items:center;justify-content:flex-end;height:100%;padding:0 var(--spacing-6)}.desktop-layout__user-area{display:flex;align-items:center;gap:var(--spacing-4)}.desktop-layout__user-name{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.desktop-layout__content{flex:1;padding:var(--spacing-6);max-width:1400px}.master-detail{display:flex;gap:var(--spacing-6);min-height:0}.master-detail__list{width:360px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-3);overflow-y:auto;max-height:calc(100vh - 120px)}.master-detail__detail{flex:1;min-width:0;background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-5);box-shadow:var(--shadow-sm)}.master-detail__empty{display:flex;align-items:center;justify-content:center;height:300px;color:var(--color-text-muted);font-size:var(--font-size-sm)}.expandable-card-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.hidden-mobile{display:none}@media (min-width: 768px){.hidden-mobile{display:block}}@media (min-width: 768px){.hidden-desktop{display:none}}.show-mobile{display:block}@media (min-width: 768px){.show-mobile{display:none}}.show-desktop{display:none}@media (min-width: 768px){.show-desktop{display:block}}.stack-to-row{display:flex;flex-direction:column;gap:var(--spacing-4)}@media (min-width: 768px){.stack-to-row{flex-direction:row}}.row-to-stack{display:flex;flex-direction:row;gap:var(--spacing-4)}@media (min-width: 768px){.row-to-stack{flex-direction:column}}.grid-1-to-2{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}@media (min-width: 768px){.grid-1-to-2{grid-template-columns:repeat(2,1fr)}}.grid-1-to-3{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}@media (min-width: 768px){.grid-1-to-3{grid-template-columns:repeat(3,1fr)}}.grid-2-to-4{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}@media (min-width: 768px){.grid-2-to-4{grid-template-columns:repeat(4,1fr)}}
