/* ─────────────────────────────────────────────
   Tokens
   ───────────────────────────────────────────── */
:root {
  /* Neutral palette */
  --ink-900:   #1a1916;
  --ink-700:   #3d3a34;
  --ink-500:   #6e6a62;
  --ink-300:   #b0aca4;
  --ink-100:   #e8e5e0;
  --ink-050:   #f4f2ef;

  /* Background */
  --bg:        #faf9f7;
  --bg-card:   #ffffff;

  /* Vegan status colours — chosen for fast legibility, not decoration */
  --vegan-bg:       #e8f5ec;
  --vegan-border:   #4caf73;
  --vegan-text:     #1b5e35;
  --vegan-dot:      #2e9e56;

  --maybe-bg:       #fff8e6;
  --maybe-border:   #e5a500;
  --maybe-text:     #5c3d00;
  --maybe-dot:      #d4920a;

  --notvegan-bg:    #fdecea;
  --notvegan-border:#e05555;
  --notvegan-text:  #6b1111;
  --notvegan-dot:   #d63c3c;

  /* Type */
  --font-sans: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --font-mono: "SF Mono", "Fira Mono", "Cascadia Code", monospace;

  /* Motion */
  --ease-out: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ─────────────────────────────────────────────
   Reset & base
   ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--ink-700);
  min-height: 100dvh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 5vh 1.25rem 4rem;
  line-height: 1.5;
}

/* ─────────────────────────────────────────────
   App shell
   ───────────────────────────────────────────── */
.app {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

/* ─────────────────────────────────────────────
   Header
   ───────────────────────────────────────────── */
.app-header {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.app-title-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.app-icon {
  flex-shrink: 0;
  border-radius: 10px;
  display: block;
}

.app-title {
  font-size: 1.35rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink-900);
}

.app-subtitle {
  font-size: 0.8125rem;
  color: var(--ink-400, var(--ink-500));
  letter-spacing: 0.01em;
}

/* ─────────────────────────────────────────────
   Search form
   ───────────────────────────────────────────── */
.app-main {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}

.search-form {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.input-wrap {
  display: flex;
  align-items: center;
  background: var(--bg-card);
  border: 1.5px solid var(--ink-100);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.input-wrap:focus-within {
  border-color: var(--ink-300);
  box-shadow: 0 0 0 3px rgba(110, 106, 98, 0.1);
}

.search-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-mono);
  font-size: 1.375rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink-900);
  padding: 0.75rem 0 0.75rem 1rem;
  /* Uppercase visual — actual normalisation done in JS */
  text-transform: uppercase;
}

.search-input::placeholder {
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-300);
}

.search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--ink-400, var(--ink-500));
  transition: color 0.15s ease;
}

.search-btn:hover  { color: var(--ink-700); }
.search-btn:active { transform: scale(0.92); }

.input-hint {
  font-size: 0.8125rem;
  color: var(--ink-500);
  padding-left: 0.25rem;
  min-height: 1.2em;
}

.input-hint.error { color: #c0392b; }

/* ─────────────────────────────────────────────
   Result card
   ───────────────────────────────────────────── */
.result-area {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.result-card {
  background: var(--bg-card);
  border: 1.5px solid var(--ink-100);
  border-radius: 12px;
  padding: 1.25rem 1.25rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  animation: fadeUp 0.22s var(--ease-out) both;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Code + name */
.result-identity {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.result-code {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--ink-400, var(--ink-500));
  text-transform: uppercase;
}

.result-name {
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink-900);
  line-height: 1.3;
}

/* Functional class pill */
.result-class {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  width: fit-content;
}

.class-pill {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.025em;
  color: var(--ink-500);
  background: var(--ink-050);
  border: 1px solid var(--ink-100);
  border-radius: 999px;
  padding: 0.2rem 0.65rem;
}

/* Divider */
.result-divider {
  height: 1px;
  background: var(--ink-100);
  border: none;
  margin: 0 -0.25rem;
}

/* Vegan status badge */
.vegan-badge {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  border-radius: 8px;
  padding: 0.75rem 0.875rem;
}

.vegan-badge.vegan {
  background: var(--vegan-bg);
  border: 1px solid var(--vegan-border);
}
.vegan-badge.maybe {
  background: var(--maybe-bg);
  border: 1px solid var(--maybe-border);
}
.vegan-badge.not-vegan {
  background: var(--notvegan-bg);
  border: 1px solid var(--notvegan-border);
}

.badge-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 0.35em;
}

.vegan     .badge-dot { background: var(--vegan-dot); }
.maybe     .badge-dot { background: var(--maybe-dot); }
.not-vegan .badge-dot { background: var(--notvegan-dot); }

.badge-body {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.badge-label {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.2;
}

.vegan     .badge-label { color: var(--vegan-text); }
.maybe     .badge-label { color: var(--maybe-text); }
.not-vegan .badge-label { color: var(--notvegan-text); }

.badge-reason {
  font-size: 0.8125rem;
  line-height: 1.5;
}

.vegan     .badge-reason { color: var(--vegan-text); opacity: 0.85; }
.maybe     .badge-reason { color: var(--maybe-text); opacity: 0.85; }
.not-vegan .badge-reason { color: var(--notvegan-text); opacity: 0.85; }

/* ─────────────────────────────────────────────
   Not-found state
   ───────────────────────────────────────────── */
.not-found {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 1.25rem;
  background: var(--bg-card);
  border: 1.5px solid var(--ink-100);
  border-radius: 12px;
  animation: fadeUp 0.22s var(--ease-out) both;
}

.not-found-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--ink-700);
}

.not-found-sub {
  font-size: 0.8125rem;
  color: var(--ink-500);
  line-height: 1.5;
}

/* ─────────────────────────────────────────────
   Loading skeleton pulse
   ───────────────────────────────────────────── */
.skeleton {
  background: var(--bg-card);
  border: 1.5px solid var(--ink-100);
  border-radius: 12px;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.skel-line {
  height: 14px;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--ink-100) 25%, var(--ink-050) 50%, var(--ink-100) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
}

.skel-line.wide  { width: 65%; }
.skel-line.full  { width: 90%; }
.skel-line.short { width: 40%; height: 10px; }

@keyframes shimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

/* ─────────────────────────────────────────────
   Responsive tweaks
   ───────────────────────────────────────────── */
@media (max-width: 360px) {
  .search-input { font-size: 1.15rem; }
  .result-name  { font-size: 1.05rem; }
}
