:root {
  color-scheme: light;
  --bg: oklch(0.985 0.005 95);
  --bg-2: oklch(0.97 0.008 95);
  --bg-3: oklch(0.95 0.01 95);
  --card: #ffffff;
  --line: oklch(0.92 0.01 95);
  --line-2: oklch(0.88 0.012 95);
  --ink: oklch(0.22 0.02 140);
  --ink-2: oklch(0.38 0.015 140);
  --ink-3: oklch(0.55 0.012 130);
  --ink-4: oklch(0.7 0.01 130);
  --primary: oklch(0.55 0.13 145);
  --primary-ink: oklch(0.32 0.1 145);
  --primary-soft: oklch(0.93 0.05 145);
  --primary-on: #ffffff;
  --accent: oklch(0.72 0.16 80);
  --accent-soft: oklch(0.95 0.06 85);
  --accent-ink: oklch(0.45 0.13 70);
  --danger: oklch(0.6 0.18 25);
  --danger-soft: oklch(0.95 0.04 25);
  --warn: oklch(0.74 0.16 65);
  --warn-soft: oklch(0.96 0.05 75);
  --ok: oklch(0.6 0.13 155);
  --ok-soft: oklch(0.94 0.05 155);
  --info: oklch(0.6 0.1 230);
  --info-soft: oklch(0.95 0.03 230);
  --radius-s: 10px;
  --radius-m: 14px;
  --radius-l: 20px;
  --radius-xl: 28px;
  --shadow-1: 0 1px 2px rgb(23 33 24 / 6%), 0 6px 18px rgb(23 33 24 / 6%);
  --shadow-2: 0 8px 26px rgb(23 33 24 / 10%);
  --shadow-3: 0 18px 60px rgb(23 33 24 / 14%);
  --font-sans: Manrope, -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-mono: "IBM Plex Mono", "SF Mono", Menlo, Consolas, monospace;
}

* {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font: 15px/1.45 var(--font-sans);
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  -webkit-tap-highlight-color: transparent;
}

button:focus-visible,
textarea:focus-visible {
  outline: 2px solid color-mix(in oklch, var(--primary) 72%, white);
  outline-offset: 2px;
}

noscript {
  display: block;
  padding: 18px;
}

.app-shell {
  width: 100%;
  height: 100svh;
  min-height: 100svh;
  background: var(--bg);
  color: var(--ink);
}

.screen {
  height: 100svh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg);
  color: var(--ink);
  padding-top: env(safe-area-inset-top);
  padding-bottom: 0;
}

.scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 8px 16px 20px;
  scrollbar-width: none;
}

.scroll::-webkit-scrollbar,
.chat-scroll::-webkit-scrollbar,
.target-row::-webkit-scrollbar {
  display: none;
}

.header {
  min-height: 66px;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 12px 16px 10px;
  border-bottom: 1px solid color-mix(in oklch, var(--line) 68%, transparent);
  background: color-mix(in oklch, var(--bg) 92%, white);
  backdrop-filter: blur(18px);
}

.header__main {
  flex: 1;
  min-width: 0;
}

.header__title {
  font-size: 18px;
  font-weight: 900;
  line-height: 1.12;
  letter-spacing: 0;
}

.header__sub {
  margin-top: 3px;
  color: var(--ink-3);
  font-size: 12px;
  font-weight: 650;
}

.brand {
  width: 38px;
  height: 38px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 24%, rgb(255 255 255 / 34%), transparent 26%),
    linear-gradient(145deg, color-mix(in oklch, var(--primary) 92%, white), var(--primary-ink));
  color: var(--primary-on);
  box-shadow: inset 0 -2px 6px rgb(0 0 0 / 14%), 0 8px 22px color-mix(in oklch, var(--primary) 32%, transparent);
}

.brand svg,
.icon svg,
.icon-tile svg {
  display: block;
}

.icon-btn {
  width: 42px;
  height: 42px;
  border: 1px solid color-mix(in oklch, var(--line) 72%, transparent);
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: color-mix(in oklch, var(--card) 86%, var(--bg-2));
  color: var(--ink-2);
  cursor: pointer;
  position: relative;
  box-shadow: 0 1px 0 rgb(255 255 255 / 70%);
}

.icon-btn--primary {
  border-color: transparent;
  background: var(--primary);
  color: var(--primary-on);
  box-shadow: 0 8px 20px color-mix(in oklch, var(--primary) 26%, transparent);
}

.icon-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ok);
  display: inline-block;
}

.dot--alert {
  position: absolute;
  top: 7px;
  right: 7px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--danger);
  border: 2px solid var(--card);
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-l);
  box-shadow: var(--shadow-1);
}

.section-title {
  margin: 19px 2px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--ink-3);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.section-title button {
  border: 0;
  background: transparent;
  color: var(--primary);
  font-weight: 900;
  cursor: pointer;
}

.btn {
  min-height: 48px;
  border: 1px solid color-mix(in oklch, var(--line) 70%, transparent);
  border-radius: var(--radius-m);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 14px;
  font-weight: 900;
  letter-spacing: 0;
  cursor: pointer;
  color: var(--ink);
  background: color-mix(in oklch, var(--card) 72%, var(--bg-2));
  box-shadow: 0 1px 0 rgb(255 255 255 / 80%);
}

.btn--primary {
  border-color: transparent;
  color: var(--primary-on);
  background: var(--primary);
  box-shadow: 0 10px 24px color-mix(in oklch, var(--primary) 22%, transparent);
}

.btn--soft {
  border-color: transparent;
  color: var(--primary-ink);
  background: var(--primary-soft);
}

.btn--danger {
  border-color: transparent;
  color: var(--danger);
  background: var(--danger-soft);
}

.btn--block {
  width: 100%;
}

.btn:disabled {
  opacity: 0.52;
  cursor: not-allowed;
}

.chip {
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  background: color-mix(in oklch, var(--card) 88%, var(--bg-2));
  color: var(--ink-2);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.chip--ok {
  border-color: transparent;
  background: var(--ok-soft);
  color: var(--ok);
}

.chip--warn {
  border-color: transparent;
  background: var(--warn-soft);
  color: var(--accent-ink);
}

.chip--danger {
  border-color: transparent;
  background: var(--danger-soft);
  color: var(--danger);
}

.chip--primary {
  border-color: transparent;
  background: var(--primary-soft);
  color: var(--primary-ink);
}

.tabs {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  padding: 6px 6px calc(10px + env(safe-area-inset-bottom));
  border-top: 1px solid var(--line);
  background: color-mix(in oklch, var(--card) 94%, var(--bg));
  box-shadow: 0 -8px 24px rgb(23 33 24 / 5%);
}

.tab {
  min-width: 0;
  min-height: 54px;
  border: 0;
  background: transparent;
  color: var(--ink-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 3px;
  padding: 5px 2px 2px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  cursor: pointer;
}

.tab .icon {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
}

.tab.is-active {
  color: var(--primary);
}

.tab--scan .icon {
  width: 46px;
  height: 46px;
  margin-top: -18px;
  margin-bottom: 1px;
  border-radius: 16px;
  background: var(--primary);
  color: var(--primary-on);
  box-shadow: 0 10px 24px color-mix(in oklch, var(--primary) 35%, transparent);
}

.tab--scan.is-active .icon {
  background: var(--primary-ink);
}

.stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.row {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 13px;
}

.row + .row {
  border-top: 1px solid var(--line);
}

.row__icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: var(--bg-2);
  color: var(--ink-2);
}

.row__main {
  flex: 1;
  min-width: 0;
}

.row__title {
  font-weight: 900;
  letter-spacing: 0;
}

.row__sub {
  margin-top: 2px;
  color: var(--ink-3);
  font-size: 13px;
}

.between {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.muted {
  color: var(--ink-3);
}

.mono {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.weather {
  padding: 16px;
  background: linear-gradient(135deg, oklch(0.95 0.04 145), oklch(0.92 0.05 130));
  border-color: oklch(0.85 0.06 140);
  box-shadow: var(--shadow-2);
}

.weather .icon-btn {
  border: 0;
  background: rgb(255 255 255 / 48%);
  color: var(--primary-ink);
}

.weather__head {
  align-items: flex-start;
}

.weather__change {
  border: 0;
  border-radius: 999px;
  padding: 8px 11px;
  color: var(--primary-ink);
  background: rgb(255 255 255 / 52%);
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.weather__temp {
  margin-top: 5px;
  font-size: 40px;
  line-height: 1;
  font-weight: 900;
  color: var(--primary-ink);
}

.weather__region {
  margin-top: 4px;
  color: var(--primary-ink);
  font-size: 12px;
  font-weight: 850;
}

.weather__stats {
  margin-top: 14px;
}

.weather__prompt,
.weather__loading,
.weather__hint,
.weather__error {
  margin-top: 12px;
  color: var(--primary-ink);
  font-size: 13px;
  font-weight: 800;
}

.weather__error {
  color: var(--danger);
}

.weather-search {
  margin-top: 13px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.weather-search input {
  min-width: 0;
  min-height: 48px;
  border: 1px solid color-mix(in oklch, var(--primary) 20%, var(--line));
  border-radius: var(--radius-m);
  padding: 0 12px;
  color: var(--ink);
  background: rgb(255 255 255 / 72%);
  outline: none;
  font-weight: 800;
}

.weather-search input:focus {
  border-color: color-mix(in oklch, var(--primary) 64%, var(--line));
}

.weather-results {
  margin-top: 9px;
  display: grid;
  gap: 7px;
}

.weather-result {
  width: 100%;
  border: 1px solid color-mix(in oklch, var(--primary) 20%, var(--line));
  border-radius: var(--radius-m);
  padding: 10px 12px;
  text-align: left;
  color: var(--ink);
  background: rgb(255 255 255 / 66%);
  cursor: pointer;
}

.weather-result strong,
.weather-result span {
  display: block;
}

.weather-result strong {
  font-weight: 950;
}

.weather-result span {
  margin-top: 2px;
  color: var(--ink-3);
  font-size: 12px;
  font-weight: 800;
}

.forecast-days {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.forecast-day {
  min-width: 0;
  padding: 9px;
  border-radius: var(--radius-s);
  background: rgb(255 255 255 / 42%);
  color: var(--primary-ink);
}

.forecast-day strong,
.forecast-day span,
.forecast-day small {
  display: block;
  overflow-wrap: anywhere;
}

.forecast-day strong {
  font-size: 11px;
  font-weight: 950;
}

.forecast-day span {
  margin-top: 2px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 900;
}

.forecast-day small {
  margin-top: 1px;
  color: var(--ink-3);
  font-size: 10px;
  font-weight: 850;
}

.stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 9px;
  border-radius: var(--radius-s);
  background: rgb(255 255 255 / 42%);
  color: var(--primary-ink);
}

.stat span:first-child {
  color: var(--ink-3);
  font-size: 11px;
  font-weight: 900;
}

.quick {
  min-height: 136px;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  padding: 16px;
  text-align: left;
  border-radius: var(--radius-l);
  box-shadow: var(--shadow-1);
}

.quick strong {
  align-self: stretch;
  margin-top: auto;
  line-height: 1.12;
  font-size: 20px;
}

.quick .icon-tile {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: var(--bg-2);
  color: var(--ink-2);
}

.quick.btn--primary .icon-tile {
  background: rgb(255 255 255 / 20%);
  color: var(--primary-on);
}

.attention-card,
.field-card {
  width: 100%;
  padding: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.attention-card {
  border-color: color-mix(in oklch, var(--danger) 22%, var(--line));
  background: var(--danger-soft);
  box-shadow: 0 8px 20px color-mix(in oklch, var(--danger) 9%, transparent);
}

.attention-card .row {
  padding: 17px;
}

.attention-card .row__icon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: var(--danger);
  color: var(--primary-on);
}

.attention-card .row__title {
  font-size: 17px;
}

.attention-card .row__sub {
  color: color-mix(in oklch, var(--ink-2) 78%, var(--danger));
  font-size: 15px;
}

.attention-card__chevron {
  color: var(--ink-3);
  display: grid;
  place-items: center;
}

.field-card {
  border: 1px solid var(--line);
  background: var(--card);
}

.field-card:active,
.quick:active,
.attention-card:active,
.activity-row:active {
  transform: translateY(1px);
}

.field-thumb,
.placeholder {
  border-radius: var(--radius-m);
  background:
    linear-gradient(135deg, rgb(255 255 255 / 20%), transparent),
    repeating-linear-gradient(
      135deg,
      oklch(0.91 0.04 135),
      oklch(0.91 0.04 135) 7px,
      oklch(0.86 0.045 145) 7px,
      oklch(0.86 0.045 145) 14px
    );
  color: var(--primary-ink);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.field-thumb {
  width: 56px;
  height: 56px;
  flex: 0 0 auto;
}

.progress {
  height: 6px;
  background: var(--bg-3);
  border-radius: 999px;
  overflow: hidden;
}

.progress > span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--primary), color-mix(in oklch, var(--accent) 45%, var(--primary)));
  border-radius: inherit;
}

.onboarding {
  height: 100svh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg);
  color: var(--ink);
  padding: calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));
}

.onboarding__top {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 950;
  letter-spacing: 0;
}

.onboarding__top > span:not(.brand) {
  min-width: 0;
}

.onboarding__back {
  width: 38px;
  height: 38px;
  margin-right: 2px;
  background: var(--card);
}

.onboarding__body {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 17px;
  padding: 18px 0;
}

.hero-art {
  min-height: 188px;
  position: relative;
  margin-bottom: 4px;
  border-radius: var(--radius-xl);
  background:
    linear-gradient(155deg, rgb(255 255 255 / 54%), rgb(255 255 255 / 12%)),
    radial-gradient(circle at 18% 20%, var(--accent-soft), transparent 34%),
    linear-gradient(135deg, oklch(0.93 0.05 145), oklch(0.97 0.03 95));
  border: 1px solid oklch(0.88 0.035 120);
  box-shadow: var(--shadow-2);
  overflow: hidden;
}

.hero-art::before {
  content: "";
  position: absolute;
  inset: 86px -12px -42px;
  background:
    linear-gradient(160deg, transparent 0 42%, rgb(255 255 255 / 58%) 42% 44%, transparent 44%),
    repeating-linear-gradient(135deg, oklch(0.78 0.08 140), oklch(0.78 0.08 140) 8px, oklch(0.7 0.08 145) 8px, oklch(0.7 0.08 145) 16px);
  transform: rotate(-3deg);
}

.hero-bubble {
  position: absolute;
  max-width: 82%;
  padding: 12px 14px;
  border-radius: 18px;
  background: var(--card);
  box-shadow: var(--shadow-2);
  font-size: 13px;
  z-index: 1;
}

.hero-bubble--user {
  left: 14px;
  top: 24px;
  border-bottom-left-radius: 6px;
}

.hero-bubble--bot {
  right: 14px;
  top: 104px;
  color: var(--primary-on);
  background: var(--primary);
  border-bottom-right-radius: 6px;
}

.onboarding h1 {
  margin: 0;
  font-size: 30px;
  line-height: 1.08;
  font-weight: 950;
  letter-spacing: 0;
}

.onboarding p {
  margin: 7px 0 0;
  color: var(--ink-3);
}

.onboarding-footer {
  display: grid;
  gap: 10px;
}

.onboarding-progress {
  display: flex;
  justify-content: center;
  gap: 7px;
  padding: 0 0 2px;
}

.onboarding-progress span {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--line-2);
  transition:
    width 160ms ease,
    background 160ms ease;
}

.onboarding-progress span.is-active {
  width: 22px;
  background: var(--primary);
}

.onboarding-skip {
  min-height: 34px;
  border: 0;
  border-radius: var(--radius-s);
  margin-left: auto;
  padding: 0 4px;
  background: transparent;
  color: var(--ink-3);
  font-weight: 900;
  cursor: pointer;
}

.onboarding-skip:active {
  color: var(--primary-ink);
}

.onboarding__body--feature {
  justify-content: center;
  gap: 30px;
  padding: 12px 0 24px;
  text-align: center;
}

.feature-art {
  width: 100%;
  max-width: 360px;
  min-height: 264px;
  margin: 0 auto;
  position: relative;
}

.photo-card {
  width: 250px;
  height: 250px;
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%) rotate(-4deg);
  border-radius: 32px 32px 46px 46px;
  background:
    linear-gradient(135deg, rgb(255 255 255 / 16%), transparent),
    repeating-linear-gradient(
      135deg,
      oklch(0.89 0.045 145),
      oklch(0.89 0.045 145) 10px,
      oklch(0.82 0.05 145) 10px,
      oklch(0.82 0.05 145) 20px
    );
  box-shadow: var(--shadow-3);
}

.leaf-file {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--primary-ink);
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  transform: rotate(4deg);
}

.scan-pill {
  min-height: 58px;
  position: absolute;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  border-radius: 24px;
  background: var(--card);
  color: var(--primary);
  box-shadow: var(--shadow-2);
  font-size: 20px;
  font-weight: 950;
}

.scan-pill span:last-child {
  color: var(--ink);
}

.scan-pill--top {
  top: 18px;
  left: -46px;
}

.scan-pill--match {
  right: -44px;
  bottom: 10px;
}

.match-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--primary);
}

.feature-art--fields {
  min-height: 260px;
}

.field-chip {
  position: absolute;
  display: flex;
  align-items: flex-end;
  padding: 18px;
  border-radius: 26px;
  color: var(--ink);
  font-size: 19px;
  font-weight: 950;
  box-shadow: var(--shadow-2);
}

.field-chip--one {
  left: 22px;
  top: 46px;
  width: 172px;
  height: 108px;
  background: oklch(0.74 0.12 130);
}

.field-chip--two {
  right: 16px;
  top: 8px;
  width: 158px;
  height: 106px;
  background: oklch(0.82 0.12 92);
}

.field-chip--three {
  left: 96px;
  top: 170px;
  width: 230px;
  height: 108px;
  background: oklch(0.68 0.1 140);
}

.feature-copy h1 {
  margin: 0;
  font-size: 36px;
  line-height: 1.08;
  font-weight: 950;
  letter-spacing: 0;
}

.feature-copy p {
  max-width: 340px;
  margin: 18px auto 0;
  color: var(--ink-3);
  font-size: 22px;
  line-height: 1.42;
}

.choice-grid {
  display: grid;
  gap: 10px;
}

.choice {
  min-height: 70px;
  border: 1px solid var(--line);
  border-radius: var(--radius-l);
  padding: 12px;
  background: var(--card);
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  box-shadow: var(--shadow-1);
}

.choice.is-active {
  border-color: color-mix(in oklch, var(--primary) 62%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in oklch, var(--primary) 62%, transparent), var(--shadow-2);
}

.choice strong {
  display: block;
  font-weight: 900;
}

.choice > .row__icon {
  display: grid;
  margin-top: 0;
  color: var(--ink-2);
  font-size: inherit;
}

.choice > span:last-child {
  display: block;
  min-width: 0;
}

.choice > span:last-child span {
  display: block;
  margin-top: 2px;
  color: var(--ink-3);
  font-size: 13px;
}

.chat-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 13px 10px 9px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background:
    linear-gradient(180deg, var(--bg), var(--bg-2)),
    var(--bg-2);
  scrollbar-width: none;
}

.privacy-warning {
  display: block;
  margin: 2px 4px 6px;
  padding: 10px 12px;
  border: 1px solid color-mix(in oklch, var(--warn) 24%, var(--line));
  border-radius: var(--radius-m);
  color: var(--ink-3);
  background: color-mix(in oklch, var(--warn-soft) 62%, var(--card));
  font-size: 12px;
  font-style: italic;
  line-height: 1.34;
}

.bubble-line {
  display: flex;
  align-items: flex-end;
  gap: 7px;
}

.bubble-line--me {
  justify-content: flex-end;
}

.bubble {
  max-width: min(82%, 640px);
  white-space: pre-wrap;
  word-wrap: break-word;
  padding: 11px 13px;
  border-radius: 18px;
  background: var(--card);
  box-shadow: var(--shadow-1);
}

.bubble--me {
  color: var(--primary-on);
  background: var(--primary);
  border-bottom-right-radius: 6px;
}

.bubble--bot {
  border-bottom-left-radius: 6px;
}

.bubble img {
  max-width: 190px;
  display: block;
  border-radius: var(--radius-m);
  margin-bottom: 8px;
}

.typing {
  display: flex;
  gap: 4px;
  padding: 5px 0;
}

.typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink-4);
  animation: pulse 1.1s infinite ease-in-out;
}

.typing span:nth-child(2) {
  animation-delay: 0.16s;
}

.typing span:nth-child(3) {
  animation-delay: 0.32s;
}

@keyframes pulse {
  0%,
  80%,
  100% {
    opacity: 0.35;
    transform: translateY(0);
  }
  40% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

.composer {
  display: flex;
  gap: 8px;
  align-items: flex-end;
  padding: 9px 10px calc(11px + env(safe-area-inset-bottom));
  border-top: 1px solid var(--line);
  background: var(--bg);
}

.composer textarea {
  flex: 1;
  min-height: 42px;
  max-height: 110px;
  resize: none;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 10px 13px;
  color: var(--ink);
  background: var(--card);
  outline: none;
  box-shadow: inset 0 1px 0 rgb(23 33 24 / 3%);
}

.composer textarea:focus {
  border-color: color-mix(in oklch, var(--primary) 58%, var(--line));
}

.pending-shot {
  margin: 0 10px 8px;
  padding: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: var(--radius-m);
  background: var(--primary-soft);
  color: var(--primary-ink);
  font-size: 13px;
  font-weight: 900;
}

.pending-shot img {
  width: 50px;
  height: 50px;
  object-fit: cover;
  border-radius: var(--radius-s);
}

.photo-flow {
  padding-top: 22px;
}

.photo-guide-frame,
.diagnosis-hero,
.analysis-preview {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgb(255 255 255 / 16%), transparent),
    repeating-linear-gradient(
      135deg,
      oklch(0.9 0.04 145),
      oklch(0.9 0.04 145) 11px,
      oklch(0.84 0.045 145) 11px,
      oklch(0.84 0.045 145) 22px
    );
  color: var(--primary-ink);
}

.photo-guide-frame {
  min-height: 320px;
  border-radius: 34px;
}

.photo-guide-frame--live {
  background: #111b14;
}

.photo-guide-frame video,
.photo-guide-frame img,
.analysis-preview img,
.diagnosis-hero img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  display: block;
}

.photo-guide-empty {
  display: grid;
  place-items: center;
  gap: 15px;
  color: color-mix(in oklch, var(--primary-ink) 76%, white);
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0;
  text-align: center;
}

.photo-guide-empty svg {
  width: 56px;
  height: 56px;
}

.photo-guide-card {
  margin-top: 20px;
  padding: 18px 22px;
  border-radius: 26px;
}

.photo-guide-card h2 {
  margin: 0 0 14px;
  font-size: 21px;
  line-height: 1.12;
}

.guide-line {
  display: flex;
  align-items: center;
  gap: 13px;
  color: var(--ink-3);
  font-size: 18px;
  line-height: 1.25;
}

.guide-line + .guide-line {
  margin-top: 10px;
}

.guide-line span {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--ok);
  background: oklch(0.91 0.08 150);
}

.guide-line strong {
  min-width: 0;
  color: var(--ink-3);
  font-weight: 700;
}

.photo-actions {
  display: grid;
  gap: 12px;
  margin-top: 20px;
}

.photo-primary,
.photo-secondary {
  min-height: 68px;
  border-radius: 24px;
  font-size: 21px;
}

.photo-secondary {
  border-color: transparent;
  background: var(--bg-2);
  box-shadow: none;
}

.photo-flow--analysis {
  padding-top: 24px;
  text-align: center;
}

.analysis-preview {
  min-height: 452px;
  border: 3px solid var(--primary);
  border-radius: 34px;
}

.analysis-line {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 3px;
  background: color-mix(in oklch, var(--primary) 88%, transparent);
  box-shadow: 0 0 14px color-mix(in oklch, var(--primary) 45%, transparent);
}

.shot-file {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: color-mix(in oklch, var(--primary-ink) 72%, transparent);
  font-size: 17px;
  font-weight: 800;
}

.analysis-brand {
  margin: 38px auto 8px;
  display: flex;
  justify-content: center;
}

.analysis-copy h1 {
  margin: 0;
  font-size: 26px;
  line-height: 1.12;
}

.analysis-copy p {
  margin: 12px 0 0;
  color: var(--ink-3);
  font-size: 19px;
}

.analysis-steps {
  margin-top: 46px;
  display: grid;
  gap: 26px;
  text-align: left;
}

.analysis-step {
  display: flex;
  align-items: center;
  gap: 18px;
  color: var(--ink-3);
  font-size: 20px;
}

.analysis-step span {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: var(--bg-3);
}

.analysis-step span.is-done {
  color: var(--ok);
  background: oklch(0.91 0.08 150);
}

.analysis-step strong {
  font-weight: 700;
}

.diagnosis-scroll {
  padding-inline: 0;
  padding-top: 0;
}

.diagnosis-hero {
  min-height: 325px;
  border-radius: 0;
  box-shadow: none;
}

.diagnosis-card {
  margin: 26px 16px 28px;
  padding: 26px;
  border: 1px solid color-mix(in oklch, var(--warn) 55%, var(--line));
  border-radius: 28px;
  background: oklch(0.94 0.055 83);
  box-shadow: var(--shadow-2);
}

.diagnosis-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.diagnosis-pill {
  min-height: 58px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 16px;
  border-radius: 999px;
  color: var(--accent-ink);
  background: color-mix(in oklch, white 72%, var(--warn-soft));
  font-size: 17px;
  font-weight: 850;
}

.diagnosis-confidence {
  color: var(--ink-3);
  font-size: 16px;
  font-weight: 800;
  white-space: nowrap;
}

.diagnosis-confidence strong {
  color: var(--accent-ink);
  font-size: 22px;
  font-weight: 950;
}

.diagnosis-card h1 {
  margin: 24px 0 2px;
  font-size: 34px;
  line-height: 1.08;
}

.diagnosis-card em {
  color: var(--ink-2);
  font-size: 20px;
}

.diagnosis-card p {
  margin: 22px 0 0;
  color: var(--ink-2);
  font-size: 21px;
  line-height: 1.42;
}

.treatment-list {
  display: grid;
  gap: 12px;
  padding: 0 16px;
}

.treatment-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 19px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: var(--card);
  box-shadow: var(--shadow-1);
}

.treatment-step__num {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--primary-ink);
  background: oklch(0.87 0.08 140);
  font-size: 22px;
  font-weight: 950;
}

.treatment-step strong {
  display: block;
  color: var(--ink);
  font-size: 19px;
  line-height: 1.18;
}

.treatment-step p {
  margin: 6px 0 0;
  color: var(--ink-3);
  font-size: 14px;
}

.diagnosis-detail {
  width: calc(100% - 32px);
  min-height: 58px;
  margin: 18px 16px 28px;
}

.camera-wrap {
  position: relative;
  min-height: 316px;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 50% 35%, rgb(255 255 255 / 8%), transparent 32%),
    #111b14;
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-2);
}

.camera-wrap video,
.camera-wrap img {
  width: 100%;
  height: 100%;
  min-height: 316px;
  max-height: 440px;
  object-fit: cover;
  display: block;
}

.camera-empty {
  padding: 26px;
  display: grid;
  place-items: center;
  gap: 10px;
  color: #dfe9da;
  text-align: center;
}

.camera-empty svg {
  width: 42px;
  height: 42px;
}

.camera-empty strong {
  font-size: 18px;
}

.camera-empty span {
  color: rgb(223 233 218 / 76%);
}

.scan-corners::before,
.scan-corners::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 2px solid rgb(255 255 255 / 74%);
  border-radius: var(--radius-l);
  pointer-events: none;
}

.scan-corners::after {
  border-color: transparent;
  box-shadow: inset 0 0 0 999px rgb(0 0 0 / 10%);
}

.target-row {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  padding: 2px 0 9px;
  scrollbar-width: none;
}

.target-row .chip {
  cursor: pointer;
}

.target-row .chip.is-active {
  border-color: var(--primary);
  color: var(--primary-on);
  background: var(--primary);
}

.quality {
  padding: 13px;
}

.quality__head {
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 950;
}

.issue-list {
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 7px;
}

.issue-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: var(--ink-2);
  font-size: 13px;
}

.metric-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.metric {
  padding: 9px;
  border-radius: var(--radius-s);
  background: var(--bg-2);
}

.metric span {
  display: block;
  color: var(--ink-3);
  font-size: 11px;
  font-weight: 900;
}

.metric strong {
  font-family: var(--font-mono);
  font-size: 14px;
}

.activity-card {
  overflow: hidden;
}

.activity-row {
  width: 100%;
  border: 0;
  color: inherit;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.activity-row + .activity-row {
  border-top: 1px solid var(--line);
}

.activity-card .row__icon {
  border: 2px solid var(--ok);
  background: transparent;
  color: var(--ok);
}

.activity-row--accent .row__icon {
  border-color: var(--accent-ink);
  color: var(--accent-ink);
}

.tasks-scroll {
  padding-top: 18px;
}

.task-calendar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.task-calendar-head h1 {
  margin: 0;
  font-size: 25px;
  line-height: 1;
}

.task-calendar-head button {
  border: 0;
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--primary);
  background: transparent;
  font-size: 18px;
  font-weight: 850;
  cursor: pointer;
}

.task-calendar-head button svg {
  width: 18px;
  height: 18px;
}

.week-calendar {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 7px;
}

.week-day {
  min-width: 0;
  min-height: 106px;
  border: 1px solid var(--line);
  border-radius: 16px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 5px;
  color: var(--ink);
  background: var(--card);
  box-shadow: 0 1px 0 rgb(255 255 255 / 80%);
  cursor: pointer;
}

.week-day span {
  color: var(--ink-3);
  font-size: 15px;
  font-weight: 800;
}

.week-day strong {
  font-size: 26px;
  line-height: 1;
}

.week-day i,
.week-day small {
  min-height: 16px;
  color: var(--primary);
  font-size: 22px;
  font-style: normal;
  line-height: 0.7;
  letter-spacing: 2px;
}

.week-day small {
  font-size: 16px;
  letter-spacing: 0;
}

.week-day.is-active {
  border-color: transparent;
  color: var(--primary-on);
  background: var(--primary);
  box-shadow: 0 10px 24px color-mix(in oklch, var(--primary) 22%, transparent);
}

.week-day.is-active span,
.week-day.is-active i,
.week-day.is-active small {
  color: color-mix(in oklch, var(--primary-on) 80%, var(--primary-soft));
}

.task-day-head {
  margin: 44px 2px 18px;
  display: flex;
  justify-content: space-between;
  color: var(--ink-3);
  font-size: 16px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.task-day-head strong {
  font-size: 18px;
}

.task-list {
  display: grid;
  gap: 16px;
}

.task-card {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 26px 26px 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  color: inherit;
  background: var(--card);
  box-shadow: var(--shadow-1);
  text-align: left;
  cursor: pointer;
}

.task-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  background: var(--primary);
}

.task-card--danger::before {
  background: var(--danger);
}

.task-card--info::before {
  background: var(--info);
}

.task-card--accent::before {
  background: var(--accent-ink);
}

.task-card--ok::before {
  background: var(--ok);
}

.task-card.is-selected {
  border-color: color-mix(in oklch, var(--primary) 42%, var(--line));
  box-shadow: 0 14px 28px color-mix(in oklch, var(--primary) 14%, transparent);
}

.task-card__top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.task-card time {
  color: var(--ink-2);
  font-size: 20px;
  font-weight: 950;
}

.task-card__top span {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 13px;
  border-radius: 999px;
  color: var(--info);
  background: var(--info-soft);
  font-size: 16px;
  font-weight: 850;
}

.task-card--danger .task-card__top span {
  color: var(--danger);
  background: var(--danger-soft);
}

.task-card--accent .task-card__top span {
  color: var(--accent-ink);
  background: var(--accent-soft);
}

.task-card--ok .task-card__top span {
  color: var(--ok);
  background: var(--ok-soft);
}

.task-card h2 {
  margin: 17px 0 12px;
  font-size: 23px;
  line-height: 1.18;
}

.task-card p {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-3);
  font-size: 18px;
}

.task-card:active,
.week-day:active {
  transform: translateY(1px);
}

.month-overview {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.month-overview button {
  min-width: 0;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  place-items: center;
  gap: 1px;
  color: var(--ink);
  background: var(--card);
  cursor: pointer;
}

.month-overview button.is-active {
  border-color: transparent;
  color: var(--primary-on);
  background: var(--primary);
}

.month-overview strong {
  font-size: 16px;
  line-height: 1;
}

.month-overview span {
  min-width: 18px;
  min-height: 18px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--primary-on);
  background: color-mix(in oklch, var(--primary-ink) 78%, var(--primary));
  font-size: 11px;
  font-weight: 900;
}

.task-form,
.task-details,
.empty-state {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--card);
  box-shadow: var(--shadow-1);
}

.task-form {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.task-form input,
.task-form select {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: var(--radius-s);
  padding: 0 12px;
  color: var(--ink);
  background: var(--bg);
  font: inherit;
  font-weight: 800;
}

.task-form label span {
  display: block;
  margin: 0 0 5px;
  color: var(--ink-3);
  font-size: 12px;
  font-weight: 900;
}

.task-form__row {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 9px;
}

.task-form__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}

.task-details {
  display: grid;
  gap: 8px;
  padding: 16px;
}

.task-details strong {
  font-size: 20px;
  line-height: 1.16;
}

.task-details > span {
  color: var(--ink-3);
  font-size: 14px;
  font-weight: 850;
}

.empty-state {
  padding: 18px;
  color: var(--ink-3);
  font-weight: 850;
  text-align: center;
}

.mini-forecast-card {
  margin-top: 20px;
  padding: 18px 20px 20px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--card);
  box-shadow: var(--shadow-1);
}

.mini-forecast-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
}

.mini-forecast-day {
  min-width: 0;
  min-height: 122px;
  border-radius: 14px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 7px;
  color: var(--ink-3);
  background: var(--bg-2);
}

.mini-forecast-day.is-risk {
  color: var(--danger);
  background: var(--danger-soft);
}

.mini-forecast-day strong {
  color: var(--ink-3);
  font-size: 16px;
}

.mini-forecast-day span {
  color: var(--ink);
  font-size: 20px;
  font-weight: 950;
}

.mini-forecast-day small {
  font-size: 18px;
  font-weight: 850;
}

.settings-card {
  padding: 4px;
}

.segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  padding: 6px;
  border-radius: var(--radius-l);
  background: color-mix(in oklch, var(--bg-2) 78%, var(--card));
  border: 1px solid var(--line);
}

.segmented button {
  border: 0;
  border-radius: var(--radius-m);
  min-height: 40px;
  color: var(--ink-2);
  background: transparent;
  font-weight: 900;
  cursor: pointer;
}

.segmented button.is-active {
  background: var(--card);
  color: var(--primary-ink);
  box-shadow: var(--shadow-1);
}

.select-wrap {
  position: relative;
  display: block;
}

.select-wrap::after {
  content: "";
  position: absolute;
  right: 16px;
  top: 50%;
  width: 9px;
  height: 9px;
  border-right: 2px solid var(--ink-3);
  border-bottom: 2px solid var(--ink-3);
  transform: translateY(-68%) rotate(45deg);
  pointer-events: none;
}

.select-wrap select {
  width: 100%;
  min-height: 50px;
  appearance: none;
  border: 1px solid var(--line);
  border-radius: var(--radius-l);
  padding: 0 42px 0 16px;
  color: var(--ink);
  background: var(--card);
  box-shadow: var(--shadow-1);
  font-weight: 900;
  cursor: pointer;
}

.settings-note {
  margin-top: 10px;
  color: var(--ink-3);
  font-size: 13px;
  line-height: 1.35;
}

.notice {
  padding: 11px 12px;
  border-radius: var(--radius-m);
  border: 1px solid color-mix(in oklch, var(--info) 20%, var(--line));
  background: var(--info-soft);
  color: var(--ink-2);
  font-size: 13px;
}

.hidden {
  display: none !important;
}

@media (max-width: 360px) {
  .scroll {
    padding-inline: 12px;
  }

  .quick {
    min-height: 104px;
  }

  .weather__temp {
    font-size: 36px;
  }

  .feature-art {
    min-height: 238px;
  }

  .photo-card {
    width: 220px;
    height: 220px;
  }

  .scan-pill {
    min-height: 50px;
    padding: 10px 15px;
    font-size: 17px;
  }

  .scan-pill--top {
    left: -28px;
  }

  .scan-pill--match {
    right: -28px;
  }

  .field-chip--one {
    left: 12px;
  }

  .field-chip--two {
    right: 8px;
  }

  .field-chip--three {
    left: 72px;
    width: 220px;
  }

  .feature-copy h1 {
    font-size: 32px;
  }

  .feature-copy p {
    font-size: 19px;
  }
}

@media (min-width: 760px) {
  body {
    min-height: 100svh;
    display: flex;
    justify-content: center;
    align-items: center;
    background:
      linear-gradient(180deg, rgb(255 255 255 / 5%), rgb(0 0 0 / 10%)),
      oklch(0.21 0.018 145);
  }

  .app-shell {
    max-width: 414px;
    height: min(860px, calc(100svh - 44px));
    min-height: 0;
    margin: 22px 0;
    border-radius: 32px;
    overflow: hidden;
    box-shadow: 0 24px 72px rgb(0 0 0 / 34%);
  }

  .screen,
  .onboarding {
    height: 100%;
    min-height: 0;
  }
}
