/* LetzterRegen.in — Design Tokens & Base Styles
   Ported from the design handover (documentation.md §5–§6, §10)
   Stage palettes live on [data-stage] overrides below.
*/

:root {
  --font-display: 'Syne', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, Menu, monospace;

  --bg-top: #0d2d33;
  --bg-bottom: #1a4b54;
  --bg-accent: #3ea57f;
  --fg: #f4faff;
  --fg-muted: rgba(244, 250, 255, 0.78);
  --fg-dim: rgba(244, 250, 255, 0.58);
  --card-bg: rgba(255, 255, 255, 0.08);
  --card-stroke: rgba(255, 255, 255, 0.18);
  --card-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
  --card-blur: 22px;

  --c-dry:         #e26a3b;
  --c-slightly-dry:#e8a34b;
  --c-normal:      #8fb893;
  --c-wet:         #6aa7c8;
  --c-very-wet:    #3d6fa3;

  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --r-sm: 8px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;

  --photo: none;
  --overlay-top: rgba(10, 20, 12, 0.20);
  --overlay-bot: rgba(10, 20, 12, 0.20);
}

/* ── Stage palettes ──────────────────────────────────────────────
   Day bounds per stage (7 stages total):
     0 = 0 days (raining today)      · stufe-0: stormy downpour
     1 = 1–5 days                    · stufe-1: wet green clover
     2 = 6–12 days                   · stufe-2: meadow with flowers
     3 = 13–25 days                  · stufe-3: yellowing grass
     4 = 26–56 days                  · stufe-4: brown dead grass
     5 = 57–89 days                  · stufe-6: deep cracks
     6 = 90+ days                    · stufe-7: bleached cracked earth
   --photo defaults to the 960px mobile variant; the desktop 1600px
   variant is activated via the @media override further down.
*/

[data-stage="0"] {
  --bg-top: #16212a; --bg-bottom: #0a1218;
  --bg-accent: #74c7e8; --fg: #eef4fb;
  --fg-muted: rgba(238, 244, 251, 0.82);
  --fg-dim: rgba(238, 244, 251, 0.6);
  --card-bg: rgba(255,255,255,0.10); --card-blur: 24px;
  --overlay-top: rgba(8, 14, 22, 0.22);
  --overlay-bot: rgba(8, 14, 22, 0.22);
  --photo: image-set(
    url('/assets/stages/stufe-0-960.avif') type('image/avif'),
    url('/assets/stages/stufe-0-960.jpg')  type('image/jpeg')
  );
}
[data-stage="1"] {
  --bg-top: #0f2a1b; --bg-bottom: #061b10;
  --bg-accent: #8ed9a4; --fg: #f4faf2;
  --fg-muted: rgba(244, 250, 242, 0.78);
  --fg-dim: rgba(244, 250, 242, 0.58);
  --card-bg: rgba(255,255,255,0.10); --card-blur: 22px;
  --overlay-top: rgba(10, 20, 12, 0.20);
  --overlay-bot: rgba(10, 20, 12, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-1-960.avif') type('image/avif'),
    url('/assets/stages/stufe-1-960.jpg')  type('image/jpeg')
  );
}
[data-stage="2"] {
  --bg-top: #1a3a22; --bg-bottom: #0c2014;
  --bg-accent: #b8d66a; --fg: #f3f7ec;
  --fg-muted: rgba(243, 247, 236, 0.78);
  --fg-dim: rgba(243, 247, 236, 0.58);
  --card-bg: rgba(255,255,255,0.12); --card-blur: 20px;
  --overlay-top: rgba(10, 22, 14, 0.20);
  --overlay-bot: rgba(10, 22, 14, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-2-960.avif') type('image/avif'),
    url('/assets/stages/stufe-2-960.jpg')  type('image/jpeg')
  );
}
[data-stage="3"] {
  --bg-top: #3a2a12; --bg-bottom: #1a1208;
  --bg-accent: #e6c868; --fg: #faf2e0;
  --fg-muted: rgba(250, 242, 224, 0.78);
  --fg-dim: rgba(250, 242, 224, 0.58);
  --card-bg: rgba(255,255,255,0.14); --card-blur: 18px;
  --overlay-top: rgba(30, 18, 8, 0.20);
  --overlay-bot: rgba(30, 18, 8, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-3-960.avif') type('image/avif'),
    url('/assets/stages/stufe-3-960.jpg')  type('image/jpeg')
  );
}
[data-stage="4"] {
  --bg-top: #34200c; --bg-bottom: #180c04;
  --bg-accent: #d89a4e; --fg: #fbecd2;
  --fg-muted: rgba(251, 236, 210, 0.78);
  --fg-dim: rgba(251, 236, 210, 0.58);
  --card-bg: rgba(255,255,255,0.14); --card-blur: 16px;
  --overlay-top: rgba(28, 15, 6, 0.20);
  --overlay-bot: rgba(28, 15, 6, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-4-960.avif') type('image/avif'),
    url('/assets/stages/stufe-4-960.jpg')  type('image/jpeg')
  );
}
[data-stage="5"] {
  --bg-top: #231308; --bg-bottom: #0a0502;
  --bg-accent: #ff7a3c; --fg: #ffe4c8;
  --fg-muted: rgba(255, 228, 200, 0.78);
  --fg-dim: rgba(255, 228, 200, 0.58);
  --card-bg: rgba(255,255,255,0.14); --card-blur: 12px;
  --overlay-top: rgba(18, 10, 4, 0.20);
  --overlay-bot: rgba(18, 10, 4, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-6-960.avif') type('image/avif'),
    url('/assets/stages/stufe-6-960.jpg')  type('image/jpeg')
  );
}
[data-stage="6"] {
  --bg-top: #1a0e06; --bg-bottom: #050201;
  --bg-accent: #ff9050; --fg: #ffdcb8;
  --fg-muted: rgba(255, 220, 184, 0.78);
  --fg-dim: rgba(255, 220, 184, 0.58);
  --card-bg: rgba(255,255,255,0.12); --card-blur: 10px;
  --overlay-top: rgba(14, 8, 3, 0.20);
  --overlay-bot: rgba(14, 8, 3, 0.20);
  --photo: image-set(
    url('/assets/stages/stufe-7-960.avif') type('image/avif'),
    url('/assets/stages/stufe-7-960.jpg')  type('image/jpeg')
  );
}

/* Desktop/tablet: swap in the 1600px variants. */
@media (min-width: 768px) {
  [data-stage="0"] { --photo: image-set(
      url('/assets/stages/stufe-0-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-0-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="1"] { --photo: image-set(
      url('/assets/stages/stufe-1-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-1-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="2"] { --photo: image-set(
      url('/assets/stages/stufe-2-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-2-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="3"] { --photo: image-set(
      url('/assets/stages/stufe-3-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-3-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="4"] { --photo: image-set(
      url('/assets/stages/stufe-4-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-4-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="5"] { --photo: image-set(
      url('/assets/stages/stufe-6-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-6-1600.jpg')  type('image/jpeg')
    ); }
  [data-stage="6"] { --photo: image-set(
      url('/assets/stages/stufe-7-1600.avif') type('image/avif'),
      url('/assets/stages/stufe-7-1600.jpg')  type('image/jpeg')
    ); }
}

/* ── Base ────────────────────────────────────────────────────────── */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  background: var(--bg-bottom);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  overflow-x: hidden;
}

body {
  position: relative;
  background-image:
    linear-gradient(180deg, var(--overlay-top) 0%, var(--overlay-bot) 100%),
    var(--photo),
    linear-gradient(180deg, var(--bg-top) 0%, var(--bg-bottom) 100%);
  background-size: cover, cover, auto;
  background-position: center center, center center, center;
  background-attachment: fixed, fixed, fixed;
  background-repeat: no-repeat;
  min-height: 100vh;
}

a { color: inherit; }

::selection { background: var(--bg-accent); color: var(--bg-bottom); }

/* ── Typography primitives ───────────────────────────────────────── */

.lr-display {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg);
}

.lr-body { font-family: var(--font-body); color: var(--fg); }

.lr-mono {
  font-family: var(--font-mono);
  font-feature-settings: 'tnum';
  font-variant-numeric: tabular-nums;
}

.lr-label {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-dim);
}

h1, h2, h3 {
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: 100%;
}

/* ── Card (glassmorphism) ────────────────────────────────────────── */

.lr-card {
  position: relative;
  background: var(--card-bg);
  border: 1px solid var(--card-stroke);
  border-radius: var(--r-lg);
  backdrop-filter: blur(var(--card-blur)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--card-blur)) saturate(140%);
  box-shadow: var(--card-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.12);
  color: var(--fg);
  overflow: hidden;
  box-sizing: border-box;
  max-width: 100%;
}
.lr-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(140deg, rgba(255,255,255,.06) 0%, transparent 45%);
  pointer-events: none;
}
.lr-card > * { position: relative; }

/* ── Input (pill) ────────────────────────────────────────────────── */

.lr-input {
  width: 100%;
  background: rgba(255,255,255,0.1);
  border: 1px solid var(--card-stroke);
  border-radius: 999px;
  padding: 18px 26px;
  font-family: var(--font-body);
  font-size: 18px;
  color: var(--fg);
  outline: none;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background .2s, border-color .2s;
  box-sizing: border-box;
  max-width: 100%;
}
.lr-input::placeholder { color: var(--fg-dim); }
.lr-input:focus {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.38);
}

.lr-btn {
  border: none;
  padding: 0 26px;
  height: 100%;
  min-height: 52px;
  border-radius: 999px;
  background: var(--fg);
  color: var(--bg-bottom);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  letter-spacing: -0.01em;
}
.lr-btn:hover { filter: brightness(1.05); }

/* ── Header ──────────────────────────────────────────────────────── */

.lr-header {
  padding: 22px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.lr-brand {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.01em;
  text-decoration: none;
}
.lr-brand span { opacity: .55; }

/* ── Start page ──────────────────────────────────────────────────── */

.lr-start {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.lr-start-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 48px 24px;
  text-align: center;
}
.lr-start-kicker { margin-bottom: 22px; }
.lr-start-title {
  font-family: var(--font-display);
  font-size: clamp(40px, 9vw, 112px);
  line-height: 1.02;
  margin: 0;
  max-width: 1100px;
  font-weight: 700;
  letter-spacing: -0.045em;
  text-wrap: balance;
  min-width: 0;
}
.lr-start-title .lr-inline-input {
  display: inline-block;
  background: transparent;
  border: none;
  border-bottom: 0.08em solid currentColor;
  padding: 0 0.1em;
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
  text-align: center;
  outline: none;
  min-width: 4ch;
  width: min(10ch, 100%);
  max-width: 100%;
  box-sizing: border-box;
  transition: width .2s;
}
.lr-start-title .lr-inline-input::placeholder {
  color: var(--fg-muted);
  opacity: .85;
  transition: opacity .26s;
}
.lr-start-title .lr-inline-input.is-fading::placeholder { opacity: 0; }

.lr-start-sub {
  margin: 24px auto 0 auto;
  font-size: clamp(14px, 1.8vw, 18px);
  color: var(--fg-muted);
  max-width: 620px;
}

.lr-start-form {
  margin: clamp(32px, 5vw, 48px) auto 0 auto;
  width: 100%;
  max-width: 640px;
  position: relative;
}
.lr-start-form .lr-input {
  padding-right: 160px;
  font-size: clamp(15px, 1.7vw, 19px);
}
.lr-start-form .lr-btn {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
}

.lr-start-info {
  margin-top: clamp(40px, 6vw, 60px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(24px, 4vw, 48px);
  font-size: 13px;
  color: var(--fg-muted);
  text-align: left;
  max-width: 780px;
  width: 100%;
}
.lr-start-info .lr-label { font-size: 10px; margin-bottom: 6px; }
.lr-start-info p { margin: 0; line-height: 1.5; }

/* ── Location page ───────────────────────────────────────────────── */

.lr-location {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.lr-location-main {
  flex: 1;
  padding: clamp(24px, 5vw, 48px) clamp(20px, 5vw, 64px) clamp(60px, 10vw, 120px);
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

/* Loading state */
.lr-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 60vh;
  gap: 16px;
}
.lr-loading-pulse {
  position: relative;
  width: 120px;
  height: 120px;
  margin-bottom: 32px;
}
.lr-loading-pulse span {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1.5px solid var(--fg);
  animation: lr-pulse 2.4s cubic-bezier(.2,.7,.4,1) infinite;
}
.lr-loading-pulse span:nth-child(2) { animation-delay: .8s; }
.lr-loading-pulse span:nth-child(3) { animation-delay: 1.6s; }
.lr-loading-pulse::after {
  content: "";
  position: absolute;
  inset: 40%;
  border-radius: 50%;
  background: var(--fg);
  opacity: .9;
}
@keyframes lr-pulse {
  0% { transform: scale(.3); opacity: 1; }
  100% { transform: scale(1.5); opacity: 0; }
}
.lr-loading-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 7vw, 72px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  margin: 0;
}
.lr-loading-status {
  font-size: 16px;
  color: var(--fg-muted);
  margin-top: 4px;
}

/* Hero block */
.lr-hero-kicker { margin-bottom: 14px; }
.lr-hero-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin: 0 0 6px;
  flex-wrap: wrap;
}
.lr-hero-head > .lr-hero-title {
  flex: 1 1 auto;
  min-width: 0;
}
.lr-hero-title {
  font-family: var(--font-display);
  font-size: clamp(40px, 7vw, 72px);
  line-height: 1.0;
  margin: 0 0 6px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.lr-hero-head > .lr-hero-title { margin: 0; }

.lr-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border: 1px solid var(--card-stroke);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 999px;
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background .2s, border-color .2s, transform .1s;
  white-space: nowrap;
  flex-shrink: 0;
  margin-bottom: 0.35em;
}
.lr-share-btn:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.38);
}
.lr-share-btn:active { transform: scale(0.97); }
.lr-share-btn.is-copied {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.5);
}
.lr-share-icon { flex-shrink: 0; }

.lr-hero-meta {
  color: var(--fg-muted);
  font-size: 15px;
  margin-bottom: clamp(24px, 5vw, 40px);
}

.lr-hero-card {
  padding: clamp(28px, 5vw, 48px) clamp(22px, 5vw, 52px);
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(24px, 4vw, 48px);
  align-items: center;
}
.lr-hero-number {
  font-family: var(--font-display);
  font-size: clamp(80px, 18vw, 180px);
  line-height: 1.02;
  font-weight: 600;
  letter-spacing: -0.06em;
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: baseline;
  gap: 16px;
  flex-wrap: wrap;
  min-width: 0;
  max-width: 100%;
  padding-bottom: 0.05em;
}
.lr-hero-number .lr-unit {
  font-family: var(--font-body);
  font-size: clamp(22px, 3vw, 38px);
  font-weight: 500;
  opacity: .7;
  letter-spacing: normal;
  font-stretch: normal;
}
.lr-hero-detail {
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-left: 1px solid var(--card-stroke);
  padding-left: clamp(16px, 3vw, 40px);
  min-width: 0;
}
.lr-hero-detail .lr-label { font-size: 10px; margin-bottom: 4px; }
.lr-hero-detail-value {
  font-family: var(--font-display);
  font-size: clamp(18px, 2.3vw, 26px);
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.4;
  padding-bottom: 0.1em;
}
.lr-hero-foot {
  font-size: 12px;
  color: var(--fg-dim);
  margin-top: 14px;
  padding-left: 4px;
}

/* Balance block */
.lr-section { margin-bottom: clamp(28px, 4vw, 40px); }
.lr-section > .lr-label { margin-bottom: 14px; display: block; }

.lr-balance-card {
  padding: clamp(24px, 4vw, 36px) clamp(22px, 4vw, 48px);
}
.lr-balance-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr 1.1fr;
  gap: clamp(24px, 3vw, 40px);
}
.lr-balance-total {
  padding-right: 24px;
  border-right: 1px solid var(--card-stroke);
  min-width: 0;
}
.lr-balance-total .lr-label,
.lr-balance-compare .lr-label { font-size: 10px; margin-bottom: 8px; }
.lr-balance-number {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 64px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
}
.lr-balance-number small {
  font-size: clamp(16px, 2vw, 24px);
  opacity: .65;
  margin-left: 6px;
  font-weight: 500;
}
.lr-balance-compare { min-width: 0; }
.lr-compare-headline {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.lr-compare-pct {
  font-family: var(--font-display);
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
}
.lr-compare-badge {
  font-size: 13px;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
.lr-compare-meta {
  font-size: 12px;
  color: var(--fg-muted);
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.lr-compare-meta strong { color: var(--fg); font-weight: 600; }

/* Monthly table */
.lr-month-card { padding: clamp(20px, 3vw, 28px) clamp(16px, 3vw, 40px); }
.lr-month-head,
.lr-month-row {
  display: grid;
  grid-template-columns: 140px 80px minmax(0, 1fr) 80px 80px;
  gap: 14px;
  align-items: center;
}
.lr-month-head {
  padding-bottom: 10px;
  margin-bottom: 6px;
  border-bottom: 1px solid var(--card-stroke);
  font-size: 11px;
  color: var(--fg-dim);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.lr-month-row {
  padding: 10px 0;
  border-bottom: 1px dashed var(--card-stroke);
}
.lr-month-row:last-child { border-bottom: none; }
.lr-month-row .lr-month-name {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 500;
}
.lr-month-row .lr-month-name small {
  color: var(--fg-dim);
  font-size: 13px;
  font-weight: 400;
  margin-left: 2px;
}
.lr-month-row .lr-mono { font-size: 15px; font-weight: 500; }
.lr-month-row .lr-right { text-align: right; }
.lr-month-row .lr-center { text-align: center; }
.lr-bar {
  position: relative;
  height: 22px;
}
.lr-bar .track {
  position: absolute; inset: 0;
  background: rgba(255,255,255,.06);
  border-radius: 4px;
}
.lr-bar .center {
  position: absolute; top: 0; bottom: 0;
  left: 50%; width: 1px;
  background: var(--fg-dim);
}
.lr-bar .fill {
  position: absolute; top: 2px; bottom: 2px;
  border-radius: 3px;
}

/* Footer */
.lr-footer {
  margin-top: clamp(16px, 3vw, 24px);
}
.lr-footer-meta {
  font-size: 12px;
  color: var(--fg-muted);
  margin-bottom: 18px;
  padding-left: 4px;
}
.lr-footer-meta strong { color: var(--fg); font-weight: 600; }
.lr-footer-card {
  padding: 18px 22px;
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}
.lr-footer-card .lr-label { font-size: 11px; flex-shrink: 0; }
.lr-footer-form {
  position: relative;
  flex: 1 1 220px;
  min-width: 0;
}
.lr-footer-form .lr-input {
  width: 100%;
  padding: 12px 60px 12px 20px;
  font-size: 15px;
}
.lr-footer-form .lr-btn {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  min-height: 0;
  padding: 0 18px;
  font-size: 16px;
  line-height: 1;
}
.lr-footer-back {
  display: inline-block;
  margin-top: 14px;
  padding-left: 4px;
  font-size: 13px;
  color: var(--fg-muted);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.lr-error {
  padding: clamp(32px, 5vw, 48px);
  text-align: center;
}
.lr-error h1 {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.is-hidden { display: none !important; }

/* ── Semantic comparison colors (classify in JS picks via data-class) */

.cls-dry          { color: var(--c-dry); }
.cls-slightly-dry { color: var(--c-slightly-dry); }
.cls-normal       { color: var(--c-normal); }
.cls-wet          { color: var(--c-wet); }
.cls-very-wet     { color: var(--c-very-wet); }

.badge-dry          { background: rgba(226,106,59,.15);  border: 1px solid rgba(226,106,59,.4);  color: var(--c-dry); }
.badge-slightly-dry { background: rgba(232,163,75,.15);  border: 1px solid rgba(232,163,75,.4);  color: var(--c-slightly-dry); }
.badge-normal       { background: rgba(143,184,147,.18); border: 1px solid rgba(143,184,147,.45);color: var(--c-normal); }
.badge-wet          { background: rgba(106,167,200,.18); border: 1px solid rgba(106,167,200,.45);color: var(--c-wet); }
.badge-very-wet     { background: rgba(61,111,163,.22);  border: 1px solid rgba(61,111,163,.55); color: var(--c-very-wet); }

/* ── Mobile (§10) ────────────────────────────────────────────────── */

@media (max-width: 680px) {
  .lr-header { padding: 18px 20px; }

  .lr-start-main { padding: 40px 20px; }

  .lr-start-form .lr-input { padding: 14px 100px 14px 20px; font-size: 15px; }
  .lr-start-form .lr-btn { padding: 0 16px; font-size: 13px; }

  .lr-location-main { padding: 20px 16px 60px; }

  .lr-hero-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .lr-share-btn { margin-bottom: 0; }

  .lr-hero-card { grid-template-columns: 1fr; padding: 22px; gap: 20px; }
  .lr-hero-detail {
    border-left: none;
    border-top: 1px solid var(--card-stroke);
    padding-left: 0;
    padding-top: 20px;
  }
  .lr-hero-number .lr-unit { font-size: 20px; }

  .lr-balance-grid { grid-template-columns: 1fr; gap: 24px; }
  .lr-balance-total {
    padding-right: 0;
    border-right: none;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--card-stroke);
  }

  .lr-month-head { display: none; }
  .lr-month-row {
    grid-template-columns: 1fr auto auto;
    grid-template-areas:
      "name mm pct"
      "bar  bar bar";
    column-gap: 12px;
    row-gap: 8px;
    font-size: 13px;
    padding: 12px 0;
  }
  .lr-month-row > :nth-child(1) { grid-area: name; }
  .lr-month-row > :nth-child(2) { grid-area: mm; }
  .lr-month-row > :nth-child(3) { grid-area: bar; }
  .lr-month-row > :nth-child(5) { grid-area: pct; }
  .lr-month-row .lr-month-name { font-size: 15px; }
  .lr-month-row .lr-mono { font-size: 13px; }
  .lr-month-row .pct-6190 { display: none; }
  .lr-bar { height: 12px; }

  .lr-footer-card { padding: 14px 16px; gap: 10px; }
  .lr-footer-card .lr-label { width: 100%; }
  .lr-footer-form { flex-basis: 100%; }
  .lr-footer-form .lr-input { padding: 10px 56px 10px 18px; font-size: 14px; }
  .lr-footer-form .lr-btn { padding: 0 14px; font-size: 15px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
  }
}
