/* ================================================
   Mia van Ooyen – Immobilienmaklerin Bonn-Beuel
   style.css · Version 3 · 2026
   ================================================ */

/* ── Self-hosted Fonts ── */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 600; font-display: swap;
  src: local('Playfair Display SemiBold'),
       url('../fonts/playfair-display-v40-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 700; font-display: swap;
  src: local('Playfair Display Bold'),
       url('../fonts/playfair-display-v40-latin-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal; font-weight: 400; font-display: swap;
  src: local('Source Sans 3'), local('SourceSans3'),
       url('../fonts/source-sans-3-v19-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal; font-weight: 600; font-display: swap;
  src: local('Source Sans 3 SemiBold'),
       url('../fonts/source-sans-3-v19-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal; font-weight: 700; font-display: swap;
  src: local('Source Sans 3 Bold'),
       url('../fonts/source-sans-3-v19-latin-700.woff2') format('woff2');
}

/* ── Variables ── */
:root {
  --color-heading:      #1a2744;
  --color-text:         #2d2d2d;
  --color-accent:       #b0413e;
  --color-accent-hover: #8f3230;
  --color-bg:           #ffffff;
  --color-bg-soft:      #f8f7f5;
  --color-bg-dark:      #1a2744;
  --color-border:       #e4e0db;
  --color-muted:        #6b6b6b;
  --color-white:        #ffffff;
  --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body:    'Source Sans 3', 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --max-width:   1140px;
  --nav-height:  72px;
  --section-gap: 5rem;
  --radius:      4px;
  --shadow-sm:   0 2px 12px rgba(26,39,68,0.07);
  --shadow-md:   0 6px 28px rgba(26,39,68,0.11);
  --shadow-lg:   0 16px 48px rgba(26,39,68,0.14);
  --transition:  0.22s ease;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-weight:400;font-size:1rem;line-height:1.7;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit}

/* ── Typography ── */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-heading);line-height:1.22;font-weight:700}
h1{font-size:clamp(1.75rem,4.5vw,3rem);letter-spacing:-0.02em}
h2{font-size:clamp(1.5rem,3vw,2.25rem)}
h3{font-size:clamp(1.1rem,2vw,1.55rem)}
h4{font-size:1.05rem}
p{margin-bottom:1.1rem;color:var(--color-text)}
p:last-child{margin-bottom:0}
strong{font-weight:600;color:var(--color-heading)}

/* ── Layout ── */
.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:1.5rem}
.section{padding-block:var(--section-gap)}
.section--alt{background:var(--color-bg-soft)}
.section--dark{background:var(--color-bg-dark);color:var(--color-white)}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:var(--color-white)}
.section-label{font-family:var(--font-body);font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-accent);display:block;margin-bottom:0.75rem}
.section-title{margin-bottom:1rem}
.section-intro{font-size:1.05rem;color:var(--color-muted);max-width:600px;line-height:1.65}
.text-center{text-align:center}
.text-center .section-intro{margin-inline:auto}

/* ── Buttons ── */
.btn{display:inline-block;padding:0.8rem 2rem;font-family:var(--font-body);font-size:0.9rem;font-weight:600;letter-spacing:0.04em;border-radius:var(--radius);cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition);border:2px solid transparent;text-align:center;white-space:nowrap;-webkit-appearance:none;appearance:none}
.btn--primary{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}
.btn--primary:hover,.btn--primary:focus{background:var(--color-accent-hover);border-color:var(--color-accent-hover);box-shadow:0 4px 20px rgba(176,65,62,0.25);transform:translateY(-1px);outline:none}
.btn--outline{background:transparent;color:var(--color-heading);border-color:var(--color-heading)}
.btn--outline:hover,.btn--outline:focus{background:var(--color-heading);color:var(--color-white);outline:none}
.btn--outline-white{background:transparent;color:var(--color-white);border-color:rgba(255,255,255,0.6)}
.btn--outline-white:hover{background:var(--color-white);color:var(--color-heading);border-color:var(--color-white)}
.btn--sm{padding:0.6rem 1.4rem;font-size:0.82rem}
.btn--lg{padding:1rem 2.4rem;font-size:1rem}

/* ── HEADER ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);transition:box-shadow var(--transition)}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-height)}
.logo{display:flex;flex-direction:column;line-height:1.2;text-decoration:none}
.logo-name{font-family:var(--font-heading);font-size:1.18rem;font-weight:700;color:var(--color-heading)}
.logo-sub{font-size:0.67rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-muted)}
.main-nav{display:flex;align-items:center;gap:0.25rem}
.main-nav a{font-size:0.88rem;font-weight:600;color:var(--color-text);padding:0.4rem 0.85rem;border-radius:var(--radius);letter-spacing:0.02em;transition:color var(--transition),background var(--transition);position:relative}
.main-nav a:hover,.main-nav a.active{color:var(--color-accent)}
.main-nav a.active::after{content:'';position:absolute;bottom:-1px;left:0.85rem;right:0.85rem;height:2px;background:var(--color-accent);border-radius:2px}
.header-cta{margin-left:1rem}
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:18px;cursor:pointer;background:none;border:none;padding:0;z-index:1001}
.hamburger span{display:block;width:100%;height:2px;background:var(--color-heading);border-radius:2px;transition:transform 0.3s,opacity 0.3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;top:var(--nav-height);left:0;right:0;background:var(--color-white);border-bottom:1px solid var(--color-border);padding:1.5rem;z-index:999;box-shadow:var(--shadow-md);flex-direction:column;gap:0.25rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1rem;font-weight:600;color:var(--color-text);padding:0.75rem 1rem;border-radius:var(--radius);transition:color var(--transition),background var(--transition)}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--color-accent);background:var(--color-bg-soft)}
.mobile-nav .btn{margin-top:1rem;text-align:center}
.mobile-nav .btn--primary{color:#fff !important}
.mobile-nav .btn--primary:hover,.mobile-nav .btn--primary:focus{color:var(--color-heading) !important}
.page-content{padding-top:var(--nav-height)}

/* ── HERO ── */
.hero{padding-block:4rem 3.5rem;overflow:hidden;position:relative;background:var(--color-bg)}
.hero::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:var(--color-bg-soft);clip-path:polygon(8% 0,100% 0,100% 100%,0% 100%);z-index:0}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-content{padding-right:1rem}
.hero-content .section-label{margin-bottom:1rem}
.hero-content h1{margin-bottom:1.25rem}
.hero-content .lead{font-size:1.1rem;color:var(--color-muted);margin-bottom:2.25rem;line-height:1.65}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-image{display:flex;align-items:center;justify-content:center}
.hero-image--flat img{width:420px;height:420px;max-width:100%;border-radius:50%;object-fit:cover;object-position:top center;box-shadow:none}

/* Intro portrait */
.intro-img--flat{border-radius:50%;overflow:hidden;width:320px;height:320px;flex-shrink:0}
.intro-img--flat img{width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:50%}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.service-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.25rem 2rem;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}
.service-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--color-accent)}
.service-icon{width:52px;height:52px;background:var(--color-bg-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.service-icon svg{width:24px;height:24px;stroke:var(--color-accent);fill:none;stroke-width:1.8}
.service-card h3{margin-bottom:0.6rem;font-size:1.15rem}
.service-card p{color:var(--color-muted);font-size:0.95rem;margin-bottom:1.25rem}
.service-card .card-link{font-size:0.85rem;font-weight:700;color:var(--color-accent);letter-spacing:0.04em;display:inline-flex;align-items:center;gap:0.4rem;transition:gap var(--transition)}
.service-card .card-link:hover{gap:0.7rem}
.service-card .card-link::after{content:'→'}

/* ── INTRO SECTION ── */
.intro-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:center}
.intro-content h2{margin-bottom:1.25rem}
.intro-content p{color:var(--color-muted);margin-bottom:1.25rem}

/* ── USP LIST ── */
.usp-list{display:flex;flex-direction:column;gap:1.25rem;margin-top:2rem}
.usp-item{display:flex;align-items:flex-start;gap:1rem}
.usp-check{width:24px;height:24px;background:var(--color-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:0.1rem}
.usp-check svg{width:14px;height:14px;stroke:white;stroke-width:2.5;fill:none}
.usp-item p{margin:0;font-size:0.95rem;color:var(--color-muted)}
.usp-item p strong{color:var(--color-heading)}

/* ── REGION ── */
.region-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.5rem}
.region-item{display:flex;align-items:flex-start;gap:0.9rem;padding:1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition)}
.region-item:hover{border-color:var(--color-accent);box-shadow:var(--shadow-sm)}
.region-dot{width:10px;height:10px;background:var(--color-accent);border-radius:50%;flex-shrink:0;margin-top:0.45rem}
.region-item h4{font-size:0.95rem;margin-bottom:0.2rem}
.region-item p{font-size:0.85rem;color:var(--color-muted);margin:0}

/* Market data */
.market-data{display:flex;flex-direction:column;gap:1.25rem;padding:2rem;background:var(--color-heading);border-radius:var(--radius)}
.market-item strong{display:block;font-family:var(--font-heading);font-size:1.75rem;color:var(--color-white);line-height:1;margin-bottom:0.25rem}
.market-item span{font-size:0.78rem;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:0.08em;font-weight:600}

/* ── PROCESS (vertical) ── */
.steps-list{display:flex;flex-direction:column;gap:0;position:relative}
.steps-list::before{content:'';position:absolute;left:2rem;top:0;bottom:0;width:2px;background:var(--color-border);z-index:0}
.step-item{display:grid;grid-template-columns:4rem 1fr;gap:1.5rem;padding-block:1.75rem;position:relative;z-index:1}
.step-num{width:4rem;height:4rem;background:var(--color-white);border:2px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--color-heading);flex-shrink:0;transition:background var(--transition),border-color var(--transition),color var(--transition);box-shadow:0 0 0 6px var(--color-bg-soft)}
.step-item:hover .step-num{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-white)}
.step-content h3{font-size:1.1rem;margin-bottom:0.4rem}
.step-content p{color:var(--color-muted);font-size:0.95rem;margin:0}

/* ── PROCESS (horizontal – Verkaufen) ── */
.process-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:3rem;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}
.process-step{padding:2.25rem 2rem;border-right:1px solid var(--color-border);transition:background var(--transition)}
.process-step:last-child{border-right:none}
.process-step:hover{background:var(--color-bg-soft)}
.process-step-num{font-family:var(--font-heading);font-size:3rem;font-weight:700;color:var(--color-border);line-height:1;margin-bottom:1rem;display:block}
.process-step h3{font-size:1.1rem;margin-bottom:0.6rem}
.process-step p{font-size:0.9rem;color:var(--color-muted);margin:0}

/* ── TESTIMONIALS ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.testimonial-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;position:relative}
.testimonial-card::before{content:'\201C';font-family:var(--font-heading);font-size:4rem;line-height:1;color:var(--color-accent);opacity:0.25;position:absolute;top:1rem;left:1.5rem}
.testimonial-text{font-style:italic;color:var(--color-muted);margin-bottom:1.5rem;margin-top:1.5rem;font-size:0.95rem;line-height:1.7}
.testimonial-author{display:flex;align-items:center;gap:0.85rem}
.testimonial-author img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.testimonial-author-info strong{display:block;font-size:0.9rem;color:var(--color-heading)}
.testimonial-author-info span{font-size:0.78rem;color:var(--color-muted)}
.stars{color:#f4a022;font-size:0.85rem;margin-bottom:0.75rem}

/* ── CTA ── */
.cta-section{text-align:center;padding-block:5rem;background:linear-gradient(135deg,var(--color-heading) 0%,#243366 100%);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(176,65,62,0.15) 0%,transparent 60%);pointer-events:none}
.cta-section h2{color:var(--color-white);margin-bottom:1rem}
.cta-section p{color:rgba(255,255,255,0.75);max-width:540px;margin-inline:auto;margin-bottom:2.5rem;font-size:1.05rem}
.cta-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start}
.about-portrait{position:sticky;top:calc(var(--nav-height) + 2rem)}
.about-portrait img{width:100%;max-width:380px;margin-inline:auto;border-radius:50%;object-fit:cover;object-position:top center;box-shadow:none}
.about-portrait-caption{margin-top:1.25rem;text-align:center}
.about-portrait-caption strong{display:block;font-family:var(--font-heading);font-size:1.15rem;color:var(--color-heading)}
.about-portrait-caption span{font-size:0.82rem;color:var(--color-muted);letter-spacing:0.07em;text-transform:uppercase}
.cv-list{margin-top:1.5rem}
.cv-item{display:grid;grid-template-columns:130px 1fr;gap:1.25rem;padding-block:1.25rem;border-bottom:1px solid var(--color-border)}
.cv-item:last-child{border-bottom:none}
.cv-period{font-size:0.82rem;font-weight:700;color:var(--color-accent);letter-spacing:0.05em;text-transform:uppercase;padding-top:0.15rem}
.cv-detail strong{display:block;font-size:0.95rem;color:var(--color-heading);margin-bottom:0.2rem}
.cv-detail span{font-size:0.88rem;color:var(--color-muted)}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;align-items:start}
.contact-info-card{background:var(--color-bg-soft);border-radius:var(--radius);padding:2.5rem;border:1px solid var(--color-border)}
.contact-item{display:flex;gap:1.25rem;padding-block:1.5rem;border-bottom:1px solid var(--color-border)}
.contact-item:first-child{padding-top:0}
.contact-item:last-child{border-bottom:none;padding-bottom:0}
.contact-item-icon{width:44px;height:44px;background:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--color-border)}
.contact-item-icon svg{width:20px;height:20px;stroke:var(--color-accent);fill:none;stroke-width:1.8}
.contact-item-label{font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-muted);display:block;margin-bottom:0.3rem}
.contact-item-value{font-size:1rem;font-weight:600;color:var(--color-heading);line-height:1.4}
.contact-item-sub{font-size:0.85rem;color:var(--color-muted);margin-top:0.2rem}

/* ── FORMS ── */
.form-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow-sm)}
.form-title{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-heading);margin-bottom:0.4rem}
.form-subtitle{font-size:0.9rem;color:var(--color-muted);margin-bottom:2rem}
.form-group{margin-bottom:1.25rem}
.form-group>label{display:block;font-size:0.82rem;font-weight:700;color:var(--color-heading);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:0.5rem}
.form-group label .req{color:var(--color-accent);margin-left:2px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.75rem 1rem;border:1.5px solid var(--color-border);border-radius:var(--radius);font-size:0.95rem;color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-heading);box-shadow:0 0 0 3px rgba(26,39,68,0.08)}
.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(176,65,62,0.1)}
.form-group textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-error{font-size:0.8rem;color:var(--color-accent);margin-top:0.4rem;display:none}
.form-error.visible{display:block}

/* Radio – custom, Safari-safe */
.radio-group{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:0.25rem}
.radio-label{display:flex;align-items:center;gap:0.6rem;font-size:0.95rem;color:var(--color-text);cursor:pointer;font-weight:400;text-transform:none;letter-spacing:0;line-height:1.4}
.radio-label input[type="radio"]{-webkit-appearance:none;appearance:none;width:20px;height:20px;min-width:20px;max-width:20px;min-height:20px;max-height:20px;border:2px solid var(--color-border);border-radius:50%;background:white;cursor:pointer;position:relative;transition:border-color var(--transition);flex-shrink:0;margin:0;padding:0;display:inline-block;vertical-align:middle}
.radio-label input[type="radio"]:checked{border-color:var(--color-accent)}
.radio-label input[type="radio"]:checked::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--color-accent)}
.radio-label input[type="radio"]:focus{outline:2px solid var(--color-accent);outline-offset:2px}

/* Checkbox – custom with checkmark, Safari-safe */
.checkbox-label{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.85rem;color:var(--color-muted);cursor:pointer;text-transform:none;letter-spacing:0;font-weight:400;line-height:1.55}
.checkbox-label input[type="checkbox"]{-webkit-appearance:none;appearance:none;width:20px;height:20px;min-width:20px;border:2px solid var(--color-border);border-radius:3px;background:white;cursor:pointer;position:relative;transition:border-color var(--transition),background var(--transition);flex-shrink:0;margin-top:1px;margin-right:0}
.checkbox-label input[type="checkbox"]:checked{background:var(--color-accent);border-color:var(--color-accent)}
.checkbox-label input[type="checkbox"]:checked::after{content:'';position:absolute;top:2px;left:6px;width:5px;height:9px;border:2px solid white;border-top:none;border-left:none;transform:rotate(45deg)}
.checkbox-label input[type="checkbox"]:focus{outline:2px solid var(--color-accent);outline-offset:2px}
.checkbox-label a{color:var(--color-accent);text-decoration:underline}
.form-submit-row{display:flex;justify-content:flex-start;margin-top:1.5rem}
.form-message{padding:1rem 1.25rem;border-radius:var(--radius);font-size:0.9rem;margin-bottom:1.25rem;display:none}
.form-message.success{background:#f0faf0;border:1px solid #6abf69;color:#2a6a2a;display:block}
.form-message.error-msg{background:#fff5f5;border:1px solid var(--color-accent);color:var(--color-accent);display:block}

/* ── PAGE HERO ── */
.page-hero{background:var(--color-bg-soft);border-bottom:1px solid var(--color-border);padding-block:3.5rem 3rem}
.page-hero-inner{max-width:var(--max-width);margin-inline:auto;padding-inline:1.5rem}
.breadcrumb{display:flex;align-items:center;gap:0.5rem;font-size:0.8rem;color:var(--color-muted);margin-bottom:1rem}
.breadcrumb a{color:var(--color-muted);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--color-accent)}
.breadcrumb span{color:var(--color-border)}
.page-hero h1{max-width:700px}
.page-hero .lead{font-size:1.05rem;color:var(--color-muted);max-width:600px;margin-top:0.75rem;line-height:1.65}

/* ── FOOTER ── */
.site-footer{background:var(--color-heading);color:rgba(255,255,255,0.7);padding-block:4rem 2rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-brand .logo-name{color:var(--color-white)}
.footer-brand .logo-sub{color:rgba(255,255,255,0.5)}
.footer-brand p{font-size:0.88rem;color:rgba(255,255,255,0.55);margin-top:1rem;margin-bottom:0;max-width:280px;line-height:1.65}
.footer-heading{font-size:0.72rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:1.25rem;display:block}
.footer-links{display:flex;flex-direction:column;gap:0.6rem}
.footer-links a{font-size:0.9rem;color:rgba(255,255,255,0.65);transition:color var(--transition)}
.footer-links a:hover{color:var(--color-white)}
.footer-contact-item{font-size:0.9rem;color:rgba(255,255,255,0.65);margin-bottom:0.6rem;display:flex;align-items:flex-start;gap:0.6rem}
.footer-contact-item a{color:rgba(255,255,255,0.65);transition:color var(--transition)}
.footer-contact-item a:hover{color:var(--color-white)}
.footer-bottom{padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:0.8rem;color:rgba(255,255,255,0.4)}
.footer-legal-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-legal-links a{font-size:0.8rem;color:rgba(255,255,255,0.4);transition:color var(--transition)}
.footer-legal-links a:hover{color:rgba(255,255,255,0.75)}

/* ── LEGAL ── */
.legal-content{max-width:780px}
.legal-content h2{font-size:1.4rem;margin-top:2.5rem;margin-bottom:0.75rem}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-size:1rem;margin-top:1.5rem;margin-bottom:0.35rem}
.legal-content p{color:var(--color-muted);margin-bottom:0.85rem}
.legal-content ul{list-style:disc;padding-left:1.5rem;color:var(--color-muted);margin-bottom:0.85rem}
.legal-content ul li{margin-bottom:0.35rem}
.legal-content a{color:var(--color-accent);text-decoration:underline}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  :root{--section-gap:4rem}
  .hero-inner,.intro-grid{gap:2.5rem}
  .about-grid,.contact-grid{gap:3rem}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .services-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr}
  .process-step{border-right:none;border-bottom:1px solid var(--color-border)}
  .process-step:last-child{border-bottom:none}
  .intro-grid{grid-template-columns:1fr}
  .intro-img--flat{width:240px;height:240px;margin-inline:auto}
  /* All inline two-col grids */
  [style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns: 1fr 1fr"]{
    grid-template-columns:1fr !important;
    gap:2.5rem !important
  }
}
@media(max-width:768px){
  .main-nav,.header-cta{display:none}
  .hamburger{display:flex}
  .hero::before{display:none}
  .hero-inner{grid-template-columns:1fr;gap:2rem}
  .hero-content{padding-right:0;text-align:center}
  .hero-actions{justify-content:center}
  .hero-image{order:-1}
  .hero-image--flat img{width:200px;height:200px;margin:0 auto}
  .about-grid{grid-template-columns:1fr}
  .about-portrait{position:static}
  .about-portrait img{max-width:260px}
  .contact-grid{grid-template-columns:1fr}
  .contact-info-card{padding:1.5rem}
  .form-row{grid-template-columns:1fr}
  .form-card{padding:1.5rem}
  .region-list{grid-template-columns:1fr}
  .services-grid,.testimonials-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .cv-item{grid-template-columns:1fr;gap:0.25rem}
  .market-data{flex-direction:column;gap:1.25rem}
  /* All inline grids */
  [style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns: 1fr 1fr"],[style*="grid-template-columns:1fr 1.5fr"],[style*="grid-template-columns:1fr 1.6fr"],[style*="grid-template-columns: 1fr 1.5fr"],[style*="grid-template-columns: 1fr 1.6fr"],[style*="grid-template-columns:repeat(2,1fr)"],[style*="grid-template-columns: repeat(2,1fr)"]{
    grid-template-columns:1fr !important;
    gap:2rem !important
  }
}
@media(max-width:480px){
  .hero{padding-block:2.5rem 2rem}
  .hero-actions,.cta-actions{flex-direction:column;align-items:stretch;padding-inline:0}
  .hero-actions .btn,.cta-actions .btn{width:100%;text-align:center}
  .section{padding-block:3rem}
}

/* ── Utilities ── */
.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}

/* Ortsteile grid – bonn-beuel page */
@media(max-width:768px){
  .ortsteile-grid{grid-template-columns:1fr !important}
}

/* ── Haus-verkaufen USP grid responsive ── */
.vk-usp-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:900px){
  .vk-usp-grid{grid-template-columns:1fr !important;gap:2.5rem !important}
  .vk-usp-grid>div:last-child{border-radius:4px}
}
/* Verkaufen region list – 3 cols desktop, 1 col mobile */
.vk-region{grid-template-columns:repeat(3,1fr) !important}
@media(max-width:768px){.vk-region{grid-template-columns:1fr !important}}

/* Bewertung form grid */
.bew-form-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
@media(max-width:768px){.bew-form-grid{grid-template-columns:1fr !important;gap:2rem !important}}

/* Testimonial author – no image → adjust layout */
.testimonial-author{display:flex;align-items:center;gap:0.85rem;flex-wrap:wrap}
