/* Urban Home — shared stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  --navy:#0C1C38;
  --navy-dark:#07101F;
  --gold:#C9A840;
  --gold-light:#D4B84A;
  --cream:#F2EDE3;
  --stone:#C7BFA8;
  --stone-dark:#A89F85;
  --sage:#6B8463;
  --ink:#142B3B;
  --ink-soft:#5C5648;
  --ink-faint:#9a9488;
  --periwinkle:#B8C2E0;
  --white:#FFFFFF;
  --radius:8px;
  --radius-lg:10px;
  --font-display:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-body:'Inter',-apple-system,'Segoe UI',Helvetica,Arial,sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box;}
/* Skip navigation link */
.skip-link{position:absolute;top:-100%;left:12px;background:var(--gold);color:var(--navy);font-weight:500;padding:10px 18px;border-radius:0 0 6px 6px;text-decoration:none;z-index:200;transition:top .15s;}
.skip-link:focus{top:0;}
/* Visible focus rings for keyboard navigation */
:focus-visible{outline:2px solid var(--gold-light);outline-offset:3px;border-radius:3px;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.1rem;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
.container{max-width:var(--maxw); margin:0 auto; padding:0 32px;}
h1,h2,h3{font-family:var(--font-display); font-weight:400; margin:0;}
h2{font-size:2rem; line-height:1.35;}
h3{font-size:18px; line-height:1.4;}
.eyebrow{font-size:11.5px; letter-spacing:1.5px; color:var(--gold); margin-bottom:12px; text-transform:uppercase;}
.content-narrow{max-width:720px; margin:0 auto;}
.section{padding:80px 0;}
.section-tight{padding:48px 0;}
.center{text-align:center;}
.muted{color:var(--ink-soft);}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13.5px; font-weight:500; padding:13px 24px; border-radius:6px;
  cursor:pointer; border:none; font-family:var(--font-body);
  transition:transform .22s cubic-bezier(.25,.8,.25,1), box-shadow .22s, background .22s, color .22s, border-color .22s;
}
.btn:hover{transform:translateY(-2px);}
.btn-gold{background:var(--gold); color:var(--navy);}
.btn-gold:hover{background:var(--gold-light); box-shadow:0 6px 22px rgba(201,168,64,0.45);}
.btn-outline{background:transparent; border:1px solid rgba(255,255,255,0.35); color:#fff;}
.btn-outline:hover{background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.65);}
.btn-outline-dark{background:transparent; border:1px solid var(--navy); color:var(--navy);}
.btn-outline-dark:hover{background:var(--navy); color:#fff;}

/* Header */
.site-header{background:var(--navy); position:sticky; top:0; z-index:50;}
.site-header .container{display:flex; align-items:center; justify-content:space-between; padding-top:0; padding-bottom:0;}
.logo{display:inline-flex; align-items:center; position:relative;}
.logo img{height:117px;}
.logo-tagline{display:none;}
.main-nav{display:flex; gap:26px; font-size:13.5px; color:var(--periwinkle);}
.main-nav a{padding-bottom:4px; border-bottom:1px solid transparent;}
.main-nav a:hover, .main-nav a.active{color:#fff; border-bottom-color:var(--gold);}
.header-actions{display:flex; align-items:center; gap:16px;}
.lang-switch{position:relative; font-size:11.5px; color:var(--periwinkle); cursor:pointer; padding:13px 0;}
.lang-switch .lang-current{display:flex; align-items:center; gap:4px;}
.lang-menu{display:none; position:absolute; right:0; top:24px; background:#fff; border-radius:6px; padding:6px; min-width:90px; box-shadow:0 8px 24px rgba(0,0,0,0.15);}
.lang-switch.open .lang-menu{display:block;}
.lang-menu a{display:block; padding:7px 10px; font-size:12.5px; color:var(--ink); border-radius:4px;}
.lang-menu a:hover{background:var(--cream);}
.icon-link{color:var(--periwinkle); font-size:16px; display:inline-flex; align-items:center; justify-content:center; min-width:44px; min-height:44px;}
.mobile-toggle{display:none; color:#fff; font-size:22px; background:none; border:none; cursor:pointer;}

/* Hero — Chesterfield Polstermuster */
.hero{
  background-color:#060D18;
  background-image:
    radial-gradient(ellipse at center, transparent 20%, rgba(4,8,14,0.92) 100%),
    radial-gradient(ellipse at 16% 58%, rgba(201,168,64,0.13) 0%, transparent 50%),
    radial-gradient(ellipse at 84% 20%, rgba(201,168,64,0.09) 0%, transparent 45%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cpath d='M60,1 Q78,42 119,60 Q78,78 60,119 Q42,78 1,60 Q42,42 60,1 Z' fill='none' stroke='rgba(201,168,64,0.26)' stroke-width='1'/%3E%3Cpath d='M60,22 Q74,46 98,60 Q74,74 60,98 Q46,74 22,60 Q46,46 60,22 Z' fill='none' stroke='rgba(201,168,64,0.10)' stroke-width='0.5'/%3E%3Ccircle cx='60' cy='1' r='3' fill='rgba(201,168,64,0.40)'/%3E%3Ccircle cx='119' cy='60' r='3' fill='rgba(201,168,64,0.40)'/%3E%3Ccircle cx='60' cy='119' r='3' fill='rgba(201,168,64,0.40)'/%3E%3Ccircle cx='1' cy='60' r='3' fill='rgba(201,168,64,0.40)'/%3E%3Ccircle cx='60' cy='60' r='4' fill='none' stroke='rgba(201,168,64,0.20)' stroke-width='0.7'/%3E%3Ccircle cx='60' cy='60' r='2' fill='rgba(201,168,64,0.32)'/%3E%3C/svg%3E");
  background-size: 100% 100%, 100% 100%, 100% 100%, 120px 120px;
  padding:56px 0 0; text-align:center; position:relative; overflow:hidden;
}

.hero::before{content:none;}

/* Goldene Trennlinie unten */
.hero::after{
  content:'';
  position:absolute; bottom:0; left:0; right:0;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(201,168,64,0.7) 30%, #C9A840 50%, rgba(201,168,64,0.7) 70%, transparent 100%);
  z-index:1;
}
.hero .container{position:relative; z-index:1;}
.hero h1{font-size:clamp(2.8rem,4.5vw,3.6rem); color:#fff; line-height:1.3; max-width:680px; margin:0 auto 16px;}
.hero p.lead{font-family:var(--font-display); font-style:italic; font-size:1.15rem; color:rgba(214,204,188,0.90); max-width:560px; margin:0 auto 36px; line-height:1.8; letter-spacing:0.015em;}
.search-wrap{padding:0 32px 60px; display:flex; justify-content:center;}
.search-bar{background:#fff; border-radius:var(--radius-lg); padding:18px; display:flex; gap:8px; max-width:680px; width:100%; align-items:center; flex-wrap:wrap;}
.search-field{flex:1; min-width:120px; padding:10px 14px; border-right:1px solid #eee;}
.search-field:last-of-type{border-right:none;}
.search-field label{display:block; font-size:9.5px; color:var(--ink-faint); letter-spacing:.5px; margin-bottom:2px; text-transform:uppercase;}
.search-field select{border:none; font-size:13px; color:var(--ink); width:100%; font-family:var(--font-body); background:transparent;}
.stats-row{display:flex; gap:48px; justify-content:center; flex-wrap:wrap; padding:24px 32px; background:#fff;}
.stat-num{font-family:var(--font-display); font-size:24px; color:var(--ink);}
.stat-label{font-size:10px; letter-spacing:1px; color:var(--ink-faint); text-transform:uppercase;}
.stat-divider{border-left:1px solid #eee; padding-left:30px; font-size:12.5px; align-self:center;}
.stat-divider a{border-bottom:1px solid var(--gold);}

/* Page header (non-home pages) */
.page-header{background:var(--navy); padding:54px 0; text-align:center;}
.page-header h1{color:#fff; font-size:2.8rem;}
.page-header p{font-family:var(--font-display); font-style:italic; color:var(--periwinkle); font-size:1.05rem; max-width:480px; margin:14px auto 0;}

/* About page — full-image cinematic hero */
.about-hero{
  position:relative; overflow:hidden;
  min-height:600px; display:flex; align-items:center; text-align:center;
  background:
    radial-gradient(ellipse at center, rgba(6,12,22,0.38) 0%, rgba(6,12,22,0.86) 100%),
    url('../assets/urban-home-hero.png') center center / cover no-repeat;
}
.about-hero::after{
  content:''; position:absolute; bottom:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(180,140,40,0.4) 8%,
    rgba(201,168,64,0.85) 20%,
    rgba(240,215,105,1) 35%,
    rgba(255,245,180,1) 50%,
    rgba(240,215,105,1) 65%,
    rgba(201,168,64,0.85) 80%,
    rgba(180,140,40,0.4) 92%,
    transparent 100%);
  box-shadow:0 0 12px rgba(240,215,105,0.55), 0 0 4px rgba(255,245,180,0.7);
  z-index:2;
}
.about-hero .container{position:relative; z-index:1; padding-top:60px; padding-bottom:140px;}
.about-hero h1{color:#fff; font-size:clamp(2.4rem,4vw,3.4rem); line-height:1.2; max-width:720px; margin:12px auto 20px;}
.about-hero-lead{font-family:var(--font-display); font-style:italic; font-size:1.12rem; color:rgba(214,204,188,0.88); max-width:600px; margin:0 auto 36px; line-height:1.8; letter-spacing:0.01em;}
.about-hero + .section{position:relative;}
.about-hero + .section::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(201,168,64,0.4) 15%, rgba(240,215,105,1) 50%, rgba(201,168,64,0.4) 85%, transparent 100%);
  z-index:2;
}

/* Contact page — cinematic hero */
.contact-hero{
  position:relative; overflow:hidden;
  min-height:600px; display:flex; align-items:center; text-align:center;
  background:
    radial-gradient(ellipse at center, rgba(6,12,22,0.38) 0%, rgba(6,12,22,0.86) 100%),
    url('../assets/urban-home-hero.png') center center / cover no-repeat;
}
.contact-hero::after{
  content:''; position:absolute; bottom:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(180,140,40,0.4) 8%,
    rgba(201,168,64,0.85) 20%,
    rgba(240,215,105,1) 35%,
    rgba(255,245,180,1) 50%,
    rgba(240,215,105,1) 65%,
    rgba(201,168,64,0.85) 80%,
    rgba(180,140,40,0.4) 92%,
    transparent 100%);
  box-shadow:0 0 12px rgba(240,215,105,0.55), 0 0 4px rgba(255,245,180,0.7);
  z-index:2;
}
.contact-hero .container{position:relative; z-index:1; padding-top:60px; padding-bottom:140px;}
.contact-hero-content{max-width:720px; margin:0 auto;}
.contact-hero h1{color:#fff; font-size:clamp(2.4rem,4vw,3.4rem); line-height:1.2; max-width:720px; margin:12px auto 20px;}
.contact-hero-lead{font-family:var(--font-display); font-style:italic; font-size:1.12rem; color:rgba(214,204,188,0.88); max-width:600px; margin:0 auto 36px; line-height:1.8; letter-spacing:0.01em;}
.contact-hero + .section{position:relative;}
.contact-hero + .section::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(201,168,64,0.4) 15%, rgba(240,215,105,1) 50%, rgba(201,168,64,0.4) 85%, transparent 100%);
  z-index:2;
}

/* Cards */
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:22px;}
.service-card{background:#fff; border:1px solid #eee; border-radius:var(--radius); padding:28px;}
.service-card .num{font-family:var(--font-display); font-size:22px; color:var(--stone);}
.service-card h3{font-size:17px; margin:10px 0 12px;}
.check-list div{font-size:13px; color:var(--ink-soft); margin-bottom:8px; display:flex; gap:8px; align-items:flex-start;}
.check-list i{color:var(--gold); font-size:14px; margin-top:1px;}

/* Process steps */
.steps-row{display:flex; justify-content:space-between; position:relative; flex-wrap:wrap; gap:18px;}
.steps-row::before{content:'';position:absolute; top:18px; left:34px; right:34px; height:1px; background:var(--stone); z-index:0;}
.step{display:flex; flex-direction:column; align-items:center; gap:10px; width:15%; min-width:90px; z-index:1; background:#fff;}
.step-num{width:36px; height:36px; border-radius:50%; background:var(--navy); color:var(--gold-light); font-family:var(--font-display); font-size:14px; display:flex; align-items:center; justify-content:center;}
.step-label{font-size:11.5px; color:var(--ink); text-align:center;}

/* Property cards */
.prop-card{border:1px solid #eee; border-radius:var(--radius); overflow:hidden; transition:transform .25s cubic-bezier(.25,.8,.25,1), box-shadow .25s, border-color .25s;}
.prop-card:hover{transform:translateY(-6px); box-shadow:0 18px 44px rgba(13,27,42,0.16), 0 0 0 1px rgba(201,168,64,0.2); border-color:rgba(201,168,64,0.3);}
.prop-photo{height:170px; background:var(--stone); position:relative; display:flex; align-items:center; justify-content:center;}
.prop-photo .house-shape{width:70px; height:52px; background:var(--stone-dark); clip-path:polygon(8% 100%,8% 50%,50% 15%,92% 50%,92% 100%);}
.badge-corner{position:absolute; top:10px; left:10px; font-size:10px; padding:4px 9px; border-radius:3px; color:#fff;}
.badge-new{background:var(--navy);}
.badge-featured{background:var(--sage);}
.price-badge{position:absolute; bottom:10px; left:10px; background:var(--gold); color:var(--navy); font-size:13px; font-weight:500; padding:5px 12px; border-radius:3px;}
.heart{position:absolute; top:10px; right:10px; font-size:18px; background:rgba(255,255,255,0.92); border-radius:50%; padding:7px; color:var(--ink-faint); cursor:pointer; transition:transform .15s; box-sizing:content-box;}
.heart.saved{color:var(--gold); animation:pop .3s ease;}
.prop-info{padding:16px;}
.prop-title{font-size:15px; font-family:var(--font-display); font-weight:400; color:var(--ink); margin-bottom:8px;}
.prop-meta{display:flex; gap:14px; font-size:11.5px; color:var(--ink-faint);}
.prop-meta i{margin-right:4px;}

/* Virtual tours */
.tour-card{background:var(--navy); border-radius:var(--radius); height:160px; position:relative; display:flex; align-items:center; justify-content:center; transition:opacity .2s;}
.tour-card:hover{opacity:.88;}
.tour-tag{position:absolute; top:12px; left:12px; background:rgba(255,255,255,0.15); color:#fff; font-size:10px; padding:4px 9px; border-radius:3px;}
.tour-label{position:absolute; bottom:12px; left:12px; color:#fff; font-size:12px;}
.play-btn{position:relative; width:50px; height:50px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer;}
.play-btn::before{content:''; position:absolute; inset:-9px; border-radius:50%; border:2px solid var(--gold); animation:pulseRing 2s infinite;}
.play-btn i{color:var(--navy); font-size:19px;}

/* Map */
.map-box{background:#EDE8DC; border-radius:var(--radius); height:200px; position:relative; overflow:hidden;}
.map-pin{position:absolute; display:flex; flex-direction:column; align-items:center;}
.map-pin i{color:var(--gold); font-size:22px;}
.map-pin span{font-size:10.5px; color:var(--ink); background:#fff; padding:2px 7px; border-radius:3px; margin-top:2px; white-space:nowrap;}

/* Network / cross-promo */
.network-strip{padding:36px 0; border-top:1px solid #eee; border-bottom:1px solid #eee; display:flex; gap:24px; align-items:center;}
.network-strip .label{font-size:11px; letter-spacing:1.5px; color:var(--gold); min-width:120px; text-transform:uppercase;}
.network-strip h4{font-family:var(--font-display); font-size:17px; margin:0 0 6px;}

/* CTA band */
.cta-band{background:var(--navy); padding:56px 0; text-align:center;}
.cta-band h2{color:#fff; font-size:25px; margin-bottom:10px;}
.cta-band p{color:var(--periwinkle); font-size:13.5px; margin-bottom:26px;}
.cta-buttons{display:flex; gap:14px; justify-content:center; flex-wrap:wrap;}

/* Footer */
.site-footer{background:var(--navy-dark); padding:48px 0 24px; color:var(--periwinkle);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; margin-bottom:30px;}
.footer-col .ftitle{font-size:11px; letter-spacing:1px; color:var(--gold); margin-bottom:12px; text-transform:uppercase;}
.footer-col a, .footer-col p{display:block; font-size:12.5px; color:var(--periwinkle); line-height:2; margin:0;}
.footer-logo{margin-bottom:14px;}
.footer-logo img{height:93px; filter:brightness(1.08);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08); padding-top:18px; display:flex; justify-content:space-between; font-size:11.5px; color:#6B7488; flex-wrap:wrap; gap:10px;}
.footer-bottom a{margin-left:14px;}

/* Forms */
.form-field{margin-bottom:18px;}
.form-field label{display:block; font-size:12.5px; color:var(--ink); margin-bottom:6px;}
.form-field input, .form-field textarea, .form-field select{
  width:100%; padding:11px 14px; border:1px solid #ddd; border-radius:6px;
  font-family:var(--font-body); font-size:13.5px; color:var(--ink);
}
.form-field textarea{min-height:120px; resize:vertical;}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px;}
.contact-info-item{display:flex; gap:12px; margin-bottom:18px; font-size:13.5px;}
.contact-info-item i{color:var(--gold); font-size:17px; margin-top:1px;}

/* ── GOLD SECTION SEPARATORS ──
   Dünne glänzende Goldlinie überall wo Hintergrundfarbe wechselt */
.section[style*="--cream"],
.section[style*="--cream"] + .section,
.section[style*="--cream"] + .section-tight,
.page-header + .section,
.cta-band,
.site-footer{
  position:relative;
}
.section[style*="--cream"]::before,
.section[style*="--cream"] + .section::before,
.section[style*="--cream"] + .section-tight::before,
.page-header + .section::before,
.cta-band::before,
.site-footer::before{
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,
    transparent       0%,
    rgba(201,168,64,0.25) 8%,
    rgba(218,192,78,0.85) 28%,
    rgba(240,215,105,1)   50%,
    rgba(218,192,78,0.85) 72%,
    rgba(201,168,64,0.25) 92%,
    transparent       100%);
  z-index:2; pointer-events:none;
}

/* WhatsApp floating button */
.wa-float{position:fixed; bottom:24px; right:24px; z-index:98; width:56px; height:56px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,0.45); transition:transform .2s, box-shadow .2s;}
.wa-float:hover{transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,0.6);}
.wa-float svg{width:28px; height:28px; fill:#fff;}
/* Scroll reveal — initial hidden state before JS fires */
.reveal-on-scroll{opacity:0; transform:translateY(18px); transition:none;}
@media(prefers-reduced-motion:reduce){.reveal-on-scroll{opacity:1;transform:none;}}

/* Animations */
@keyframes fadeUp{0%{opacity:0; transform:translateY(16px);} 100%{opacity:1; transform:translateY(0);}}
@keyframes pulseRing{0%{transform:scale(.8); opacity:.9;} 70%{transform:scale(1.55); opacity:0;} 100%{opacity:0;}}
@keyframes pop{0%{transform:scale(1);} 50%{transform:scale(1.4);} 100%{transform:scale(1);}}
.reveal{animation:fadeUp .6s ease both;}

/* ── RESPONSIVE ── */

/* Tablet & large mobile (≤ 880px) */
@media (max-width:880px){
  .logo img{height:72px;}
  .container{padding:0 20px;}
  .section{padding:56px 0;}
  .about-hero, .contact-hero{min-height:420px;}
  .about-hero .container, .contact-hero .container{padding-bottom:72px;}
  .main-nav, .header-actions .icon-link{display:none;}
  .main-nav.open{display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--navy); padding:20px 24px 24px; gap:16px; z-index:48; border-top:1px solid rgba(255,255,255,0.1);}
  .main-nav.open a{font-size:15px;}
  .mobile-toggle{display:flex; align-items:center; justify-content:center; min-width:44px; min-height:44px;}
  .grid-3, .footer-grid, .contact-grid{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .hero h1{font-size:26px;}
  .steps-row{flex-direction:column;}
  .steps-row::before{display:none;}
  .step{width:100%; flex-direction:row; justify-content:flex-start;}
  .stats-row{gap:28px;}
  .stat-divider{border-left:none; padding-left:0; width:100%; text-align:center;}
}

/* Medium screens — two-column property grid */
@media (min-width:541px) and (max-width:879px){
  .grid-3{grid-template-columns:repeat(2,1fr);}
}

/* Small screens (≤ 540px) */
@media (max-width:540px){
  /* Layout & spacing */
  .container{padding:0 16px;}
  .section{padding:40px 0;}
  .section-tight{padding:28px 0;}

  /* Header: smaller logo, hide "Book a call" to avoid crowding */
  .logo img{height:60px;}
  .header-actions .btn-gold{display:none;}

  /* Typography */
  h2{font-size:1.5rem; line-height:1.3;}
  h3{font-size:16px;}

  /* Hero */
  .hero{padding:28px 0 0;}
  .hero h1{font-size:22px;}
  .hero p.lead{font-size:13.5px;}

  /* About & Contact hero */
  .about-hero, .contact-hero{min-height:300px;}
  .about-hero .container, .contact-hero .container{padding-top:32px; padding-bottom:48px;}
  .about-hero h1, .contact-hero h1{font-size:clamp(1.8rem,6vw,2.4rem);}
  .about-hero-lead, .contact-hero-lead{font-size:0.95rem; margin-bottom:24px;}

  /* Page header (Properties, etc.) */
  .page-header{padding:32px 0;}
  .page-header h1{font-size:1.8rem;}

  /* Search bar */
  .search-wrap{padding:0 0 40px;}
  .search-bar{flex-direction:column; gap:0;}
  .search-field{border-right:none; border-bottom:1px solid #eee; padding:12px 14px;}
  .search-field:last-of-type{border-bottom:none;}
  .search-bar .btn-gold{display:flex; width:100%; justify-content:center; border-radius:0 0 var(--radius-lg) var(--radius-lg);}

  /* Stats */
  .stats-row{padding:16px; gap:16px;}

  /* Cards */
  .service-card{padding:20px;}

  /* Network strip */
  .network-strip{flex-direction:column; align-items:flex-start; gap:14px;}

  /* CTA band */
  .cta-band{padding:40px 0;}
  .cta-band h2{font-size:20px;}
  .cta-buttons{flex-direction:column; align-items:stretch;}
  .cta-buttons .btn{width:100%; justify-content:center;}

  /* Footer */
  .footer-logo img{height:70px;}

  /* WhatsApp button */
  .wa-float{width:48px; height:48px; bottom:16px; right:16px;}
  .wa-float svg{width:24px; height:24px;}
}
