@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Inter:wght@400;500;600;700&display=swap");

:root {
  --cream: #f6f1ea;
  --card: rgba(255, 247, 238, 0.86);
  --sage: #8fa46c;
  --sage-deep: #6f8156;
  --terracotta: #c47a5a;
  --blush: #dfae9e;
  --charcoal: #2b2826;
  --beige: #ead9c8;
  --shadow: 0 24px 70px rgba(72, 52, 38, 0.15);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", system-ui, sans-serif;
  color: var(--charcoal);
  background: var(--cream);
}
button, input, textarea { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }

.screen { min-height: 100vh; position: relative; overflow: hidden; }
.login-screen {
  display: grid;
  place-items: center;
  padding: 2rem;
  background-image: linear-gradient(rgba(246,241,234,.12), rgba(246,241,234,.16)), url("./assets/images/wellness-background.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.login-card {
  width: min(92vw, 28rem);
  padding: clamp(1.5rem, 5vw, 2.5rem);
  border: 1px solid rgba(255,255,255,.74);
  border-radius: 2rem;
  background: rgba(255, 247, 238, 0.86);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
  text-align: center;
}
.leaf-badge, .icon-circle {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 999px;
  background: rgba(143, 164, 108, .14);
  color: var(--sage-deep);
}
.leaf-badge { width: 4.25rem; height: 4.25rem; margin: 0 auto 1rem; box-shadow: inset 0 0 0 1px rgba(111,129,86,.16); }
.leaf-badge svg, .icon-circle svg { display: block; margin: auto; }
.brand-kicker { color: var(--sage-deep); font-size: .78rem; letter-spacing: .25em; font-weight: 700; text-transform: uppercase; }
.brand-title, .headline, .section-title {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 500;
  line-height: .98;
}
.brand-title { margin: .4rem 0 1rem; color: var(--terracotta); font-size: 1.85rem; font-style: italic; }
.headline { margin: 0; font-size: clamp(2.3rem, 6vw, 4.6rem); }
.section-title { margin: 0; font-size: clamp(1.85rem, 4vw, 3rem); }
.copy { color: rgba(43,40,38,.72); line-height: 1.55; }
.form { display: grid; gap: 1rem; margin-top: 1.35rem; }
.field { position: relative; }
.field svg { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: var(--sage-deep); }
.field input, textarea {
  width: 100%;
  border: 1px solid rgba(111,129,86,.22);
  border-radius: 1.15rem;
  background: rgba(255,255,255,.62);
  color: var(--charcoal);
  outline: none;
  transition: border .2s, box-shadow .2s, background .2s;
}
.field input { height: 3.35rem; padding: 0 3rem 0 3rem; }
textarea { min-height: 10rem; padding: 1rem; resize: vertical; }
.field input:focus, textarea:focus { border-color: rgba(196,122,90,.58); box-shadow: 0 0 0 4px rgba(196,122,90,.12); background: rgba(255,255,255,.8); }
.eye-button {
  position: absolute;
  right: .55rem;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  place-items: center;
  width: 2.35rem;
  height: 2.35rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: rgba(43,40,38,.54);
}
.primary-button, .secondary-button, .nav-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  border-radius: 999px;
  font-weight: 700;
  transition: transform .2s, box-shadow .2s, background .2s;
}
.primary-button {
  border: 0;
  padding: .98rem 1.35rem;
  color: #fffaf4;
  background: linear-gradient(135deg, var(--terracotta), #b96b4b);
  box-shadow: 0 14px 30px rgba(196,122,90,.27);
}
.primary-button:hover { transform: translateY(-1px); box-shadow: 0 18px 34px rgba(196,122,90,.32); }
.secondary-button, .nav-button {
  border: 1px solid rgba(111,129,86,.28);
  padding: .78rem 1rem;
  color: var(--sage-deep);
  background: rgba(255,247,238,.62);
}
.link-row { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-top: 1rem; color: var(--sage-deep); font-weight: 700; }
.link-row span { width: 1px; height: 1.25rem; background: rgba(43,40,38,.16); }

.app-shell {
  min-height: 100vh;
  padding: clamp(1rem, 3vw, 2.3rem);
  background:
    radial-gradient(ellipse at 8% 8%, rgba(143,164,108,.24), transparent 28rem),
    radial-gradient(ellipse at 90% 18%, rgba(223,174,158,.32), transparent 26rem),
    radial-gradient(ellipse at 12% 92%, rgba(196,122,90,.13), transparent 24rem),
    radial-gradient(ellipse at 82% 78%, rgba(143,164,108,.13), transparent 22rem),
    linear-gradient(135deg, #f6f1ea, #fff7ee);
  position: relative;
}
.app-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .28;
  background-image: radial-gradient(rgba(111,129,86,.18) 1px, transparent 1px);
  background-size: 14px 14px;
}
.app-shell::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .18;
  background:
    radial-gradient(ellipse at 5% 12%, rgba(43,40,38,.13), transparent 11rem),
    radial-gradient(ellipse at 0% 8%, rgba(111,129,86,.12), transparent 7rem),
    linear-gradient(120deg, transparent 0 62%, rgba(196,122,90,.1) 62% 64%, transparent 64%);
  filter: blur(1px);
}
.container { width: min(72rem, 100%); margin: 0 auto; position: relative; z-index: 1; }
.topbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .8rem;
  border: 1px solid rgba(255,255,255,.68);
  border-radius: 2rem;
  background: rgba(255,247,238,.78);
  box-shadow: 0 18px 52px rgba(72,52,38,.1);
  backdrop-filter: blur(15px);
}
.logo { display: flex; align-items: center; gap: .85rem; min-width: max-content; }
.logo .leaf-badge { width: 3rem; height: 3rem; margin: 0; }
.logo-text { font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.35rem; line-height: 1; }
.journey-greeting { margin: 0 0 .65rem; color: rgba(111,129,86,.95); font-size: 1rem; font-weight: 700; }
.nav { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: .5rem; margin-left: auto; }
.nav-button { min-height: 2.65rem; color: var(--sage-deep); background: rgba(143,164,108,.12); }
.nav-button.active { background: rgba(143,164,108,.18); box-shadow: inset 0 -2px 0 var(--sage-deep); }

.hero, .card {
  border: 1px solid rgba(255,255,255,.65);
  border-radius: 2rem;
  background: var(--card);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}
.hero { display: grid; grid-template-columns: 1.15fr .85fr; gap: 1.5rem; margin-top: 1.8rem; padding: clamp(1.5rem, 4vw, 3rem); overflow: hidden; }
.hero-art {
  min-height: 17rem;
  border-radius: 1.5rem;
  background:
    linear-gradient(120deg, rgba(255,247,238,.18), rgba(255,247,238,.78)),
    url("./assets/images/wellness-background.png");
  background-size: cover;
  background-position: center bottom;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.6);
}
.kicker { color: var(--sage-deep); font-size: .82rem; font-weight: 800; letter-spacing: .3em; text-transform: uppercase; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.4rem; }
.grid { display: grid; gap: 1.2rem; margin-top: 1.2rem; }
.two-col { grid-template-columns: 1.1fr .9fr; }
.card { padding: clamp(1.25rem, 3vw, 2rem); }
.section-heading { display: flex; align-items: center; gap: .7rem; margin-bottom: 1rem; }
.section-heading .icon-circle { width: 2.45rem; height: 2.45rem; }
.eyebrow { color: var(--sage-deep); font-size: .78rem; font-weight: 800; letter-spacing: .28em; text-transform: uppercase; }
.small { font-size: .92rem; }
.muted { color: rgba(43,40,38,.62); }
.greeting { margin: .5rem 0 1rem; color: var(--sage-deep); font-weight: 700; }
.pulse-list, .message-list, .milestone-list { display: grid; gap: .8rem; }
.encouragement-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .65rem;
  margin: 1rem 0;
}
.encouragement-form input,
.gratitude-form input,
.gratitude-form select,
.gratitude-form textarea,
.reminder-form select {
  min-width: 0;
  border: 1px solid rgba(111,129,86,.22);
  border-radius: 1rem;
  background: rgba(255,255,255,.55);
  color: var(--charcoal);
  padding: .85rem 1rem;
  outline: none;
}
.encouragement-form input { border-radius: 999px; }
.encouragement-form input:focus { border-color: rgba(196,122,90,.5); box-shadow: 0 0 0 4px rgba(196,122,90,.1); }
.gratitude-form {
  display: grid;
  gap: .7rem;
  margin: 1rem 0 .4rem;
}
.gratitude-form textarea { min-height: 7rem; }
.gratitude-form .secondary-button { justify-self: start; }
.reminder-center-section { margin-top: 1.2rem; }
.reminder-form {
  display: grid;
  gap: .75rem;
  margin-top: 1rem;
}
.reminder-form label {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .75rem .85rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.36);
  color: rgba(43,40,38,.72);
  font-weight: 600;
}
.reminder-form input { accent-color: var(--sage-deep); }
.reminder-form .secondary-button { justify-self: start; }
.milestone-card { margin-top: 1.2rem; }
.pulse-row, .message, .milestone, .feature {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: .8rem;
  padding: .78rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.42);
}
.pulse-row-soft { grid-template-columns: auto 1fr; }
.pulse-row-soft .small { margin: .45rem 0 0; }
.progress-track { height: .48rem; border-radius: 999px; background: rgba(234,217,200,.78); overflow: hidden; }
.progress-fill { height: 100%; border-radius: inherit; background: var(--sage-deep); }
.quote {
  margin: 1rem 0 0;
  padding: 1rem;
  border: 1px solid rgba(196,122,90,.18);
  border-radius: 1rem;
  background: rgba(255,247,238,.66);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.2rem;
  line-height: 1.3;
}
.tip { margin-top: .9rem; padding: .9rem; border-radius: 1rem; background: rgba(143,164,108,.12); color: rgba(43,40,38,.72); }
.daily-affirmation-section { margin-top: 2.4rem; }
.daily-affirmation-section .secondary-button { margin-top: 1rem; }
#affirmation-save-message { min-height: 1.25rem; margin: .65rem 0 0; color: var(--sage-deep); font-weight: 700; }
.focus-grid { display: grid; gap: .8rem; margin-top: 1rem; }
.focus-choice {
  display: grid;
  gap: .25rem;
  width: 100%;
  padding: 1rem;
  border: 1px solid rgba(111,129,86,.2);
  border-radius: 1rem;
  background: rgba(255,255,255,.42);
  color: rgba(43,40,38,.76);
  text-align: left;
}
.focus-choice strong { color: var(--sage-deep); }
.focus-choice span { font-size: .92rem; line-height: 1.45; }
.focus-choice { cursor: pointer; }
.focus-choice:hover { background: rgba(143,164,108,.12); }
.premium-tools { display: grid; gap: 1.2rem; margin: 1.2rem 0 3rem; }
.smart-goal-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin: 1rem 0;
}
.smart-goal-form input, .smart-goal-form select {
  min-width: 0;
  border: 1px solid rgba(111,129,86,.22);
  border-radius: 1rem;
  background: rgba(255,255,255,.55);
  color: var(--charcoal);
  padding: .85rem 1rem;
  outline: none;
}
.smart-goal-form button { grid-column: 1 / -1; }
.install-guide { margin-top: 1.2rem; }
.install-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.install-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  margin-top: 1rem;
}
.install-card {
  padding: 1rem;
  border: 1px solid rgba(111,129,86,.18);
  border-radius: 1rem;
  background: rgba(255,255,255,.38);
}
.install-card .book-icon { margin-bottom: .7rem; font-weight: 800; }
.install-card ol { margin: .65rem 0 0; padding-left: 1.15rem; color: rgba(43,40,38,.72); line-height: 1.55; }
.compact-card { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.book-icon {
  display: grid;
  place-items: center;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 1rem;
  background: rgba(143,164,108,.12);
  color: var(--sage-deep);
}
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 10;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(43,40,38,.28);
}
.modal { width: min(92vw, 34rem); }
.hidden { display: none !important; }

@media (max-width: 780px) {
  .login-screen { padding: 1rem; background-position: center; }
  .topbar { align-items: flex-start; flex-direction: column; border-radius: 1.4rem; }
  .logo { min-width: 0; }
  .nav { width: 100%; justify-content: stretch; display: grid; grid-template-columns: repeat(2, 1fr); }
  .nav-button { width: 100%; padding: .7rem .6rem; font-size: .88rem; }
  .hero, .two-col { grid-template-columns: 1fr; }
  .hero-art { min-height: 10rem; }
  .compact-card { align-items: flex-start; flex-direction: column; }
  .install-heading { flex-direction: column; }
  .install-grid { grid-template-columns: 1fr; }
  .smart-goal-form { grid-template-columns: 1fr; }
  .pulse-row, .message, .milestone, .feature { grid-template-columns: auto 1fr; }
  .encouragement-form { grid-template-columns: 1fr; }
}
