/* Scotland 2026 — restrained palette, mobile-first.
   Deep green (Highlands), warm sand (links), off-white background. */

:root {
  --bg:           #f6f1e7;       /* off-white, warm */
  --bg-soft:      #efe7d6;
  --paper:        #fbf7ef;
  --ink:          #1f2a24;       /* near-black with green undertone */
  --ink-soft:     #4a5a52;
  --ink-faint:    #7d8b83;
  --line:         #d8cdb6;
  --line-strong:  #b8a988;
  --accent:       #2a4a3a;       /* deep green */
  --accent-deep:  #1c3327;
  --sand:         #b88a4a;       /* warm links sand */
  --sand-soft:    #e7d4ae;
  --warn:         #a04a2a;
  --good:         #3f6b50;
  --finale:       #6f2c1a;       /* burgundy for the Royal Dornoch final */
  --shadow:       0 1px 2px rgba(31,42,36,0.06), 0 4px 12px rgba(31,42,36,0.04);
  --radius:       6px;
  --radius-lg:    10px;
  --serif:        Georgia, "Iowan Old Style", "Palatino Linotype", "Book Antiqua", serif;
  --sans:         -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono:         "SF Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1,h2,h3,h4,h5 { font-family: var(--serif); font-weight: 600; line-height: 1.2; margin: 0 0 .4em; }
h1 { font-size: 1.75rem; }
h2 { font-size: 1.35rem; }
h3 { font-size: 1.1rem; }
h4 { font-size: 1rem; }
p { margin: 0 0 .8em; }
a { color: var(--accent); text-underline-offset: 2px; }
a:hover { color: var(--accent-deep); }
button, input, select, textarea {
  font-family: var(--sans);
  font-size: .95rem;
  color: inherit;
}
button {
  background: var(--paper);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: .5em .9em;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease;
}
button:hover { background: var(--bg-soft); border-color: var(--accent); }
button:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
input[type="text"], input[type="url"], input[type="number"], input[type="time"], textarea, select {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .45em .6em;
  width: 100%;
}
textarea { font-family: var(--serif); resize: vertical; }
label { display: block; font-family: var(--sans); font-size: .85rem; color: var(--ink-soft); margin-bottom: .25em; }
hr { border: 0; border-top: 1px solid var(--line); margin: 1.5rem 0; }

/* ---------- Top bar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 20;
  background: var(--accent);
  color: #fbf7ef;
  border-bottom: 1px solid var(--accent-deep);
}
.topbar a { color: var(--sand-soft); }
.topbar-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem;
  padding: .65rem 1rem;
  max-width: 980px; margin: 0 auto;
}
.brand strong { display: block; font-size: 1.1rem; letter-spacing: .01em; }
.brand-sub { font-family: var(--sans); font-size: .78rem; color: var(--sand-soft); opacity: .9; }
.view-toggle { display: flex; gap: 4px; }
.view-toggle button {
  background: transparent;
  color: #fbf7ef;
  border: 1px solid rgba(255,255,255,0.2);
  padding: .35em .8em;
  font-family: var(--sans);
  font-size: .85rem;
}
.view-toggle button[aria-selected="true"] {
  background: var(--paper);
  color: var(--accent-deep);
  border-color: var(--paper);
}
.countdown {
  text-align: center;
  font-family: var(--sans);
  font-size: .82rem;
  padding: .35rem 1rem .5rem;
  color: var(--sand-soft);
  border-top: 1px solid rgba(255,255,255,0.1);
}
.countdown.finale-done { color: #f3deb6; }
.countdown strong { color: #fbf7ef; font-weight: 600; }

/* ---------- Main layout ---------- */
main {
  max-width: 980px;
  margin: 0 auto;
  padding: 1rem;
}

/* ---------- View transitions ---------- */
.view { display: block; }
.view-hidden { display: none; }

/* ---------- Section headers ---------- */
.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin: 1.25rem 0 .5rem;
  border-bottom: 1px solid var(--line);
  padding-bottom: .35rem;
}
.section-head h2 { margin: 0; }
.section-head .meta { font-family: var(--sans); font-size: .82rem; color: var(--ink-faint); }

/* ---------- Day card ---------- */
.day {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 1rem 1.1rem;
  margin: .9rem 0;
  box-shadow: var(--shadow);
  scroll-margin-top: 110px;
}
.day-anchor {
  border-left: 4px solid var(--accent);
  background: linear-gradient(180deg, #fbf7ef 0%, #f6efdf 100%);
}
.day-finale {
  border-left: 4px solid var(--finale);
  background: linear-gradient(180deg, #fbf3ec 0%, #f4e4d4 100%);
}
.day-head {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: .5rem .9rem;
  margin-bottom: .3rem;
}
.day-num {
  font-family: var(--serif); font-size: 1.4rem; font-style: italic;
  color: var(--accent); font-weight: 600; letter-spacing: 0;
  margin-right: .15rem;
}
.day-date { font-weight: 600; font-size: 1.05rem; }
.day-loc { color: var(--ink-soft); font-style: italic; }
.day-anchor-tag {
  font-family: var(--sans); font-size: .7rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--accent);
  border: 1px solid var(--accent); padding: .1rem .45rem; border-radius: 999px;
}
.day-finale .day-anchor-tag { color: var(--finale); border-color: var(--finale); }
.day-meta-row {
  display: flex; flex-wrap: wrap; gap: .5rem 1.1rem;
  font-family: var(--sans); font-size: .85rem; color: var(--ink-soft);
  margin: .35rem 0 .8rem;
}
.day-meta-row .pill {
  background: var(--bg-soft); padding: .15rem .55rem; border-radius: 999px;
  border: 1px solid var(--line);
}
.day-meta-row .pill.midge-elevated { background: #f5e0c4; border-color: var(--sand); color: var(--warn); }
.day-meta-row .pill.midge-medium { background: #f3eada; border-color: var(--line-strong); }
.day-meta-row .pill.weather { background: var(--paper); border-color: var(--line-strong); }

.day-blocks { display: grid; grid-template-columns: 1fr; gap: .5rem; }
.day-block { padding: .35rem 0; }
.day-block h4 {
  font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent); margin: 0 0 .2rem;
}
.day-block ul { margin: 0; padding-left: 1.1rem; }
.day-block li { margin: .15rem 0; }

.day-workblock {
  font-family: var(--sans); font-size: .85rem;
  background: #ecf0e9; border: 1px dashed var(--accent);
  border-radius: var(--radius); padding: .35rem .6rem; margin-top: .5rem;
}
.day-workblock strong { color: var(--accent-deep); }

.day-decision {
  margin-top: .7rem; padding: .65rem .8rem;
  background: var(--sand-soft); border: 1px solid var(--sand);
  border-radius: var(--radius);
}
.day-decision h4 { font-family: var(--sans); font-size: .8rem; margin: 0 0 .25rem; color: var(--accent-deep); }
.day-decision .decision-cta {
  font-family: var(--sans); font-size: .8rem; color: var(--accent-deep); display: inline-block; margin-top: .25rem;
}

.day-actions { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .7rem; }
.day-actions button {
  font-family: var(--sans); font-size: .82rem; padding: .3em .65em;
}

/* ---------- Branch decision card (inline in plan view) ---------- */
.branch-card {
  background: linear-gradient(180deg, #f4e4d4 0%, #efd9bf 100%);
  border: 1px solid var(--sand);
  border-radius: var(--radius-lg);
  padding: 1rem 1.1rem;
  margin: 1.5rem 0;
  box-shadow: var(--shadow);
}
.branch-card h2 { margin: 0; color: var(--accent-deep); }
.branch-card .rule {
  font-family: var(--sans); font-size: .85rem;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
  padding: .55rem .7rem; margin: .8rem 0;
}
.branch-card .rule strong { color: var(--warn); }
.branch-options { display: grid; grid-template-columns: 1fr; gap: .65rem; margin-top: .7rem; }
.branch-opt {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: .7rem .85rem;
}
.branch-opt h3 { margin: 0 0 .2rem; }
.branch-opt-meta {
  font-family: var(--sans); font-size: .8rem; color: var(--ink-soft);
  display: grid; grid-template-columns: auto 1fr; gap: .15rem .6rem;
  margin: .35rem 0 .4rem;
}
.branch-opt button { width: 100%; font-family: var(--sans); }
.branch-opt.chosen {
  border: 2px solid var(--accent);
  background: #ecf0e9;
}
.branch-opt.chosen h3::after {
  content: " · locked"; font-family: var(--sans); font-size: .7rem;
  color: var(--accent); letter-spacing: .08em; text-transform: uppercase;
}
.branch-collapsed-list { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; margin-top: .6rem; }
.branch-collapsed-list .branch-opt { padding: .45rem .65rem; }
.branch-collapsed-list .branch-opt h3 { font-size: .9rem; }
.branch-forecast {
  font-family: var(--sans); font-size: .82rem;
  margin-top: .6rem; padding: .55rem .7rem;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
}
.branch-forecast table { width: 100%; border-collapse: collapse; margin-top: .3rem; }
.branch-forecast th, .branch-forecast td {
  text-align: left; padding: .25rem .5rem; border-bottom: 1px solid var(--line);
  font-size: .82rem;
}
.branch-forecast th { font-weight: 600; color: var(--ink-soft); }

@media (min-width: 700px) {
  .branch-options { grid-template-columns: repeat(3, 1fr); }
}

/* ---------- Course / hike pages (modals) ---------- */
.modal {
  position: fixed; inset: 0; background: rgba(28,51,39,0.55);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 2rem 1rem;
  z-index: 100;
  overflow-y: auto;
}
.modal[hidden] { display: none; }
.modal-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  max-width: 720px; width: 100%;
  padding: 1.25rem 1.4rem;
  position: relative;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.modal-close {
  position: absolute; top: .5rem; right: .6rem;
  background: transparent; border: 0;
  font-size: 1.6rem; line-height: 1;
  color: var(--ink-soft); cursor: pointer;
  padding: .2rem .5rem;
}
.modal-close:hover { color: var(--accent-deep); }

.course-page h2 { margin-bottom: .1rem; }
.course-meta {
  font-family: var(--sans); font-size: .85rem; color: var(--ink-soft);
  display: flex; flex-wrap: wrap; gap: .3rem .9rem; margin: .2rem 0 .8rem;
}
.course-meta .pill {
  background: var(--bg-soft); padding: .1rem .5rem; border-radius: 999px; border: 1px solid var(--line);
}
.course-section {
  margin: .9rem 0;
  padding-top: .4rem;
  border-top: 1px solid var(--line);
}
.course-section h4 {
  font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent); margin: 0 0 .35rem;
}
.tee-banner {
  background: var(--sand-soft); border: 1px solid var(--sand);
  border-radius: var(--radius); padding: .5rem .7rem;
  font-family: var(--sans); font-size: .85rem; margin: .4rem 0;
}
.tee-banner.confirmed { background: #ecf0e9; border-color: var(--good); color: var(--accent-deep); }
.checklist { list-style: none; padding: 0; margin: .3rem 0; }
.checklist li { display: flex; align-items: center; gap: .5rem; margin: .2rem 0; font-family: var(--sans); font-size: .9rem; }
.checklist input { width: auto; margin: 0; }

.tracking-links {
  background: var(--bg-soft); border: 1px solid var(--line);
  border-radius: var(--radius); padding: .5rem .65rem; margin-top: .35rem;
}
.tracking-links a { font-family: var(--sans); font-size: .85rem; display: inline-block; margin-right: .8rem; }
.tracking-input-row { display: flex; gap: .35rem; margin-top: .35rem; }
.tracking-input-row input { flex: 1; }
.tracking-input-row button { font-family: var(--sans); font-size: .82rem; }

.photo-links { font-family: var(--sans); font-size: .82rem; }
.photo-links a { display: inline-block; margin: 0 .4rem .2rem 0; padding: .15rem .45rem;
  background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--radius);
  text-decoration: none; }

/* ---------- Reading panel / topic cards ---------- */
.topic-card {
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: .7rem .85rem; margin: .5rem 0;
  background: var(--paper);
}
.topic-card summary {
  font-weight: 600; cursor: pointer;
}
.topic-card summary::marker { color: var(--accent); }
.topic-card .topic-body { margin-top: .4rem; }
.topic-card label.read-toggle {
  font-family: var(--sans); font-size: .8rem; color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: .35rem; margin-top: .4rem;
}

/* ---------- Bookings / budget tables ---------- */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table.data {
  width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: .88rem;
}
table.data th, table.data td {
  border-bottom: 1px solid var(--line);
  padding: .45rem .55rem;
  text-align: left;
  vertical-align: top;
}
table.data th { font-weight: 600; color: var(--ink-soft); background: var(--bg-soft); }
table.data input[type="text"], table.data input[type="number"] { font-size: .85rem; padding: .2rem .35rem; }
.status-tag {
  font-family: var(--sans); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em;
  padding: .1rem .45rem; border-radius: 999px; border: 1px solid var(--line);
}
.status-confirmed { color: var(--good); border-color: var(--good); background: #e9f1ec; }
.status-pending   { color: var(--sand); border-color: var(--sand); background: #f7ecd5; }
.status-play-by-ear { color: var(--ink-soft); }
.budget-summary { font-family: var(--sans); font-size: .9rem; margin: .4rem 0; }
.budget-summary strong { color: var(--accent-deep); }

/* ---------- Logging form ---------- */
.log-form { background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--radius);
  padding: .7rem .85rem; margin-top: .5rem; }
.log-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem .7rem; }
.log-form textarea { min-height: 4em; }
.log-form .full { grid-column: 1 / -1; }
.slider-label { font-family: var(--sans); font-size: .82rem; }

/* ---------- Decision modal (Sutherland branch screen) ---------- */
.branch-modal .branch-options { grid-template-columns: 1fr; }
@media (min-width: 600px) {
  .branch-modal .branch-options { grid-template-columns: 1fr 1fr 1fr; }
}

/* ---------- Pronunciation popover ---------- */
.pron {
  border-bottom: 1px dotted var(--accent);
  cursor: help;
  position: relative;
}
.pron::after {
  content: " ?";
  font-family: var(--sans); font-size: .7rem;
  color: var(--accent); margin-left: 1px;
}
.pron:hover::before, .pron:focus::before {
  content: attr(data-pron);
  position: absolute; left: 0; bottom: 110%;
  background: var(--accent-deep); color: #fbf7ef;
  font-family: var(--sans); font-size: .78rem;
  padding: .25rem .5rem; border-radius: var(--radius);
  white-space: nowrap; z-index: 10;
}

/* ---------- Today view header ---------- */
.today-header {
  background: var(--accent);
  background-size: cover;
  background-position: center;
  color: #fbf7ef;
  border-radius: var(--radius-lg);
  padding: 2rem 1.4rem 1.5rem;
  margin: 0 0 1.2rem;
  min-height: 220px;
  display: flex; flex-direction: column; justify-content: flex-end;
  box-shadow: var(--shadow);
  position: relative; overflow: hidden;
}
.today-eyebrow {
  font-family: var(--sans); font-size: .72rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--sand-soft); margin-bottom: .35rem;
}
.today-header h1 {
  color: #fbf7ef; margin: 0 0 .15rem;
  font-size: 2.1rem; font-weight: 600; line-height: 1.05;
  letter-spacing: -.01em;
}
.today-header .when {
  font-family: var(--serif); font-size: 1rem; font-style: italic; color: var(--sand-soft);
}
.today-header .work-now {
  margin-top: .8rem;
  font-family: var(--sans); font-size: .88rem;
  background: rgba(0,0,0,.25); backdrop-filter: blur(4px);
  padding: .45rem .7rem; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.18);
  align-self: flex-start;
}
.today-empty {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 1rem; font-family: var(--sans); font-size: .9rem; color: var(--ink-soft);
}

/* ---------- Drive / sunset summary ---------- */
.summary-row {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: .4rem .7rem;
  font-family: var(--sans); font-size: .85rem; color: var(--ink-soft);
  margin-top: .4rem;
}
@media (min-width: 600px) {
  .summary-row { grid-template-columns: repeat(4, 1fr); }
}
.summary-row .k { color: var(--ink-faint); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.summary-row .v { color: var(--ink); font-size: .92rem; }

/* ---------- Footer ---------- */
.footer {
  border-top: 1px solid var(--line);
  padding: 1.5rem 1rem 3rem;
  margin-top: 2rem;
  background: var(--bg-soft);
}
.footer-actions {
  max-width: 980px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: .5rem;
  margin-bottom: .7rem;
}
.btn-as-label {
  display: inline-block;
  background: var(--paper);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: .5em .9em;
  cursor: pointer;
  font-family: var(--sans); font-size: .95rem;
}
.btn-as-label:hover { background: var(--bg); border-color: var(--accent); }
.btn-warn { color: var(--warn); border-color: var(--warn); }
.btn-warn:hover { background: #f7ecd5; }
.footer-meta {
  max-width: 980px; margin: 0 auto;
  font-family: var(--sans); font-size: .82rem; color: var(--ink-soft);
}

/* ---------- Trip hero (Plan view masthead) ---------- */
.trip-hero {
  margin: 0 0 1.5rem;
  padding: 1.6rem 0 1.4rem;
  border-bottom: 1px solid var(--line);
}
.trip-hero-eyebrow {
  font-family: var(--sans); font-size: .72rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--ink-faint); margin-bottom: .8rem;
}
.trip-hero-title {
  font-family: var(--serif);
  font-size: 1.85rem; font-weight: 600; line-height: 1.2;
  margin: 0 0 1.4rem;
  letter-spacing: -.005em;
  color: var(--ink);
  max-width: 32ch;
}
.trip-hero-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .5rem .8rem;
  font-family: var(--sans);
}
.trip-hero-stats > div {
  display: flex; flex-direction: column; gap: .1rem;
  border-left: 2px solid var(--accent);
  padding-left: .55rem;
}
.trip-hero-stats .n {
  font-family: var(--serif); font-size: 1.6rem; font-weight: 600;
  color: var(--accent-deep); line-height: 1;
}
.trip-hero-stats .l {
  font-size: .7rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ink-faint);
}
@media (max-width: 600px) {
  .trip-hero-title { font-size: 1.45rem; max-width: none; }
  .trip-hero-stats { grid-template-columns: repeat(3, 1fr); }
}

/* ---------- Route map ---------- */
.route-map {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: .8rem;
  margin: 0 0 1.5rem;
  max-width: 560px;
  margin-left: auto; margin-right: auto;
}
.route-map svg {
  width: 100%;
  height: auto;
  display: block;
}
.route-map svg .coast { /* coastline subtle */ }
.route-key {
  display: flex; gap: .8rem; flex-wrap: wrap; align-items: center;
  font-family: var(--sans); font-size: .76rem; color: var(--ink-soft);
  margin-top: .35rem; padding-top: .55rem; border-top: 1px dashed var(--line);
}
.route-key .key-dot {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  margin-right: .35rem; vertical-align: middle;
  border: 2px solid var(--accent);
}
.route-key .key-dot.anchor { background: var(--accent); }
.route-key .key-dot.stop   { background: var(--paper); }
.route-key .key-dot.finale { background: var(--finale); border-color: var(--finale); }
.route-key .key-spacer { color: var(--ink-faint); }
.route-key .key-note { font-style: italic; color: var(--ink-faint); }

/* ---------- Day links footer (replaces pre-reading) ---------- */
.day-links {
  margin-top: .7rem; padding-top: .55rem;
  border-top: 1px dashed var(--line);
  font-family: var(--sans); font-size: .8rem; color: var(--ink-soft);
}
.day-links a {
  color: var(--ink-soft);
  text-decoration: none; border-bottom: 1px solid var(--line-strong);
  margin-right: .15rem;
}
.day-links a:hover { color: var(--accent-deep); border-bottom-color: var(--accent); }
.day-links .dot { margin: 0 .35rem; color: var(--ink-faint); }

/* ---------- Course / hike modal hero image ---------- */
.course-page .hero {
  height: 220px;
  background-size: cover;
  background-position: center;
  border-radius: var(--radius-lg);
  margin: 0 0 1rem;
  background-color: var(--bg-soft);
  position: relative;
}
.course-page .hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.18) 100%);
  border-radius: var(--radius-lg);
}
.course-page.is-finale .hero {
  height: 280px;
  box-shadow: 0 4px 20px rgba(111,44,26,.18);
}
.course-page.is-finale h2 {
  font-size: 1.7rem; color: var(--finale);
}
.finale-tag {
  display: inline-block;
  font-family: var(--sans); font-size: .68rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--finale);
  border: 1.5px solid var(--finale);
  padding: .2rem .55rem; border-radius: 999px;
  margin: 0 0 .6rem;
}

/* ---------- Day card refinements ---------- */
.day { padding: 1.1rem 1.2rem; }
.day-finale {
  border-left-width: 5px;
  box-shadow: 0 2px 16px rgba(111,44,26,.10), var(--shadow);
}
.day-finale .day-num { color: var(--finale); }
.day-finale .day-anchor-tag {
  background: var(--finale); color: #fbf7ef;
  font-weight: 600;
}

/* ---------- Countdown polish ---------- */
.countdown {
  font-family: var(--serif);
  font-size: .9rem;
  font-style: italic;
}
.countdown strong {
  font-style: normal;
  font-family: var(--sans); font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: .02em;
}

/* ---------- Print stylesheet (backup view) ---------- */
@media print {
  :root { --bg: #fff; --paper: #fff; --bg-soft: #fff; }
  body { background: #fff; font-size: 11pt; }
  .topbar, .view-toggle, .footer-actions, .day-actions, .modal, .countdown,
  .branch-card .rule, button, .btn-as-label { display: none !important; }
  .footer { border: 0; padding: 0; background: #fff; }
  .footer-meta { display: none; }
  .day { box-shadow: none; border: 1px solid #999; page-break-inside: avoid; }
  .day-anchor, .day-finale { background: #fff; border-left-width: 3px; }
  .branch-card { background: #fff; }
  .topic-card[open] .topic-body { display: block; }
  .topic-card { box-shadow: none; }
  .topic-card .read-toggle { display: none; }
  a { color: inherit; text-decoration: underline; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; word-break: break-all; }
  a[href^="#"]::after, a[href=""]::after { content: ""; }
  .view-hidden { display: block !important; } /* show all views in print */
  .section-head { page-break-after: avoid; }
  h2, h3 { page-break-after: avoid; }
  .topbar-row { padding: 0; max-width: none; }
  main { max-width: none; padding: 0; }
}
