*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,system-ui,sans-serif;line-height:1.7;color:#333;background:#fff}
.css-fl77qen{max-width:780px;margin:0 auto;padding:0 20px}
header{background:#1a1a2e;color:#fff;padding:32px 0;margin-bottom:40px}
header h1{font-size:28px;margin-bottom:4px}
header p{opacity:.7;font-size:15px}
header .css-hyel7i3{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.css-c9zsvuf{border-bottom:1px solid #eee;padding:24px 0}
.css-c9zsvuf h2{font-size:20px;margin-bottom:8px}
.css-c9zsvuf h2 a{color:#1a1a2e;text-decoration:none}
.css-c9zsvuf h2 a:hover{color:#e94560}
.css-c9zsvuf .date{font-size:13px;color:#999;margin-bottom:8px}
.css-ne5j7x1{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.css-fw57yko{padding-bottom:60px}
.css-fw57yko h1{font-size:32px;margin-bottom:8px}
.css-fw57yko time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.css-fw57yko h2{font-size:22px;margin:32px 0 12px}
.css-fw57yko h3{font-size:18px;margin:24px 0 8px}
.css-fw57yko p{margin-bottom:16px}
.css-fw57yko ul,.css-fw57yko ol{margin:0 0 16px 24px}
.css-fw57yko a{color:#e94560}
.css-fw57yko img{max-width:100%;height:auto;border-radius:8px;margin:16px 0}
footer{border-top:1px solid #eee;padding:24px 0;margin-top:40px;text-align:center;font-size:13px;color:#999}
footer a{color:#999}
.css-qzurq92{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.css-926hdmn{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.css-6ixw1ur{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.css-6zxy71l{text-align:center;margin:0 0 20px}
.css-fmknlsd{max-width:100%;height:auto;border-radius:6px}
.css-ei4hwcm{text-align:center;margin:24px 0}
.css-vsbw1v1{max-width:100%;height:auto;border-radius:6px}
.css-dz2pry9{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.css-dz2pry9 h3{font-size:18px;margin-bottom:12px}
.css-dz2pry9 ul{list-style:none;padding:0}
.css-dz2pry9 li{padding:4px 0}
.css-dz2pry9 a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#1F3C5E;--accent:#CC8800;--bg:#E9E5DC;--fg:#1E1A16;--border:#C4BEB1;--r:3px;--fb:'Karla';--fh:'Barlow Condensed'}
/* === Custom === */
/* Design reference: 1980s-90s South American spirit label + coastal Ecuador cantina menu */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Karla:ital,wght@0,400;0,500;0,700;1,400&display=swap');

/* --- Base --- */
:root body { font-family: var(--fb), system-ui, -apple-system, sans-serif; color: var(--fg); background: var(--bg); line-height: 1.72; font-size: 16px; }
::selection { background: var(--accent); color: var(--bg); }
:root hr { border: 0; border-top: 1px solid var(--border); margin: 28px 0; }

/* --- Header (site masthead) --- */
:root header { background: var(--primary); color: var(--bg); padding: 28px 0 20px; margin-bottom: 36px; border-bottom: 4px solid var(--accent); }
:root header h1 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 34px; font-weight: 700; color: var(--bg); letter-spacing: .02em; margin-bottom: 4px; line-height: 1.12; text-transform: uppercase; }
:root header h1 + p { font-size: 15px; color: rgba(233,229,220,.93); font-family: var(--fb), system-ui, sans-serif; }
:root header a { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 22px; color: var(--bg); text-decoration: none; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }

/* --- Main container --- */
:root main { padding-bottom: 56px; }

/* --- Article page: title and date --- */
:root main > h1 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 36px; font-weight: 700; color: var(--fg); line-height: 1.14; margin: 8px 0 6px; letter-spacing: .01em; text-transform: uppercase; }
:root main > time { display: block; font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--accent); margin-bottom: 26px; letter-spacing: .16em; text-transform: uppercase; font-weight: 700; }

/* --- Article page body --- */
:root main > article:not(:has(> .date)) > p { margin-bottom: 20px; font-size: 16px; line-height: 1.74; }
:root main > article:not(:has(> .date)) > h2 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 22px; font-weight: 700; color: var(--primary); margin: 44px 0 14px; border-left: 4px solid var(--accent); padding-left: 12px; letter-spacing: .02em; text-transform: uppercase; }
:root main > article:not(:has(> .date)) > h3 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 19px; font-weight: 700; color: var(--accent); margin: 32px 0 10px; letter-spacing: .02em; }
:root main > article:not(:has(> .date)) ul,
:root main > article:not(:has(> .date)) ol { margin: 0 0 18px 22px; }
:root main > article:not(:has(> .date)) li { margin-bottom: 6px; font-size: 16px; }
:root main > article:not(:has(> .date)) > blockquote { border-left: 4px solid var(--accent); padding: 10px 0 10px 18px; margin: 26px 0; font-style: italic; color: var(--fg); background: rgba(204,136,0,.06); border-radius: 0 var(--r) var(--r) 0; }

/* --- Article body links --- */
:root main > article:not(:has(> .date)) > p a,
:root main > article:not(:has(> .date)) > p a:visited { color: var(--primary); text-decoration: underline; text-decoration-color: var(--accent); text-underline-offset: 3px; text-decoration-thickness: 1.5px; font-weight: 500; }
:root main > article:not(:has(> .date)) > p a:hover { color: var(--accent); text-decoration-color: var(--primary); }

/* --- Image wrapper in article --- */
:root main > article:not(:has(> .date)) > div:has(> img) { margin: 0 0 26px; max-height: 400px; overflow: hidden; }
:root main > article:not(:has(> .date)) > div:has(> img) > img { width: 100%; height: 360px; object-fit: cover; object-position: center; display: block; border: 1px solid var(--border); border-radius: var(--r); }

/* --- Aside / footnote block in article --- */
:root main > article:not(:has(> .date)) > div:has(> em) { border-top: 2px solid var(--primary); border-bottom: 1px solid var(--border); padding: 10px 0 10px 14px; margin-top: 32px; margin-bottom: 28px; font-size: 13px; color: var(--fg); font-family: var(--fb), system-ui, sans-serif; }
:root main > article:not(:has(> .date)) > div:has(> em) em { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-style: normal; color: var(--primary); text-transform: uppercase; font-size: 11px; letter-spacing: .16em; display: inline-block; margin-right: 8px; font-weight: 700; }

/* --- Article listing cards (home page) --- */
:root main > article:has(> .date) { padding: 20px 0; border-bottom: 1px solid var(--border); }
:root main > article:has(> .date):last-of-type { border-bottom: 0; }
:root main > article:has(> .date) > h2 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 21px; font-weight: 600; margin-bottom: 4px; line-height: 1.26; letter-spacing: .01em; text-transform: uppercase; }
:root main > article:has(> .date) > h2 a { color: var(--fg); text-decoration: none; }
:root main > article:has(> .date) > h2 a:hover { color: var(--primary); }
:root main > article:has(> .date) > .date { font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 8px; display: block; font-weight: 700; }
:root main > article:has(> .date) > p:not(.date) { font-size: 14.5px; color: var(--fg); opacity: .94; margin-bottom: 10px; line-height: 1.60; }
:root main > article:has(> .date) > a:last-child { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 13px; color: var(--primary); text-decoration: none; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; border-bottom: 2px solid var(--accent); padding-bottom: 1px; }
:root main > article:has(> .date) > a:last-child:hover { color: var(--accent); border-bottom-color: var(--primary); }

/* --- Related articles sidebar section --- */
:root main > section { margin-top: 36px; padding-top: 16px; border-top: 2px solid var(--primary); }
:root main > section > h3 { font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 16px; color: var(--primary); margin-bottom: 16px; text-transform: uppercase; letter-spacing: .12em; font-weight: 700; }
:root main > section > ul { list-style: none; margin: 0; padding: 0; }
:root main > section > ul > li { padding: 8px 0; border-bottom: 1px dotted var(--border); }
:root main > section > ul > li:last-child { border-bottom: 0; }
:root main > section > ul > li > a { color: var(--fg); text-decoration: none; font-family: var(--fb), system-ui, sans-serif; font-size: 14px; }
:root main > section > ul > li > a:hover { color: var(--primary); }

/* --- Footer --- */
:root footer { background: transparent; border-top: 1px solid var(--border); padding: 20px 0 28px; margin-top: 36px; text-align: center; font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--fg); opacity: .58; letter-spacing: .06em; }
:root footer a { color: var(--fg); text-decoration: none; border-bottom: 1px dotted var(--border); }
:root footer a:hover { color: var(--primary); border-bottom-color: var(--primary); opacity: 1; }

/* --- Responsive adjustments --- */
@media (max-width: 640px) {
  :root header { padding: 18px 0 14px; margin-bottom: 24px; }
  :root header h1 { font-size: 26px; }
  :root header a { font-size: 18px; }
  :root main > h1 { font-size: 28px; }
  :root main > article:not(:has(> .date)) > h2 { font-size: 18px; }
  :root main > article:has(> .date) > h2 { font-size: 18px; }
}

/* --- Print styles --- */
@media print {
  :root header { background: none; color: var(--fg); border-bottom: 1px solid var(--fg); }
  :root footer { display: none; }
}

/* === R2 fixes (2026-06-16T20:00:06.390602+00:00) === */

/* --- Comparison & article tables --- */
#comparison-table table,
:root main > article table { width: 100%; border-collapse: collapse; margin: 24px 0 28px; font-size: 15px; }
#comparison-table table th,
:root main > article table th { background: var(--primary); color: var(--bg); font-family: var(--fh), 'Arial Narrow', system-ui, sans-serif; font-size: 13px; letter-spacing: .1em; text-transform: uppercase; padding: 10px 14px; text-align: left; }
#comparison-table table td,
:root main > article table td { padding: 10px 14px; border-bottom: 1px solid var(--border); }
#comparison-table table tr:last-child td,
:root main > article table tr:last-child td { border-bottom: 0; }

/* === R3 fixes (2026-06-16T20:40:20.179568+00:00) === */

/* --- Visit/affiliate links: dashed thicker underline at bold weight --- */
:root main > article:not(:has(> .date)) > p a[href*='/visit/'],
:root main > article:not(:has(> .date)) > p a[href*='/visit/']:visited { text-decoration-style: dashed; text-decoration-thickness: 2px; font-weight: 700; }

/* --- Related-articles section: subtle amber background + padding + radius --- */
:root main > section { padding: 20px 14px 10px; background: rgba(204,136,0,.05); border-radius: var(--r); }

/* === R4 fixes (2026-06-16T21:20:19.479129+00:00) === */

/* --- Visit/affiliate links: amber highlight tint behind text --- */
:root main > article:not(:has(> .date)) > p a[href*='/visit/'],
:root main > article:not(:has(> .date)) > p a[href*='/visit/']:visited { background: rgba(204,136,0,.12); border-radius: 2px; padding: 0 3px; }
