@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap";:root{--color-primary: #824a5e;--color-primary-dim: #753f52;--color-primary-container: #fdb5cc;--color-on-primary: #ffeff2;--color-on-primary-container: #653245;--color-secondary: #056380;--color-secondary-container: #95dbfc;--color-on-secondary: #e5f5ff;--color-on-secondary-container: #004e65;--color-tertiary: #5e5f03;--color-tertiary-container: #fcfc95;--color-on-tertiary-container: #606106;--color-surface: #fff4f2;--color-surface-dim: #fec8bc;--color-surface-container: #ffe2db;--color-surface-container-low: #ffede9;--color-surface-container-high: #ffdad2;--color-surface-container-highest: #ffd3c9;--color-surface-container-lowest: #ffffff;--color-surface-bright: #fff4f2;--color-on-surface: #412823;--color-on-surface-variant: #72544e;--color-outline: #906f68;--color-outline-variant: #caa59c;--color-error: #b41340;--color-error-container: #f74b6d;--color-inverse-surface: #1c0905;--color-inverse-on-surface: #b9958d;--shadow-squishy: 0 8px 24px rgba(65, 40, 35, .08);--shadow-soft: 0 4px 16px rgba(65, 40, 35, .06);--shadow-float: 0 12px 32px rgba(65, 40, 35, .12);--radius-sm: .75rem;--radius-md: 1rem;--radius-lg: 1.5rem;--radius-xl: 2rem;--radius-xxl: 3rem;--radius-full: 9999px;--font-body: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-headline: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--max-width: 480px;--nav-height: 64px;--header-height: 60px;color:var(--color-on-surface);background-color:var(--color-surface);font-family:var(--font-body);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 600,"GRAD" 0,"opsz" 24;vertical-align:middle}.material-symbols-filled{font-variation-settings:"FILL" 1,"wght" 600,"GRAD" 0,"opsz" 24;vertical-align:middle}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--color-surface);min-height:100vh}#root{min-height:100vh;width:100%;display:flex;justify-content:center}a{color:inherit;text-decoration:none}p,h1,h2,h3,h4,h5,h6{margin:0}input,button,textarea,select{font-family:inherit}img{max-width:100%;display:block}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.6}}@keyframes bounce-in{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}@keyframes slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-pulse-soft{animation:pulse-soft 2s ease-in-out infinite}.animate-bounce-in{animation:bounce-in .4s ease-out}.animate-slide-up{animation:slide-up .3s ease-out}.animate-float{animation:float 3s ease-in-out infinite}.tonal-transition{transition:background-color .3s ease,box-shadow .3s ease}.app-shell{width:100%;max-width:var(--max-width);min-height:100vh;display:flex;flex-direction:column;background:var(--color-surface);position:relative}.app-content{flex:1;overflow-y:auto}.app-content.has-nav{padding-top:var(--header-height);padding-bottom:calc(var(--nav-height) + 20px)}.app-header{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-width);height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#fff4f2cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:0 0 var(--radius-xxl) var(--radius-xxl);box-shadow:var(--shadow-soft);z-index:100}.header-left{display:flex;align-items:center;gap:8px}.header-brand{font-family:var(--font-headline);font-weight:800;font-size:20px;color:var(--color-on-surface);letter-spacing:-.5px;font-style:italic}.header-logo{font-size:24px}.header-back{background:var(--color-surface-container-high);border:none;font-size:18px;cursor:pointer;padding:6px 12px;border-radius:var(--radius-full);color:var(--color-on-surface);transition:all .2s}.header-back:hover{transform:scale(1.05)}.header-back:active{transform:scale(.95)}.header-title{font-family:var(--font-headline);font-weight:700;font-size:17px}.header-right{display:flex;align-items:center;gap:8px}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-width);height:var(--nav-height);display:flex;align-items:center;justify-content:space-around;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xxl) var(--radius-xxl) 0 0;box-shadow:0 -4px 20px #4128230f;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;padding:8px 14px;border-radius:var(--radius-lg);color:var(--color-on-surface-variant);transition:all .2s}.bottom-nav-tab.active{color:var(--color-primary);background:var(--color-primary-container);transform:scale(1.05)}.bottom-nav-tab:hover:not(.active){transform:scale(1.05)}.bottom-nav-tab:active{transform:scale(.95)}.bottom-nav-icon{font-size:22px;line-height:1}.bottom-nav-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:800;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:hover{transform:scale(1.05)}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(to top,var(--color-primary),var(--color-primary-container));color:var(--color-on-primary);padding:12px 24px;font-size:15px;box-shadow:var(--shadow-squishy)}.btn-accent{background:linear-gradient(to top,var(--color-secondary),var(--color-secondary-container));color:var(--color-on-secondary);padding:12px 24px;font-size:15px;box-shadow:var(--shadow-squishy)}.btn-ghost{background:none;color:var(--color-on-surface-variant);padding:12px 24px;font-size:14px}.btn-ghost:hover{color:var(--color-on-surface)}.btn-outline{background:var(--color-surface-container-highest);border:none;color:var(--color-on-surface);padding:10px 18px;font-size:13px}.btn-sm{padding:8px 16px;font-size:13px}.btn-lg{padding:16px 32px;font-size:16px}.btn-full{width:100%}.form-group{margin-bottom:16px}.form-label{display:block;font-size:11px;font-weight:800;color:var(--color-on-surface-variant);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input{width:100%;padding:12px 16px;border:none;border-radius:var(--radius-lg);font-size:15px;background:var(--color-surface-container-high);color:var(--color-on-surface);outline:none;transition:all .3s ease;box-shadow:inset 0 2px 4px #4128230a}.form-input:focus{background:var(--color-surface-container-lowest);box-shadow:0 0 0 2px #824a5e40}.form-input::placeholder{color:var(--color-outline-variant)}.form-textarea{width:100%;padding:12px 16px;border:none;border-radius:var(--radius-lg);font-size:15px;background:var(--color-surface-container-high);color:var(--color-on-surface);outline:none;resize:vertical;font-family:var(--font-body);transition:all .3s ease;box-shadow:inset 0 2px 4px #4128230a}.form-textarea:focus{background:var(--color-surface-container-lowest);box-shadow:0 0 0 2px #824a5e40}.form-error{color:var(--color-error);font-size:13px;font-weight:600;margin:8px 0}.card{background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-squishy)}.text-accent{color:var(--color-primary)}.text-secondary{color:var(--color-on-surface-variant)}.text-sm{font-size:13px}.landing{padding:0 24px 48px;display:flex;flex-direction:column;min-height:100vh}.landing-hero{padding:72px 0 48px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px}.landing-badge{display:inline-flex;align-items:center;gap:6px;background:var(--color-secondary-container);color:var(--color-secondary);font-size:10px;font-weight:800;padding:6px 16px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:1px}.landing-badge:before{content:"";width:6px;height:6px;background:var(--color-secondary);border-radius:50%;animation:pulse-soft 2s ease-in-out infinite}.landing-headline{font-family:var(--font-headline);font-size:clamp(32px,8vw,44px);font-weight:900;line-height:1.05;color:var(--color-on-surface);letter-spacing:-1.5px}.landing-headline .text-accent{color:var(--color-primary);font-style:italic}.landing-sub{font-size:16px;color:var(--color-on-surface-variant);max-width:340px;line-height:1.6}.landing-features{display:flex;flex-direction:column;gap:12px;margin-top:20px}.feature-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--color-surface-container);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);border-bottom:6px solid rgba(130,74,94,.08);transition:all .3s ease;animation:slide-up .4s ease-out backwards}.feature-card:nth-child(1){animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s;background:#95dbfc33;border-bottom-color:#05638014}.feature-card:nth-child(3){animation-delay:.3s;background:#fcfc9533;border-bottom-color:#5e5f0314}.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-float)}.feature-icon{font-size:28px;flex-shrink:0;width:48px;height:48px;background:var(--color-surface-container-lowest);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.feature-title{font-family:var(--font-headline);font-weight:800;font-size:16px;margin-bottom:4px}.feature-desc{font-size:13px;color:var(--color-on-surface-variant);line-height:1.5}.landing-proof{text-align:center;padding:32px 0}.proof-stat{font-size:13px;color:var(--color-outline);font-style:italic}.landing-footer{text-align:center;padding:28px 0;margin-top:auto}.landing-footer p:first-child{font-family:var(--font-headline);font-weight:800;font-size:16px;font-style:italic}.footer-links{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;font-size:12px}.footer-links a{color:var(--color-primary);font-weight:700;text-decoration:none;transition:opacity .2s}.footer-links a:hover{opacity:.7}.footer-dot{color:var(--color-outline-variant)}.onboarding{padding:24px 24px 40px;min-height:100vh;display:flex;flex-direction:column}.onboarding-progress{height:6px;background:var(--color-surface-container-high);border-radius:var(--radius-full);margin-bottom:36px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-container));border-radius:var(--radius-full);transition:width .4s ease}.onboarding-step{display:flex;flex-direction:column;gap:16px;animation:slide-up .3s ease-out}.onboarding-title{font-family:var(--font-headline);font-size:26px;font-weight:900;letter-spacing:-1px}.onboarding-sub{color:var(--color-on-surface-variant);font-size:15px}.role-grid{display:flex;flex-direction:column;gap:10px}.role-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:18px 20px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);cursor:pointer;text-align:left;box-shadow:var(--shadow-soft);transition:all .25s ease}.role-card.selected{background:var(--color-primary-container);box-shadow:var(--shadow-squishy);transform:scale(1.02)}.role-card:hover:not(.selected){transform:scale(1.02);box-shadow:var(--shadow-squishy)}.role-card:active{transform:scale(.98)}.role-icon{font-size:26px}.role-label{font-weight:800;font-size:16px}.role-desc{font-size:13px;color:var(--color-on-surface-variant)}.goal-list{display:flex;flex-direction:column;gap:8px}.goal-option{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);cursor:pointer;text-align:left;font-size:15px;font-weight:600;box-shadow:var(--shadow-soft);transition:all .25s ease}.goal-option.selected{background:var(--color-primary-container);transform:scale(1.02)}.goal-option:active{transform:scale(.98)}.goal-check{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-surface-container-high);font-size:13px;font-weight:800;color:var(--color-primary);flex-shrink:0;transition:all .2s}.goal-option.selected .goal-check{background:var(--color-primary);color:var(--color-on-primary);transform:scale(1.1)}.feed{padding:16px 20px}.feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.feed-title{font-family:var(--font-headline);font-size:22px;font-weight:900;letter-spacing:-.5px}.filter-row{display:flex;gap:8px;margin-bottom:18px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0}.filter-row::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:8px 16px;border:none;border-radius:var(--radius-full);background:var(--color-surface-container-high);font-size:12px;font-weight:800;cursor:pointer;transition:all .2s ease;color:var(--color-on-surface-variant);text-transform:uppercase;letter-spacing:.3px}.filter-chip.active{background:linear-gradient(to top,var(--color-primary),var(--color-primary-container));color:var(--color-on-primary);box-shadow:var(--shadow-soft)}.filter-chip:hover:not(.active){transform:scale(1.05)}.filter-chip:active{transform:scale(.95)}.feed-loading,.feed-empty{padding:56px 20px;text-align:center;color:var(--color-on-surface-variant)}.feed-empty-icon{font-size:56px;margin-bottom:16px;animation:float 3s ease-in-out infinite}.feed-empty-text{margin-bottom:20px;font-weight:600}.sighting-list{display:flex;flex-direction:column;gap:16px}.sighting-card{background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-squishy);cursor:pointer;transition:all .25s ease;animation:slide-up .4s ease-out backwards}.sighting-card:nth-child(1){animation-delay:.05s}.sighting-card:nth-child(2){animation-delay:.1s}.sighting-card:nth-child(3){animation-delay:.15s}.sighting-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-float)}.sighting-card:active{transform:scale(.98)}.sighting-photo{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--color-surface-container)}.sighting-photo img{width:100%;height:100%;object-fit:cover}.sighting-photo-placeholder{display:flex;align-items:center;justify-content:center;font-size:52px;aspect-ratio:16/10;animation:float 3s ease-in-out infinite}.sighting-badge{position:absolute;top:12px;left:12px;padding:5px 12px;border-radius:var(--radius-full);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.badge-spotted{background:#fdb5cce6;color:var(--color-on-primary-container)}.badge-help{background:#f74b6de6;color:#fff}.sighting-body{padding:14px 16px}.sighting-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--color-outline);margin-bottom:6px;flex-wrap:wrap;font-weight:500}.sighting-location{color:var(--color-on-surface-variant);font-weight:700}.sighting-name{font-family:var(--font-headline);font-weight:800;font-size:17px;margin-bottom:4px;letter-spacing:-.3px}.sighting-desc{font-size:14px;color:var(--color-on-surface-variant);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sighting-actions{display:flex;align-items:center;gap:10px;margin-top:12px}.action-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;font-size:13px;font-weight:600;color:var(--color-outline);cursor:pointer;padding:4px 0;transition:all .2s}.action-btn:hover{transform:scale(1.1)}.action-btn.cheered{color:var(--color-primary)}.action-btn-lg{font-size:14px;padding:8px 18px;background:var(--color-surface-container-high);border:none;border-radius:var(--radius-full);font-weight:700;transition:all .2s}.action-btn-lg:hover{transform:scale(1.05)}.action-btn-lg:active{transform:scale(.95)}.action-btn-lg.cheered{background:var(--color-primary-container);color:var(--color-on-primary-container)}.sighting-author{margin-left:auto;font-size:11px;color:var(--color-outline);font-weight:600}.post-sighting{padding:20px 24px}.section-title{font-family:var(--font-headline);font-size:22px;font-weight:900;margin-bottom:20px;letter-spacing:-.5px}.type-row{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.type-chip{padding:10px 16px;border:none;border-radius:var(--radius-full);background:var(--color-surface-container-high);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease;color:var(--color-on-surface-variant)}.type-chip.active{background:var(--color-primary-container);color:var(--color-on-primary-container);box-shadow:var(--shadow-soft);transform:scale(1.05)}.type-chip:hover:not(.active){transform:scale(1.05)}.type-chip:active{transform:scale(.95)}.photo-upload-btn{width:100%;padding:36px;border:none;border-radius:var(--radius-xl);background:var(--color-surface-container);font-size:15px;font-weight:700;color:var(--color-on-surface-variant);cursor:pointer;transition:all .25s ease;box-shadow:inset 0 2px 8px #4128230a}.photo-upload-btn:hover{background:var(--color-surface-container-high);transform:scale(1.02)}.photo-preview{position:relative;border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-squishy)}.photo-preview img{width:100%;aspect-ratio:16/10;object-fit:cover}.photo-change{position:absolute;bottom:10px;right:10px;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:11px;font-weight:700;padding:5px 12px;border-radius:var(--radius-full)}.location-row{display:flex;gap:8px}.location-row .form-input{flex:1}.sighting-detail{padding-bottom:24px;animation:slide-up .3s ease-out}.detail-loading{padding:56px;text-align:center;color:var(--color-on-surface-variant)}.detail-photo{width:100%}.detail-photo img{width:100%;aspect-ratio:16/10;object-fit:cover}.detail-content{padding:20px}.detail-badge{display:inline-block;padding:5px 14px;border-radius:var(--radius-full);font-size:10px;font-weight:800;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.badge-spotted,.detail-badge.badge-spotted{background:var(--color-primary-container);color:var(--color-on-primary-container)}.badge-needs_help{background:var(--color-error-container);color:#fff}.badge-lost{background:var(--color-tertiary-container);color:var(--color-on-tertiary-container)}.detail-name{font-family:var(--font-headline);font-size:24px;font-weight:900;margin-bottom:8px;letter-spacing:-1px}.detail-meta{display:flex;gap:12px;font-size:13px;color:var(--color-on-surface-variant);margin-bottom:14px;flex-wrap:wrap;font-weight:500}.detail-desc{font-size:15px;line-height:1.6;margin-bottom:18px}.detail-actions{display:flex;gap:10px;margin-bottom:18px}.help-banner{padding:14px 18px;border-radius:var(--radius-xl);background:#f74b6d1f;font-size:14px;margin-bottom:18px;font-weight:600;line-height:1.5}.help-banner-lost{background:#fcfc954d}.rescue-contacts{margin-top:10px}.rescue-title{font-weight:800;font-size:13px;margin-bottom:6px}.rescue-list{margin:0;padding:0 0 0 18px;font-size:13px;line-height:1.6;color:var(--color-on-surface)}.rescue-list li{margin-bottom:4px}.rescue-list strong{color:var(--color-primary)}.detail-comments{padding:0 20px}.comments-title{font-family:var(--font-headline);font-size:17px;font-weight:800;margin-bottom:14px}.comments-empty{font-size:14px;color:var(--color-outline);margin-bottom:14px}.comments-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.comment-item{padding:12px 16px;background:var(--color-surface-container-low);border-radius:var(--radius-lg);animation:slide-up .3s ease-out}.comment-header{display:flex;justify-content:space-between;margin-bottom:4px}.comment-author{font-size:11px;font-weight:800;color:var(--color-primary);text-transform:uppercase;letter-spacing:.3px}.comment-time{font-size:10px;color:var(--color-outline)}.comment-text{font-size:14px;line-height:1.5}.comment-input-row{display:flex;gap:8px;margin-top:8px}.comment-input-row .form-input{flex:1}.questions{padding:16px 20px}.question-list{display:flex;flex-direction:column;gap:10px}.question-card{display:block;width:100%;text-align:left;padding:16px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);cursor:pointer;transition:all .25s ease}.question-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-float)}.question-card:active{transform:scale(.98)}.question-text{font-size:15px;font-weight:700;margin-bottom:8px;line-height:1.4}.question-meta{display:flex;gap:12px;font-size:11px;color:var(--color-outline);flex-wrap:wrap;font-weight:600}.question-detail{padding:18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);margin:14px 0;box-shadow:var(--shadow-squishy)}.question-form{margin-bottom:18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);padding:18px;box-shadow:var(--shadow-squishy)}.chat{display:flex;flex-direction:column;height:calc(100vh - var(--header-height) - var(--nav-height))}.chat-header-info{padding:18px 20px 10px}.credit-status{margin-top:10px}.credit-free{display:inline-block;padding:4px 12px;background:var(--color-secondary-container);color:var(--color-on-secondary-container);border-radius:var(--radius-full);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.3px}.credit-premium{display:inline-block;padding:4px 12px;background:var(--color-primary-container);color:var(--color-on-primary-container);border-radius:var(--radius-full);font-size:11px;font-weight:800}.credit-empty{font-size:13px;color:var(--color-on-surface-variant)}.credit-link{color:var(--color-primary);font-weight:800;text-decoration:underline}.chat-messages{flex:1;overflow-y:auto;padding:10px 20px;display:flex;flex-direction:column;gap:12px}.chat-welcome{text-align:center;padding:36px 0;animation:bounce-in .4s ease-out}.chat-welcome-icon{font-size:56px;margin-bottom:10px;animation:float 3s ease-in-out infinite}.chat-welcome-text{font-size:17px;color:var(--color-on-surface-variant);margin-bottom:20px;font-weight:600}.chat-suggestions{display:flex;flex-direction:column;gap:8px}.suggestion-chip{padding:12px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);font-size:14px;font-weight:600;cursor:pointer;text-align:left;color:var(--color-on-surface);box-shadow:var(--shadow-soft);transition:all .2s ease}.suggestion-chip:hover{transform:scale(1.02);box-shadow:var(--shadow-squishy);background:var(--color-primary-container)}.suggestion-chip:active{transform:scale(.98)}.chat-bubble{display:flex;gap:8px;max-width:88%;animation:slide-up .25s ease-out}.chat-bubble.user{align-self:flex-end;flex-direction:row-reverse}.bubble-avatar{width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:var(--color-primary-container);border-radius:var(--radius-full)}.bubble-content{padding:12px 16px;border-radius:var(--radius-xl);font-size:14px;line-height:1.6;white-space:pre-wrap}.chat-bubble.assistant .bubble-content{background:var(--color-surface-container-low);color:var(--color-on-surface);border-bottom-left-radius:6px}.chat-bubble.user .bubble-content{background:linear-gradient(to top,var(--color-primary),var(--color-primary-container));color:var(--color-on-primary);border-bottom-right-radius:6px;box-shadow:var(--shadow-soft)}.bubble-typing{color:var(--color-outline);font-style:italic;animation:pulse-soft 1.5s ease-in-out infinite}.chat-input-row{display:flex;gap:8px;padding:14px 20px;background:#fff4f2e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chat-input{flex:1}.explore-hub{padding:16px 20px}.explore-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.explore-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:24px 16px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);cursor:pointer;transition:all .25s ease}.explore-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-float)}.explore-card:active{transform:scale(.97)}.explore-card:nth-child(1){border-bottom:5px solid var(--color-primary-container)}.explore-card:nth-child(2){border-bottom:5px solid var(--color-secondary-container)}.explore-card:nth-child(3){border-bottom:5px solid var(--color-tertiary-container)}.explore-card:nth-child(4){border-bottom:5px solid var(--color-surface-container-high)}.explore-card-icon{font-size:36px;animation:float 3s ease-in-out infinite}.explore-card:nth-child(2) .explore-card-icon{animation-delay:.3s}.explore-card:nth-child(3) .explore-card-icon{animation-delay:.6s}.explore-card:nth-child(4) .explore-card-icon{animation-delay:.9s}.explore-card-title{font-family:var(--font-headline);font-weight:800;font-size:14px}.explore-card-desc{font-size:11px;color:var(--color-on-surface-variant);line-height:1.4}.cat-profiles{padding:16px 20px}.cat-grid{display:flex;flex-direction:column;gap:12px}.cat-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);cursor:pointer;text-align:left;width:100%;transition:all .25s ease;animation:slide-up .3s ease-out backwards}.cat-card:nth-child(1){animation-delay:.05s}.cat-card:nth-child(2){animation-delay:.1s}.cat-card:nth-child(3){animation-delay:.15s}.cat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-float)}.cat-card:active{transform:scale(.98)}.cat-card-avatar{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--color-primary-container);border-radius:var(--radius-full);flex-shrink:0}.cat-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.cat-card-name{font-weight:800;font-size:16px;letter-spacing:-.3px}.cat-card-vibe{font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px}.cat-card-meta{font-size:12px;color:var(--color-on-surface-variant)}.cat-card-location{font-size:11px;color:var(--color-outline);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-profile-hero{text-align:center;padding:24px 0;animation:bounce-in .4s ease-out}.cat-profile-avatar{width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-size:44px;background:var(--color-primary-container);border-radius:var(--radius-full);margin:0 auto 12px;animation:float 3s ease-in-out infinite}.cat-profile-name{font-family:var(--font-headline);font-size:26px;font-weight:900;letter-spacing:-1px;margin-bottom:4px}.cat-profile-vibe{display:inline-block;padding:3px 14px;background:var(--color-primary-container);color:var(--color-on-primary-container);border-radius:var(--radius-full);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.cat-profile-stats{display:flex;justify-content:center;gap:24px;margin:16px 0}.cat-stat{text-align:center}.cat-stat-value{display:block;font-family:var(--font-headline);font-size:22px;font-weight:900;color:var(--color-primary)}.cat-stat-label{font-size:10px;font-weight:700;color:var(--color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px}.cat-profile-location{font-size:13px;color:var(--color-on-surface-variant);margin-top:8px}.cat-sighting-history{display:flex;flex-direction:column;gap:10px}.cat-history-item{display:block;width:100%;text-align:left;padding:14px 16px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);cursor:pointer;transition:all .2s ease}.cat-history-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.cat-history-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:11px;color:var(--color-outline)}.cat-history-desc{font-size:14px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.cat-history-loc{font-size:12px;color:var(--color-on-surface-variant)}.map-view{padding:16px 20px}.map-locations{display:flex;flex-direction:column;gap:14px}.map-location-card{background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);padding:18px;box-shadow:var(--shadow-squishy);animation:slide-up .3s ease-out backwards}.map-location-card:nth-child(1){animation-delay:.05s}.map-location-card:nth-child(2){animation-delay:.1s}.map-location-card:nth-child(3){animation-delay:.15s}.map-location-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.map-location-pin{font-size:28px;flex-shrink:0}.map-location-name{font-family:var(--font-headline);font-weight:800;font-size:15px;letter-spacing:-.3px}.map-location-count{font-size:11px;color:var(--color-on-surface-variant);font-weight:600}.map-location-sightings{display:flex;flex-wrap:wrap;gap:8px}.map-sighting-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-surface-container-low);border:none;border-radius:var(--radius-full);font-size:13px;cursor:pointer;transition:all .2s ease}.map-sighting-chip:hover{background:var(--color-primary-container);transform:scale(1.05)}.map-sighting-chip:active{transform:scale(.95)}.map-chip-name{font-weight:700}.map-chip-time{font-size:10px;color:var(--color-outline)}.guides{padding:16px 20px}.guide-list{display:flex;flex-direction:column;gap:12px}.guide-card{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);cursor:pointer;text-align:left;width:100%;transition:all .25s ease;animation:slide-up .3s ease-out backwards}.guide-card:nth-child(1){animation-delay:.05s}.guide-card:nth-child(2){animation-delay:.1s}.guide-card:nth-child(3){animation-delay:.15s}.guide-card:nth-child(4){animation-delay:.2s}.guide-card:nth-child(5){animation-delay:.25s}.guide-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-float)}.guide-card:active{transform:scale(.98)}.guide-card-icon{font-size:28px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-container);border-radius:var(--radius-full)}.guide-card-title{font-family:var(--font-headline);font-weight:800;font-size:15px;margin-bottom:4px}.guide-card-excerpt{font-size:13px;color:var(--color-on-surface-variant);line-height:1.4}.guide-article{padding:20px 0;animation:slide-up .3s ease-out}.guide-article-icon{font-size:48px;display:block;margin-bottom:12px}.guide-article-title{font-family:var(--font-headline);font-size:24px;font-weight:900;letter-spacing:-1px;margin-bottom:12px;line-height:1.15}.guide-article-tags{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.guide-tag{padding:4px 10px;background:var(--color-tertiary-container);color:var(--color-on-tertiary-container);border-radius:var(--radius-full);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.guide-article-body{font-size:15px;line-height:1.7;color:var(--color-on-surface)}.guide-article-body p{margin-bottom:16px}.guide-article-body strong{color:var(--color-primary);font-weight:700}.guide-card-body{flex:1;min-width:0}.guide-card-meta{display:flex;gap:8px;align-items:center;margin-top:6px}.guide-read-time{font-size:11px;color:var(--color-outline);font-weight:600}.guide-quiz-badge,.guide-ai-badge{font-size:10px;padding:2px 6px;border-radius:var(--radius-full);font-weight:700}.guide-quiz-badge{background:var(--color-tertiary-container);color:var(--color-on-tertiary-container)}.guide-ai-badge{background:var(--color-secondary-container);color:var(--color-on-secondary-container)}.guide-article-meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}.share-guide-btn{font-size:12px!important;padding:4px 10px!important}.guide-search{margin-bottom:10px}.guide-filter-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.guide-filter-chip{padding:4px 12px;background:var(--color-surface-container);border:none;border-radius:var(--radius-full);font-size:12px;font-weight:600;color:var(--color-on-surface-variant);cursor:pointer;text-transform:capitalize;transition:all .2s}.guide-filter-chip:hover{background:var(--color-surface-container-high)}.guide-filter-chip.active{background:var(--color-primary);color:var(--color-on-primary)}.guide-stats-banner{display:flex;gap:8px;align-items:center;justify-content:center;padding:8px 12px;background:var(--color-surface-container-low);border-radius:var(--radius-lg);margin-bottom:16px;font-size:12px;font-weight:600;color:var(--color-on-surface-variant)}.quiz-section{margin-top:28px;padding:20px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy)}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.quiz-badge{font-size:12px;font-weight:800;padding:4px 10px;background:var(--color-tertiary-container);color:var(--color-on-tertiary-container);border-radius:var(--radius-full)}.quiz-progress{font-size:12px;font-weight:700;color:var(--color-outline)}.quiz-question{font-family:var(--font-headline);font-size:16px;font-weight:800;line-height:1.3;margin-bottom:14px}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--color-surface-container-low);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;text-align:left;font-size:14px;width:100%;transition:all .2s}.quiz-option:hover:not(:disabled){border-color:var(--color-primary)}.quiz-option.correct{border-color:var(--color-success);background:#34d3991a}.quiz-option.incorrect{border-color:var(--color-error-container);background:#ef444414}.quiz-option-letter{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);background:var(--color-surface-container);font-weight:800;font-size:12px;flex-shrink:0}.quiz-option.correct .quiz-option-letter{background:var(--color-success);color:#fff}.quiz-option.incorrect .quiz-option-letter{background:var(--color-error-container);color:#fff}.quiz-explanation{margin-top:12px;padding:14px;border-radius:var(--radius-lg);font-size:13px;line-height:1.5;animation:slide-up .2s ease-out}.quiz-explanation.correct{background:#34d3991a}.quiz-explanation.incorrect{background:#ef44440f}.quiz-explanation .btn{margin-top:10px}.quiz-result{text-align:center;padding:24px 20px;margin-top:28px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy)}.quiz-result-emoji{font-size:48px;display:block;margin-bottom:8px}.quiz-result-title{font-family:var(--font-headline);font-size:20px;font-weight:900;margin-bottom:4px}.quiz-result-score{font-size:14px;color:var(--color-on-surface-variant);margin-bottom:14px}.guide-ai-section{margin-top:20px}.ai-tip-btn{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:linear-gradient(135deg,var(--color-secondary-container),var(--color-surface-container-low));border:none;border-radius:var(--radius-xl);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-on-surface);transition:all .2s}.ai-tip-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.ai-tip-btn:disabled{opacity:.7}.ai-tip-arrow{margin-left:auto;color:var(--color-outline)}.ai-tip-response{padding:16px;background:var(--color-surface-container-low);border-radius:var(--radius-xl);animation:slide-up .3s ease-out}.ai-tip-header{display:flex;gap:8px;align-items:center;margin-bottom:8px;font-size:13px}.ai-tip-text{font-size:14px;line-height:1.6;color:var(--color-on-surface);white-space:pre-line}.guide-related{margin-top:28px}.guide-related-title{font-family:var(--font-headline);font-size:16px;font-weight:800;margin-bottom:10px}.guide-related-list{display:flex;flex-direction:column;gap:8px}.guide-related-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;width:100%;font-size:13px;font-weight:600;transition:all .2s}.guide-related-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.guide-related-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-actions-secondary{display:flex;gap:10px;margin-bottom:18px}.action-btn-lg.watching{background:var(--color-secondary-container);color:var(--color-on-secondary-container)}.bottom-nav-icon{position:relative}.nav-badge{position:absolute;top:-6px;right:-10px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:var(--color-error-container);color:#fff;font-size:9px;font-weight:800;border-radius:var(--radius-full);padding:0 4px;line-height:1}.user-profile{padding:16px 20px}.profile-hero{text-align:center;padding:20px 0 24px;animation:bounce-in .4s ease-out}.profile-avatar{width:72px;height:72px;display:flex;align-items:center;justify-content:center;font-size:40px;background:var(--color-primary-container);border-radius:var(--radius-full);margin:0 auto 10px}.profile-name{font-family:var(--font-headline);font-size:22px;font-weight:900;letter-spacing:-.5px}.profile-role{display:inline-block;padding:4px 14px;background:var(--color-surface-container-high);border-radius:var(--radius-full);font-size:12px;font-weight:700;color:var(--color-on-surface-variant);margin-top:6px}.streak-card{display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);margin-bottom:20px;animation:slide-up .3s ease-out}.streak-emoji{font-size:36px;animation:float 2s ease-in-out infinite}.streak-info{display:flex;flex-direction:column;gap:2px}.streak-count{font-family:var(--font-headline);font-size:20px;font-weight:900;color:var(--color-primary)}.streak-label{font-size:12px;color:var(--color-on-surface-variant);font-weight:500}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}.stat-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:16px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);animation:slide-up .3s ease-out backwards}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}.stat-value{font-family:var(--font-headline);font-size:28px;font-weight:900;color:var(--color-primary)}.stat-label{font-size:10px;font-weight:700;color:var(--color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px;text-align:center}.watched-section{margin-top:4px}.watch-count{font-weight:500;color:var(--color-outline)}.watch-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:var(--color-error-container);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:800}.watched-list{display:flex;flex-direction:column;gap:8px}.watched-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;width:100%;transition:all .2s ease}.watched-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.watched-icon{font-size:24px;flex-shrink:0}.watched-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.watched-name{font-weight:700;font-size:14px}.watched-loc{font-size:11px;color:var(--color-outline);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.watched-new{padding:3px 8px;background:var(--color-error-container);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:800;flex-shrink:0}.header-search-btn{background:var(--color-surface-container-high);border:none;width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .2s}.header-search-btn:hover{transform:scale(1.1)}.header-search-btn:active{transform:scale(.95)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--color-surface);display:flex;flex-direction:column;max-width:var(--max-width);margin:0 auto;animation:slide-up .2s ease-out}.search-header{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--color-surface-container-high)}.search-input{flex:1}.search-results{flex:1;overflow-y:auto;padding:16px 20px}.search-section{margin-bottom:24px}.search-section-title{font-family:var(--font-headline);font-size:14px;font-weight:800;color:var(--color-on-surface-variant);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;width:100%;margin-bottom:8px;transition:all .2s}.search-result-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.search-result-icon{font-size:22px;flex-shrink:0}.search-result-info{display:flex;flex-direction:column;gap:2px;min-width:0}.search-result-name{font-weight:700;font-size:14px}.search-result-meta{font-size:11px;color:var(--color-outline);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-hints{padding:24px 0}.search-hint-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.digest-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#41282366;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.digest-modal{width:100%;max-width:var(--max-width);background:var(--color-surface-container-lowest);border-radius:var(--radius-xxl) var(--radius-xxl) 0 0;padding:28px 24px 36px;box-shadow:var(--shadow-float);animation:slide-up .3s ease-out;position:relative}.digest-close{position:absolute;top:16px;right:20px;background:var(--color-surface-container-high);border:none;width:32px;height:32px;border-radius:var(--radius-full);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.digest-close:hover{transform:scale(1.1)}.digest-icon{font-size:40px;display:block;margin-bottom:10px}.digest-title{font-family:var(--font-headline);font-size:20px;font-weight:900;margin-bottom:4px;letter-spacing:-.5px}.digest-success{text-align:center}.digest-success-icon{font-size:48px;display:block;margin-bottom:12px}.digest-email{display:inline-block;padding:4px 14px;background:var(--color-surface-container-high);border-radius:var(--radius-full);font-size:13px;font-weight:600;color:var(--color-on-surface-variant);margin:10px 0 16px}.photo-nudge{text-align:center;padding:48px 20px;animation:bounce-in .4s ease-out}.photo-nudge-icon{font-size:56px;display:block;margin-bottom:16px;animation:float 3s ease-in-out infinite}.photo-nudge-title{font-family:var(--font-headline);font-size:22px;font-weight:900;margin-bottom:8px}.photo-nudge-text{font-size:15px;color:var(--color-on-surface-variant);line-height:1.5;margin-bottom:24px}.photo-nudge-text strong{color:var(--color-primary)}.photo-nudge-actions{display:flex;flex-direction:column;gap:8px}.notif-prefs{padding:16px 20px}.prefs-section{margin-bottom:24px}.prefs-label{font-family:var(--font-headline);font-size:14px;font-weight:800;color:var(--color-on-surface-variant);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.prefs-options{display:flex;gap:8px}.prefs-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 8px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);cursor:pointer;transition:all .2s;text-align:center}.prefs-option.active{background:var(--color-primary-container);box-shadow:var(--shadow-squishy);transform:scale(1.03)}.prefs-option:hover:not(.active){transform:scale(1.02)}.prefs-option:active{transform:scale(.97)}.prefs-option-label{font-weight:800;font-size:14px}.prefs-option-desc{font-size:11px;color:var(--color-on-surface-variant)}.prefs-toggle{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;width:100%;transition:all .2s}.prefs-toggle.active{background:var(--color-primary-container)}.prefs-toggle:active{transform:scale(.98)}.prefs-toggle-check{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-surface-container-high);font-size:13px;font-weight:800;color:var(--color-primary);flex-shrink:0}.prefs-toggle.active .prefs-toggle-check{background:var(--color-primary);color:var(--color-on-primary)}.prefs-cat-chips{display:flex;flex-wrap:wrap;gap:8px}.prefs-cat-chip{padding:8px 14px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-full);font-size:13px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-soft);transition:all .2s}.prefs-cat-chip.active{background:var(--color-primary-container);color:var(--color-on-primary-container)}.prefs-cat-chip:hover:not(.active){transform:scale(1.05)}.prefs-cat-chip:active{transform:scale(.95)}.prefs-actions{margin-top:32px;display:flex;flex-direction:column;gap:8px}.profile-settings{margin-top:24px}.profile-settings-btn{display:flex;align-items:center;gap:12px;width:100%;padding:16px 18px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);cursor:pointer;font-size:15px;font-weight:600;text-align:left;transition:all .2s}.profile-settings-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.profile-settings-arrow{margin-left:auto;color:var(--color-outline)}.proof-counters{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}.proof-counter{display:flex;flex-direction:column;align-items:center;gap:2px}.proof-number{font-size:28px;font-weight:900;font-family:var(--font-headline);color:var(--color-primary)}.proof-label{font-size:12px;color:var(--color-on-surface-variant);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.photo-buttons{display:flex;gap:10px}.photo-buttons .photo-upload-btn{flex:1}.camera-btn{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-container))!important;color:var(--color-on-primary)!important}.location-autocomplete{flex:1;position:relative}.location-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--color-surface-container-lowest);border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-squishy);z-index:20;max-height:200px;overflow-y:auto}.location-suggestion{display:block;width:100%;padding:10px 14px;background:none;border:none;text-align:left;font-size:14px;color:var(--color-on-surface);cursor:pointer;transition:background .15s}.location-suggestion:hover{background:var(--color-surface-container-low)}.activity-section{padding:0 20px;margin-bottom:16px}.activity-list{display:flex;flex-direction:column;gap:6px}.activity-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-surface-container-lowest);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;width:100%;transition:all .2s}.activity-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.activity-icon{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-container-low);border-radius:var(--radius-full);flex-shrink:0}.activity-info{display:flex;flex-direction:column;gap:2px;min-width:0}.activity-text{font-size:14px;font-weight:600;color:var(--color-on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:12px;color:var(--color-on-surface-variant)}.pwa-banner{position:fixed;bottom:calc(var(--nav-height) + 8px);left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:calc(var(--max-width) - 32px);z-index:200;animation:slide-up .3s ease-out}.pwa-banner-content{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy)}.pwa-banner-icon{font-size:28px}.pwa-banner-text{display:flex;flex-direction:column;flex:1;min-width:0}.pwa-banner-text strong{font-size:14px;color:var(--color-on-surface)}.pwa-banner-text span{font-size:12px;color:var(--color-on-surface-variant)}.pwa-banner-close{background:none;border:none;font-size:16px;color:var(--color-outline);cursor:pointer;padding:4px}.breed-section{padding:0 20px;margin-bottom:16px}.breed-id-btn{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:linear-gradient(135deg,var(--color-tertiary-container),var(--color-surface-container-low));border:none;border-radius:var(--radius-xl);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-on-surface);transition:all .2s}.breed-id-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-squishy)}.breed-id-btn:disabled{opacity:.7}.breed-result{padding:16px;background:var(--color-surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-squishy);animation:slide-up .3s ease-out}.breed-result-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.breed-result-emoji{font-size:32px}.breed-result-name{font-family:var(--font-headline);font-size:18px;font-weight:900}.breed-confidence{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase}.confidence-high{background:#34d39933;color:#059669}.confidence-medium{background:#fbbf2433;color:#d97706}.confidence-low{background:#ef444426;color:#dc2626}.breed-traits{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.breed-trait{padding:3px 10px;background:var(--color-surface-container);border-radius:var(--radius-full);font-size:12px;font-weight:600}.breed-fun-fact{font-size:13px;line-height:1.5;color:var(--color-on-surface-variant);margin-bottom:8px;padding:8px 12px;background:var(--color-tertiary-container);border-radius:var(--radius-lg)}.breed-care{font-size:13px;line-height:1.5}.breed-care ul{margin:4px 0 0 16px;padding:0}.breed-care li{margin-bottom:4px;color:var(--color-on-surface-variant)}.cat-confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;overflow:hidden}.confetti-particle{position:absolute;top:-30px;animation:confetti-fall linear forwards;will-change:transform}@keyframes confetti-fall{0%{transform:translateY(0) translate(0) rotate(0) scale(.5);opacity:1}20%{opacity:1;transform:translateY(20vh) translate(var(--drift, 0px)) rotate(120deg) scale(1.1)}to{transform:translateY(110vh) translate(calc(var(--drift, 0px) * 1.5)) rotate(720deg) scale(.4);opacity:0}}.post-success-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;animation:success-pop .5s cubic-bezier(.34,1.56,.64,1) forwards}.post-success-icon{font-size:64px;animation:success-bounce .6s cubic-bezier(.34,1.56,.64,1) .2s both}.post-success-title{font-family:var(--font-headline);font-size:28px;font-weight:800;color:var(--color-primary);margin:12px 0 4px}.post-success-text{color:var(--color-on-surface-variant);font-size:15px}@keyframes success-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes success-bounce{0%{transform:scale(0) rotate(-10deg)}50%{transform:scale(1.3) rotate(5deg)}to{transform:scale(1) rotate(0)}}.cat-eyes-svg{display:inline-block;vertical-align:middle;flex-shrink:0}.header-logo{display:inline-flex;align-items:center}.nav-tail{position:absolute;top:-14px;right:16px;opacity:.7;transition:opacity .3s}.cat-tail-svg .cat-tail-path{transition:d .3s ease}.cat-tail-svg.wagging .cat-tail-path{animation:tail-wag .4s ease-in-out infinite alternate}.cat-tail-svg.wagging .cat-tail-tip{animation:tail-tip-wag .4s ease-in-out infinite alternate}@keyframes tail-wag{0%{d:path("M2,20 Q10,6 20,12 Q30,18 38,4")}to{d:path("M2,20 Q14,8 20,16 Q26,24 38,8")}}@keyframes tail-tip-wag{0%{transform:translate(0)}to{transform:translate(-4px,4px)}}.memorial-wall{padding:0 20px 24px}.memorial-header{text-align:center;padding:28px 0 20px}.memorial-header-icon{font-size:48px;display:block;margin-bottom:8px;animation:memorial-rainbow-float 3s ease-in-out infinite}@keyframes memorial-rainbow-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.05)}}.memorial-header-title{font-family:var(--font-headline);font-size:24px;font-weight:800;color:var(--color-on-surface);margin:0 0 6px}.memorial-header-sub{font-size:14px;color:var(--color-on-surface-variant);line-height:1.5;max-width:320px;margin:0 auto}.memorial-share-btn{margin:0 0 24px}.memorial-empty{text-align:center;padding:40px 20px;color:var(--color-on-surface-variant)}.memorial-empty-icon{font-size:40px;display:block;margin-bottom:12px;opacity:.5}.memorial-grid{display:grid;gap:16px}.memorial-card{display:flex;background:var(--color-surface-container);border:none;border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;text-align:left;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s}.memorial-card:hover{transform:scale(1.02);box-shadow:var(--shadow-squishy)}.memorial-card:active{transform:scale(.98)}.memorial-card-photo{width:100px;min-height:100px;flex-shrink:0;overflow:hidden}.memorial-card-photo img{width:100%;height:100%;object-fit:cover}.memorial-card-placeholder{width:100px;min-height:100px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface-container-high);font-size:32px;opacity:.4}.memorial-card-body{padding:12px 14px;flex:1;min-width:0}.memorial-card-name{font-family:var(--font-headline);font-weight:800;font-size:16px;margin:0 0 2px;color:var(--color-on-surface)}.memorial-card-years{font-size:12px;color:var(--color-on-surface-variant);display:block;margin-bottom:6px}.memorial-card-story{font-size:13px;color:var(--color-on-surface-variant);line-height:1.4;margin:0}.memorial-card-reactions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.memorial-card-reaction-pip{font-size:12px;background:var(--color-surface-container-high);padding:2px 8px;border-radius:var(--radius-full);color:var(--color-on-surface-variant)}.memorial-detail-card{background:var(--color-surface-container);border-radius:var(--radius-xl);overflow:hidden;margin:16px 0;box-shadow:var(--shadow-soft)}.memorial-detail-photo{width:100%;max-height:300px;overflow:hidden}.memorial-detail-photo img{width:100%;height:100%;object-fit:cover}.memorial-detail-name{font-family:var(--font-headline);font-size:22px;font-weight:800;margin:16px 16px 2px;color:var(--color-on-surface)}.memorial-detail-years{font-size:14px;color:var(--color-on-surface-variant);margin:0 16px 12px}.memorial-detail-story{font-size:15px;line-height:1.65;color:var(--color-on-surface);margin:0 16px 16px;white-space:pre-line}.memorial-detail-meta{display:flex;justify-content:space-between;padding:12px 16px;font-size:12px;color:var(--color-on-surface-variant);border-top:1px solid var(--color-outline-variant)}.memorial-reactions-section{padding:20px 0}.memorial-reactions-prompt{text-align:center;font-family:var(--font-headline);font-weight:700;font-size:16px;margin:0 0 16px;color:var(--color-on-surface)}.memorial-reactions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.memorial-reaction-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border:2px solid var(--color-outline-variant);border-radius:var(--radius-lg);background:var(--color-surface-container);cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);overflow:visible}.memorial-reaction-btn:hover{transform:scale(1.06);border-color:var(--color-primary);box-shadow:var(--shadow-squishy)}.memorial-reaction-btn:active{transform:scale(.94)}.memorial-reaction-btn.active{border-color:var(--color-primary);background:var(--color-primary-container);box-shadow:var(--shadow-squishy)}.memorial-reaction-emoji{font-size:28px;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.memorial-reaction-btn.active .memorial-reaction-emoji{transform:scale(1.15)}.memorial-reaction-label{font-size:11px;font-weight:700;color:var(--color-on-surface-variant);text-align:center;line-height:1.2}.memorial-reaction-btn.active .memorial-reaction-label{color:var(--color-primary)}.memorial-reaction-count{font-size:12px;font-weight:800;color:var(--color-primary);background:var(--color-surface);padding:1px 8px;border-radius:var(--radius-full);min-width:20px;text-align:center}.react-purr .memorial-reaction-emoji{animation:purr-vibrate .6s ease-in-out}@keyframes purr-vibrate{0%,to{transform:translate(0) scale(1.1)}10%{transform:translate(-2px) scale(1.15)}20%{transform:translate(2px) scale(1.1)}30%{transform:translate(-1.5px) scale(1.15)}40%{transform:translate(1.5px) scale(1.1)}50%{transform:translate(-1px) scale(1.15)}60%{transform:translate(1px) scale(1.1)}}.react-rainbow .memorial-reaction-emoji{animation:rainbow-glow .8s ease-in-out}@keyframes rainbow-glow{0%{transform:scale(1);filter:brightness(1)}25%{transform:scale(1.3) rotate(-5deg);filter:brightness(1.4) hue-rotate(60deg)}50%{transform:scale(1.5) rotate(5deg);filter:brightness(1.6) hue-rotate(120deg)}75%{transform:scale(1.3) rotate(-3deg);filter:brightness(1.3) hue-rotate(180deg)}to{transform:scale(1.15);filter:brightness(1)}}.react-heart .memorial-reaction-emoji{animation:heart-beat .7s ease-in-out}@keyframes heart-beat{0%{transform:scale(1)}15%{transform:scale(1.35)}30%{transform:scale(1.05)}45%{transform:scale(1.3)}60%{transform:scale(1.1)}to{transform:scale(1.15)}}.react-candle .memorial-reaction-emoji{animation:candle-flicker .8s ease-in-out}@keyframes candle-flicker{0%{transform:scale(1) translateY(0);opacity:.8}20%{transform:scale(1.2) translateY(-4px);opacity:1}40%{transform:scale(1.1) translateY(-2px);opacity:.9}60%{transform:scale(1.25) translateY(-6px);opacity:1}80%{transform:scale(1.15) translateY(-3px);opacity:.95}to{transform:scale(1.15) translateY(0);opacity:1}}.react-forever .memorial-reaction-emoji{animation:paw-stamp .5s cubic-bezier(.34,1.56,.64,1)}@keyframes paw-stamp{0%{transform:scale(.5) rotate(-15deg);opacity:.3}50%{transform:scale(1.4) rotate(5deg);opacity:1}to{transform:scale(1.15) rotate(0);opacity:1}}.reaction-burst{position:absolute;top:50%;left:50%;pointer-events:none;z-index:10}.burst-particle{position:absolute;font-size:16px;animation:burst-fly .7s cubic-bezier(.34,1.56,.64,1) forwards;opacity:0}.burst-particle:nth-child(1){--burst-angle: 0deg}.burst-particle:nth-child(2){--burst-angle: 60deg}.burst-particle:nth-child(3){--burst-angle: 120deg}.burst-particle:nth-child(4){--burst-angle: 180deg}.burst-particle:nth-child(5){--burst-angle: 240deg}.burst-particle:nth-child(6){--burst-angle: 300deg}@keyframes burst-fly{0%{transform:translate(-50%,-50%) rotate(var(--burst-angle)) translateY(0) scale(.3);opacity:1}60%{opacity:1;transform:translate(-50%,-50%) rotate(var(--burst-angle)) translateY(-36px) scale(1.1)}to{transform:translate(-50%,-50%) rotate(var(--burst-angle)) translateY(-48px) scale(0);opacity:0}}.memorial-reactions-total{text-align:center;font-size:13px;color:var(--color-on-surface-variant);margin:16px 0 0;font-weight:600}.memorial-create-header{padding-top:8px}.memorial-create-intro{font-size:14px;color:var(--color-on-surface-variant);line-height:1.5;margin:0 0 20px}.memorial-photo-btn{width:100%}.form-hint{display:block;text-align:right;font-size:11px;color:var(--color-on-surface-variant);margin-top:4px}.memorial-posted{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;position:relative}.memorial-posted-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.memorial-star{position:absolute;font-size:20px;animation:star-float 2.5s ease-in-out infinite;opacity:0}.memorial-star:nth-child(1){top:10%;left:15%}.memorial-star:nth-child(2){top:20%;right:10%}.memorial-star:nth-child(3){top:40%;left:8%}.memorial-star:nth-child(4){top:55%;right:15%}.memorial-star:nth-child(5){top:70%;left:20%}.memorial-star:nth-child(6){top:30%;right:25%}@keyframes star-float{0%{opacity:0;transform:scale(.3) translateY(10px)}30%{opacity:1;transform:scale(1.2) translateY(-5px)}60%{opacity:.7;transform:scale(.9) translateY(-15px)}to{opacity:0;transform:scale(.3) translateY(-25px)}}.memorial-posted-icon{font-size:64px;animation:success-bounce .6s cubic-bezier(.34,1.56,.64,1) .2s both;position:relative;z-index:1}.memorial-posted-title{font-family:var(--font-headline);font-size:24px;font-weight:800;color:var(--color-primary);margin:12px 0 4px;position:relative;z-index:1}.memorial-posted-text{color:var(--color-on-surface-variant);font-size:15px;position:relative;z-index:1}
