:root{--bg-surface-primary:#f7f1e6;--bg-surface-elevated:#ffffff;--bg-surface-sunken:#eee6d8;--text-primary:#2a201f;--text-secondary:#6b5a55;--text-disabled:#b4aca0;--text-on-accent:#ffffff;--accent:#7a2e3d;--accent-deep:#5c2230;--accent-on-light:#6e2735;--accent-tint:#efd9de;--border:#e5ddcd;--border-strong:#c9c0ae;--border-focus:var(--accent);--success:#5f6e37;--warning:#b6843a;--error:#a93d2a;--info:#5a6b78;--status-pill:#ebe3d0;--map-land:#eee6d8;--map-water:#dde3de;--map-road:#e5ddcd;--map-label:#6b5a55;--map-pin:var(--accent);--map-radius-fill:rgba(122,46,61,0.12);--font-display:var(--font-inter),var(--font-sarabun),"Noto Sans Thai",system-ui,sans-serif;--font-body:var(--font-inter),var(--font-sarabun),"Noto Sans Thai",system-ui,sans-serif;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:20px;--text-xl:24px;--text-2xl:30px;--text-3xl:36px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-display-weight:700;--tracking-tight:-0.01em;--tracking-normal:0;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-pill:999px;--elev-flat:none;--elev-raised:0 1px 2px rgba(60,40,25,0.06),0 4px 12px rgba(60,40,25,0.08);--elev-overlay:0 12px 32px rgba(60,40,25,0.14);--shadow-sm:0 1px 2px rgba(60,40,25,0.06);--shadow-md:var(--elev-raised);--shadow-lg:var(--elev-overlay);--motion-fast:120ms;--motion-standard:200ms;--motion-slow:350ms;--motion-ease-default:cubic-bezier(0.4,0,0.2,1);--motion-reduced:0ms;--texture-grain:rgba(60,40,25,0.05)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg-surface-primary);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;-webkit-font-smoothing:antialiased}.pair{display:inline-flex;gap:var(--space-1)}.pair__en,.pair__th{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.pair__th{line-height:1.6}.pair--title .pair__en,.pair--title .pair__th{font-size:var(--text-lg);font-weight:var(--font-weight-bold)}.pair--hero .pair__en,.pair--hero .pair__th{font-size:var(--text-2xl);font-weight:var(--font-weight-bold)}.pair--muted .pair__en,.pair--muted .pair__th{color:var(--text-secondary)}.pair--row{gap:var(--space-2);align-items:baseline;flex-wrap:wrap}.lang-toggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-pill);overflow:hidden}.lang-toggle__seg{min-height:44px;padding:var(--space-1) var(--space-3);font:var(--font-weight-semibold) var(--text-sm) /1.4 var(--font-body);background:transparent;color:var(--text-secondary);border:none;cursor:pointer;transition:background var(--motion-fast) var(--motion-ease-default)}.lang-toggle__seg[aria-pressed=true]{background:var(--accent-tint);color:var(--accent-on-light)}.lang-toggle__seg:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.app-header__lang{flex-shrink:0}.app-shell__lang{display:flex;justify-content:flex-end;padding:var(--space-2) var(--space-4) 0}.icon-inline{display:inline-block;vertical-align:text-bottom;flex-shrink:0}.ai-portrait{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface-sunken);margin:0}.ai-portrait__img{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:3/4;object-fit:cover;color:var(--text-disabled);background:linear-gradient(135deg,var(--bg-surface-sunken),var(--accent-tint));font-size:var(--text-2xl);font-weight:var(--font-weight-bold)}.ai-badge{position:absolute;left:var(--space-2);bottom:var(--space-2);display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:color-mix(in srgb,var(--text-primary) 72%,transparent);color:var(--text-on-accent);border-radius:var(--radius-pill);font:var(--font-weight-medium) var(--text-xs) /1.4 var(--font-body);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ai-badge .pair{gap:0}.ai-badge .pair__en,.ai-badge .pair__th{font-size:var(--text-xs);font-weight:var(--font-weight-medium);color:var(--text-on-accent)}.portrait-gallery{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) 0;margin-top:var(--space-2);-webkit-overflow-scrolling:touch}.portrait-gallery__thumb{position:relative;flex:0 0 auto;width:64px;padding:0;border:2px solid transparent;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface-sunken);cursor:pointer}.portrait-gallery__thumb:disabled{cursor:default}.portrait-gallery__thumb[aria-pressed=true]{border-color:var(--accent)}.portrait-gallery__thumb-img{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:3/4;object-fit:cover;color:var(--text-disabled);background:linear-gradient(135deg,var(--bg-surface-sunken),var(--accent-tint));font-size:var(--text-lg);font-weight:var(--font-weight-bold)}.portrait-gallery__active{position:absolute;left:0;right:0;bottom:0;padding:2px 0;background:color-mix(in srgb,var(--accent) 88%,transparent);color:var(--text-on-accent);font:var(--font-weight-medium) var(--text-xs) /1.2 var(--font-body);text-align:center}.match-figure{display:inline-flex;align-items:baseline;gap:var(--space-1);font:var(--font-weight-bold) var(--text-3xl) /1.15 var(--font-display);letter-spacing:var(--tracking-tight);color:var(--accent-on-light)}.match-figure span{font-size:var(--text-base);font-weight:var(--font-weight-semibold)}.posture-pill{display:inline-flex;gap:var(--space-1);align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font:var(--font-weight-semibold) var(--text-sm) /1.5 var(--font-body)}.posture-pill--good{background:color-mix(in srgb,var(--success) 14%,transparent);color:var(--success)}.posture-pill--neutral{background:var(--accent-tint);color:var(--accent-on-light)}.posture-pill--watch{background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--warning)}.trust-row{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.verified-badge{background:color-mix(in srgb,var(--success) 14%,transparent);color:var(--success)}.trust-chip,.verified-badge{display:inline-flex;gap:var(--space-1);align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font:var(--font-weight-semibold) var(--text-sm) /1.5 var(--font-body)}.trust-chip{background:var(--bg-surface-sunken);color:var(--text-secondary)}.combo-pill-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:var(--space-2);gap:var(--space-2);width:100%}.combo-pill{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font:var(--font-weight-semibold) var(--text-xs) /1.4 var(--font-body);background:var(--bg-surface-sunken);color:var(--text-secondary);text-align:center}.cand-card{display:block;text-align:left;cursor:pointer;background:var(--bg-surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--elev-raised);overflow:hidden;padding:0;font-family:inherit;width:100%;transition:box-shadow var(--motion-standard) var(--motion-ease-default),border-color var(--motion-standard) var(--motion-ease-default)}.cand-card:hover{box-shadow:var(--elev-overlay);border-color:var(--border-strong)}.cand-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.cand-card .ai-portrait{border-radius:0}.cand-card__body{padding:var(--space-3)}.cand-card__match{margin-bottom:var(--space-1)}.cand-card__match--overlay{position:absolute;top:var(--space-2);right:var(--space-2);margin:0;display:inline-flex;align-items:center;z-index:1;padding:2px var(--space-2);background:color-mix(in srgb,var(--bg-surface-elevated) 86%,transparent);border-radius:var(--radius-pill);box-shadow:var(--elev-raised);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.cand-card__match--overlay .match-figure{font-size:var(--text-base)}.cand-card__match--overlay .match-figure span{font-size:var(--text-xs)}.cand-card__match--wiw{right:auto;left:var(--space-2)}.cand-card__match--wid{left:auto;right:var(--space-2)}.cand-card__name{font-weight:var(--font-weight-bold);font-size:var(--text-xl);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cand-card__name-overlay{position:absolute;left:0;right:0;bottom:0;z-index:1;display:flex;flex-wrap:nowrap;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-4) var(--space-3) var(--space-2);background:linear-gradient(0deg,color-mix(in srgb,#000 58%,transparent),color-mix(in srgb,#000 28%,transparent) 60%,transparent);pointer-events:none}.cand-card__name-overlay .cand-card__name{color:#fff;font-size:var(--text-lg);min-width:0;flex:1 1 auto;text-shadow:0 1px 2px color-mix(in srgb,#000 50%,transparent)}.cand-card__name-overlay .cand-card__dist{flex:0 0 auto;margin-top:0;color:#fff;text-shadow:0 1px 2px color-mix(in srgb,#000 50%,transparent)}.cand-card__dist,.cand-card__meta{color:var(--text-secondary);font-size:var(--text-sm)}.cand-card__dist{display:inline-flex;align-items:center;gap:var(--space-1);margin-top:var(--space-1)}.card{background:var(--bg-surface-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--elev-raised);padding:var(--space-4);margin-bottom:var(--space-3)}.card__title{margin:0 0 var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin:0 0 var(--space-2)}.card__header>.card__title{margin:0}.card__actions{display:inline-flex;align-items:center;gap:var(--space-2)}.edit-wiwwid-section{box-shadow:none;background:var(--bg-surface-primary,var(--bg-surface-elevated))}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:48px;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font:var(--font-weight-semibold) var(--text-base) /1.2 var(--font-body);cursor:pointer;border:1px solid transparent;transition:background var(--motion-fast) var(--motion-ease-default)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-deep)}.btn-primary:disabled{background:var(--border-strong);color:var(--text-disabled);cursor:not-allowed}.btn-secondary{background:var(--bg-surface-elevated);color:var(--accent-on-light);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--bg-surface-sunken)}.btn--compact.btn-primary,.btn--compact.btn-secondary{min-height:0;width:auto;padding:var(--space-1) var(--space-3);font:var(--font-weight-semibold) var(--text-sm) /1.5 var(--font-body)}.info-bar{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);background:var(--bg-surface-sunken);color:var(--text-secondary);margin-bottom:var(--space-4)}.info-bar--privacy{background:var(--accent-tint);color:var(--accent-on-light)}.info-bar--warn{background:color-mix(in srgb,var(--warning) 14%,transparent);color:var(--warning)}.alert-bar{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);background:color-mix(in srgb,var(--error) 12%,transparent);color:var(--error);margin-bottom:var(--space-4)}.reveal-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-surface-sunken);border:1px dashed var(--border-strong);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;text-align:left;color:var(--text-primary)}.reveal-btn:hover{border-color:var(--accent)}.reveal-btn:disabled{opacity:.5;cursor:not-allowed}.reveal-btn__body{flex:1 1;min-width:0}.reveal-btn__cost{border:1px solid var(--accent-on-light);border-radius:var(--radius-pill);background:var(--accent-tint);color:var(--accent-on-light)}.reveal-btn__cost,.reveal-btn__photo-count{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-sm);font-weight:var(--font-weight-bold)}.reveal-btn__photo-count{border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--bg-surface-elevated);color:var(--text-secondary)}.reveal-cover{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;background:var(--bg-surface-primary);color:var(--text-primary);overscroll-behavior:contain}.reveal-cover__bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-subtle,var(--border-strong));background:var(--bg-surface-elevated)}.reveal-cover__title{margin:0;min-width:0;flex:1 1 auto;font-size:var(--text-lg);color:var(--text-primary)}.reveal-cover__close{flex:0 0 auto;position:relative;z-index:1}.reveal-cover__body{flex:1 1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.reveal-cover__field{background:var(--accent-tint);border:1px solid var(--accent);border-radius:var(--radius-md);padding:var(--space-4)}.reveal-cover__field h3{margin:0 0 var(--space-2);font-size:var(--text-sm);color:var(--accent-on-light)}.reveal-cover__field p{margin:0}.reveal-cover__hint{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.reveal-cover__body--deck{align-items:center;justify-content:flex-start;overflow-x:hidden}.reveal-deck__slide{position:relative;max-width:480px;margin:0 auto;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface-sunken)}.reveal-deck__img,.reveal-deck__slide{width:100%;max-height:calc(100dvh - 220px)}.reveal-deck__img{display:block;aspect-ratio:3/4;object-fit:cover;object-fit:contain}.reveal-deck__real-person{position:absolute;top:var(--space-3);left:var(--space-3);display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:var(--font-weight-bold);line-height:1.2}.reveal-deck__nav{display:flex;align-items:center;justify-content:center;gap:var(--space-4);width:100%}.reveal-deck__count{font-size:var(--text-sm);color:var(--text-secondary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:4ch;text-align:center}.reveal-deck__dots{display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.reveal-deck__dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-pill);background:var(--text-secondary);opacity:.45}.reveal-deck__dot[data-active=true]{background:var(--accent);opacity:1}.reveal-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.reveal-actions--two-buttons{gap:var(--space-2)}.reveal-actions__row{display:flex;flex-direction:column;gap:var(--space-3)}.reveal-nudge{margin:0;font-size:var(--text-sm);color:var(--text-secondary);text-align:center}.revealed-block{margin:var(--space-4) 0;padding:var(--space-4);background:var(--accent-tint);border:1px solid var(--accent);border-radius:var(--radius-md);font-size:var(--text-sm)}.revealed-block h3{margin:0 0 var(--space-2);color:var(--accent-on-light);font-size:var(--text-sm)}.modal-card{background:var(--bg-surface-elevated);border-radius:var(--radius-lg);box-shadow:var(--elev-overlay);padding:var(--space-6);max-width:420px;width:100%;max-height:calc(100dvh - var(--space-4) * 2);display:flex;flex-direction:column}.modal__title{margin:0 0 var(--space-3);flex:0 0 auto}.modal__body{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;margin:0 calc(-1 * var(--space-6));padding:0 var(--space-6)}.modal__actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);flex:0 0 auto}.sku-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3);margin-bottom:var(--space-4)}.sku{display:block;position:relative;text-align:left;padding:var(--space-3);background:var(--bg-surface-elevated);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;color:var(--text-primary);transition:border-color var(--motion-fast) var(--motion-ease-default)}.sku:hover{border-color:var(--border-strong)}.sku:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.sku.selected{border-color:var(--accent);background:var(--accent-tint);color:var(--accent-on-light)}.sku__tokens{margin-top:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.sku.selected .sku__tokens{color:var(--accent-on-light)}.sku__price{font-size:var(--text-lg)}.sku__bonus,.sku__price{font-weight:var(--font-weight-bold)}.sku__bonus{position:absolute;top:var(--space-2);right:var(--space-2);padding:2px var(--space-2);background:var(--success);color:var(--text-on-accent);border-radius:var(--radius-pill);font-size:var(--text-xs)}.sku__price--strikethrough{color:var(--text-secondary);font-weight:var(--font-weight-regular)}.sku__price--strikethrough s{text-decoration:line-through}.sku__free-badge{margin-top:var(--space-1);display:inline-block;padding:2px var(--space-2);background:var(--success);color:var(--text-on-accent);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:var(--font-weight-bold);align-self:flex-start}.sku.is-disabled{opacity:.5;cursor:not-allowed}.sku.is-disabled:hover{border-color:var(--border)}.topup__balance-guard{margin:0 0 var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);background:var(--bg-surface-sunken);color:var(--text-primary);font-size:var(--text-sm)}.topup__balance-guard:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.checkin-list{list-style:none;margin:0;padding:0;flex-direction:column}.checkin-list,.checkin-list li{display:flex;gap:var(--space-2)}.checkin-list li{align-items:center;font-size:var(--text-sm)}.checkin-list .is-done{color:var(--success)}.checkin-list .is-due{color:var(--warning);font-weight:var(--font-weight-semibold)}.checkin-list .is-missed{color:var(--error)}.checkin-list .is-missed,.hotline{font-weight:var(--font-weight-semibold)}.hotline{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--accent-on-light);text-decoration:none}.map-stub{justify-content:center;width:100%;height:140px;border-radius:var(--radius-md);color:var(--map-pin);background:linear-gradient(160deg,var(--map-water) 0 25%,var(--map-land) 25%)}.app-header,.map-stub{display:flex;align-items:center}.app-header{gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-surface-primary)}.app-header__title{flex:1 1 auto;min-width:clamp(0px,40vw,108px)}.app-header__title>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header__progress{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.app-header .btn-secondary{flex:0 1 auto;min-width:0;min-height:36px;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);white-space:nowrap;overflow:hidden}.app-header .btn-secondary>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.step-progress{padding:var(--space-2) var(--space-4) 0;background:var(--bg-surface-primary)}.step-progress__bar{height:4px;border-radius:var(--radius-pill);overflow:hidden;background:var(--bg-surface-sunken)}.step-progress__fill{height:100%;border-radius:var(--radius-pill);background:var(--accent);transition:width var(--motion-standard) var(--motion-ease-default)}.step-progress__label{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}@media (prefers-reduced-motion:reduce){.step-progress__fill{transition:none}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;flex-shrink:0}.icon-btn:hover{background:var(--bg-surface-sunken)}.icon-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.onboarding-shell{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.onboarding-shell main{padding:var(--space-4);flex:1 1;display:flex;flex-direction:column;min-height:0}.lead{margin:0 0 var(--space-3)}.lead,.role-note{color:var(--text-secondary)}.role-note{font-size:var(--text-xs)}.hero-band{padding:var(--space-6) var(--space-4);text-align:center}.grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3)}.preview-grid-wrap{padding:0 var(--space-4) var(--space-4)}.cand-card.preview{cursor:default}.step-list{list-style:none;margin:0 0 var(--space-4);padding:0;flex-direction:column}.step-list,.step-list li{display:flex;gap:var(--space-3)}.step-list li{align-items:flex-start}.step-list .icon-inline{color:var(--accent-on-light);margin-top:var(--space-1)}.cta-bar{position:-webkit-sticky;position:sticky;bottom:0;background:var(--bg-surface-primary);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);margin:var(--space-4) calc(-1 * var(--space-4)) 0}.cta-bar--stacked{flex-direction:column}.btn-row,.cta-bar--stacked{display:flex;gap:var(--space-3)}.btn-row>*{flex:1 1}.btn-primary,.btn-secondary{width:100%}.field{margin-bottom:var(--space-3)}.field__label{display:block;margin-bottom:var(--space-2)}.field__hint{display:block;font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}input[type=email],input[type=number],input[type=password],input[type=text],select.input,textarea{width:100%;font-family:inherit;font-size:var(--text-base);padding:var(--space-3);background:var(--bg-surface-sunken);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}textarea{min-height:88px;resize:vertical;line-height:1.6}textarea.input--multiline{min-height:140px}input:focus-visible,select.input:focus-visible,textarea:focus-visible{outline:2px solid var(--border-focus);outline-offset:1px;border-color:var(--border-focus)}.field__error{display:none;color:var(--error);font-size:var(--text-xs);margin-top:var(--space-1)}.field.has-error .field__error{display:block}.dob-row,.height-row{display:flex;gap:var(--space-2);align-items:center}.dob-row input{width:64px;text-align:center}.dob-row .yyyy{width:96px}.height-row input{width:96px;text-align:center}.otp-row{display:flex;gap:var(--space-2);align-items:center;margin-top:var(--space-2)}.otp-box{width:44px;height:52px;text-align:center;font-size:var(--text-lg);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.field__error[role=alert]{display:block}.link-btn{background:none;border:none;padding:0;color:var(--accent);font:inherit;cursor:pointer;text-decoration:underline}.link-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.signup-mock-note{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-3)}.signup-resend-row{display:flex;justify-content:flex-end;margin-top:var(--space-2)}.signup-resend-row .link-btn,.signup-resend-row .signup-resend-cooldown{font-size:var(--text-xs);color:var(--text-secondary)}.signup-resend-row .link-btn{color:var(--accent)}.suffix{color:var(--text-secondary);font-size:var(--text-sm)}fieldset.radio-group{border:none;padding:0;margin:0 0 var(--space-3)}fieldset.radio-group legend{padding:0;margin-bottom:var(--space-2)}.radio-group__sub{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-2)}.radio-options{display:flex;gap:var(--space-2);flex-wrap:wrap}.radio-options label{flex:1 1;min-width:90px;display:flex;align-items:center;justify-content:center;gap:var(--space-1);text-align:center;padding:var(--space-3) var(--space-2);min-height:52px;background:var(--bg-surface-primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);transition:border-color var(--motion-fast) var(--motion-ease-default),background var(--motion-fast) var(--motion-ease-default)}.radio-options--stacked{flex-direction:column;flex-wrap:nowrap}.radio-options--stacked label{flex:0 0 auto;width:100%;justify-content:flex-start;text-align:left}.radio-options input[type=checkbox],.radio-options input[type=radio]{position:absolute;opacity:0;pointer-events:none}.radio-options label:hover{border-color:var(--border-strong)}.radio-options label:focus-visible,.radio-options label:focus-within{outline:2px solid var(--border-focus);outline-offset:2px}.radio-options label.selected{background:var(--accent-tint);border-color:var(--accent);color:var(--accent-on-light);font-weight:var(--font-weight-semibold)}.radio-options label.is-disabled{opacity:.45;cursor:not-allowed;background:var(--bg-surface-sunken);border-style:dashed}.choice-tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:var(--space-2);gap:var(--space-2);width:100%}.choice-tile-grid--compact{grid-template-columns:repeat(2,1fr);gap:var(--space-1)}.choice-tile-grid--compact .choice-tile{gap:var(--space-1);padding:var(--space-2);min-height:40px;font-size:var(--text-xs)}.choice-tile-grid--compact .choice-tile__check{width:16px;height:16px}.choice-tile{position:relative;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);min-height:64px;background:var(--bg-surface-primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);transition:border-color var(--motion-fast) var(--motion-ease-default),background var(--motion-fast) var(--motion-ease-default)}.choice-tile:hover{border-color:var(--border-strong)}.choice-tile:focus-visible,.choice-tile:focus-within{outline:2px solid var(--border-focus);outline-offset:2px}.choice-tile.selected{background:var(--accent-tint);border-color:var(--accent);color:var(--accent-on-light);font-weight:var(--font-weight-semibold)}.choice-tile__check{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border:1.5px solid var(--border-strong);border-radius:50%;background:var(--bg-surface-primary);color:var(--accent);transition:border-color var(--motion-fast) var(--motion-ease-default),background var(--motion-fast) var(--motion-ease-default)}.choice-tile__check[data-checked=true]{border-color:var(--accent);background:transparent}.choice-tile__label{flex:1 1 auto;min-width:0}.gating-hint{display:none;font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2);font-style:italic}fieldset.is-locked .gating-hint{display:block}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-1)}.switch{position:relative;width:44px;height:26px;flex-shrink:0;background:var(--border-strong);border:none;border-radius:var(--radius-pill);cursor:pointer}.switch[aria-checked=true]{background:var(--accent)}.switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--text-on-accent);border-radius:var(--radius-pill);transition:transform var(--motion-fast) var(--motion-ease-default)}.switch[aria-checked=true]:after{transform:translateX(18px)}.switch:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.toggle-row__state{display:inline-flex;align-items:center;gap:var(--space-2);flex-shrink:0}.switch__state-text{font-size:var(--text-xs);color:var(--text-secondary)}.check-row{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-3) 0;border-bottom:1px solid var(--border);cursor:pointer}.check-row.selected{background:var(--accent-tint);border-color:var(--accent);color:var(--accent-on-light);font-weight:var(--font-weight-semibold);border-radius:var(--radius-sm);padding-left:var(--space-2);padding-right:var(--space-2)}.check-row:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.check-row input{margin-top:4px;width:22px;height:22px;accent-color:var(--accent);flex-shrink:0}.link{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--accent-on-light);background:none;border:none;font:var(--font-weight-semibold) var(--text-sm) /1.5 var(--font-body);cursor:pointer;padding:var(--space-2) 0;text-align:left}.link:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-sm)}.link--pill{padding:var(--space-1) var(--space-3);background:var(--accent-tint);color:var(--accent-on-light);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);border-radius:var(--radius-pill);transition:background var(--motion-fast) var(--motion-ease-default),border-color var(--motion-fast) var(--motion-ease-default)}.link--pill:hover{background:color-mix(in srgb,var(--accent) 18%,var(--accent-tint));border-color:color-mix(in srgb,var(--accent) 36%,transparent)}.link--pill:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-pill)}.camera-capture{display:flex;flex-direction:column;flex:1 1;min-height:0}.camera-capture__hint{margin:0 0 var(--space-3)}.camera-view{position:relative;flex:1 1;min-height:0;width:100%;max-width:calc((100dvh - 320px) * 3 / 4);aspect-ratio:3/4;margin:0 auto var(--space-3);border-radius:var(--radius-md);background:#1a1410;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-disabled)}.camera-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.face-oval{position:relative;width:60%;aspect-ratio:3/4;border:2px dashed var(--accent-tint);border-radius:50%}.shutter{width:64px;height:64px;border-radius:var(--radius-pill);background:var(--accent);border:4px solid var(--bg-surface-elevated);box-shadow:var(--elev-raised);cursor:pointer;margin:0 auto;display:block}.shutter:focus-visible{outline:2px solid var(--border-focus);outline-offset:4px}.shutter:disabled{cursor:not-allowed;opacity:.5}.camera-view__processing{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);background:rgba(26,20,16,.7);color:#fff;text-align:center;padding:var(--space-4);font-size:var(--text-sm)}.camera-view__processing .ring{width:48px;height:48px;border-width:5px}.camera-view__preview{position:absolute;inset:0;z-index:1;background:#1a1410;display:flex;align-items:center;justify-content:center;overflow:hidden}.camera-view__preview-img{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-capture__confirm{display:flex;gap:var(--space-3);justify-content:center;align-items:center;margin:0 auto;max-width:360px;width:100%}.camera-capture__confirm>button{flex:1 1;min-height:48px}.progress-ring{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8) 0}.ring{width:96px;height:96px;border-radius:var(--radius-pill);border:8px solid var(--border);border-top-color:var(--accent);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}input[type=range]{width:100%;accent-color:var(--accent)}.map{aspect-ratio:4/3;border-radius:var(--radius-md);border:1px solid var(--border);background:radial-gradient(circle at 50% 55%,var(--map-radius-fill) 0 30%,transparent 31%),repeating-linear-gradient(0deg,transparent 0 28px,var(--map-road) 28px 30px),repeating-linear-gradient(90deg,transparent 0 28px,var(--map-road) 28px 30px),linear-gradient(160deg,var(--map-water) 0 25%,var(--map-land) 25%);position:relative;overflow:hidden}.map__pin{position:absolute;left:50%;top:55%;transform:translate(-50%,-100%);color:var(--map-pin)}.portrait-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.modal-backdrop{position:fixed;inset:0;z-index:100;background:rgba(40,28,20,.5);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.app-shell{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.app-shell main{padding:var(--space-4);flex:1 1}.app-header__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.app-header--branded{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}.app-header--branded .app-header__title{justify-self:start;flex:initial}.app-header--branded .app-header__actions{justify-self:end}.app-header__brand{justify-self:center;color:var(--accent-deep)}.app-header__brand,.wallet-chip{display:inline-flex;align-items:center}.wallet-chip{gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill,999px);background:var(--accent-tint);color:var(--accent-on-light);font-size:var(--text-sm);font-weight:600;white-space:nowrap}.sort-bar{gap:var(--space-2);align-items:center;padding:var(--space-3) var(--space-4)}.sort-bar,.sub-tabs{display:flex;border-bottom:1px solid var(--border)}.sub-tabs{align-items:stretch;justify-content:space-between;padding:0 var(--space-4);background:var(--bg-surface-primary)}.sub-tabs__tabs{display:flex;align-items:stretch}.sub-tabs__actions{display:flex;gap:var(--space-2)}.sub-tabs__actions,.sub-tabs__tab{align-items:center;margin-bottom:-1px}.sub-tabs__tab{display:inline-flex;gap:var(--space-1);padding:var(--space-3) var(--space-4);color:var(--text-secondary);text-decoration:none;font-size:var(--text-base);font-weight:500;border-bottom:2px solid transparent}.sub-tabs__tab:hover{color:var(--text-primary)}.sub-tabs__tab:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.sub-tabs__tab--active{color:var(--accent-on-light);font-weight:600;border-bottom-color:var(--accent)}.sub-tabs__action{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-3) 0;background:transparent;border:0;color:var(--text-secondary);font-family:inherit;font-size:var(--text-base);font-weight:500;cursor:pointer}.sub-tabs__action:hover{color:var(--text-primary)}.sub-tabs__action:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.sub-tabs__badge{justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 var(--space-1);margin-left:var(--space-1);background:var(--accent);color:var(--text-on-accent);font-size:var(--text-xs);font-weight:600;line-height:1}.chip,.sub-tabs__badge{display:inline-flex;align-items:center;border-radius:var(--radius-pill,999px)}.chip{gap:var(--space-1);padding:var(--space-1) var(--space-3);border:1px solid var(--border);background:var(--bg-surface-primary);color:var(--text-primary);font-family:inherit;font-size:var(--text-sm);cursor:pointer}.chip:hover{border-color:var(--border-strong)}.chip:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.chip.is-active{border-color:var(--accent);background:var(--accent-tint);color:var(--accent-on-light)}.chip-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.chip-row>.chip{cursor:default}.chip-row>.chip:hover{border-color:var(--border)}.state-block{text-align:center;padding:var(--space-6) var(--space-4);color:var(--text-secondary)}.state-block .icon-inline,.state-block svg{color:var(--text-secondary);margin-bottom:var(--space-3)}.skeleton-card{border-radius:var(--radius-md);background:var(--bg-surface-sunken);aspect-ratio:3/4}.list-row{display:flex;align-items:center;gap:var(--space-3);width:100%;text-align:left;padding:var(--space-3) var(--space-4);border:none;border-bottom:1px solid var(--border);background:var(--bg-surface-primary);color:var(--text-primary);font-family:inherit;cursor:pointer}.list-row:hover{background:var(--bg-surface-sunken)}.list-row:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.list-row__body{flex:1 1;min-width:0}.list-row__name{font-weight:600;font-size:var(--text-base)}.list-row__sub{font-size:var(--text-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-1)}.list-row--readonly{cursor:default}.list-row--readonly:hover{background:var(--bg-surface-primary)}.list-row__value{font-size:var(--text-base);color:var(--text-secondary);white-space:nowrap}.avatar,.list-row__sub.is-unlocked{color:var(--accent-on-light)}.avatar{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-pill,999px);background:var(--accent-tint);font-weight:700;flex-shrink:0}.avatar__img{width:100%;height:100%;border-radius:inherit;object-fit:cover}.avatar--link{cursor:pointer;text-decoration:none;transition:background-color var(--motion-fast,.12s) ease}.avatar--link:hover{background:var(--accent-tint-strong,var(--accent-tint))}.avatar--link:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.match-faces{justify-content:center}.match-faces,.match-row{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0}.wiwwid-scores{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3);margin:var(--space-3) 0 var(--space-4)}.wiwwid-score{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);text-align:center}.wiwwid-score+.wiwwid-score{border-left:1px solid var(--border-subtle,var(--border,rgba(0,0,0,.08)))}.wiwwid-score__label{font:var(--font-weight-semibold) var(--text-sm) /1.3 var(--font-body);color:var(--text-secondary)}.rep-count{display:flex;align-items:baseline;gap:var(--space-2);margin:var(--space-2) 0 0}.rep-count__value{font:var(--font-display-weight) var(--text-2xl) /1.1 var(--font-display);color:var(--text-primary)}.rep-count__label{color:var(--text-secondary)}.rep-group{margin-top:var(--space-4)}.rep-group__heading{margin:0 0 var(--space-2);font:var(--font-weight-semibold) var(--text-sm) /1.4 var(--font-body);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.rep-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.standing-history{margin-top:var(--space-4)}.standing-event{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--error) 24%,transparent);background:color-mix(in srgb,var(--error) 8%,transparent)}.standing-event .icon-inline{color:var(--error)}.rep-tag{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border)}.rep-tag--positive{background:color-mix(in srgb,var(--success) 12%,transparent);border-color:color-mix(in srgb,var(--success) 28%,transparent)}.rep-tag--positive .rep-tag__icon,.rep-tag--positive .rep-tag__pct{color:var(--success)}.rep-tag--negative{background:color-mix(in srgb,var(--warning) 12%,transparent);border-color:color-mix(in srgb,var(--warning) 28%,transparent)}.rep-tag--negative .rep-tag__icon,.rep-tag--negative .rep-tag__pct{color:var(--warning)}.rep-tag__icon{display:inline-flex;flex:0 0 auto}.rep-tag__label{flex:1 1 auto;min-width:0}.rep-tag__pct{flex:0 0 auto;font:var(--font-weight-bold) var(--text-base) /1 var(--font-body)}.rep-noflags{display:flex;align-items:center;gap:var(--space-2);margin:0;color:var(--success)}.app-nav{position:-webkit-sticky;position:sticky;bottom:0;display:flex;border-top:1px solid var(--border);background:var(--bg-surface-primary)}.app-nav__item{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) 0;min-height:56px;border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:var(--text-xs);cursor:pointer}.app-nav__item:hover{color:var(--text-primary)}.app-nav__item:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.app-nav__item.is-active{color:var(--accent-on-light)}.app-nav__item .pair{font-size:var(--text-xs)}.app-nav__icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.app-nav__avatar{width:18px;height:18px;border-radius:var(--radius-pill,999px);object-fit:cover;display:block}.app-nav__avatar--me{width:36px;height:36px}.app-nav__avatar--fallback{display:inline-flex;align-items:center;justify-content:center;background:var(--bg-surface-sunken);color:var(--text-secondary)}.app-nav__icon-wrap--me{border-radius:var(--radius-pill,999px);box-shadow:0 0 0 2px transparent}.app-nav__icon-wrap--me.is-active{box-shadow:0 0 0 2px var(--accent)}.nav-dot{top:-2px;right:-4px;width:8px;height:8px}.nav-badge,.nav-dot{position:absolute;border-radius:var(--radius-pill,999px);background:var(--accent);box-shadow:0 0 0 2px var(--bg-surface-primary)}.nav-badge{top:-6px;right:-8px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;color:var(--text-on-accent);font-size:10px;line-height:1;font-weight:var(--font-weight-bold)}.notif-bell{position:relative}.notif-bell__dot{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:var(--radius-pill,999px);background:var(--error);box-shadow:0 0 0 2px var(--bg-surface-primary);animation:notif-pulse 1.6s var(--motion-ease-default) infinite}@keyframes notif-pulse{0%,to{opacity:1}50%{opacity:.45}}@media (prefers-reduced-motion:reduce){.notif-bell__dot{animation:none;opacity:1}}.chat-row__meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0}.txn__time{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.badge-unread{display:inline-flex;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1);border-radius:var(--radius-pill,999px);background:var(--accent);color:var(--text-on-accent)}.badge-unread,.list-section__label{align-items:center;font-size:var(--text-xs);font-weight:var(--font-weight-bold)}.list-section__label{display:flex;gap:var(--space-2);margin:0;padding:var(--space-2) var(--space-4);text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);background:var(--bg-surface-sunken);border-bottom:1px solid var(--border)}.list-section__label svg{color:var(--accent)}.swipe-row{position:relative;overflow:hidden}.swipe-row__affordance{position:absolute;top:0;bottom:0;left:0;display:flex;align-items:center;padding-left:var(--space-4);color:var(--text-on-accent);background:var(--accent)}.swipe-row__affordance--delete{left:auto;right:0;padding-left:0;padding-right:var(--space-4);justify-content:flex-end;color:#fff;background:var(--error)}.swipe-row__surface{position:relative;display:flex;align-items:stretch;transform:translateX(var(--swipe-offset,0));transition:transform var(--motion-fast,.12s) ease;background:var(--bg-surface-primary);touch-action:pan-y}.swipe-row__surface .list-row{flex:1 1;min-width:0}.swipe-row__pin-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;border:none;border-bottom:1px solid var(--border);background:var(--bg-surface-primary);color:var(--text-secondary);cursor:pointer}.swipe-row__pin-btn[aria-pressed=true]{color:var(--accent)}.swipe-row__pin-btn:hover{background:var(--bg-surface-sunken)}.swipe-row__pin-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.swipe-row__delete-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;border:none;border-bottom:1px solid var(--border);background:var(--bg-surface-primary);color:var(--error);cursor:pointer}.swipe-row__delete-btn:hover{background:color-mix(in srgb,var(--error) 10%,transparent)}.swipe-row__delete-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.list-row__pin-marker{color:var(--accent);margin-right:var(--space-1);vertical-align:-2px}.swipe-row__menu-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;border:none;border-bottom:1px solid var(--border);background:var(--bg-surface-primary);color:var(--text-secondary);cursor:pointer}.swipe-row__menu-btn:hover{background:var(--bg-surface-sunken)}.swipe-row__menu-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.row-menu{position:relative;display:flex}.row-menu__backdrop{position:fixed;inset:0;z-index:90}.row-menu__panel{position:absolute;top:100%;right:0;z-index:91;min-width:160px;display:flex;flex-direction:column;padding:var(--space-1);background:var(--bg-surface-primary);border:1px solid var(--border);border-radius:var(--radius-md,12px);box-shadow:var(--shadow-md,0 4px 16px rgba(40,28,20,.18))}.row-menu__item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font:inherit;text-align:left;white-space:nowrap;cursor:pointer}.row-menu__item:hover{background:var(--bg-surface-sunken)}.row-menu__item:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.row-menu__item--danger{color:var(--error)}.archive-back{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border:none;border-bottom:1px solid var(--border);background:var(--bg-surface-primary);color:var(--text-secondary);font:inherit;cursor:pointer}.archive-back:hover{background:var(--bg-surface-sunken)}.archive-back:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.chat-stream-wrap{position:relative;min-height:0}.chat-stream,.chat-stream-wrap{flex:1 1;display:flex;flex-direction:column}.chat-stream{gap:var(--space-3);padding:var(--space-4);overflow-y:auto}.chat-set-date-float{position:absolute;top:var(--space-3);right:max(var(--space-3),env(safe-area-inset-right,0px));z-index:5;min-height:0;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-pill);font:var(--font-weight-medium) var(--text-xs) /1.2 var(--font-body);white-space:nowrap;box-shadow:var(--shadow-md,0 4px 16px rgba(40,28,20,.18))}.bubble,.chat-set-date-float{width:-moz-fit-content;width:fit-content}.bubble{position:relative;max-width:78%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-base);line-height:1.45}.bubble.incoming{align-self:flex-start;margin-right:auto;background:var(--bg-surface-sunken);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.bubble.outgoing{align-self:flex-end;margin-left:auto;background:var(--accent);color:var(--text-on-accent);border-bottom-right-radius:var(--radius-sm)}.bubble__video{display:inline-flex;align-items:center;gap:var(--space-2);background:transparent;border:1px solid;border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:inherit;font-family:inherit;cursor:pointer}.bubble-row{display:flex;flex-direction:column;max-width:78%}.bubble-row--me{align-self:flex-end;align-items:flex-end}.bubble-row--them{align-self:flex-start;align-items:flex-start}.bubble-row .bubble{max-width:100%}.bubble__timestamp{font-size:var(--text-xs);color:var(--text-disabled);margin-top:var(--space-1);padding:0 var(--space-1);line-height:1.2;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.composer{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);padding-bottom:max(var(--space-3),env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);background:var(--bg-surface-primary)}.composer input[type=text]{flex:1 1;min-width:0}.composer .btn-primary{flex-shrink:0}.wallet-balance{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4);text-align:center;border-bottom:1px solid var(--border)}.wallet-balance>.icon-inline{color:var(--accent)}.wallet-balance__amount{display:flex;align-items:baseline;gap:var(--space-2)}.wallet-balance__count{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight)}.wallet-balance__unit{color:var(--text-secondary)}.wallet-balance__note{margin:0;max-width:32ch}.wallet-balance .btn-primary{align-self:stretch;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.wallet-history{padding:var(--space-4)}.wallet-history__heading{margin:0 0 var(--space-3);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.txn-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.txn-row__delta{flex-shrink:0;min-width:3.5ch;font-family:var(--font-display);font-weight:var(--font-weight-bold);font-size:var(--text-base);text-align:right}.txn-row__delta.is-credit{color:var(--success)}.txn-row__delta.is-debit{color:var(--text-secondary)}.txn-row__body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px}.txn-row__reason{font-size:var(--text-base);color:var(--text-primary)}.txn-row__kind{font-size:var(--text-xs)}.txn-row__when{flex-shrink:0;font-size:var(--text-sm);color:var(--text-secondary)}.topup{padding:var(--space-4)}.bonus-banner{display:flex;align-items:flex-start;gap:var(--space-2);margin:0 0 var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);background:var(--accent-tint);color:var(--accent-on-light);font-size:var(--text-sm)}.bonus-banner>.icon-inline{flex-shrink:0;margin-top:2px}.pay-with{margin-top:var(--space-6)}.pay-with__heading{margin:0 0 var(--space-3);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.pay-method{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface-primary)}.pay-method.is-selected{border-color:var(--accent);background:var(--accent-tint);color:var(--accent-on-light)}.pay-method__check{margin-left:auto;color:var(--accent)}.pay-with__note{margin:var(--space-2) 0 0}.topup-footer{position:-webkit-sticky;position:sticky;bottom:0;padding:var(--space-4);background:var(--bg-surface-primary);border-top:1px solid var(--border)}.topup-footer .btn-primary{width:100%}.topup-qr{flex-direction:column;gap:var(--space-4);padding:var(--space-4);text-align:center}.qr-frame,.topup-qr{display:flex;align-items:center}.qr-frame{justify-content:center;width:220px;height:220px;border:1px solid var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-surface-primary)}.qr-frame__glyph{width:160px;height:160px;color:var(--text-primary)}.topup-qr__instruction{margin:0;max-width:34ch}.topup-qr__summary{display:flex;flex-direction:column;gap:var(--space-1)}.topup-qr__amount{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.topup-qr__pending{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-pill,999px);background:var(--bg-surface-sunken);color:var(--text-secondary);font-size:var(--text-sm)}.topup-qr .btn-primary{align-self:stretch}.payment-status{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-8) var(--space-4) var(--space-6);text-align:center}.payment-status__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-pill,999px)}.payment-status__icon--ok{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}.payment-status__icon--fail{background:color-mix(in srgb,var(--error) 16%,transparent);color:var(--error)}.payment-status__icon--pending{background:var(--bg-surface-sunken);color:var(--text-secondary)}.payment-status__title{margin:0}.payment-status__body,.payment-status__nocharge,.payment-status__reason{margin:0;max-width:36ch}.payment-status__bonus{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--accent-on-light);font-size:var(--text-sm)}.payment-status__actions{display:flex;flex-direction:column;gap:var(--space-2);align-self:stretch;margin-top:var(--space-2)}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-row__label{color:var(--text-secondary);font-size:var(--text-sm)}.setting-row__value{text-align:right}.btn-danger,.setting-row__actions{display:inline-flex;align-items:center;gap:var(--space-2)}.btn-danger{justify-content:center;min-height:48px;width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font:var(--font-weight-semibold) var(--text-base) /1.2 var(--font-body);cursor:pointer;background:var(--error);color:var(--text-on-accent);border:1px solid transparent;transition:background var(--motion-fast) var(--motion-ease-default)}.btn-danger:hover{background:var(--accent-deep)}.btn-danger:disabled{background:var(--border-strong);color:var(--text-disabled);cursor:not-allowed}.cascade-list{margin:0 0 var(--space-4);padding-left:var(--space-6)}.cascade-list li{margin-bottom:var(--space-2)}.emergency-section,.sensitive-section{border-color:var(--error)}.photo-grid{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2)}.photo-add{display:inline-flex;align-items:center;justify-content:center;width:88px;height:88px;border:2px dashed var(--border-strong);border-radius:var(--radius-md);background:var(--bg-surface-sunken);color:var(--accent-on-light);cursor:pointer}.photo-slot{display:flex;flex-direction:column;gap:var(--space-1);width:88px}.photo-slot__img{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:var(--radius-md);background:var(--bg-surface-sunken);color:var(--text-secondary);font-weight:var(--font-weight-semibold);object-fit:cover}.photo-slot__tier{font-size:var(--text-xs);min-height:36px;padding:var(--space-1) var(--space-2)}.photo-slot__frame{position:relative;display:block;width:88px;height:88px}.photo-profile-marker{position:absolute;bottom:var(--space-1);left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;max-width:calc(100% - var(--space-2));font-size:var(--text-xs);font-weight:var(--font-weight-semibold);line-height:1.2;padding:2px var(--space-2);border-radius:var(--radius-pill);background:var(--border-strong);color:var(--text-primary);box-shadow:var(--shadow-sm);white-space:nowrap;pointer-events:none}.photo-slot__media{position:relative;width:88px;height:88px}.photo-slot__media[data-blurred=true] .photo-slot__img{filter:blur(12px);overflow:hidden}.photo-slot__reveal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:color-mix(in srgb,var(--bg-surface-sunken) 35%,transparent);color:var(--text-on-dark,#fff);cursor:pointer}.photo-slot__media[data-blurred=false] .photo-slot__reveal{inset:auto var(--space-1) var(--space-1) auto;width:28px;height:28px;background:color-mix(in srgb,var(--bg-surface) 70%,transparent);color:var(--text-secondary)}.install-prompt{position:fixed;left:50%;bottom:var(--space-3);transform:translateX(-50%);z-index:50;display:flex;flex-direction:column;gap:var(--space-3);width:min(420px,calc(100vw - var(--space-4)));padding:var(--space-4);border-radius:var(--radius-md);background:var(--bg-surface-elevated);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg)}.install-prompt__copy{display:flex;flex-direction:column;gap:var(--space-1)}.install-prompt__actions{display:flex;gap:var(--space-2);justify-content:flex-end}.admin-console{max-width:720px;margin:0 auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.admin-console__header{display:flex;flex-direction:column;gap:var(--space-1)}.admin-console__title{margin:0;font:var(--font-weight-semibold) var(--text-xl,20px) /1.25 var(--font-display,var(--font-body));color:var(--text-primary)}.admin-console__subtitle{margin:0;color:var(--text-secondary);font-size:var(--text-sm)}.admin-console__threshold{margin:0;color:var(--text-secondary);font-size:var(--text-xs)}.staff-badge{display:inline-flex;align-items:center;gap:var(--space-1);align-self:flex-start;padding:var(--space-1) var(--space-2);border-radius:var(--radius-pill,999px);background:var(--accent-tint);color:var(--accent-on-light);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em}.signal-banner{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-surface-sunken);color:var(--text-primary);font-size:var(--text-sm)}.signal-banner .icon-inline{color:var(--warning);flex:0 0 auto;margin-top:2px}.flag-list{list-style:none;margin:0;padding:0;gap:var(--space-4)}.flag-card,.flag-list{display:flex;flex-direction:column}.flag-card{gap:var(--space-3)}.flag-card__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);flex-wrap:wrap}.similarity{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--text-secondary);font-size:var(--text-sm)}.similarity strong{color:var(--text-primary);font-size:var(--text-base)}.status-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-pill,999px);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize;border:1px solid var(--border);background:var(--bg-surface-sunken);color:var(--text-secondary)}.status-pill--pending{border-color:var(--warning);color:var(--warning)}.status-pill--confirmed{border-color:var(--error);color:var(--error)}.status-pill--dismissed{border-color:var(--success);color:var(--success)}.status-pill--escalated{border-color:var(--accent);color:var(--accent-on-light)}.sla-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill,999px);font-size:var(--text-sm);font-weight:var(--font-weight-semibold)}.sla-pill--green{background:color-mix(in srgb,var(--success) 14%,transparent);color:var(--success)}.sla-pill--yellow{background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--warning)}.sla-pill--red{background:color-mix(in srgb,var(--error) 14%,transparent);color:var(--error)}.flag-compare{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3)}.flag-side{display:flex;flex-direction:column;gap:var(--space-2)}.flag-side__label{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:0;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.flag-side__label,.review-state-badge{align-items:center;font-size:var(--text-xs);font-weight:var(--font-weight-semibold)}.review-state-badge{display:inline-flex;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-pill);border:1px solid var(--accent);background:var(--accent-tint);color:var(--accent-on-light);text-transform:none;letter-spacing:0}.flag-photos{display:flex;gap:var(--space-2);flex-wrap:wrap}.flag-photo{display:inline-flex;align-items:center;justify-content:center;width:64px;height:80px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface-sunken);color:var(--text-secondary)}.flag-photo--ai_portrait{background:linear-gradient(135deg,var(--bg-surface-sunken),var(--accent-tint));color:var(--accent-on-light)}.flag-photo--none{border-style:dashed}.flag-meta{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3);margin:0}.flag-meta__group{display:grid;grid-template-columns:auto 1fr;grid-gap:var(--space-1) var(--space-2);gap:var(--space-1) var(--space-2);align-content:start}.flag-meta dt{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.flag-meta dd{margin:0;font-size:var(--text-xs);color:var(--text-primary)}.flag-meta .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.flag-resolved{align-items:center;margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.flag-actions,.flag-resolved{display:flex;gap:var(--space-2)}.flag-actions{flex-wrap:wrap}.flag-actions .btn-danger,.flag-actions .btn-secondary{width:auto;flex:1 1 auto}.dialog-backdrop{position:fixed;inset:0;align-items:center;justify-content:center;background:rgba(42,33,26,.45);z-index:50}.dialog,.dialog-backdrop{display:flex;padding:var(--space-4)}.dialog{width:100%;max-width:420px;flex-direction:column;gap:var(--space-3);border-radius:var(--radius-lg);background:var(--bg-surface-elevated);box-shadow:var(--shadow-lg)}.dialog__title{display:flex;align-items:center;gap:var(--space-2);margin:0;font:var(--font-weight-semibold) var(--text-lg,18px) /1.25 var(--font-body);color:var(--text-primary)}.dialog__body{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.dialog__actions{display:flex;gap:var(--space-2)}.dialog__actions .btn-danger,.dialog__actions .btn-secondary{width:auto;flex:1 1 auto}@media (max-width:420px){.flag-compare,.flag-meta{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:var(--motion-reduced)!important;animation-iteration-count:1!important;transition-duration:var(--motion-reduced)!important;scroll-behavior:auto!important}}.boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-3);min-height:50vh;padding:var(--space-8) var(--space-6);color:var(--text-secondary)}.boundary__icon{color:var(--accent);margin-bottom:var(--space-2)}.boundary__title{margin:0;font:var(--font-display-weight) var(--text-xl) /1.2 var(--font-display);color:var(--text-primary)}.boundary__body{margin:0;max-width:38ch;font-size:var(--text-base);line-height:1.5;color:var(--text-secondary)}.boundary__actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-4)}.boundary--loading{min-height:40vh}.boundary__spinner{width:40px;height:40px;border-radius:var(--radius-pill);border:4px solid var(--border);border-top-color:var(--accent);animation:spin 1s linear infinite}.boundary__loading-label{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.dev-switcher{position:relative;display:inline-flex;margin-top:var(--space-1)}.dev-switcher__trigger{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border:1px dashed var(--border-subtle,var(--text-secondary));border-radius:var(--radius-pill,999px);background:var(--bg-surface-sunken,transparent);color:var(--text-secondary);font-size:var(--text-xs);cursor:pointer}.dev-switcher__name{max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-switcher__menu{position:absolute;top:calc(100% + var(--space-1));left:0;z-index:40;min-width:14rem;max-height:60vh;overflow-y:auto;padding:var(--space-1);border:1px solid var(--border-subtle,var(--text-secondary));border-radius:var(--radius-md,12px);background:var(--bg-surface-primary);box-shadow:var(--shadow-md,0 8px 24px rgba(0,0,0,.18))}.dev-switcher__hint{margin:0 0 var(--space-1);padding:0 var(--space-2);font-size:var(--text-xs);color:var(--text-secondary)}.dev-switcher__row{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2);border:none;border-radius:var(--radius-sm,8px);background:transparent;color:var(--text-primary);font-size:var(--text-sm);text-align:left;cursor:pointer}.dev-switcher__row:focus-visible,.dev-switcher__row:hover{background:var(--bg-surface-sunken,rgba(0,0,0,.04))}.dev-switcher__row--current{font-weight:var(--font-weight-bold)}.dev-switcher__row[disabled]{opacity:.5;cursor:default}.dev-switcher__row-label{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-switcher__row-phone{font-size:var(--text-xs);color:var(--text-secondary)}.dev-switcher__error{margin:var(--space-1) 0 0;padding:0 var(--space-2);font-size:var(--text-xs);color:var(--error)}.setting-row__heading{margin:var(--space-3) 0 var(--space-1);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-weight:var(--font-weight-semibold)}.setting-row__heading:first-child{margin-top:0}.setting-row__heading-wrap{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);margin:var(--space-3) 0 var(--space-1)}.setting-row__heading-wrap:first-child{margin-top:0}.setting-row__heading-toast,.setting-row__heading-wrap>.setting-row__heading{margin:0}