.contact-page { background: #fbf8f1; }
.contact-hero { position: relative; min-height: clamp(340px, 27.5vw, 420px); display: grid; align-items: center; overflow: hidden; background: #dfe7da; }
.contact-hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 42%; filter: saturate(1.02) brightness(1.08); }
.contact-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(246,241,229,.9) 0%, rgba(246,241,229,.72) 31%, rgba(246,241,229,.22) 56%, rgba(246,241,229,.02) 100%); }
.contact-hero-soft { position: absolute; z-index: 1; left: 0; top: 0; bottom: 0; width: min(58vw, 760px); background: linear-gradient(90deg, rgba(255,253,248,.93), rgba(255,253,248,.78), rgba(255,253,248,0)); }
.contact-hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, 560px) 1fr; align-items: center; min-height: inherit; padding-block: 28px; }
.contact-hero-copy h1 { font-size: clamp(34px, 3.45vw, 54px); }
.contact-hero-copy p { margin: 18px 0 0; color: #536251; font-size: clamp(16px, 1.35vw, 19px); line-height: 1.5; }
.contact-ornament { display: flex; align-items: center; gap: 11px; margin-top: 18px; color: var(--green-dark); }
.contact-ornament span { width: clamp(54px, 7vw, 100px); height: 1px; background: currentColor; opacity: .42; }
.contact-ornament b { color: var(--green); font-size: 15px; line-height: 1; }
.contact-ornament-small { gap: 0; margin: -6px 0 18px; }
.contact-ornament-small span { width: 118px; }
.contact-main { position: relative; z-index: 3; margin-top: clamp(-54px, -4vw, -34px); padding-bottom: 34px; }
.contact-card-grid { display: grid; grid-template-columns: minmax(280px, .82fr) minmax(360px, 1.18fr); gap: 18px; align-items: stretch; }
.contact-card { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,253,248,.96); box-shadow: 0 16px 36px rgba(46,61,44,.09); }
.contact-page main h2::after { content: ""; display: block; width: 118px; height: 1px; margin: 12px 0 18px; background: var(--green-dark); opacity: .42; }
.contact-card::after { content: ""; position: absolute; right: -20px; bottom: -18px; width: 132px; height: 132px; background: url("/assets/images/edelweiss.png") center/contain no-repeat; opacity: .09; pointer-events: none; }
.contact-details-card { background-image: url("/assets/images/hintergrund-fewo.png?v=20260616-fewo-bg"); background-size: cover; background-position: right bottom; background-repeat: no-repeat; }
.contact-details-card, .contact-form-card, .host-card-copy, .location-copy-card { padding: clamp(20px, 2.2vw, 30px); }
.contact-lines { display: grid; gap: 34px; font-style: normal; color: var(--green-dark); font-size: 17px; line-height: 1.45; font-weight: 500; }
.contact-card-logo { width: min(230px, 78%); height: auto; margin: 0 0 4px; }
.contact-lines a, .contact-lines > span { display: grid; grid-template-columns: 28px 1fr; gap: 13px; align-items: start; }
.contact-lines svg, .service-box svg { width: 24px; height: 24px; color: var(--green); fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.service-box { margin-top: 24px; padding: 16px; border: 1px solid rgba(108,119,66,.2); border-radius: 12px; background: rgba(238,241,229,.72); }
.service-box h3 { display: flex; align-items: center; gap: 9px; margin-bottom: 8px; font-size: 24px; }
.service-box p { margin: 0 0 5px; color: #566451; }
.service-box strong { color: var(--green-dark); }
.contact-form { display: grid; gap: 13px; }
.contact-form label { display: grid; gap: 6px; color: var(--green-dark); font-size: 12px; font-weight: 800; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid rgba(108,119,66,.22); border-radius: 8px; background: #fff; color: var(--ink); font: 600 14px/1.35 var(--font-body); }
.contact-form input { height: 44px; padding: 0 12px; }
.contact-form textarea { min-height: 118px; resize: vertical; padding: 12px; }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.contact-form button { justify-self: center; gap: 9px; margin-top: 2px; text-transform: uppercase; }
.contact-form button:disabled { opacity: .48; cursor: not-allowed; transform: none; box-shadow: none; }
.form-note { margin: 0; color: #69776b; font-size: 13px; text-align: center; }
.host-card { display: grid; grid-template-rows: 210px 1fr; }
.host-card > img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.host-card-copy p { margin: 0 0 16px; color: #566451; line-height: 1.65; }
.host-signature { font-family: var(--font-script); font-size: 34px; line-height: 1; color: var(--green); }
.host-card-copy span { display: inline-flex; border-top: 1px solid var(--line); padding-top: 12px; color: var(--green-dark); font-weight: 800; }
.location-section { padding: 10px 0 36px; }
.location-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(300px, .75fr); gap: 18px; align-items: stretch; }
.map-panel { display: block; position: relative; min-height: 420px; overflow: hidden; border: 1px solid var(--line); border-radius: 16px; background: var(--white); box-shadow: 0 16px 36px rgba(46,61,44,.09); }
.map-panel-link { color: inherit; text-decoration: none; }
.map-panel img { width: 100%; height: 100%; min-height: 420px; display: block; object-fit: cover; }
.map-line { position: absolute; height: 3px; border-radius: 999px; background: rgba(108,119,66,.28); transform-origin: left center; }
.map-line-one { left: 8%; right: 8%; top: 48%; transform: rotate(-9deg); }
.map-line-two { left: 18%; right: 6%; top: 64%; transform: rotate(10deg); }
.map-place { position: absolute; padding: 7px 10px; border-radius: 999px; background: rgba(255,253,248,.82); border: 1px solid rgba(108,119,66,.16); color: var(--green-dark); font-weight: 800; font-size: 13px; }
.place-jerzens { left: 13%; top: 23%; }
.place-pitztal { right: 15%; bottom: 25%; }
.map-marker { position: absolute; left: 47%; top: 38%; display: grid; justify-items: center; gap: 3px; transform: translate(-50%, -50%); color: var(--green-dark); text-align: center; }
.map-marker span { width: 30px; height: 30px; border-radius: 50% 50% 50% 0; background: var(--green); transform: rotate(-45deg); box-shadow: 0 8px 16px rgba(79,91,48,.25); }
.map-marker span::after { content: ""; position: absolute; inset: 9px; border-radius: 50%; background: #fffdf8; }
.map-marker strong, .map-marker small { padding: 2px 8px; border-radius: 999px; background: rgba(255,253,248,.9); }
.location-copy-card { display: flex; flex-direction: column; justify-content: center; }
.location-copy-card p { margin: 0 0 22px; color: #566451; line-height: 1.7; }
.location-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.contact-benefits { padding: 0 0 48px; }
.contact-benefit-row { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); overflow: hidden; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,253,248,.95); box-shadow: 0 12px 28px rgba(46,61,44,.07); }
.contact-benefit-row span { display: flex; align-items: center; justify-content: center; gap: 9px; min-height: 72px; padding: 13px; color: var(--green-dark); font-weight: 800; text-align: center; }
.contact-benefit-row svg { flex: 0 0 20px; width: 20px; height: 20px; color: var(--green); fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.contact-benefit-row span + span { border-left: 1px solid var(--line); }
@media (max-width: 1120px) { .contact-card-grid { grid-template-columns: 1fr 1fr; } .host-card { grid-column: 1 / -1; grid-template-columns: 280px 1fr; grid-template-rows: auto; } .location-grid { grid-template-columns: 1fr; } .contact-benefit-row { grid-template-columns: repeat(3, minmax(0, 1fr)); } .contact-benefit-row span { border-top: 1px solid var(--line); } .contact-benefit-row span:nth-child(-n+3) { border-top: 0; } .contact-benefit-row span:nth-child(4) { border-left: 0; } }
@media (max-width: 760px) { .contact-hero { min-height: 560px; } .contact-hero-grid { grid-template-columns: 1fr; align-content: center; } .contact-hero .hero-badge { justify-self: start; width: 168px; margin-top: 14px; } .contact-card-grid, .form-row, .host-card { grid-template-columns: 1fr; } .host-card { grid-template-rows: 220px auto; } .map-panel { min-height: 330px; } .contact-benefit-row { grid-template-columns: 1fr; } .contact-benefit-row span { justify-content: flex-start; border-left: 0 !important; border-top: 1px solid var(--line) !important; } .contact-benefit-row span:first-child { border-top: 0 !important; } .contact-form button, .location-actions .btn { width: 100%; } }
@media (max-width: 760px) {
  .contact-card-grid .contact-card {
    background-color: rgba(255,253,248,.97);
  }

  .contact-details-card {
    background-image: linear-gradient(rgba(255,253,248,.78), rgba(255,253,248,.82)), url("/assets/images/hintergrund-fewo.png?v=20260616-fewo-bg");
  }

  .contact-card::after {
    opacity: .07;
  }
}
@media (max-width: 520px) { .contact-hero-copy p br { display: none; } .contact-main { margin-top: -28px; } .contact-details-card, .contact-form-card, .host-card-copy, .location-copy-card { padding: 18px; } }
.contact-form .consent-label { display: grid; grid-template-columns: 22px 1fr; gap: 10px; align-items: start; color: #566451; font-size: 12px; font-weight: 500; line-height: 1.5; }
.contact-form .consent-label input { width: 18px; height: 18px; min-height: 0; margin: 2px 0 0; padding: 0; accent-color: var(--green); }
.contact-form .consent-label a { color: var(--green-dark); font-weight: 750; text-decoration: underline; text-underline-offset: 2px; }

.spam-guard { padding: 12px; border: 1px solid rgba(108,119,66,.2); border-radius: 10px; background: rgba(238,241,229,.56); }
.spam-guard span { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.spam-guard strong { color: var(--green-dark); font-size: 15px; }
.spam-guard small { min-height: 16px; color: #9a3f2d; font-size: 12px; font-weight: 700; }

.field-trap { position: absolute; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden; opacity: 0; pointer-events: none; }
.contact-form.is-loading button { opacity: .48; cursor: wait; }

/* Responsive polish up to 1280px only */
@media (max-width: 1280px) {
  .contact-lines a,
  .contact-lines > span,
  .location-actions .btn,
  .contact-form button {
    min-height: 42px;
  }

  .contact-lines a,
  .contact-lines > span {
    align-items: center;
  }

  .contact-form .consent-label {
    min-height: 42px;
  }
}

@media (max-width: 520px) {
  .spam-guard span {
    align-items: flex-start;
    flex-direction: column;
    gap: 6px;
  }
}

/* Mobile-Heros wie Buchen gestalten */
@media (max-width: 900px) {
  .contact-hero::after {
    background: linear-gradient(180deg, rgba(255,253,248,.5) 0%, rgba(255,253,248,.7) 47%, rgba(251,248,241,.86) 100%), radial-gradient(circle at 14% 8%, rgba(255,238,193,.62), rgba(255,238,193,0) 28%), linear-gradient(90deg, rgba(255,253,248,.8), rgba(255,253,248,.2) 35%, rgba(255,253,248,.7));
  }

  .contact-hero-soft {
    display: none;
  }

  .contact-hero-grid {
    grid-template-columns: 1fr;
    align-content: center;
    justify-items: center;
    text-align: center;
    padding-block: 48px 58px;
  }

  .contact-hero-copy {
    justify-self: center;
    text-align: center;
  }

  .contact-hero .hero-badge {
    justify-self: center;
    margin: 18px auto 0;
  }
}
