:root {
  --sand: #F5F2EC;
  --sand-dark: #EAE5DB;
  --ink: #1C1B18;
  --ink-mid: #3D3B35;
  --ink-muted: #7A786F;
  --ink-faint: #B5B2A8;
  --border: rgba(28,27,24,0.12);
  --border-mid: rgba(28,27,24,0.22);
  --accent: #2B5F3E;
  --accent-light: #EBF4EF;
  --c1: #1a4a6b; --c1-bg: #EBF3FA;
  --c2: #2d5a27; --c2-bg: #EAF3E6;
  --c3: #7a4a0a; --c3-bg: #FBF1E2;
  --c4: #6b2c4a; --c4-bg: #F7EBF2;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'DM Sans', system-ui, sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--sans); background: var(--sand); color: var(--ink); font-size: 15px; line-height: 1.6; min-height: 100vh; }
.page { max-width: 680px; margin: 0 auto; padding: 48px 24px 80px; }
.eyebrow { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 8px; }
h1 { font-family: var(--serif); font-size: 36px; font-weight: 500; line-height: 1.2; color: var(--ink); margin-bottom: 16px; }
h2 { font-family: var(--serif); font-size: 24px; font-weight: 500; color: var(--ink); margin: 36px 0 12px; }
h3 { font-size: 13px; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-muted); margin: 28px 0 10px; }
p { font-size: 15px; line-height: 1.75; color: var(--ink-mid); margin-bottom: 16px; }
.lead { font-size: 17px; line-height: 1.7; color: var(--ink-mid); margin-bottom: 28px; }
hr { border: none; border-top: 1px solid var(--border); margin: 32px 0; }
.card { background: white; border: 1px solid var(--border); border-radius: 12px; padding: 20px 24px; margin-bottom: 12px; }
.card-label { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 6px; }
.card-title { font-size: 16px; font-weight: 500; color: var(--ink); margin-bottom: 6px; }
.card-body { font-size: 14px; line-height: 1.65; color: var(--ink-mid); }
.callout { background: var(--accent-light); border: 1px solid rgba(43,95,62,0.2); border-radius: 10px; padding: 16px 20px; margin: 20px 0; }
.callout-label { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); font-weight: 500; margin-bottom: 6px; }
.callout p { font-size: 13px; line-height: 1.65; color: var(--ink-mid); margin: 0; }
.script-block { background: var(--sand-dark); border-left: 3px solid var(--accent); border-radius: 0 8px 8px 0; padding: 14px 18px; font-size: 14px; line-height: 1.7; color: var(--ink); font-style: italic; margin: 16px 0; }
.script-label { font-size: 10px; font-style: normal; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 6px; }
.corner-tag { display: inline-block; font-size: 11px; font-weight: 500; padding: 4px 12px; border-radius: 20px; margin-bottom: 16px; }
.corner-1 { background: var(--c1-bg); color: var(--c1); border: 1px solid rgba(26,74,107,0.2); }
.corner-2 { background: var(--c2-bg); color: var(--c2); border: 1px solid rgba(45,90,39,0.2); }
.corner-3 { background: var(--c3-bg); color: var(--c3); border: 1px solid rgba(122,74,10,0.2); }
.corner-4 { background: var(--c4-bg); color: var(--c4); border: 1px solid rgba(107,44,74,0.2); }
.form-group { margin-bottom: 20px; }
label { display: block; font-size: 13px; font-weight: 500; color: var(--ink); margin-bottom: 6px; }
label .hint { font-weight: 400; color: var(--ink-muted); font-size: 12px; margin-left: 6px; }
input[type=text], input[type=email], select, textarea { width: 100%; background: white; border: 1px solid var(--border-mid); border-radius: 8px; padding: 10px 14px; font-family: var(--sans); font-size: 14px; color: var(--ink); outline: none; transition: border-color 0.15s; }
input:focus, select:focus, textarea:focus { border-color: var(--accent); }
textarea { resize: vertical; min-height: 100px; }
.radio-group { display: flex; flex-direction: column; gap: 8px; }
.radio-option { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px; background: white; border: 1px solid var(--border); border-radius: 8px; cursor: pointer; transition: border-color 0.12s, background 0.12s; }
.radio-option:hover { background: var(--sand); border-color: var(--border-mid); }
.radio-option input[type=radio] { margin-top: 2px; flex-shrink: 0; accent-color: var(--accent); }
.radio-option-text { font-size: 13px; line-height: 1.5; color: var(--ink-mid); }
.scale-row { display: flex; gap: 8px; align-items: center; margin: 6px 0; }
.scale-label { font-size: 12px; color: var(--ink-muted); min-width: 60px; }
.scale-label.right { text-align: right; }
.scale-buttons { display: flex; gap: 4px; flex: 1; justify-content: center; }
.scale-btn { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--border-mid); background: white; font-size: 13px; font-weight: 500; color: var(--ink-mid); cursor: pointer; transition: all 0.12s; font-family: var(--sans); }
.scale-btn:hover, .scale-btn.selected { background: var(--accent); color: white; border-color: var(--accent); }
.btn { display: inline-block; padding: 12px 28px; border-radius: 8px; font-family: var(--sans); font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.15s; text-decoration: none; border: none; }
.btn-primary { background: var(--accent); color: white; }
.btn-primary:hover { opacity: 0.88; }
.btn-outline { background: transparent; border: 1px solid var(--border-mid); color: var(--ink-mid); }
.btn-outline:hover { background: var(--sand); }
.btn-full { width: 100%; text-align: center; }
.success-msg { display: none; background: var(--accent-light); border: 1px solid rgba(43,95,62,0.3); border-radius: 10px; padding: 20px 24px; margin-top: 16px; }
.success-msg.show { display: block; }
.success-msg h3 { color: var(--accent); font-size: 15px; font-weight: 500; margin-bottom: 6px; text-transform: none; letter-spacing: 0; }
.success-msg p { font-size: 13px; color: var(--ink-mid); margin: 0; }
.nav-links { display: flex; gap: 12px; margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--border); flex-wrap: wrap; }
.day-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--sand-dark); border: 1px solid var(--border); border-radius: 20px; padding: 4px 12px; font-size: 11px; font-weight: 500; color: var(--ink-muted); margin-bottom: 20px; }
.day-chip span { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px) { .two-col { grid-template-columns: 1fr; } h1 { font-size: 28px; } .page { padding: 32px 16px 60px; } }
.corner-content { display: none; }
.corner-content.active { display: block; }
.week-nav { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 28px; }
.week-dot { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--border-mid); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 500; color: var(--ink-muted); cursor: pointer; transition: all 0.12s; text-decoration: none; }
.week-dot.active { background: var(--accent); color: white; border-color: var(--accent); }
.week-dot.done { background: var(--sand-dark); border-color: var(--border); }
.stat-card { background: white; border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center; }
.stat-number { font-family: var(--serif); font-size: 32px; font-weight: 600; color: var(--ink); }
.stat-label { font-size: 11px; color: var(--ink-faint); margin-top: 2px; }
.progress-bar { height: 6px; background: var(--sand-dark); border-radius: 3px; overflow: hidden; margin: 6px 0; }
.progress-fill { height: 100%; background: var(--accent); border-radius: 3px; transition: width 0.6s ease; }
table { width: 100%; border-collapse: collapse; font-size: 13px; margin: 12px 0; }
th { text-align: left; padding: 8px 12px; background: var(--sand-dark); font-weight: 500; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-muted); border-bottom: 1px solid var(--border); }
td { padding: 10px 12px; border-bottom: 1px solid var(--border); color: var(--ink-mid); vertical-align: top; }
tr:last-child td { border-bottom: none; }
