: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}: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;--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-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);--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{display:flex;justify-content:space-between;align-items:center;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)}.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);border-left:2px solid var(--color-border-default);margin-left:var(--spacing-md)}.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)}.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)}.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}.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)}
