
:root{
  --bg:#FDFDFC; --paper:#ffffff; --ink:#111111;
  --ink-85:rgba(0,0,0,.85); --ink-78:rgba(0,0,0,.78); --ink-65:rgba(0,0,0,.65);
  --muted:rgba(0,0,0,.5); --faint:rgba(0,0,0,.35); --ghost:rgba(0,0,0,.25);
  --hair:rgba(0,0,0,.08); --border:rgba(0,0,0,.12);
  --accent:#E5484D; --accent-soft:rgba(229,72,77,.10);
  --card:#F6F5F4; --green:#1a7f37; --amber:#9a5b09; --blue:#2480ED;
  --mono:"SF Mono",SFMono-Regular,ui-monospace,"Cascadia Code",Consolas,monospace;
  --serif:"IBM Plex Serif",Georgia,"Times New Roman",serif;
  --sans:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --script:"Yellowtail","Brush Script MT",cursive;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:15px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit}
::selection{background:rgba(36,128,237,.16)}

/* ---------- layout ---------- */
.wrap{
  max-width:812px; margin:0 auto; padding:52px 28px 120px;
  display:grid; grid-template-columns:166px minmax(0,1fr); gap:54px;
}
.rail{position:sticky; top:52px; align-self:start}
.content{min-width:0}

/* ---------- brand + nav ---------- */
.brand{display:block; text-decoration:none; line-height:0; margin-bottom:30px}
.brand-logo{display:block; width:80px; max-width:100%; height:auto}
/* Hamburger (two bars). Hidden on desktop; toggles the rail nav on mobile. */
.menu-toggle{
  display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px;
  width:36px; height:36px; padding:0; border:none; background:none; cursor:pointer;
}
.menu-toggle span{display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .2s ease}
.rail.open .menu-toggle span:first-child{transform:translateY(3.5px) rotate(45deg)}
.rail.open .menu-toggle span:last-child{transform:translateY(-3.5px) rotate(-45deg)}
nav{font-size:14px}
.nav-group{margin-bottom:20px}
.nav-group > .grp{
  font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ghost); margin:0 0 8px;
}
.nav-link{
  display:flex; justify-content:space-between; align-items:baseline; gap:8px;
  text-decoration:none; color:var(--muted); padding:3px 0; transition:color .12s;
}
.nav-link:hover{color:var(--ink)}
.nav-link.active{color:var(--ink); font-weight:500}
.nav-link .ct{font-family:var(--mono); font-size:10.5px; color:var(--ghost)}
.rail-foot{margin-top:26px; font-family:var(--mono); font-size:10.5px; color:var(--ghost); line-height:1.6}

/* ---------- sidebar email opt-in ---------- */
.optin{width:100%; margin:4px 0 22px; background:var(--card); padding:12px; border-radius:20px}
.optin-lead{font-size:12px; color:var(--ink-78); line-height:1.45; margin:0 0 9px}
.optin-form{display:flex; flex-direction:column; gap:7px; margin-bottom:0}
.optin-input{
  width:100%; font-family:var(--sans); font-size:12.5px; color:var(--ink); background:var(--paper);
  border:1px solid var(--border); border-radius:8px; padding:8px 10px;
}
.optin-input::placeholder{color:var(--faint)}
.optin-input:focus{outline:none; border-color:var(--ghost); box-shadow:0 0 0 3px rgba(0,0,0,.03)}
.optin-btn{
  font-family:var(--sans); font-size:12.5px; font-weight:500; color:#fff; background:var(--accent);
  border:none; border-radius:100px; padding:9px 12px; cursor:pointer; transition:opacity .12s;
}
.optin-btn:hover{opacity:.9}
.optin-done{font-size:12px; color:var(--ink-78); line-height:1.45; margin:0}
.optin-done b{color:var(--accent); font-weight:600}

/* ---------- hero ---------- */
h1{
  font-family:var(--serif); font-weight:500; font-size:30px; line-height:1.22;
  color:var(--ink-85); margin:0; letter-spacing:-.005em;
}
.ul{text-decoration:underline; text-decoration-color:var(--accent); text-decoration-thickness:2px; text-underline-offset:4px}
.lede{color:var(--ink-65); font-size:15px; margin:18px 0 0; max-width:62ch}

/* ---------- toolbar (sort + category filter) ---------- */
/* Nested-radius rule: outer = inner + padding. Inner controls are 8px and the
   toolbar padding is a uniform 8px, so the toolbar radius is 16px and both
   dropdowns stay concentric with the toolbar's corners. */
.toolbar{
  display:flex; justify-content:space-between; align-items:center; gap:10px 16px; flex-wrap:wrap;
  background:var(--card); border-radius:16px; padding:8px; margin:24px 0 6px;
}
.filter{
  font-family:var(--sans); font-size:13px; color:var(--ink-78); background:var(--paper);
  border:1px solid var(--border); border-radius:8px; height:32px; padding:0 30px 0 11px; cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat; background-position:right 11px center;
}
.filter:focus{outline:none; border-color:var(--ghost); box-shadow:0 0 0 3px rgba(0,0,0,.03)}
.activefilter{font-size:12.5px; color:var(--muted); margin:14px 0 0}
.activefilter b{color:var(--ink-78); font-weight:600}
.activefilter a{color:var(--accent); text-decoration:none; margin-left:8px}
.activefilter a:hover{text-decoration:underline}

/* ---------- section ---------- */
.section{border-top:1px solid var(--hair); padding-top:16px; margin-top:34px}
.section:first-of-type{margin-top:28px}
/* About FAQ: no divider lines, spacing only. */
.section.faq{border-top:none; padding-top:0}
/* "More in …" heading: a light uppercase label, no divider. */
.section.more{border-top:none; padding-top:0}
.section.more h2{font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--faint)}
.section-head h2 a{color:inherit; text-decoration:none}
.section-head h2 a:hover{color:var(--accent)}
/* Sitemap page lists. */
.sitemap-list{list-style:none; margin:8px 0 0; padding:0; columns:200px; column-gap:28px}
.sitemap-list li{margin:0 0 5px; break-inside:avoid}
.sitemap-list a{color:var(--ink-65); text-decoration:none; font-size:14px}
.sitemap-list a:hover{color:var(--accent); text-decoration:underline}
.section-head{display:flex; justify-content:space-between; align-items:baseline; gap:12px}
.section-head h2{font-size:13px; font-weight:550; color:var(--ink-78); margin:0; letter-spacing:.01em}
.section-more{font-size:12px; color:var(--muted); text-decoration:none; white-space:nowrap}
.section-more:hover{color:var(--accent)}
.section-blurb{color:var(--faint); font-size:13px; margin:4px 0 6px}

/* ---------- favicon + DR box (shared squared style) ---------- */
.fav{
  width:24px; height:24px; border-radius:3px; border:1px solid var(--hair);
  background:var(--paper); object-fit:contain; flex:0 0 auto; vertical-align:middle; padding:4px;
}
.fav-lg{width:24px; height:24px; border-radius:4px; vertical-align:-4px; margin-right:6px}
.dr2{
  display:inline-flex; align-items:center; gap:3px; white-space:nowrap;
  font-family:var(--mono); font-size:11px; line-height:1.4; padding:2px 5px;
  border:1px solid var(--border); border-radius:5px; color:var(--ink-78);
}
.dr2 .l{font-size:11px; letter-spacing:.02em; color:var(--faint)}
/* Monochrome DR — darker shade = higher rating. */
.dr2.t1{border-color:rgba(0,0,0,.16); color:var(--ink)}
.dr2.t2{color:var(--ink-78)}
.dr2.t3{background:transparent; color:var(--muted)}

/* ---------- listing rows ---------- */
.row{padding:15px 0; border-top:1px solid var(--hair)}
.rows .row:first-child{border-top:none}
.row-title{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.row-title a.name{font-size:15px; font-weight:500; color:var(--ink); text-decoration:none}
.row-title a.name:hover{text-decoration:underline; text-decoration-color:var(--accent); text-underline-offset:3px}
.row-title .dom{font-family:var(--mono); font-size:11px; color:var(--faint)}
.ext{display:inline-flex; align-items:center; color:var(--faint); text-decoration:none; margin-left:-3px; transition:color .12s}
.ext:hover{color:var(--accent)}
.ext svg{display:block}
.row-desc{color:var(--ink-65); font-size:13.5px; line-height:1.55; margin:6px 0 0}
.row-meta{display:flex; align-items:center; gap:4px; flex-wrap:wrap; margin-top:9px}

/* ---------- chips ---------- */
.chip{
  font-family:var(--sans); font-size:11px; line-height:1.4; padding:2px 7px; border-radius:5px;
  border:1px solid var(--border); color:var(--muted); background:var(--paper); white-space:nowrap;
}
a.chip{text-decoration:none; cursor:pointer; transition:border-color .12s, color .12s}
a.chip:hover{border-color:var(--ghost); color:var(--ink-78)}
/* Monochrome chips — meaning comes from the label, not colour.
   badge required is a filled grey flag. */
.chip.badge{color:var(--ink-78); border-color:var(--ghost); background:var(--card)}
/* dofollow / nofollow: same colour; direction shown by an arrow. */
.chip.dofollow,.chip.nofollow{display:inline-flex; align-items:center; gap:3px}
.larr{display:block; flex:none}

/* ---------- prose / detail ---------- */
.crumb{font-size:12px; color:var(--faint); margin-bottom:18px}
.crumb a{color:var(--muted); text-decoration:none}
.crumb a:hover{color:var(--accent)}
h1 .dr2{vertical-align:middle; margin-left:10px}
.prose{color:var(--ink-65); font-size:15px; max-width:62ch}
.prose p{margin:14px 0}
/* Buttons echo the logo: coral pill, white label. */
.btn{
  display:inline-flex; align-items:center; gap:7px; margin-top:20px;
  background:var(--accent); color:#fff; text-decoration:none;
  font-family:var(--sans); font-size:13.5px; font-weight:500;
  padding:10px 18px; border-radius:100px; border:none; cursor:pointer; transition:opacity .12s;
}
.btn:hover{opacity:.9}
/* Detail page: Visit website + Suggest a change share a row, flush under the text. */
.detail-actions{display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap}
.detail-actions .btn{margin-top:0}
.suggest-edit{color:var(--accent); text-decoration:underline; text-underline-offset:3px; font-size:13px; white-space:nowrap}
.suggest-edit:hover{opacity:.8}

/* ---------- form (submit page) ---------- */
.form{max-width:54ch; margin-top:26px}
.field{margin-bottom:16px}
.field label{display:block; font-size:12.5px; font-weight:500; color:var(--ink-78); margin-bottom:6px}
.field .opt{color:var(--faint); font-weight:400}
.input,.textarea{
  width:100%; font-family:var(--sans); font-size:14px; color:var(--ink); background:var(--paper);
  border:1px solid var(--border); border-radius:8px; padding:9px 12px;
}
.input::placeholder,.textarea::placeholder{color:var(--faint)}
.input:focus,.textarea:focus{outline:none; border-color:var(--ghost); box-shadow:0 0 0 3px rgba(0,0,0,.03)}
.textarea{min-height:92px; line-height:1.5; resize:vertical}
.form .field:last-of-type{margin-bottom:6px}
.form .btn{margin-top:2px}
.facts{margin-top:28px}
.fact{display:flex; justify-content:space-between; gap:16px; padding:11px 0; border-bottom:1px solid var(--hair); font-size:13.5px}
.fact:last-child{border-bottom:none}
.fact .k{color:var(--faint)}
.fact .v{color:var(--ink-78); text-align:right}
.fact .v a{text-decoration:underline; text-decoration-color:var(--ghost); text-underline-offset:3px; transition:text-decoration-color .12s, color .12s}
.fact .v a:hover{text-decoration-color:var(--accent); color:var(--accent)}

/* ---------- footer ---------- */
.foot{display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  margin-top:30px; padding-top:18px; border-top:1px solid var(--hair);
  font-size:12px; color:var(--faint)}
.foot a{color:var(--muted); text-decoration:none}
.foot a:hover{color:var(--accent)}
.note{font-size:12px; color:var(--faint); background:var(--card); border:1px solid var(--hair);
  border-radius:9px; padding:11px 13px; margin-top:20px; line-height:1.55}

/* ---------- responsive ---------- */
@media (max-width:720px){
  .wrap{grid-template-columns:1fr; gap:0; padding:20px 20px 80px}
  .rail{position:static; margin-bottom:24px}
  .rail-head{display:flex; justify-content:space-between; align-items:center}
  .brand{margin-bottom:0}
  .menu-toggle{display:flex}
  nav{display:none; margin-top:22px}
  .rail.open nav{display:block}
  h1{font-size:26px}
}
