/* ============================================
   IMMOBILIEN FISCHERMANNS – v2 Stylesheet
   Mobile-first, responsive, brand-accurate
   ============================================ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --accent: #008eaa;
  --accent-dark: #006e87;
  --accent-light: #e6f5f8;
  --accent-mid: #b3e0e9;
  --text: #575656;
  --text-dark: #1a1a2e;
  --white: #ffffff;
  --gray-1: #f8f9fa;
  --gray-2: #f0f4f5;
  --gray-border: #e2e8ea;
  --shadow-sm: 0 2px 8px rgba(0,142,170,.08);
  --shadow-md: 0 8px 30px rgba(0,142,170,.12);
  --shadow-lg: 0 20px 60px rgba(0,142,170,.18);
  --radius: 16px;
  --radius-sm: 10px;
  --nav-h: 70px;
  --transition: all 0.28s cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { font-family:'Inter',system-ui,sans-serif; color:var(--text); background:var(--white); line-height:1.6; overflow-x:hidden; }

/* ===== UTILITIES ===== */
.container { max-width:1200px; margin:0 auto; padding:0 20px; }
.accent { color:var(--accent); }
.section-label { display:inline-block; font-size:11px; font-weight:700; color:var(--accent); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:10px; }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:28px; flex-wrap:wrap; gap:14px; }
.section-header.center { flex-direction:column; align-items:center; text-align:center; }
.section-header h2 { font-size:clamp(24px,4vw,38px); font-weight:800; color:var(--text-dark); line-height:1.2; margin-bottom:10px; }
.section-header p { font-size:15px; color:var(--text); max-width:540px; line-height:1.7; }

/* ===== BUTTONS ===== */
.btn-primary { display:inline-flex; align-items:center; gap:8px; background:var(--accent); color:var(--white); padding:11px 22px; border-radius:var(--radius-sm); font-weight:600; font-size:14px; text-decoration:none; border:2px solid var(--accent); transition:var(--transition); cursor:pointer; white-space:nowrap; }
.btn-primary:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline { display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--accent); padding:11px 22px; border-radius:var(--radius-sm); font-weight:600; font-size:14px; text-decoration:none; border:2px solid var(--accent); transition:var(--transition); cursor:pointer; white-space:nowrap; }
.btn-outline:hover { background:var(--accent); color:var(--white); transform:translateY(-2px); }
.btn-sm { display:inline-flex; align-items:center; gap:5px; color:var(--accent); padding:7px 14px; border-radius:8px; font-weight:600; font-size:12px; text-decoration:none; border:1.5px solid var(--accent); transition:var(--transition); white-space:nowrap; }
.btn-sm:hover { background:var(--accent); color:var(--white); }
.btn-call { display:inline-flex; align-items:center; gap:6px; color:var(--accent); font-weight:600; font-size:14px; text-decoration:none; transition:var(--transition); }
.btn-call:hover { color:var(--accent-dark); }

/* ===== NAVBAR ===== */
.navbar { position:fixed; top:0; width:100%; z-index:1000; height:var(--nav-h); display:flex; align-items:center; padding:0 20px; background:rgba(255,255,255,0.97); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid transparent; transition:var(--transition); }
.navbar.scrolled { border-bottom-color:var(--gray-border); box-shadow:0 2px 16px rgba(0,0,0,.06); }
.nav-container { max-width:1200px; width:100%; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0; }
.logo-img-icon { height:40px; width:40px; object-fit:contain; }
.logo-img-full { height:32px; object-fit:contain; }
.nav-links { display:none; list-style:none; gap:2px; }
.nav-links.open { display:flex; flex-direction:column; position:absolute; top:var(--nav-h); left:0; right:0; background:var(--white); border-bottom:1px solid var(--gray-border); padding:12px 20px 16px; box-shadow:0 8px 24px rgba(0,0,0,.08); z-index:999; }
.nav-links a { text-decoration:none; color:var(--text); font-size:15px; font-weight:500; padding:10px 14px; border-radius:8px; display:block; transition:var(--transition); }
.nav-links a:hover, .nav-links a.active { color:var(--accent); background:var(--accent-light); }
.nav-actions { display:flex; align-items:center; gap:10px; }
.call-text { display:none; }
.hamburger { background:none; border:1.5px solid var(--gray-border); border-radius:8px; font-size:16px; color:var(--text); cursor:pointer; padding:8px 10px; transition:var(--transition); }
.hamburger:hover { border-color:var(--accent); color:var(--accent); }

/* ===== HERO PHOTO ===== */
.hero-photo { position:relative; margin-top:var(--nav-h); width:100%; }
.hero-photo-img { width:100%; height:auto; display:block; }
.hero-photo-overlay { position:absolute; bottom:0; left:0; right:0; padding:20px; background:linear-gradient(to top, rgba(0,0,0,.3) 0%, transparent 100%); }
.hero-photo-badges { display:flex; gap:10px; flex-wrap:wrap; }
.hero-badge-pill { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.9); color:var(--accent); font-size:12px; font-weight:700; padding:6px 14px; border-radius:30px; backdrop-filter:blur(4px); }

/* ===== INTRO SECTION ===== */
.intro-section { padding:64px 0; background:var(--white); border-bottom:1px solid var(--gray-border); }
.intro-grid { display:grid; grid-template-columns:1fr; gap:40px; align-items:center; }
.intro-left { text-align:center; }
.intro-eyebrow { font-size:clamp(16px,3vw,22px); color:var(--text); font-weight:400; display:block; margin-bottom:16px; }
.intro-logo { max-width:min(340px, 90%); height:auto; display:block; margin:0 auto 16px; }
.intro-tagline { font-size:clamp(24px,5vw,40px); font-weight:800; color:var(--text-dark); }
.intro-dots { display:grid; grid-template-columns:repeat(8,8px); gap:10px; margin:24px auto 0; width:fit-content; }
.intro-dots::after { content:''; display:grid; grid-template-columns:repeat(8,8px); gap:10px; height:80px; background-image:radial-gradient(circle, #d1d5db 1.5px, transparent 1.5px); background-size:18px 18px; width:144px; height:80px; }
.intro-right p { font-size:15px; color:var(--text); line-height:1.8; margin-bottom:16px; }
.intro-stats { display:flex; gap:20px; margin:24px 0 28px; flex-wrap:wrap; }
.istat-num { display:block; font-size:clamp(22px,4vw,28px); font-weight:800; color:var(--accent); }
.istat-label { font-size:12px; color:var(--text); }

/* ===== SERVICES ===== */
.services-section { padding:72px 0; background:var(--gray-1); }
.services-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.service-card { background:var(--white); border-radius:var(--radius); padding:24px 20px; border:1px solid var(--gray-border); transition:var(--transition); }
.service-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--accent-mid); }
.scard-icon { width:52px; height:52px; background:var(--accent-light); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; color:var(--accent); margin-bottom:16px; transition:var(--transition); }
.service-card:hover .scard-icon { background:var(--accent); color:var(--white); }
.service-card h3 { font-size:16px; font-weight:700; color:var(--text-dark); margin-bottom:8px; }
.service-card p { font-size:13px; color:var(--text); line-height:1.7; margin-bottom:16px; }
.scard-link { display:inline-flex; align-items:center; gap:5px; color:var(--accent); font-size:13px; font-weight:600; text-decoration:none; transition:var(--transition); }
.scard-link:hover { gap:9px; }

/* ===== PROPERTIES ===== */
.properties-section { padding:72px 0; }
.filter-tabs { display:flex; gap:8px; margin-bottom:24px; flex-wrap:wrap; }
.ftab { padding:8px 18px; border-radius:30px; font-size:13px; font-weight:600; cursor:pointer; border:2px solid var(--gray-border); background:var(--white); color:var(--text); transition:var(--transition); }
.ftab.active { background:var(--accent); border-color:var(--accent); color:var(--white); }
.ftab:hover:not(.active) { border-color:var(--accent); color:var(--accent); }
.prop-grid { display:grid; grid-template-columns:1fr; gap:20px; }
.prop-card { background:var(--white); border-radius:var(--radius); overflow:hidden; border:1px solid var(--gray-border); transition:var(--transition); }
.prop-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--accent-mid); }
.prop-img { height:180px; background:linear-gradient(135deg,var(--accent-light),var(--accent-mid)); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.prop-emoji { font-size:56px; }
.prop-badge { position:absolute; top:12px; left:12px; padding:4px 10px; border-radius:20px; font-size:11px; font-weight:700; text-transform:uppercase; }
.prop-badge.sale { background:var(--accent); color:var(--white); }
.prop-badge.rent { background:#e74c3c; color:var(--white); }
.prop-body { padding:16px; }
.prop-body h3 { font-size:15px; font-weight:700; color:var(--text-dark); margin-bottom:6px; line-height:1.3; }
.prop-loc { font-size:12px; color:var(--text); margin-bottom:12px; display:flex; align-items:center; gap:4px; }
.prop-loc i { color:var(--accent); }
.prop-features { display:flex; gap:12px; padding:10px 0; border-top:1px solid var(--gray-border); border-bottom:1px solid var(--gray-border); margin-bottom:12px; font-size:11px; color:var(--text); flex-wrap:wrap; }
.prop-features span { display:flex; align-items:center; gap:4px; }
.prop-features i { color:var(--accent); }
.prop-footer { display:flex; align-items:center; justify-content:space-between; }
.prop-price { font-size:16px; font-weight:800; color:var(--accent); }

/* ===== GOOGLE REVIEWS ===== */
.reviews-section { padding:72px 0; background:var(--gray-1); }
.google-header { display:flex; align-items:center; gap:10px; justify-content:center; margin-bottom:8px; }
.google-rating-summary { display:flex; align-items:center; gap:16px; margin-top:14px; background:var(--white); border-radius:var(--radius); padding:16px 24px; border:1px solid var(--gray-border); box-shadow:var(--shadow-sm); }
.rating-big { font-size:48px; font-weight:900; color:var(--text-dark); line-height:1; }
.stars-row { color:#FBBC05; font-size:20px; letter-spacing:2px; }
.stars-row.small { font-size:14px; letter-spacing:1px; }
.reviews-grid { display:grid; grid-template-columns:1fr; gap:16px; margin-top:28px; }
.review-card { background:var(--white); border-radius:var(--radius); padding:20px; border:1px solid var(--gray-border); transition:var(--transition); }
.review-card:hover { box-shadow:var(--shadow-md); border-color:var(--accent-mid); transform:translateY(-2px); }
.review-header { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.review-avatar { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:16px; flex-shrink:0; }
.review-header strong { display:block; font-size:14px; color:var(--text-dark); }
.google-icon-sm { margin-left:auto; flex-shrink:0; }
.review-card p { font-size:14px; color:var(--text); line-height:1.7; font-style:italic; }
.review-date { font-size:12px; color:#9ca3af; margin-top:10px; display:block; }

/* ===== INLINE CONTACT FORM ===== */
.kontakt-inline-section { padding:72px 0; background:var(--white); }
.inline-kontakt-grid { display:grid; grid-template-columns:1fr; gap:32px; }
.kontakt-form { background:var(--white); border-radius:var(--radius); padding:28px; border:1px solid var(--gray-border); box-shadow:var(--shadow-md); }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--text-dark); margin-bottom:5px; }
.form-group input, .form-group textarea, .form-group select { width:100%; padding:11px 14px; border:1.5px solid var(--gray-border); border-radius:var(--radius-sm); font-size:14px; color:var(--text); font-family:inherit; outline:none; transition:var(--transition); background:var(--gray-1); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color:var(--accent); background:var(--white); box-shadow:0 0 0 3px rgba(0,142,170,.08); }
.form-group textarea { resize:vertical; min-height:110px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-success { display:none; align-items:center; gap:10px; padding:14px; background:#d1fae5; border-radius:10px; margin-top:14px; color:#065f46; font-size:14px; }
.form-success.show { display:flex; }
.form-success i { font-size:20px; color:#059669; flex-shrink:0; }
.kontakt-aside { display:flex; flex-direction:column; gap:20px; }
.kontakt-aside-photo { border-radius:var(--radius); overflow:hidden; }
.kontakt-aside-photo img { width:100%; height:280px; object-fit:cover; object-position:top; display:block; }
.kontakt-aside-info { padding:24px; background:var(--gray-1); border-radius:var(--radius); border:1px solid var(--gray-border); }
.kontakt-aside-info h3 { font-size:20px; font-weight:800; color:var(--text-dark); margin-bottom:4px; }
.kontakt-aside-info p { font-size:13px; color:var(--accent); font-weight:600; margin-bottom:16px; }
.info-card-link { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--gray-border); font-size:14px; color:var(--text); text-decoration:none; transition:var(--transition); }
.info-card-link:last-child { border:none; }
.info-card-link:hover { color:var(--accent); }
.info-card-link i { color:var(--accent); width:16px; text-align:center; }

/* ===== FOOTER ===== */
footer { background:#111827; color:#9ca3af; }
.footer-grid { padding:48px 0 32px; display:grid; grid-template-columns:1fr; gap:32px; }
.footer-logo-link { display:block; margin-bottom:14px; }
.footer-logo-img { height:36px; filter:brightness(0) invert(1); opacity:.9; }
.footer-brand p { font-size:14px; line-height:1.7; margin-bottom:18px; }
.footer-contacts { display:flex; flex-direction:column; gap:8px; }
.footer-contacts a { color:#9ca3af; font-size:13px; text-decoration:none; display:flex; align-items:center; gap:8px; transition:var(--transition); }
.footer-contacts a:hover { color:var(--accent); }
.footer-col h4 { font-size:13px; font-weight:700; color:var(--white); margin-bottom:14px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-col ul a { color:#9ca3af; font-size:13px; text-decoration:none; transition:var(--transition); }
.footer-col ul a:hover { color:var(--accent); }
.footer-bottom { border-top:1px solid #1f2937; padding:18px 0; }
.footer-bottom-inner { display:flex; justify-content:space-between; align-items:center; font-size:12px; flex-wrap:wrap; gap:8px; }

/* ===== OTHER PAGES ===== */
.page-hero { padding:calc(var(--nav-h) + 48px) 0 48px; background:linear-gradient(135deg,var(--accent-light),var(--white)); text-align:center; }
.page-hero h1 { font-size:clamp(28px,5vw,48px); font-weight:800; color:var(--text-dark); margin-bottom:12px; }
.page-hero p { font-size:16px; color:var(--text); max-width:520px; margin:0 auto; }
.about-full { padding:72px 0; }
.about-full-grid { display:grid; grid-template-columns:1fr; gap:40px; }
.about-img-placeholder { width:100%; height:340px; background:linear-gradient(135deg,var(--accent-light),var(--accent-mid)); border-radius:24px; display:flex; align-items:center; justify-content:center; font-size:80px; position:relative; }
.about-img-wrap { position:relative; }
.about-tag-badge { position:absolute; bottom:-18px; right:-8px; background:var(--accent); color:var(--white); border-radius:12px; padding:14px 18px; box-shadow:var(--shadow-lg); text-align:center; }
.about-tag-badge strong { display:block; font-size:24px; font-weight:900; }
.about-tag-badge span { font-size:11px; opacity:.85; }
.about-content h2 { font-size:clamp(24px,4vw,36px); font-weight:800; color:var(--text-dark); line-height:1.2; margin-bottom:14px; }
.about-content p { font-size:15px; color:var(--text); line-height:1.8; margin-bottom:14px; }
.about-features { display:grid; grid-template-columns:1fr; gap:14px; margin:24px 0; }
.afeat { display:flex; align-items:flex-start; gap:12px; }
.afeat-icon { width:38px; height:38px; background:var(--accent-light); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:15px; color:var(--accent); flex-shrink:0; }
.afeat strong { display:block; font-size:14px; color:var(--text-dark); font-weight:700; }
.afeat span { font-size:12px; color:var(--text); }
.kontakt-section { padding:72px 0; }
.kontakt-grid { display:grid; grid-template-columns:1fr; gap:32px; }
.kontakt-info h3 { font-size:22px; font-weight:700; color:var(--text-dark); margin-bottom:12px; }
.kontakt-info p { font-size:15px; color:var(--text); line-height:1.8; margin-bottom:24px; }
.info-card { display:flex; align-items:center; gap:14px; padding:14px; background:var(--white); border-radius:var(--radius-sm); border:1px solid var(--gray-border); margin-bottom:10px; text-decoration:none; transition:var(--transition); }
.info-card:hover { border-color:var(--accent); box-shadow:var(--shadow-sm); }
.info-card-icon { width:40px; height:40px; background:var(--accent-light); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--accent); font-size:16px; flex-shrink:0; }
.info-card strong { display:block; font-size:14px; color:var(--text-dark); font-weight:700; }
.info-card span { font-size:13px; color:var(--text); }
.legal-section { padding:calc(var(--nav-h) + 48px) 0 72px; }
.legal-content { max-width:720px; }
.legal-content h1 { font-size:36px; font-weight:800; color:var(--text-dark); margin-bottom:28px; }
.legal-content h2 { font-size:18px; font-weight:700; color:var(--text-dark); margin:28px 0 10px; }
.legal-content p { font-size:15px; color:var(--text); line-height:1.8; margin-bottom:8px; }

/* ===== TABLET (≥ 640px) ===== */
@media (min-width:640px) {
  .prop-grid { grid-template-columns:1fr 1fr; }
  .reviews-grid { grid-template-columns:1fr 1fr; }
  .intro-grid { grid-template-columns:1fr 1fr; }
  .intro-left { text-align:left; }
  .intro-logo { margin:0 0 16px; }
  .about-features { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .call-text { display:inline; }
}

/* ===== DESKTOP (≥ 900px) ===== */
@media (min-width:900px) {
  .nav-links { display:flex !important; flex-direction:row !important; position:static !important; background:none !important; border:none !important; padding:0 !important; box-shadow:none !important; }
  .hamburger { display:none; }
  .services-grid { grid-template-columns:repeat(4,1fr); }
  .prop-grid { grid-template-columns:repeat(3,1fr); }
  .reviews-grid { grid-template-columns:repeat(4,1fr); }
  .inline-kontakt-grid { grid-template-columns:1fr 1fr; align-items:start; }
  .kontakt-grid { grid-template-columns:1fr 1fr; }
  .about-full-grid { grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
  .footer-grid { grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
  .form-row { grid-template-columns:1fr 1fr; }
}

/* ===== LARGE (≥ 1100px) ===== */
@media (min-width:1100px) {
/* Hero badge layering fixed */
.hero-photo-overlay { position:absolute; bottom:0; left:0; right:0; padding:20px; pointer-events:none; }
.hero-title-badge { pointer-events:auto; position:relative; margin-left:auto; margin-right:48px; margin-bottom:8px; background:linear-gradient(90deg, rgba(0,142,170,0.98), rgba(0,142,170,0.95)); border-radius:14px; padding:16px 18px; display:flex; align-items:center; gap:12px; box-shadow:0 8px 30px rgba(0,0,0,0.18); }
.hero-badge-svg svg{width:64px;height:64px;display:block}
@media(max-width:900px){
  .hero-title-badge{margin-right:24px;padding:12px;}
  .hero-badge-svg svg{width:52px;height:52px}
}
@media(max-width:640px){
  .hero-photo-overlay{position:static;background:transparent;padding:16px}
  .hero-title-badge{width:100%;margin:0;flex-direction:row;justify-content:space-between}
  .hero-title{font-size:18px}
  .hero-sub{font-size:13px}
  .hero-badge-svg svg{width:44px;height:44px}
}
  .intro-grid { gap:72px; }
  .hero-photo-overlay { padding:32px 40px; }
}

/* ===== AOS animations ===== */
[data-aos] { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
[data-aos].aos-animate { opacity:1; transform:translateY(0); }
/* Logo responsiveness: show full logo by default, icon-only on small widths */
.logo-img-full { display:block; height:36px; }
.logo-img-icon { display:none; height:40px; }
@media (max-width:640px) {
  .logo-img-full { display:none; }
  .logo-img-icon { display:block; }
}

/* ===== GOOGLE REVIEWS ===== */
.review-section { padding:100px 0; background:var(--gray-1); }
.google-rating-badge { display:flex; align-items:center; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:8px; margin-bottom:40px; }
.google-logo { height:22px; }
.rating-stars { color:#f59e0b; font-size:20px; letter-spacing:2px; }
.rating-score { font-size:22px; font-weight:800; color:var(--text-dark); }
.rating-count { font-size:13px; color:var(--text); }
.google-link { display:inline-flex; align-items:center; gap:6px; color:var(--accent); font-size:13px; font-weight:600; text-decoration:none; margin-left:8px; }
.google-link:hover { text-decoration:underline; }
.reviews-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.review-card { background:var(--white); border-radius:var(--radius); padding:28px; border:1px solid var(--gray-border); transition:var(--transition); }
.review-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--accent-mid); }
.review-header { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.reviewer-avatar { width:44px; height:44px; border-radius:50%; background:var(--accent); color:var(--white); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:18px; flex-shrink:0; }
.reviewer-info { flex:1; }
.reviewer-info strong { display:block; font-size:15px; color:var(--text-dark); font-weight:700; }
.reviewer-info span { font-size:12px; color:var(--text); }
.review-stars { color:#f59e0b; font-size:16px; letter-spacing:1px; flex-shrink:0; }
.review-card p { font-size:14px; color:var(--text); line-height:1.8; font-style:italic; }

/* ===== KONTAKT FORM SECTION ===== */
.kontakt-form-section { padding:100px 0; background:var(--white); }
.kontakt-form-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:72px; align-items:start; }
.kontakt-form-left h2 { font-size:clamp(28px,4vw,38px); font-weight:800; color:var(--text-dark); margin-bottom:12px; line-height:1.2; }
.kontakt-form-left p { font-size:15px; color:var(--text); line-height:1.8; margin-bottom:28px; }
.kontakt-info-cards { display:flex; flex-direction:column; gap:12px; margin-bottom:28px; }
.info-card { display:flex; align-items:center; gap:16px; padding:14px 18px; background:var(--gray-1); border-radius:var(--radius-sm); border:1px solid var(--gray-border); text-decoration:none; transition:var(--transition); }
.info-card:hover { border-color:var(--accent); box-shadow:var(--shadow-sm); background:var(--accent-light); }
.info-card-icon { width:42px; height:42px; background:var(--accent-light); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--accent); font-size:16px; flex-shrink:0; }
.info-card strong { display:block; font-size:14px; color:var(--text-dark); font-weight:700; }
.info-card span { font-size:13px; color:var(--text); }
.kontakt-photo-wrap { position:relative; border-radius:var(--radius); overflow:hidden; max-height:240px; }
.kontakt-photo { width:100%; height:240px; object-fit:cover; object-position:top; display:block; border-radius:var(--radius); }
.kontakt-photo-badge { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(0,0,0,0.7),rgba(0,0,0,0)); padding:20px 18px 14px; }
.kontakt-photo-badge strong { display:block; font-size:15px; color:#fff; font-weight:700; }
.kontakt-photo-badge span { font-size:12px; color:rgba(255,255,255,0.85); }
.kontakt-form { background:var(--white); border-radius:var(--radius); padding:36px; border:1px solid var(--gray-border); box-shadow:var(--shadow-md); }
.kontakt-form .form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.kontakt-form .form-group { margin-bottom:16px; }
.kontakt-form .form-group label { display:block; font-size:13px; font-weight:600; color:var(--text-dark); margin-bottom:6px; }
.kontakt-form .form-group input,
.kontakt-form .form-group select,
.kontakt-form .form-group textarea { width:100%; padding:11px 14px; border:1.5px solid var(--gray-border); border-radius:var(--radius-sm); font-size:14px; color:var(--text); font-family:inherit; outline:none; transition:var(--transition); background:var(--gray-1); }
.kontakt-form .form-group input:focus,
.kontakt-form .form-group select:focus,
.kontakt-form .form-group textarea:focus { border-color:var(--accent); background:var(--white); box-shadow:0 0 0 3px rgba(0,142,170,.08); }
.kontakt-form .form-group textarea { resize:vertical; }
.form-success { display:none; align-items:center; gap:12px; padding:18px; background:#d1fae5; border-radius:var(--radius-sm); margin-top:16px; color:#065f46; font-size:14px; }
.form-success i { font-size:22px; color:#059669; flex-shrink:0; }

@media(max-width:900px) {
  .reviews-grid { grid-template-columns:1fr; }
  .kontakt-form-grid { grid-template-columns:1fr; gap:40px; }
}
/* Kontakt page adapted styles (reuse existing classes) */
.kontakt-section { padding:100px 0; }
.kontakt-grid { display:grid; grid-template-columns:1fr 440px; gap:40px; align-items:start; }
.form-card { background:var(--white); border-radius:16px; padding:28px; border:1px solid var(--gray-border); box-shadow:var(--shadow-md); }
.form-card h3 { font-size:20px; margin-bottom:6px; color:var(--text-dark); }
.form-card p { margin-bottom:18px; color:var(--text); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-group label { display:block; font-weight:700; margin-bottom:6px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:12px 14px; border-radius:10px; border:1.5px solid var(--gray-border); background:var(--gray-1); }
.form-actions { margin-top:12px; }
.contact-info h3 { font-size:20px; color:var(--text-dark); margin-bottom:8px; }
.info-card { display:flex; gap:12px; align-items:center; background:var(--white); border-radius:10px; padding:12px; border:1px solid var(--gray-border); margin-bottom:12px; }
.info-card-icon { width:44px; height:44px; display:flex; align-items:center; justify-content:center; border-radius:10px; background:var(--accent-light); color:var(--accent); font-size:20px; }
.note-box { background:var(--accent-light); border-radius:10px; padding:14px; border:1px solid var(--accent-mid); margin-top:12px; }
@media(max-width:900px){ .kontakt-grid{grid-template-columns:1fr;} }
