/* ============================================================
   GrowDoctor – Design System · "Verde Rafinat" (2026)
   Refinare a temei Fresh Organic: mai aerisit, editorial,
   header luminos, hero luminos · mobile-first.
   Înlocuiește direct css/styles.css — aceleași clase.
   ============================================================ */
:root {
  /* paletă verde organic */
  --green-900: #143d22;  /* forest-deep – titluri */
  --green-800: #0f6a39;  /* primary */
  --green-700: #1f7a3d;  /* accente / linkuri */
  --green-600: #1f8a47;
  --green-500: #22c55e;  /* emerald-accent */
  --green-400: #4ad07f;
  --lime:      #9bdb4d;
  --lime-soft: #d8f3b0;
  --mint:      #cdeed9;
  --mint-soft: #eef7f1;

  --terracotta: #e2725b;
  --earth:  #8a6240;
  --water:  #2a93d5;
  --sun:    #f2a93b;
  --danger: #ba1a1a;
  --warn:   #e08a1a;
  --ok:     #1f9d54;

  --ink:   #14271c;       /* on-surface */
  --muted: #5e7065;       /* on-surface-variant */
  --line:  #e3efe7;       /* outline-variant */
  --card:  #ffffff;

  /* fundal Sage White */
  --bg:    #eef5ef;

  /* umbre subtile, ton verde (refinate) */
  --sh-sm: 0 1px 2px rgba(16, 60, 35, .05);
  --sh:    0 6px 16px -11px rgba(16, 60, 35, .30);
  --sh-lg: 0 14px 30px -16px rgba(16, 60, 35, .25);
  --sh-green: 0 10px 22px -8px rgba(33, 179, 101, .55);

  /* raze de colț (mai generoase) */
  --r-sm: 14px;
  --r:    18px;
  --r-lg: 24px;
  --r-pill: 999px;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "Hanken Grotesk", -apple-system, "Segoe UI", Roboto, system-ui, sans-serif;
  color: var(--ink);
  line-height: 1.5;
  padding-bottom: 96px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: var(--bg);
  background-image:
    radial-gradient(1200px 480px at 100% -8%, rgba(155, 219, 77, .12), transparent 60%),
    radial-gradient(1000px 500px at -10% 0%, rgba(33, 179, 101, .09), transparent 55%);
  background-attachment: fixed;
  transition: background-color .3s, color .3s;
}
/* Titluri & nume — serif editorial (Literata) */
.app-header h1, .hero h2, .section-title, .detail-head h2, .plant-info h3,
.season-title, .prod-name, .pa-title, .modal h3, .gname, .disease-item .dn,
.empty p, .nbar-head b, .home-hero .hh-title, .toolkit-head h3 {
  font-family: "Literata", Georgia, "Times New Roman", serif;
}

/* ---------- Header (luminos) ---------- */
.app-header {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: rgba(238, 245, 239, .85);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  color: var(--green-900);
  box-shadow: 0 1px 0 rgba(16, 60, 35, .06);
}
.brand { display: flex; align-items: center; gap: 11px; cursor: pointer; flex: 1; min-width: 0; }
.brand > div { min-width: 0; }
.brand h1, .brand-sub { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand-logo {
  font-size: 20px; flex: 0 0 auto; width: 40px; height: 40px;
  display: grid; place-items: center; border-radius: 13px;
  background: linear-gradient(140deg, #e9f6ee, #cdeed9);
  box-shadow: inset 0 0 0 1px rgba(33, 179, 101, .14);
}
.app-header h1 { font-size: 18px; margin: 0; font-weight: 700; letter-spacing: -.2px; color: var(--green-900); }
.brand-sub { margin: 1px 0 0; font-size: 11.5px; color: var(--muted); font-weight: 600; }
.header-season {
  display: none;
  background: var(--mint-soft); color: var(--green-700);
  padding: 7px 13px; border-radius: var(--r-pill);
  font-size: 11.5px; font-weight: 800; flex: 0 0 auto;
  box-shadow: inset 0 0 0 1px rgba(33, 179, 101, .12);
}
@media (min-width: 480px) { .header-season { display: inline-flex; } }

/* butoane antet */
.hdr-back, .hdr-home {
  flex: 0 0 auto; width: 36px; height: 36px;
  display: none; align-items: center; justify-content: center;
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-pill);
  color: var(--green-700); cursor: pointer; transition: background .15s, transform .1s;
  box-shadow: var(--sh-sm);
}
.hdr-back { font-size: 24px; line-height: 1; padding: 0 2px 3px 0; margin-right: 4px; }
.hdr-home { display: inline-flex; font-size: 16px; margin-left: 6px; }
.hdr-back.show { display: inline-flex; }
.hdr-back:active, .hdr-home:active { background: var(--mint-soft); transform: scale(.93); }

/* ---------- View ---------- */
.view { padding: 18px 16px; max-width: 720px; margin: 0 auto; animation: viewIn .35s cubic-bezier(.22,.9,.3,1); }
@keyframes viewIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.section-title {
  font-size: 14px; font-weight: 700; margin: 22px 4px 11px; color: var(--green-900);
  display: flex; align-items: center; gap: 9px; letter-spacing: -.1px;
}
.muted { color: var(--muted); }
.small { font-size: 12.5px; }

/* ---------- Cards ---------- */
.card {
  background: var(--card); border-radius: var(--r-lg);
  box-shadow: var(--sh); padding: 18px; margin-bottom: 14px;
  border: 1px solid var(--line);
}
.hero {
  position: relative; overflow: hidden;
  background: linear-gradient(155deg, #ffffff, #e7f5ed);
  border: 1px solid #d6ecdd;
}
.hero::after {
  content: ""; position: absolute; right: -40px; top: -50px;
  width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(155,219,77,.45), rgba(33,179,101,.14) 70%, transparent);
  filter: blur(4px); pointer-events: none;
}
.hero h2 { margin: 0 0 6px; font-size: 19px; color: var(--green-900); font-weight: 800; letter-spacing: -.3px; position: relative; }
.hero p { margin: 0; font-size: 13.5px; color: #46604f; position: relative; }

/* ---------- Home: hero landing (luminos) ---------- */
.home-hero {
  position: relative; overflow: hidden; border-radius: var(--r-lg);
  padding: 32px 24px; margin-bottom: 16px; color: var(--green-900);
  background: linear-gradient(155deg, #ffffff 0%, #eaf7ef 55%, #e0f3e7 100%);
  box-shadow: var(--sh-lg); border: 1px solid #d6ecdd;
}
.home-hero::before {
  content: ""; position: absolute; right: -50px; top: -50px;
  width: 170px; height: 170px; border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle at 35% 35%, rgba(155,219,77,.40), rgba(33,179,101,.12) 70%, transparent);
  filter: blur(6px);
}
.hh-badge {
  position: relative; display: inline-flex; align-items: center; gap: 6px;
  background: #def0e0; border: none; color: var(--green-700);
  padding: 6px 14px; border-radius: var(--r-pill); font-size: 11.5px; font-weight: 800;
}
.hh-title {
  position: relative;
  font-size: clamp(28px, 8vw, 44px); line-height: 1.1; margin: 16px 0 12px;
  font-weight: 700; letter-spacing: -.5px; color: var(--green-900);
}
.hh-sub { position: relative; color: #46604f; font-size: 14px; line-height: 1.55; max-width: 540px; margin: 0 0 20px; }
.hh-cta { position: relative; display: flex; gap: 10px; flex-wrap: wrap; }
.hh-cta .btn { width: auto; flex: 0 1 auto; }
.hh-cta .btn.secondary { background: #fff; color: var(--green-700); border-color: #cfe9d8; }

.toolkit-head { text-align: center; margin: 28px 0 16px; }
.toolkit-head h3 { font-size: clamp(20px, 5.5vw, 28px); color: var(--green-900); margin: 0 0 7px; font-weight: 700; letter-spacing: -.3px; }
.toolkit-head p { color: var(--muted); font-size: 13.5px; line-height: 1.5; max-width: 520px; margin: 0 auto; }

/* ---------- Quick tiles ---------- */
.tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; }
.tile {
  background: var(--card); border: 1px solid var(--line); border-radius: 20px;
  padding: 16px; cursor: pointer; box-shadow: var(--sh);
  transition: transform .14s cubic-bezier(.34,1.4,.5,1), box-shadow .14s; text-align: left;
}
.tile:active { transform: scale(.96); box-shadow: var(--sh-sm); }
.tile .t-ico {
  font-size: 21px; display: grid; place-items: center; width: 44px; height: 44px;
  border-radius: 13px; margin-bottom: 11px;
  background: linear-gradient(140deg, var(--mint-soft), var(--mint));
  box-shadow: inset 0 0 0 1px rgba(33,179,101,.12);
}
.tile .t-name { font-weight: 800; font-size: 14px; letter-spacing: -.2px; }
.tile .t-sub { font-size: 11.5px; color: var(--muted); margin-top: 3px; line-height: 1.35; }

/* ---------- Search & chips ---------- */
.search-bar {
  display: flex; align-items: center; gap: 9px; background: var(--card);
  border: 1px solid var(--line); border-radius: var(--r-pill); padding: 12px 16px; margin-bottom: 14px;
  box-shadow: var(--sh-sm);
}
.search-bar input { border: none; outline: none; flex: 1; font-size: 15px; background: transparent; color: var(--ink); }
.chip-bar { position: relative; margin-bottom: 12px; }
.chips { display: flex; gap: 8px; overflow-x: auto; padding: 2px 2px 8px; scrollbar-width: none; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; }
.chips::-webkit-scrollbar { display: none; }
.chips.expanded { flex-wrap: wrap; overflow: visible; padding-right: 2px; }
.chip {
  flex: 0 0 auto; padding: 8px 15px; border-radius: var(--r-pill); border: 1px solid var(--line);
  background: var(--card); font-size: 12.5px; font-weight: 700; cursor: pointer; color: var(--muted);
  transition: all .15s; box-shadow: var(--sh-sm); white-space: nowrap;
}
.chip:active { transform: scale(.95); }
.chip.active { background: linear-gradient(135deg, var(--green-600), var(--green-500)); color: #fff; border-color: transparent; box-shadow: var(--sh-green); }
.chip-bar::before, .chip-bar::after {
  content: ""; position: absolute; top: 0; bottom: 8px; width: 30px; pointer-events: none; z-index: 1; transition: opacity .2s;
}
.chip-bar::before { left: 0; background: linear-gradient(to right, var(--bg), rgba(238,245,239,0)); }
.chip-bar::after { right: 28px; background: linear-gradient(to left, var(--bg), rgba(238,245,239,0)); }
.chip-bar.at-start::before { opacity: 0; }
.chip-bar.at-end::after { opacity: 0; }
.chip-bar.expanded::before, .chip-bar.expanded::after { opacity: 0; }
.chip-toggle {
  position: absolute; right: 0; top: 1px; z-index: 2; width: 30px; height: 36px;
  border: 1px solid var(--line); background: var(--card); color: var(--green-700);
  font-size: 15px; cursor: pointer; border-radius: var(--r-pill); display: grid; place-items: center;
  box-shadow: var(--sh-sm); transition: transform .2s;
}
.chip-toggle.up { transform: rotate(180deg); }
.chip-bar.expanded .chip-toggle { position: static; float: right; margin: -2px 0 6px 8px; }

/* ---------- Plant rows ---------- */
.plant-row {
  display: flex; align-items: center; gap: 14px; background: var(--card);
  border: 1px solid var(--line); border-radius: var(--r); padding: 11px; margin-bottom: 9px;
  cursor: pointer; box-shadow: var(--sh-sm); transition: transform .14s, box-shadow .14s;
}
.plant-row:active { transform: scale(.985); box-shadow: var(--sh); }
.plant-emoji {
  font-size: 28px; width: 48px; height: 48px; display: grid; place-items: center;
  background: linear-gradient(140deg, var(--mint-soft), var(--mint)); border-radius: 14px; flex: 0 0 auto;
  box-shadow: inset 0 0 0 1px rgba(33,179,101,.10);
}
.plant-info { flex: 1; min-width: 0; }
.plant-info h3 { margin: 0; font-size: 15px; font-weight: 700; letter-spacing: -.2px; }
.plant-info .latin { font-style: italic; color: var(--muted); font-size: 11.5px; }
.plant-info .cat { font-size: 11px; color: var(--green-700); font-weight: 700; }
.arrow { color: #b9cdbf; font-size: 22px; font-weight: 300; }

/* ---------- Plant detail ---------- */
.detail-head { display: flex; align-items: center; gap: 14px; margin-bottom: 10px; }
.detail-head .plant-emoji { font-size: 36px; width: 62px; height: 62px; border-radius: 18px; }
.detail-head h2 { margin: 0; font-size: 21px; font-weight: 800; letter-spacing: -.4px; }
.back-btn {
  display: inline-flex; align-items: center; gap: 5px; background: none; border: none;
  color: var(--green-700); font-weight: 700; font-size: 14px; cursor: pointer; padding: 6px 0; margin-bottom: 4px;
}
.back-btn:active { opacity: .6; }
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.info-item { background: var(--mint-soft); border-radius: var(--r-sm); padding: 11px 13px; border: 1px solid var(--line); }
.info-item .k { font-size: 10.5px; color: var(--green-700); font-weight: 800; text-transform: uppercase; letter-spacing: .4px; }
.info-item .v { font-size: 13.5px; font-weight: 600; margin-top: 3px; }

.tag { display: inline-block; padding: 3px 10px; border-radius: var(--r-pill); font-size: 10.5px; font-weight: 800; letter-spacing: .2px; }
.tag.bio { background: #def5e6; color: var(--ok); }
.tag.mineral { background: #e3f0fb; color: var(--water); }
.tag.mixt { background: #fcf0db; color: var(--warn); }
.tag.mecanic { background: #efeae2; color: var(--earth); }
.tag.chimic { background: #fbe4e4; color: var(--danger); }
.tag.organic { background: #eef6dd; color: #6a8a2a; }

.timeline-item { display: flex; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.timeline-item:last-child { border-bottom: none; }
.tl-month { flex: 0 0 96px; font-weight: 800; font-size: 12.5px; color: var(--green-700); }
.tl-body { flex: 1; font-size: 13px; min-width: 0; }
.tl-body .what { font-weight: 700; }
.tl-body .dose { color: var(--muted); font-size: 12px; margin-top: 1px; }

.disease-item { padding: 12px 0; border-bottom: 1px solid var(--line); }
.disease-item:last-child { border-bottom: none; }
.disease-item .dn { font-weight: 800; font-size: 14px; color: var(--green-900); }
.disease-item .ds { font-size: 12.5px; color: var(--muted); margin: 3px 0; }
.disease-item .dt { font-size: 12.5px; }

.range-wrap { margin-top: 8px; }
.range-bar { height: 8px; border-radius: var(--r-pill); background: linear-gradient(90deg, var(--sun), var(--green-500), var(--sun)); }
.range-label { display: flex; justify-content: space-between; font-size: 11px; color: var(--muted); margin-top: 5px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: linear-gradient(135deg, var(--green-600), var(--green-500)); color: #fff; border: none;
  border-radius: 15px; padding: 14px 18px; font-size: 15px; font-weight: 800; cursor: pointer; width: 100%;
  box-shadow: var(--sh-green); transition: transform .12s, box-shadow .12s; letter-spacing: -.1px;
}
.btn:active { transform: scale(.975); box-shadow: var(--sh-sm); }
.btn.secondary { background: var(--card); color: var(--green-700); border: 1.5px solid #cfe9d8; box-shadow: var(--sh-sm); }
.btn.ghost { background: var(--mint-soft); color: var(--green-700); box-shadow: none; border: 1px solid #d7f0e0; }
.btn.danger { background: linear-gradient(135deg, #e0514f, #d33b39); box-shadow: 0 10px 22px -8px rgba(224,81,79,.45); }
.btn-row { display: flex; gap: 10px; }
.btn-row .btn { width: auto; flex: 1; }

/* ---------- Diagnose ---------- */
.symptom-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.symptom {
  display: flex; align-items: center; gap: 8px; background: var(--card); border: 1.5px solid var(--line);
  border-radius: var(--r-sm); padding: 12px; font-size: 12.5px; cursor: pointer; font-weight: 600;
  transition: all .14s; box-shadow: var(--sh-sm);
}
.symptom .s-ico { font-size: 18px; }
.symptom:active { transform: scale(.97); }
.symptom.sel { border-color: var(--green-500); background: var(--mint-soft); color: var(--green-900); box-shadow: inset 0 0 0 1px var(--green-500); }
.symptom.sel::after { content: "✓"; margin-left: auto; color: var(--green-600); font-weight: 900; }

.result-card { border-left: 5px solid var(--green-500); }
.result-card.sev-mare { border-left-color: var(--danger); }
.result-card.sev-medie { border-left-color: var(--warn); }
.result-card.sev-mica { border-left-color: var(--ok); }
.match-bar { height: 7px; border-radius: var(--r-pill); background: var(--line); overflow: hidden; margin: 9px 0; }
.match-fill { height: 100%; background: linear-gradient(90deg, var(--green-500), var(--lime)); border-radius: var(--r-pill); transition: width .5s cubic-bezier(.22,.9,.3,1); }
.pill { font-size: 11px; font-weight: 800; padding: 4px 11px; border-radius: var(--r-pill); background: var(--mint-soft); color: var(--green-700); }
.pill.sev-mare { background: #fbe4e4; color: var(--danger); }
.pill.sev-medie { background: #fcf1db; color: var(--warn); }
.pill.sev-mica { background: #def5e6; color: var(--ok); }

.photo-drop {
  border: 2px dashed var(--green-400); border-radius: var(--r); padding: 24px; text-align: center;
  background: var(--mint-soft); cursor: pointer; margin-bottom: 14px; transition: background .15s;
}
.photo-drop:active { background: var(--mint); }
.photo-drop .pd-ico { font-size: 34px; }
.photo-preview { width: 100%; border-radius: var(--r); margin-bottom: 12px; }

/* ---------- Lab (sol & apă) ---------- */
.field { margin-bottom: 13px; }
.field label { display: block; font-size: 12.5px; font-weight: 800; margin-bottom: 6px; color: var(--green-900); }
.field .input-wrap { display: flex; align-items: center; gap: 8px; background: var(--card); border: 1.5px solid var(--line); border-radius: var(--r-sm); padding: 0 14px; transition: border-color .15s, box-shadow .15s; }
.field .input-wrap:focus-within { border-color: var(--green-500); box-shadow: 0 0 0 3px rgba(33,179,101,.12); }
.field input, .field select { border: none; outline: none; padding: 13px 0; font-size: 15px; flex: 1; background: transparent; width: 100%; color: var(--ink); }
.field .unit { color: var(--muted); font-size: 13px; font-weight: 700; }

.verdict { border-radius: var(--r-sm); padding: 13px 15px; margin-bottom: 10px; font-size: 13px; display: flex; gap: 11px; }
.verdict .v-ico { font-size: 20px; flex: 0 0 auto; }
.verdict.ok   { background: #e9f9ef; border: 1px solid #bce8cd; }
.verdict.warn { background: #fdf4e2; border: 1px solid #f3dca6; }
.verdict.bad  { background: #fce9e9; border: 1px solid #f2c4c4; }
.verdict .vt { font-weight: 800; }
.verdict .vd { color: var(--muted); margin-top: 2px; }
.verdict .vf { margin-top: 4px; }

/* ---------- Empty states ---------- */
.empty { text-align: center; padding: 44px 22px; color: var(--muted); }
.empty .e-ico {
  font-size: 40px; width: 88px; height: 88px; margin: 0 auto 14px; display: grid; place-items: center;
  border-radius: 50%; background: linear-gradient(160deg, var(--mint-soft), var(--mint));
  box-shadow: inset 0 0 0 1px rgba(33,179,101,.12);
}
.empty p { font-size: 13.5px; line-height: 1.5; }

/* ---------- Garden ---------- */
.garden-card { display: flex; align-items: center; gap: 13px; }
.garden-card .meta { flex: 1; min-width: 0; }
.garden-card .meta .gname { font-weight: 800; font-size: 15px; letter-spacing: -.2px; }
.garden-card .meta .gdate { font-size: 12px; color: var(--muted); margin-top: 1px; }
.next-task { font-size: 12px; background: linear-gradient(135deg, var(--mint-soft), var(--mint)); color: var(--green-800); padding: 9px 12px; border-radius: var(--r-sm); margin-top: 9px; font-weight: 700; }
.garden-note { font-size: 12.5px; background: #fffdf3; border: 1px solid #f0e7c6; color: #7a6a3a; padding: 8px 11px; border-radius: var(--r-sm); margin-top: 9px; }
.icon-btn { background: none; border: none; font-size: 19px; cursor: pointer; color: var(--muted); padding: 6px; border-radius: 10px; transition: background .15s; }
.icon-btn:active { background: var(--mint-soft); }

/* segmented control */
.seg { display: flex; flex-wrap: wrap; gap: 5px; background: var(--card); border: 1px solid var(--line); border-radius: 15px; padding: 5px; box-shadow: var(--sh-sm); }
.seg-btn { flex: 1 1 auto; min-width: 64px; border: none; background: none; padding: 10px 6px; border-radius: 11px; font-size: 12.5px; font-weight: 800; color: var(--muted); cursor: pointer; transition: all .18s; letter-spacing: -.1px; white-space: nowrap; }
.seg-btn.active { background: linear-gradient(135deg, var(--green-600), var(--green-500)); color: #fff; box-shadow: var(--sh-green); }

/* istoric */
.season-head { font-weight: 800; font-size: 14px; color: var(--green-900); margin: 18px 4px 9px; display: flex; align-items: center; gap: 6px; }

/* ghid sezonier */
.season-card.cur { border: 1.5px solid var(--green-500); background: linear-gradient(180deg, var(--mint-soft), var(--card) 45%); }
.season-title { font-weight: 800; font-size: 16.5px; color: var(--green-900); display: flex; align-items: center; gap: 7px; flex-wrap: wrap; letter-spacing: -.3px; }
.guide-item { padding: 11px 0; border-bottom: 1px solid var(--line); }
.guide-item:last-child { border-bottom: none; }
.gi-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 5px; }
.gi-top .what { font-weight: 800; font-size: 13.5px; color: var(--green-900); }

/* sugestii tratament */
.sugg { display: inline-block; margin: 0 6px 6px 0; padding: 8px 12px; border-radius: var(--r-pill); border: 1px solid var(--green-400); background: var(--mint-soft); color: var(--green-700); font-size: 12px; font-weight: 700; cursor: pointer; transition: transform .1s; }
.sugg:active { transform: scale(.95); }

/* catalog produse */
.prod-card { padding: 15px; }
.prod-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 7px; }
.prod-name { font-weight: 800; font-size: 14.5px; letter-spacing: -.2px; color: var(--green-900); }
.prod-row { font-size: 12.5px; margin: 4px 0; }
.prod-row b { color: var(--green-800); }

/* plan personalizat */
.plan-need { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.plan-month { display: flex; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.plan-month:last-child { border-bottom: none; }
.plan-mname { flex: 0 0 86px; font-weight: 800; font-size: 12.5px; color: var(--green-700); }
.plan-acts { flex: 1; min-width: 0; }
.plan-act { font-size: 12.5px; margin-bottom: 6px; }
.plan-act .pa-ico { margin-right: 4px; }
.shop-item { display: flex; align-items: flex-start; gap: 9px; font-size: 12.5px; padding: 7px 0; border-bottom: 1px solid var(--line); }
.shop-item:last-child { border-bottom: none; }

/* ---------- Bottom nav (floating glass) ---------- */
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 30;
  display: grid; grid-template-columns: repeat(6, 1fr);
  background: rgba(255,255,255,.90);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-top: 1px solid rgba(227,239,231,.9);
  padding: 8px 4px; padding-bottom: max(8px, env(safe-area-inset-bottom));
  box-shadow: 0 -6px 24px rgba(16, 60, 35, .06);
}
.nav-btn {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  background: none; border: none; padding: 5px 2px 3px; cursor: pointer;
  font-size: 9.5px; color: var(--muted); font-weight: 700; letter-spacing: -.1px;
}
.nav-btn .nav-ico {
  font-size: 17px; width: 44px; height: 28px; display: grid; place-items: center;
  border-radius: var(--r-pill); filter: grayscale(.35);
  transition: background .22s cubic-bezier(.34,1.4,.5,1), transform .18s, filter .2s;
}
.nav-btn.active { color: var(--green-700); }
.nav-btn.active .nav-ico { background: linear-gradient(140deg, var(--mint), var(--lime-soft)); filter: none; transform: translateY(-1px); }
.nav-btn:active .nav-ico { transform: scale(.9); }
@media (min-width: 760px) {
  .bottom-nav {
    left: 50%; right: auto; transform: translateX(-50%);
    width: 720px; max-width: calc(100% - 32px);
    bottom: 14px; border: 1px solid var(--line); border-radius: var(--r);
  }
}

/* ---------- Modal (bottom sheet) ---------- */
.modal-back { position: fixed; inset: 0; background: rgba(13, 40, 25, .5); z-index: 50; display: flex; align-items: flex-end; justify-content: center; animation: fadeIn .22s; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--card); width: 100%; max-width: 720px; max-height: 92vh; overflow-y: auto;
  border-radius: 26px 26px 0 0; padding: 22px 20px; padding-bottom: max(22px, env(safe-area-inset-bottom));
  animation: slideup .3s cubic-bezier(.22,.9,.3,1); position: relative;
}
.modal::before { content: ""; position: absolute; top: 9px; left: 50%; transform: translateX(-50%); width: 42px; height: 5px; border-radius: var(--r-pill); background: #d9e6dd; }
@keyframes slideup { from { transform: translateY(100%); } to { transform: none; } }
.modal h3 { margin: 6px 0 16px; font-size: 18px; font-weight: 800; letter-spacing: -.3px; }
.divider { height: 1px; background: var(--line); margin: 14px 0; }
.notice { font-size: 11.5px; color: var(--muted); text-align: center; margin-top: 18px; line-height: 1.55; padding: 0 8px; }

.prod-links { margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--line); font-size: 12px; }
.prod-links .lnk { display: inline-block; margin: 4px 4px 0 0; padding: 4px 10px; background: var(--mint-soft); border: 1px solid var(--green-400); border-radius: var(--r-pill); color: var(--green-800); font-weight: 700; cursor: pointer; font-size: 11px; }
.prod-links .lnk:active { transform: scale(0.95); }

/* grafic balanță nutrienți */
.nbar { margin-bottom: 14px; }
.nbar:last-of-type { margin-bottom: 6px; }
.nbar-head { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; margin-bottom: 5px; font-size: 12.5px; }
.nbar-head b { color: var(--green-900); font-weight: 800; }
.nbar-val { font-weight: 800; }
.nbar-val.ok { color: var(--ok); }
.nbar-val.warn { color: var(--warn); }
.nbar-val.bad { color: var(--danger); }
.nbar-val .muted { font-weight: 600; }
.nbar-track { position: relative; height: 14px; border-radius: var(--r-pill); overflow: hidden; background: var(--line); }
.nbar-zone { position: absolute; top: 0; bottom: 0; }
.nbar-zone.red { background: rgba(224,81,79,.22); }
.nbar-zone.amber { background: rgba(224,138,26,.24); }
.nbar-zone.green { background: rgba(33,179,101,.28); }
.nbar-mark { position: absolute; top: -3px; bottom: -3px; width: 4px; border-radius: 3px; transform: translateX(-2px); box-shadow: 0 0 0 2px #fff; }
.nbar-mark.ok { background: var(--ok); }
.nbar-mark.warn { background: var(--warn); }
.nbar-mark.bad { background: var(--danger); }
.nbar-legend { display: flex; gap: 14px; justify-content: center; margin-top: 12px; font-size: 11px; color: var(--muted); }
.nbar-legend span { display: inline-flex; align-items: center; gap: 5px; }
.nbar-legend .lg { width: 11px; height: 11px; border-radius: 4px; display: inline-block; }
.nbar-legend .lg.red { background: rgba(224,81,79,.5); }
.nbar-legend .lg.amber { background: rgba(224,138,26,.55); }
.nbar-legend .lg.green { background: rgba(33,179,101,.6); }

/* evidențiere card produs accesat din diagnoză */
.prod-card.flash { animation: cardFlash 1.6s ease; }
@keyframes cardFlash {
  0%, 100% { box-shadow: var(--sh); }
  20%, 60% { box-shadow: 0 0 0 3px var(--green-400), var(--sh); }
}

/* Scroll to top */
#scrollTop { position: fixed; bottom: 85px; right: 16px; width: 44px; height: 44px; background: var(--green-700); color: #fff; border: none; border-radius: 50%; display: none; align-items: center; justify-content: center; font-size: 20px; box-shadow: var(--sh-lg); z-index: 40; cursor: pointer; }

/* Toast */
.toast {
  position: fixed; left: 50%; bottom: 100px;
  transform: translateX(-50%) translateY(20px);
  background: #143d22; color: #fff; padding: 12px 20px; border-radius: var(--r-pill);
  font-size: 13px; font-weight: 700; z-index: 80; box-shadow: var(--sh-lg);
  opacity: 0; pointer-events: none; transition: opacity .26s, transform .26s; max-width: 86%;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ---------- Tipărire / PDF ---------- */
#printArea { display: none; }
.pa-title { font-size: 20px; font-weight: 800; margin: 0 0 2px; }
.pa-sub { font-size: 12px; color: #555; margin: 0 0 14px; }
.pa-h { font-size: 14px; font-weight: 800; margin: 16px 0 6px; }
.pa-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.pa-table th, .pa-table td { border: 1px solid #cdd8d0; padding: 6px 9px; text-align: left; vertical-align: top; }
.pa-table th { background: #eaf5ee; font-weight: 700; }
.pa-note { font-size: 10.5px; color: #666; margin-top: 14px; line-height: 1.5; }
@media print {
  body.gd-printing > *:not(#printArea) { display: none !important; }
  body.gd-printing #printArea { display: block; padding: 0; color: #000; }
  @page { margin: 14mm; }
}

/* ============================================================
   TEMA DARK · "Night Garden" (teal pe verde-petrol închis)
   ============================================================ */
:root[data-theme="dark"] {
  --green-900: #c2ebdc;
  --green-800: #3cddc7;
  --green-700: #62fae3;
  --green-600: #14b8a6;
  --green-500: #2dd4bf;
  --green-400: #5eead4;
  --lime: #8bd6b6;
  --lime-soft: #0f3a30;
  --mint: #0e3a2d;
  --mint-soft: #0b2d23;
  --terracotta: #ff9d7d;
  --water: #7cc6ee;
  --sun: #ffc480;
  --danger: #ffb4ab;
  --warn: #ffc480;
  --ok: #4edea3;
  --ink: #c2ebdc;
  --muted: #93a89f;
  --line: #163f31;
  --card: #0a2c22;
  --bg: #021712;
  --sh-sm: 0 1px 2px rgba(0,0,0,.45);
  --sh: 0 8px 20px -14px rgba(0,0,0,.6);
  --sh-lg: 0 16px 34px -16px rgba(0,0,0,.6);
  --sh-green: 0 12px 26px -8px rgba(45,212,191,.4);
}
:root[data-theme="dark"] body {
  background-image:
    radial-gradient(1200px 480px at 100% -8%, rgba(45,212,191,.10), transparent 60%),
    radial-gradient(1000px 500px at -10% 0%, rgba(20,184,166,.08), transparent 55%);
}
:root[data-theme="dark"] .app-header {
  background: rgba(2,23,18,.85);
  color: #eafff8;
  box-shadow: 0 1px 0 rgba(94,234,212,.08);
}
:root[data-theme="dark"] .app-header h1 { color: #eafff8; }
:root[data-theme="dark"] .brand-logo { background: linear-gradient(140deg,#0c4339,#072a23); box-shadow: inset 0 0 0 1px rgba(94,234,212,.18); }
:root[data-theme="dark"] .hdr-back, :root[data-theme="dark"] .hdr-home { background: var(--card); border-color: var(--line); color: var(--green-700); }
:root[data-theme="dark"] .hero,
:root[data-theme="dark"] .home-hero {
  background: linear-gradient(155deg, #07362b 0%, #06302a 55%, #04241d 100%);
  border-color: #15493a;
  color: #eafff8;
}
:root[data-theme="dark"] .hero p, :root[data-theme="dark"] .hh-sub { color: #a7cabf; }
:root[data-theme="dark"] .hh-badge { background: rgba(94,234,212,.12); color: #5eead4; }
:root[data-theme="dark"] .btn { color: #04231e; }
:root[data-theme="dark"] .btn.secondary { color: var(--green-700); border-color: #1e4d3f; background: var(--card); }
:root[data-theme="dark"] .btn.ghost { color: var(--green-700); border-color: #1e4d3f; }
:root[data-theme="dark"] .hh-cta .btn.secondary { background: rgba(94,234,212,.08); color: #5eead4; }
:root[data-theme="dark"] .chip.active,
:root[data-theme="dark"] .seg-btn.active { color: #04231e; }
:root[data-theme="dark"] #scrollTop { color: #04231e; }
:root[data-theme="dark"] .arrow { color: #4f6a60; }
:root[data-theme="dark"] .modal::before { background: #2a3f37; }
:root[data-theme="dark"] .chip-bar::before { background: linear-gradient(to right, var(--bg), rgba(2,23,18,0)); }
:root[data-theme="dark"] .chip-bar::after { background: linear-gradient(to left, var(--bg), rgba(2,23,18,0)); }
:root[data-theme="dark"] .bottom-nav {
  background: rgba(2,23,18,.9); border-top-color: #163029;
  box-shadow: 0 -6px 24px rgba(0,0,0,.4);
}
:root[data-theme="dark"] .verdict.ok { background: #0c3a2b; border-color: #1c5a44; }
:root[data-theme="dark"] .verdict.warn { background: #3a2f12; border-color: #5a4a1c; }
:root[data-theme="dark"] .verdict.bad { background: #3a1c1c; border-color: #5a2a2a; }
:root[data-theme="dark"] .garden-note { background: #2e2912; border-color: #4a431c; color: #e6d79a; }
:root[data-theme="dark"] .tag.bio, :root[data-theme="dark"] .pill { background: #0e3a2a; color: #6fe0b4; }
:root[data-theme="dark"] .tag.mineral { background: #10324a; color: #8fd0f5; }
:root[data-theme="dark"] .tag.mixt { background: #3a3012; color: #ffcf8a; }
:root[data-theme="dark"] .tag.mecanic { background: #322b22; color: #d8b48a; }
:root[data-theme="dark"] .tag.chimic { background: #3a1c1c; color: #ffb0a8; }
:root[data-theme="dark"] .tag.organic { background: #2c3a16; color: #c6e08a; }
:root[data-theme="dark"] .pill.sev-mare { background: #3a1c1c; color: #ffb0a8; }
:root[data-theme="dark"] .pill.sev-medie { background: #3a3012; color: #ffcf8a; }
:root[data-theme="dark"] .pill.sev-mica { background: #0e3a2a; color: #6fe0b4; }
:root[data-theme="dark"] .nbar-mark { box-shadow: 0 0 0 2px var(--card); }
