:root {
  --bg: #F5EDE0;
  --bg-soft: #F8F1E5;
  --bg-deep: #EBDCC6;
  --card: rgba(255, 255, 255, 0.78);
  --terra: #C76A52;
  --terra-soft: #E9A892;
  --sage: #6B7F5C;
  --sage-soft: #B8C5A6;
  --sage-bg: rgba(184, 197, 166, 0.22);
  --mustard: #E8A24B;
  --mustard-soft: #F2C77A;
  --text: #4A3528;
  --text-soft: #8B6B5C;
  --border: rgba(107, 127, 92, 0.18);
  --shadow: 0 4px 16px rgba(74, 53, 40, 0.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  background: radial-gradient(ellipse at top, #F5DDC8 0%, #F5EDE0 50%, #EBDCC6 100%) fixed;
  color: var(--text);
  min-height: 100vh;
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

.hidden { display: none !important; }

.muted { color: var(--text-soft); font-size: 13px; line-height: 1.4; }
.err { color: var(--terra); font-size: 13px; margin-top: 8px; min-height: 18px; }
.center { text-align: center; }

input, select, button {
  font: inherit; color: inherit;
}
input[type="date"], input[type="text"], input[type="password"], input[type="time"], input[type="number"], select {
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--border);
  padding: 12px 14px;
  border-radius: 12px;
  outline: none;
  width: 100%;
  transition: border-color .15s;
}
input:focus, select:focus { border-color: var(--sage); }
.num { max-width: 90px; }
button {
  cursor: pointer;
  border: none;
  border-radius: 12px;
  padding: 12px 18px;
  font-weight: 600;
  transition: transform .12s, opacity .12s;
}
button:active { transform: scale(0.96); }
button.primary {
  background: var(--sage); color: white;
}
button.primary:hover { opacity: 0.92; }
button.ghost {
  background: transparent; color: var(--text-soft);
  border: 1px solid var(--border);
}

/* GATE */
.gate {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: radial-gradient(ellipse at top, #F5DDC8 0%, #F5EDE0 50%, #EBDCC6 100%);
  z-index: 100;
}
.gate-card {
  max-width: 380px; width: 100%;
  background: var(--card);
  border-radius: 24px;
  padding: 36px 28px;
  text-align: center;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.gate-leaf { font-size: 56px; margin-bottom: 8px; }
.gate-card h1 { font-family: Georgia, serif; font-size: 28px; color: var(--sage); margin-bottom: 8px; }
.gate-card p { margin-bottom: 16px; }
.gate-card input { margin-bottom: 12px; text-align: center; }
.gate-card button { width: 100%; font-size: 18px; }

/* APP */
#app {
  max-width: 640px;
  margin: 0 auto;
  padding: 16px 16px 100px;
}

.header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 6px 16px;
}
.brand { display: flex; align-items: center; gap: 8px; }
.brand-icon { font-size: 26px; }
.brand-name { font-family: Georgia, serif; font-size: 22px; color: var(--sage); font-weight: 700; }
.tabs { display: flex; gap: 6px; }
.tabs .tab {
  background: rgba(255,255,255,0.5);
  border: 1px solid var(--border);
  padding: 8px 12px;
  font-size: 18px;
  border-radius: 12px;
  color: var(--text-soft);
}
.tabs .tab.active { background: var(--sage); color: white; border-color: var(--sage); }

.tab-panel { display: none; animation: fade .2s ease; }
.tab-panel.active { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.today-header {
  margin-bottom: 18px;
  padding: 4px 4px;
}
.date {
  font-family: Georgia, serif;
  font-size: 22px;
  color: var(--terra);
  font-weight: 700;
  text-transform: capitalize;
}
.summary { color: var(--text-soft); font-style: italic; margin-top: 4px; font-size: 14px; }

.progress-card {
  background: var(--card);
  border-radius: 18px;
  padding: 16px 18px;
  margin-bottom: 20px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.prog-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.prog-label { color: var(--sage); font-weight: 700; font-size: 14px; letter-spacing: 0.5px; }
.prog-counter { color: var(--terra); font-weight: 700; font-size: 14px; }
.prog-bar {
  height: 10px;
  background: var(--sage-bg);
  border-radius: 5px;
  overflow: hidden;
}
#prog-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--sage-soft), var(--sage));
  border-radius: 5px;
  transition: width .35s ease;
}
.prog-meta {
  display: flex; justify-content: space-between;
  margin-top: 12px;
  font-size: 12px;
  color: var(--text-soft);
}
.prog-meta b { color: var(--text); font-weight: 700; }

.task-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }

.task {
  display: flex; align-items: flex-start; gap: 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px 16px;
  transition: background .2s, transform .12s;
  cursor: pointer;
}
.task:hover { background: rgba(255,255,255,0.92); }
.task:active { transform: scale(0.99); }
.task.done { background: var(--sage-bg); }
.task.done .task-label { text-decoration: line-through; color: var(--text-soft); }
.task.info { cursor: default; }
.task.info:hover { background: var(--card); }
.task.info::before { display: none; }

.task-check {
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 2px solid var(--sage-soft);
  background: transparent;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  color: white;
  transition: background .2s, border-color .2s;
  margin-top: 2px;
}
.task.done .task-check {
  background: var(--sage);
  border-color: var(--sage);
}
.task.done .task-check::after { content: "✓"; }
.task.info .task-check {
  border-color: transparent;
  background: transparent;
  color: var(--text-soft);
}
.task.info .task-check::after { content: "•"; font-size: 22px; line-height: 1; color: var(--text-soft); }

.task-body { flex: 1; }
.task-label { font-size: 15px; line-height: 1.4; color: var(--text); }
.task-meta { font-size: 11px; color: var(--text-soft); margin-top: 4px; }
.task-meta .plant-badge {
  display: inline-block;
  background: rgba(107, 127, 92, 0.15);
  color: var(--sage);
  padding: 1px 7px; border-radius: 8px;
  font-weight: 700;
}

.bonus-wrap { margin-top: 24px; }
.bonus-label {
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--mustard); font-weight: 700;
  margin-bottom: 8px;
  padding-left: 4px;
}
.bonus-list .task { border-style: dashed; }
.bonus-list .task .task-check { border-color: var(--mustard-soft); }
.bonus-list .task.done .task-check { background: var(--mustard); border-color: var(--mustard); }
.task-meta .plant-badge.bonus-badge {
  background: rgba(232, 162, 75, 0.22);
  color: var(--mustard);
}

/* PLAN — 3-day & month */
.plan-section { margin-bottom: 22px; }
.section-label {
  font-size: 11px; letter-spacing: 2.5px;
  color: var(--sage); font-weight: 700;
  margin: 8px 4px 10px;
  display: flex; align-items: center; justify-content: space-between;
}
.section-label .mini { font-size: 16px; padding: 4px 10px; border-radius: 8px; }
.threeday-strip {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}
.day-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 8px 12px;
  cursor: pointer;
  transition: transform .12s, background .2s;
  font-size: 12px;
  text-align: center;
}
.day-card:hover { background: rgba(255,255,255,0.95); }
.day-card:active { transform: scale(0.98); }
.day-card.today { border-color: var(--terra); border-width: 2px; }
.day-card .day-dow { font-size: 10px; letter-spacing: 1.5px; color: var(--text-soft); text-transform: uppercase; }
.day-card .day-num {
  font-family: Georgia, serif;
  font-size: 26px; font-weight: 800;
  color: var(--sage);
  margin: 2px 0 0;
  line-height: 1;
}
.day-card .day-mon {
  font-size: 9px; color: var(--text-soft);
  letter-spacing: 1.2px; text-transform: uppercase;
}
.day-card .day-flags {
  display: flex; gap: 3px; justify-content: center;
  margin-top: 8px;
  flex-wrap: wrap;
}
.day-card .day-flags span { font-size: 13px; line-height: 1; }
.day-card .day-summary {
  font-size: 11px;
  color: var(--text-soft);
  margin-top: 6px;
  line-height: 1.3;
  font-style: italic;
}
.day-card .day-progress {
  margin-top: 8px;
  height: 4px;
  background: var(--sage-bg);
  border-radius: 2px;
  overflow: hidden;
}
.day-card .day-progress > div {
  height: 100%;
  background: var(--sage);
  transition: width .3s;
}

/* Month grid */
.month-legend {
  display: flex; flex-wrap: wrap;
  gap: 10px 14px;
  font-size: 11px; color: var(--text-soft);
  margin-bottom: 10px;
  justify-content: center;
}
.month-legend i.dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}
.dot.d-transfusion { background: var(--terra); }
.dot.d-period { background: #C24876; }
.dot.d-ovulation { background: #7BB3D6; }
.dot.d-fertile { background: #B8D5A6; }
.dot.d-pms { background: #8B7CA9; }
.dot.d-kamp { background: var(--mustard); }
.dot.d-holiday { background: var(--sage-soft); }

.month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  background: var(--card);
  padding: 8px;
  border-radius: 14px;
  border: 1px solid var(--border);
}
.month-grid .mhead {
  font-size: 10px; color: var(--text-soft);
  text-align: center; font-weight: 700;
  padding: 4px 0;
  letter-spacing: 0.5px;
}
.mcell {
  aspect-ratio: 1;
  border-radius: 10px;
  background: rgba(255,255,255,0.5);
  border: 1px solid transparent;
  padding: 4px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: space-between;
  cursor: pointer;
  font-size: 13px;
  position: relative;
  min-height: 42px;
  transition: background .15s, transform .1s;
}
.mcell.empty { background: transparent; cursor: default; }
.mcell:hover:not(.empty) { background: rgba(255,255,255,0.85); }
.mcell:active:not(.empty) { transform: scale(0.95); }
.mcell.today { border-color: var(--terra); border-width: 2px; font-weight: 800; color: var(--terra); }
.mcell.work { background: rgba(232, 162, 75, 0.10); }
.mcell.transfusion { background: rgba(199, 106, 82, 0.16); color: var(--terra); }
.mcell.kamp { background: rgba(232, 162, 75, 0.30); }
.mcell.holiday { background: rgba(184, 197, 166, 0.25); }
.mcell .mnum { font-weight: 600; }
.mcell .mflags {
  display: flex; gap: 2px;
}
.mcell .mflags i {
  width: 5px; height: 5px;
  border-radius: 50%;
  display: block;
}

/* Day modal (plan tab) */
.day-modal-h {
  font-family: Georgia, serif;
  font-size: 22px; color: var(--terra);
  margin-bottom: 4px;
  text-transform: capitalize;
}
.day-modal-sum { color: var(--text-soft); font-style: italic; margin-bottom: 12px; font-size: 13px; }
.day-modal-list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.day-modal-list li {
  background: var(--sage-bg);
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 13px;
}

/* GARDEN */
.panel-h {
  font-family: Georgia, serif;
  font-size: 24px;
  color: var(--sage);
  margin: 4px 4px 14px;
}
.garden-stats {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 16px;
  margin-bottom: 14px;
  display: flex;
  justify-content: space-around;
  text-align: center;
  font-size: 13px;
  color: var(--text-soft);
}
.garden-stats b { display: block; color: var(--sage); font-size: 18px; }

.garden-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.plant-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 12px 8px 10px;
  text-align: center;
  cursor: pointer;
  transition: transform .15s, background .2s;
}
.plant-card:hover { background: rgba(255,255,255,0.92); }
.plant-card:active { transform: scale(0.97); }
.plant-card.locked {
  opacity: 0.45;
  filter: grayscale(0.7);
  cursor: default;
}
.plant-card .pcard-img {
  width: 100%;
  aspect-ratio: 1;
  background-size: cover; background-position: center;
  border-radius: 12px;
  margin-bottom: 6px;
  background-color: var(--sage-bg);
  display: flex; align-items: center; justify-content: center;
  font-size: 38px;
}
.plant-card.locked .pcard-img::after { content: "🔒"; font-size: 22px; }
.plant-card .pcard-name { font-size: 12px; color: var(--text); font-weight: 600; line-height: 1.2; }
.plant-card .pcard-rarity { font-size: 10px; color: var(--text-soft); margin-top: 2px; }
.rarity-rare { color: var(--mustard) !important; font-weight: 700; }
.rarity-epic { color: var(--terra) !important; font-weight: 700; }
.rarity-mythic { color: #8b5cf6 !important; font-weight: 700; }

/* SETTINGS */
.set-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  margin-bottom: 14px;
}
.set-card h3 { font-family: Georgia, serif; font-size: 17px; color: var(--sage); margin-bottom: 6px; }
.set-card .row { display: flex; gap: 8px; margin-top: 10px; align-items: center; }
.set-card .row.col { flex-direction: column; align-items: stretch; }
.set-card .row.col .row { margin-top: 0; }
.set-list { list-style: none; margin-top: 10px; }
.set-list li {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 10px;
  background: rgba(255,255,255,0.5);
  border-radius: 10px; margin-bottom: 6px;
  font-size: 14px;
}
.set-list li .del { font-size: 12px; color: var(--terra); cursor: pointer; padding: 4px 8px; background: rgba(199,106,82,0.1); border-radius: 8px; border: none; }
.upcoming { margin-top: 12px; font-size: 13px; color: var(--text-soft); display: flex; flex-wrap: wrap; gap: 6px; }
.upcoming .chip { background: rgba(199,106,82,0.15); color: var(--terra); padding: 3px 10px; border-radius: 10px; font-weight: 600; }

/* CELEBRATE */
.celebrate {
  position: fixed; inset: 0;
  background: rgba(74, 53, 40, 0.6);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  z-index: 200;
  animation: fade .2s;
}
.celebrate-inner {
  background: var(--bg-soft);
  border-radius: 24px;
  padding: 32px 28px;
  text-align: center;
  max-width: 320px;
  border: 2px solid var(--sage-soft);
  position: relative;
  overflow: hidden;
}
.celebrate-burst {
  font-size: 60px;
  animation: pop .6s ease;
}
@keyframes pop {
  0% { transform: scale(0.3); opacity: 0; }
  50% { transform: scale(1.3); }
  100% { transform: scale(1); opacity: 1; }
}
.celebrate-plant {
  width: 140px; height: 140px;
  margin: 12px auto;
  background-size: cover; background-position: center;
  border-radius: 24px;
  background-color: var(--sage-bg);
}
.celebrate-inner h2 { font-family: Georgia, serif; color: var(--terra); font-size: 24px; }
.celebrate-inner p { color: var(--text); font-style: italic; margin: 6px 0 18px; }

/* PLANT MODAL */
.modal {
  position: fixed; inset: 0;
  background: rgba(74, 53, 40, 0.55);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  z-index: 150;
}
.modal-card {
  background: var(--bg-soft);
  border-radius: 22px;
  padding: 24px;
  max-width: 380px; width: 100%;
  max-height: 88vh; overflow-y: auto;
  position: relative;
  border: 1px solid var(--border);
}
.modal-close {
  position: absolute; top: 12px; right: 12px;
  background: none; color: var(--text-soft);
  padding: 6px 10px; border-radius: 999px;
}
.modal-plant-img {
  width: 100%; aspect-ratio: 1;
  border-radius: 18px;
  background-color: var(--sage-bg);
  background-size: cover; background-position: center;
  margin-bottom: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 64px;
}
.modal h3 { font-family: Georgia, serif; color: var(--sage); font-size: 22px; margin-bottom: 4px; }
.modal .modal-fam { color: var(--text-soft); font-style: italic; margin-bottom: 14px; font-size: 13px; }
.modal .care-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 12px; }
.modal .care-cell {
  background: var(--sage-bg);
  border-radius: 12px;
  padding: 10px;
  font-size: 12px;
}
.modal .care-cell b { display: block; color: var(--sage); margin-bottom: 2px; font-size: 11px; letter-spacing: 0.5px; text-transform: uppercase; }
.modal .fun-fact {
  margin-top: 14px;
  background: rgba(232, 162, 75, 0.2);
  padding: 12px 14px; border-radius: 12px;
  font-size: 13px; line-height: 1.45;
  color: var(--text);
  font-style: italic;
}
.modal .fun-fact::before { content: "✨ "; }

/* Bottom nav (mobile feel) */
@media (max-width: 480px) {
  #app { padding: 12px 12px 80px; }
  .garden-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}
