/* =========================================================================
   Immospeurder — centrale sitestijl
   Eén bron voor de gedeelde opmaak (kleuren, typografie, header, footer,
   knoppen, kaarten, animaties, responsive). Geëxtraheerd uit index.php
   (het ijkpunt). Pas je hier iets aan, dan verandert het op elke pagina
   die dit bestand inlaadt.
   Lettertypes (Schibsted Grotesk + Instrument Serif) komen uit
   homepage-fonts.css; die wordt apart, niet-renderblokkerend geladen.
   ========================================================================= */

/* ---------- Design-tokens ---------- */
:root{
  --bg:#f4f7f4;
  --ink:#11271b;
  --green:#15924f;
  --green-2:#2fa35e;
  --green-bright:#2bbf72;
  --green-soft:rgba(95,224,138,.1);
  --green-soft-border:rgba(95,224,138,.22);
  --accent:#df9d70;
  --muted:#5f7268;
  --muted-2:#7d9084;
  --muted-3:#8a9b91;
  --ink-soft:#3a4f43;
  --line:rgba(17,39,27,.08);
  --line-2:rgba(17,39,27,.07);
  --maxw:1200px;
  --radius:16px;
  --radius-lg:20px;
  --shadow-card:0 18px 44px rgba(0,0,0,.06);
  --shadow-float:0 24px 60px rgba(0,0,0,.12);
  --font-body:'Schibsted Grotesk',system-ui,-apple-system,sans-serif;
  --font-head:'Instrument Serif',Georgia,'Times New Roman',serif;
}

/* ---------- Basis ---------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.6;
}
img{max-width:100%;height:auto}
a{color:inherit}
::selection{background:rgba(95,224,138,.3)}

/* Toegankelijkheid: zichtbare focus + skip-link + schermlezerstekst */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--green);
  outline-offset:2px;
  border-radius:6px;
}
.skip-to-content{position:absolute;left:-9999px;top:0;z-index:9999;padding:8px 16px;background:#fff;color:var(--green);font-size:14px;text-decoration:none}
.skip-to-content:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Typografie ---------- */
main h1,main h2,main h3{
  font-family:var(--font-head);
  font-weight:400;
  letter-spacing:-.012em;
  line-height:1.06;
  color:var(--ink);
  margin:0 0 .4em;
}
main h1{font-size:clamp(34px,5vw,58px)}
main h2{font-size:clamp(26px,3.6vw,42px)}
main h3{font-size:clamp(20px,2.4vw,27px)}
main h4{font-family:var(--font-body);font-weight:700;font-size:18px;margin:0 0 .5em}

/* ---------- Lay-outhulpjes ---------- */
.imo-container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.imo-container--narrow{max-width:900px}
.imo-section{padding:40px 0}
.imo-section--tight{padding:24px 0}
.imo-grid{display:grid;gap:16px}
.imo-grid--2{grid-template-columns:repeat(2,1fr)}
.imo-grid--3{grid-template-columns:repeat(3,1fr)}
.imo-grid--4{grid-template-columns:repeat(4,1fr)}

/* ---------- Tekstblokken ---------- */
.imo-prose{color:var(--muted);font-size:15px;line-height:1.7;max-width:760px}
.imo-prose p{margin:0 0 14px}
.imo-prose a{color:var(--green);text-decoration:none}
.imo-prose a:hover{text-decoration:underline}
.imo-prose strong{color:var(--ink)}
.imo-lead{color:var(--muted);font-size:17px;line-height:1.6;max-width:620px;margin:0 0 26px}

/* ---------- Badge / label ---------- */
.imo-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:30px;
  background:var(--green-soft);border:1px solid var(--green-soft-border);
  color:var(--green-bright);font-size:12.5px;font-weight:600;letter-spacing:.02em;
}
.imo-badge__dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.imo-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}

/* ---------- Knoppen ---------- */
.imo-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(120deg,var(--green),var(--green-2));
  color:#fff;border:none;border-radius:12px;
  padding:14px 26px;font-weight:700;font-size:15px;font-family:inherit;
  text-decoration:none;cursor:pointer;white-space:nowrap;
  box-shadow:0 6px 16px rgba(95,224,138,.28);
  transition:transform .18s,box-shadow .18s;
}
.imo-btn:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(95,224,138,.4)}
.imo-btn--ghost{
  background:#fff;color:var(--green);
  border:1px solid var(--line);box-shadow:none;
}
.imo-btn--ghost:hover{background:#eef9f1;border-color:var(--green-soft-border)}
.imo-btn--sm{padding:9px 16px;font-size:14px;border-radius:10px}
/* hergebruik uit index.php */
.cta-btn{transition:transform .18s,box-shadow .18s}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(95,224,138,.4)}

/* ---------- Kaarten ---------- */
.imo-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-card)}
.imo-card--lg{border-radius:var(--radius-lg);padding:clamp(22px,4vw,34px)}

/* Linkkaart-hovers (zoals index.php) */
.usp,.showcase,.citycard{transition:transform .18s,border-color .18s,box-shadow .18s}
.usp:hover{background:#eef9f1;border-color:rgba(95,224,138,.28);transform:translateY(-3px)}
.showcase:hover{border-color:rgba(95,224,138,.3);box-shadow:0 22px 50px rgba(0,0,0,.18);transform:translateY(-3px)}
.citycard:hover{background:#eef9f1;border-color:rgba(95,224,138,.28);transform:translateY(-2px)}
.pill{transition:all .18s}
.pill:hover{background:rgba(95,224,138,.1);border-color:rgba(95,224,138,.3);color:var(--green-bright)}

/* ---------- Hero ---------- */
.imo-hero{position:relative;overflow:hidden}
.imo-hero__blob{position:absolute;pointer-events:none;border-radius:50%}
.imo-hero__blob--a{top:-180px;right:-140px;width:560px;height:560px;background:radial-gradient(circle,rgba(95,224,138,.16),transparent 68%)}
.imo-hero__blob--b{bottom:-220px;left:-180px;width:620px;height:620px;background:radial-gradient(circle,rgba(231,201,135,.09),transparent 70%)}
.imo-hero__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:60px 24px 36px}

/* ---------- FAQ-accordion (zoals index.php) ---------- */
.imo-faq{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.imo-faq details{border-bottom:1px solid var(--line-2)}
.imo-faq details:last-child{border-bottom:none}
.imo-faq summary{
  cursor:pointer;list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 20px;font-weight:600;font-size:15px;color:var(--ink);
}
.imo-faq summary::-webkit-details-marker{display:none}
.imo-faq .faq-mark{color:var(--green);font-size:22px;font-weight:300;line-height:1;transition:transform .2s}
.imo-faq details[open] .faq-mark{transform:rotate(45deg)}
.imo-faq .faq-body{padding:0 20px 18px;color:var(--muted);font-size:14px;line-height:1.65}

/* ---------- Breadcrumb ---------- */
.imo-breadcrumb{font-size:13px;color:var(--muted);padding:14px 0 0}
.imo-breadcrumb a{color:var(--muted);text-decoration:none}
.imo-breadcrumb a:hover{color:var(--green)}
.imo-breadcrumb span{margin:0 6px;color:var(--muted-3)}

/* ---------- Formulieren ---------- */
.imo-form{max-width:560px}
.imo-form .form-row{margin:0 0 16px}
.imo-form label{display:block;font-size:13.5px;color:var(--ink-soft);font-weight:600;margin-bottom:6px}
.imo-form input[type=text],.imo-form input[type=email],.imo-form input[type=tel],.imo-form input[type=password],.imo-form input[type=file],.imo-form textarea,.imo-form select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;
  font-size:15px;font-family:inherit;background:#fff;color:var(--ink);
  transition:border-color .18s,box-shadow .18s;
}
.imo-form textarea{resize:vertical;min-height:150px;line-height:1.55}
.imo-form input:focus,.imo-form textarea:focus,.imo-form select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(21,146,79,.12);outline:none}
.imo-form ::placeholder{color:#9aa8a0;opacity:1}
.imo-form .imo-hint{display:block;color:var(--muted);font-size:12.5px;margin-top:6px}
.imo-form .imo-btn{width:100%;margin-top:6px}

/* Inhoudelijke meldingen / feedback */
.imo-note{background:#f1f9f1;border-left:4px solid var(--green);padding:14px 18px;border-radius:8px;margin:18px 0;color:var(--ink);font-size:14px;line-height:1.55}
.imo-note strong{display:block;margin-bottom:6px}
.imo-alert{padding:12px 16px;border-radius:10px;font-weight:600;margin:0 0 16px;font-size:14.5px}
.imo-alert--ok{background:rgba(95,224,138,.16);color:#15803d;border:1px solid var(--green-soft-border)}
.imo-alert--err{background:#fde8e8;color:#b91c1c;border:1px solid #f3c4c4}

/* ---------- Account-layout (mijn account: profiel, wachtwoord, foto's) ---------- */
.imo-account{display:grid;grid-template-columns:240px 1fr;gap:28px;align-items:start}
.imo-account__nav{display:flex;flex-direction:column;gap:18px;position:sticky;top:90px}
.imo-account__group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 12px;box-shadow:var(--shadow-card)}
.imo-account__title{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);padding:6px 12px 8px}
.imo-account__nav a{display:block;padding:9px 12px;border-radius:10px;font-size:14.5px;font-weight:600;color:var(--ink-soft);text-decoration:none;transition:background .16s,color .16s}
.imo-account__nav a:hover{background:#eef9f1;color:var(--green)}
.imo-account__nav a.is-active{background:var(--green-soft);color:var(--green);border:1px solid var(--green-soft-border)}
.imo-account__main{min-width:0}
@media(max-width:760px){.imo-account{grid-template-columns:1fr}.imo-account__nav{position:static;flex-direction:row;flex-wrap:wrap}.imo-account__group{flex:1;min-width:180px}}

/* ---------- Fotobewerker (pand-afbeeldingen) ---------- */
.imo-imgrow{display:flex;gap:18px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line-2)}
.imo-imgrow:last-child{border-bottom:none}
.imo-thumb{width:170px;height:120px;flex:0 0 170px;border-radius:12px;background:#eef2ef;border:1px solid var(--line);position:relative;overflow:hidden}
.imo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.imo-thumb .ph{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted-3);font-size:12px}
.imo-imgrow__body{flex:1;min-width:0}
.imo-imgrow__body h5{margin:0 0 8px;font-size:14px;color:var(--ink)}
.imo-imgrow__body .main{display:inline-block;background:var(--green-soft);color:var(--green);font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;margin-left:6px;text-transform:uppercase}
.imo-imgrow input[type=file]{font-size:14px;width:auto;padding:8px 0;border:none;background:none}
.imo-del{display:inline-block;margin-top:8px;color:#c0392b;font-size:13px;font-weight:600;text-decoration:none}
.imo-del:hover{text-decoration:underline}
.imo-status{display:flex;gap:18px;align-items:flex-start;background:var(--green-soft);border:1px solid var(--green-soft-border);border-radius:var(--radius);padding:22px 24px;margin-bottom:22px}
.imo-status__icon{flex:0 0 50px;width:50px;height:50px;border-radius:50%;background:var(--green);color:#fff;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.imo-status__title{margin:0 0 8px;font-size:clamp(20px,2.4vw,27px);line-height:1.15}
.imo-status__text{margin:0;font-size:15px;line-height:1.6;color:var(--ink-soft)}
.imo-status--warn{background:#fff7ec;border-color:#f0c98a}
.imo-status--warn .imo-status__icon{background:#e08a1e}
.imo-status--warn .imo-status__title{color:#8a5a12}
@media(max-width:560px){.imo-status{flex-direction:column;padding:18px}.imo-imgrow{flex-direction:column;align-items:stretch}.imo-thumb{width:100%;flex:none;height:180px}}

/* =========================================================================
   HEADER
   ========================================================================= */
.imo-header{position:sticky;top:0;z-index:300;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(255,255,255,.82);border-bottom:1px solid var(--line-2)}
.imo-header__bar{max-width:var(--maxw);margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.imo-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.imo-logo__mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#1fae5c,#15924f 55%,#0f5f2c);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(95,224,138,.4),inset 0 1px 1px rgba(255,255,255,.35),inset 0 -2px 3px rgba(0,0,0,.25)}
.imo-logo__txt{font-weight:800;font-size:19px;letter-spacing:-.02em}
.imo-logo__txt b{color:var(--green);font-weight:800}
.imo-nav{display:flex;align-items:center;gap:2px}
.nav-link{padding:9px 13px;border-radius:9px;text-decoration:none;color:var(--ink-soft);font-size:14px;font-weight:500;transition:all .18s}
.nav-link:hover{color:var(--green);background:rgba(95,224,138,.08)}
.imo-nav__cta{margin-left:8px;padding:9px 16px;border-radius:10px;text-decoration:none;color:#fff;font-size:14px;font-weight:700;background:linear-gradient(120deg,var(--green),var(--green-2));box-shadow:0 4px 14px rgba(95,224,138,.3)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:22px;height:2px;background:var(--green);border-radius:2px;display:block}
.imo-mobnav{display:none;flex-direction:column;padding:8px 24px 18px;gap:2px;border-top:1px solid var(--line-2);background:rgba(255,255,255,.98)}
.imo-mobnav a{padding:12px 8px;text-decoration:none;color:var(--ink-soft);font-weight:500;border-radius:8px}
.imo-mobnav__cta{margin-top:6px;padding:13px 8px;text-align:center;color:#fff;font-weight:700;background:linear-gradient(120deg,var(--green),var(--green-2));border-radius:10px}

/* =========================================================================
   FOOTER
   ========================================================================= */
.imo-footer{background:linear-gradient(180deg,#eef2ef,#e6ece8);border-top:1px solid var(--line-2);padding:40px 24px 34px;margin-top:20px}
.imo-footer__inner{max-width:var(--maxw);margin:0 auto}
.imo-footer__brand{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.imo-footer__mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#1fae5c,#15924f 55%,#0f5f2c);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(95,224,138,.4),inset 0 1px 1px rgba(255,255,255,.35),inset 0 -2px 3px rgba(0,0,0,.25)}
.imo-footer__name{font-weight:800;font-size:17px}
.imo-footer__name b{color:var(--green);font-weight:800}
.imo-footer__links{display:flex;flex-wrap:wrap;gap:18px 22px;margin-bottom:20px}
.fhead-link{color:var(--muted);text-decoration:none;font-size:13.5px;transition:color .18s}
.fhead-link:hover{color:var(--green)}
.imo-footer__copy{border-top:1px solid var(--line-2);padding-top:18px;color:var(--muted-3);font-size:13px}

/* =========================================================================
   ANIMATIES (uit index.php) — uit bij prefers-reduced-motion
   ========================================================================= */
@keyframes floatA{0%,100%{transform:translate3d(0,0,60px) rotateY(-16deg) rotateX(6deg)}50%{transform:translate3d(0,-18px,60px) rotateY(-12deg) rotateX(8deg)}}
@keyframes floatB{0%,100%{transform:translate3d(40px,-26px,-40px) rotateY(-14deg) scale(.92)}50%{transform:translate3d(40px,-40px,-40px) rotateY(-14deg) scale(.92)}}
@keyframes floatC{0%,100%{transform:translate3d(-30px,44px,-130px) rotateY(-18deg) scale(.82)}50%{transform:translate3d(-30px,30px,-130px) rotateY(-18deg) scale(.82)}}
@keyframes grow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes riseIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.imo-rise{animation:riseIn .7s cubic-bezier(.22,1,.36,1) both}

/* Parallax-hulp (lichtgewicht, alleen actief met JS + zonder reduced-motion) */
.imo-parallax{will-change:transform}

/* =========================================================================
   jQuery UI autocomplete (licht thema) — voor de stad-zoekvelden
   ========================================================================= */
.ui-autocomplete{position:absolute;z-index:9999;max-height:330px;overflow-y:auto;overflow-x:hidden;background:#fff;border:1px solid rgba(17,39,27,.12);border-radius:12px;padding:6px;margin:4px 0 0;list-style:none;box-shadow:0 18px 44px rgba(0,0,0,.18)}
.ui-autocomplete .ui-menu-item{list-style:none;margin:0}
.ui-autocomplete .ui-menu-item-wrapper,.ui-autocomplete a.suggestion-link{display:block;padding:9px 11px;border-radius:8px;color:var(--ink-soft);text-decoration:none;font-size:14px;cursor:pointer}
.ui-autocomplete .ui-menu-item-wrapper.ui-state-active,.ui-autocomplete a.suggestion-link:hover,.ui-autocomplete .ui-menu-item a.suggestion-link.ui-state-active{background:rgba(95,224,138,.14);color:var(--ink)}
.suggestion-link__flex{display:flex;align-items:center;gap:8px}
.suggestion-link__flex img{width:14px;height:14px;flex-shrink:0;filter:invert(42%) sepia(64%) saturate(560%) hue-rotate(96deg)}
.suggestions{position:relative}

/* Locatie-zoekveld met fijne kader + groene focus (index-stijl) */
.loc-field{transition:border-color .2s,box-shadow .2s}
.loc-field:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(95,224,138,.22)}
.loc-field input::placeholder{color:#8a9b91}

/* Zoek-tabs (Te koop / Te huur) — herbruikbaar, index-stijl */
.tab{flex:1;text-align:center;padding:11px 8px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .2s;background:transparent;color:#5f7268}
.tab.tab--on{background:linear-gradient(120deg,#15924f,#2fa35e);color:#ffffff;box-shadow:0 4px 14px rgba(95,224,138,.32)}

/* =========================================================================
   COMPAT — grote stedendirectory-pagina's (towns*.php): oude klassen in
   het nieuwe thema, zodat de duizenden links niet aangeraakt hoeven worden.
   ========================================================================= */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.hero-banner{position:relative;overflow:hidden;background:linear-gradient(135deg,#eaf6ee,#dcefe3);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,5vw,48px);margin:24px 0;text-align:center}
.hero-banner h1{font-family:var(--font-head);font-weight:400;font-size:clamp(32px,5vw,52px);line-height:1.05;color:var(--ink);margin:0}
.content-section{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,4vw,32px);margin-bottom:20px;box-shadow:var(--shadow-card)}
.content-section h2{font-family:var(--font-head);font-weight:400;font-size:clamp(24px,3.4vw,34px);color:var(--ink);margin:0 0 14px}
.content-section p{margin:0 0 14px;color:var(--muted);line-height:1.7}
.cities-section{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,4vw,28px);margin-bottom:20px;box-shadow:var(--shadow-card)}
.cities-section h2{font-family:var(--font-head);font-weight:400;font-size:clamp(22px,3vw,30px);color:var(--ink);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px 18px}
.cities-grid a{display:block;padding:7px 0;font-size:14px;color:var(--ink-soft);border-bottom:1px solid var(--line-2);text-decoration:none}
.cities-grid a:hover{color:var(--green)}
.city-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-top:16px}
.city-card{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 16px;text-decoration:none;color:var(--ink);transition:transform .18s,border-color .18s,box-shadow .18s}
.city-card:hover{border-color:var(--green-soft-border);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.city-card h3{margin:0 0 4px;font-size:15px;font-weight:700;color:var(--ink)}
.city-card span{font-size:12.5px;color:var(--muted-2)}
.interlink-section{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,4vw,28px);margin-bottom:20px;box-shadow:var(--shadow-card)}
.interlink-section h2{font-family:var(--font-head);font-weight:400;font-size:clamp(22px,3vw,30px);margin:0 0 16px}
.interlink-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.interlink-col h3{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin:0 0 10px}
.interlink-col a{display:block;padding:5px 0;font-size:14px;color:var(--muted);text-decoration:none}
.interlink-col a:hover{color:var(--green)}
.faq-list{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.faq-list details{border-bottom:1px solid var(--line-2)}
.faq-list details:last-child{border-bottom:none}
.faq-list summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;font-weight:600;color:var(--ink)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:'+';color:var(--green);font-size:20px;line-height:1;transition:transform .2s}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list .faq-a{padding:0 18px 16px;color:var(--muted);font-size:14px;line-height:1.6}
.provinces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:16px}
.province-card{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;text-decoration:none;color:var(--ink);transition:transform .18s,border-color .18s}
.province-card:hover{border-color:var(--green-soft-border);transform:translateY(-2px)}
@media(max-width:768px){.interlink-grid{grid-template-columns:1fr}}

/* =========================================================================
   ACCOUNT — ingelogde account-pagina's (my-properties, my-bookmarks,
   my-search, my-privacy). Sidebar-navigatie + lijst/kaart van zoekertjes.
   ========================================================================= */
.imo-account{display:grid;grid-template-columns:240px 1fr;gap:28px;align-items:start}
.imo-account__nav{display:flex;flex-direction:column;gap:18px;position:sticky;top:88px}
.imo-account__group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 14px 8px;box-shadow:var(--shadow-card)}
.imo-account__title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin:0 6px 8px;padding-bottom:8px;border-bottom:1px solid var(--line-2)}
.imo-account__nav a{display:block;padding:9px 10px;border-radius:9px;font-size:14px;font-weight:500;color:var(--ink-soft);text-decoration:none;transition:all .18s}
.imo-account__nav a:hover{background:rgba(95,224,138,.08);color:var(--green)}
.imo-account__nav a.current{background:var(--green-soft);color:var(--green);font-weight:700}
.imo-account__nav a.imo-account__highlight{color:var(--green);font-weight:700}
.imo-account__main{min-width:0}
.imo-account__heading{font-family:var(--font-body);font-size:18px;font-weight:700;color:var(--ink);margin:0 0 16px}

/* Lijst van zoekertjes / favorieten */
.imo-list{display:flex;flex-direction:column;gap:14px}
.imo-list__item{display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card)}
.imo-list__media{flex-shrink:0;width:140px;height:100px;border-radius:11px;overflow:hidden;background:#eef2ef}
.imo-list__media img{width:100%;height:100%;object-fit:cover;display:block}
.imo-list__body{flex:1;min-width:0}
.imo-list__body h4{margin:0 0 4px;font-size:16px}
.imo-list__body h4 a{color:var(--ink);text-decoration:none}
.imo-list__body h4 a:hover{color:var(--green)}
.imo-list__addr{font-size:14px;color:var(--muted);line-height:1.5}
.imo-list__price{font-size:17px;font-weight:700;color:var(--ink);margin-top:6px}
.imo-list__price strike{color:var(--muted-3)}
.imo-list__actions{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.imo-status{display:inline-flex;align-items:center;font-size:12.5px;font-weight:600;padding:4px 10px;border-radius:30px;margin-top:8px}
.imo-status--active{background:var(--green-soft);color:var(--green)}
.imo-status--pending{background:rgba(231,201,135,.18);color:#8a6a2e}
.imo-link-del{color:#b91c1c;font-size:13.5px;font-weight:600;text-decoration:none}
.imo-link-del:hover{text-decoration:underline}

/* Bewaarde zoekopdrachten (tekstuele rijen) */
.imo-saved__item{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-card)}
.imo-saved__text{font-size:14.5px;color:var(--ink);font-weight:500;flex:1;min-width:0}
.imo-saved__actions{display:flex;gap:14px;align-items:center;flex-shrink:0}
.imo-saved__actions a{font-size:13.5px;font-weight:600;text-decoration:none;color:var(--green)}
.imo-saved__actions a:hover{text-decoration:underline}
.imo-saved__add{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}

.imo-pagination{margin-top:28px}

@media(max-width:820px){
  .imo-account{grid-template-columns:1fr}
  .imo-account__nav{position:static;flex-direction:row;flex-wrap:wrap}
  .imo-account__group{flex:1 1 180px}
}
@media(max-width:560px){
  .imo-list__item{flex-direction:column;align-items:stretch}
  .imo-list__media{width:100%;height:170px}
  .imo-list__actions{flex-direction:row;flex-wrap:wrap;align-items:center}
}

/* =========================================================================
   RESPONSIVE — breekpunten zoals index.php
   ========================================================================= */
@media(max-width:820px){
  .imo-nav{display:none}
  .burger{display:flex}
  .imo-grid--3,.imo-grid--4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:620px){
  .imo-grid--2,.imo-grid--3,.imo-grid--4{grid-template-columns:1fr}
  .imo-hero__inner{padding:40px 18px 28px}
  main h1{font-size:clamp(30px,8vw,40px)}
  .search-fields{flex-wrap:wrap}
  .search-fields .sel{flex:1 1 42%}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  .imo-parallax{transform:none !important}
}

/* =========================================================================
   ADMIN-PANEEL (intern) — eigen topbar + nav in dezelfde look, via admin-partials
   ========================================================================= */
.adm-topbar{position:sticky;top:0;z-index:9999;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(255,255,255,.9);border-bottom:1px solid var(--line-2)}
.adm-topbar__bar{max-width:1280px;margin:0 auto;padding:0 20px;min-height:62px;display:flex;align-items:center;gap:16px;position:relative;flex-wrap:wrap}
.adm-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);flex-shrink:0}
.adm-logo__mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#1fae5c,#15924f 55%,#0f5f2c);display:flex;align-items:center;justify-content:center;box-shadow:0 5px 14px rgba(95,224,138,.4)}
.adm-logo__txt{font-weight:800;font-size:18px;letter-spacing:-.02em}
.adm-logo__txt b{color:var(--green);font-weight:800}
.adm-logo__tag{font-weight:600;font-size:10px;color:var(--muted-3);letter-spacing:.12em;margin-left:4px;vertical-align:middle}
.adm-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto}
.adm-burger span{width:22px;height:2px;background:var(--green);border-radius:2px;display:block}
.adm-nav{display:flex;align-items:center;gap:2px;flex-wrap:wrap;margin-left:auto}
.adm-nav a{padding:8px 12px;color:var(--ink-soft);font-weight:500;font-size:14px;border-radius:8px;text-decoration:none;transition:all .15s}
.adm-nav a:hover{background:rgba(95,224,138,.1);color:var(--green)}
.adm-nav a.is-active{background:rgba(21,146,79,.1);color:var(--green);font-weight:700}
.adm-nav__btn{background:linear-gradient(120deg,var(--green),var(--green-2));color:#fff !important;font-weight:700;box-shadow:0 4px 12px rgba(95,224,138,.3)}
.adm-nav__btn:hover{background:var(--green) !important}
@media(max-width:1000px){
  .adm-burger{display:flex}
  .adm-nav{display:none;position:absolute;top:calc(100% + 10px);left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:10px 16px 16px;border:1px solid var(--line);border-radius:0 0 14px 14px;box-shadow:0 10px 26px rgba(0,0,0,.1);margin:0}
  .adm-nav.open{display:flex}
  .adm-nav a{padding:12px 10px}
}

/* Admin content */
.adm-wrap{max-width:1280px;margin:0 auto;padding:34px 20px}
.adm-h1{font-family:var(--font-head);font-weight:400;font-size:clamp(28px,3.6vw,40px);color:var(--ink);margin:0 0 4px;line-height:1.05}
.adm-sub{color:var(--muted);margin:0 0 28px;font-size:15px}
.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.adm-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s;box-shadow:var(--shadow-card)}
.adm-card:hover{border-color:var(--green-soft-border);box-shadow:0 10px 26px rgba(21,146,79,.12);transform:translateY(-2px);text-decoration:none}
.adm-card__icon{width:52px;height:52px;flex-shrink:0;border-radius:12px;background:var(--green-soft);display:flex;align-items:center;justify-content:center}
.adm-card__icon svg{fill:var(--green)}
.adm-card__count{font-family:var(--font-head);font-size:1.9em;font-weight:400;color:var(--ink);line-height:1.1}
.adm-card__title{font-weight:700;color:var(--green)}
.adm-card__desc{font-size:13px;color:var(--muted);margin-top:2px}
.adm-card--alert{border-color:#e6a23c;background:#fff9f0}
.adm-card--alert:hover{border-color:#d4881f;box-shadow:0 10px 26px rgba(214,136,31,.16)}
.adm-card--alert .adm-card__icon{background:#fdecd1}
.adm-card--alert .adm-card__icon svg{fill:#d4881f}
.adm-card--alert .adm-card__count,.adm-card--alert .adm-card__title{color:#c47010}
.adm-card__badge{display:inline-block;margin-left:6px;background:#e6920c;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;vertical-align:middle;white-space:nowrap}

/* Admin generieke bouwstenen (formulier-/tabelpagina's) */
.adm-card-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:clamp(18px,3vw,28px);box-shadow:var(--shadow-card);margin-bottom:20px}
.adm-table{width:100%;border-collapse:collapse;font-size:14px}
.adm-table th,.adm-table td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line-2)}
.adm-table th{font-weight:700;color:var(--ink-soft);background:rgba(17,39,27,.03)}
.adm-table tr:hover td{background:rgba(95,224,138,.05)}
.adm-tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
