:root{--font-family-base:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";--font-size-xs:0.75rem;--font-size-sm:0.8125rem;--font-size-base:0.875rem;--font-size-md:0.9375rem;--font-size-lg:1rem;--font-size-xl:1.125rem;--font-size-2xl:1.25rem;--font-size-3xl:1.5rem;--font-size-4xl:1.875rem;--font-size-5xl:2.25rem;--line-height-tight:1.25;--line-height-snug:1.375;--line-height-normal:1.5;--line-height-relaxed:1.625;--line-height-loose:2;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--letter-spacing-tight:-0.025em;--letter-spacing-normal:0;--letter-spacing-wide:0.025em;--text-primary:var(--tupa-text-primary,#fff);--text-secondary:var(--tupa-text-secondary,#ffffffb3);--text-tertiary:var(--tupa-text-tertiary,#ffffff80);--text-muted:var(--tupa-text-muted,#ffffff4d);--text-accent:var(--tupa-orange,#ff8d23);--text-link:var(--tupa-purple,#7b3fb1);--text-error:#ff4d4d;--text-success:#4ade80}@media (min-width:768px){:root{--font-size-base:0.9375rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem}}body{font-size:.875rem;font-size:var(--font-size-base);letter-spacing:0;letter-spacing:var(--letter-spacing-normal);line-height:1.5;line-height:var(--line-height-normal)}.heading-1,.heading-2,.heading-3,.heading-4,.heading-5,.heading-6,body,h1,h2,h3,h4,h5,h6{color:#fff;color:var(--text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;font-family:var(--font-family-base)}.heading-1,.heading-2,.heading-3,.heading-4,.heading-5,.heading-6,h1,h2,h3,h4,h5,h6{font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.25;line-height:var(--line-height-tight);margin:0}.heading-1,h1{font-size:1.5rem;font-size:var(--font-size-3xl);font-weight:700;font-weight:var(--font-weight-bold);letter-spacing:-.025em;letter-spacing:var(--letter-spacing-tight)}.heading-2,h2{font-size:1.25rem;font-size:var(--font-size-2xl)}.heading-2,.heading-3,h2,h3{font-weight:600;font-weight:var(--font-weight-semibold)}.heading-3,h3{font-size:1.125rem;font-size:var(--font-size-xl)}.heading-4,h4{font-size:1rem;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold)}.heading-5,h5{font-size:.9375rem;font-size:var(--font-size-md)}.heading-5,.heading-6,h5,h6{font-weight:500;font-weight:var(--font-weight-medium)}.heading-6,.text-base,h6{font-size:.875rem;font-size:var(--font-size-base)}.text-base,.text-sm{line-height:1.5;line-height:var(--line-height-normal)}.text-sm{font-size:.8125rem;font-size:var(--font-size-sm)}.text-xs{font-size:.75rem;font-size:var(--font-size-xs)}.text-lg,.text-xs{line-height:1.5;line-height:var(--line-height-normal)}.text-lg{font-size:1rem;font-size:var(--font-size-lg)}.text-xl{font-size:1.125rem;font-size:var(--font-size-xl);line-height:1.5;line-height:var(--line-height-normal)}.font-normal{font-weight:400;font-weight:var(--font-weight-normal)}.font-medium{font-weight:500;font-weight:var(--font-weight-medium)}.font-semibold{font-weight:600;font-weight:var(--font-weight-semibold)}.font-bold{font-weight:700;font-weight:var(--font-weight-bold)}.leading-tight{line-height:1.25;line-height:var(--line-height-tight)}.leading-snug{line-height:1.375;line-height:var(--line-height-snug)}.leading-normal{line-height:1.5;line-height:var(--line-height-normal)}.leading-relaxed{line-height:1.625;line-height:var(--line-height-relaxed)}.leading-loose{line-height:2;line-height:var(--line-height-loose)}.text-primary{color:#fff;color:var(--text-primary)}.text-secondary{color:#ffffffb3;color:var(--text-secondary)}.text-tertiary{color:#ffffff80;color:var(--text-tertiary)}.text-muted{color:#ffffff4d;color:var(--text-muted)}.text-accent{color:#ff8d23;color:var(--text-accent)}.text-link{color:#7b3fb1;color:var(--text-link)}.text-error{color:#ff4d4d;color:var(--text-error)}.text-success{color:#4ade80;color:var(--text-success)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-italic{font-style:italic}.text-underline{text-decoration:underline}.text-no-underline{text-decoration:none}.label{color:#fff;color:var(--text-primary);display:block;font-size:.875rem;font-size:var(--font-size-base);margin-bottom:.25rem}.label,.label-sm{font-weight:500;font-weight:var(--font-weight-medium);line-height:1.5;line-height:var(--line-height-normal)}.label-sm{color:#ffffffb3;color:var(--text-secondary);font-size:.8125rem;font-size:var(--font-size-sm)}.section-header{color:#ff8d23;color:var(--text-accent);font-size:1.125rem;font-size:var(--font-size-xl);font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.25;line-height:var(--line-height-tight);margin:0 0 .75rem}.section-subheader{color:#ffffff80;color:var(--text-tertiary);font-size:.875rem;font-size:var(--font-size-base);font-weight:400;font-weight:var(--font-weight-normal);line-height:1.625;line-height:var(--line-height-relaxed);margin:0 0 1rem}.card-title{color:#fff;color:var(--text-primary);font-size:1rem;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.375;line-height:var(--line-height-snug);margin:0 0 .5rem}.card-description{color:#ffffffb3;color:var(--text-secondary);font-size:.875rem;font-size:var(--font-size-base);line-height:1.625;line-height:var(--line-height-relaxed);margin:0}.card-meta{color:#ffffff4d;color:var(--text-muted);font-size:.8125rem;font-size:var(--font-size-sm);line-height:1.5;line-height:var(--line-height-normal);margin:0}.button-text{font-size:.875rem;font-size:var(--font-size-base);letter-spacing:0;letter-spacing:var(--letter-spacing-normal)}.button-text,.button-text-sm{font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.25;line-height:var(--line-height-tight)}.button-text-sm{font-size:.8125rem;font-size:var(--font-size-sm)}.button-text-lg{font-size:1rem;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.25;line-height:var(--line-height-tight)}.with-emoji{gap:.5rem}.emoji,.with-emoji{align-items:center;display:inline-flex}.emoji{font-size:1.1em;line-height:1;vertical-align:middle}.heading-1 .emoji,.heading-2 .emoji,.heading-3 .emoji,.heading-4 .emoji,.heading-5 .emoji,.heading-6 .emoji,.section-header .emoji,h1 .emoji,h2 .emoji,h3 .emoji,h4 .emoji,h5 .emoji,h6 .emoji{font-size:1em;margin:0;vertical-align:middle}.breed-content{word-wrap:break-word;color:#fff;color:var(--text-primary);font-size:.875rem;font-size:var(--font-size-base);line-height:1.375;line-height:var(--line-height-snug);white-space:pre-wrap}.breed-content h1,.breed-content h2,.breed-content h3{align-items:center;display:flex;font-size:.9375rem;font-size:var(--font-size-md);font-weight:600;font-weight:var(--font-weight-semibold);gap:.375rem;line-height:1.25;line-height:var(--line-height-tight);margin:.75rem 0 .375rem}.breed-content h1:first-child,.breed-content h2:first-child,.breed-content h3:first-child{margin-top:0}.breed-content p{margin:.5rem 0}.breed-content ul{margin:.5rem 0;padding-left:1.25rem}.breed-content li{margin:.25rem 0}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.5rem}.mb-6{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.5rem}.mt-6{margin-top:2rem}@media (max-width:767px){.heading-1,h1{font-size:1.25rem;font-size:var(--font-size-2xl)}.heading-2,h2{font-size:1.125rem;font-size:var(--font-size-xl)}.section-header{font-size:1rem;font-size:var(--font-size-lg)}}@media print{body{color:#000;font-size:12pt;line-height:1.5}h1{font-size:20pt}h2{font-size:18pt}h3{font-size:16pt}h4{font-size:14pt}h5,h6{font-size:12pt}}:root{--tupa-coral:#f4a261;--tupa-teal:#2a9d8f;--tupa-sand:#e9c46a;--tupa-terracotta:#e76f51;--tupa-bg-primary:#12151b;--tupa-bg-secondary:#1c212a;--tupa-bg-elevated:#232b36;--tupa-surface-dark:#1c212af2;--tupa-surface-glass:#232b36e0;--tupa-surface-overlay:#2a9d8f1f;--tupa-text-primary:#f7f9fc;--tupa-text-secondary:#f7f9fcd1;--tupa-text-tertiary:#f7f9fc9e;--tupa-text-muted:#f7f9fc70;--tupa-text-accent:#ffd08b;--tupa-status-success:#22c55e;--tupa-status-success-surface:#22c55e29;--tupa-status-info:#38bdf8;--tupa-status-info-surface:#38bdf829;--tupa-status-warning:#f59e0b;--tupa-status-warning-surface:#f59e0b29;--tupa-status-warning-text:#111827;--tupa-status-error:#ef4444;--tupa-status-error-surface:#ef444429;--tupa-status-error-text:#fecaca;--tupa-gradient-primary:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);--tupa-gradient-secondary:linear-gradient(90deg,#2a9d8f,#f4a261);--tupa-gradient-accent:linear-gradient(180deg,#f4a261,#e76f51);--tupa-gradient-bg:linear-gradient(135deg,#12151b,#1c212a 50%,#12151b);--tupa-border-subtle-colour:#8899b142;--tupa-border-strong-colour:#8899b173;--tupa-border-subtle:1px solid var(--tupa-border-subtle-colour);--tupa-border-medium:1px solid var(--tupa-border-strong-colour);--tupa-border-bright:1px solid #f4a2618c;--tupa-glow-coral:0 0 12px #f4a26159,0 0 24px #f4a26133;--tupa-glow-teal:0 0 12px #2a9d8f59,0 0 24px #2a9d8f33;--tupa-glow-sand:0 0 12px #e9c46a59,0 0 24px #e9c46a33;--tupa-glow-purple:0 0 12px #506eff33;--tupa-glow-violet:0 0 12px #7f5af033;--tupa-glow-orange:0 0 12px #f4a26140;--tupa-glow-gradient:0 0 16px #f4a26147,0 0 32px #2a9d8f24;--tupa-radius-sm:10px;--tupa-radius-md:14px;--tupa-radius-lg:18px;--tupa-radius-xl:24px;--tupa-radius-full:999px;--tupa-shadow-sm:0 2px 8px #03081459;--tupa-shadow-md:0 6px 18px #03081466;--tupa-shadow-lg:0 12px 32px #03081475;--tupa-shadow-glow:0 6px 20px #f4a26138;--space-xs:0.375rem;--space-sm:0.5rem;--space-md:0.75rem;--space-lg:1rem;--space-xl:1.5rem;--tupa-transition-fast:0.16s ease;--tupa-transition-normal:0.24s ease;--tupa-transition-slow:0.34s ease;--tupa-focus-ring:2px solid #7dd3fc;--tupa-sticky-actions-bg:#151b24eb;--tupa-orange:#f4a261;--tupa-purple:#2a9d8f;--tupa-violet:#2a9d8f}.tupa-bg-primary{background:#12151b;background:var(--tupa-bg-primary)}.tupa-bg-secondary{background:#1c212a;background:var(--tupa-bg-secondary)}.tupa-bg-gradient{background:linear-gradient(135deg,#12151b,#1c212a 50%,#12151b);background:var(--tupa-gradient-bg)}.tupa-bg-gradient-primary{background:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);background:var(--tupa-gradient-primary)}.tupa-surface-glass{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#232b36e0;background:var(--tupa-surface-glass)}.tupa-text-primary{color:#f7f9fc;color:var(--tupa-text-primary)}.tupa-text-secondary{color:#f7f9fcd1;color:var(--tupa-text-secondary)}.tupa-text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);background:var(--tupa-gradient-primary);-webkit-background-clip:text;background-clip:text}.tupa-border-glow{border:1px solid #8899b173;border:var(--tupa-border-medium);box-shadow:0 0 12px #506eff33;box-shadow:var(--tupa-glow-purple)}.tupa-border-gradient{background:#1c212a;background:var(--tupa-bg-secondary);border-radius:14px;border-radius:var(--tupa-radius-md);position:relative}.tupa-border-gradient:before{background:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);background:var(--tupa-gradient-primary);border-radius:inherit;content:"";inset:-1px;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none;position:absolute}.tupa-glow-violet{box-shadow:0 0 12px #7f5af033;box-shadow:var(--tupa-glow-violet)}.tupa-glow-purple{box-shadow:0 0 12px #506eff33;box-shadow:var(--tupa-glow-purple)}.tupa-glow-orange{box-shadow:0 0 12px #f4a26140;box-shadow:var(--tupa-glow-orange)}.tupa-glow-gradient{box-shadow:0 0 16px #f4a26147,0 0 32px #2a9d8f24;box-shadow:var(--tupa-glow-gradient)}.tupa-hover-glow{transition:box-shadow .24s ease;transition:box-shadow var(--tupa-transition-normal)}.tupa-hover-glow:hover{box-shadow:0 0 16px #f4a26147,0 0 32px #2a9d8f24;box-shadow:var(--tupa-glow-gradient)}.tupa-card{background:#232b36e0;background:var(--tupa-surface-glass);border:1px solid #8899b142;border:var(--tupa-border-subtle);border-radius:14px;border-radius:var(--tupa-radius-md);box-shadow:0 6px 18px #03081466;box-shadow:var(--tupa-shadow-md);padding:1.5rem;transition:all .24s ease;transition:all var(--tupa-transition-normal)}.tupa-card:hover{border-color:#7b3fb199;box-shadow:0 6px 20px #f4a26138;box-shadow:var(--tupa-shadow-glow)}.tupa-button{border:none;border-radius:14px;border-radius:var(--tupa-radius-md);cursor:pointer;font-weight:600;outline:none;padding:.75rem 1.5rem;transition:all .24s ease;transition:all var(--tupa-transition-normal)}.tupa-button-primary{background:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);background:var(--tupa-gradient-primary);box-shadow:0 0 16px #f4a26147,0 0 32px #2a9d8f24;box-shadow:var(--tupa-glow-gradient);color:#f7f9fc;color:var(--tupa-text-primary)}.tupa-button-primary:hover{box-shadow:0 0 30px #7b3fb199,0 0 50px #ff8d234d;transform:translateY(-2px)}.tupa-button-secondary{background:#0000;border:1px solid #8899b173;border:var(--tupa-border-medium);color:#f7f9fc;color:var(--tupa-text-primary)}.tupa-button-secondary:hover{background:#2a9d8f1f;background:var(--tupa-surface-overlay);border-color:#ff8d2399;box-shadow:0 0 12px #f4a26140;box-shadow:var(--tupa-glow-orange)}.tupa-input{background:#232b36e0;background:var(--tupa-surface-glass);border:1px solid #8899b142;border:var(--tupa-border-subtle);border-radius:10px;border-radius:var(--tupa-radius-sm);color:#f7f9fc;color:var(--tupa-text-primary);outline:none;padding:.75rem 1rem;transition:all .24s ease;transition:all var(--tupa-transition-normal)}.tupa-input:focus{border-color:#7b3fb199;box-shadow:0 0 12px #506eff33;box-shadow:var(--tupa-glow-purple)}.tupa-input::placeholder{color:#f7f9fc70;color:var(--tupa-text-muted)}.tupa-navbar{align-items:center;background:#232b36e0;background:var(--tupa-surface-glass);border-bottom:1px solid #8899b142;border-bottom:var(--tupa-border-subtle);box-shadow:0 6px 18px #03081466;box-shadow:var(--tupa-shadow-md);display:flex;justify-content:space-between;padding:1rem 1.5rem}.tupa-accent-line{background:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);background:var(--tupa-gradient-primary);box-shadow:0 0 16px #f4a26147,0 0 32px #2a9d8f24;box-shadow:var(--tupa-glow-gradient);height:2px;margin:1rem 0}@keyframes gradient-shift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.tupa-text-gradient-animated{-webkit-text-fill-color:#0000;animation:gradient-shift 3s ease infinite;background:linear-gradient(90deg,#5a4d8c,#7b3fb1,#ff8d23,#7b3fb1,#5a4d8c);-webkit-background-clip:text;background-clip:text;background-size:200% auto}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #7b3fb14d}50%{box-shadow:0 0 20px #ff8d2380,0 0 40px #7b3fb14d}}.tupa-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}:focus-visible{outline:2px solid #7dd3fc;outline:var(--tupa-focus-ring);outline-offset:2px}:root{--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px}html{font-size:clamp(14px,3.5vw,16px)}h1{font-size:clamp(1.5rem,5vw,2.25rem)}h2{font-size:clamp(1.25rem,4vw,1.75rem)}h3{font-size:clamp(1.1rem,3vw,1.375rem)}h4{font-size:clamp(1rem,2.5vw,1.125rem)}.tap-target,[role=button],a,button{min-height:44px;min-width:44px}a+a,a+button,button+a,button+button{margin-left:8px;margin-left:var(--space-sm)}input,select,textarea{font-size:16px}.safe-area-container{padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}@media (max-width:480px){.responsive-table table,table.responsive-table{display:block;width:100%}.responsive-table table thead,table.responsive-table thead{display:none}.responsive-table table tbody,.responsive-table table tr,table.responsive-table tbody,table.responsive-table tr{display:block;width:100%}.responsive-table table td,table.responsive-table td{border-bottom:1px solid #ffffff1a;border-bottom:var(--tupa-border-subtle,1px solid #ffffff1a);display:flex;justify-content:space-between;padding:8px 16px;padding:var(--space-sm) var(--space-md)}.responsive-table table td:before,table.responsive-table td:before{color:var(--tupa-text-secondary);content:attr(data-label);flex-shrink:0;font-weight:600;margin-right:8px;margin-right:var(--space-sm)}.modal,.tupa-modal,[role=dialog]{border-radius:20px 20px 0 0!important;border-radius:var(--tupa-radius-lg,20px) var(--tupa-radius-lg,20px) 0 0!important;bottom:0!important;left:0!important;margin:0!important;max-height:90dvh!important;max-width:100%!important;overflow-y:auto!important;padding-bottom:calc(24px + env(safe-area-inset-bottom, 0px))!important;padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom, 0px))!important;position:fixed!important;right:0!important;top:auto!important;width:100%!important}.mobile-fluid{max-width:100%!important}}@media (min-width:481px){html{font-size:clamp(14px,2.5vw,16px)}.responsive-grid{grid-template-columns:repeat(2,1fr)}.modal,.tupa-modal,[role=dialog]{border-radius:28px!important;border-radius:var(--tupa-radius-xl,28px)!important;bottom:auto!important;left:50%!important;max-height:90dvh!important;max-width:min(90vw,540px)!important;position:fixed!important;right:auto!important;top:50%!important;transform:translate(-50%,-50%)!important;width:min(90vw,540px)!important}}@media (min-width:769px){html{font-size:15px}.responsive-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1025px){html{font-size:16px}.responsive-grid{grid-template-columns:repeat(4,1fr)}}@media (hover:none) and (pointer:coarse){.tap-target,[role=button],a,button{min-height:48px;min-width:48px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.mobile-dashboard{padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px))}@media (max-width:768px){.mobile-dashboard .health-insights-grid,.mobile-dashboard [role=toolbar]{grid-template-columns:repeat(2,1fr)!important}}.theme-playful{--tupa-bg-primary:#fcfaf7;--tupa-bg-secondary:#f4efe8;--tupa-bg-elevated:#fff;--tupa-coral:#f4a261;--tupa-teal:#2a9d8f;--tupa-sand:#e9c46a;--tupa-terracotta:#e76f51;--tupa-surface-dark:#f5efe9f2;--tupa-surface-glass:#ffffffeb;--tupa-surface-overlay:#2a9d8f14;--tupa-text-primary:#1f2937;--tupa-text-secondary:#1f2937c7;--tupa-text-tertiary:#1f29379e;--tupa-text-muted:#1f293773;--tupa-text-accent:#9a3412;--tupa-status-success:#16a34a;--tupa-status-success-surface:#16a34a1f;--tupa-status-info:#0284c7;--tupa-status-info-surface:#0284c71f;--tupa-status-warning:#d97706;--tupa-status-warning-surface:#d977061f;--tupa-status-warning-text:#111827;--tupa-status-error:#dc2626;--tupa-status-error-surface:#dc26261f;--tupa-status-error-text:#991b1b;--tupa-gradient-primary:linear-gradient(135deg,#f4a261,#e76f51 50%,#e9c46a);--tupa-gradient-secondary:linear-gradient(90deg,#2a9d8f,#f4a261);--tupa-gradient-accent:linear-gradient(180deg,#f4a261,#e76f51);--tupa-gradient-bg:linear-gradient(135deg,#fcfaf7,#f4efe8 50%,#fcfaf7);--tupa-border-subtle-colour:#78829638;--tupa-border-strong-colour:#78829661;--tupa-border-subtle:1px solid var(--tupa-border-subtle-colour);--tupa-border-medium:1px solid var(--tupa-border-strong-colour);--tupa-border-bright:1px solid #f4a26180;--tupa-glow-coral:0 0 12px #f4a2613d,0 0 24px #f4a26121;--tupa-glow-teal:0 0 12px #2a9d8f3d,0 0 24px #2a9d8f21;--tupa-glow-sand:0 0 12px #e9c46a3d,0 0 24px #e9c46a21;--tupa-glow-purple:0 0 12px #506eff24;--tupa-glow-violet:0 0 12px #506eff24;--tupa-glow-orange:0 0 12px #f4a26133;--tupa-glow-gradient:0 0 16px #f4a26140,0 0 32px #2a9d8f1f;--tupa-radius-sm:10px;--tupa-radius-md:14px;--tupa-radius-lg:18px;--tupa-radius-xl:24px;--tupa-radius-full:999px;--tupa-shadow-sm:0 2px 8px #26465314;--tupa-shadow-md:0 6px 16px #2646531f;--tupa-shadow-lg:0 12px 28px #26465329;--tupa-shadow-glow:0 4px 20px #f4a26140;--space-xs:0.375rem;--space-sm:0.5rem;--space-md:0.75rem;--space-lg:1rem;--space-xl:1.5rem;--tupa-transition-fast:0.16s ease;--tupa-transition-normal:0.24s ease;--tupa-transition-slow:0.34s ease;--tupa-focus-ring:2px solid #0ea5e9;--tupa-sticky-actions-bg:#ffffffeb;--tupa-orange:#f4a261;--tupa-purple:#2a9d8f;--tupa-violet:#2a9d8f}.theme-playful body{background:var(--tupa-gradient-bg)}.theme-playful .tupa-card{background:var(--tupa-surface-glass);box-shadow:var(--tupa-shadow-md)}.theme-playful .tupa-card:hover{box-shadow:var(--tupa-shadow-glow);transform:translateY(-2px)}.theme-playful .tupa-button-primary{background:var(--tupa-gradient-primary);color:#fff;text-shadow:0 1px 2px #0000001a}.theme-playful .tupa-button-primary:hover{box-shadow:0 6px 25px #ffb34766;transform:translateY(-2px) scale(1.02)}.theme-playful .tupa-input,.theme-playful input,.theme-playful select,.theme-playful textarea{background:#fff;border:2px solid #b794f64d;color:#2d2d2d}.theme-playful .tupa-input:focus,.theme-playful input:focus,.theme-playful select:focus,.theme-playful textarea:focus{border-color:#b794f699;box-shadow:0 0 0 3px #b794f61a;outline:none}.theme-playful .tupa-input::placeholder,.theme-playful input::placeholder,.theme-playful select::placeholder,.theme-playful textarea::placeholder{color:#2d2d2d66}.theme-playful .tupa-accent-line{background:var(--tupa-gradient-primary);border-radius:3px;box-shadow:0 2px 8px #ffb3474d;height:3px}.theme-playful .tupa-text-gradient{-webkit-text-fill-color:#0000;background:var(--tupa-gradient-primary);-webkit-background-clip:text;background-clip:text}.theme-playful .tupa-navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:2px solid #b794f633;box-shadow:0 2px 12px #b794f626}@keyframes playful-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.theme-playful .tupa-button-primary:active{animation:playful-bounce .3s ease}.theme-playful .tupa-card,.theme-playful section{background-clip:padding-box,border-box;background-image:linear-gradient(var(--tupa-bg-elevated),var(--tupa-bg-elevated)),var(--tupa-gradient-secondary);background-origin:border-box;border:2px solid #0000}@keyframes playful-pulse{0%,to{box-shadow:0 0 10px #b794f633}50%{box-shadow:0 0 20px #ffb34766}}.theme-playful .tupa-pulse-glow{animation:playful-pulse 2s ease-in-out infinite}.theme-playful ::-webkit-scrollbar{height:10px;width:10px}.theme-playful ::-webkit-scrollbar-track{background:#b794f61a;border-radius:10px}.theme-playful ::-webkit-scrollbar-thumb{background:var(--tupa-gradient-secondary);border-radius:10px}.theme-playful ::-webkit-scrollbar-thumb:hover{background:var(--tupa-gradient-primary)}[data-theme=light]{--page-bg:var(--page-bg,#fff);--page-text:var(--page-text,#111827);--text-muted:var(--text-muted,#6b7280);--border:var(--border,#e6e1f6);--focus:var(--focus,#7c3aed);--card-bg-default:var(--card-bg-default,#fffdf6);--card-bg-yellow:var(--card-bg-yellow,#fff7e6);--card-bg-purple:var(--card-bg-purple,#f8f4ff);--card-bg-orange:var(--card-bg-orange,#fff7f0);--accent-yellow:var(--accent-yellow,#b45309);--accent-purple:var(--accent-purple,#6b21a8);--accent-orange:var(--accent-orange,#c2410c);--avatar-bg:var(--avatar-bg,#fff4d6);--avatar-text:var(--avatar-text,#111827);--input-bg:var(--input-bg,#fff);--input-text:var(--input-text,#111827);--input-placeholder:var(--input-placeholder,#6b7280)}[data-theme=light] .app,[data-theme=light] body{background:var(--page-bg);color:var(--page-text)}[data-theme=light] .card .title,[data-theme=light] .title,[data-theme=light] h1,[data-theme=light] h2,[data-theme=light] h3{color:var(--page-text);font-weight:700;text-shadow:none}[data-theme=light] .card .desc,[data-theme=light] .card .meta,[data-theme=light] .card .nutrition,[data-theme=light] p{color:var(--text-muted)}[data-theme=light] .search-box,[data-theme=light] input,[data-theme=light] textarea{background:var(--input-bg);border:1px solid var(--border);caret-color:var(--focus);color:var(--input-text)}[data-theme=light] .search-box::placeholder,[data-theme=light] input::placeholder,[data-theme=light] textarea::placeholder{color:var(--input-placeholder);opacity:1}[data-theme=light] .card{background:var(--card-bg-default);border:2px solid var(--border);border-radius:8px;box-shadow:0 1px 0 #00000005;color:var(--page-text);padding:18px}[data-theme=light] .card.card--yellow{background:var(--card-bg-yellow);border-color:#b453091f}[data-theme=light] .card.card--purple{background:var(--card-bg-purple);border-color:#6b21a81a}[data-theme=light] .card.card--orange{background:var(--card-bg-orange);border-color:#c2410c1a}[data-theme=light] .card.card--orange .title,[data-theme=light] .card.card--purple .title,[data-theme=light] .card.card--yellow .title{color:var(--page-text)}[data-theme=light] .card .body,[data-theme=light] .card .desc{color:var(--text-muted);font-weight:400}[data-theme=light] .card .callout--positive{color:var(--accent-yellow);font-weight:700}[data-theme=light] .card .callout--safe{color:var(--accent-purple);font-weight:700}[data-theme=light] .card .callout--caution{color:var(--accent-orange);font-weight:700}[data-theme=light] .card .avatar{align-items:center;background:var(--avatar-bg);border:2px solid #0000000f;border-radius:8px;color:var(--avatar-text);display:inline-flex;font-size:1.8rem;font-weight:700;height:64px;justify-content:center;width:64px}[data-theme=light] .card .meta,[data-theme=light] .card .nutrition{color:#4b5563;font-size:.9rem}[data-theme=light] .card a{color:var(--focus);text-decoration:underline}[data-theme=light] .btn,[data-theme=light] .chip{background:var(--input-bg);border:1px solid var(--border);color:var(--page-text)}[data-theme=light] .card .force-white,[data-theme=light] .force-white{color:var(--page-text)!important;text-shadow:none!important}[data-theme=light] :focus{outline:3px solid #7c3aed2e;outline-offset:2px}[data-theme=light] .card .emoji,[data-theme=light] .card .icon{color:inherit;opacity:1}[data-theme=light] .card .muted-white,[data-theme=light] .muted-white{color:var(--text-muted)!important}[data-theme=light]{--food-card-title:#111827;--food-card-text:#1f2937;--food-card-meta:#4b5563;--food-card-variants:#6b7280;--food-safe-bg:#22c55e26;--food-safe-border:#22c55e;--food-safe-text:#16a34a;--food-moderate-bg:#eab30826;--food-moderate-border:#eab308;--food-moderate-text:#a16207;--food-occasional-bg:#fb923c26;--food-occasional-border:#fb923c;--food-occasional-text:#c2410c;--food-limited-bg:#f9731626;--food-limited-border:#f97316;--food-limited-text:#c2410c;--food-toxic-bg:#ef444426;--food-toxic-border:#ef4444;--food-toxic-text:#dc2626}[data-theme=light] .food-card-title,[data-theme=light] .food-name{color:var(--food-card-title)!important;font-weight:700;text-shadow:none}[data-theme=light] .food-card-message,[data-theme=light] .food-description{color:var(--food-card-text)!important;font-weight:500}[data-theme=light] .food-card-meta,[data-theme=light] .food-notes,[data-theme=light] .food-nutrition{color:var(--food-card-meta)!important;font-weight:400}[data-theme=light] .food-variants{background:#00000008!important;border-color:#0000001a!important;color:var(--food-card-variants)!important}[data-theme=light] .food-badge-safe{background:var(--food-safe-bg)!important;border-color:var(--food-safe-border)!important;color:var(--food-safe-text)!important}[data-theme=light] .food-badge-moderate{background:var(--food-moderate-bg)!important;border-color:var(--food-moderate-border)!important;color:var(--food-moderate-text)!important}[data-theme=light] .food-badge-occasional{background:var(--food-occasional-bg)!important;border-color:var(--food-occasional-border)!important;color:var(--food-occasional-text)!important}[data-theme=light] .food-badge-limited{background:var(--food-limited-bg)!important;border-color:var(--food-limited-border)!important;color:var(--food-limited-text)!important}[data-theme=light] .food-badge-avoid,[data-theme=light] .food-badge-toxic{background:var(--food-toxic-bg)!important;border-color:var(--food-toxic-border)!important;color:var(--food-toxic-text)!important}[data-theme=light] .food-category-badge{font-weight:700;text-shadow:none}:root{--tupa-sage-surface:#e4ece4;--tupa-forest-green:#1a4d2e;--tupa-accent-orange:#ff6b35;--tupa-background:#f4f8f4}*,:after,:before{box-sizing:border-box}#root,body,html{background:#0b0607;background:var(--tupa-bg-primary,#0b0607);height:100%;margin:0;padding:0}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit}body,html{overflow-x:hidden;width:100%}*{box-sizing:border-box}*,img{max-width:100%}img{height:auto}@media (max-width:992px){main{grid-template-columns:1fr!important}}@media (max-width:768px){.messages-container{grid-template-columns:1fr!important}nav{flex-direction:column}button{min-height:44px;min-width:44px;padding:.75rem 1rem}.tupa-card{padding:1rem!important}.modal,[role=dialog]{margin:.5rem!important;max-height:90vh!important;max-width:95vw!important;overflow-y:auto!important;width:95vw!important}div,h1,h2,h3,h4,h5,h6,p,span{word-wrap:break-word;overflow-wrap:break-word}}@media (max-width:600px){.tupa-card{max-width:100%!important;width:100%!important}body{font-size:14px}form>div{flex-direction:column!important}.modal,[role=dialog]{padding:1rem!important}}@media (max-width:375px){body{font-size:13px}button{font-size:.875rem;padding:.625rem .875rem}h1{font-size:1.5rem!important}h2{font-size:1.25rem!important}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (hover:none) and (pointer:coarse){a,button,input,select,textarea{min-height:44px}}@media (max-width:768px){.tupa-navbar-subtitle{display:none!important}}@keyframes loading{0%{transform:translateX(-100%)}to{transform:translateX(200%)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes notificationPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.birthday-field-button:hover{background:var(--tupa-surface-glass)!important;border-color:var(--tupa-coral)!important}.birthday-field-button:focus{outline:2px solid var(--tupa-coral);outline-offset:2px}.tupa-form-scaffold{background:var(--tupa-surface-glass);border:var(--tupa-border-medium);border-radius:var(--tupa-radius-lg);box-shadow:var(--tupa-shadow-md);margin:0 auto;width:min(780px,100%)}.tupa-form-scaffold__header{border-bottom:var(--tupa-border-subtle);display:flex;gap:1rem;justify-content:space-between;padding:1rem 1.25rem}.tupa-form-scaffold__mode{color:var(--tupa-text-secondary);font-size:.8rem;letter-spacing:.04em;margin:0 0 .35rem;text-transform:uppercase}.tupa-form-scaffold__title{color:var(--tupa-text-primary);margin:0}.tupa-form-scaffold__description{color:var(--tupa-text-secondary);font-size:.95rem;line-height:1.5;margin:.5rem 0 0}.tupa-form-scaffold__meta{grid-gap:.35rem;align-content:start;display:grid;gap:.35rem;justify-items:end}.tupa-form-scaffold__saved,.tupa-form-scaffold__unsaved{border:1px solid #0000;border-radius:var(--tupa-radius-full);font-size:.8rem;padding:.25rem .65rem}.tupa-form-scaffold__unsaved{background:var(--tupa-status-error-surface);border-color:var(--tupa-status-error);color:var(--tupa-status-error);color:var(--tupa-status-error-text,var(--tupa-status-error))}.tupa-form-scaffold__saved{background:var(--tupa-surface-overlay);border-color:var(--tupa-border-subtle);color:var(--tupa-text-secondary)}.tupa-form-scaffold__content{grid-gap:1rem;display:grid;gap:1rem;padding:1rem 1.25rem}.tupa-form-section{background:var(--tupa-surface-overlay);border:var(--tupa-border-subtle);border-radius:var(--tupa-radius-md);padding:1rem}.tupa-form-section__header{margin-bottom:.75rem}.tupa-form-section__title{color:var(--tupa-text-primary);font-size:1rem;margin:0}.tupa-form-section__description{color:var(--tupa-text-secondary);font-size:.9rem;line-height:1.45;margin:.4rem 0 0}.tupa-form-validation-summary{background:var(--tupa-status-error-surface);border:1px solid var(--tupa-status-error);border-radius:var(--tupa-radius-sm);color:var(--tupa-status-error);color:var(--tupa-status-error-text,var(--tupa-status-error));padding:.75rem}.tupa-form-validation-summary__title{font-weight:600;margin:0}.tupa-form-validation-summary__list{grid-gap:.3rem;display:grid;gap:.3rem;margin:.5rem 0 0 1rem;padding:0}.tupa-form-validation-summary__item{background:#0000;border:0;color:inherit;cursor:pointer;padding:0;text-align:left;text-decoration:underline}.tupa-sticky-form-actions{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--tupa-surface-glass);background:var(--tupa-sticky-actions-bg,var(--tupa-surface-glass));border-radius:0 0 var(--tupa-radius-lg) var(--tupa-radius-lg);border-top:1px solid var(--tupa-border-subtle);bottom:0;display:flex;gap:.75rem;justify-content:space-between;padding:.85rem 1rem;position:-webkit-sticky;position:sticky;z-index:5}.tupa-sticky-form-actions__left{min-width:120px}.tupa-sticky-form-actions__state{color:var(--tupa-text-secondary);font-size:.82rem}.tupa-sticky-form-actions__state.is-unsaved{color:var(--tupa-text-accent);font-weight:600}.tupa-sticky-form-actions__right{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}@media (max-width:768px){.tupa-form-scaffold__header{display:grid;justify-items:start}.tupa-form-scaffold__meta{justify-items:start}.tupa-sticky-form-actions{align-items:stretch;flex-direction:column}.tupa-sticky-form-actions__left{min-width:0}.tupa-sticky-form-actions__right{width:100%}.tupa-sticky-form-actions__right>button{flex:1 1}}:root{--z-base:0;--z-content:1;--z-header:1000;--z-bottom-nav:1000;--z-dropdown:5000;--z-tooltip:5000;--z-popover:5000;--z-modal-backdrop:9998;--z-modal-overlay:9998;--z-modal-content:9999;--z-notification:10000;--z-toast:10000;--z-tour:10001;--z-support-widget:2147483647}.data-export-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:var(--z-modal-overlay)}.data-export-modal{background:#fff;background:var(--tupa-bg-primary,#fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:100%}.data-export-header{align-items:center;background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--tupa-border,#e0e0e0);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1.5rem}.data-export-header h2{font-size:1.75rem;font-weight:700;margin:0}.data-export-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;height:36px;transition:background .2s;width:36px}.data-export-close:hover{background:#ffffff4d}.data-export-error{align-items:center;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;display:flex;justify-content:space-between;margin:1rem;padding:1rem}.data-export-error button{background:#0000;border:1px solid #c33;border-radius:4px;color:#c33;cursor:pointer;font-size:.875rem;padding:.25rem .75rem}.data-export-tabs{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--tupa-border,#e0e0e0);display:flex;gap:.5rem;padding:0 1.5rem}.data-export-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;color:var(--tupa-text-secondary,#666);cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 1.5rem;position:relative;top:2px;transition:all .2s}.data-export-tab.active,.data-export-tab:hover{color:#ff8d23;color:var(--tupa-orange,#ff8d23)}.data-export-tab.active{border-bottom-color:#ff8d23;border-bottom-color:var(--tupa-orange,#ff8d23)}.data-export-content{flex:1 1;overflow-y:auto;padding:1.5rem}.export-intro,.import-intro{color:#666;color:var(--tupa-text-secondary,#666);line-height:1.6;margin-bottom:1.5rem}.export-type-selector{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.export-type-option{align-items:center;background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:2px solid #e0e0e0;border:2px solid var(--tupa-border,#e0e0e0);border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s}.export-type-option:hover{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23)}.export-type-option input[type=radio]{cursor:pointer;height:20px;width:20px}.export-type-option span{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-weight:600}.export-actions{display:flex;gap:1rem;margin-bottom:2rem}.export-btn{background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem;transition:opacity .2s}.export-btn:hover:not(:disabled){opacity:.9}.export-btn:disabled{cursor:not-allowed;opacity:.5}.export-info{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--tupa-border,#e0e0e0);border-radius:8px;padding:1.25rem}.export-info h3{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-size:1.125rem;margin:0 0 1rem}.export-info ul{color:#666;color:var(--tupa-text-secondary,#666);line-height:1.8;margin:0;padding-left:1.5rem}.export-info li{margin-bottom:.5rem}.import-file-select{margin-bottom:1.5rem}.import-file-label{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:2px dashed #e0e0e0;border:2px dashed var(--tupa-border,#e0e0e0);border-radius:8px;color:#666;color:var(--tupa-text-secondary,#666);cursor:pointer;display:block;font-weight:600;padding:2rem;text-align:center;transition:all .2s}.import-file-label:hover{background:#ff8d230d;border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23)}.import-file-input{display:none}.import-btn{background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1.5rem;padding:.875rem;transition:opacity .2s;width:100%}.import-btn:hover:not(:disabled){opacity:.9}.import-btn:disabled{cursor:not-allowed;opacity:.5}.import-result{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.import-result h3{color:#155724;margin:0 0 .75rem}.import-result p{color:#155724;margin:0 0 .5rem}.import-errors{color:#856404!important}.imported-pets{border-top:1px solid #c3e6cb;margin-top:1rem;padding-top:1rem}.imported-pets strong{color:#155724;display:block;margin-bottom:.5rem}.imported-pets ul{color:#155724;margin:0;padding-left:1.5rem}.import-template{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--tupa-border,#e0e0e0);border-radius:8px;padding:1.25rem}.import-template h3{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-size:1.125rem;margin:0 0 .75rem}.import-template p{color:#666;color:var(--tupa-text-secondary,#666);margin:0 0 1rem}.import-template-code{background:#1a1a1a;border-radius:6px;color:#0f0;font-family:Courier New,monospace;font-size:.875rem;line-height:1.6;margin-bottom:1rem;overflow-x:auto;padding:1rem}.download-template-btn{background:#ff8d23;background:var(--tupa-orange,#ff8d23);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.625rem 1.25rem;transition:opacity .2s}.download-template-btn:hover{opacity:.9}@media (prefers-color-scheme:dark){.data-export-modal{background:#1a1a1a;background:var(--tupa-bg-primary,#1a1a1a);color:#fff;color:var(--tupa-text-primary,#fff)}.export-info,.export-type-option,.import-template{background:#2a2a2a;background:var(--tupa-bg-secondary,#2a2a2a);border-color:#444;border-color:var(--tupa-border,#444)}}@media (max-width:768px){.data-export-modal{max-height:95vh}.export-actions{flex-direction:column}.export-btn{width:100%}}.help-hub-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:var(--z-modal-overlay)}.help-hub-modal{background:#fff;background:var(--tupa-bg-primary,#fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);display:flex;flex-direction:column;max-height:90vh;max-width:900px;width:100%}.help-hub-header{align-items:center;background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--tupa-border,#e0e0e0);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1.5rem}.help-hub-header h2{font-size:1.75rem;font-weight:700;margin:0}.help-hub-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;height:36px;transition:background .2s;width:36px}.help-hub-close:hover{background:#ffffff4d}.help-hub-error{align-items:center;background:#fee2e2f2;border:1px solid #fca5a5cc;border-radius:8px;box-shadow:0 2px 8px #dc26261a;color:#991b1b;display:flex;gap:1rem;justify-content:space-between;margin:1rem;padding:1rem 1.25rem}.help-hub-error button{transition:all .2s}.help-hub-error button:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.help-hub-tabs{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--tupa-border,#e0e0e0);display:flex;gap:.5rem;padding:0 1.5rem}.help-hub-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;color:var(--tupa-text-secondary,#666);cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 1.5rem;position:relative;top:2px;transition:all .2s}.help-hub-tab.active,.help-hub-tab:hover{color:#ff8d23;color:var(--tupa-orange,#ff8d23)}.help-hub-tab.active{border-bottom-color:#ff8d23;border-bottom-color:var(--tupa-orange,#ff8d23)}.help-hub-content{flex:1 1;overflow-y:auto;padding:1.5rem}.help-hub-loading{font-size:1.125rem;padding:3rem;text-align:center}.help-hub-loading,.tours-intro{color:#666;color:var(--tupa-text-secondary,#666)}.tours-intro{line-height:1.6;margin-bottom:1.5rem}.tours-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.tour-card{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--tupa-border,#e0e0e0);border-radius:8px;padding:1.25rem;transition:all .2s}.tour-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.tour-card-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.75rem}.tour-card-header h3{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);flex:1 1;font-size:1.125rem;font-weight:700;margin:0}.tour-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:.25rem .625rem;white-space:nowrap}.tour-badge.completed{background:#d4edda;color:#155724}.tour-badge.skipped{background:#f8d7da;color:#721c24}.tour-badge.in-progress{background:#fff3cd;color:#856404}.tour-badge.new{background:#d1ecf1;color:#0c5460}.tour-description{font-size:.9375rem;line-height:1.5}.tour-description,.tour-meta{color:#666;color:var(--tupa-text-secondary,#666);margin-bottom:1rem}.tour-meta{display:flex;font-size:.875rem;gap:1rem}.tour-start-btn{background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.625rem;transition:opacity .2s;width:100%}.tour-start-btn:hover{opacity:.9}.help-search{display:flex;gap:.75rem;margin-bottom:1.5rem}.help-search-input{border:2px solid #e0e0e0;border:2px solid var(--tupa-border,#e0e0e0);border-radius:8px;flex:1 1;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s}.help-search-input:focus{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23);outline:none}.help-search-btn{background:#ff8d23;background:var(--tupa-orange,#ff8d23);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:opacity .2s}.help-search-btn:hover{opacity:.9}.help-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.help-category-btn{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--tupa-border,#e0e0e0);border-radius:20px;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.help-category-btn:hover{background:#ff8d23;background:var(--tupa-orange,#ff8d23);border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23);color:#fff}.help-category-btn.active{background:#7b3fb1;background:var(--tupa-purple,#7b3fb1);border-color:#7b3fb1;border-color:var(--tupa-purple,#7b3fb1);color:#fff}.help-articles{grid-gap:1rem;display:grid;gap:1rem}.no-articles{color:#666;color:var(--tupa-text-secondary,#666);padding:3rem;text-align:center}.help-article-card{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--tupa-border,#e0e0e0);border-radius:8px;cursor:pointer;padding:1.25rem;transition:all .2s}.help-article-card:hover{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23);box-shadow:0 4px 12px #0000001a}.help-article-card h4{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-size:1.125rem;font-weight:700;margin:0 0 .75rem}.help-article-excerpt{font-size:.9375rem;line-height:1.6;margin-bottom:.75rem}.help-article-excerpt,.help-article-meta{color:#666;color:var(--tupa-text-secondary,#666)}.help-article-meta{align-items:center;display:flex;font-size:.875rem;justify-content:space-between}.help-hub-footer{border-top:2px solid #e0e0e0;border-top:2px solid var(--tupa-border,#e0e0e0);color:#666;color:var(--tupa-text-secondary,#666);padding:1rem 1.5rem;text-align:center}.help-hub-footer a{color:#ff8d23;color:var(--tupa-orange,#ff8d23);font-weight:600;text-decoration:none}.help-hub-footer a:hover{text-decoration:underline}@media (prefers-color-scheme:dark){.help-hub-modal{background:#1a1a1a;background:var(--tupa-bg-primary,#1a1a1a);color:#fff;color:var(--tupa-text-primary,#fff)}.help-article-card,.help-category-btn,.help-search-input,.tour-card{background:#2a2a2a;background:var(--tupa-bg-secondary,#2a2a2a);border-color:#444;border-color:var(--tupa-border,#444)}.help-search-input{color:#fff;color:var(--tupa-text-primary,#fff)}}@media (max-width:768px){.help-hub-modal{max-height:95vh}.tours-grid{grid-template-columns:1fr}.help-search{flex-direction:column}.help-categories{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.5rem}}.feedback-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:var(--z-modal-overlay)}.feedback-modal{background:#fff;background:var(--tupa-bg-primary,#fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.feedback-header{align-items:center;background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--tupa-border,#e0e0e0);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-content)}.feedback-header h2{font-size:1.75rem;font-weight:700;margin:0}.feedback-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;height:36px;transition:background .2s;width:36px}.feedback-close:hover{background:#ffffff4d}.feedback-error{align-items:center;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;display:flex;justify-content:space-between;margin:1rem;padding:1rem}.feedback-error button{background:#0000;border:1px solid #c33;border-radius:4px;color:#c33;cursor:pointer;font-size:.875rem;padding:.25rem .75rem}.feedback-form{grid-gap:1rem;display:grid;gap:1rem;padding:0}.feedback-field,.feedback-field--tight{margin-bottom:0}.feedback-field label{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);display:block;font-weight:600;margin-bottom:.5rem}.feedback-optional{color:#666;color:var(--tupa-text-secondary,#666);font-size:.875rem;font-weight:400}.feedback-required{color:#ef4444}.feedback-type-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.feedback-type-card{align-items:center;background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:2px solid #e0e0e0;border:2px solid var(--tupa-border,#e0e0e0);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:1rem;position:relative;transition:all .2s}.feedback-type-card:hover{transform:translateY(-2px)}.feedback-type-card.selected,.feedback-type-card:hover{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23)}.feedback-type-card.selected{background:#ff8d231a}.feedback-type-card input[type=radio]{opacity:0;position:absolute}.feedback-type-label{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-size:1rem;font-weight:600;margin-bottom:.25rem;text-align:center}.feedback-type-desc{color:#666;color:var(--tupa-text-secondary,#666);font-size:.75rem;line-height:1.4;text-align:center}.feedback-field input[type=email],.feedback-field input[type=text],.feedback-field textarea{background:#fff;background:var(--tupa-bg-primary,#fff);border:2px solid #e0e0e0;border:2px solid var(--tupa-border,#e0e0e0);border-radius:8px;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.feedback-field input:focus,.feedback-field textarea:focus{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23);outline:none}.feedback-field textarea{min-height:120px;resize:vertical}.feedback-char-count{text-align:right}.feedback-char-count,.feedback-field-hint{color:#666;color:var(--tupa-text-secondary,#666);font-size:.875rem;margin-top:.25rem}.feedback-field-hint{line-height:1.4}.feedback-inline-error{color:#ef4444;font-size:.82rem;margin:.35rem 0 0}.feedback-actions{display:flex;gap:1rem;margin-top:2rem}.feedback-cancel-btn,.feedback-submit-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem;transition:all .2s}.feedback-cancel-btn{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:2px solid #e0e0e0;border:2px solid var(--tupa-border,#e0e0e0);color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a)}.feedback-cancel-btn:hover:not(:disabled){background:#e0e0e0;background:var(--tupa-border,#e0e0e0)}.feedback-submit-btn{background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));color:#fff}.feedback-submit-btn:hover:not(:disabled){opacity:.9}.feedback-cancel-btn:disabled,.feedback-submit-btn:disabled{cursor:not-allowed;opacity:.5}.feedback-footer{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border-radius:0 0 12px 12px;border-top:2px solid #e0e0e0;border-top:2px solid var(--tupa-border,#e0e0e0);padding:1rem 1.5rem;text-align:center}.feedback-footer p{color:#666;color:var(--tupa-text-secondary,#666);font-size:.875rem;line-height:1.4;margin:0}.feedback-success{padding:3rem 2rem;text-align:center}.feedback-success-icon{font-size:4rem;margin-bottom:1rem}.feedback-success h2{color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);margin:0 0 1rem}.feedback-success p{color:#666;color:var(--tupa-text-secondary,#666);line-height:1.6;margin:0 0 .5rem}.feedback-close-btn{background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:linear-gradient(135deg,var(--tupa-purple,#7b3fb1),var(--tupa-orange,#ff8d23));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:2rem;padding:.875rem 2rem;transition:opacity .2s}.feedback-close-btn:hover{opacity:.9}@media (prefers-color-scheme:dark){.feedback-modal{background:#1a1a1a;background:var(--tupa-bg-primary,#1a1a1a);color:#fff;color:var(--tupa-text-primary,#fff)}.feedback-field input,.feedback-field textarea,.feedback-type-card{background:#2a2a2a;background:var(--tupa-bg-secondary,#2a2a2a);border-color:#444;border-color:var(--tupa-border,#444)}.feedback-cancel-btn{color:#fff;color:var(--tupa-text-primary,#fff)}.feedback-cancel-btn,.feedback-footer{background:#2a2a2a;background:var(--tupa-bg-secondary,#2a2a2a)}}@media (max-width:768px){.feedback-modal{max-height:95vh}.feedback-type-grid{grid-template-columns:repeat(2,1fr)}.feedback-actions{flex-direction:column}.feedback-cancel-btn,.feedback-submit-btn{width:100%}.feedback-type-grid{grid-template-columns:1fr}}.support-widget{bottom:16px;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:auto;position:fixed;right:16px;z-index:var(--z-support-widget)}.support-widget-btn{align-items:center;background:#fff;background:var(--tupa-surface-overlay,#fff);border:2px solid #0000;border-radius:8px;border-radius:var(--tupa-radius-md,8px);box-shadow:0 4px 12px #00000026;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;min-height:44px;padding:.5rem 1rem;transition:all .2s;transition:all var(--tupa-transition-fast,.2s)}.support-widget-feedback{border-color:#ff6b6b;border-color:var(--tupa-coral,#ff6b6b)}.support-widget-feedback:hover{background:linear-gradient(135deg,#ff6b6b,#ff8d23);background:var(--tupa-gradient-secondary,linear-gradient(135deg,#ff6b6b,#ff8d23));box-shadow:0 6px 20px #ff6b6b66;color:#fff;transform:translateY(-2px)}.support-widget-help{border-color:#7b3fb1;border-color:var(--tupa-purple,#7b3fb1)}.support-widget-help:hover{background:linear-gradient(135deg,#7b3fb1,#9b5fd1);background:var(--tupa-gradient-primary,linear-gradient(135deg,#7b3fb1,#9b5fd1));box-shadow:0 6px 20px #7b3fb166;color:#fff;transform:translateY(-2px)}.support-widget-icon{font-size:1.25rem;line-height:1}.support-widget-text{white-space:nowrap}.support-widget-btn:focus{outline:3px solid #7b3fb1;outline:3px solid var(--tupa-purple,#7b3fb1);outline-offset:2px}.support-widget-btn:focus-visible{box-shadow:0 0 0 4px #7b3fb14d;outline:3px solid #7b3fb1;outline:3px solid var(--tupa-purple,#7b3fb1);outline-offset:2px}.support-widget-btn:active{transform:scale(.98)}@media (max-width:768px){.support-widget{bottom:12px;gap:6px;right:12px}.support-widget-btn{font-size:.8125rem;min-height:40px;padding:.4rem .8rem}.support-widget-icon{font-size:1.1rem}}@media (max-width:480px){.support-widget-text{display:none}.support-widget-btn{justify-content:center;min-width:44px;padding:.6rem}}.support-widget--mobile{align-items:flex-start;bottom:calc(80px + env(safe-area-inset-bottom, 0px));flex-direction:column-reverse;gap:8px;left:12px;right:auto}.support-widget--mobile .support-widget-toggle{background:#363639e6;background:var(--tupa-surface-glass,#363639e6);border:1px solid #2a9d8f59;border:var(--tupa-border-medium,1px solid #2a9d8f59);border-radius:50%;box-shadow:0 4px 16px #00000059;box-shadow:var(--tupa-shadow-md,0 4px 16px #00000059);height:44px;justify-content:center;min-height:44px;min-width:44px;padding:0;width:44px}.support-widget--mobile .support-widget-feedback .support-widget-text,.support-widget--mobile .support-widget-help .support-widget-text{display:inline}@media (prefers-color-scheme:dark){.support-widget-btn{background:#2a2a2a;background:var(--tupa-surface-overlay,#2a2a2a);color:#fff;color:var(--tupa-text-primary,#fff)}}.growth-save-bar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0009;border-top:1px solid #ffffff14;bottom:0;padding:12px;position:-webkit-sticky;position:sticky;z-index:50}.growth-save-btn{border-radius:14px;font-size:16px;min-height:48px;width:100%}.health-section{grid-gap:1rem;background:linear-gradient(180deg,var(--tupa-surface-glass),var(--tupa-bg-secondary));border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-lg);box-shadow:var(--tupa-shadow-lg);display:grid;gap:1rem;padding:clamp(1rem,2.5vw,1.4rem)}.health-header{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.health-header h2{color:var(--tupa-text-primary);font-size:clamp(1.05rem,2.6vw,1.35rem);margin:0}.health-close-btn,.health-qr-modal-close{align-items:center;background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-sm);color:var(--tupa-text-secondary);cursor:pointer;display:inline-flex;height:34px;justify-content:center;transition:all var(--tupa-transition-fast);width:34px}.health-close-btn:hover,.health-qr-modal-close:hover{border-color:var(--tupa-border-strong-colour);color:var(--tupa-text-primary)}.health-tabs{display:flex;gap:.45rem;overflow-x:auto;padding-bottom:.25rem}.health-tab{background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-full);color:var(--tupa-text-secondary);cursor:pointer;font-size:.78rem;font-weight:600;padding:.46rem .9rem;transition:all var(--tupa-transition-fast);white-space:nowrap}.health-tab:hover{border-color:var(--tupa-border-strong-colour);color:var(--tupa-text-primary)}.health-tab.active{background:var(--tupa-gradient-secondary);border-color:#0000;color:#fff}.health-content{grid-gap:.9rem;display:grid;gap:.9rem;min-height:280px}.health-overview{grid-gap:.8rem;display:grid;gap:.8rem}.health-info-card{background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-left:3px solid var(--tupa-teal);border-radius:var(--tupa-radius-md);padding:.75rem .85rem}.health-info-hint{color:var(--tupa-text-secondary);font-size:.83rem;line-height:1.45;margin:0}.health-summary-grid{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.health-summary-item{grid-gap:.28rem;background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-md);display:grid;gap:.28rem;padding:.7rem .75rem}.health-summary-label{color:var(--tupa-text-muted);font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.health-summary-value{color:var(--tupa-text-primary);font-size:1.04rem;font-weight:700}.health-list-section{grid-gap:.7rem;display:grid;gap:.7rem}.health-section-header{align-items:center;display:flex;gap:.6rem;justify-content:space-between}.health-section-header h3{color:var(--tupa-text-primary);font-size:.98rem;margin:0}.health-empty-state{background:var(--tupa-surface-overlay);border:1px dashed var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-md);color:var(--tupa-text-muted);font-size:.83rem;padding:1.2rem 1rem;text-align:center}.health-empty-state p{margin:.35rem 0}.health-hint{color:var(--tupa-text-muted);font-size:.76rem}.health-item-card{background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-md);padding:.75rem .8rem;transition:border-color var(--tupa-transition-fast),transform var(--tupa-transition-fast)}.health-item-card:hover{border-color:var(--tupa-border-strong-colour);transform:translateY(-1px)}.health-item-header{align-items:flex-start;display:flex;gap:.6rem;justify-content:space-between;margin-bottom:.55rem}.health-item-header h4{color:var(--tupa-text-primary);font-size:.9rem;margin:0}.health-item-actions{display:flex;gap:.35rem}.health-item-actions button{background:#0000;border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-full);color:var(--tupa-text-secondary);cursor:pointer;font-size:.72rem;padding:.22rem .54rem;transition:all var(--tupa-transition-fast)}.health-item-actions button:hover{border-color:var(--tupa-border-strong-colour);color:var(--tupa-text-primary)}.health-item-details{grid-gap:.32rem;display:grid;gap:.32rem}.health-item-details p{color:var(--tupa-text-secondary);font-size:.8rem;line-height:1.4;margin:0}.health-item-details strong{color:var(--tupa-text-primary);font-weight:600}.health-item-hint{color:var(--tupa-text-muted)!important;font-size:.72rem!important}.health-form-modal{align-items:center;background:#0a0e16bd;display:flex;inset:0;justify-content:center;padding:.75rem;position:fixed;z-index:1000}.health-form{grid-gap:.65rem;background:var(--tupa-bg-secondary);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-lg);box-shadow:var(--tupa-shadow-lg);display:grid;gap:.65rem;max-height:90vh;max-width:520px;overflow-y:auto;padding:clamp(.9rem,2.4vw,1.35rem);width:100%}.health-form h4{color:var(--tupa-text-primary);font-size:1rem;margin:0 0 .2rem}.health-form input,.health-form select,.health-form textarea,.health-qr-url-input{background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-sm);color:var(--tupa-text-primary);font-family:inherit;font-size:.82rem;padding:.62rem .72rem;width:100%}.health-form input:focus,.health-form select:focus,.health-form textarea:focus,.health-qr-url-input:focus{border-color:var(--tupa-teal);outline:none}.health-form textarea{min-height:90px;resize:vertical}.health-form label{align-items:center;color:var(--tupa-text-secondary);display:flex;font-size:.8rem;gap:.4rem}.health-form label input[type=checkbox]{width:auto}.health-form-row{grid-gap:.55rem;display:grid;gap:.55rem;grid-template-columns:1fr 1fr}.health-form-actions,.health-qr-actions{display:flex;flex-wrap:wrap;gap:.5rem}.health-section-error,.health-section-loading{grid-gap:.7rem;background:var(--tupa-surface-overlay);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-md);color:var(--tupa-text-secondary);display:grid;gap:.7rem;padding:1.5rem 1rem;place-items:center;text-align:center}.health-section-error p{color:var(--tupa-status-error-text);margin:0}.health-qr-modal-overlay{align-items:center;background:#0a0e16cc;display:flex;inset:0;justify-content:center;padding:.75rem;position:fixed;z-index:2000}.health-qr-modal{background:var(--tupa-bg-secondary);border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-lg);box-shadow:var(--tupa-shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.health-qr-modal-header{align-items:center;border-bottom:1px solid var(--tupa-border-subtle-colour);display:flex;justify-content:space-between;padding:1rem}.health-qr-modal-header h3{color:var(--tupa-text-primary);font-size:1rem;margin:0}.health-qr-modal-content{grid-gap:.9rem;align-items:center;display:grid;gap:.9rem;padding:1rem}.health-qr-instructions,.health-qr-label,.health-qr-note{color:var(--tupa-text-secondary);font-size:.8rem;margin:0;text-align:center}.health-qr-code-container{background:#fff;border:1px solid var(--tupa-border-subtle-colour);border-radius:var(--tupa-radius-md);display:flex;justify-content:center;padding:.7rem}.health-qr-code-container img{display:block;height:auto;max-width:280px;width:100%}@media (max-width:768px){.health-form-row,.health-summary-grid{grid-template-columns:1fr}.health-tab{padding:.42rem .78rem}.health-form-actions,.health-qr-actions{flex-direction:column}}.pet-sharing-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#080c18b3;inset:0;position:fixed}.pet-sharing-layer{align-items:center;display:flex;inset:0;justify-content:center;padding:1rem;pointer-events:none;position:fixed}.pet-sharing-modal{--care-circle-modal-surface:var(--tupa-bg-primary,#0f1728);--care-circle-panel-surface:var(--tupa-bg-elevated,#151f33);--care-circle-muted-surface:var(--tupa-bg-secondary,#1b2740);--care-circle-border:var(--tupa-border-subtle,1px solid #ffffff1f);background:var(--care-circle-modal-surface);border:1px solid #ffffff1f;border:var(--tupa-border-subtle,1px solid #ffffff1f);border-radius:20px;border-radius:var(--tupa-radius-xl,20px);box-shadow:0 22px 56px #0006;box-shadow:var(--tupa-shadow-glow,0 22px 56px #0006);color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);max-height:92vh;max-width:920px;overflow-y:auto;pointer-events:auto;width:100%}.pet-sharing-header{align-items:center;background:linear-gradient(135deg,#7b3fb1,#ff8d23);background:var(--tupa-gradient-primary,linear-gradient(135deg,#7b3fb1,#ff8d23));border-bottom:1px solid #ffffff1f;border-bottom:var(--tupa-border-subtle,1px solid #ffffff1f);border-radius:20px 20px 0 0;border-radius:var(--tupa-radius-xl,20px) var(--tupa-radius-xl,20px) 0 0;color:#fff;display:flex;justify-content:space-between;padding:.9rem 1rem;position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-content)}.pet-sharing-header h2{font-size:clamp(1.15rem,3vw,1.55rem);font-weight:700;margin:0}.pet-sharing-close{background:#fff3;background:var(--tupa-surface-glass,#fff3);border:1px solid #fff3;border:var(--tupa-border-subtle,1px solid #fff3);border-radius:50%;color:#fff;cursor:pointer;font-size:1.3rem;height:36px;width:36px}.pet-sharing-error,.pet-sharing-success{align-items:center;border-radius:10px;display:flex;gap:1rem;justify-content:space-between;margin:1rem;padding:.875rem 1rem}.pet-sharing-error{background:#fee;border:1px solid #fcc;color:#9b2230}.pet-sharing-success{background:#e6f7eb;border:1px solid #c8efd3;color:#1f6c38}.pet-sharing-error button,.pet-sharing-success button{background:#0000;border:1px solid;border-radius:999px;color:inherit;cursor:pointer;font-size:.8rem;padding:.25rem .75rem}.pet-sharing-content{grid-gap:1rem;display:grid;gap:1rem;padding:1rem}.care-circle-hub{grid-gap:.875rem;background:#ffffff14;background:var(--tupa-surface-glass,#ffffff14);border:1px solid #ffffff1f;border:var(--tupa-border-subtle,1px solid #ffffff1f);border-radius:16px;display:grid;gap:.875rem;padding:1rem}.care-circle-eyebrow{color:#7b3fb1;color:var(--tupa-purple,#7b3fb1);font-size:.72rem;font-weight:700;letter-spacing:.08em;margin:0;text-transform:uppercase}.care-circle-hub h3{font-size:clamp(1.05rem,2.4vw,1.35rem);margin:.25rem 0}.care-circle-subtitle{color:#666;color:var(--tupa-text-secondary,#666);margin:0}.hub-avatar-row{display:flex;flex-wrap:wrap;gap:.5rem}.hub-avatar{background:color-mix(in srgb,#7b3fb1 14%,#fff);background:color-mix(in srgb,var(--tupa-purple,#7b3fb1) 14%,#fff);border:1px solid color-mix(in srgb,#7b3fb1 25%,#0000);border:1px solid color-mix(in srgb,var(--tupa-purple,#7b3fb1) 25%,#0000);border-radius:999px;color:#7b3fb1;color:var(--tupa-purple,#7b3fb1);display:grid;font-size:.75rem;font-weight:700;height:2.25rem;overflow:hidden;place-items:center;width:2.25rem}.hub-avatar img{height:100%;object-fit:cover;width:100%}.hub-avatar-extra{background:color-mix(in srgb,#ff8d23 16%,#fff);background:color-mix(in srgb,var(--tupa-orange,#ff8d23) 16%,#fff);color:#8a4f00}.hub-stat-grid{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:repeat(3,minmax(0,1fr))}.hub-stat-card{grid-gap:.15rem;background:var(--care-circle-panel-surface);border:var(--care-circle-border);border-radius:12px;border-radius:var(--tupa-radius-md,12px);box-shadow:0 2px 8px #0000001f;box-shadow:var(--tupa-shadow-sm,0 2px 8px #0000001f);display:grid;gap:.15rem;padding:.85rem}.hub-stat-card strong{font-size:1.2rem}.hub-stat-card span{color:#666;color:var(--tupa-text-secondary,#666);font-size:.8rem}.hub-quick-actions{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:repeat(2,minmax(0,1fr))}.hub-quick-actions :is(button){width:100%}.hub-quick-actions button:disabled{cursor:not-allowed;opacity:.7}.hub-permission-copy{background:color-mix(in srgb,var(--care-circle-muted-surface) 92%,#7b3fb1 8%);background:color-mix(in srgb,var(--care-circle-muted-surface) 92%,var(--tupa-purple,#7b3fb1) 8%);border:1px solid color-mix(in srgb,#7b3fb1 28%,#0000);border:1px solid color-mix(in srgb,var(--tupa-purple,#7b3fb1) 28%,#0000);border-radius:12px;box-shadow:inset 0 1px 0 #ffffff08;padding:.65rem .75rem}.hub-permission-title{color:#9ca7bd;color:var(--tupa-text-secondary,#9ca7bd);font-size:.78rem;font-weight:700;letter-spacing:.08em;margin:0;text-transform:uppercase}.hub-permission-copy ul{grid-gap:.24rem;display:grid;gap:.24rem;list-style:none;margin:.42rem 0 0;padding:0}.hub-permission-copy li{color:#e7ecf7;color:var(--tupa-text-primary,#e7ecf7);font-size:.84rem;line-height:1.35;margin:0}.hub-permission-copy li:before{color:color-mix(in srgb,#7b3fb1 68%,#fff);color:color-mix(in srgb,var(--tupa-purple,#7b3fb1) 68%,#fff);content:"•";margin-right:.42rem}.hub-activity-preview{grid-gap:.5rem;display:grid;gap:.5rem}.hub-activity-item{grid-gap:.15rem;border-left:3px solid #ff8d23;border-left:3px solid var(--tupa-orange,#ff8d23);display:grid;gap:.15rem;padding-left:.6rem}.hub-activity-item span{color:#666;color:var(--tupa-text-secondary,#666);font-size:.82rem}.care-circle-onboarding,.care-circle-viral-nudge,.duplicate-warning{background:var(--care-circle-panel-surface);border:var(--care-circle-border);border-radius:14px;border-radius:var(--tupa-radius-lg,14px);padding:.9rem}.care-circle-onboarding h3,.care-circle-viral-nudge p,.duplicate-warning h4{margin:0}.care-circle-onboarding p,.duplicate-warning p{color:#666;color:var(--tupa-text-secondary,#666);margin:.45rem 0 0}.duplicate-warning div,.onboarding-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.care-circle-viral-nudge :is(button),.duplicate-warning :is(button),.onboarding-actions :is(button){min-height:40px}.pet-sharing-content-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1.2fr 1fr}.pet-sharing-info,.pet-sharing-invite,.pet-sharing-list,.pet-sharing-marketing-card{background:var(--care-circle-panel-surface);border:var(--care-circle-border);border-radius:14px;border-radius:var(--tupa-radius-lg,14px);padding:.9rem}.inline-hint,.pet-sharing-intro,.share-role-copy{color:#666;color:var(--tupa-text-secondary,#666);font-size:.88rem}.invite-form{grid-gap:.7rem;display:grid;gap:.7rem}.invite-field label{display:block;font-size:.86rem;font-weight:600;margin-bottom:.25rem}.invite-field input,.invite-field select,.role-selector,.transfer-panel select{background:#f8f9fa;background:var(--tupa-bg-secondary,#f8f9fa);border:1px solid #ddd;border:1px solid var(--tupa-border,#ddd);border-radius:10px;color:#1a1a1a;color:var(--tupa-text-primary,#1a1a1a);padding:.6rem .7rem;width:100%}.invite-field input:focus,.invite-field select:focus,.role-selector:focus,.transfer-panel select:focus{border-color:#ff8d23;border-color:var(--tupa-orange,#ff8d23);outline:none}.invite-button-row{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr))}.revoke-btn{background:#b73244;background:var(--tupa-terracotta,#b73244);border:none;border-radius:10px;border-radius:var(--tupa-radius-md,10px);color:#fff;cursor:pointer;font-weight:700;padding:.62rem .8rem}.pet-sharing-info ul,.pet-sharing-marketing-card ul{grid-gap:.3rem;display:grid;gap:.3rem;margin:.5rem 0 0;padding-left:1rem}.activity-feed,.shares-grid{grid-gap:.7rem;display:grid;gap:.7rem}.activity-card,.share-card,.transfer-card{background:#f8f9fa;background:var(--tupa-surface-glass,#f8f9fa);border:1px solid #ffffff1f;border:var(--tupa-border-subtle,1px solid #ffffff1f);border-radius:12px;border-radius:var(--tupa-radius-md,12px);padding:.75rem}.share-card-header{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between}.share-user-name{font-weight:700}.share-user-email,.share-user-expiry{color:#666;color:var(--tupa-text-secondary,#666);font-size:.84rem}.share-badges{display:flex;flex-wrap:wrap;gap:.45rem}.share-badge{border-radius:999px;font-size:.72rem;font-weight:700;padding:.2rem .6rem}.role-owner,.status-owner{background:#f4e7ff;color:#5e2a89}.role-manager{background:#e2f7f7;color:#185b66}.role-carer{background:#fff3dd;color:#825500}.role-viewer,.status-pending{background:#ececec;color:#505050}.share-actions{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:1fr auto;margin-top:.65rem}.transfer-panel{grid-gap:.5rem;display:grid;gap:.5rem;margin-top:.7rem}.activity-card{grid-gap:.65rem;display:grid;gap:.65rem;grid-template-columns:auto 1fr}.activity-avatar{background:color-mix(in srgb,#7b3fb1 15%,#fff);background:color-mix(in srgb,var(--tupa-purple,#7b3fb1) 15%,#fff);border-radius:999px;color:#7b3fb1;color:var(--tupa-purple,#7b3fb1);display:grid;font-size:.72rem;font-weight:700;height:2rem;place-items:center;width:2rem}.activity-content p{margin:0}.activity-content span{color:#666;color:var(--tupa-text-secondary,#666);font-size:.8rem}.notification-pref-grid{grid-gap:.55rem;display:grid;gap:.55rem;grid-template-columns:repeat(2,minmax(0,1fr))}.notification-pref-item{align-items:center;border:1px solid #ddd;border:1px solid var(--tupa-border,#ddd);border-radius:10px;display:flex;font-size:.85rem;gap:.4rem;padding:.5rem .6rem}.privacy-note{color:#666;color:var(--tupa-text-secondary,#666);font-size:.84rem;margin:.7rem 0 0}.no-shares,.pet-sharing-loading{background:var(--care-circle-muted-surface);color:#666;color:var(--tupa-text-secondary,#666);padding:1rem}.care-circle-empty,.no-shares,.pet-sharing-loading{border-radius:10px;border-radius:var(--tupa-radius-md,10px);text-align:center}.care-circle-empty{grid-gap:.35rem;background:color-mix(in srgb,var(--care-circle-panel-surface) 82%,#7b3fb1 18%);background:color-mix(in srgb,var(--care-circle-panel-surface) 82%,var(--tupa-purple,#7b3fb1) 18%);border:var(--care-circle-border);display:grid;gap:.35rem;justify-items:center;min-height:120px;padding:.95rem .85rem}.pet-sharing-modal ::selection{background:color-mix(in srgb,#7b3fb1 34%,#0000);background:color-mix(in srgb,var(--tupa-purple,#7b3fb1) 34%,#0000);color:inherit}.care-circle-empty.compact{min-height:96px;padding:.8rem .75rem}.care-circle-empty h4{font-size:1rem;margin:0}.care-circle-empty p{color:#666;color:var(--tupa-text-secondary,#666);margin:0;max-width:40ch}.care-circle-empty-icon{background:linear-gradient(135deg,#4db6ac,#7b3fb1);background:var(--tupa-gradient-secondary,linear-gradient(135deg,#4db6ac,#7b3fb1));border-radius:999px;color:#fff;display:grid;height:2rem;place-items:center;width:2rem}.modal-backdrop{background:#080c18a6;display:grid;inset:0;padding:1rem;place-items:center;position:fixed;z-index:calc(var(--z-modal-overlay) + 1)}.confirm-modal{background:var(--care-circle-panel-surface);border:var(--care-circle-border);border-radius:14px;padding:1rem;width:min(420px,100%)}.confirm-modal h4{margin:0}.confirm-modal p{color:#666;color:var(--tupa-text-secondary,#666)}.confirm-actions{gap:.5rem}.confirm-actions,.pet-sharing-footer{display:flex;justify-content:flex-end}.pet-sharing-footer{background:var(--care-circle-modal-surface);border-top:1px solid #e0e0e0;border-top:1px solid var(--tupa-border,#e0e0e0);bottom:0;padding:.85rem 1rem 1rem;position:-webkit-sticky;position:sticky}@media (max-width:900px){.hub-quick-actions,.hub-stat-grid,.notification-pref-grid,.pet-sharing-content-grid{grid-template-columns:1fr}}@media (max-width:640px){.pet-sharing-layer,.pet-sharing-overlay{padding:0}.pet-sharing-modal{border-radius:0;height:100vh;max-height:100vh;width:100vw}.pet-sharing-header{border-radius:0}.invite-button-row,.share-actions{grid-template-columns:1fr}}.admin-breed-manual-review{--review-text-secondary:#f1faeed9;--review-text-tertiary:#f1faeeb3}.admin-breed-manual-review .text-gray-600{color:#f1faeecc!important}.admin-breed-manual-review .text-gray-500{color:#f1faeebf!important}.admin-breed-manual-review .text-gray-400{color:#f1faeeb3!important}.admin-breed-manual-review .text-xs{color:#f1faeed9}.admin-breed-manual-review .text-sm{color:#f1faeecc}[data-theme=light] .admin-breed-manual-review .text-gray-600{color:#374151!important}[data-theme=light] .admin-breed-manual-review .text-gray-500{color:#4b5563!important}[data-theme=light] .admin-breed-manual-review .text-gray-400{color:#6b7280!important}[data-theme=light] .admin-breed-manual-review .dark\:text-gray-400{color:#4b5563!important}.admin-breed-manual-review .bg-gray-100{background-color:#2a9d8f26!important}.admin-breed-manual-review .text-gray-800{color:#f1faeee6!important}[data-theme=light] .admin-breed-manual-review .bg-gray-100{background-color:#e5e7eb!important}[data-theme=light] .admin-breed-manual-review .text-gray-800{color:#1f2937!important}.admin-breed-manual-review table td{color:#f1faeed9}.admin-breed-manual-review table th{color:#f1faeef2;font-weight:600}[data-theme=light] .admin-breed-manual-review table td{color:#374151}[data-theme=light] .admin-breed-manual-review table th{color:#111827}.admin-breed-manual-review .hover\:text-gray-700:hover{color:#f1faee!important}[data-theme=light] .admin-breed-manual-review .hover\:text-gray-700:hover{color:#1f2937!important}.admin-breed-manual-review .confidence-indicator{font-weight:600;text-shadow:0 1px 2px #0000004d}[data-theme=light] .admin-breed-manual-review .confidence-indicator{text-shadow:none}.admin-breed-manual-review .confidence-low{color:#fca5a5!important;font-weight:600}.admin-breed-manual-review .confidence-medium{color:#fde047!important;font-weight:600}.admin-breed-manual-review .confidence-high{color:#86efac!important;font-weight:600}[data-theme=light] .admin-breed-manual-review .confidence-low{color:#dc2626!important}[data-theme=light] .admin-breed-manual-review .confidence-medium{color:#d97706!important}[data-theme=light] .admin-breed-manual-review .confidence-high{color:#16a34a!important}.vet-view-container{background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh}.vet-view-header{align-items:center;background:linear-gradient(135deg,#4a148c,#6a1b9a);box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:16px 24px}.vet-view-badge{align-items:center;display:flex;font-size:14px;font-weight:600;gap:8px}.vet-view-badge-icon{font-size:18px}.vet-view-close{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:opacity .2s;width:32px}.vet-view-close:hover{opacity:.8}.vet-view-content{margin:0 auto;max-width:800px;padding:24px}.vet-view-pet-header{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-bottom:24px;padding:24px}.vet-view-pet-header h1{color:#4a148c;font-size:32px;margin:0 0 8px}.vet-view-generated{color:#666;font-size:14px;margin:0}.vet-view-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-bottom:16px;padding:24px}.vet-view-section-title{border-bottom:2px solid #e0e0e0;color:#4a148c;font-size:20px;margin:0 0 16px;padding-bottom:8px}.vet-view-subsection-title{color:#6a1b9a;font-size:16px;font-weight:600;margin:24px 0 12px}.vet-view-subsection-title:first-of-type{margin-top:0}.vet-view-snapshot{background:linear-gradient(135deg,#f5f1ff,#ede7f6);border-left:4px solid #6a1b9a}.vet-view-snapshot-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.vet-view-snapshot-item{display:flex;flex-direction:column;gap:4px}.vet-view-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.vet-view-value{color:#4a148c;font-size:16px;font-weight:700}.vet-view-details-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.vet-view-detail-item{display:flex;flex-direction:column;gap:4px}.vet-view-detail-item span:last-child{color:#333;font-size:16px;font-weight:500}.vet-view-med-card{background:#f9f9f9;border-radius:8px;margin-bottom:12px;padding:16px}.vet-view-med-card:last-child{margin-bottom:0}.vet-view-med-name{color:#4a148c;font-size:18px;margin:0 0 12px}.vet-view-med-details p{color:#333;font-size:14px;margin:6px 0}.vet-view-med-details strong{color:#666;font-weight:600}.vet-view-history-item{background:#f9f9f9;border-radius:8px;margin-bottom:8px;padding:12px}.vet-view-history-item p{color:#333;font-size:14px;margin:4px 0}.vet-view-history-item strong{color:#4a148c;font-weight:600}.vet-view-status{color:#666;font-size:13px;font-weight:400}.vet-view-date{color:#999;font-size:13px}.vet-view-notes{color:#666!important;font-size:13px!important;font-style:italic;margin-top:4px!important}.vet-view-clinic{color:#666;font-size:13px}.vet-view-severity{color:#d32f2f;font-size:13px;font-weight:600}.vet-view-none-recorded{color:#999;font-style:italic;margin:0}.vet-view-vacc-status{display:flex;gap:24px;margin-bottom:16px}.vet-view-vacc-badge{border-radius:16px;font-size:14px;font-weight:600;padding:4px 12px}.vet-view-vacc-badge.up-to-date{background:#e8f5e9;color:#2e7d32}.vet-view-vacc-badge.due-soon{background:#fff3e0;color:#f57c00}.vet-view-vacc-badge.overdue{background:#ffebee;color:#c62828}.vet-view-vacc-badge.not-recorded{background:#f5f5f5;color:#666}.vet-view-vacc-item{background:#f9f9f9;border-radius:8px;margin-bottom:8px;padding:12px}.vet-view-vacc-item p{color:#333;font-size:14px;margin:4px 0}.vet-view-vacc-type{color:#666;font-size:13px}.vet-view-due-date{color:#f57c00;font-size:13px}.vet-view-qr-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-top:24px;padding:24px;text-align:center}.vet-view-qr-description{color:#666;font-size:14px;margin:0 0 16px}.vet-view-qr-code{height:auto;max-width:200px;width:100%}.vet-view-footer{color:#999;font-size:12px;padding:24px;text-align:center}.vet-view-footer p{margin:4px 0}.vet-view-error,.vet-view-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:24px;text-align:center}.vet-view-spinner{animation:vet-view-spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#6a1b9a;height:48px;margin-bottom:16px;width:48px}@keyframes vet-view-spin{to{transform:rotate(1turn)}}.vet-view-loading p{color:#666;font-size:16px}.vet-view-error{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:24px auto;max-width:500px}.vet-view-error-icon{font-size:64px;margin-bottom:16px}.vet-view-error h2{color:#d32f2f;font-size:24px;margin:0 0 16px}.vet-view-error p{color:#666;font-size:16px;margin:8px 0}.vet-view-error-hint{color:#999!important;font-size:14px!important;font-style:italic}@media (max-width:768px){.vet-view-content{padding:16px}.vet-view-pet-header h1{font-size:24px}.vet-view-section{padding:16px}.vet-view-section-title{font-size:18px}.vet-view-details-grid,.vet-view-snapshot-grid{grid-template-columns:1fr}.vet-view-vacc-status{flex-direction:column;gap:12px}}@media print{.vet-view-close,.vet-view-header,.vet-view-qr-section{display:none}}
/*# sourceMappingURL=main.d8c2bc39.css.map*/