/* Guide / article pages — clean readable layout, same five-tone palette. */
:root {
  --c-dark: #50514F; --c-red: #F25F5C; --c-yellow: #FFE066; --c-blue: #247BA0; --c-teal: #70C1B3;
  --bg: #f4f6f5; --surface: #fff; --surface-2: #eef1f0; --ink: #50514F; --muted: #8c8e8b;
  --line: rgba(80,81,79,0.16); --line-soft: rgba(80,81,79,0.08); --accent-dk: #1c6182;
  --road-red: #d8453f; --road-blue: #2f6fb0; --green: #1f8f5f;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Cormorant Garamond', Georgia, serif;
  background: radial-gradient(120% 70% at 50% -8%, #fff 0%, #f2f4f3 60%, #e7eae9 100%) fixed;
  color: var(--ink); line-height: 1.75; letter-spacing: 0.01em;
}
a { color: var(--c-blue); text-decoration: none; }
a:hover { text-decoration: underline; }

.ghead {
  position: sticky; top: 0; z-index: 5;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 18px; background: rgba(255,255,255,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.gbrand { font-family: 'Cinzel', serif; font-weight: 700; font-size: 0.95rem; letter-spacing: 0.08em; color: var(--c-dark); }
.gbrand span { color: var(--c-blue); }
.gplay {
  font-family: 'Cinzel', serif; font-size: 0.72rem; letter-spacing: 0.08em;
  color: #fff; background: var(--c-blue); padding: 8px 14px; border-radius: 100px;
}
.gplay:hover { text-decoration: none; filter: brightness(1.06); }

.wrap { max-width: 720px; margin: 0 auto; padding: 8px 18px 60px; }
.crumb { font-family: 'JetBrains Mono', monospace; font-size: 0.74rem; color: var(--muted); margin: 14px 0 6px; }
.crumb a { color: var(--muted); }

h1 { font-family: 'Cinzel', serif; font-weight: 700; font-size: clamp(1.5rem, 6vw, 2.1rem); letter-spacing: 0.03em; color: var(--c-dark); line-height: 1.3; margin: 6px 0 4px; }
.lead { color: var(--muted); font-size: 1.08rem; margin: 0 0 22px; }
h2 { font-family: 'Cinzel', serif; font-size: 1.25rem; letter-spacing: 0.04em; color: var(--c-dark); margin: 34px 0 10px; padding-bottom: 6px; border-bottom: 2px solid var(--line); }
h3 { font-size: 1.12rem; color: var(--accent-dk); margin: 22px 0 6px; }
p { margin: 10px 0; }
ul, ol { margin: 10px 0; padding-left: 1.3em; }
li { margin: 5px 0; }
strong { color: var(--c-dark); font-weight: 700; }
.note { background: var(--surface); border: 1px solid var(--line); border-left: 4px solid var(--c-blue); border-radius: 10px; padding: 12px 16px; margin: 18px 0; font-size: 0.98rem; }
.warn { border-left-color: var(--c-red); }
.warn strong { color: var(--c-red); }

.tbl { overflow-x: auto; margin: 16px 0; -webkit-overflow-scrolling: touch; }
table.data { border-collapse: collapse; width: 100%; font-size: 0.95rem; }
table.data th, table.data td { border: 1px solid var(--line); padding: 8px 10px; text-align: left; }
table.data th { background: var(--surface-2); font-family: 'Cinzel', serif; font-size: 0.85rem; letter-spacing: 0.04em; }
table.data td.r { text-align: right; font-family: 'JetBrains Mono', monospace; }

/* mini road legend marks */
.mk { display: inline-block; width: 15px; height: 15px; border-radius: 50%; vertical-align: middle; margin: 0 1px; }
.mk.bk { background: var(--road-red); } .mk.pl { background: var(--road-blue); } .mk.ti { background: var(--green); }
.mk.ring-bk { background: transparent; border: 2.5px solid var(--road-red); }
.mk.ring-pl { background: transparent; border: 2.5px solid var(--road-blue); }

.cards-link { display: block; margin: 28px 0; padding: 16px 18px; border-radius: 14px; background: var(--c-teal); color: #143a34; text-align: center; font-family: 'Cinzel', serif; letter-spacing: 0.04em; }
.cards-link:hover { text-decoration: none; filter: brightness(1.04); }
.cards-link b { display: block; font-size: 1.15rem; color: #0f2e29; }

.more { margin: 40px 0 0; padding-top: 20px; border-top: 1px solid var(--line); }
.more h2 { border: none; margin-bottom: 8px; }
.more ul { list-style: none; padding: 0; }
.more li { margin: 8px 0; }

.gfoot { text-align: center; color: var(--muted); font-size: 0.82rem; padding: 28px 20px; border-top: 1px solid var(--line); margin-top: 40px; font-style: italic; }
.gfoot a { color: var(--muted); }
