:root {
  --bg: #faf7f2;
  --bg-card: #fffdf9;
  --bg-sunk: #f2ede4;
  --text: #2a2620;
  --text-muted: #6c6760;
  --accent: #3b6b6a;
  --accent-warm: #b85a2f;
  --accent-soft: #d6e0df;
  --border: #e4dfd7;
  --border-strong: #cdc6ba;
  --shadow: 0 1px 2px rgba(42, 38, 32, 0.04), 0 4px 16px rgba(42, 38, 32, 0.06);
  --radius: 6px;
  --maxw: 1100px;
  --maxw-text: 780px;
  --font-serif: "Source Serif Pro", "Iowan Old Style", "Apple Garamond", Georgia, serif;
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: var(--accent); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color 0.15s; }
a:hover { border-bottom-color: var(--accent); }

h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: 600; line-height: 1.22; color: var(--text); letter-spacing: -0.01em; }
h1 { font-size: 2.6rem; margin: 0 0 0.4em; }
h2 { font-size: 1.85rem; margin: 2.2em 0 0.8em; }
h3 { font-size: 1.3rem; margin: 1.6em 0 0.4em; }
h4 { font-size: 1.05rem; margin: 1.2em 0 0.3em; font-family: var(--font-sans); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); font-weight: 600; }

p { margin: 0 0 1em; }

small { color: var(--text-muted); }

hr { border: none; border-top: 1px solid var(--border); margin: 3rem 0; }

ul, ol { padding-left: 1.4rem; }
li { margin: 0.3em 0; }

table { width: 100%; border-collapse: collapse; margin: 1.2em 0; font-size: 0.96rem; }
th, td { text-align: left; padding: 0.65em 0.9em; border-bottom: 1px solid var(--border); }
th { background: var(--bg-sunk); font-weight: 600; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); }
td.num { text-align: right; font-variant-numeric: tabular-nums; }
tbody tr:last-child td { border-bottom: 2px solid var(--border-strong); }
tfoot td, tr.total td { font-weight: 700; background: var(--bg-sunk); border-top: 2px solid var(--border-strong); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.container-text { max-width: var(--maxw-text); margin: 0 auto; padding: 0 24px; }

/* Top nav */
.topnav { background: var(--bg-card); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 100; backdrop-filter: blur(6px); }
.topnav .container { display: flex; align-items: center; justify-content: space-between; height: 56px; }
.topnav .brand { font-family: var(--font-serif); font-weight: 600; font-size: 1.1rem; border: none; }
.topnav .brand:hover { color: var(--accent); }
.topnav nav a { margin-left: 1.5rem; font-size: 0.93rem; color: var(--text-muted); }
.topnav nav a:hover, .topnav nav a.active { color: var(--text); }

/* Hero */
.hero { padding: 5rem 0 3.5rem; background: linear-gradient(180deg, #f2ede4 0%, var(--bg) 100%); border-bottom: 1px solid var(--border); }
.hero .eyebrow { text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.8rem; color: var(--accent-warm); font-weight: 600; margin-bottom: 1rem; }
.hero h1 { font-size: 3.2rem; margin-bottom: 0.6em; }
.hero .lede { font-size: 1.25rem; color: var(--text-muted); max-width: 720px; line-height: 1.5; }
.hero-meta { display: flex; flex-wrap: wrap; gap: 2.2rem; margin-top: 2.8rem; font-size: 0.95rem; }
.hero-meta div { display: flex; flex-direction: column; gap: 0.2rem; }
.hero-meta .label { text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem; color: var(--text-muted); }
.hero-meta .value { font-family: var(--font-serif); font-size: 1.25rem; font-weight: 600; }

/* Section headings */
.section { padding: 3.5rem 0; }
.section-eyebrow { text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.78rem; color: var(--accent-warm); font-weight: 600; margin-bottom: 0.6rem; }
.section h2 { margin-top: 0; }

/* Options grid */
.options-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.4rem; margin-top: 2rem; }
.option-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem 1.6rem 1.3rem; position: relative; transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s; display: flex; flex-direction: column; }
.option-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--border-strong); }
.option-number { font-family: var(--font-serif); font-size: 0.85rem; font-weight: 600; color: var(--accent-warm); letter-spacing: 0.1em; }
.option-card h3 { margin: 0.1em 0 0.25em; font-size: 1.4rem; }
.option-card .tagline { font-family: var(--font-serif); font-style: italic; color: var(--text-muted); margin: 0.3em 0 1.2em; font-size: 1.05rem; line-height: 1.4; }
.option-card .pitch { font-size: 0.95rem; margin: 0 0 1.2em; line-height: 1.55; }
.option-card .weights { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.4rem; margin: 0 0 1.2em; padding: 0; }
.option-card .weights div { display: flex; flex-direction: column; align-items: flex-start; }
.option-card .weights dt { text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.7rem; color: var(--text-muted); margin-bottom: 0.2em; }
.option-card .weights dd { margin: 0; color: var(--accent); letter-spacing: 0.05em; font-size: 0.95rem; }
.option-card .meta { font-size: 0.83rem; color: var(--text-muted); display: flex; justify-content: space-between; margin-top: auto; padding: 0.9rem 0 0.9rem; border-top: 1px solid var(--border); }
.option-card .meta strong { color: var(--text); font-weight: 600; }
.option-card .cta { display: inline-block; font-size: 0.95rem; color: var(--accent); font-weight: 500; border-bottom: 1px solid var(--accent-soft); padding-bottom: 1px; align-self: flex-start; }
.option-card .cta:hover { color: var(--accent-warm); border-bottom-color: var(--accent-warm); }

.urgency { display: inline-block; padding: 0.2em 0.6em; border-radius: 3px; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; margin-left: 0.5em; }
.urgency.high { background: #f7dcca; color: #7a3010; }
.urgency.med { background: #f4e9c5; color: #6d5a1b; }
.urgency.low { background: #d6e7d4; color: #2f5a2b; }

/* Comparison table */
.comparison { margin: 2rem -12px 0; overflow-x: auto; }
.comparison table { min-width: 860px; }
.comparison td { vertical-align: middle; }
.comparison td.num { white-space: nowrap; }
.comparison a { font-weight: 500; }
.dots { color: var(--accent); letter-spacing: 0.08em; font-family: var(--font-serif); }

/* Option page */
.option-page .hero { background: linear-gradient(180deg, #e6ece8 0%, var(--bg) 100%); padding-top: 3.5rem; padding-bottom: 3rem; }
.option-page .hero .eyebrow { color: var(--accent); }
.option-page h1 { font-size: 2.8rem; }
.option-page .hero .lede { font-size: 1.15rem; }

.highlights-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 0.8rem 1.4rem; margin: 1rem 0 2rem; padding: 0; list-style: none; }
.highlights-grid li { padding-left: 1.1rem; position: relative; line-height: 1.55; }
.highlights-grid li::before { content: "◆"; color: var(--accent-warm); position: absolute; left: 0; top: 0.15em; font-size: 0.75rem; }

.day { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.3rem 1.4rem; margin: 0 0 0.9rem; transition: border-color 0.15s; }
.day:hover { border-color: var(--border-strong); }
.day-header { display: flex; align-items: baseline; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 0.9rem; }
.day-header .night { font-family: var(--font-serif); font-size: 1.3rem; font-weight: 600; color: var(--accent); }
.day-header .date { font-family: var(--font-serif); color: var(--text-muted); font-size: 1.05rem; }
.day-header .location { font-family: var(--font-serif); font-weight: 600; font-size: 1.15rem; }
.day-body { display: grid; grid-template-columns: 140px 1fr; gap: 0.3rem 1.2rem; font-size: 0.96rem; }
.day-body dt { text-transform: uppercase; letter-spacing: 0.07em; font-size: 0.72rem; color: var(--text-muted); padding-top: 0.28em; font-weight: 600; }
.day-body dd { margin: 0; padding: 0.28em 0; border-bottom: 1px solid var(--border); line-height: 1.5; }
.day-body dd:last-of-type { border-bottom: none; }

.budget-table td.num { font-family: var(--font-serif); }

.pros-cons { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin: 1rem 0 2rem; }
.pros-cons > div { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.2rem 1.4rem; }
.pros-cons h4 { margin-top: 0; color: var(--accent); }
.pros-cons.cons h4 { color: var(--accent-warm); }
.pros-cons ul { padding-left: 1.2rem; margin: 0; }

.callout { background: var(--bg-sunk); border-left: 3px solid var(--accent-warm); padding: 1.2rem 1.4rem; margin: 1.6rem 0; border-radius: 0 var(--radius) var(--radius) 0; }
.callout h4 { margin: 0 0 0.6em; color: var(--accent-warm); }
.callout ul { margin: 0; }

.best-for { background: var(--accent); color: #fff; padding: 1.6rem 1.8rem; border-radius: var(--radius); margin: 2rem 0; font-family: var(--font-serif); font-size: 1.2rem; line-height: 1.5; font-style: italic; }
.best-for strong { font-style: normal; text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.75rem; display: block; margin-bottom: 0.5em; opacity: 0.85; font-family: var(--font-sans); }

.back-link { display: inline-block; margin: 2.5rem 0 0; color: var(--text-muted); font-size: 0.9rem; border: none; }
.back-link:hover { color: var(--accent); }

/* Practicalities */
.prac-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.4rem; margin-top: 1.8rem; }
.prac-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.4rem 1.6rem; }
.prac-card h3 { margin-top: 0; font-size: 1.2rem; }

/* Footer */
footer { background: var(--text); color: #d8d3ca; padding: 2.5rem 0 2.5rem; margin-top: 5rem; font-size: 0.92rem; }
footer a { color: #e8e4db; border-bottom-color: rgba(232, 228, 219, 0.35); }
footer .container { display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
footer p { margin: 0.3em 0; color: #a8a39a; }

/* Responsive */
@media (max-width: 760px) {
  .hero h1 { font-size: 2.2rem; }
  .hero .lede { font-size: 1.08rem; }
  h1 { font-size: 2rem; }
  h2 { font-size: 1.5rem; }
  .hero-meta { gap: 1.5rem; }
  .pros-cons { grid-template-columns: 1fr; }
  .day-body { grid-template-columns: 1fr; gap: 0; }
  .day-body dt { padding-top: 0.6em; border-bottom: none; }
  .day-body dd { padding-top: 0.1em; padding-bottom: 0.6em; }
  .option-card .weights { grid-template-columns: repeat(3, 1fr); gap: 0.3rem; }
  .topnav nav a { margin-left: 0.9rem; }
  footer .container { flex-direction: column; }
}

/* Print */
@media print {
  .topnav, footer, .back-link { display: none; }
  body { background: #fff; }
  .day, .prac-card, .option-card, .pros-cons > div { break-inside: avoid; box-shadow: none; border-color: #bbb; }
  .hero { padding: 1rem 0; }
}
