/* seo.css — aanvullende stijlen voor de statische SEO-locatiepagina's.
   Hergebruikt de tokens uit het inline :root-blok (zelfde look als de homepage). */

.seo-main { position: relative; z-index: 2; }

/* breadcrumbs */
.crumbs { font-size: 13.5px; color: var(--ink-3); padding: 10px 0 0; }
.crumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; padding: 0; margin: 0; }
.crumbs li { display: inline-flex; align-items: center; gap: 6px; }
.crumbs li::after { content: "›"; color: var(--ink-4); margin-left: 6px; }
.crumbs li:last-child::after { content: ""; }
.crumbs a { color: var(--acc-2); text-decoration: none; }
.crumbs a:hover { text-decoration: underline; }
.crumbs li[aria-current] { color: var(--ink-2); }

/* page head */
.seo-hero { padding: 26px 0 8px; }
.seo-hero h1 { font-size: clamp(30px, 6vw, 50px); margin: 12px 0 14px; }
.seo-hero .lead { max-width: 720px; }
.seo-hero-grid { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 30px; align-items: center; }
.seo-hero-img { display: flex; justify-content: center; }
.seo-hero-img img { width: 100%; max-width: 360px; height: auto; filter: drop-shadow(0 30px 50px rgba(20,30,60,0.22)); }
@media (max-width: 820px){ .seo-hero-grid { grid-template-columns: 1fr; } .seo-hero-img { order: -1; max-width: 280px; margin: 0 auto; } }

/* generic content section */
.seo-sec { padding: 30px 0; }
.seo-sec h2 { font-size: clamp(24px, 4.6vw, 34px); margin-bottom: 14px; }
.seo-sec h3 { font-size: 20px; margin: 18px 0 8px; }
.seo-sec p { color: var(--ink-2); margin-bottom: 12px; max-width: 760px; }
.seo-list { list-style: none; display: grid; gap: 10px; margin: 14px 0; max-width: 760px; }
.seo-list li { position: relative; padding-left: 26px; color: var(--ink-2); }
.seo-list li::before { content: ""; position: absolute; left: 0; top: 7px; width: 14px; height: 14px; border-radius: 50%;
  background: var(--acc-soft); box-shadow: 0 0 0 4px rgba(10,132,255,0.06); }
.seo-list li b { color: var(--ink); font-weight: 600; }

/* CTA card */
.seo-cta { margin: 22px 0; padding: 26px; text-align: center; }
.seo-cta h2 { margin-bottom: 8px; }
.seo-cta p { margin: 0 auto 16px; max-width: 560px; }
.seo-cta .btn { font-size: 17px; padding: 16px 30px; }

/* model block + thumbnails */
.model-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; margin-top: 16px; }
.model-card { padding: 14px; text-align: center; text-decoration: none; color: inherit; display: block; }
.model-card img { width: 100%; max-width: 120px; height: auto; margin: 0 auto 8px; display: block; }
.model-card b { display: block; font-size: 14.5px; }
.model-card span { font-size: 13px; color: var(--ink-3); }

/* area / internal links */
.link-cloud { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.link-cloud a { text-decoration: none; }

/* FAQ */
.faq { max-width: 800px; }
.faq details { border-bottom: 1px solid var(--line); padding: 4px 0; }
.faq summary { cursor: pointer; font-weight: 600; padding: 14px 0; list-style: none; display: flex; justify-content: space-between; gap: 12px; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--acc-2); font-weight: 400; font-size: 22px; line-height: 1; }
.faq details[open] summary::after { content: "–"; }
.faq details p { padding: 0 0 14px; color: var(--ink-2); }

/* footer disclaimer */
.foot-disclaimer { font-size: 12.5px; color: var(--ink-4); max-width: 620px; margin-top: 8px; }

/* nav cta on subpages reuses .btn */
.seo-trust { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 16px; }
.seo-trust .ht { display: inline-flex; align-items: center; gap: 7px; font-size: 14px; color: var(--ink-2); font-weight: 500; }
.seo-trust .ht svg { color: var(--acc-2); }
