.fewo-page { background: #fbf8f1; }
.fewo-page .site-header { box-shadow: 0 8px 24px rgba(46,61,44,.04); }
.fewo-hero { position: relative; min-height: clamp(520px, 56vw, 700px); overflow: hidden; display: grid; align-items: center; background: var(--cream); }
.fewo-hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 48%; filter: saturate(1.02) brightness(1.03); }
.fewo-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(247,241,229,.95) 0%, rgba(247,241,229,.82) 32%, rgba(247,241,229,.2) 62%, rgba(247,241,229,.02) 100%); }
.fewo-hero-panel { position: relative; z-index: 2; width: min(560px, calc(100% - 56px)); margin-left: clamp(28px, 8vw, 128px); padding: clamp(28px, 4vw, 54px) clamp(26px, 4vw, 50px); border-left: 2px solid rgba(108,119,66,.32); background: linear-gradient(90deg, rgba(255,253,248,.72), rgba(255,253,248,.38)); backdrop-filter: blur(2px); }
.fewo-kicker { margin: 0 0 10px; color: var(--gold); font-size: 12px; font-weight: 850; letter-spacing: .16em; text-transform: uppercase; }
.fewo-hero h1 { color: var(--green-dark); font-family: var(--font-heading); font-size: clamp(48px, 6vw, 86px); line-height: .95; font-weight: 600; }
.fewo-lead { margin: 18px 0 0; color: #42523d; font-family: var(--font-heading); font-size: clamp(28px, 3.4vw, 48px); line-height: 1.04; font-weight: 600; }
.fewo-meta { margin: 18px 0 28px; color: #566653; font-size: clamp(14px, 1.1vw, 17px); font-weight: 700; }
.fewo-meta span { color: var(--gold); padding: 0 8px; }
.fewo-tabs-wrap { position: relative; z-index: 3; margin-top: 0; padding-top: 26px; background: #fbf8f1; }
.fewo-tabs { width: min(760px, 100%); margin: 0 auto; padding: 8px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,253,248,.96); box-shadow: 0 16px 36px rgba(46,61,44,.12); }
.fewo-tabs button { position: relative; min-height: 44px; border: 0; border-radius: 999px; background: transparent; color: var(--green-dark); font: 800 14px/1 var(--font-body); cursor: pointer; transition: background .18s ease, color .18s ease, transform .18s ease; }
.fewo-tabs button + button::before { content: ""; position: absolute; left: -4px; top: 10px; bottom: 10px; width: 1px; background: rgba(108,119,66,.22); }
.fewo-tabs button:hover { transform: translateY(-1px); }
.fewo-tabs button.is-active { background: var(--green); color: #fff; box-shadow: 0 9px 18px rgba(108,119,66,.2); }
.fewo-detail-section { padding: 46px 0 46px; background: #fbf8f1; }
.fewo-panel[hidden] { display: none; }
.fewo-panel { position: relative; }
.fewo-main-grid { display: grid; grid-template-columns: minmax(300px, .86fr) minmax(0, 1.35fr); gap: clamp(26px, 4vw, 58px); align-items: start; }
.fewo-copy-card { position: relative; height: auto; padding: clamp(26px, 3vw, 42px); border: 1px solid var(--line); border-radius: 12px; background: linear-gradient(180deg, rgba(255,253,248,.98), rgba(255,253,248,.9)); box-shadow: var(--shadow); overflow: hidden; }
.fewo-copy-card::after { content: ""; position: absolute; right: -34px; bottom: -28px; width: 230px; height: 116px; background: url("/assets/images/hintergrund-fewo.png?v=20260616-fewo-bg") center/contain no-repeat; opacity: .09; pointer-events: none; }
.fewo-copy-card h2 { margin-bottom: 18px; font-size: clamp(31px, 3vw, 46px); white-space: nowrap; }
.fewo-copy-card p { margin: 0 0 26px; max-width: 460px; color: var(--muted); font-size: 17px; line-height: 1.65; }
.fewo-facts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 4rem; }
.fewo-facts span { min-height: 54px; display: flex; align-items: center; gap: 8px; padding: 12px 13px; border: 1px solid rgba(108,119,66,.18); border-radius: 8px; background: var(--green-soft); color: var(--green-dark); font-size: 14px; font-weight: 750; }
.fewo-facts span::before { content: ""; width: 24px; height: 24px; flex: 0 0 24px; display: grid; place-items: center; border-radius: 50%; background-color: rgba(108,119,66,.14); background-repeat: no-repeat; background-position: center; background-size: 15px 15px; }
.fewo-facts span:nth-child(1)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E"); }
.fewo-facts span:nth-child(2)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 3h18v18H3z'/%3E%3Cpath d='M7 7h4v4H7z'/%3E%3Cpath d='M14 7h3'/%3E%3Cpath d='M14 11h3'/%3E%3Cpath d='M7 16h10'/%3E%3C/svg%3E"); }
.fewo-facts span:nth-child(3)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 18v-6a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2v6'/%3E%3Cpath d='M2 12V7a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v5'/%3E%3Cpath d='M12 12V7a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v5'/%3E%3Cpath d='M2 18h20'/%3E%3C/svg%3E"); }
.fewo-facts span:nth-child(4)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 11 12 3l9 8'/%3E%3Cpath d='M5 10v10h14V10'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3C/svg%3E"); }
.fewo-facts span:nth-child(5)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19h16'/%3E%3Cpath d='M6 19V9l6-4 6 4v10'/%3E%3Cpath d='M9 19v-6h6v6'/%3E%3C/svg%3E"); }
.fewo-facts span:nth-child(6)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236C7742' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13a10 10 0 0 1 14 0'/%3E%3Cpath d='M8.5 16.5a5 5 0 0 1 7 0'/%3E%3Cpath d='M12 20h.01'/%3E%3C/svg%3E"); background-position: center 42%; }
.fewo-gallery { display: grid; grid-template-rows: minmax(0, 1fr) auto; gap: 14px; height: var(--fewo-gallery-height, auto); overflow: hidden; }
.fewo-gallery img { width: 100%; object-fit: cover; border-radius: 10px; box-shadow: 0 16px 30px rgba(46,61,44,.12); }
.fewo-gallery-main,
.fewo-thumbs img { cursor: pointer; transition: transform .18s ease, box-shadow .18s ease; }
.fewo-gallery-main:hover,
.fewo-thumbs img:hover { transform: translateY(-2px); box-shadow: 0 18px 34px rgba(46,61,44,.16); }
.fewo-gallery-main:focus-visible,
.fewo-thumbs img:focus-visible { outline: 3px solid rgba(108,119,66,.55); outline-offset: 4px; }
.fewo-gallery-main { aspect-ratio: auto; height: 100%; min-height: 0; }
.fewo-thumbs { display: flex; gap: 14px; overflow-x: auto; padding: 4px 4px 8px; scrollbar-width: thin; }
.fewo-thumbs img { flex: 0 0 clamp(108px, 18%, 156px); aspect-ratio: 4 / 3; height: var(--fewo-thumb-height, 112px); min-height: 0; }
.fewo-thumbs img.is-active { outline: 3px solid rgba(108,119,66,.46); outline-offset: 3px; }
.fewo-lightbox-open { overflow: hidden; }
.fewo-lightbox { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: clamp(18px, 4vw, 56px); background: rgba(22, 28, 18, .86); }
.fewo-lightbox[hidden] { display: none; }
.fewo-lightbox-image { max-width: min(1120px, 86vw); max-height: 86vh; width: auto; height: auto; border-radius: 10px; object-fit: contain; box-shadow: 0 28px 80px rgba(0,0,0,.38); cursor: pointer; }
.fewo-lightbox-close,
.fewo-lightbox-nav { position: absolute; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.38); border-radius: 50%; background: rgba(255,253,248,.94); color: var(--green-dark); box-shadow: 0 12px 30px rgba(0,0,0,.22); cursor: pointer; }
.fewo-lightbox-close { top: clamp(18px, 3vw, 34px); right: clamp(18px, 3vw, 34px); width: 46px; height: 46px; font: 900 20px/1 var(--font-body); }
.fewo-lightbox-nav { top: 50%; width: 48px; height: 48px; transform: translateY(-50%); font: 900 25px/1 var(--font-body); }
.fewo-lightbox-prev { left: clamp(16px, 3vw, 34px); }
.fewo-lightbox-next { right: clamp(16px, 3vw, 34px); }
.fewo-lightbox-close:hover,
.fewo-lightbox-nav:hover { background: #fff; transform: translateY(-1px); }
.fewo-lightbox-nav:hover { transform: translateY(calc(-50% - 1px)); }
.fewo-lightbox-close:focus-visible,
.fewo-lightbox-nav:focus-visible,
.fewo-lightbox-image:focus-visible { outline: 3px solid rgba(255,255,255,.72); outline-offset: 4px; }
.fewo-equipment { margin-top: 42px; padding: 32px clamp(24px, 3vw, 38px); border-block: 1px solid var(--line); background: linear-gradient(90deg, rgba(255,253,248,.9), rgba(255,253,248,.72)), url("/assets/images/hintergrund-edelweiss.jpg") 82% calc(50% + 70px) / cover no-repeat; }
.fewo-equipment h3 { position: relative; display: inline-block; margin-bottom: 20px; font-size: clamp(34px, 3.4vw, 48px); }
.fewo-equipment h3::after { content: ""; display: block; width: 100%; height: 2px; margin-top: 12px; background: var(--green); opacity: .8; }
.equipment-groups { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px 34px; }
.equipment-group { min-width: 0; }
.equipment-group h4 { margin: 0 0 12px; color: var(--green-dark); font-size: 18px; font-weight: 850; }
.fewo-equipment ul { margin: 0; padding: 0; display: grid; gap: 20px; list-style: none; }
.fewo-equipment li { position: relative; padding-left: 32px; color: #475542; font-size: 15px; font-weight: 650; }
.fewo-equipment li::before { content: "✓"; position: absolute; left: 0; top: -2px; width: 22px; height: 22px; display: grid; place-items: center; border-radius: 50%; background: rgba(108,119,66,.14); color: var(--green); font-size: 13px; font-weight: 900; }
.fewo-other-list { margin-top: 34px; display: grid; gap: 14px; }
.fewo-other { width: 100%; display: grid; grid-template-columns: 150px minmax(0, .78fr) minmax(130px, .22fr); gap: 20px; align-items: center; padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); box-shadow: 0 10px 24px rgba(46,61,44,.07); color: inherit; text-align: left; cursor: pointer; }
.fewo-other img { width: 150px; height: 92px; object-fit: cover; border-radius: 8px; }
.fewo-other strong { display: block; margin-bottom: 18px; color: var(--green-dark); font-family: var(--font-heading); font-size: 28px; font-weight: 700; }
.fewo-other small { display: block; color: var(--muted); font-size: 13px; line-height: 1.4; }
.fewo-other-facts { display: flex; flex-wrap: wrap; gap: 9px 0; align-items: center; }
.fewo-other-facts span { display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; }
.fewo-other-facts span:not(:last-child)::after { content: "|"; margin: 0 16px; color: rgba(108,119,66,.34); font-weight: 700; }
.fewo-other-facts span::before { content: ""; width: 15px; height: 15px; flex: 0 0 15px; background: var(--green); opacity: .88; -webkit-mask: var(--fact-icon) center / contain no-repeat; mask: var(--fact-icon) center / contain no-repeat; }
.fewo-other-facts span:nth-child(1)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E"); }
.fewo-other-facts span:nth-child(2)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 3h18v18H3z'/%3E%3Cpath d='M7 7h4v4H7z'/%3E%3Cpath d='M14 7h3'/%3E%3Cpath d='M14 11h3'/%3E%3Cpath d='M7 16h10'/%3E%3C/svg%3E"); }
.fewo-other-facts span:nth-child(4)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 18v-6a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2v6'/%3E%3Cpath d='M2 18h20'/%3E%3Cpath d='M6 10V6h12v4'/%3E%3C/svg%3E"); }
.fewo-other-facts span:nth-child(5)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 3h16'/%3E%3Cpath d='M6 3v18'/%3E%3Cpath d='M18 3v18'/%3E%3Cpath d='M8 8h8'/%3E%3Cpath d='M8 13h8'/%3E%3Cpath d='M8 18h8'/%3E%3C/svg%3E"); }
.fewo-other-facts span:nth-child(6)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19h16'/%3E%3Cpath d='M6 19V9l6-4 6 4v10'/%3E%3Cpath d='M9 19v-6h6v6'/%3E%3C/svg%3E"); }
.fewo-other-facts span:nth-child(3)::before { --fact-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13a10 10 0 0 1 14 0'/%3E%3Cpath d='M8.5 16.5a5 5 0 0 1 7 0'/%3E%3Cpath d='M12 20h.01'/%3E%3C/svg%3E"); transform: translateY(-2px); }
.fewo-other em { justify-self: end; text-align: right; color: var(--green); font-style: normal; font-size: 14px; font-weight: 850; white-space: nowrap; }
.fewo-outside { padding: 14px 0 54px; background: #fbf8f1; }
.fewo-outside .container { display: grid; gap: 24px; }
.fewo-outside-head { max-width: 700px; }
.fewo-outside-head h2 { margin-bottom: 12px; font-size: clamp(36px, 3.8vw, 58px); }
.fewo-outside-head p:last-child { margin: 0; color: var(--muted); font-size: 17px; line-height: 1.6; }
.fewo-outside-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr) minmax(0, 1.08fr); gap: 16px; align-items: stretch; }
.fewo-outside-card { position: relative; min-width: 0; min-height: 250px; margin: 0; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--paper); box-shadow: 0 16px 34px rgba(46,61,44,.1); }
.fewo-outside-card img { width: 100%; height: 100%; min-height: 250px; display: block; object-fit: cover; cursor: pointer; transition: transform .28s ease; }
.fewo-outside-card:hover img { transform: scale(1.025); }
.fewo-outside-card figcaption { position: absolute; left: 14px; right: 14px; bottom: 14px; width: fit-content; max-width: calc(100% - 28px); padding: 9px 13px; border-radius: 999px; background: rgba(255,253,248,.92); color: var(--green-dark); font-size: 13px; font-weight: 850; box-shadow: 0 10px 22px rgba(46,61,44,.16); }
.fewo-request { padding: 50px 0 64px; background: #fbf8f1; }
.request-card { position: relative; display: grid; grid-template-columns: minmax(280px, .78fr) minmax(0, 1fr); gap: clamp(26px, 5vw, 70px); padding: clamp(28px, 4vw, 54px); border: 1px solid var(--line); border-radius: 14px; background: linear-gradient(90deg, rgba(255,253,248,.94), rgba(255,253,248,.72)), url("/assets/images/edelweiss.png") left center/48% auto no-repeat, url("/assets/images/berge-footer.png") right bottom/70% auto no-repeat; box-shadow: var(--shadow); overflow: hidden; }
.request-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,253,248,.78), rgba(255,253,248,.28)); pointer-events: none; }
.request-card > * { position: relative; z-index: 1; }
.request-copy h2 { font-size: clamp(40px, 4vw, 62px); margin-bottom: 16px; }
.request-copy p { color: var(--muted); font-size: 18px; }
.request-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; align-content: center; }
.request-action { min-height: 128px; display: flex; flex-direction: column; justify-content: center; gap: 10px; padding: 24px; border: 1px solid rgba(108,119,66,.25); border-radius: 10px; background: rgba(255,255,255,.82); color: var(--green-dark); box-shadow: 0 10px 24px rgba(46,61,44,.08); }
.request-action span { font-family: var(--font-heading); font-size: clamp(26px, 2.4vw, 38px); line-height: 1; font-weight: 700; }
.request-action small { color: var(--muted); font-size: 14px; line-height: 1.35; font-weight: 700; }
.request-action-booking { background: var(--green); color: #fff; border-color: var(--green); }
.request-action-booking small { color: rgba(255,255,255,.86); }
.request-action:hover { transform: translateY(-2px); }
@media (max-width: 1080px) { .fewo-main-grid, .request-card { grid-template-columns: 1fr; } .fewo-gallery { height: auto; overflow: visible; } .fewo-gallery-main { aspect-ratio: 16 / 10; height: auto; min-height: 320px; } .fewo-thumbs img { aspect-ratio: 4 / 3; height: auto; min-height: 132px; } .fewo-outside-grid { grid-template-columns: 1fr 1fr; } .fewo-outside-card:first-child { grid-column: 1 / -1; } }
@media (max-width: 1240px) {
  .fewo-other .fewo-other-facts {
    display: inline-grid;
    width: auto;
    max-width: 100%;
    grid-template-columns: repeat(3, max-content);
    gap: 9px 0;
    align-items: center;
    justify-content: start;
  }

  .fewo-other-facts span {
    min-width: 0;
    justify-content: center;
    padding: 0 16px;
    white-space: nowrap;
  }

  .fewo-other-facts span:not(:last-child)::after {
    content: none;
  }

  .fewo-other-facts span:nth-child(1),
  .fewo-other-facts span:nth-child(4) {
    padding-left: 0;
  }

  .fewo-other-facts span:nth-child(3),
  .fewo-other-facts span:nth-child(6) {
    padding-right: 0;
  }

  .fewo-other-facts span:nth-child(1) { grid-column: 1; grid-row: 1; }
  .fewo-other-facts span:nth-child(2) { grid-column: 2; grid-row: 1; }
  .fewo-other-facts span:nth-child(3) { grid-column: 3; grid-row: 1; }
  .fewo-other-facts span:nth-child(4) { grid-column: 1; grid-row: 2; }
  .fewo-other-facts span:nth-child(5) { grid-column: 2; grid-row: 2; }
  .fewo-other-facts span:nth-child(6) { grid-column: 3; grid-row: 2; }

  .fewo-other-facts span:nth-child(2),
  .fewo-other-facts span:nth-child(3),
  .fewo-other-facts span:nth-child(5),
  .fewo-other-facts span:nth-child(6) {
    border-left: 1px solid rgba(108,119,66,.34);
  }
}
@media (min-width: 761px) and (max-width: 900px) {
  .fewo-other {
    grid-template-columns: 150px minmax(0, 1fr) max-content;
  }

  .fewo-other em {
    justify-self: end;
    align-self: center;
    text-align: right;
  }
}

@media (max-width: 760px) { .fewo-hero { min-height: 560px; align-items: end; } .fewo-hero::after { background: linear-gradient(180deg, rgba(247,241,229,.25), rgba(247,241,229,.96) 62%); } .fewo-hero-panel { width: calc(100% - 24px); margin: 0 auto 24px; padding: 26px 22px; background: rgba(255,253,248,.78); } .fewo-meta span { padding: 0 4px; } .fewo-tabs { overflow-x: auto; grid-template-columns: repeat(3, minmax(96px, 1fr)); border-radius: 12px; } .fewo-detail-section { padding: 46px 0 46px; } .fewo-facts { grid-template-columns: repeat(2, minmax(0, 1fr)); } .fewo-thumbs { grid-template-columns: 1fr; } .fewo-thumbs img { min-height: 180px; } .equipment-groups { grid-template-columns: 1fr; } .fewo-other { grid-template-columns: 88px minmax(0, 1fr); gap: 13px; } .fewo-other img { width: 88px; height: 78px; } .fewo-other em { grid-column: 2; justify-self: start; text-align: left; } .fewo-outside { padding: 0 0 42px; } .fewo-outside-grid { grid-template-columns: 1fr; } .fewo-outside-card:first-child { grid-column: auto; } .fewo-outside-card, .fewo-outside-card img { min-height: 230px; } .request-actions { grid-template-columns: 1fr; } }
@media (max-width: 760px) { .fewo-thumbs img { flex-basis: min(68vw, 240px); height: auto; min-height: 0; } }
@media (max-width: 420px) { .fewo-facts { grid-template-columns: 1fr; } .fewo-gallery-main { min-height: 250px; } .fewo-other { grid-template-columns: 1fr; } .fewo-other img { width: 100%; height: 150px; } .fewo-other em { grid-column: 1; } }

@media (min-width: 660px) and (max-width: 760px) {
  .fewo-other {
    grid-template-columns: 120px minmax(0, 1fr) minmax(120px, max-content);
    gap: 16px;
  }

  .fewo-other img {
    width: 120px;
    height: 82px;
  }

  .fewo-other em {
    grid-column: auto;
    justify-self: end;
    text-align: right;
  }
}

@media (max-width: 760px) {
  .fewo-hero-panel {
    width: calc(100vw - 32px);
    max-width: calc(100vw - 32px);
  }
}

.fewo-hero h1 {
  font-size: clamp(44px, 5.2vw, 78px);
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

@media (max-width: 760px) {
  .fewo-hero h1 {
    font-size: clamp(42px, 11vw, 48px);
  }
}

#ferienwohnungen-hero .hero-image {
  object-position: center 59%;
  transform: translateX(4%) scale(1.08);
  transform-origin: center center;
}

/* Responsive polish up to 1280px only */
@media (max-width: 1280px) {
  .fewo-copy-card h2 {
    white-space: normal;
  }

  .fewo-thumbs {
    flex-wrap: wrap;
    overflow-x: visible;
    padding-bottom: 4px;
  }

  .fewo-thumbs img {
    flex: 1 1 clamp(104px, 14vw, 156px);
  }

  .fewo-other-facts span {
    white-space: nowrap;
  }

  .request-action,
  .fewo-other,
  .fewo-tabs button {
    min-height: 44px;
  }
}

@media (max-width: 760px) {
  .fewo-thumbs img {
    flex-basis: calc(50% - 7px);
  }

  .fewo-other strong {
    margin-bottom: 10px;
  }
}

@media (max-width: 360px) {
  .fewo-tabs {
    gap: 4px;
    padding: 6px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .fewo-tabs button {
    font-size: 13px;
  }
}

/* Fewo-Galerie mobil als Swipebar */
@media (max-width: 760px) {
  .fewo-thumbs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 10px;
  }

  .fewo-thumbs img {
    flex: 0 0 min(68vw, 240px);
    scroll-snap-align: start;
  }
}

/* Fewo-Galerie Swipebar bis 900px */
@media (max-width: 900px) {
  .fewo-thumbs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 10px;
  }

  .fewo-thumbs img {
    flex: 0 0 min(68vw, 240px);
    scroll-snap-align: start;
  }
}

/* Mobile-Heros wie Buchen gestalten */
@media (max-width: 900px) {
  .fewo-equipment {
    background-position: 0 0, 96% calc(50% + 70px);
  }

  .fewo-hero {
    align-items: center;
  }

  .fewo-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));
  }

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

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

  .fewo-hero .hero-actions {
    justify-content: center;
  }

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

/* Ferienwohnungen-Hero mobile Buchen-Optik */
@media (max-width: 900px) {
  #ferienwohnungen-hero {
    align-items: center;
  }

  #ferienwohnungen-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));
  }

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

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

  #ferienwohnungen-hero .hero-actions {
    justify-content: center;
  }

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

@media (max-width: 620px) {
  #fewo-title span {
    font-size: clamp(42px, 11.5vw, 54px);
    white-space: nowrap;
  }
}

@media (max-width: 640px) {
  .fewo-other .fewo-other-facts {
    grid-template-columns: repeat(3, max-content);
    gap: 8px 0;
  }

  .fewo-other-facts span {
    gap: 5px;
    padding-inline: 9px;
    font-size: 12px;
  }

  .fewo-other-facts span:nth-child(1),
  .fewo-other-facts span:nth-child(4) {
    padding-left: 0;
  }

  .fewo-other-facts span:nth-child(3),
  .fewo-other-facts span:nth-child(6) {
    padding-right: 0;
  }
}

/* Smartphones und Tablets: eine Bildflaeche, direkt per Swipe wechselbar. */
@media (max-width: 1080px) {
  .fewo-gallery {
    display: block;
    height: auto;
    overflow: visible;
  }

  .fewo-gallery-main {
    width: 100%;
    aspect-ratio: 16 / 10;
    height: auto;
    min-height: 320px;
    border-radius: inherit;
    overflow: hidden;
    cursor: grab;
    touch-action: pan-y;
    user-select: none;
    will-change: transform, opacity;
    transition: transform 190ms ease-out, opacity 190ms ease-out;
  }

  .fewo-gallery-main.is-swiping {
    transition: none;
  }

  .fewo-gallery-main:active {
    cursor: grabbing;
  }

  .fewo-thumbs {
    display: none;
  }

  .fewo-gallery::after {
    content: "← Swipe →";
    display: block;
    margin: 10px auto 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    color: var(--green);
    font-size: 13px;
    font-weight: 850;
    text-shadow: none;
    letter-spacing: .12em;
    line-height: 1;
    text-align: center;
    text-transform: uppercase;
  }
}

@media (max-width: 420px) {
  .fewo-gallery-main {
    min-height: 250px;
  }
}
