/* =========================================
   KONTAKT
   ========================================= */
.section--kontakt{
  background:#f5f5f5;
  color:#2d3037;
}
.section--kontakt .section-content{
  height:100%;
  padding:clamp(24px,4vw,48px) clamp(24px,5vw,72px);
  box-sizing:border-box;
  display:flex;
  flex-direction:column;
  gap:clamp(16px,2vw,28px);
  overflow-y:auto;
}

.kontakt-header{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-width:760px;
}
.kontakt-kicker{
  display:inline-block;
  align-self:flex-start;
  padding:8px 14px;
  background:#ed324a;
  color:#fff;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-weight:700;
}
.kontakt-title{
  margin:0;
  font-size:clamp(26px,3vw,34px);
  letter-spacing:0.02em;
  text-transform:uppercase;
}
.kontakt-lead{
  margin:0;
  line-height:1.6;
  color:#555;
  max-width:60ch;
}

.kontakt-grid{
  display:grid;
  grid-template-columns:minmax(280px, 360px) 1fr;
  gap:clamp(20px, 3vw, 36px);
  align-items:start;
}

/* --- INFO --- */
.kontakt-info{
  background:#2d3037;
  color:#fff;
  padding:clamp(20px,2.5vw,28px);
  display:flex;
  flex-direction:column;
  gap:18px;
  box-shadow:0 14px 40px rgba(0,0,0,.12);
}
.kontakt-info h3{
  margin:0;
  font-size:18px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#fff;
  border-bottom:2px solid #ed324a;
  padding-bottom:10px;
}
.kontakt-info__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.kontakt-info__list li{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.kontakt-info__label{
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#a9adb4;
  font-weight:700;
}
.kontakt-info__value{
  color:#fff;
  text-decoration:none;
  font-weight:500;
  word-break:break-word;
}
a.kontakt-info__value:hover{ color:#ed324a; }

.kontakt-info__cta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:6px;
}
.kontakt-info__cta .btn-ghost{
  background:transparent;
  color:#fff;
  border-color:#fff;
}
.kontakt-info__cta .btn-ghost:hover{
  background:#fff;
  color:#2d3037;
}

/* --- FORMULARZ --- */
.kontakt-form{
  background:#fff;
  padding:clamp(20px,2.5vw,28px);
  display:flex;
  flex-direction:column;
  gap:14px;
  box-shadow:0 14px 40px rgba(0,0,0,.08);
}
.kontakt-honeypot{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}
.kontakt-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.kontakt-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
}
.kontakt-field > span{
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:11px;
  color:#2d3037;
}
.kontakt-field input,
.kontakt-field textarea{
  font:inherit;
  padding:10px 12px;
  border:1.5px solid #d8dadf;
  background:#fff;
  color:#2d3037;
  border-radius:0;
  transition:border-color .2s ease, box-shadow .2s ease;
  width:100%;
  box-sizing:border-box;
  font-family:inherit;
}
.kontakt-field textarea{ resize:vertical; min-height:120px; }
.kontakt-field input:focus,
.kontakt-field textarea:focus{
  outline:none;
  border-color:#ed324a;
  box-shadow:0 0 0 3px rgba(237,50,74,.15);
}
.kontakt-field .is-invalid{ border-color:#ed324a; background:#fff4f5; }
.kontakt-err{
  color:#ed324a;
  font-style:normal;
  font-size:12px;
  font-weight:600;
}

.kontakt-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:12px;
  line-height:1.5;
  color:#444;
}
.kontakt-check input{ margin-top:3px; flex:0 0 auto; }

.kontakt-actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:6px;
}
.kontakt-actions .btn{ cursor:pointer; }
.kontakt-required{
  font-size:12px;
  color:#777;
}

.kontakt-alert{
  padding:12px 14px;
  border-left:4px solid #ed324a;
  background:#fff4f5;
  font-size:14px;
  color:#2d3037;
}
.kontakt-alert--ok{
  border-left-color:#1f8a4c;
  background:#eaf6ee;
}
.kontakt-alert--err{
  border-left-color:#ed324a;
  background:#fff4f5;
}

/* --- MAPA --- */
.kontakt-map{
  position:relative;
  width:100%;
  border:1px solid #d8dadf;
  background:#e9ecef;
  box-shadow:0 14px 40px rgba(0,0,0,.08);
  overflow:hidden;
}
.kontakt-map iframe{
  display:block;
  width:100%;
  height:320px;
  border:0;
}
.kontakt-map__bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:8px;
  padding:10px 14px;
  background:#2d3037;
  color:#fff;
  font-size:13px;
}
.kontakt-map__addr{
  letter-spacing:.04em;
  font-weight:600;
}
.kontakt-map__links{
  display:flex;
  gap:14px;
}
.kontakt-map__links a{
  color:#fff;
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.4);
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  padding-bottom:1px;
  transition:color .2s ease, border-color .2s ease;
}
.kontakt-map__links a:hover{
  color:#ed324a;
  border-bottom-color:#ed324a;
}

@media (max-width: 960px){
  .kontakt-grid{ grid-template-columns:1fr; }
  .kontakt-row{ grid-template-columns:1fr; }
  .kontakt-map iframe{ height:260px; }
}
