/*
Theme Name: Adria Estate
Theme URI: https://example.com/adria-estate
Author: Built for Rico
Author URI: https://example.com
Description: A clean, trustworthy WordPress theme for a Dutch buyer's broker selling real estate in Croatia. Inspired by modern coastal-property agencies. Includes built-in "Properties" (Aanbod) and "Testimonials" managers so you can edit everything from the dashboard with no code. Fully in Dutch.
Version: 2.1.1
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: adria-estate
Tags: real-estate, business, custom-menu, featured-images, translation-ready
*/

/* =========================================================
   Design tokens — navy & white, warm accent (Middelland-style)
   ========================================================= */
:root{
  --navy:#153450;         /* primary deep navy */
  --navy-2:#1e4a70;       /* lighter navy */
  --navy-dark:#0f2740;    /* darkest navy */
  --gold:#c99a4e;         /* warm accent */
  --gold-soft:#e6d2a8;
  --ink:#1c2733;          /* main text */
  --muted:#5f6d7a;        /* secondary text */
  --cloud:#f4f6f8;        /* light section background */
  --line:#e4e9ee;         /* borders */
  --white:#ffffff;
  --radius:12px;
  --shadow:0 8px 26px rgba(21,52,80,.09);
  --shadow-lg:0 22px 55px rgba(21,52,80,.16);
  --maxw:1180px;
  --font-head:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--white);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy-2);text-decoration:none}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.22;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.6vw,3.1rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.3rem)}
h3{font-size:1.22rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.container--narrow{max-width:820px}
.section{padding:74px 0}
.section--tint{background:var(--cloud)}
.section--navy{background:var(--navy);color:#fff}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;font-weight:700;color:var(--gold);margin-bottom:.6rem}
.section-head{max-width:700px;margin:0 auto 46px;text-align:center}
.section-head p{color:var(--muted)}
.section--navy .section-head p{color:rgba(255,255,255,.85)}

/* Buttons */
.btn{display:inline-block;padding:14px 28px;border-radius:8px;font-weight:600;font-family:var(--font-body);font-size:.98rem;cursor:pointer;border:2px solid transparent;transition:.2s ease;text-align:center}
.btn--primary{background:var(--gold);color:#2a2410;border-color:var(--gold)}
.btn--primary:hover{background:#b7883b;border-color:#b7883b;color:#2a2410}
.btn--navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn--navy:hover{background:var(--navy-dark);border-color:var(--navy-dark);color:#fff}
.btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn--outline:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn--ghost:hover{background:var(--cloud);color:var(--navy)}
.btn--sm{padding:10px 18px;font-size:.9rem}

/* =========================================================
   Header
   ========================================================= */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700;font-size:1.3rem;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand-mark{width:42px;height:42px;border-radius:9px;flex:none;background:linear-gradient(135deg,var(--navy),var(--navy-2));display:grid;place-items:center;color:#fff;font-family:var(--font-head);font-size:1.15rem}
.brand small{display:block;font-family:var(--font-body);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-weight:600}
.main-nav ul{display:flex;gap:26px;list-style:none;margin:0;padding:0;align-items:center}
.main-nav a{color:var(--ink);font-weight:500;font-size:.97rem}
.main-nav a:hover{color:var(--navy-2)}
.header-cta{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;gap:4px;align-items:center;font-size:.82rem;font-weight:600}
.lang-switch a{color:var(--muted);padding:4px 7px;border-radius:6px;line-height:1}
.lang-switch a:hover{color:var(--navy-2)}
.lang-switch a.current{background:var(--cloud);color:var(--navy)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.2s}

/* =========================================================
   Hero
   ========================================================= */
.hero{position:relative;color:#fff;padding:130px 0 140px;background:var(--navy);background-size:cover;background-position:center}
/* Lichte, deels transparante laag: de villa/zeezicht blijft zichtbaar, tekst leesbaar. */
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(15,39,64,.62) 0%,rgba(15,39,64,.42) 45%,rgba(15,39,64,.28) 100%)}
.hero .container{position:relative;z-index:2;max-width:900px}
.hero h1{color:#fff;margin-bottom:.35em;max-width:14ch}
.hero p{font-size:1.2rem;max-width:600px;margin:0 0 2rem;color:rgba(255,255,255,.92)}
.hero .btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* Trust bar under hero */
.trust-bar{background:var(--navy-dark);color:#fff}
.trust-bar .container{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-top:22px;padding-bottom:22px;text-align:center}
.trust-bar b{display:block;font-family:var(--font-head);font-size:1.7rem;color:#fff}
.trust-bar span{color:rgba(255,255,255,.7);font-size:.9rem}

/* =========================================================
   Mission / intro
   ========================================================= */
.mission{text-align:center;max-width:760px;margin:0 auto}
.mission h2{margin-bottom:.4em}
.mission p{font-size:1.12rem;color:var(--muted)}

/* =========================================================
   Guide band (free buying guide CTA)
   ========================================================= */
.guide-band{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;border-radius:16px;overflow:hidden;display:grid;grid-template-columns:1.3fr 1fr;box-shadow:var(--shadow-lg)}
.guide-band .g-text{padding:44px}
.guide-band h2{color:#fff}
.guide-band p{color:rgba(255,255,255,.88)}
.guide-band .g-img{background-size:cover;background-position:center;min-height:260px}

/* =========================================================
   Property cards
   ========================================================= */
.property-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.property-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);display:flex;flex-direction:column;transition:.25s ease}
.property-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.property-media{position:relative;aspect-ratio:4/3;background:#dce4ea;overflow:hidden;display:block}
.property-media img{width:100%;height:100%;object-fit:cover}
.property-badge{position:absolute;top:14px;left:14px;background:var(--gold);color:#2a2410;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:6px 12px;border-radius:6px}
.property-price{position:absolute;bottom:14px;right:14px;background:rgba(15,39,64,.94);color:#fff;font-weight:700;padding:8px 14px;border-radius:8px;font-size:1.02rem}
.property-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.property-body h3{margin:0 0 6px;font-size:1.18rem}
.property-body h3 a{color:var(--ink)}
.property-body h3 a:hover{color:var(--navy-2)}
.property-loc{color:var(--muted);font-size:.92rem;margin-bottom:14px}
.property-meta{display:flex;gap:18px;padding-top:14px;margin-top:auto;border-top:1px solid var(--line);color:var(--muted);font-size:.9rem}
.property-meta b{color:var(--ink);font-weight:600}

/* =========================================================
   Testimonials
   ========================================================= */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.testi-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.testi-stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px}
.testi-card p{font-size:1rem;color:var(--ink);flex:1}
.testi-person{display:flex;align-items:center;gap:12px;margin-top:16px}
.testi-person img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none}
.testi-person b{display:block;font-size:.95rem}
.testi-person span{font-size:.84rem;color:var(--muted)}

/* =========================================================
   Why us — three columns
   ========================================================= */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.why-card{text-align:center;padding:34px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.why-card .ic{width:60px;height:60px;border-radius:14px;margin:0 auto 18px;background:var(--cloud);border:1px solid var(--line);display:grid;place-items:center;font-size:1.6rem}
.why-card h3{margin-bottom:.4em}
.why-card p{color:var(--muted);font-size:.96rem;margin:0}

/* =========================================================
   Story split
   ========================================================= */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/3;object-fit:cover}
.split .eyebrow{margin-bottom:.6rem}

/* =========================================================
   Regions
   ========================================================= */
.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.region-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;padding:20px;box-shadow:var(--shadow);transition:.25s;color:#fff;background-size:cover;background-position:center}
.region-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);color:#fff}
.region-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(15,39,64,.82));z-index:1}
.region-card .region-inner{position:relative;z-index:2}
.region-card h3{color:#fff;margin:0 0 2px}
.region-card span{font-size:.84rem;color:rgba(255,255,255,.88)}

/* =========================================================
   Blog / knowledge cards
   ========================================================= */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.25s}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.blog-card .b-media{aspect-ratio:16/10;background:#dce4ea;overflow:hidden}
.blog-card .b-media img{width:100%;height:100%;object-fit:cover}
.blog-card .b-body{padding:22px}
.blog-card h3{font-size:1.08rem;margin-bottom:.4em}
.blog-card .b-body p{color:var(--muted);font-size:.93rem}

/* =========================================================
   Split service band ("iets online gevonden?")
   ========================================================= */
.service-band{background:var(--cloud);border:1px solid var(--line);border-radius:16px;padding:44px;text-align:center}
.service-band h2{margin-bottom:.3em}
.service-band p{color:var(--muted);max-width:640px;margin:0 auto 1.4rem}

/* =========================================================
   Contact Form 7 — passend gemaakt op de huisstijl
   ========================================================= */
.contact-form-card{max-width:640px;margin:0 auto 26px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:34px;text-align:left;color:var(--ink)}
.wpcf7-form p{margin:0 0 16px}
.wpcf7-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:6px;color:var(--ink)}
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=url],
.wpcf7-form input[type=date],
.wpcf7-form input[type=number],
.wpcf7-form select,
.wpcf7-form textarea{
  width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:8px;
  font-family:var(--font-body);font-size:.96rem;color:var(--ink);background:#fff;
}
.wpcf7-form textarea{min-height:120px;resize:vertical}
.wpcf7-form input:focus,.wpcf7-form select:focus,.wpcf7-form textarea:focus{outline:none;border-color:var(--navy-2);box-shadow:0 0 0 3px rgba(30,74,112,.12)}
.wpcf7-form .wpcf7-submit{
  background:var(--gold);color:#2a2410;border:2px solid var(--gold);
  padding:13px 28px;border-radius:8px;font-weight:600;font-size:.98rem;cursor:pointer;transition:.2s;
}
.wpcf7-form .wpcf7-submit:hover{background:#b7883b;border-color:#b7883b}
.wpcf7-response-output{border-radius:8px;margin:8px 0 0!important;padding:12px 14px!important;font-size:.92rem}
.wpcf7 .wpcf7-not-valid-tip{color:#c0392b;font-size:.84rem}
.cf7-inline .wpcf7-form input,.cf7-inline .wpcf7-form textarea,.cf7-inline .wpcf7-form select{padding:10px 11px}
.cf7-inline .wpcf7-form p{margin:0 0 12px}
.cf7-inline .wpcf7-form .wpcf7-submit{width:100%;padding:12px}

/* =========================================================
   Single property
   ========================================================= */
.single-hero{position:relative;aspect-ratio:16/7;background:#dce4ea;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.single-hero img{width:100%;height:100%;object-fit:cover}
.single-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:flex-start;margin:28px 0 20px}
.single-head .price{font-family:var(--font-head);font-size:1.9rem;color:var(--navy-2)}
.spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0 30px}
.spec{background:var(--cloud);border:1px solid var(--line);border-radius:10px;padding:18px;text-align:center}
.spec b{display:block;font-size:1.2rem;color:var(--ink)}
.spec span{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.single-layout{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.inquiry-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;position:sticky;top:96px}
.inquiry-box h3{margin-top:0}
.inquiry-box .field{margin-bottom:14px}
.inquiry-box label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);display:block;margin-bottom:5px}
.inquiry-box input,.inquiry-box textarea{width:100%;padding:11px;border:1px solid var(--line);border-radius:8px;font-family:var(--font-body);font-size:.95rem}
.inquiry-box .btn{width:100%}

/* =========================================================
   Archive / listings toolbar
   ========================================================= */
.page-hero{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;padding:64px 0;text-align:center}
.page-hero h1{color:#fff;margin:0}
.page-hero p{color:rgba(255,255,255,.9);margin:.4rem 0 0}
.filter-bar{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:12px;align-items:end;margin:-40px auto 40px;position:relative;z-index:5}
.search-field label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:6px}
.search-field select,.search-field input{width:100%;padding:12px;border:1px solid var(--line);border-radius:8px;font-size:.95rem;font-family:var(--font-body);background:#fff}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{background:var(--navy-dark);color:#c3cfda;padding:60px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:34px;margin-bottom:40px}
.site-footer h4{color:#fff;font-family:var(--font-body);font-size:.94rem;text-transform:uppercase;letter-spacing:.09em;margin-bottom:16px}
.site-footer a{color:#c3cfda}
.site-footer a:hover{color:var(--gold)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:9px}
.footer-brand .brand{color:#fff}
.footer-brand p{color:#93a4b4;font-size:.94rem;margin-top:14px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;text-align:center;font-size:.85rem;color:#8394a4}

/* =========================================================
   Pagination + generic content
   ========================================================= */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:44px;flex-wrap:wrap}
.pagination a,.pagination span{padding:10px 16px;border:1px solid var(--line);border-radius:8px;color:var(--ink)}
.pagination .current{background:var(--navy);color:#fff;border-color:var(--navy)}
.entry-content{max-width:760px;margin:0 auto}
.entry-content img{border-radius:var(--radius);margin:20px 0}

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:960px){
  .property-grid,.testi-grid,.why-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .split,.guide-band{grid-template-columns:1fr}
  .guide-band .g-img{min-height:200px}
  .single-layout{grid-template-columns:1fr}
  .inquiry-box{position:static}
  .filter-bar{grid-template-columns:1fr 1fr}
  .trust-bar .container{grid-template-columns:repeat(2,1fr)}
  .spec-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .main-nav{display:none}
  .main-nav.open{display:block;position:absolute;top:74px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:18px 22px}
  .main-nav.open ul{flex-direction:column;gap:16px;align-items:flex-start}
  .nav-toggle{display:block}
  .header-cta .btn{display:none}
  .property-grid,.testi-grid,.why-grid,.blog-grid,.region-grid,.footer-grid,.filter-bar{grid-template-columns:1fr}
  .section{padding:52px 0}
}
