/* ============================================
   KONTAKT — page-contact.php
   ============================================ */

.site-main--contact { padding: 0; }

/* ===========================
   HERO
   =========================== */
.contact-hero {
    position: relative;
    height: 500px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.contact-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.contact-hero__bg img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}
.contact-hero__gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(252,248,255,1) 0%, rgba(252,248,255,1) 40%, rgba(252,248,255,.7) 65%, rgba(252,248,255,0) 100%);
}

.contact-hero__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    text-align: left;
}

.contact-hero__title,
.contact-hero__desc {
    max-width: 580px;
}

.contact-hero__title {
    font-family: var(--font-display);
    font-size: var(--text-display);
    line-height: .9;
    color: var(--c-secondary);
    margin: 0 0 1.25rem;
}

.contact-hero__desc {
    font-size: var(--text-body-lg);
    color: var(--c-text-muted);
    line-height: 1.55;
    max-width: 460px;
    margin: 0;
}

/* ===========================
   CONTACT INFO
   =========================== */
.contact-info {
    padding: var(--section-gap) 0;
}

.contact-info__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: start;
}

.contact-info__title {
    font-family: var(--font-display);
    font-size: var(--text-headline-md);
    line-height: .92;
    color: var(--c-secondary);
    margin: 0 0 2.5rem;
}

/* Right column — map */
.contact-info__map-col {
    position: sticky;
    top: 6rem;
    border-radius: 1.5rem;
    overflow: hidden;
    height: 520px;
    box-shadow: 0 25px 60px rgba(0,40,66,.12);
}
.contact-map {
    width: 100%; height: 100%;
    border: none; display: block;
}
.contact-map-img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}

/* Details list */
.contact-details {
    list-style: none;
    margin: 0 0 3rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.contact-details__item {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
}

.contact-details__icon {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    background: rgba(248,183,25,.15);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--c-primary);
}

.contact-details__label {
    font-size: var(--text-label-sm);
    letter-spacing: var(--ls-label-sm);
    text-transform: uppercase;
    color: var(--c-text-muted);
    font-weight: 600;
    margin: 0 0 .3rem;
}

.contact-details__value {
    font-size: var(--text-body-lg);
    font-weight: 600;
    color: var(--c-on-bg);
    margin: 0;
}
.contact-details__value a {
    color: var(--c-on-bg);
    text-decoration: none;
}
.contact-details__value a:hover { color: var(--c-primary); }

/* Workshop teaser */
.contact-workshop-teaser {
    background: var(--c-surface-container);
    border-radius: var(--radius-xl);
    padding: 2rem 2.5rem;
    position: relative;
    overflow: hidden;
}

.contact-workshop-teaser__paw {
    position: absolute;
    top: -1rem;
    right: 1rem;
    font-size: 6rem;
    opacity: .1;
    pointer-events: none;
    line-height: 1;
}

.contact-workshop-teaser__title {
    font-family: var(--font-display);
    font-size: var(--text-headline-sm);
    line-height: 1;
    color: var(--c-secondary);
    margin: 0 0 .75rem;
}

.contact-workshop-teaser__desc {
    font-size: var(--text-body-md);
    color: var(--c-text-muted);
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

.contact-workshop-teaser__link {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: var(--text-label-lg);
    font-weight: 600;
    color: var(--c-primary);
    text-decoration: none;
    transition: gap .2s;
}
.contact-workshop-teaser__link:hover { gap: .875rem; }

/* ===========================
   FAQ
   =========================== */
.contact-faq {
    background: var(--c-surface-low);
    padding: var(--section-gap) 0;
}

.contact-faq__header {
    text-align: center;
    margin-bottom: 3.5rem;
}

.contact-faq__title {
    font-family: var(--font-display);
    font-size: var(--text-headline-md);
    line-height: .92;
    color: var(--c-secondary);
    margin: 0 0 .5rem;
}

.contact-faq__subtitle {
    font-size: var(--text-body-lg);
    color: var(--c-text-muted);
    margin: 0;
}

.contact-faq__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.contact-faq__card {
    background: #fff;
    border-radius: var(--radius-xl);
    padding: 2rem;
    box-shadow: 0 4px 20px rgba(0,40,66,.04);
    transition: transform .2s;
}
.contact-faq__card:hover { transform: translateY(-4px); }

.contact-faq__card-title {
    font-family: var(--font-display);
    font-size: var(--text-headline-sm);
    line-height: 1;
    color: var(--c-primary);
    margin: 0 0 1rem;
}

.contact-faq__card-body {
    font-size: var(--text-body-md);
    color: var(--c-text-muted);
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

.contact-faq__card-link {
    font-size: var(--text-label-sm);
    letter-spacing: var(--ls-label-sm);
    text-transform: uppercase;
    font-weight: 700;
    color: var(--c-secondary);
    text-decoration: none;
    border-bottom: 2px solid var(--c-primary-cta);
    padding-bottom: .15rem;
    transition: color .15s;
}
.contact-faq__card-link:hover { color: var(--c-primary); }

/* ===========================
   RESPONSIVE
   =========================== */
@media (max-width: 900px) {
    .contact-hero { height: 400px; }
    .contact-hero__gradient {
        background: linear-gradient(180deg, rgba(252,248,255,.95) 60%, rgba(252,248,255,0) 100%);
    }
    .contact-info__inner { grid-template-columns: 1fr; gap: 3rem; }
    .contact-info__map-col { position: static; height: 360px; }
    .contact-faq__grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
    .contact-hero { height: 320px; }
    .contact-hero__title { font-size: clamp(2.5rem, 9vw, 4rem); }
}
