/*
Theme Name: Vastgoedhulp in Spanje
Theme URI: https://vastgoedhulpinspanje.com
Author: Vastgoedhulp in Spanje
Description: Persoonlijke Nederlandse aankoopbegeleiding in Spanje. Adviseur-gedreven thema met kostencalculator. Code-first, lichtgewicht.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: vastgoedhulp
*/

:root{
    --ink:#1A1410;          /* warm near-black */
    --ink-2:#241C16;
    --sand:#F6F1E9;         /* light section */
    --paper:#FFFCF7;        /* warm white */
    --clay:#C8893B;         /* clay-gold accent */
    --clay-deep:#A86C28;
    --teal:#173B36;         /* deep mediterranean teal */
    --teal-soft:#23534C;
    --muted:#6B6155;
    --line:#E4DCCE;
    --radius:14px;
    --maxw:1180px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;
    font-family:"Figtree",system-ui,-apple-system,sans-serif;
    color:var(--ink);
    background:var(--paper);
    font-size:17px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-0.01em;margin:0}
  p{margin:0 0 1em}
  a{color:inherit}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{
    font-size:13px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;
    color:var(--clay-deep);margin:0 0 18px;display:flex;align-items:center;gap:10px;
  }
  .eyebrow::before{content:"";width:26px;height:1.5px;background:var(--clay);display:inline-block}
  .eyebrow.light{color:var(--clay)}

  /* buttons */
  .btn{
    display:inline-flex;align-items:center;gap:9px;justify-content:center;
    font-family:inherit;font-weight:600;font-size:15.5px;letter-spacing:0.01em;
    padding:14px 24px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
    text-decoration:none;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;
  }
  .btn-primary{background:#D9A85F;color:#fff;box-shadow:0 8px 24px -10px rgba(200,137,59,.7)}
  .btn-primary:hover{background:var(--clay);transform:translateY(-2px)}
  .btn-ghost{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
  .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
  .btn-dark{background:var(--ink);color:#fff}
  .btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}
  .btn-line{background:transparent;border-color:var(--ink);color:var(--ink)}
  .btn-line:hover{background:var(--ink);color:#fff}
  :focus-visible{outline:3px solid var(--clay);outline-offset:2px;border-radius:6px}

  /* nav */
  header.nav{position:sticky;top:0;z-index:50;background:rgba(26,20,16,.82);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
  .brand{display:flex;align-items:center;gap:11px;color:#fff;text-decoration:none;font-family:"Fraunces",serif;font-size:20px;font-weight:600;letter-spacing:-0.01em}
  .brand .dot{width:11px;height:11px;border-radius:50%;background:var(--clay);box-shadow:0 0 0 4px rgba(200,137,59,.18)}
  .nav-links{display:flex;gap:30px;align-items:center}
  .nav-links a{color:rgba(255,255,255,.78);text-decoration:none;font-size:15px;font-weight:500}
  .nav-links a:hover{color:#fff}
  .nav-cta{display:flex;gap:12px;align-items:center}
  .nav .btn{padding:10px 18px;font-size:14.5px}
  .menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer}

  /* hero */
  .hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
  .hero::before{ /* warm ambient glow */
    content:"";position:absolute;width:780px;height:780px;right:-180px;top:-260px;
    background:radial-gradient(circle, rgba(200,137,59,.42) 0%, rgba(200,137,59,.10) 38%, transparent 68%);
    filter:blur(6px);pointer-events:none;
  }
  .hero::after{
    content:"";position:absolute;left:-150px;bottom:-220px;width:560px;height:560px;
    background:radial-gradient(circle, rgba(35,83,76,.55) 0%, transparent 66%);pointer-events:none;
  }
  .hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding:84px 0 92px}
  .hero h1{font-size:clamp(38px,5.4vw,66px);font-weight:500}
  .hero h1 em{font-style:italic;color:var(--clay);font-weight:400}
  .hero .lead{font-size:19.5px;color:rgba(255,255,255,.82);max-width:30ch;margin:24px 0 32px}
  .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
  .hero-trust{margin-top:38px;display:flex;gap:28px;flex-wrap:wrap;color:rgba(255,255,255,.66);font-size:14.5px}
  .hero-trust b{color:#fff;font-weight:600}
  .hero-trust span{display:flex;align-items:center;gap:8px}
  .hero-trust .tick{color:var(--clay)}

  /* hero card */
  .hero-card{
    background:linear-gradient(180deg, rgba(255,252,247,.07), rgba(255,252,247,.03));
    border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:30px;
    backdrop-filter:blur(4px);box-shadow:0 30px 70px -40px rgba(0,0,0,.7)
  }
  .hero-card h3{font-size:21px;color:#fff;margin-bottom:6px}
  .hero-card p{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:22px}
  .stepmini{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-top:1px solid rgba(255,255,255,.1)}
  .stepmini:first-of-type{border-top:none}
  .stepmini .n{font-family:"Fraunces",serif;color:var(--clay);font-size:17px;min-width:24px}
  .stepmini b{color:#fff;font-weight:600;font-size:15.5px;display:block}
  .stepmini small{color:rgba(255,255,255,.62);font-size:13.5px}

  /* sections */
  section{padding:92px 0}
  .section-head{max-width:62ch;margin-bottom:54px}
  .section-head h2{font-size:clamp(30px,4vw,46px)}
  .section-head p{color:var(--muted);font-size:18.5px;margin-top:18px}

  /* advisor */
  .advisor{background:var(--sand)}
  .advisor-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center}
  .portrait{
    aspect-ratio:4/5;border-radius:18px;border:1px solid var(--line);
    background:
      radial-gradient(120% 80% at 30% 10%, rgba(200,137,59,.16), transparent 60%),
      linear-gradient(160deg,#2a201a,#173b36);
    position:relative;overflow:hidden;display:flex;align-items:flex-end;color:#fff;
    box-shadow:0 30px 60px -34px rgba(26,20,16,.5)
  }
  .portrait .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,.4);font-size:14px;letter-spacing:.04em;text-align:center;padding:24px}
  .portrait .cap{position:relative;z-index:2;width:100%;padding:22px;background:linear-gradient(0deg,rgba(20,15,12,.78),transparent)}
  .portrait .cap b{font-family:"Fraunces",serif;font-size:20px;display:block}
  .portrait .cap small{color:rgba(255,255,255,.78)}
  .advisor h2{font-size:clamp(28px,3.6vw,42px)}
  .advisor blockquote{margin:22px 0 0;font-family:"Fraunces",serif;font-style:italic;font-size:22px;line-height:1.45;color:var(--teal)}
  .promises{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px}
  .promises li{display:flex;gap:13px;align-items:flex-start;font-size:16.5px}
  .promises .tick{flex:0 0 22px;width:22px;height:22px;border-radius:50%;background:var(--clay);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;margin-top:3px}

  /* calculator */
  .calc{background:var(--ink);color:#fff;position:relative;overflow:hidden}
  .calc::before{content:"";position:absolute;right:-160px;top:40px;width:520px;height:520px;background:radial-gradient(circle,rgba(200,137,59,.28),transparent 66%);pointer-events:none}
  .calc .wrap{position:relative;z-index:2}
  .calc .section-head h2{color:#fff}
  .calc .section-head p{color:rgba(255,255,255,.72)}
  .calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:stretch}
  .calc-panel{background:rgba(255,252,247,.05);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:30px}
  .field{margin-bottom:22px}
  .field label{display:block;font-size:14px;font-weight:600;letter-spacing:.02em;color:rgba(255,255,255,.82);margin-bottom:9px}
  .field input[type=number]{
    width:100%;font-family:inherit;font-size:20px;font-weight:600;color:#fff;
    background:rgba(0,0,0,.25);border:1.5px solid rgba(255,255,255,.16);border-radius:10px;padding:13px 15px;
  }
  .field input[type=range]{width:100%;accent-color:var(--clay);margin-top:6px}
  .toggle{display:flex;gap:8px;background:rgba(0,0,0,.25);border:1.5px solid rgba(255,255,255,.16);border-radius:10px;padding:5px}
  .toggle button{flex:1;background:transparent;border:none;color:rgba(255,255,255,.7);font-family:inherit;font-weight:600;font-size:14.5px;padding:11px;border-radius:7px;cursor:pointer}
  .toggle button.active{background:var(--clay);color:#fff}
  select.region{width:100%;font-family:inherit;font-size:16px;font-weight:600;color:#fff;background:rgba(0,0,0,.25);border:1.5px solid rgba(255,255,255,.16);border-radius:10px;padding:13px 15px;appearance:none}
  select.region option{color:#1A1410}

  .result{display:flex;flex-direction:column}
  .result .total-card{background:linear-gradient(150deg,var(--teal-soft),var(--teal));border-radius:14px;padding:24px;margin-bottom:18px}
  .result .total-card small{color:rgba(255,255,255,.8);font-size:14px;letter-spacing:.03em;text-transform:uppercase;font-weight:600}
  .result .total-card .big{font-family:"Fraunces",serif;font-size:42px;font-weight:600;margin-top:4px}
  .result .total-card .sub{color:rgba(255,255,255,.82);font-size:14.5px;margin-top:4px}
  .breakdown{list-style:none;padding:0;margin:0 0 18px}
  .breakdown li{display:flex;justify-content:space-between;padding:12px 2px;border-bottom:1px solid rgba(255,255,255,.1);font-size:15.5px}
  .breakdown li span:first-child{color:rgba(255,255,255,.8)}
  .breakdown li b{font-weight:600}
  .breakdown li.grand{border-bottom:none;padding-top:15px;font-size:17px}
  .breakdown li.grand b{color:var(--clay)}
  .calc-cta{display:flex;gap:13px;align-items:center;flex-wrap:wrap;margin-top:6px}
  .disclaimer{margin-top:16px;font-size:12.5px;color:rgba(255,255,255,.5);line-height:1.5}

  /* listings */
  .listings{background:var(--paper)}
  .filterbar{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:30px;padding:20px 22px;background:var(--sand);border:1px solid var(--line);border-radius:14px}
  .filterbar .fg{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}
  .filterbar label{font-size:12.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
  .filterbar select{font-family:inherit;font-size:15px;font-weight:500;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:11px 13px;appearance:none;cursor:pointer}
  .filterbar select:focus-visible{border-color:var(--clay)}
  .count{font-size:14.5px;color:var(--muted);margin:0 0 20px}
  .count b{color:var(--ink)}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .card{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .25s ease}
  .card:hover{transform:translateY(-4px);box-shadow:0 26px 50px -30px rgba(26,20,16,.4)}
  .card .media{position:relative;aspect-ratio:3/2;
    background:linear-gradient(150deg,#2a201a 0%,#173b36 100%);overflow:hidden}
  .card .media::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 25% 0%,rgba(200,137,59,.22),transparent 58%)}
  .card .media .tag{position:absolute;top:14px;left:14px;z-index:2;background:rgba(26,20,16,.62);color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.03em;padding:6px 12px;border-radius:999px;backdrop-filter:blur(3px)}
  .card .media .price{position:absolute;bottom:14px;left:14px;z-index:2;color:#fff;font-family:"Fraunces",serif;font-size:24px;font-weight:600;text-shadow:0 2px 12px rgba(0,0,0,.5)}
  .card .body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
  .card .body h3{font-size:18.5px;margin-bottom:4px}
  .card .body .loc{color:var(--muted);font-size:14.5px;margin-bottom:14px}
  .card .specs{display:flex;gap:16px;flex-wrap:wrap;font-size:14px;color:var(--ink);border-top:1px solid var(--line);padding-top:13px;margin-top:auto}
  .card .specs span{display:flex;align-items:center;gap:6px}
  .card .specs b{font-weight:600}
  .card .ref{font-size:12px;color:var(--muted);letter-spacing:.04em;margin-top:12px}
  .card .go{margin-top:14px;font-weight:600;font-size:14.5px;color:var(--clay-deep);text-decoration:none;display:inline-flex;gap:6px;align-items:center}
  .card .go:hover{gap:10px}
  .empty{grid-column:1/-1;text-align:center;padding:50px 20px;color:var(--muted)}
  .listings-foot{text-align:center;margin-top:36px}

  /* process */
  .process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
  .step{background:var(--paper);padding:30px 24px}
  .step .n{font-family:"Fraunces",serif;font-size:15px;color:#fff;background:var(--ink);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .step:nth-child(3) .n{background:var(--clay)}
  .step h3{font-size:19px;margin-bottom:9px}
  .step p{color:var(--muted);font-size:15px;margin:0}

  /* trust band */
  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;text-align:center}
  .stat .num{font-family:"Fraunces",serif;font-size:clamp(38px,5vw,56px);color:var(--clay-deep);font-weight:600;line-height:1}
  .stat .lab{color:var(--muted);font-size:16px;margin-top:8px}

  /* faq */
  .faq{background:var(--sand)}
  .faq-list{display:grid;gap:14px;max-width:840px}
  details{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:4px 22px}
  details[open]{border-color:var(--clay)}
  summary{list-style:none;cursor:pointer;padding:20px 0;font-weight:600;font-size:17.5px;display:flex;justify-content:space-between;align-items:center;gap:16px}
  summary::-webkit-details-marker{display:none}
  summary .plus{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--clay);color:var(--clay-deep);display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s}
  details[open] summary .plus{transform:rotate(45deg)}
  details p{color:var(--muted);padding:0 0 22px;margin:0;font-size:16px}

  /* final cta */
  .final{background:var(--teal);color:#fff;position:relative;overflow:hidden}
  .final::before{content:"";position:absolute;right:-120px;bottom:-160px;width:520px;height:520px;background:radial-gradient(circle,rgba(200,137,59,.32),transparent 64%)}
  .final .wrap{position:relative;z-index:2;text-align:center;max-width:720px}
  .final h2{font-size:clamp(32px,4.4vw,50px);color:#fff}
  .final p{color:rgba(255,255,255,.85);font-size:19px;margin:20px auto 34px;max-width:48ch}
  .final-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

  /* footer */
  footer{background:var(--ink);color:rgba(255,255,255,.62);padding:54px 0 30px;font-size:14.5px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1)}
  footer h4{color:#fff;font-family:"Figtree";font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 16px}
  footer a{color:rgba(255,255,255,.62);text-decoration:none;display:block;margin-bottom:9px}
  footer a:hover{color:#fff}
  .foot-bottom{padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(255,255,255,.4)}

  /* reveal */
  .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
  .reveal.in{opacity:1;transform:none}

  @media (max-width:920px){
    .hero-inner,.advisor-grid,.calc-grid,.foot-grid{grid-template-columns:1fr}
    .process-grid{grid-template-columns:1fr 1fr}
    .stats{grid-template-columns:1fr}
    .nav-links{display:none}
    .menu-toggle{display:block}
    section{padding:64px 0}
    .hero-inner{padding:54px 0 64px}
  }
  @media (prefers-reduced-motion:reduce){
    .reveal{opacity:1;transform:none;transition:none}
    html{scroll-behavior:auto}
  }
