.sync-indicator{position:fixed;bottom:1rem;right:1rem;background:var(--color-bg-card);border-radius:24px;padding:.5rem 1rem;box-shadow:0 2px 12px #00000026;font-size:.875rem;z-index:1000;transition:all .3s ease;max-width:calc(100vw - 3rem);width:fit-content;overflow:hidden}.sync-indicator--syncing{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.sync-indicator--pending{background:linear-gradient(135deg,#fbbf24,#d97706);color:var(--color-gray-900);font-weight:500}.sync-indicator--error{background:linear-gradient(135deg,var(--color-error-light) 0%,var(--color-error) 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.sync-indicator__content{display:flex;align-items:center;gap:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sync-indicator__icon{font-size:1rem}.sync-indicator__spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.sync-indicator__last-sync{opacity:.8;font-size:.8rem}@media (max-width: 640px){.sync-indicator{bottom:.75rem;right:.75rem;padding:.4rem .8rem;font-size:.8rem;max-width:calc(100vw - 1.5rem)}.sync-indicator__icon{font-size:.9rem}.sync-indicator__spinner{width:14px;height:14px}.sync-indicator__last-sync{font-size:.75rem}}.offline-privacy-notice-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.offline-privacy-notice{background:var(--color-bg-card);border-radius:12px;padding:2rem;max-width:500px;width:100%;box-shadow:var(--shadow-xl)}.offline-privacy-notice h3{margin:0 0 1rem;color:var(--color-gray-900);font-size:1.25rem}.offline-privacy-notice p{margin:0 0 1.5rem;color:var(--color-gray-600);line-height:1.6}.offline-privacy-notice__actions{display:flex;gap:.75rem;justify-content:flex-end}.offline-privacy-notice__actions .btn-primary{background:var(--color-primary);color:#fff;border:none;padding:.625rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.offline-privacy-notice__actions .btn-primary:hover{background:#5a67d8}@media (max-width: 640px){.offline-privacy-notice{padding:1.5rem}.offline-privacy-notice h3{font-size:1.125rem}.offline-privacy-notice p{font-size:.875rem}}.offline-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;padding:.75rem 1rem;z-index:9999;box-shadow:0 2px 8px #00000026;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.offline-banner__content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem}.offline-banner__icon{font-size:1.5rem;flex-shrink:0}.offline-banner__text{flex:1}.offline-banner__text strong{display:block;font-size:1rem;margin-bottom:.25rem}.offline-banner__text p{font-size:.875rem;margin:0;opacity:.95}.offline-banner__pending{margin-top:.25rem!important;font-weight:600}.offline-banner__close{background:#fff3;border:none;color:#fff;width:2rem;height:2rem;border-radius:.375rem;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.offline-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;border-radius:10px;font-weight:800;font-size:12px;letter-spacing:.03em;text-transform:uppercase;box-shadow:0 6px 20px #ef444459;line-height:1}.offline-banner__close:hover{background:#ffffff4d}.offline-banner__close:active{background:#fff6}@media (max-width: 640px){.offline-banner{padding:.5rem .75rem}.offline-banner__icon{font-size:1.25rem}.offline-banner__text strong{font-size:.9rem}.offline-banner__text p{font-size:.8rem}}.pending-sync-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;padding:.125rem .25rem;border-radius:4px;transition:all .2s}.pending-sync-badge--pending{color:#f59e0b;background:#f59e0b1a}.pending-sync-badge--error{color:#ef4444;background:#ef44441a}.pending-sync-badge--error:hover{background:#ef444433;transform:scale(1.05)}.pending-sync-badge__hint{font-size:.75rem;opacity:0;transition:opacity .2s}.pending-sync-badge--error:hover .pending-sync-badge__hint{opacity:1}.pending-sync-badge--clickable{cursor:pointer}@media (max-width: 640px){.pending-sync-badge{font-size:.8rem}.pending-sync-badge__hint{display:none}}.snowflake{position:fixed;top:-20px;z-index:9999;-webkit-user-select:none;user-select:none;pointer-events:none;animation-name:fall;animation-timing-function:linear;animation-iteration-count:infinite;color:#fff;text-shadow:0 0 5px rgba(255,255,255,.8)}[data-theme=dark] .snowflake{opacity:.8}:root:not([data-theme=dark]) .snowflake{color:#a0aec0;text-shadow:0 0 2px rgba(160,174,192,.5)}@keyframes fall{0%{transform:translateY(-5vh) translate(0) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(105vh) translate(20px) rotate(360deg);opacity:.3}}.santa-hat-decoration{position:absolute;top:-14px;right:-6px;width:24px;height:24px;transform:rotate(15deg);z-index:10;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2));pointer-events:none}.patient-combobox{position:relative}.patient-combobox__input{width:100%}.patient-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-2);background:var(--color-bg-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:260px;overflow-y:auto;padding:var(--space-1);z-index:5;display:none}.patient-suggestions.visible{display:block}.patient-suggestion{width:100%;text-align:left;background:transparent;border:1px solid transparent;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:flex-start;gap:4px;color:var(--color-gray-800);cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base)}.patient-suggestion+.patient-suggestion{margin-top:var(--space-1)}.patient-suggestion:hover,.patient-suggestion:focus-visible{background:var(--color-gray-50);border-color:var(--color-gray-200);box-shadow:var(--shadow-sm);outline:none}.patient-suggestion.is-active{background:#eef2ff;border-color:#c7d2fe;box-shadow:0 4px 12px #667eea1f}.patient-name{font-weight:700;color:var(--color-gray-900)}.patient-meta{color:var(--color-gray-600);font-size:13px;line-height:1.4;word-break:break-word}.suggestion-message{padding:var(--space-3);color:var(--color-gray-600);font-size:13px}.clinic-management{max-width:1200px;margin:0 auto;padding:2rem}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid var(--color-gray-200)}.tabs button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;color:var(--color-gray-600);transition:all .2s}.tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tabs button:hover{color:var(--color-primary)}.header-actions{margin-bottom:1.5rem;display:flex;justify-content:flex-end}.data-table{width:100%;border-collapse:collapse;background:var(--color-bg-card);box-shadow:0 2px 4px #0000001a;border-radius:8px;overflow:hidden}.data-table thead{background:var(--color-gray-50)}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--color-gray-200)}.data-table th{font-weight:600;color:var(--color-gray-800)}.data-table code{background:var(--color-gray-100);padding:.25rem .5rem;border-radius:4px;font-family:monospace;color:var(--color-gray-900)}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.badge-success{background:#e8f5e9;color:#2e7d32}.badge-warning{background:#fff3e0;color:#bf360c}.badge-danger{background:#ffebee;color:#c62828}.badge-primary{background:#e3f2fd;color:#1565c0}.badge-secondary{background:#f5f5f5;color:#424242}.member-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.btn-danger-small,.btn-small{padding:.375rem .75rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-danger-small{background:#ffebee;color:#c62828}.btn-danger-small:hover{background:#c62828;color:#fff}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-close-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:transparent;cursor:pointer;padding:0;z-index:0}.modal-close-overlay:focus-visible{outline:2px solid var(--color-primary)}.modal-content{background:var(--color-bg-card);padding:2rem;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;z-index:1;color:var(--color-gray-900)}.modal-content h2{margin-top:0;margin-bottom:1.5rem;color:var(--color-gray-900)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-gray-800)}.form-group input{width:100%;padding:.75rem;border:1px solid var(--color-gray-300);border-radius:4px;font-size:1rem;background:var(--color-bg-input);color:var(--color-gray-900)}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.invite-code-display{text-align:center}.code-box{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.5rem 0;padding:1rem;background:var(--color-gray-50);border-radius:8px}.code-box code{font-size:1.25rem;font-weight:600;font-family:monospace;color:var(--color-primary)}.warning{color:var(--color-warning);font-weight:500;margin:1rem 0}.error-message{background:var(--color-error-light);color:var(--color-error-dark);padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid var(--color-error)}:root{--color-primary: #667eea;--color-primary-dark: #5a67d8;--color-primary-light: #7c8ff2;--color-primary-alpha: rgba(102, 126, 234, .12);--color-secondary: #764ba2;--color-bg: #f5f7fa;--color-bg-white: #ffffff;--color-bg-gray: #f7fafc;--color-bg-card: #ffffff;--color-bg-input: #ffffff;--color-bg-page: #f5f7fa;--color-gray-50: #f7fafc;--color-gray-100: #edf2f7;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e0;--color-gray-400: #a0aec0;--color-gray-500: #718096;--color-gray-600: #4a5568;--color-gray-700: #2d3748;--color-gray-800: #1a202c;--color-gray-900: #171923;--color-success: #48bb78;--color-success-dark: #38a169;--color-success-light: #d1fae5;--color-error: #e53e3e;--color-error-dark: #c53030;--color-error-light: #fc8181;--color-warning: #ed8936;--color-warning-light: #fef3c7;--color-info-light: #dbeafe;--header-bg: rgba(255, 255, 255, .98);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--container-max-width: 1180px;--layout-max-width: var(--container-max-width);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--shadow-xl: 0 10px 40px rgba(0, 0, 0, .1);--shadow-2xl: 0 16px 48px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: .9375rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.5rem;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-tight: 1.25;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-family-mono: "Courier New", Courier, monospace;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-toast: 600;--header-height: 64px;--color-border: var(--color-gray-300)}[data-theme=dark]{--color-bg: #1a1b1e;--color-bg-page: #1a1b1e;--color-bg-card: #25262b;--color-bg-input: #2c2e33;--color-bg-white: #25262b;--color-gray-50: #2c2e33;--color-gray-100: #2d2e33;--color-gray-200: #373a40;--color-gray-300: #4a4d55;--color-gray-400: #718096;--color-gray-500: #a0aec0;--color-gray-600: #cbd5e0;--color-gray-700: #e2e8f0;--color-gray-800: #edf2f7;--color-gray-900: #e0e0e0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .4);--header-bg: rgba(37, 38, 43, .95);--color-border: var(--color-gray-200);--color-primary-alpha: rgba(102, 126, 234, .18)}[data-theme=dark] body{background-color:#1a1b1e;background-image:radial-gradient(circle at 50% 10%,rgba(255,255,255,.05) 0%,transparent 70%),linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 25%,transparent 75%,rgba(0,0,0,.25) 75%,rgba(0,0,0,.25)),linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 25%,transparent 75%,rgba(0,0,0,.25) 75%,rgba(0,0,0,.25));background-position:0 0,0 0,2px 2px;background-size:100% 100%,4px 4px,4px 4px}[data-theme=dark] .pwa-step{background:var(--color-bg-card);border:1px solid var(--color-gray-300);border-left:4px solid var(--color-primary)}[data-theme=dark] .pwa-step__text{color:var(--color-gray-900)}[data-theme=dark] .pwa-benefits{background:#fbbf241a;border-left:4px solid #fbbf24}[data-theme=dark] .pwa-benefits__title{color:#fbbf24}[data-theme=dark] .modal-content,[data-theme=dark] .share-modal__content{background-color:var(--color-bg-card);color:var(--color-gray-900);box-shadow:var(--shadow-xl)}[data-theme=dark] .modal-title,[data-theme=dark] .share-modal__title,[data-theme=dark] .share-card__title{color:var(--color-gray-900)}[data-theme=dark] .modal-close-overlay{background-color:#000000b3}[data-theme=dark] .share-modal__input{background-color:var(--color-bg-input);color:var(--color-gray-900);border-color:var(--color-gray-300)}[data-theme=dark] .share-card{background-color:var(--color-bg-input);border-color:var(--color-gray-300)}[data-theme=dark] .share-meta__value{color:var(--color-gray-900)}[data-theme=dark] .data-table,[data-theme=dark] .share-table table{background-color:var(--color-bg-card);color:var(--color-gray-200)}[data-theme=dark] .data-table th,[data-theme=dark] .share-table th{background-color:var(--color-bg-card);color:var(--color-gray-600);border-bottom-color:var(--color-gray-200)}[data-theme=dark] .data-table td,[data-theme=dark] .share-table td{border-bottom-color:var(--color-gray-200);color:var(--color-gray-900)}[data-theme=dark] .data-table tr:nth-child(2n){background-color:#ffffff08}[data-theme=dark] .notes-cell{color:var(--color-gray-400)}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder,[data-theme=dark] .form-field__input::placeholder{color:var(--color-gray-400);opacity:1}[data-theme=dark] .share-container,[data-theme=dark] .share-container-wide{background-color:var(--color-bg-default);min-height:100vh}[data-theme=dark] .share-card-surface{background-color:var(--color-bg-card);color:var(--color-gray-200);border:1px solid var(--color-gray-700)}[data-theme=dark] .share-hero__title{color:var(--color-gray-900)}[data-theme=dark] .share-hero__subtitle{color:var(--color-gray-600)}[data-theme=dark] .language-switcher{background-color:var(--color-bg-input)!important;border-color:var(--color-gray-300)!important;color:var(--color-gray-900)!important}[data-theme=dark] .share-result__banner{background-color:#064e3b80;border-color:#0596694d}[data-theme=dark] .share-result__title{color:#d1fae5}[data-theme=dark] .share-result__subtitle{color:#a7f3d0}[data-theme=dark] .share-card__section{background-color:#0003;border-color:var(--color-gray-300)}[data-theme=dark] .share-card__title{color:var(--color-gray-800)}[data-theme=dark] .share-card__qr{background-color:#fff;border-color:var(--color-gray-300)}[data-theme=dark] .btn--danger,[data-theme=dark] .btn-danger{background-color:#4c1d1d;border-color:#7f1d1d;color:#fff;box-shadow:none}[data-theme=dark] .btn--danger:hover:not(:disabled),[data-theme=dark] .btn-danger:hover:not(:disabled){background-color:#7f1d1d;border-color:#9b2c2c;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .btn--secondary,[data-theme=dark] .btn-secondary,[data-theme=dark] .icon-btn{background-color:var(--color-bg-input);border-color:var(--color-gray-300);color:var(--color-gray-400)}[data-theme=dark] .btn--secondary:hover:not(:disabled),[data-theme=dark] .btn-secondary:hover:not(:disabled),[data-theme=dark] .icon-btn:hover:not(:disabled){background-color:var(--color-gray-200);border-color:var(--color-primary);color:var(--color-primary-light)}[data-theme=dark] .badge-success{background-color:#1c3329;color:#e6fffa}[data-theme=dark] .badge-warning{background-color:#422a19;color:ivory}[data-theme=dark] .badge-danger{background-color:#4c1d1d;color:#fff}[data-theme=dark] .badge-primary{background-color:#1a365d;color:#ebf8ff}[data-theme=dark] .badge-secondary{background-color:var(--color-gray-200);color:var(--color-gray-300)}[data-theme=dark] .btn-danger-small{background-color:#4c1d1d;color:#fff}[data-theme=dark] .btn-danger-small:hover{background-color:#7f1d1d;color:#fff}[data-theme=dark] .chart-placeholder{background:repeating-linear-gradient(to bottom,var(--color-bg-input) 0,var(--color-bg-input) 1px,transparent 1px,transparent 30px);border-color:var(--color-gray-300)}[data-theme=dark] .alert{border-width:1px}[data-theme=dark] .alert--info{background-color:#1a365d;color:#ebf8ff;border-color:#2c5282}[data-theme=dark] .alert--success{background-color:#1c3329;color:#e6fffa;border-color:#276749}[data-theme=dark] .alert--warning{background-color:#422a19;color:ivory;border-color:#744210}[data-theme=dark] .alert--error{background-color:#4c1d1d;color:#fff;border-color:#7f1d1d}[data-theme=dark] .patient-info-item .patient-info-value{color:var(--color-gray-900)}[data-theme=dark] .pet-code{background:#1e3a2f;border-color:#2d5a47}[data-theme=dark] .pet-code__label-chip,[data-theme=dark] .pet-code__value-chip{background:#234d3d;color:#fff}[data-theme=dark] .pet-code__hint{background:#2d5a47;border-color:#3d7a5f;color:#fff}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{overflow-x:hidden;max-width:100vw;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);background:var(--color-bg);background-color:var(--color-bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font-size:1.875rem;font-weight:600;letter-spacing:.01em;color:var(--color-gray-800)}h2{font-size:1.5rem;font-weight:600;color:var(--color-gray-800)}h3{font-size:1.25rem;font-weight:600;color:var(--color-gray-800)}h4{font-size:1rem;font-weight:600;color:var(--color-gray-800)}.pet-code__label{align-items:center;color:#0f5132;display:inline-flex;font-size:13px;font-weight:700;gap:var(--space-1)}.pet-code__value{color:#065f46;font-family:monospace;font-weight:700;letter-spacing:.02em}.auth-container{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);display:flex;justify-content:center;min-height:100vh;padding:var(--space-5)}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:transparent}.flex-1{flex:1 1 0%;min-width:0}.app-header{background:var(--header-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--color-gray-200)}.app-header__inner{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-4)}.app-header__top{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0}.app-header-inner{max-width:var(--layout-max-width);margin:0 auto;padding:0 var(--space-4)}.app-top-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0}.app-logo-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.app-logo{display:flex;align-items:center;gap:var(--space-2);font-weight:700;font-size:1.43rem;text-decoration:none;color:var(--color-primary);transition:opacity var(--transition-fast)}.app-logo:hover{opacity:.8}.app-logo__mark{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.43rem;font-weight:var(--font-weight-bold)}.app-logo--compact{font-size:28px}.app-logo-mark{width:36px;height:36px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.app-user-menu{display:flex;align-items:center;gap:var(--space-3)}.user-profile-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.user-profile-btn:hover{background:var(--color-gray-100);border-color:var(--color-gray-300)}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs)}.user-avatar-small{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}.app-nav{display:flex;gap:var(--space-1);padding-bottom:var(--space-2);overflow-x:auto;scrollbar-width:none}.app-nav::-webkit-scrollbar{display:none}.app-nav.mobile-open{display:flex}.nav-link{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--color-gray-500);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-decoration:none;white-space:nowrap;transition:all var(--transition-base);border-bottom:2px solid transparent}.nav-link:hover{color:var(--color-primary);background:var(--color-gray-50)}.nav-link--active{color:var(--color-primary);background:var(--color-bg-page);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.nav-link.active{color:var(--color-primary);background:var(--color-bg);border-bottom-color:var(--color-primary);font-weight:600}.mobile-menu-btn{display:none;padding:var(--space-2);background:transparent;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-xl);line-height:1}.page{flex:1;background:transparent;margin-top:var(--space-1);box-shadow:0 -2px 10px #0000000d;padding:var(--space-6) 0}.page-inner{max-width:var(--layout-max-width);margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-10)}.page-inner.page-narrow{max-width:var(--layout-max-width)}.page__inner{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-4)}.page-title{margin:0 0 var(--space-4);font-size:1.5rem;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap}.ai-page-header{flex-direction:column;align-items:flex-start;gap:var(--space-1);margin-bottom:var(--space-4)}.ai-page-header .page-subtitle{margin:0;color:var(--color-gray-600)}.records-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center;margin-bottom:var(--space-4)}.records-actions__primary{display:flex;gap:var(--space-2)}.records-actions__secondary{display:flex;gap:var(--space-2);flex-wrap:wrap}.records-actions__filters{margin-top:var(--space-3);justify-content:flex-start}.sticky-actions{position:sticky;top:var(--space-3);z-index:5;background:var(--color-bg);padding:var(--space-2) 0}.page-subtitle{font-size:14px;color:var(--color-gray-600);margin-top:calc(var(--space-2) * -1);margin-bottom:var(--space-4)}.support-banner{margin:0 auto;max-width:var(--layout-max-width);width:100%}.support-banner__inner{background:linear-gradient(to right,#4caf500d,#4caf501a);border-bottom:1px solid rgba(76,175,80,.1);border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-2) var(--space-4);display:flex;justify-content:center}.support-link{color:#2e7d32;font-weight:var(--font-weight-medium);text-decoration:none;display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);transition:opacity var(--transition-base)}.support-link:hover{opacity:.8;text-decoration:underline}@media (min-width: 768px){.support-banner__inner{justify-content:flex-end}}.support-banner+.page{margin-top:0;padding-top:var(--space-2)}.relative{position:relative}.h-full{height:100%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.form-field input,.form-field select,.form-field textarea{background:var(--color-bg-input);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);color:var(--color-gray-800);font-size:14px;padding:var(--space-3);transition:all .2s ease;width:100%}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.form-field__input,.form-field__select,.form-field__textarea{background:var(--color-bg-input);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-900);font-family:inherit;font-size:var(--font-size-base);padding:var(--space-3);transition:all var(--transition-base)}.form-field__input:focus,.form-field__select:focus,.form-field__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.btn--sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn--lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-lg)}.btn--icon{width:32px;height:32px;padding:0;background:var(--color-bg-card);border:1px solid var(--color-gray-200);color:var(--color-gray-600);box-shadow:var(--shadow-sm)}.btn--icon:hover{background:var(--color-gray-50);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 2px 6px #667eea26;transform:translateY(-1px)}.btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;box-shadow:0 4px 14px #667eea66}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea66}.btn--secondary{background:var(--color-bg-card);color:var(--color-gray-700);border:2px solid var(--color-gray-300);box-shadow:var(--shadow-sm)}.btn--secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 4px 12px #667eea26}.btn--danger{background:#fef2f2;color:var(--color-error);border:2px solid #fee2e2;box-shadow:0 2px 6px #dc26261a}.btn--danger:hover:not(:disabled){background:#fee2e2;border-color:#fecaca;box-shadow:0 4px 12px #dc262633}.btn--link{background:none;border:none;color:var(--color-primary);padding:var(--space-1) var(--space-2);box-shadow:none}.btn--link:hover:not(:disabled){color:var(--color-primary-dark);text-decoration:underline}.btn--link.btn--danger{color:var(--color-error)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;background:linear-gradient(135deg,#5568d3,#653a8f);color:#fff;border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 4px 14px #667eea66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea66}.btn-primary:disabled{background:var(--color-gray-300);cursor:not-allowed;opacity:.6;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;background:var(--color-bg-card);color:var(--color-gray-700);border:2px solid var(--color-gray-300);border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 6px #0000000d}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:#667eea;color:#667eea;box-shadow:0 4px 12px #667eea26}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;background:#fef2f2;color:var(--color-error-dark);border:2px solid #fee2e2;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #dc26261a}.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#fecaca;box-shadow:0 4px 12px #dc262633}.btn-link{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:none;border:none;color:#667eea;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-link:hover:not(:disabled){color:#5a67d8;text-decoration:underline}.btn-link.danger{color:var(--color-error)}.btn-link.danger:hover:not(:disabled){color:var(--color-error-dark)}.btn-sm{padding:6px 14px;font-size:13px}.icon-btn{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:var(--color-bg-card);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-600);font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.icon-btn:hover{background:var(--color-gray-50);border-color:#667eea;color:#667eea;box-shadow:0 2px 6px #667eea26;transform:translateY(-1px)}.card{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-300);margin-bottom:var(--space-4)}.card__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.card__title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.card__subtitle{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--space-1)}.card__body{padding:var(--space-4)}.card--info{background:var(--color-info-light);border-color:#bfdbfe}.card--success{background:var(--color-success-light);border-color:#86efac}.card--warning{background:var(--color-warning-light);border-color:#fde68a}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.card-title{font-size:16px;font-weight:600;color:var(--color-gray-800)}.card-subtitle{font-size:13px;color:var(--color-gray-500)}.card-body{padding:var(--space-5)}.card--danger{border-color:#e53e3e4d}.card--danger .card-header{background:#fef2f2;border-bottom-color:#e53e3e33}.card--danger .card-title{color:var(--color-error)}.pet-code__label{display:inline-flex;align-items:center;gap:var(--space-1);font-weight:700;color:#0f5132;font-size:13px}.pet-code__value{font-weight:700;color:#065f46;font-family:monospace;letter-spacing:.02em}.form-field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.form-field__label{color:var(--color-gray-700);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.form-field__hint{font-size:var(--font-size-xs);color:var(--color-gray-500)}.form-field__error{font-size:var(--font-size-xs);color:var(--color-error)}.form-field__textarea{padding:var(--space-3);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-gray-900);background:var(--color-bg-input);transition:all var(--transition-base);font-family:inherit}.form-field__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.form-field label{color:var(--color-gray-600);font-weight:500;font-size:14px}.form-field input,.form-field select,.form-field textarea,.form-field__input,.form-field__select,.form-field__textarea{padding:var(--space-3);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);font-size:14px;color:var(--color-gray-800);background:var(--color-bg-input);transition:all .2s ease;width:100%;font-family:inherit}.form-field input:focus,.form-field select:focus,.form-field textarea:focus,.form-field__input:focus,.form-field__select:focus,.form-field__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.form-field input:disabled,.form-field select:disabled{background:var(--color-gray-100);cursor:not-allowed}.form-field select:disabled{background:var(--color-gray-100);cursor:not-allowed}.form-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);align-items:end}.entry-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:var(--space-3);align-items:end}.settings-form{display:flex;flex-direction:column;gap:var(--space-4);max-width:500px}.vet-add-form{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);align-items:end}.ai-form,.records-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3);align-items:end}.top-panel{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.top-panel-card{background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200)}.top-panel-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.pet-avatar{width:46px;height:46px;border-radius:50%;background:conic-gradient(from 160deg,#fb7185,#f97316,#facc15,#fb7185);padding:2px;flex-shrink:0}.pet-avatar-inner{width:100%;height:100%;border-radius:50%;background:#0f172a;display:flex;align-items:center;justify-content:center;color:#e5e7eb;font-weight:600;font-size:24px}.pet-avatar--large{width:56px;height:56px}.pet-avatar--large .pet-avatar-inner{font-size:32px}.pet-main{flex:1;min-width:0}.pet-name-row{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-1)}.pet-name{font-size:16px;font-weight:600;color:var(--color-gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pet-age{font-size:13px;color:var(--color-gray-500)}.pet-meta{font-size:13px;color:var(--color-gray-600);margin-bottom:var(--space-2)}.pet-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag-pill{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#eef2ff;color:#4c51bf;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:var(--space-1)}.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--color-success)}.pet-actions{margin-left:auto;display:flex;flex-direction:column;gap:var(--space-1);align-items:flex-end}.top-panel-right-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.period-block{min-width:0}.period-label{font-size:12px;color:var(--color-gray-500);margin-bottom:var(--space-1);font-weight:500}.pill-group{display:inline-flex;border-radius:var(--radius-full);background:var(--color-gray-200);padding:2px;gap:2px;overflow-x:auto;max-width:100%;width:fit-content;scrollbar-width:none}@media (max-width: 768px){.pill-group{border-radius:var(--radius-lg);width:100%;flex-wrap:wrap}}.pill-group::-webkit-scrollbar{display:none}.pill{border:none;background:transparent;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:inherit;color:var(--color-gray-700);cursor:pointer;white-space:nowrap;transition:all var(--transition-base)}.pill:hover{color:var(--color-gray-800)}.pill--active{background:var(--color-bg-card);color:var(--color-primary);font-weight:var(--font-weight-semibold);box-shadow:0 0 0 1px #667eea59}.notes-cell{max-width:200px;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.chart-placeholder{height:280px;border-radius:var(--radius-xl);background:repeating-linear-gradient(to bottom,#f7fafc 0,#f7fafc 1px,transparent 1px,transparent 30px);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--color-gray-500);margin-bottom:var(--space-4);border:1px solid var(--color-gray-200)}.metrics-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}.metric{padding:var(--space-3);border-radius:var(--radius-lg);background:var(--color-gray-50);border:1px solid var(--color-gray-200)}.metric-label{font-size:12px;color:var(--color-gray-500);margin-bottom:var(--space-1);font-weight:500}.metric-value{font-weight:600;font-size:16px;color:var(--color-gray-800)}.metric--good .metric-value{color:var(--color-success)}.metric--bad .metric-value{color:var(--color-error)}.chart-actions{margin-top:var(--space-4);display:flex;flex-wrap:wrap;gap:var(--space-2)}.share-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center}.share-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;border:none}.share-modal__content{position:relative;background:var(--color-bg-card);width:min(620px,96vw);max-height:92vh;overflow-y:auto;border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000002e;padding:var(--space-5);z-index:1;display:flex;flex-direction:column;gap:var(--space-4)}.share-modal__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.share-modal__eyebrow{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--color-gray-500);margin-bottom:var(--space-1)}.share-modal__title{margin:0;font-size:22px;color:var(--color-gray-900)}.share-modal__close{border:none;background:var(--color-gray-100);color:var(--color-gray-600);border-radius:var(--radius-md);width:32px;height:32px;font-size:18px;cursor:pointer;transition:all var(--transition-base)}.share-modal__close:hover{background:var(--color-gray-200);color:var(--color-gray-900)}.share-modal__body{display:flex;flex-direction:column;gap:var(--space-4)}.share-modal__subtitle{margin:0;color:var(--color-gray-700);line-height:1.6}.share-modal__label{display:block;margin-bottom:var(--space-2);color:var(--color-gray-700);font-weight:600}.share-modal__input{width:100%;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-bg-input);color:var(--color-gray-900)}.share-modal__input:disabled{background:var(--color-gray-50)}.share-modal__input--mono{font-family:var(--font-family-mono);letter-spacing:.02em}.share-modal__date-range{display:flex;gap:var(--space-2);align-items:center}.share-modal__divider{color:var(--color-gray-500)}.share-modal__actions{display:flex;gap:var(--space-2);justify-content:flex-end}.share-modal__actions .btn{min-width:160px}.share-modal__actions--footer{justify-content:center}.share-result__banner{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-3);background:var(--color-success-light);border-radius:var(--radius-lg);border:1px solid #bbf7d0}.share-result__icon{font-size:22px}.share-result__title{margin:0;font-weight:700;color:var(--color-gray-900)}.share-result__subtitle{margin:0;color:var(--color-gray-600)}.share-card{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.share-card__section{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-3);background:var(--color-gray-50);display:flex;flex-direction:column;gap:var(--space-3)}.share-card__title{margin:0;font-size:15px;font-weight:700;color:var(--color-gray-800)}.share-card__qr{display:flex;justify-content:center;padding:var(--space-3);background:#fff;border:1px dashed var(--color-gray-200);border-radius:var(--radius-md)}.copy-input-wrapper{display:flex;gap:var(--space-2);flex-wrap:wrap}.copy-input-wrapper .share-modal__input{flex:1;min-width:220px}.share-modal__copy{min-width:200px}.share-modal__copy--success{background:var(--color-success);border-color:var(--color-success);color:#fff}.share-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-2)}.share-meta__item{padding:var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-gray-50)}.pet-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-3)}.pet-card{padding:var(--space-4);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);background:var(--color-bg-card);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3)}.pet-card__header{display:flex;justify-content:space-between;gap:var(--space-3);align-items:flex-start}.pet-card__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.04em;color:var(--color-gray-500);font-size:12px;font-weight:700}.pet-card__title{margin:2px 0 var(--space-1);font-size:1.1rem;color:var(--color-gray-900)}.pet-card__tags{display:flex;gap:var(--space-1);flex-wrap:wrap}.pet-card__meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);color:var(--color-gray-500);font-size:13px}.pet-card__created{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);padding:6px 10px}.pet-card__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-2)}.pet-card__item{background:var(--color-bg-card);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);min-height:72px}.pet-card__item--wide{grid-column:1 / -1}.pet-card__label{font-size:12px;letter-spacing:.02em;text-transform:uppercase;color:var(--color-gray-500)}.pet-card__value{color:var(--color-gray-800);font-weight:600;line-height:1.5}.pet-card__actions{display:flex;justify-content:flex-end;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.pet-management-header{display:flex;align-items:center;gap:var(--space-2);width:100%;justify-content:space-between}.pet-add-btn{margin-left:auto}.pet-management-header .card__title{margin:0}@media (max-width: 640px){.pet-management-header{flex-direction:column;align-items:stretch}.pet-add-btn{margin-left:0;width:100%}}.pet-code{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);width:fit-content;border-radius:var(--radius-lg);background:#ecfdf3;border:1px solid #bbf7d0;position:relative;cursor:help}.pet-code__label-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:6px 10px;border-radius:var(--radius-md);background:#d1fae5;color:#064e3b;font-weight:700;font-size:13px;letter-spacing:.01em}.pet-code__value-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-md);background:#d1fae5;color:#065f46;font-weight:800;font-family:monospace;letter-spacing:.03em}.pet-code__hint{width:18px;height:18px;border-radius:50%;background:#a7f3d0;border:1px solid #6ee7b7;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#064e3b}.pet-code:after{content:attr(data-tooltip);position:absolute;left:0;right:0;bottom:calc(100% + 6px);margin:0 auto;padding:var(--space-2) var(--space-3);background:#0f172a;color:#e2e8f0;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:12px;line-height:1.4;max-width:min(280px,calc(100vw - 32px));width:max-content;white-space:normal;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:5}.pet-code:hover:after,.pet-code:focus-visible:after{opacity:1;transform:translateY(0)}.pet-code__copy{background:#0f5132;color:#ecfdf3;border:1px solid rgba(15,81,50,.25);border-radius:var(--radius-full);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease}.pet-code__copy:hover{background:#0b3b24;box-shadow:0 4px 12px #065f4633}.pet-code__copy:active{transform:translateY(1px)}.pet-code--vet{background:#e0f2fe;border-color:#bfdbfe}.pet-code--vet .pet-code__label-chip,.pet-code--vet .pet-code__value-chip{background:#dbeafe;color:#1e3a8a}.pet-code--vet .pet-code__hint{background:#bfdbfe;border-color:#93c5fd;color:#1e40af}.pet-code__copy--vet{background:#1e3a8a;border-color:#1e40af40}.pet-code__copy--vet:hover{background:#1d4ed8;box-shadow:0 4px 12px #3b82f633}@media (max-width: 640px){.pet-code{flex-wrap:wrap;width:100%;justify-content:center}.pet-code__label-chip,.pet-code__value-chip{flex:1 1 100%;justify-content:center}}.captcha-loading{padding:var(--space-2);margin:var(--space-2) 0;text-align:center;color:var(--color-gray-600);font-size:14px}.captcha-dev{padding:var(--space-2);margin:var(--space-2) 0;background-color:var(--color-warning-light);border:1px solid #ffc107;border-radius:var(--radius-sm);color:#856404;font-size:.85rem;text-align:center}.captcha-wrapper{display:flex;justify-content:center;margin:var(--space-4) 0}.captcha-container{min-height:100px}.btn--fullwidth{width:100%}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-3{margin-top:var(--space-3)}.mt-5{margin-top:var(--space-5)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.text-strong{font-weight:600}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:12px}.text-muted{color:var(--color-gray-600)}.link-plain{text-decoration:none;color:inherit}.stack-col{display:flex;flex-direction:column}.gap-3{gap:var(--space-3)}.auth-success-icon{font-size:3rem;margin:0}.auth-link-block{display:block;text-align:center;margin-top:var(--space-5)}.nav-link--disabled{opacity:.5;cursor:not-allowed}.user-profile-btn--disabled{cursor:not-allowed;opacity:.6}.nav-link--button{border:none;background:none;text-align:left}.nav-link--danger{color:var(--color-error)}.chart-container{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6);width:100%;position:relative;z-index:1}.chart-mobile-title{margin:0 0 1rem;font-size:1.125rem;color:#667eea}.chart-plot{width:100%;margin-bottom:12px;min-height:650px}.chart-plot--mobile{margin-bottom:20px;min-height:360px}@media (min-width: 641px) and (max-width: 1024px){.chart-plot:not(.chart-plot--mobile){min-height:550px}}.weight-stats-summary{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0;border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.weight-stats-row{display:flex;flex-wrap:wrap;gap:var(--space-4)}.weight-stats-row--secondary{padding-top:var(--space-2);border-top:1px solid rgba(167,243,208,.5)}.weight-stat-item{display:flex;align-items:baseline;gap:var(--space-1)}.weight-stat-item--small{font-size:14px}.weight-stat-label{color:#065f46;font-weight:500;font-size:14px}.weight-stat-value{color:#064e3b;font-weight:700;font-size:16px}.weight-stat-value--primary{font-size:20px}@media (max-width: 640px){.weight-stats-summary{padding:var(--space-2)}.weight-stats-row{flex-direction:column;gap:var(--space-2)}.weight-stat-item{justify-content:space-between;width:100%}.weight-stat-value--primary{font-size:18px}}.password-strength{display:grid;gap:var(--space-2);margin-top:var(--space-2)}.password-strength__bar{height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.password-strength__fill{height:100%;border-radius:inherit;transition:width .2s ease}.password-strength__fill--0{width:0%}.password-strength__fill--25{width:25%}.password-strength__fill--50{width:50%}.password-strength__fill--75{width:75%}.password-strength__fill--100{width:100%}.password-strength__text{font-weight:600}.password-strength--empty .password-strength__fill,.password-strength--empty .password-strength__text{background:#718096;color:var(--color-gray-900)}.password-strength--weak .password-strength__fill,.password-strength--weak .password-strength__text{background:#dc2626;color:#fff}.password-strength--medium .password-strength__fill,.password-strength--medium .password-strength__text{background:#f59e0b;color:var(--color-gray-900)}.password-strength--strong .password-strength__fill,.password-strength--strong .password-strength__text{background:#16a34a;color:#052e16}.share-meta__label{display:block;color:var(--color-gray-600);margin-bottom:var(--space-1)}.share-meta__value{font-weight:700;color:var(--color-gray-900)}.pwa-modal__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0;color:var(--color-gray-900)}.pwa-modal__subtitle{font-size:.95rem;color:var(--color-gray-600);margin:0 0 var(--space-4)}.pwa-step-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-3)}.pwa-step{display:flex;gap:var(--space-3);padding:var(--space-3);background:#f0f7ff;border-left:4px solid #667eea;border-radius:var(--radius-lg)}.pwa-step__number{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:#5568d3;color:#fff;border-radius:var(--radius-md);font-weight:700;font-size:1rem}.pwa-step__text{flex:1;align-self:center;color:var(--color-gray-800);line-height:1.5}.pwa-benefits{margin-top:var(--space-5);padding:var(--space-3);background:var(--color-warning-light);border-left:4px solid #fbbf24;border-radius:var(--radius-lg)}.pwa-benefits__title{font-size:.95rem;color:#92400e;margin:0 0 var(--space-2);font-weight:700}.pwa-benefits__list{font-size:.9rem;color:#78350f;margin:0;padding-left:1.2rem;line-height:1.6;display:grid;gap:var(--space-1)}.pwa-modal__actions{display:flex;justify-content:center!important;margin-top:var(--space-4)}.pwa-modal__close-btn{width:100%;max-width:400px;padding:.875rem 1.5rem}.profile-header{display:flex;justify-content:space-between;align-items:flex-start}.profile-header__eyebrow{margin:0 0 var(--space-1);text-transform:uppercase;letter-spacing:.04em;color:var(--color-gray-500);font-size:12px;font-weight:700}.profile-header__title{margin:0;font-size:1.25rem;color:var(--color-gray-900)}.profile-summary{display:flex;flex-direction:column;gap:var(--space-3)}.profile-summary__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.profile-summary__item{background:var(--color-bg-input);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.profile-summary__label{text-transform:uppercase;color:var(--color-gray-500);letter-spacing:.04em;font-size:12px;font-weight:700}.profile-summary__value{color:var(--color-gray-900);font-weight:600;line-height:1.5}.profile-summary__actions{display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.only-mobile{display:none}@media (max-width: 900px){.only-mobile{display:inline-flex}}.ai-request-card{margin-bottom:var(--space-4)}.ai-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-3);align-items:flex-end}.ai-form-grid--request{grid-template-columns:minmax(280px,1fr) minmax(0,2fr) auto;gap:var(--space-4);align-items:stretch}.ai-request-card .card__body{background:var(--color-bg-card)}.ai-form-field{display:flex;flex-direction:column;gap:var(--space-2)}.ai-form-field--wide textarea{min-height:140px;resize:vertical}.ai-actions{display:flex;justify-content:flex-end;width:100%;align-self:end}.ai-actions .btn{min-width:200px;max-width:240px;width:100%}.verdict-header{display:flex;justify-content:space-between;gap:var(--space-3);align-items:flex-start}.result-period{margin-top:var(--space-1);color:var(--color-gray-600)}.verdict-eyebrow{margin:0;text-transform:uppercase;letter-spacing:.04em;color:var(--color-gray-500);font-size:12px;font-weight:700}.verdict-header h3{margin:2px 0 0;font-size:1.25rem;color:var(--color-gray-900)}.verdict-subtitle{margin:var(--space-1) 0 0;color:var(--color-gray-600)}.verdict-meta{display:flex;gap:var(--space-2);flex-wrap:wrap}.results-card{margin-top:var(--space-4)}.analysis-result{background:var(--color-bg-card);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--space-4);line-height:1.6;color:var(--color-gray-800);box-shadow:var(--shadow-sm)}.analysis-result.has-error{border-color:var(--color-warning);background:var(--color-warning-light)}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}.analysis-section{display:flex;flex-direction:column;gap:var(--space-2)}.analysis-section__title{margin:0;font-size:15px;font-weight:700;color:var(--color-gray-800)}.analysis-section__text{margin:0;color:var(--color-gray-700);line-height:1.6;font-size:14px;white-space:pre-wrap}.analysis-section__list{margin:var(--space-2) 0 0;padding-left:var(--space-4);display:grid;gap:var(--space-2);color:var(--color-gray-700);line-height:1.6;font-size:14px}.analysis-list--numbered{list-style:decimal;padding-left:var(--space-5)}.analysis-list--bulleted{list-style:disc}.analysis-section__list li{margin:0}.results-card .analysis-result{margin-top:var(--space-3)}.analysis-placeholder{padding:var(--space-4);border:1px dashed var(--color-gray-300);border-radius:var(--radius-lg);background:var(--color-gray-50)}.analysis-placeholder__note{margin-top:var(--space-1);color:var(--color-gray-600)}.answer-to-question{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #7dd3fc;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0ea5e914}.answer-to-question__icon{font-size:24px;line-height:1;flex-shrink:0}.answer-to-question__content{flex:1;min-width:0}.answer-to-question__title{font-size:15px;font-weight:600;color:var(--color-gray-900);margin-bottom:var(--space-2)}.answer-to-question__text{font-size:14px;line-height:1.6;color:var(--color-gray-800);margin:0}.analysis-disclaimer{display:flex;gap:var(--space-2);margin-top:var(--space-3);font-size:13px;color:var(--color-gray-600);background:var(--color-bg-card);border:1px solid #fed7aa;border-radius:var(--radius-md);padding:var(--space-3)}.analysis-disclaimer__icon{font-size:20px;line-height:1.2}.analysis-disclaimer__text{margin:var(--space-1) 0 0;color:var(--color-gray-700);line-height:1.5}.analysis-disclaimer__list{margin:var(--space-2) 0 0;padding-left:var(--space-4);color:var(--color-gray-700);display:grid;gap:var(--space-1)}.meta-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-full);background:var(--color-gray-100);color:var(--color-gray-700);font-weight:700;font-size:12px}.meta-chip--muted{background:var(--color-gray-50);color:var(--color-gray-500)}.meta-chip--warning{background:#fef3c7;color:#b45309}.share-container,.share-container-wide{max-width:1180px;margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-10)}.share-container{max-width:720px}.share-hero{text-align:center;margin-bottom:var(--space-6)}.share-hero__title{font-size:28px;color:var(--color-primary);margin-bottom:var(--space-2);font-weight:800}.share-hero__subtitle{color:var(--color-gray-600);font-size:16px}.language-switcher{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);background:#f8fbff;border:1px solid #e5eaf5;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg)}.share-card-surface{background:var(--color-bg-card);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md)}.share-captcha{display:flex;flex-direction:column;gap:var(--space-4);align-items:center;text-align:center}.share-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.share-stat-card{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background:var(--color-bg-card);box-shadow:var(--shadow-sm)}.share-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.share-pet-info{border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);background:var(--color-bg-card);box-shadow:var(--shadow-sm)}.share-tabs{display:flex;gap:var(--space-2);padding:var(--space-2);background:var(--color-gray-100);border-radius:var(--radius-xl);overflow-x:auto;margin-bottom:var(--space-6)}.share-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:transparent;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:14px;color:var(--color-gray-600);cursor:pointer;transition:all .2s ease;white-space:nowrap}.share-tab:hover{background:#ffffff80;color:var(--color-gray-800)}.share-tab--active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:var(--shadow-sm)}.share-tab__badge{background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:999px;min-width:20px;text-align:center}.share-tab--active .share-tab__badge{background:var(--color-primary-dark)}@media (max-width: 640px){.share-tabs{gap:var(--space-1)}.share-tab{padding:var(--space-2) var(--space-3);font-size:13px}}.share-stats-card__label{color:var(--color-gray-500);font-size:13px}.share-stats-card__value{color:var(--color-gray-900);font-weight:800;font-size:26px}.chart-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.chart-stat{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-sm);text-align:center}.chart-stat__label{margin:0 0 var(--space-2) 0;color:var(--color-gray-600);font-weight:600}.chart-stat__value{margin:0;font-size:22px;font-weight:800;color:var(--color-gray-900)}.chart-stat__sub{margin:var(--space-2) 0 0 0;color:var(--color-gray-600);font-size:13px}.chart-stat--accent{background:var(--color-bg-input);border:1px solid var(--color-success)}.chart-stat__value--accent{color:var(--color-success);font-size:24px}@media (max-width: 640px){.chart-stats{grid-template-columns:1fr}.app-shell,.app-header,.app-header__inner,.page,.page-inner,.page__inner,.card,.card__body,.card-body,.form-grid,.entry-form{max-width:100vw!important;overflow-x:hidden!important}.card{margin-left:0!important;margin-right:0!important}.form-field,.form-field input,.form-field select,.form-field textarea{max-width:100%!important}.pill-group{max-width:calc(100vw - 2rem)!important}}.share-table{overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm)}.share-table table{width:100%;border-collapse:collapse}.share-table th,.share-table td{padding:var(--space-3);border-bottom:1px solid var(--color-gray-200)}.share-table thead{background:var(--color-gray-50);text-transform:uppercase;font-size:12px;color:var(--color-gray-600)}@media (max-width: 640px){.share-table table{min-width:0;font-size:11px}.share-table th,.share-table td{padding:var(--space-1) 4px;font-size:11px}.share-table thead{font-size:9px}.share-table th{padding:var(--space-1) 4px}}.share-footer{border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);background:var(--color-bg-card);box-shadow:var(--shadow-sm)}@media (max-width: 640px){.page-inner,.page__inner{padding:var(--space-5) var(--space-3) var(--space-8);max-width:100%}}@media (max-width: 640px){.share-modal__content{padding:var(--space-4)}.share-modal__actions{flex-direction:column;align-items:stretch}.share-modal__actions .btn{width:100%}}.action-buttons--chart{display:flex;gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap}.action-buttons--chart .action-btn{flex:1;min-width:200px}.action-buttons--chart .action-btn--share{background:var(--color-bg-card);border-color:var(--color-primary);color:var(--color-primary)}.action-buttons--chart .action-btn--share:hover{background:var(--color-bg-page);border-color:var(--color-primary);color:var(--color-primary)}.action-buttons--chart .action-btn--manage{background:var(--color-bg-card);border-color:var(--color-success);color:var(--color-success)}.action-buttons--chart .action-btn--manage:hover{background:var(--color-bg-page);border-color:var(--color-success);color:var(--color-success)}@media (max-width: 640px){.action-buttons--chart{flex-direction:column}.action-buttons--chart .action-btn{width:100%;min-width:0}}.table-wrapper,.table-container{width:100%;overflow-x:auto}.table-container table{min-width:640px}table{width:100%;min-width:640px;border-collapse:collapse;font-size:14px}thead{background:var(--color-gray-50)}th{padding:var(--space-3) var(--space-2);text-align:left;font-size:12px;font-weight:600;color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-gray-200)}td{padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-700)}@media (max-width: 640px){th,td{padding:var(--space-2) var(--space-1)}}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--color-gray-50)}.table-actions{display:flex;gap:var(--space-2);justify-content:flex-start}.link-more{margin-top:var(--space-3);font-size:13px;color:var(--color-primary);font-weight:600;cursor:pointer;text-align:center}.link-more:hover{text-decoration:underline}.badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:12px;font-weight:600;display:inline-block}.badge--admin{background:#fee2e2;color:var(--color-error-dark)}.badge--user{background:#dbeafe;color:#1e40af}.badge--vet{background:#d1fae5;color:#065f46}.admin-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);border-bottom:2px solid var(--color-gray-200);overflow-x:auto}.admin-tab{padding:var(--space-3) var(--space-5);border:none;background:transparent;font-size:14px;font-weight:500;color:var(--color-gray-600);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .2s ease}.admin-tab:hover{color:var(--color-primary)}.admin-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-gray-200)}.pagination-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);background:var(--color-bg-card);font-size:14px;font-weight:500;color:var(--color-gray-700);cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:14px;color:var(--color-gray-600)}.message{padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);font-size:14px;font-weight:500}.message.success{background:#d1fae5;color:#065f46;border:2px solid #10b981}.message.error{background:#fee2e2;color:var(--color-error-dark);border:2px solid var(--color-error)}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);z-index:9999}.loading-screen__card{background:var(--color-bg-card);border-radius:var(--radius-2xl);padding:var(--space-10);box-shadow:0 24px 60px #0f172a4d;display:flex;flex-direction:column;align-items:center;gap:var(--space-6);min-width:280px;text-align:center}.loading-screen__icon{font-size:48px;line-height:1;animation:float 3s ease-in-out infinite}.loading-screen__text{display:flex;flex-direction:column;gap:var(--space-2)}.loading-screen__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin:0}.loading-screen__subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}.loading-screen__spinner{width:32px;height:32px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px;gap:var(--space-4);padding:var(--space-8);background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-600);text-align:center}.loading:before{content:"🐾";font-size:40px;line-height:1;animation:float 3s ease-in-out infinite;display:block;order:-1}.loading:after{content:"";width:32px;height:32px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;display:block;order:1}.no-data{text-align:center;padding:var(--space-10) var(--space-5);color:var(--color-gray-500)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);background:#f3f4ff;color:#1e3a8a;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.tag__dot{width:6px;height:6px;border-radius:50%;background:var(--color-success)}.tag--warning{background:var(--color-warning-light);color:#92400e}.tag--success{background:var(--color-success-light);color:#065f46}.tag--error{background:var(--color-error-light);color:#991b1b}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-5)}.info-item{display:flex;flex-direction:column;gap:var(--space-1)}.info-item__label{font-size:var(--font-size-xs);color:var(--color-gray-500);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.info-item__value{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.timeline{display:flex;flex-direction:column;gap:var(--space-4)}.timeline-item{padding-left:var(--space-5);border-left:3px solid var(--color-gray-200);position:relative}.timeline-item--active{border-left-color:var(--color-primary)}.timeline-item:before{content:"";position:absolute;left:-7px;top:4px;width:10px;height:10px;background:var(--color-gray-300);border-radius:50%}.timeline-item--active:before{background:var(--color-primary)}.timeline-item__date{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-bottom:var(--space-1)}.timeline-item__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--space-1)}.timeline-item__description{font-size:var(--font-size-sm);color:var(--color-gray-600);line-height:var(--line-height-relaxed)}.alert{padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.alert--info{background:var(--color-info-light);color:#1e40af;border:1px solid #bfdbfe}.alert--warning{background:var(--color-warning-light);color:#92400e;border:1px solid #fde68a}.alert--success{background:var(--color-success-light);color:#065f46;border:1px solid #86efac}.alert--error{background:var(--color-error-light);color:#991b1b;border:1px solid #fecaca}.resend-verification-btn{max-width:100%;word-wrap:break-word;white-space:normal;text-align:center;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}@media (max-width: 480px){.resend-verification-btn{font-size:.875rem;padding:var(--space-2) var(--space-3);line-height:1.4}}.search-bar{width:100%}.search-bar__wrapper{position:relative;display:flex;align-items:center}.search-bar__icon{position:absolute;left:var(--space-3);font-size:var(--font-size-lg);pointer-events:none;color:var(--color-gray-400)}.search-bar__input{width:100%;padding:var(--space-3) var(--space-10) var(--space-3) var(--space-10);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);font-size:var(--font-size-base);background:var(--color-bg-input);transition:all var(--transition-base)}.search-bar__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.search-bar__input::placeholder{color:var(--color-gray-400)}.search-bar__clear{position:absolute;right:var(--space-3);width:24px;height:24px;border:none;background:var(--color-gray-300);color:var(--color-gray-600);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;transition:all var(--transition-base)}.search-bar__clear:hover{background:var(--color-error);color:#fff}@media (max-width: 768px){.search-bar__input{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-8) var(--space-2) var(--space-8)}.search-bar__icon{font-size:var(--font-size-base)}}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-base)}.sortable-header:hover{background-color:var(--color-gray-100)}.sortable-header__content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.sortable-header__icon{font-size:var(--font-size-sm);opacity:.6;transition:opacity var(--transition-base)}.sortable-header:hover .sortable-header__icon{opacity:1}.tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-4);border-bottom:2px solid var(--color-gray-200);overflow-x:auto}.tabs__button{padding:var(--space-3) var(--space-4);border:none;background:transparent;color:var(--color-gray-600);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all var(--transition-base);font-family:inherit}.tabs__button:hover{color:var(--color-primary)}.tabs__button--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.tab-content{display:block}.patient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.patient-card{background:var(--color-bg-card);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-md);overflow:hidden}.patient-card__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.patient-card__info{flex:1}.patient-card__name{margin:0;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.patient-card__meta{font-size:var(--font-size-sm);color:var(--color-gray-600)}.patient-card__body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.patient-stat{display:flex;justify-content:space-between;font-size:var(--font-size-sm)}.patient-stat__label{color:var(--color-gray-600)}.patient-stat__value{font-weight:var(--font-weight-semibold)}.patient-card__footer{padding:var(--space-4);border-top:1px solid var(--color-gray-200)}.vet-list{display:flex;flex-direction:column;gap:var(--space-3)}.vet-card{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-4);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);gap:var(--space-3);flex-wrap:wrap}.vet-card__info{flex:1;min-width:200px}.vet-card__name{margin:0 0 var(--space-1);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.vet-card__clinic,.vet-card__contact,.vet-card__meta{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:var(--space-1) 0}.code-tag{background:var(--color-warning-light);padding:2px 6px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-family:var(--font-family-mono);font-weight:var(--font-weight-semibold);color:#92400e}.clinic-code{font-family:var(--font-family-mono);font-size:var(--font-size-sm);background:var(--color-gray-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.pwa-install-btn{display:none;width:100%;padding:var(--space-3);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);text-align:left;font-family:inherit}.pwa-install-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.pwa-install-btn:before{content:"📱 ";margin-right:var(--space-2)}@media (max-width: 768px){.pwa-install-btn{display:block}}.pwa-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;align-items:center;justify-content:center;padding:var(--space-4)}.pwa-modal.active{display:flex}.pwa-modal__content{background:var(--color-bg-card);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0000004d}.pwa-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);border-bottom:1px solid var(--color-gray-200)}.pwa-modal__close{width:32px;height:32px;border:none;background:var(--color-gray-100);color:var(--color-gray-600);border-radius:var(--radius-md);font-size:20px;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;font-family:inherit}.pwa-modal__close:hover{background:var(--color-gray-200);color:var(--color-gray-900)}.pwa-modal__body{padding:var(--space-5)}.pwa-instructions{margin:0;padding-left:var(--space-5);color:var(--color-gray-700);line-height:var(--line-height-relaxed)}.pwa-instructions li{margin-bottom:var(--space-2)}.pwa-instructions li:last-child{margin-bottom:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1;min-width:0}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.dashboard-top-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-4)}@media (min-width: 768px){.dashboard-top-grid{grid-template-columns:1fr 1fr}}.hidden{display:none}.w-full{width:100%}.mb-0{margin-bottom:0}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-900{color:var(--color-gray-900)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.table{width:100%;min-width:640px;border-collapse:collapse;font-size:var(--font-size-sm)}.table__head{background:var(--color-gray-50)}.table__head-cell{padding:var(--space-2) var(--space-2);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-gray-600);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-gray-200)}.table__cell{padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--color-gray-100)}@media (max-width: 640px){.table__head-cell,.table__cell{padding:var(--space-2) var(--space-1)}}.table__row:last-child .table__cell{border-bottom:none}.table__actions{display:flex;gap:var(--space-2)}.pagination__info{font-size:var(--font-size-sm);color:var(--color-gray-600)}.pet-code:focus-visible:after{opacity:1;transform:translateY(0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none;font-family:inherit}.btn--primary,.btn--link{border:none}.btn:disabled{opacity:.5;cursor:not-allowed}.pill:hover:not(:disabled){color:var(--color-gray-800);background:#ffffff80}.form-field input:focus-visible,.form-field select:focus-visible,.form-field textarea:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.btn--primary:disabled,.btn--secondary:disabled,.btn--danger:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.card--elevated{box-shadow:var(--shadow-lg)}.card--flat{box-shadow:none;border:1px solid var(--color-gray-200)}.btn--loading{position:relative;pointer-events:none;opacity:.7}.btn--loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.table__row:hover{background:var(--color-gray-50);transition:background var(--transition-fast)}.form-field--invalid .form-field__input,.form-field--invalid .form-field__select,.form-field--invalid .form-field__textarea{border-color:var(--color-error)}.form-field--valid .form-field__input,.form-field--valid .form-field__select,.form-field--valid .form-field__textarea{border-color:var(--color-success)}.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-modal-backdrop)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .3s ease-in-out}.animate-slide-in-up{animation:slideInUp .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.hide-on-mobile{display:block}.show-on-mobile{display:none}@media (max-width: 640px){.hide-on-mobile{display:none}.show-on-mobile{display:block}}.text-left{text-align:left}.d-none{display:none}.d-block{display:block}.date-range-filter{display:flex;flex-direction:column;gap:var(--space-4);background:var(--color-bg-card);padding:var(--space-4);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.date-range-filter__header{display:flex;flex-direction:column;gap:var(--space-2)}.date-range-filter__label{font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.date-range-filter__custom-panel{display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-gray-100);animation:slideDown .2s ease-out}.form-grid-pair{display:grid;grid-template-columns:1fr;gap:var(--space-3)}.form-label-sm{display:block;font-size:var(--font-size-xs);color:var(--color-gray-500);margin-bottom:var(--space-1);font-weight:600}.date-range-filter__actions{display:flex;justify-content:flex-end}.btn-full-mobile{width:100%}@media (min-width: 768px){.date-range-filter__custom-panel{flex-direction:row;align-items:flex-end}.date-range-filter__custom-panel .form-grid-pair{grid-template-columns:1fr 1fr;flex-grow:1;margin-bottom:0}.date-range-filter__custom-panel .form-group{margin-bottom:0}.date-range-filter__actions,.btn-full-mobile{width:auto}}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--space-5)}.auth-card{background:var(--color-bg-card);padding:var(--space-10);border-radius:var(--radius-2xl);box-shadow:0 24px 60px #0f172a4d;width:100%;max-width:420px}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--color-gray-200)}.auth-footer a:hover{text-decoration:underline}.auth-logo{text-align:center;margin-bottom:var(--space-6)}.auth-card h1{color:var(--color-primary);margin:0;font-size:2rem}.auth-card h2{text-align:center;margin-bottom:var(--space-6);color:var(--color-gray-700);font-size:1.25rem}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-footer{margin-top:var(--space-6);text-align:center;font-size:14px;color:var(--color-gray-600)}.auth-footer p{margin:var(--space-2) 0}.auth-footer a{color:var(--color-primary);text-decoration:none;font-weight:600}.auth-divider{margin:var(--space-6) 0;text-align:center;position:relative}.auth-divider span{position:relative;background:var(--color-bg-card);padding:0 var(--space-3);color:var(--color-gray-500);font-size:var(--font-size-sm)}.auth-actions{display:flex;flex-direction:column;gap:var(--space-3)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;font-size:14px;color:var(--color-gray-700);line-height:1.5;width:100%;max-width:100%}.checkbox-label.mb-4{margin-bottom:var(--space-4)}.checkbox-input{margin-top:4px;width:18px;height:18px;min-width:18px;cursor:pointer;flex-shrink:0;accent-color:var(--color-primary)}.checkbox-text{flex:1;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word;min-width:0;max-width:100%}.checkbox-text a{word-break:break-word}.verification-code{display:flex;gap:var(--space-2);justify-content:center;margin:var(--space-6) 0}.verification-code__input{width:48px;height:56px;text-align:center;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);transition:all var(--transition-base);font-family:var(--font-family-mono)}.verification-code__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}@media (max-width: 640px){.verification-code__input{width:40px;height:48px;font-size:var(--font-size-xl)}}.patient-grid,.pet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.patient-card{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);overflow:hidden;transition:all var(--transition-base);cursor:pointer}.patient-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.patient-card__header{padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--color-gray-200)}.patient-card__info{flex:1;min-width:0}.patient-card__name{margin:0 0 var(--space-1);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.patient-card__meta{margin:0;font-size:var(--font-size-sm);color:var(--color-gray-600)}.patient-card__body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.patient-stat{display:flex;justify-content:space-between;align-items:center}.patient-stat__label{font-size:var(--font-size-xs);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.patient-stat__value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.patient-card__footer{padding:var(--space-3) var(--space-4);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200)}.patient-card__footer .btn{width:100%}.page__title{margin:0 0 var(--space-2);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.page__subtitle{margin:0 0 var(--space-6);font-size:var(--font-size-base);color:var(--color-gray-600);line-height:var(--line-height-relaxed)}@media (max-width: 960px){.top-panel{grid-template-columns:minmax(0,1fr)}.pet-actions{align-items:flex-start;margin-left:0;margin-top:var(--space-2)}.entry-form,.metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.page-inner,.page__inner{padding:var(--space-4) var(--space-3) var(--space-8)}.mobile-menu-btn{display:block}.app-nav{display:none;flex-direction:column;gap:var(--space-1);padding:var(--space-3) 0;border-top:1px solid var(--color-gray-200)}.app-nav.mobile-open{display:flex}.nav-link{border-radius:var(--radius-lg);border-bottom:none;padding-left:var(--space-3);border-left:3px solid transparent}.nav-link--active,.nav-link.active{background:var(--color-primary-alpha, rgba(139, 92, 246, .12));border-left-color:var(--color-primary);color:var(--color-primary)}.entry-form{grid-template-columns:minmax(0,1fr)}.btn-primary{width:100%}.top-panel-right-inner{flex-direction:column;align-items:stretch}.pill-group{width:100%;max-width:100%;display:flex}.metrics-row{grid-template-columns:minmax(0,1fr)}.card-header{flex-direction:column;align-items:flex-start}.vet-add-form,.ai-form,.records-filters{grid-template-columns:1fr}.auth-card{padding:var(--space-6)}.checkbox-label{gap:var(--space-3);font-size:13px;line-height:1.5}.checkbox-input{width:20px;height:20px;min-width:20px;margin-top:2px}.checkbox-text{flex:1;min-width:0}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--space-6)}.error-content{text-align:center;max-width:500px;background:var(--color-bg-card);padding:var(--space-10);border-radius:var(--radius-2xl);box-shadow:0 24px 60px #0f172a4d}.error-cat{font-size:120px;margin-bottom:var(--space-4);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.error-title{margin:0 0 var(--space-2);font-size:72px;font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}.error-subtitle{margin:0 0 var(--space-4);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.error-text{margin:0 0 var(--space-6);font-size:var(--font-size-base);color:var(--color-gray-600);line-height:var(--line-height-relaxed)}.error-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}@media (max-width: 640px){.error-content{padding:var(--space-6)}.error-cat{font-size:80px}.error-title{font-size:56px}.error-actions{flex-direction:column}.error-actions .btn{width:100%}}.vet-code{font-family:var(--font-family-mono);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-success);background:#16a34a1a;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md)}.patient-cards{display:grid;gap:var(--space-4)}.patient-detail-card{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);overflow:hidden}.patient-detail-card__header{padding:var(--space-4);border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.patient-detail-card__name{margin:0 0 var(--space-1);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.patient-detail-card__owner{margin:0;font-size:var(--font-size-sm);color:var(--color-gray-600)}.patient-detail-card__body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.patient-detail-card__info{display:flex;gap:var(--space-4);flex-wrap:wrap}.patient-detail-card__label{font-size:var(--font-size-sm);color:var(--color-gray-700)}.patient-detail-card__glucose{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-gray-50);border-radius:var(--radius-md)}.patient-detail-card__glucose-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.patient-detail-card__glucose-value--high{color:var(--color-error)}.patient-detail-card__glucose-value--normal{color:var(--color-success)}.patient-detail-card__meta{font-size:var(--font-size-xs);color:var(--color-gray-500)}.patient-detail-card__footer{padding:var(--space-3) var(--space-4);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);display:flex;gap:var(--space-2);flex-wrap:wrap}.patient-info-title{margin:0 0 var(--space-4);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.patient-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.patient-info-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.patient-info-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em}.patient-info-value{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-900)}@media (max-width: 640px){.patient-info-grid{grid-template-columns:1fr}}@media (max-width: 1024px){.analysis-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.verdict-header{flex-direction:column;align-items:flex-start}.ai-actions{justify-content:stretch}.ai-actions .btn{width:100%;max-width:none}.ai-form-grid,.ai-form-grid--request{grid-template-columns:1fr}.ai-form-field--pet-period{gap:var(--space-3)}}@media (max-width: 640px){.patient-detail-card__footer{flex-direction:column}.patient-detail-card__footer .btn{width:100%}}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080;padding:var(--space-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:var(--color-bg-card);width:min(500px,100%);max-height:90vh;overflow-y:auto;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-5);position:relative;animation:modalSlideIn .2s ease-out;margin:auto}.modal-title{margin:0 0 var(--space-4);font-size:1.25rem;font-weight:600;color:var(--color-gray-900)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5)}.modal-actions--close{margin-top:var(--space-4);border-top:1px solid var(--color-gray-200);padding-top:var(--space-4)}.reminders-form-section{margin-bottom:var(--space-4)}.reminders-form-title{margin:0 0 var(--space-3);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800)}.reminders-divider{border:none;border-top:1px solid var(--color-gray-200);margin:var(--space-4) 0}.reminders-list{display:flex;flex-direction:column;gap:var(--space-2)}.reminders-empty{text-align:center;color:var(--color-gray-500);font-size:var(--font-size-sm);padding:var(--space-4)}.reminder-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.reminder-item__info{display:flex;flex-direction:column;gap:var(--space-1)}.reminder-item__header{display:flex;align-items:center;gap:var(--space-2)}.reminder-item__time{font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.reminder-item__days{font-size:var(--font-size-sm);color:var(--color-gray-500)}.reminder-item__type{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;padding:var(--space-0-5) var(--space-2);background:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-sm)}.reminder-item__message{font-size:var(--font-size-sm);color:var(--color-gray-600)}.reminder-item__actions{display:flex;gap:var(--space-2)}.weekday-selector{display:flex;gap:var(--space-1);flex-wrap:wrap}.weekday-btn{width:40px;height:40px;border:2px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s ease}.weekday-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.weekday-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.weekday-btn--active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.reminders-warning{background:#ef44441a;color:var(--color-error);padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.reminders-test-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-gray-200);text-align:center}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-logo__title{color:var(--color-primary);margin:0;font-size:var(--font-size-3xl)}.auth-card__title{text-align:center;margin-bottom:var(--space-3);color:var(--color-gray-900);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.auth-card__subtitle{text-align:center;color:var(--color-gray-600);margin-bottom:var(--space-6);font-size:var(--font-size-base)}@media (min-width: 640px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.page{padding:var(--space-8) 0}.page__title{font-size:var(--font-size-3xl)}}@media (min-width: 1024px){.form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 640px){.user-profile-btn span{display:none}.info-grid{grid-template-columns:1fr;gap:var(--space-4)}.auth-card{padding:var(--space-6)}.pet-management-header{flex-direction:column;align-items:stretch}.pet-add-btn{margin-left:0;width:100%}}@media (min-width: 769px){.only-mobile{display:none!important}}@media (min-width: 900px){.only-mobile{display:inline-flex}}@media (max-width: 768px){.user-profile-btn{display:none!important}.only-mobile{display:flex!important}.nav-link--profile{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4)!important}.nav-link--profile .user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.nav-link--profile span{font-weight:500}}@media (max-height: 700px){.modal-content{max-height:95vh;padding:var(--space-4)}}@media (max-height: 600px){.modal{align-items:flex-start;padding:var(--space-2);overflow-y:auto}.modal-content{max-height:none;padding:var(--space-3);margin-top:var(--space-2);margin-bottom:var(--space-2)}.pwa-modal__title{font-size:1.25rem;margin-bottom:var(--space-2)}.pwa-modal__subtitle{font-size:.875rem;margin-bottom:var(--space-3)}.pwa-step-list{gap:var(--space-2)}.pwa-step{padding:var(--space-2)}.pwa-benefits{margin-top:var(--space-3);padding:var(--space-3)}.pwa-modal__actions{margin-top:var(--space-3)}.pwa-modal__close-btn{padding:.75rem 1.25rem}}.ai-page-header{margin-bottom:var(--space-6)}.ai-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;margin-top:var(--space-2)}.ai-form-field--pet-period{display:flex;flex-direction:column;gap:var(--space-4)}.card--info{background:linear-gradient(135deg,#e0f2fe,#bae6fd);border:1px solid #7dd3fc}.info-box{display:flex;gap:var(--space-4);align-items:flex-start}.info-box__icon{font-size:2rem;background:#ffffff80;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.info-box__content{flex:1}.info-box__title{margin:0 0 var(--space-2);font-size:1.125rem;font-weight:600;color:#0c4a6e}.info-box__text{margin:0 0 var(--space-2);color:#075985;line-height:1.5}.info-box__text:last-child{margin-bottom:0}[data-theme=dark] .card--info{background-image:none!important;background-color:#0ea5e926!important;border-color:#0284c7}[data-theme=dark] .info-box__icon{background:#0ea5e933}[data-theme=dark] .info-box__title{color:#e0f2fe}[data-theme=dark] .info-box__text{color:#bae6fd}.dashboard-header-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);align-items:stretch}@media (max-width: 768px){.dashboard-header-grid{grid-template-columns:minmax(0,1fr)}}.theme-selection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.theme-option{padding:1rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;font-weight:500}.theme-option--light{border:1px solid var(--color-gray-200);background:var(--color-bg-white);color:var(--color-gray-900)}.theme-option--light.theme-option--active{border:2px solid var(--color-primary);background:var(--color-bg-white);color:var(--color-primary)}.theme-option--dark{border:1px solid var(--color-gray-200);background:#1a1b1e;color:#fff}.theme-option--dark.theme-option--active{border:2px solid var(--color-primary)}.app-footer{margin-top:auto;padding:1.5rem 1rem;background:var(--surface-1);border-top:1px solid var(--border-color)}.app-footer-inner{max-width:var(--max-width);margin:0 auto}.footer-links{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.footer-link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease;display:inline-flex;align-items:center;gap:.25rem}.footer-link:hover{color:var(--primary)}.footer-link--highlight{color:var(--primary);font-weight:500}.footer-link--highlight:hover{color:var(--primary-hover);text-decoration:underline}.footer-link--telegram{position:relative;color:var(--text-secondary);font-weight:500}.footer-link--telegram:hover{color:#08c}.footer-link--telegram:hover .telegram-icon{transform:translateY(-2px)}.telegram-icon{display:inline-flex;align-items:center;font-size:1rem;transition:transform .2s ease}.footer-link__text{font-size:.875rem}.footer-link--telegram[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:.5rem .75rem;background:#000000e6;color:#fff;font-size:.75rem;border-radius:4px;white-space:nowrap;margin-bottom:.5rem;pointer-events:none;z-index:1000}.footer-link--telegram[title]:hover:before{content:"";position:absolute;bottom:calc(100% + .25rem);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000e6;pointer-events:none;z-index:1000}.footer-separator{color:var(--border-color);-webkit-user-select:none;user-select:none}.footer-copyright{color:var(--text-secondary)}@media (max-width: 600px){.app-footer{padding:1rem}.footer-links{font-size:.8125rem}}.email-verification{display:flex;flex-direction:column;gap:1.5rem;width:100%}.verification-header{text-align:center}.verification-header h2{margin:0 0 .5rem;color:#1f2937;font-size:1.5rem}.verification-description{color:#6b7280;font-size:.95rem;margin:0;line-height:1.5}.code-inputs{display:flex;justify-content:center;gap:.5rem;margin:1rem 0}.code-input{width:3rem;height:3.5rem;text-align:center;font-size:1.5rem;font-weight:600;border:2px solid #d1d5db;border-radius:.5rem;outline:none;transition:all .2s;font-family:Courier New,monospace}.code-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.code-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.verify-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:.5rem;cursor:pointer;transition:all .2s;width:100%}.verify-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.verify-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.resend-section{text-align:center}.resend-button{background:none;border:none;color:#667eea;font-size:.9rem;cursor:pointer;padding:.5rem;text-decoration:underline;transition:color .2s}.resend-button:hover:not(:disabled){color:#764ba2}.resend-button:disabled{color:#9ca3af;cursor:not-allowed;text-decoration:none}.cancel-button{background:#f3f4f6;color:#4b5563;border:1px solid #d1d5db;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;border-radius:.5rem;cursor:pointer;transition:all .2s;width:100%}.cancel-button:hover:not(:disabled){background:#e5e7eb}.cancel-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.code-input{width:2.5rem;height:3rem;font-size:1.25rem}.code-inputs{gap:.4rem}}
