.auth-screen{background:radial-gradient(circle at 50% 30%,rgba(244,216,154,.35) 0%,transparent 60%),linear-gradient(180deg,var(--cream) 0%,var(--cream-deep) 100%);padding:40px 24px}.auth-brand{text-align:center;margin:24px 0 32px}.auth-logo{font-size:56px;margin-bottom:8px}.auth-brand-name{font-family:var(--serif);font-size:40px;font-weight:500;color:var(--rust);letter-spacing:-.02em;line-height:1}.auth-brand-name em{font-style:italic;font-weight:400;color:var(--terracotta)}.auth-brand-tag{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-soft);margin-top:8px}.auth-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);padding:28px 24px;box-shadow:var(--shadow-sm)}.auth-title{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:6px}.auth-title em{font-style:italic;color:var(--terracotta)}.auth-subtitle{font-size:13px;color:var(--ink-muted);line-height:1.5;margin-bottom:20px}.auth-field{margin-bottom:14px}.auth-field-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-bottom:8px;display:block}.otp-row{display:flex;gap:8px;justify-content:center;margin:16px 0 8px}.otp-digit{width:44px;height:54px;text-align:center;font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);background:var(--cream);border:1.5px solid var(--line);border-radius:10px;outline:none;transition:border-color .2s,box-shadow .2s}.otp-digit:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px #d8694a26}.otp-digit.filled{border-color:var(--rust)}.auth-error{margin-top:12px;padding:10px 12px;background:#e8704a14;border:1px solid rgba(232,112,74,.3);border-radius:10px;font-size:13px;color:var(--coral)}.auth-success{margin-top:12px;padding:10px 12px;background:#7fa3721a;border:1px solid rgba(127,163,114,.3);border-radius:10px;font-size:13px;color:var(--sage-deep)}.auth-meta{margin-top:16px;font-size:12px;color:var(--ink-muted);text-align:center;line-height:1.5}.auth-meta a,.auth-meta button{color:var(--terracotta);font-weight:600;background:none;border:none;cursor:pointer;font-size:12px}.auth-disclaimer{text-align:center;font-size:11px;color:var(--ink-muted);margin-top:24px;line-height:1.5;padding:0 8px}.splash-screen{background:transparent;align-items:center;justify-content:center;padding:60px 32px}.splash-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px;flex:1;justify-content:center;animation:splashRise .9s cubic-bezier(.2,.9,.3,1)}.splash-logo-mark{margin-bottom:8px;animation:logoFloat 4s ease-in-out infinite}.splash-brand{font-family:var(--serif);font-size:56px;font-weight:500;color:var(--rust);letter-spacing:-.02em;line-height:1}.splash-brand em{font-style:italic;font-weight:400;color:var(--terracotta)}.splash-tagline{font-family:var(--serif);font-size:18px;font-weight:300;font-style:italic;color:var(--ink-soft);max-width:280px;line-height:1.5}.splash-cta{margin-top:24px;padding:18px 48px;background:var(--rust);color:var(--cream);border:none;border-radius:100px;font-family:var(--sans);font-size:16px;font-weight:600;letter-spacing:.01em;cursor:pointer;box-shadow:0 6px 20px #8b3a2840;transition:all .2s}.splash-cta:hover{transform:translateY(-2px);box-shadow:0 10px 28px #8b3a2852}.splash-secondary{margin-top:4px;padding:10px;background:transparent;border:none;color:var(--ink-soft);font-size:13px;font-weight:500;cursor:pointer}.splash-secondary:hover{color:var(--terracotta)}.splash-footer{position:absolute;bottom:32px;left:0;right:0;text-align:center;font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-muted)}.onboard-screen{background:transparent}.onboard-header{padding:18px 24px 0;flex-shrink:0}.onboard-step-label{font-size:12px;font-weight:600;color:var(--terracotta);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}.onboard-question,.onboard-title{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--ink);margin-bottom:12px;line-height:1.15;letter-spacing:-.015em}.onboard-question em,.onboard-title em{font-style:italic;font-weight:400;color:var(--terracotta)}.onboard-sub,.onboard-subtitle{font-size:15px;color:var(--ink-soft);line-height:1.55;margin-bottom:24px}.dietary-info-banner{background:#7fa3721f;border-left:3px solid var(--sage);padding:12px 14px;border-radius:8px;font-size:12px;color:var(--sage-deep);line-height:1.5;margin-bottom:16px}.onboard-body{flex:1;overflow-y:auto;padding:0 24px 20px}.onboard-section{margin-bottom:24px}.onboard-label{font-size:12px;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;display:block}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.onboard-bottom{padding:16px 24px;padding-bottom:max(16px,env(safe-area-inset-bottom));flex-shrink:0}.watch-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.watch-card{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:16px;position:relative}.watch-emoji{font-size:28px;margin-bottom:8px}.watch-name{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--ink);margin-bottom:4px;line-height:1.2}.watch-detail{font-size:12px;color:var(--ink-soft);line-height:1.4}.watch-tag{position:absolute;top:12px;right:12px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:100px}.watch-tag.alert{background:var(--coral);color:var(--cream)}.watch-tag.good{background:var(--sage);color:var(--cream)}.watch-footnote{font-size:12px;color:var(--ink-muted);margin-top:16px;line-height:1.5;font-style:italic}.nutrient-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.nutrient-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px;text-align:center}.nutrient-card .n-emoji{font-size:32px;margin-bottom:6px}.nutrient-card .n-name{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:2px}.nutrient-card .n-desc{font-size:12px;color:var(--ink-muted);line-height:1.3}.home-screen{background:transparent}.home-header{padding:8px 24px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}.home-greeting-block{flex:1;min-width:0}.home-greeting-label{font-size:12px;color:var(--ink-muted);font-weight:500;letter-spacing:.04em;margin-bottom:4px}.home-greeting-title{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink);line-height:1.2;letter-spacing:-.01em}.home-greeting-title em{font-style:italic;font-weight:400;color:var(--terracotta)}.switch-kid-btn{display:inline-flex;align-items:center;gap:5px;margin-top:8px;padding:5px 11px;background:var(--cream-deep);border:1px solid var(--line);border-radius:100px;font-size:11px;font-weight:600;color:var(--ink-soft);cursor:pointer}.switch-kid-btn:hover{border-color:var(--terracotta);color:var(--terracotta)}.home-section-label{padding:0 24px;font-size:12px;font-weight:600;color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;margin:18px 0 14px}.scan-cards{padding:0 24px;display:flex;flex-direction:column;gap:12px;margin-bottom:28px}.scan-card{padding:20px;display:flex;align-items:center;gap:16px;border-radius:20px;cursor:pointer;transition:all .25s ease;border:1.5px solid var(--line);background:var(--white)}.scan-card:hover{border-color:var(--terracotta);transform:translateY(-2px);box-shadow:var(--shadow-md)}.scan-card.primary{background:linear-gradient(135deg,var(--rust),var(--terracotta));border-color:var(--rust);color:var(--cream);box-shadow:0 8px 24px #8b3a2838}.scan-card.primary:hover{border-color:var(--rust);box-shadow:0 12px 30px #8b3a284d}.scan-card-icon{width:50px;height:50px;flex-shrink:0;border-radius:14px;background:#d8694a1a;color:var(--terracotta);display:flex;align-items:center;justify-content:center;font-size:24px}.scan-card.primary .scan-card-icon{background:#fff3;color:var(--cream)}.scan-card-info{flex:1;min-width:0}.scan-card-title{font-family:var(--serif);font-size:18px;font-weight:500;letter-spacing:-.01em;margin-bottom:2px;line-height:1.2}.scan-card-desc{font-size:12px;color:var(--ink-muted);line-height:1.4}.scan-card.primary .scan-card-desc{color:#fffc}.scan-card-arrow{font-size:18px;color:var(--ink-muted);flex-shrink:0}.scan-card.primary .scan-card-arrow{color:#ffffffb3}.recent-section{margin-top:8px;padding:0 24px 100px}.recent-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}.recent-title{font-size:12px;font-weight:600;color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase}.recent-link{font-size:12px;font-weight:600;color:var(--terracotta);cursor:pointer;background:none;border:none}.recent-list{display:flex;flex-direction:column;gap:8px}.tip-card{display:flex;align-items:flex-start;gap:14px;padding:18px;background:#f4d89a33;border:1px solid rgba(244,216,154,.5);border-radius:20px}.tip-emoji{font-size:28px;flex-shrink:0}.tip-text{font-size:13px;color:var(--ink-soft);line-height:1.5}.scan-frame{width:240px;height:240px;position:relative;display:flex;align-items:center;justify-content:center}.scan-corners{position:absolute;top:0;right:0;bottom:0;left:0}.corner{position:absolute;width:36px;height:36px;border-color:var(--rust);border-style:solid;border-width:0}.corner.tl{top:0;left:0;border-top-width:3px;border-left-width:3px;border-radius:8px 0 0}.corner.tr{top:0;right:0;border-top-width:3px;border-right-width:3px;border-radius:0 8px 0 0}.corner.bl{bottom:0;left:0;border-bottom-width:3px;border-left-width:3px;border-radius:0 0 0 8px}.corner.br{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-radius:0 0 8px}.scan-line-anim{position:absolute;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent);animation:scanLine 1.6s ease-in-out infinite}.scan-hint{font-size:13px;color:var(--ink-muted);text-align:center}.scan-note{font-size:12px;color:var(--ink-muted);margin-top:12px;line-height:1.4}.scan-divider{display:flex;align-items:center;gap:12px;margin:20px 0 12px;color:var(--ink-muted);font-size:12px;text-transform:uppercase;letter-spacing:.1em}.scan-divider:before,.scan-divider:after{content:"";flex:1;height:1px;background:var(--line)}.barcode-example{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px}.barcode-example-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:10px}.barcode-visual{display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid var(--line);border-radius:6px;padding:10px 14px;margin-bottom:10px}.barcode-bars{font-family:SF Mono,Menlo,monospace;letter-spacing:-1px;font-size:24px;color:var(--ink);-webkit-user-select:none;user-select:none;line-height:1}.barcode-digits{display:flex;gap:8px;font-family:SF Mono,Menlo,monospace;font-size:13px;color:var(--ink);margin-top:4px}.barcode-digit-edge{background:#d8694a26;border:1.5px solid var(--terracotta);border-radius:4px;padding:1px 6px;font-weight:700;color:var(--rust)}.barcode-example-note{font-size:12px;color:var(--ink-muted);line-height:1.5}.lookup-error{display:flex;flex-direction:column;align-items:center;text-align:center;padding:16px;background:#e8704a0f;border:1px solid rgba(232,112,74,.25);border-radius:var(--radius-sm);margin-top:12px}.link-status{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm)}.processing-spinner{width:28px;height:28px;border:3px solid var(--line);border-top-color:var(--rust);border-radius:50%;animation:spinFwd .8s linear infinite}.photo-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;background:var(--white);border:2px dashed var(--line);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.photo-upload-area:hover{border-color:var(--terracotta);background:#d8694a0a}.photo-upload-icon{font-size:56px;margin-bottom:12px}.photo-upload-title{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);margin-bottom:6px}.photo-upload-desc{font-size:13px;color:var(--ink-muted);text-align:center;line-height:1.4}.scan-tip{display:flex;gap:12px;padding:16px;margin-top:16px;background:#f4d89a33;border:1px solid rgba(244,216,154,.5);border-radius:var(--radius-md)}.scan-tip-icon{font-size:22px;flex-shrink:0}.photo-result{display:flex;flex-direction:column;align-items:center;padding:20px 0}.photo-preview{width:100%;max-width:320px;border-radius:var(--radius-md);margin-bottom:20px;box-shadow:var(--shadow-md)}.photo-status{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;font-size:15px;font-weight:600;color:var(--ink)}.photo-status-sub{font-size:13px;font-weight:400;color:var(--ink-muted)}.link-prompt{text-align:center;padding:16px 0 24px}.link-emoji{font-size:48px;margin-bottom:12px}.link-title{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);margin-bottom:4px}.link-desc{font-size:13px;color:var(--ink-muted)}.retailer-chips{display:flex;flex-wrap:wrap;gap:8px}code{background:var(--cream-deep);padding:1px 5px;border-radius:4px;font-size:11px;font-family:SF Mono,Menlo,monospace}.result-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--white);border:1.5px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;cursor:pointer}.result-card:hover{border-color:var(--terracotta);box-shadow:var(--shadow-sm)}.result-card-thumb{width:48px;height:48px;border-radius:10px;background:var(--cream-deep);display:flex;align-items:center;justify-content:center;font-size:26px}.result-card-info{flex:1;min-width:0}.result-card-name{font-size:15px;font-weight:600;color:var(--ink)}.result-card-brand{font-size:12px;color:var(--ink-muted);margin-top:2px}.result-top-bar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:10px 14px 10px 8px;background:var(--cream);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.result-top-bar.safe{border-bottom-color:#7fa37266}.result-top-bar.flag{border-bottom-color:#e8704a66}.result-top-bar.warn{border-bottom-color:#f4d89a99}.result-back-btn{width:36px;height:36px;border-radius:50%;background:transparent;border:none;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:20px}.result-back-btn:hover{background:var(--cream-deep)}.result-product-id{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.result-product-thumb{width:38px;height:38px;border-radius:10px;background:var(--butter);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.result-product-text{flex:1;min-width:0}.result-product-brand{font-size:10px;color:var(--ink-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-product-name{font-size:14px;font-weight:600;color:var(--ink);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.verdict-band{display:flex;align-items:center;gap:10px;padding:12px 16px}.verdict-band.safe{background:linear-gradient(90deg,#7fa3722e,#7fa3720f)}.verdict-band.flag{background:linear-gradient(90deg,#e8704a33,#e8704a0f)}.verdict-band.warn{background:linear-gradient(90deg,#f4d89a8c,#f4d89a2e)}.verdict-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--cream);font-size:18px;font-weight:700}.verdict-band.safe .verdict-icon{background:var(--sage)}.verdict-band.flag .verdict-icon{background:var(--coral)}.verdict-band.warn .verdict-icon{background:var(--rust)}.verdict-text{flex:1;min-width:0}.verdict-label{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);line-height:1.15;letter-spacing:-.01em}.verdict-label em{font-style:italic}.verdict-meta{font-size:11px;color:var(--ink-soft);margin-top:1px}.r-section-label{font-size:10px;font-weight:700;color:var(--ink-muted);letter-spacing:.1em;text-transform:uppercase;margin:14px 16px 8px}.r-section-label strong{color:var(--terracotta)}.score-ring-row{display:flex;align-items:center;gap:16px;padding:14px 16px}.score-ring-mini{position:relative;width:84px;height:84px;flex-shrink:0}.score-ring-mini svg{width:100%;height:100%}.score-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-ring-num{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1}.score-ring-grade{font-size:10px;font-weight:700;margin-top:2px;letter-spacing:.04em}.score-dim-bars{flex:1;display:flex;flex-direction:column;gap:6px}.dim-row{display:flex;align-items:center;gap:8px;font-size:11px}.dim-name{width:70px;color:var(--ink-soft);font-weight:600;flex-shrink:0}.dim-track{flex:1;height:6px;background:#e8dcc480;border-radius:3px;overflow:hidden}.dim-fill{height:100%;border-radius:3px;transition:width .6s ease}.dim-val{width:24px;text-align:right;font-weight:700;color:var(--ink);font-size:10px;flex-shrink:0}.flag-cols{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px}.flag-col{background:var(--cream);border:1.5px solid var(--line);border-radius:12px;padding:10px 10px 8px;display:flex;flex-direction:column}.flag-col.green{border-color:#7fa37273;background:#7fa3720f}.flag-col.red{border-color:#e8704a73;background:#e8704a0f}.flag-col-head{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}.flag-col.green .flag-col-head{color:var(--sage-deep)}.flag-col.red .flag-col-head{color:var(--rust)}.flag-col-head .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.flag-col.green .dot{background:var(--sage)}.flag-col.red .dot{background:var(--coral)}.flag-list{display:flex;flex-direction:column;gap:6px}.flag-item{display:flex;gap:6px;align-items:flex-start;font-size:12px;color:var(--ink);line-height:1.35}.flag-item-icon{flex-shrink:0;font-size:11px;line-height:1.4}.flag-item-text{flex:1}.flag-item-text b{font-weight:600}.flag-item-text small{display:block;font-size:10px;color:var(--ink-muted);margin-top:2px;font-weight:400}.flag-empty{font-size:11px;color:var(--ink-muted);font-style:italic}.serving-context-banner{margin:6px 16px;padding:8px 12px;background:#f4d89a66;border-radius:8px;font-size:11px;color:var(--ink-soft);display:flex;align-items:center;gap:6px;line-height:1.4}.serving-context-banner:before{content:"ℹ";color:var(--terracotta);font-weight:700;flex-shrink:0}.serving-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:0 16px;margin-bottom:8px}.serving-toggle{display:inline-flex;background:var(--cream-deep);border:1px solid var(--line);border-radius:100px;padding:2px;gap:2px}.serving-toggle button{padding:5px 11px;background:transparent;border:none;font-family:var(--sans);font-size:11px;font-weight:600;color:var(--ink-soft);cursor:pointer;border-radius:100px;transition:all .2s;letter-spacing:.02em}.serving-toggle button.active{background:var(--rust);color:var(--cream);box-shadow:0 2px 6px #8b3a2833}.serving-info{font-size:10px;color:var(--ink-muted);font-style:italic}.insight-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px}.insight-card{background:var(--cream);border:1.5px solid var(--line);border-radius:12px;padding:10px 11px;position:relative}.insight-card.alert{border-color:#e8704a66;background:#e8704a0d}.insight-card.good{border-color:#7fa37266;background:#7fa3720f}.insight-row-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.insight-emoji{font-size:16px}.insight-mini-tag{font-size:8px;font-weight:700;padding:2px 5px;border-radius:100px;letter-spacing:.04em;text-transform:uppercase}.insight-mini-tag.alert{background:var(--coral);color:var(--cream)}.insight-mini-tag.good{background:var(--sage);color:var(--cream)}.insight-label{font-size:10px;font-weight:700;color:var(--ink-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:1px}.insight-value{font-family:var(--serif);font-size:16px;font-weight:500;color:var(--ink);line-height:1.1;letter-spacing:-.01em}.insight-context{font-size:10px;color:var(--ink-soft);margin-top:3px;line-height:1.35}.ingredients-box{margin:8px 16px;padding:12px 14px;background:var(--cream);border:1px solid var(--line);border-radius:12px;font-size:12px;color:var(--ink-soft);line-height:1.6}.source-row{margin:12px 16px 24px;padding:9px 12px;background:transparent;border:1px dashed var(--line);border-radius:12px;font-size:10px;color:var(--ink-muted);display:flex;align-items:center;gap:6px;line-height:1.4}.source-row strong{color:var(--ink-soft);font-weight:600}.partial-data-box{text-align:center;padding:24px 8px}.partial-data-box .partial-emoji{font-size:48px;margin-bottom:12px}.partial-data-box .partial-title{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);margin-bottom:8px}.partial-data-box .partial-note{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-bottom:16px;padding:0 8px}.bot-screen{background:var(--cream)}.bot-header{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--cream);border-bottom:1px solid var(--line);flex-shrink:0}.bot-back{background:transparent;border:none;cursor:pointer;color:var(--ink);padding:6px;display:flex;align-items:center;justify-content:center;font-size:22px}.bot-header-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--butter),var(--terracotta));color:var(--rust);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.bot-header-text{flex:1}.bot-header-name{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--ink);letter-spacing:-.01em}.bot-header-status{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--sage-deep);margin-top:1px}.bot-header-status:before{content:"";width:6px;height:6px;background:var(--sage);border-radius:50%;display:inline-block}.bot-messages{flex:1;overflow-y:auto;padding:20px 16px 12px;display:flex;flex-direction:column;gap:12px}.bot-msg{display:flex;gap:8px;max-width:85%;animation:msgIn .4s ease both}.bot-msg.from-bot{align-self:flex-start}.bot-msg.from-user{align-self:flex-end;flex-direction:row-reverse}.bot-msg-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--butter),var(--terracotta));flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}.bot-msg-bubble{padding:12px 14px;border-radius:18px;font-size:14px;line-height:1.45;white-space:pre-wrap}.bot-msg.from-bot .bot-msg-bubble{background:var(--white);color:var(--ink);border-bottom-left-radius:4px;box-shadow:var(--shadow-sm)}.bot-msg.from-bot .bot-msg-bubble strong{color:var(--terracotta);font-weight:600}.bot-msg.from-user .bot-msg-bubble{background:var(--rust);color:var(--cream);border-bottom-right-radius:4px}.bot-msg.from-user .bot-msg-bubble strong{color:var(--butter);font-weight:600}.bot-typing{display:flex;gap:4px;padding:14px 16px;background:var(--white);border-radius:18px 18px 18px 4px;align-self:flex-start;margin-left:36px;box-shadow:var(--shadow-sm)}.bot-typing span{width:7px;height:7px;background:var(--ink-muted);border-radius:50%;animation:typing 1.2s ease-in-out infinite}.bot-typing span:nth-child(2){animation-delay:.15s}.bot-typing span:nth-child(3){animation-delay:.3s}.bot-suggestions{padding:4px 16px 8px;display:flex;gap:8px;overflow-x:auto;flex-shrink:0}.bot-suggestions::-webkit-scrollbar{display:none}.suggestion-chip{background:var(--white);border:1px solid var(--line);border-radius:100px;padding:8px 14px;font-size:12px;font-family:var(--sans);color:var(--ink);cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.suggestion-chip:hover{border-color:var(--terracotta);color:var(--terracotta)}.bot-input-row{display:flex;gap:8px;padding:12px 16px 14px;padding-bottom:max(14px,env(safe-area-inset-bottom));background:var(--cream);border-top:1px solid var(--line);flex-shrink:0}.bot-input{flex:1;padding:12px 16px;border:1.5px solid var(--line);border-radius:100px;font-family:var(--sans);font-size:14px;background:var(--cream-deep);color:var(--ink);outline:none}.bot-input:focus{border-color:var(--terracotta)}.bot-input::placeholder{color:var(--ink-muted)}.bot-send{width:44px;height:44px;border-radius:50%;background:var(--rust);color:var(--cream);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}.bot-send:disabled{background:var(--line);color:var(--ink-muted);cursor:not-allowed}:root{--cream: #FBF6EE;--cream-deep: #F4E9D7;--terracotta: #D8694A;--terracotta-deep: #B8533C;--rust: #8B3A28;--butter: #F4D89A;--sage: #7FA372;--sage-deep: #5F8456;--coral: #E8704A;--ink: #3A2E26;--ink-soft: #6A5A4E;--ink-muted: #9E8E7E;--line: #E8DCC4;--white: #FFFFFF;--shadow-sm: 0 2px 6px rgba(58, 46, 38, .06);--shadow-md: 0 8px 24px rgba(58, 46, 38, .1);--shadow-lg: 0 20px 50px rgba(58, 46, 38, .15);--radius-sm: 12px;--radius-md: 20px;--radius-lg: 28px;--serif: "Fraunces", Georgia, serif;--sans: "DM Sans", -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;width:100%}body{font-family:var(--sans);background:radial-gradient(circle at 10% 20%,rgba(216,105,74,.08) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(127,163,114,.06) 0%,transparent 40%),var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;overflow:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.4;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.23  0 0 0 0 0.18  0 0 0 0 0.15  0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}#root{position:relative;z-index:1}::-webkit-scrollbar{width:0;height:0}input,button,textarea{font-family:inherit}button{cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes splashRise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes scanLine{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:180px;opacity:0}}@keyframes spinFwd{to{transform:rotate(360deg)}}@keyframes progressFill{0%{width:0%}}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}@keyframes msgIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .5s ease both}.app-shell{width:100%;height:100vh;max-width:430px;margin:0 auto;position:relative;overflow:hidden;background:transparent}.status-bar{height:env(safe-area-inset-top,12px);flex-shrink:0}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;animation:fadeIn .4s ease both;overflow:hidden}.scrollable{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.btn-primary{width:100%;padding:16px 24px;background:var(--rust);color:var(--cream);border:none;border-radius:100px;font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all .2s ease;box-shadow:0 6px 18px #8b3a2838}.btn-primary:hover{background:var(--terracotta-deep);transform:translateY(-1px);box-shadow:0 10px 24px #8b3a2847}.btn-primary:active{transform:translateY(0)}.btn-primary[disabled]{background:var(--line);color:var(--ink-muted);cursor:not-allowed;box-shadow:none;transform:none}.btn-ghost{width:100%;padding:14px 24px;background:transparent;color:var(--ink-soft);border:1.5px solid var(--line);border-radius:100px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-ghost:hover{border-color:var(--ink-soft);background:#e8dcc44d}.btn-text{background:none;border:none;color:var(--terracotta);font-size:13px;font-weight:600;cursor:pointer;padding:4px 0}.text-input{width:100%;background:var(--cream);border:1.5px solid var(--line);border-radius:12px;padding:16px 18px;font-size:15px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}.text-input:focus{border-color:var(--terracotta);box-shadow:0 0 0 4px #d8694a1f}.chip{display:inline-flex;align-items:center;gap:4px;padding:10px 16px;background:var(--white);border:1.5px solid var(--line);border-radius:100px;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--terracotta)}.chip.selected{background:var(--terracotta);color:var(--cream);border-color:var(--terracotta)}.chip.selected:before{content:"✓ ";font-weight:700}.chip.chip-restriction.selected{background:var(--sage-deep);border-color:var(--sage-deep)}.age-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.age-pill{padding:14px 10px;background:var(--white);border:1.5px solid var(--line);border-radius:12px;cursor:pointer;text-align:center;font-size:13px;font-weight:500;color:var(--ink);transition:all .2s}.age-pill:hover{border-color:var(--terracotta)}.age-pill.selected{background:var(--terracotta);color:var(--cream);border-color:var(--terracotta)}.age-card{background:var(--white);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:16px;cursor:pointer;transition:all .2s;text-align:center}.age-card:hover{border-color:var(--terracotta)}.age-card.selected{border-color:var(--terracotta);background:#d8694a0f}.age-card .emoji{font-size:32px;margin-bottom:8px}.age-card .label{font-size:14px;font-weight:600;color:var(--ink)}.age-card .hint{font-size:12px;color:var(--ink-muted);margin-top:2px}.onboard-progress{display:flex;gap:6px;margin-bottom:18px}.onboard-progress span{flex:1;height:4px;border-radius:2px;background:var(--line);transition:background .3s}.onboard-progress span.done,.onboard-progress span.active{background:var(--terracotta)}.step-dots{display:flex;gap:6px;margin-bottom:20px}.step-dot{flex:1;height:4px;background:var(--line);border-radius:2px;transition:all .3s}.step-dot.active,.step-dot.done{background:var(--terracotta)}.section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:12px}.nav-header{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;flex-shrink:0}.nav-back{width:40px;height:40px;border-radius:50%;background:transparent;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;color:var(--ink)}.nav-back:hover{background:var(--cream-deep)}.badge{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:100px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.badge.safe{background:var(--sage);color:var(--cream)}.badge.flag{background:var(--coral);color:var(--cream)}.badge.warn{background:var(--butter);color:var(--ink)}.ask-bar{position:absolute;left:14px;right:14px;bottom:14px;padding-bottom:env(safe-area-inset-bottom,0px);z-index:50;pointer-events:none}.ask-bar-inner{background:linear-gradient(135deg,var(--rust),var(--terracotta));border-radius:100px;padding:11px 16px 11px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;pointer-events:auto;box-shadow:0 8px 22px #8b3a2852;transition:all .2s}.ask-bar-inner:hover{transform:translateY(-2px);box-shadow:0 12px 26px #8b3a2866}.ask-bar-avatar{width:30px;height:30px;border-radius:50%;background:var(--butter);display:flex;align-items:center;justify-content:center;font-size:16px;position:relative;flex-shrink:0}.ask-bar-avatar:after{content:"";position:absolute;bottom:0;right:-1px;width:9px;height:9px;background:var(--sage);border:2px solid var(--rust);border-radius:50%}.ask-bar-text{flex:1;min-width:0}.ask-bar-title{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--cream);line-height:1.1}.ask-bar-sub{font-size:10px;color:#fffc;margin-top:1px}.ask-bar-arrow{color:var(--cream);font-size:18px;flex-shrink:0}.fab-bot{display:none}.avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:500;font-size:18px;cursor:pointer;flex-shrink:0;box-shadow:var(--shadow-sm)}.avatar.color-1{background:linear-gradient(135deg,var(--butter),var(--terracotta));color:var(--rust)}.avatar.color-2{background:linear-gradient(135deg,#C8E0B4,var(--sage-deep));color:var(--cream)}.avatar.color-3{background:linear-gradient(135deg,var(--butter),#C7826B);color:var(--rust)}.recent-item{display:flex;align-items:center;gap:12px;padding:14px;background:#f4e9d780;border-radius:12px;margin-bottom:8px;cursor:pointer;transition:background .2s}.recent-item:hover{background:var(--cream-deep)}.recent-thumb{width:38px;height:38px;border-radius:10px;background:var(--cream-deep);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.recent-thumb.safe{background:#7fa3722e;color:var(--sage-deep)}.recent-thumb.flag{background:#e8704a2e;color:var(--coral)}.recent-info{flex:1;min-width:0}.recent-name{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-status,.recent-brand{font-size:11px;color:var(--ink-muted);margin-top:2px}.recent-time{font-size:11px;color:var(--ink-muted);flex-shrink:0}
