/* ============================================================
   tankpuls-pages.css — shared styles for subpages
   Extends tankpuls.css. Use on simple content pages.
   ============================================================ */

/* Document page shell (content-heavy subpages) */
.doc{
  padding-top:clamp(64px, 8vw, 112px);
  padding-bottom:clamp(80px, 10vw, 140px);
}
.doc-head{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:24px;
  align-items:baseline;
  font-family:var(--f-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--n-500);
  padding-bottom:20px;
  border-bottom:1px solid var(--n-200);
  margin-bottom:40px;
}
.doc-head .n{color:var(--ink);font-weight:500;}
.doc-head .l{color:var(--n-700);}
.doc-head .r{color:var(--n-400);}

.doc-title{
  font-family:var(--f-display);
  font-size:clamp(40px, 6vw, 72px);
  font-weight:500;
  letter-spacing:-.035em;
  line-height:1.02;
  margin-bottom:24px;
  color:var(--ink);
  max-width:900px;
  text-wrap:balance;
}
.doc-title em{font-style:normal;color:var(--mint-deep);}

.doc-lede{
  font-size:19px;
  line-height:1.5;
  color:var(--n-700);
  max-width:640px;
  margin-bottom:64px;
}

/* Two-column docs layout: sticky TOC + prose */
.doc-layout{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:64px;
  align-items:start;
}
.doc-toc{
  position:sticky;
  top:88px;
  font-family:var(--f-mono);
  font-size:12px;
}
.doc-toc h5{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--n-500);
  font-weight:500;
  margin-bottom:16px;
}
.doc-toc ol{list-style:none;display:flex;flex-direction:column;gap:2px;counter-reset:toc;}
.doc-toc a{
  display:grid;
  grid-template-columns:28px 1fr;
  gap:10px;
  padding:8px 0 8px 12px;
  margin-left:-12px;
  color:var(--n-700);
  border-left:2px solid transparent;
  transition:all 160ms;
}
.doc-toc a::before{
  counter-increment:toc;
  content:counter(toc, decimal-leading-zero);
  color:var(--n-400);
}
.doc-toc a:hover,.doc-toc a.is-active{
  color:var(--ink);
  border-left-color:var(--mint);
  background:var(--n-50);
}

/* Prose */
.prose{max-width:720px;}
.prose h2{
  font-family:var(--f-display);
  font-size:28px;
  font-weight:500;
  letter-spacing:-.02em;
  line-height:1.15;
  margin:56px 0 16px;
  color:var(--ink);
  scroll-margin-top:88px;
}
.prose h2:first-child{margin-top:0;}
.prose h2::before{
  content:"";
  display:inline-block;
  width:16px;height:1px;
  background:var(--mint);
  vertical-align:middle;
  margin-right:12px;
  transform:translateY(-4px);
}
.prose h3{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:500;
  letter-spacing:-.01em;
  margin:32px 0 10px;
  color:var(--ink);
}
.prose p{
  font-size:15.5px;
  line-height:1.65;
  color:var(--n-700);
  margin-bottom:16px;
  text-wrap:pretty;
}
.prose p b, .prose strong{color:var(--ink);font-weight:500;}
.prose ul,.prose ol{
  margin:0 0 16px 0;
  padding-left:20px;
  color:var(--n-700);
}
.prose li{
  font-size:15.5px;
  line-height:1.65;
  margin-bottom:6px;
}
.prose ul li::marker{color:var(--mint-deep);}
.prose a{
  color:var(--ink);
  border-bottom:1px solid var(--n-300);
  transition:border-color 160ms, color 160ms;
}
.prose a:hover{color:var(--mint-deep);border-bottom-color:var(--mint);}
.prose hr{
  border:0;border-top:1px solid var(--n-200);margin:48px 0;
}
.prose .callout{
  background:var(--n-50);
  border:1px solid var(--n-200);
  border-left:3px solid var(--mint);
  border-radius:var(--r-sm);
  padding:20px 24px;
  margin:24px 0;
}
.prose .callout b{color:var(--ink);font-weight:500;}

/* Meta card — publication / contact */
.meta-card{
  background:var(--n-50);
  border:1px solid var(--n-200);
  border-radius:var(--r-md);
  padding:24px;
  margin-bottom:40px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.meta-card dt{
  font-family:var(--f-mono);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--n-500);
  margin-bottom:6px;
}
.meta-card dd{
  font-size:14px;
  color:var(--ink);
  font-weight:500;
  line-height:1.55;
}
.meta-card dd.mono{font-family:var(--f-mono);font-weight:400;}

/* Tables */
.prose table{
  width:100%;
  border-collapse:collapse;
  margin:16px 0 24px;
  font-size:14px;
}
.prose th, .prose td{
  text-align:left;
  padding:10px 12px;
  border-bottom:1px solid var(--n-200);
  vertical-align:top;
}
.prose th{
  font-family:var(--f-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--n-600);
  font-weight:500;
  background:var(--n-50);
}
.prose td{color:var(--n-700);}
.prose td b{color:var(--ink);font-weight:500;}
.prose td.mono, .prose th.mono{font-family:var(--f-mono);}

/* Code blocks */
.prose code{
  font-family:var(--f-mono);
  font-size:.88em;
  background:var(--n-100);
  padding:1px 6px;
  border-radius:4px;
  color:var(--ink);
}
.prose pre{
  background:var(--ink);
  color:var(--paper);
  padding:20px 24px;
  border-radius:var(--r-md);
  overflow-x:auto;
  font-family:var(--f-mono);
  font-size:13px;
  line-height:1.6;
  margin:16px 0 24px;
  border:1px solid var(--n-800);
}
.prose pre code{background:transparent;padding:0;color:inherit;font-size:inherit;}
.prose pre .c-key{color:#8DE5D8;}
.prose pre .c-str{color:#E4A33A;}
.prose pre .c-num{color:#14D8C0;}
.prose pre .c-kw{color:#9CA8B4;}
.prose pre .c-com{color:#5A6B7C;font-style:italic;}

/* API endpoint card */
.endpoint{
  background:var(--paper);
  border:1px solid var(--n-200);
  border-radius:var(--r-md);
  overflow:hidden;
  margin:16px 0 24px;
}
.endpoint-head{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 20px;
  background:var(--n-50);
  border-bottom:1px solid var(--n-200);
  font-family:var(--f-mono);
  font-size:13px;
}
.endpoint-method{
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:500;
  letter-spacing:.1em;
  padding:4px 8px;
  border-radius:4px;
  text-transform:uppercase;
}
.endpoint-method.get{background:var(--mint-soft);color:var(--mint-deep);}
.endpoint-method.post{background:rgba(228,163,58,.15);color:#B87A1E;}
.endpoint-path{
  color:var(--ink);
  font-weight:500;
  font-family:var(--f-mono);
  flex:1;
  font-size:13px;
}
.endpoint-desc{
  padding:16px 20px;
  font-size:14px;
  color:var(--n-700);
  line-height:1.55;
}
.endpoint-params{
  border-top:1px dashed var(--n-200);
  padding:14px 20px;
  font-family:var(--f-mono);
  font-size:12px;
  color:var(--n-600);
  display:grid;
  grid-template-columns:140px 80px 1fr;
  gap:8px 20px;
}
.endpoint-params b{color:var(--ink);font-weight:500;}
.endpoint-params .type{color:var(--mint-deep);}

/* Page hero (lighter than landing hero) */
.page-hero{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(80px, 10vw, 140px) 0 clamp(72px, 9vw, 112px);
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(700px 400px at 85% 20%, rgba(20,216,192,.14) 0%, transparent 60%),
    radial-gradient(500px 300px at 10% 90%, rgba(20,216,192,.06) 0%, transparent 60%);
  pointer-events:none;
}
.page-hero::after{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 80%);
  pointer-events:none;
}
.page-hero-inner{position:relative;z-index:1;}
.page-hero .breadcrumb{
  font-family:var(--f-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--n-400);
  margin-bottom:24px;
  display:flex;
  gap:10px;
  align-items:center;
}
.page-hero .breadcrumb a{color:var(--n-400);transition:color 160ms;}
.page-hero .breadcrumb a:hover{color:var(--mint);}
.page-hero .breadcrumb .sep{color:var(--n-600);}
.page-hero .breadcrumb .cur{color:var(--paper);}
.page-hero h1{
  font-family:var(--f-display);
  font-size:clamp(40px, 6vw, 80px);
  font-weight:500;
  letter-spacing:-.035em;
  line-height:1;
  margin-bottom:20px;
  text-wrap:balance;
  max-width:900px;
}
.page-hero h1 em{font-style:normal;color:var(--mint);}
.page-hero .lede{
  font-size:19px;
  line-height:1.5;
  color:var(--n-300);
  max-width:620px;
}

/* Generic reveal already in tankpuls.css */

@media (max-width: 900px){
  .doc-layout{grid-template-columns:1fr;gap:32px;}
  .doc-toc{position:static;border-bottom:1px solid var(--n-200);padding-bottom:24px;}
  .meta-card{grid-template-columns:1fr 1fr;}
  .endpoint-params{grid-template-columns:1fr;gap:4px;}
  .endpoint-params .type{color:var(--mint-deep);font-size:11px;}
}
@media (max-width: 560px){
  .meta-card{grid-template-columns:1fr;}
  .doc-head .r{display:none;}
}

/* ============================================================
   City pages — /tankpreise/<slug>/
   ============================================================ */

/* Hero with embedded map */
.city-hero{
  background:var(--ink);
  color:var(--paper);
  position:relative;
  overflow:hidden;
  padding:clamp(80px, 10vw, 130px) 0 0;
}
.city-hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(700px 400px at 85% 20%, rgba(20,216,192,.14) 0%, transparent 60%),
    radial-gradient(500px 300px at 10% 90%, rgba(20,216,192,.06) 0%, transparent 60%);
  pointer-events:none;z-index:1;
}
.city-hero-inner{position:relative;z-index:2;}
.city-hero .breadcrumb{
  font-family:var(--f-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--n-400);
  margin-bottom:20px;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
}
.city-hero .breadcrumb a{color:var(--n-400);transition:color 160ms;}
.city-hero .breadcrumb a:hover{color:var(--mint);}
.city-hero .breadcrumb .sep{color:var(--n-600);}
.city-hero .breadcrumb .cur{color:var(--paper);}
.city-hero h1{
  font-family:var(--f-display);
  font-size:clamp(38px, 5.5vw, 72px);
  font-weight:500;
  letter-spacing:-.035em;
  line-height:1;
  margin-bottom:18px;
  text-wrap:balance;
  max-width:900px;
}
.city-hero h1 em{font-style:normal;color:var(--mint);}
.city-hero .lede{
  font-size:18px;
  line-height:1.5;
  color:var(--n-300);
  max-width:640px;
  margin-bottom:32px;
}
.city-hero .city-stats{
  display:flex;gap:32px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:12px;
  color:var(--n-400);
  border-top:1px solid rgba(255,255,255,.08);
  padding:20px 0 0;
}
.city-hero .city-stats b{
  display:block;
  font-family:var(--f-display);
  font-size:24px;font-weight:500;
  color:var(--paper);
  letter-spacing:-.01em;
  margin-bottom:2px;
  font-variant-numeric:tabular-nums;
}
.city-hero .city-stats span{
  text-transform:uppercase;letter-spacing:.1em;font-size:10px;
}

/* City map — full-width, lives between hero and content */
.city-map-wrap{
  background:var(--ink);
  padding:40px 0 56px;
  position:relative;
  z-index:0;
}
.city-map{
  height:clamp(360px, 50vh, 520px);
  background:#0c1822;
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  overflow:hidden;
  position:relative;
  z-index:0;
}
.city-map.is-locked{cursor:pointer;}
.city-map .leaflet-control-attribution{
  background:rgba(0,0,0,.4);
  color:rgba(255,255,255,.55);
  font-size:10px;
}
.city-map .leaflet-control-attribution a{color:rgba(255,255,255,.7);}
.city-map img.leaflet-tile{
  filter:hue-rotate(-8deg) saturate(1.35);
}

/* City content — two column meta + prose */
.city-info{padding:80px 0 64px;}
.city-grid{
  display:grid;
  grid-template-columns:1fr 280px;
  gap:64px;
  align-items:start;
}
.city-prose{max-width:720px;}
.city-prose h2{
  font-family:var(--f-display);
  font-size:28px;font-weight:500;
  letter-spacing:-.02em;
  line-height:1.15;
  margin-bottom:18px;color:var(--ink);
}
.city-prose h2::before{
  content:"";display:inline-block;
  width:16px;height:1px;background:var(--mint);
  vertical-align:middle;margin-right:12px;
  transform:translateY(-4px);
}
.city-prose p{
  font-size:15.5px;line-height:1.65;
  color:var(--n-700);margin-bottom:14px;
  text-wrap:pretty;
}
.city-prose p b{color:var(--ink);font-weight:500;}
.city-meta{
  position:sticky;top:88px;
  background:var(--n-50);
  border:1px solid var(--n-200);
  border-radius:var(--r-md);
  padding:20px 24px;
}
.city-meta dl{display:grid;grid-template-columns:1fr;gap:14px;}
.city-meta dt{
  font-family:var(--f-mono);
  font-size:10px;text-transform:uppercase;
  letter-spacing:.1em;color:var(--n-500);
  margin-bottom:4px;
}
.city-meta dd{
  font-size:14px;color:var(--ink);font-weight:500;
  line-height:1.45;
}
.city-meta dd.live::before{
  content:"";display:inline-block;
  width:7px;height:7px;border-radius:999px;
  background:var(--mint-deep);
  margin-right:8px;vertical-align:1px;
  box-shadow:0 0 0 3px rgba(20,216,192,.18);
}

/* Station list */
.city-stations{
  padding:0 0 80px;
  background:var(--n-50);
  padding:64px 0 80px;
  border-top:1px solid var(--n-200);
}
.city-stations .stations-head{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.city-stations h2{
  font-family:var(--f-display);
  font-size:28px;font-weight:500;
  letter-spacing:-.02em;color:var(--ink);
}
.city-stations .muted{color:var(--n-500);font-size:13px;font-family:var(--f-mono);}
.fuel-tabs{
  display:flex;gap:4px;
  background:var(--paper);
  border:1px solid var(--n-200);
  border-radius:999px;
  padding:3px;
}
.fuel-tabs button{
  font-family:var(--f-mono);
  font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;
  padding:8px 14px;
  border:0;background:transparent;color:var(--n-600);
  border-radius:999px;cursor:pointer;
  transition:all 160ms;
}
.fuel-tabs button:hover{color:var(--ink);}
.fuel-tabs button.is-active{background:var(--ink);color:var(--paper);}

.station-list{
  display:grid;grid-template-columns:1fr;gap:8px;
}
.station-row{
  display:grid;
  grid-template-columns:32px 36px 1fr auto;
  gap:14px;align-items:center;
  background:var(--paper);
  border:1px solid var(--n-200);
  border-radius:var(--r-sm);
  padding:14px 18px;
  transition:border-color 160ms;
}
.station-row:hover{border-color:var(--n-300);}
.station-row__rank{
  font-family:var(--f-mono);
  font-size:11px;color:var(--n-400);
  letter-spacing:.05em;
}
.station-row__logo{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  background:var(--n-50);border-radius:6px;
  flex-shrink:0;
}
.station-row__logo img{
  width:24px;height:24px;object-fit:contain;
}
.station-row__main{min-width:0;}
.station-row__name{
  font-size:14px;font-weight:500;color:var(--ink);
  margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.station-row__addr{
  font-size:12px;color:var(--n-500);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.station-row__price{
  font-family:var(--f-display);
  font-size:22px;font-weight:500;letter-spacing:-.015em;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.station-row__price small{font-size:.55em;vertical-align:.55em;color:var(--n-500);font-weight:400;}
.station-row.is-cheapest{
  border-color:var(--mint);
  background:var(--mint-soft);
}
.station-row.is-cheapest .station-row__price{color:var(--mint-deep);}
.station-row.is-loading{
  height:64px;background:var(--n-100);animation:tp-pulse 1.4s ease-in-out infinite;
}
@keyframes tp-pulse{0%,100%{opacity:.6;}50%{opacity:1;}}

.station-row.station-row--more{
  display:flex;justify-content:center;
  padding:18px;background:var(--paper);
  font-size:13px;color:var(--n-600);
  font-family:var(--f-mono);
}

/* City FAQ — collapsible answers, also drives FAQPage rich snippet */
.city-faq{
  padding:72px 0 0;border-top:1px solid var(--n-200);
}
.city-faq h2{
  font-family:var(--f-display);
  font-size:28px;font-weight:500;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:8px;
}
.city-faq p.muted{
  color:var(--n-500);font-size:13px;font-family:var(--f-mono);
  margin-bottom:28px;
}
.city-faq__list{max-width:780px;}
.city-faq__item{
  border-bottom:1px solid var(--n-200);
}
.city-faq__item:first-of-type{border-top:1px solid var(--n-200);}
.city-faq__item summary{
  list-style:none;
  display:grid;
  grid-template-columns:36px 1fr 24px;
  gap:14px;align-items:start;
  padding:20px 0;cursor:pointer;
}
.city-faq__item summary::-webkit-details-marker{display:none;}
.city-faq__item .num{
  font-family:var(--f-mono);font-size:11px;
  color:var(--n-400);letter-spacing:.08em;
  padding-top:2px;
}
.city-faq__item .q{
  font-family:var(--f-display);
  font-size:16px;font-weight:500;color:var(--ink);
  line-height:1.4;
}
.city-faq__item .plus{
  width:18px;height:18px;position:relative;display:inline-block;
  align-self:start;margin-top:1px;
}
.city-faq__item .plus::before,
.city-faq__item .plus::after{
  content:"";position:absolute;
  background:var(--n-500);
  transition:transform 200ms;
}
.city-faq__item .plus::before{left:0;right:0;top:8px;height:1.5px;}
.city-faq__item .plus::after{top:0;bottom:0;left:8px;width:1.5px;}
.city-faq__item[open] .plus::after{transform:scaleY(0);}
.city-faq__item:hover .q{color:var(--mint-deep);}
.city-faq__item .ans{
  padding:0 0 22px 50px;
}
.city-faq__item .ans p{
  font-size:15px;line-height:1.65;color:var(--n-700);
  margin:0;
}

/* Nearby cities */
.nearby{padding:80px 0;border-top:1px solid var(--n-200);}
.nearby h2{
  font-family:var(--f-display);
  font-size:28px;font-weight:500;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:8px;
}
.nearby p.muted{
  color:var(--n-500);font-size:13px;font-family:var(--f-mono);
  margin-bottom:28px;
}
.nearby-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:10px;
}
.nearby-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;
  background:var(--paper);
  border:1px solid var(--n-200);
  border-radius:var(--r-sm);
  transition:all 160ms;
  font-size:14px;color:var(--ink);
}
.nearby-card:hover{
  border-color:var(--mint);
  background:var(--mint-soft);
  transform:translateY(-1px);
}
.nearby-card b{font-weight:500;}
.nearby-card span{font-size:11px;color:var(--n-500);font-family:var(--f-mono);}

/* CTA band on city pages */
.city-cta{
  padding:80px 0;background:var(--ink);color:var(--paper);
  position:relative;overflow:hidden;
}
.city-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 500px at 70% 30%, rgba(20,216,192,.16) 0%, transparent 60%);
  pointer-events:none;
}
.city-cta-inner{position:relative;z-index:1;text-align:center;}
.city-cta h2{
  font-family:var(--f-display);
  font-size:clamp(28px, 4vw, 44px);
  font-weight:500;letter-spacing:-.025em;
  margin-bottom:14px;text-wrap:balance;
}
.city-cta p{
  color:var(--n-300);font-size:17px;
  max-width:540px;margin:0 auto 28px;line-height:1.5;
}

/* Cities index page (/tankpreise/) */
/* Stadt-Verzeichnis: Suche + Letter-Jumps */
.cities-search{
  margin:0 0 32px;
  position:sticky;
  top:64px;
  z-index:40;
  background:linear-gradient(180deg, var(--paper) 60%, rgba(255,255,255,0.0) 100%);
  padding:14px 0 18px;
}
.cities-search-wrap{
  display:flex;
  align-items:center;
  gap:14px;
  background:var(--paper);
  border:1px solid var(--n-300);
  border-radius:999px;
  padding:4px 8px 4px 22px;
  transition:border-color 160ms, box-shadow 160ms;
  box-shadow:0 1px 0 var(--n-100);
}
.cities-search-wrap:focus-within{
  border-color:var(--mint-deep);
  box-shadow:0 0 0 4px var(--mint-soft), 0 1px 0 var(--n-100);
}
.cities-search-wrap svg{
  color:var(--n-500);
  flex-shrink:0;
}
.cities-search-wrap input{
  flex:1;
  border:0;
  background:transparent;
  padding:14px 0;
  font-family:var(--f-display);
  font-size:16px;
  color:var(--ink);
  outline:none;
  min-width:0;
}
.cities-search-wrap input::placeholder{color:var(--n-500);}
.cities-search-wrap input::-webkit-search-cancel-button{
  -webkit-appearance:none;appearance:none;
  width:16px;height:16px;
  background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%239ca3af" stroke-width="2.5" stroke-linecap="round"><path d="M18 6 6 18M6 6l12 12"/></svg>') center/contain no-repeat;
  cursor:pointer;
}
.cities-search-count{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--n-600);
  background:var(--n-100);
  border-radius:999px;
  padding:6px 12px;
  white-space:nowrap;
  flex-shrink:0;
}

/* Quick-Jump-Leiste A B C ... */
.cities-search-letters{
  display:flex;
  flex-wrap:wrap;
  gap:2px;
  margin-top:12px;
  justify-content:center;
}
.cities-search-letters a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;height:30px;
  border-radius:8px;
  font-family:var(--f-mono);
  font-size:12px;
  color:var(--n-600);
  font-weight:500;
  transition:all 140ms;
}
.cities-search-letters a:hover{
  background:var(--mint-soft);
  color:var(--mint-deep);
}

.cities-search-empty{
  text-align:center;
  color:var(--n-500);
  font-family:var(--f-mono);
  font-size:13px;
  padding:64px 16px;
}

@media (max-width:640px){
  .cities-search{top:60px;}
  .cities-search-wrap{padding:2px 6px 2px 16px;}
  .cities-search-wrap input{font-size:15px;padding:11px 0;}
  .cities-search-count{display:none;}
  .cities-search-letters a{width:26px;height:26px;font-size:11px;}
}

.cities-index{padding:0 0 96px;}
.cities-letter{
  font-family:var(--f-mono);
  font-size:11px;text-transform:uppercase;letter-spacing:.12em;
  color:var(--n-500);
  border-top:1px solid var(--n-200);
  padding-top:24px;margin-top:40px;margin-bottom:16px;
}
.cities-letter:first-of-type{margin-top:0;border-top:0;padding-top:0;}
.cities-list{
  display:grid;grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:6px 24px;
}
.cities-list a{
  display:flex;justify-content:space-between;align-items:baseline;gap:8px;
  padding:8px 0;font-size:14px;color:var(--ink);
  border-bottom:1px solid transparent;
  transition:border-color 160ms;
}
.cities-list a:hover{border-bottom-color:var(--n-300);}
.cities-list a span{
  font-size:10px;color:var(--n-500);font-family:var(--f-mono);
}

@media (max-width: 900px){
  .city-grid{grid-template-columns:1fr;gap:32px;}
  .city-meta{position:static;}
}
@media (max-width: 560px){
  .city-hero .city-stats{gap:18px;}
  .city-hero .city-stats b{font-size:18px;}
  .station-row{grid-template-columns:32px 1fr auto;gap:10px;}
  .station-row__logo{display:none;}
  .station-row__price{font-size:18px;}
}
