/* =========================================
   KONTAKT - layout and cards
========================================= */

.contact-page__section{
  padding: clamp(26px, 4vw, 52px) 0;
}

.contact-page__container{
  max-width: min(var(--container), 1180px);
}

.contact-page__header{
  margin-bottom: 18px;
}

.contact-page__title{
  margin: 0 0 10px;
}

.contact-page__lead{
  margin: 0;
  color: var(--text-muted);
  max-width: 74ch;
  line-height: 1.55;
}

.contact-page__intro{
  margin: 14px 0 18px;
  padding: 14px;
  border: 1px solid var(--border-muted);
  border-radius: var(--radius);
  background: color-mix(in oklab, var(--surface-1) 92%, #ffffff 8%);
}

.contact-page__grid{
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.contact-page__card{
  grid-column: span 6;
}

.contact-page__card--form{
  grid-column: span 12;
}

.contact-page__card-title{
  margin: 0 0 12px;
  font-size: clamp(1.08rem, 2vw, 1.3rem);
}

.contact-page__muted{
  color: var(--text-muted);
  margin: 0;
}

.contact-page__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.contact-page__item{
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 10px;
  border: 1px solid var(--border-muted);
  border-radius: 12px;
  background: color-mix(in oklab, var(--surface-1) 90%, #ffffff 10%);
}

.contact-page__item-main{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.contact-page__item-main--link:hover{
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact-page__icon{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--border-muted);
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  background: color-mix(in oklab, var(--surface-2) 86%, transparent);
}

.contact-page__icon svg{
  width: 18px;
  height: 18px;
}

.contact-page__hours{
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.contact-page__hours-item{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--border-muted);
  background: color-mix(in oklab, var(--surface-1) 90%, #ffffff 10%);
}

.contact-page__hours-item.is-today{
  border-color: color-mix(in oklab, var(--primary) 45%, var(--border-muted));
  background: color-mix(in oklab, var(--primary) 10%, var(--surface-1));
}

.contact-page__status{
  margin: 12px 0 0;
  padding: 9px 11px;
  border-radius: 10px;
  font-weight: 650;
  border: 1px solid var(--border-muted);
}

.contact-page__status--open{
  color: #14532d;
  background: #dcfce7;
  border-color: #86efac;
}

.contact-page__status--closed{
  color: #7f1d1d;
  background: #fee2e2;
  border-color: #fca5a5;
}

.contact-page__status--soon{
  color: #78350f;
  background: #fef3c7;
  border-color: #fcd34d;
}

.contact-page__meeting{
  margin-top: 14px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklab, var(--primary) 32%, var(--border-muted));
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--primary) 10%, var(--surface-1)), var(--surface-1));
}

.contact-page__meeting h3{
  margin: 0 0 8px;
  font-size: 1rem;
}

.contact-page__meeting p{
  margin: 0;
  color: var(--text);
  line-height: 1.5;
}

.contact-page__meeting p + p{
  margin-top: 8px;
}

.contact-page__map-frame{
  margin-top: 10px;
  border: 1px solid var(--border-muted);
  border-radius: 12px;
  overflow: hidden;
  min-height: 260px;
  background: color-mix(in oklab, var(--surface-2) 88%, transparent);
}

.contact-page__map-frame iframe{
  width: 100%;
  height: 100%;
  min-height: 260px;
  border: 0;
}

.contact-page__map-empty{
  padding: 14px;
  color: var(--text-muted);
}

.contact-page__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.contact-page__tips{
  margin: 12px 0 0;
  padding-left: 18px;
}

.contact-page__tips li{
  margin: 6px 0;
}

.contact-page__bank-list{
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.contact-page__bank-list li{
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--border-muted);
  background: color-mix(in oklab, var(--surface-1) 90%, #ffffff 10%);
}

.contact-page__bank-list span{
  color: var(--text-muted);
  font-size: var(--fs-1);
}

.contact-page__iban{
  letter-spacing: .02em;
}

.contact-page__card--tax{
  border-color: color-mix(in oklab, #f59e0b 32%, var(--border-muted));
  background:
    linear-gradient(160deg, color-mix(in oklab, #f59e0b 16%, var(--surface-1)) 0%, var(--surface-1) 72%);
}

.contact-page__tax-krs{
  margin: 14px 0 0;
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklab, #ef4444 48%, var(--border-muted));
  background: color-mix(in oklab, #ef4444 10%, var(--surface-1));
}

.contact-page__tax-krs span{
  color: var(--text-muted);
  font-size: var(--fs-1);
}

.contact-page__tax-krs strong{
  font-size: clamp(1.4rem, 3vw, 2rem);
  letter-spacing: .03em;
  line-height: 1;
  color: #b91c1c;
}

.contact-page__form{
  margin-top: 10px;
}

.contact-page .btn[disabled]{
  opacity: .7;
  cursor: not-allowed;
}

@media (max-width: 980px){
  .contact-page__card{
    grid-column: span 12;
  }
}
