/* CityWalkGems blog - merk-stylesheet (stijl van /tour-guide pagina's).
   RESTYLEN = pas de tokens in :root aan en herbouw. Niets anders nodig.
   Losgekoppeld van de Lovable-bundle; jij beheert deze file. */

:root{
  --accent:#f1502e;        /* koraal - merk-accent (logo, stadsnaam, eyebrow) */
  --accent-soft:#ff6a44;
  --ink:#16203a;           /* navy-zwart: koppen + primaire knop */
  --body:#41485a;          /* leestekst */
  --bg:#ffffff;
  --card:#f6f7f9;
  --line:#eceef2;
  --maxw:760px;
  --font-display:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-ui:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--body);font-family:var(--font-ui);
  font-size:18px;line-height:1.75;-webkit-font-smoothing:antialiased}
a{color:inherit}

/* Header (wit, koraal logo-pin + koraal CTA) */
.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:10}
.site-header .bar{max-width:1140px;margin:0 auto;padding:14px 22px;display:flex;
  align-items:center;justify-content:space-between;gap:16px}
.brandmark{display:flex;align-items:center;gap:10px;text-decoration:none}
.brandmark .pin{width:34px;height:34px;border-radius:10px;background:var(--accent);
  display:grid;place-items:center;color:#fff;font-size:18px}
.brandmark .name{font-family:var(--font-ui);font-weight:800;font-size:1.15rem;color:var(--ink);letter-spacing:-.01em}
.header-cta{background:var(--accent);color:#fff;text-decoration:none;font-family:var(--font-ui);
  font-weight:700;font-size:.92rem;padding:11px 18px;border-radius:999px}
.header-cta:hover{background:var(--accent-soft)}

/* Hero met preview-foto + warme overlay */
.hero{position:relative;min-height:clamp(340px,52vh,540px);display:flex;align-items:flex-end;
  overflow:hidden;background-image:linear-gradient(120deg,#ffd9c2,#ffb59a)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,16,14,.12) 0%,rgba(20,16,14,.05) 35%,rgba(20,16,14,.62) 100%)}
.hero-inner{position:relative;z-index:2;max-width:1140px;margin:0 auto;width:100%;padding:38px 22px 40px}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.92);
  color:var(--ink);font-family:var(--font-ui);font-weight:700;font-size:.78rem;
  padding:7px 14px;border-radius:999px}
.badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent)}
.hero h1{font-family:var(--font-display);color:#fff;font-weight:800;line-height:1.08;
  font-size:clamp(2.1rem,5vw,3.4rem);margin:16px 0 8px;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.hero h1 .city{color:var(--accent-soft)}
.hero .meta{font-family:var(--font-ui);color:#fff;opacity:.92;font-size:.95rem;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.hero .credit{position:absolute;right:10px;bottom:6px;z-index:2;font-family:var(--font-ui);
  font-size:.68rem;color:rgba(255,255,255,.82)}
.hero .credit a{color:#fff;text-decoration:underline}

/* Artikel */
.wrap{max-width:var(--maxw);margin:0 auto;padding:40px 22px 64px}
.eyebrow{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;color:var(--accent);font-weight:800}
article h2{font-family:var(--font-display);color:var(--ink);font-size:1.7rem;line-height:1.25;
  font-weight:800;margin:38px 0 12px}
article h3{font-family:var(--font-ui);color:var(--ink);font-size:1.18rem;font-weight:700;margin:26px 0 6px}
article p{margin:0 0 18px}
article strong{color:var(--ink);font-weight:700}
figure{margin:26px 0}
figure img{width:100%;border-radius:16px;display:block}
figcaption{font-family:var(--font-ui);font-size:.78rem;color:#8a8f9b;margin-top:8px}
figcaption a{color:#8a8f9b}

/* CTA-kaart */
.cta{margin:40px 0 0;padding:30px;border:1px solid var(--line);border-radius:20px;background:var(--card);font-family:var(--font-ui)}
.cta .eyebrow{margin-bottom:6px;display:block}
.cta h2{font-family:var(--font-display);margin:0 0 8px;font-size:1.5rem;color:var(--ink)}
.cta p{margin:0 0 16px;color:var(--body)}
.btn-row{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-block;text-decoration:none;font-weight:700;padding:13px 22px;border-radius:999px}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#0e1730}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-soon{background:#eef2f7;color:#7a8aa0;border:1px solid var(--line);cursor:default}

/* Andere tours + taalwissel */
.more{margin:46px 0 0;font-family:var(--font-ui)}
.more h2{font-family:var(--font-display);color:var(--ink);font-size:1.4rem;margin:0 0 14px}
.more ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.more a{display:block;padding:13px 16px;border:1px solid var(--line);border-radius:12px;
  text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem}
.more a:hover{border-color:var(--accent);color:var(--accent)}
.langs{margin:30px 0 0;font-family:var(--font-ui);font-size:.88rem;color:#8a8f9b}
.langs a{color:var(--ink);text-decoration:none;margin-right:12px;border-bottom:2px solid var(--accent)}

/* Index */
.post-list{list-style:none;padding:0;margin:24px 0}
.post-list li{padding:16px 0;border-bottom:1px solid var(--line)}
.post-list a{color:var(--ink);text-decoration:none;font-weight:700;font-size:1.2rem;font-family:var(--font-display)}
.post-list .d{color:#8a8f9b;font-size:.85rem;font-family:var(--font-ui)}

/* Footer */
.site-footer{background:#0e1018;color:#c7c7cf;font-family:var(--font-ui);margin-top:60px}
.site-footer .inner{max-width:1140px;margin:0 auto;padding:46px 22px 26px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px}
.site-footer h4{color:#fff;font-size:.95rem;margin:0 0 12px}
.site-footer a{color:#c7c7cf;text-decoration:none;display:block;padding:4px 0;font-size:.9rem}
.site-footer a:hover{color:var(--accent-soft)}
.site-footer .brand p{font-size:.9rem;line-height:1.6;max-width:34ch}
.site-footer .bottom{border-top:1px solid #1c1e28;text-align:center;padding:18px;font-size:.82rem;color:#8a8a93}
.site-footer .order{color:var(--accent-soft);font-style:italic}

@media(max-width:680px){
  .more ul,.site-footer .inner{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2rem}
}

/* ---- Voorpagina (homepage op de root) ---- */
.home-hero{background:linear-gradient(120deg,#ffffff,#fff5f1);border-bottom:1px solid var(--line);padding:54px 22px 42px}
.home-hero .inner{max-width:1140px;margin:0 auto}
.home-hero h1{font-family:var(--font-display);color:var(--ink);font-weight:800;line-height:1.06;
  font-size:clamp(2.2rem,5vw,3.6rem);margin:.16em 0 .22em;max-width:16ch}
.home-hero h1 .accent{color:var(--accent)}
.home-hero p.lead{font-size:1.12rem;color:var(--body);max-width:56ch;margin:.2em 0 0}
.home-main{max-width:1140px;margin:0 auto;padding:30px 22px 72px}
.home-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 0 22px}
.home-toolbar .count{font-family:var(--font-ui);font-weight:700;color:var(--ink);font-size:.92rem}
.city-search{flex:1;min-width:220px;max-width:340px;padding:11px 16px;border:1px solid var(--line);
  border-radius:999px;font-family:var(--font-ui);font-size:.95rem;color:var(--ink);background:#fff}
.city-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(241,80,46,.12)}
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.city-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:18px 20px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .15s,transform .15s,box-shadow .15s}
.city-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 26px rgba(20,32,58,.09)}
.city-card .city-name{font-family:var(--font-display);font-weight:800;color:var(--ink);font-size:1.22rem;
  text-decoration:none;line-height:1.2}
.city-card .city-name::after{content:"";position:absolute;inset:0}
.city-card:hover .city-name{color:var(--accent)}
.city-card .city-tour{position:relative;z-index:1;font-family:var(--font-ui);font-weight:700;
  font-size:.82rem;color:var(--accent);text-decoration:none;align-self:flex-start}
.city-card .city-tour:hover{text-decoration:underline}
.city-card .city-soon{font-family:var(--font-ui);font-size:.82rem;color:#9aa2b1}
.home-empty{color:#9aa2b1;font-family:var(--font-ui);padding:28px 0}
.home-langs{margin-top:42px;padding-top:22px;border-top:1px solid var(--line);
  font-family:var(--font-ui);font-size:.88rem;color:var(--body)}
.home-langs a{color:var(--accent);text-decoration:none;font-weight:700;margin:0 6px}
.home-langs a:hover{text-decoration:underline}

/* Voorpagina: app-hint op kaart + laatste artikelen */
.city-card .city-go{font-family:var(--font-ui);font-weight:700;font-size:.8rem;color:var(--accent)}
.home-latest{margin-top:48px;padding-top:30px;border-top:1px solid var(--line)}
.home-latest h2{font-family:var(--font-display);color:var(--ink);font-size:1.7rem;font-weight:800;margin:0 0 14px}
.latest-list{list-style:none;margin:0;padding:0}
.latest-list li{display:flex;justify-content:space-between;gap:16px;align-items:baseline;
  padding:12px 4px;border-bottom:1px solid var(--line)}
.latest-list a{font-family:var(--font-ui);font-weight:600;color:var(--ink);text-decoration:none}
.latest-list a:hover{color:var(--accent)}
.latest-list .d{font-family:var(--font-ui);font-size:.82rem;color:#9aa2b1;white-space:nowrap}
.latest-more{display:inline-block;margin-top:16px;font-family:var(--font-ui);font-weight:700;
  color:var(--accent);text-decoration:none}
.latest-more:hover{text-decoration:underline}

/* Interne links: nabije steden (SEO + navigatie) */
.more-cities{margin:32px 0 8px;padding-top:20px;border-top:1px solid var(--line,#e4ebf2)}
.more-cities h2{font-size:1.05rem;margin:0 0 12px}
.more-cities .mc-links{display:flex;flex-wrap:wrap;gap:8px}
.more-cities .mc-links a{display:inline-block;padding:8px 14px;border-radius:999px;
  background:#f3f5f8;color:var(--ink,#1f3147);text-decoration:none;font-weight:600;font-size:.9rem;
  border:1px solid var(--line,#e4ebf2)}
.more-cities .mc-links a:hover{background:#e9eef4}
