.fewo-booking-widget,
.fewo-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 1rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.fewo-card {
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 12px;
  padding: 1rem;
  margin: 1rem 0;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.fewo-admin-nav {
  display: flex;
  gap: .75rem;
  align-items: center;
  margin: 1rem 0;
  flex-wrap: wrap;
}
.fewo-admin-nav a {
  padding: .4rem .7rem;
  border: 1px solid #ddd;
  border-radius: 999px;
  text-decoration: none;
}

.fewo-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: .75rem;
}
.fewo-table th,
.fewo-table td {
  border-bottom: 1px solid #ddd;
  text-align: left;
  vertical-align: top;
  padding: .65rem;
}
.fewo-table-bookings { font-size: .92rem; }
.fewo-actions { display: grid; gap: .4rem; min-width: 220px; }
.fewo-actions form { display: grid; gap: .35rem; }
.fewo-grid-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: .75rem;
  align-items: end;
}
.fewo-grid-form input,
.fewo-actions input,
.fewo-actions select {
  width: 100%;
  box-sizing: border-box;
  padding: .55rem;
  border: 1px solid #bbb;
  border-radius: 8px;
}
code {
  background: #f4f4f4;
  padding: .2rem .35rem;
  border-radius: 4px;
  word-break: break-all;
}

/* Kuppenheim Apartment booking widget */
.fewo-booking-widget {
  max-width: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, .9fr);
  gap: clamp(1rem, 3vw, 2rem);
  font-family: inherit;
  align-items: start;
}

.fewo-booking-widget .fewo-card {
  background: rgba(255,255,255,.94);
  border: 1px solid var(--line, #e5ddd4);
  border-radius: var(--radius, 24px);
  padding: clamp(1.2rem, 2vw, 2rem);
  margin: 0;
  box-shadow: var(--shadow, 0 20px 60px rgba(32,32,32,.08));
  overflow: hidden;
}

.fewo-card h2 {
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.75rem, 3vw, 2.65rem);
  line-height: 1.05;
  margin: .35rem 0 1rem;
}
.fewo-card p { color: var(--muted, #666); }

.fewo-calendar-controls {
  display: grid;
  grid-template-columns: 2.35rem minmax(0, 1fr) 2.35rem;
  gap: .75rem;
  align-items: center;
  margin: 1.4rem 0 1.2rem;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 999px;
  padding: .35rem;
  background: var(--surface, #faf7f2);
}
.fewo-calendar-controls strong {
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
}
.fewo-calendar-controls button {
  width: 2.35rem;
  height: 2.35rem;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 4px 14px rgba(32,32,32,.08);
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}
.fewo-calendar-controls button:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(32,32,32,.12);
}

.fewo-calendar {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  max-width: 100%;
}
.fewo-month h3 {
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  margin: .25rem 0 1rem;
}
.fewo-month-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .42rem;
  width: 100%;
}
.fewo-weekday {
  font-size: .8rem;
  color: var(--muted, #666);
  text-align: center;
  font-weight: 700;
}
.fewo-empty-day { min-height: 2.55rem; }
.fewo-day {
  min-width: 0;
  width: 100%;
  aspect-ratio: 1 / .86;
  min-height: 2.55rem;
  border: 1px solid var(--line, #e5ddd4);
  background: #fff;
  color: var(--dark, #202624);
  border-radius: 12px;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
  font: inherit;
  font-weight: 650;
}
.fewo-day.free:hover {
  transform: translateY(-1px);
  border-color: var(--accent, #b76d48);
  box-shadow: 0 8px 18px rgba(32,32,32,.08);
}
.fewo-day.in-range {
  background: #f6eee7;
  border-color: rgba(183,109,72,.28);
}
.fewo-day.selected-start,
.fewo-day.selected-end {
  outline: 0;
  background: var(--dark, #202624);
  color: #fff;
  border-color: var(--dark, #202624);
}
.fewo-day.occupied,
.fewo-day.blocked,
.fewo-day.hold {
  color: #8b837b;
  background: #eee9e2;
  cursor: not-allowed;
  text-decoration: line-through;
}
.fewo-legend {
  display: flex;
  gap: .75rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: .9rem;
  color: var(--muted, #666);
}
.fewo-dot {
  width: .75rem;
  height: .75rem;
  border-radius: 50%;
  display: inline-block;
  border: 1px solid #aaa;
}
.fewo-dot.occupied,
.fewo-dot.blocked { background: #ddd; }

.fewo-booking-form fieldset {
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 18px;
  margin: 1rem 0;
  padding: 1rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
}
.fewo-booking-form legend {
  color: var(--dark, #202624);
  font-weight: 800;
  padding: 0 .35rem;
}
.fewo-booking-form label {
  display: grid;
  gap: .35rem;
}
.fewo-booking-form input,
.fewo-booking-form textarea,
.fewo-booking-form select {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 12px;
  padding: .75rem .85rem;
  font: inherit;
  background: #fff;
}
.fewo-booking-form input:focus,
.fewo-booking-form textarea:focus,
.fewo-booking-form select:focus {
  outline: 2px solid rgba(183,109,72,.25);
  border-color: var(--accent, #b76d48);
}
.fewo-full { grid-column: 1 / -1; }
.fewo-muted { color: var(--muted, #666); font-size: .92rem; }
.fewo-required-hint {
  margin: -.2rem 0 .2rem;
  color: var(--muted, #666);
  font-size: .88rem;
}
.fewo-field-label {
  display: inline-flex;
  gap: .25rem;
  align-items: baseline;
  font-weight: 700;
}
.fewo-required { color: var(--accent, #b76d48); font-weight: 900; }
.fewo-optional { color: var(--muted, #666); font-size: .82rem; font-weight: 600; }
.fewo-checkbox,
.fewo-radio {
  display: flex !important;
  grid-template-columns: auto 1fr !important;
  align-items: flex-start;
  gap: .6rem !important;
}
.fewo-checkbox input,
.fewo-radio input { width: auto; margin-top: .2rem; }
.fewo-checkbox a { color: var(--accent, #b76d48); font-weight: 700; }

.fewo-confirmation-fieldset {
  padding: .66rem .84rem .78rem !important;
  gap: .44rem !important;
}
.fewo-confirmation-list {
  display: grid;
  gap: .42rem;
}
.fewo-checkbox--compact {
  gap: .5rem !important;
  margin: 0;
  line-height: 1.34;
}
.fewo-checkbox--compact input {
  flex: 0 0 auto;
  margin-top: .18rem;
}
.fewo-checkbox--compact span {
  display: block;
}
.fewo-checkbox--compact a {
  text-decoration: underline;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}
.fewo-policy--compact {
  margin-top: .18rem;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
}
.fewo-policy--compact summary {
  cursor: pointer;
  padding: .68rem .85rem;
  font-weight: 800;
  line-height: 1.25;
  list-style: none;
}
.fewo-policy--compact summary::-webkit-details-marker {
  display: none;
}
.fewo-policy--compact summary::before {
  content: '›';
  display: inline-block;
  margin-right: .45rem;
  transform: rotate(0deg);
  transition: transform .18s ease;
}
.fewo-policy--compact[open] summary::before {
  transform: rotate(90deg);
}
.fewo-policy--compact pre {
  margin: 0 .85rem .85rem;
  max-height: 260px;
  overflow: auto;
  font-size: .92rem;
  line-height: 1.45;
}
.fewo-disabled { opacity: .55; }
.fewo-hp { position: absolute !important; left: -9999px !important; }

.fewo-button {
  border: 0;
  border-radius: 999px;
  padding: .9rem 1.25rem;
  background: var(--dark, #202624);
  color: #fff;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  font-weight: 800;
  transition: transform .18s ease, box-shadow .18s ease;
}
.fewo-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 30px rgba(32,32,32,.16);
}
.fewo-button-small { padding: .4rem .7rem; font-size: .85rem; }
.fewo-button-danger { background: #8b0000; }

.fewo-price {
  padding: 1rem;
  background: linear-gradient(135deg, #fff7ee, #fff);
  border: 1px solid rgba(183,109,72,.22);
  border-radius: 18px;
  margin: 1rem 0;
  color: var(--dark, #202624);
}
.fewo-price small { color: var(--muted, #666); }
.fewo-voucher {
  margin: 1rem 0 0;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}
.fewo-voucher summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .82rem 1rem;
  cursor: pointer;
  font-weight: 800;
  list-style: none;
}
.fewo-voucher summary::-webkit-details-marker {
  display: none;
}
.fewo-voucher summary::after {
  content: '+';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 999px;
  background: #f6eee7;
  color: var(--dark, #202624);
  flex: 0 0 auto;
}
.fewo-voucher[open] summary::after {
  content: '-';
}
.fewo-voucher__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .7rem;
  align-items: end;
  padding: 0 1rem 1rem;
}
.fewo-voucher__body label {
  margin: 0;
}
.fewo-voucher-status {
  grid-column: 1 / -1;
  margin: -.2rem 0 0;
  font-size: .9rem;
}
.fewo-unit-picker {
  display: block;
  margin: 1rem 0 1.2rem;
  padding: .95rem;
  border: 1px solid rgba(31, 35, 32, .12);
  border-radius: 14px;
  background: #fffdfa;
}
.fewo-unit-picker__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: .75rem;
}
.fewo-unit-picker__eyebrow {
  margin: 0 0 .25rem;
  color: var(--accent, #b76d48);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.fewo-unit-picker__head h3 {
  margin: 0 0 .25rem;
  font-size: 1rem;
}
.fewo-unit-picker__head p {
  margin: 0;
  color: #6a7069;
  font-size: .92rem;
  line-height: 1.45;
}
.fewo-unit-sort {
  display: grid;
  gap: .25rem;
  min-width: 150px;
  margin: 0;
  font-size: .82rem;
  font-weight: 700;
  color: #525952;
}
.fewo-unit-sort select {
  min-height: 2.35rem;
  border: 1px solid rgba(31, 35, 32, .16);
  border-radius: 10px;
  padding: .45rem .65rem;
  background: #fff;
  font: inherit;
}
.fewo-unit-results {
  display: grid;
  gap: .65rem;
}
.fewo-unit-card {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) minmax(150px, .32fr);
  gap: .8rem;
  align-items: stretch;
  width: 100%;
  padding: .7rem;
  border: 1px solid rgba(31, 35, 32, .13);
  border-radius: 12px;
  background: #fff;
  color: inherit;
  text-align: left;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease, background .16s ease;
}
.fewo-unit-card:hover,
.fewo-unit-card.is-selected {
  border-color: rgba(105, 116, 97, .46);
  box-shadow: 0 10px 24px rgba(31, 35, 32, .1);
  transform: translateY(-1px);
}
.fewo-unit-card.is-selected {
  background: linear-gradient(135deg, #fff, #fbf7f1);
}
.fewo-unit-card__media {
  min-width: 0;
}
.fewo-unit-card img,
.fewo-unit-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 96px;
  border-radius: 10px;
  object-fit: cover;
  background: #e8e3dc;
}
.fewo-unit-card__main,
.fewo-unit-card__aside,
.fewo-unit-card__price {
  min-width: 0;
}
.fewo-unit-card__main {
  display: grid;
  align-content: start;
  gap: .38rem;
}
.fewo-unit-card__title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
}
.fewo-unit-card h4 {
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
}
.fewo-unit-card p {
  margin: 0;
  color: #6a7069;
  font-size: .9rem;
  line-height: 1.42;
}
.fewo-unit-card__badge,
.fewo-unit-card__amenities span,
.fewo-unit-card__facts li {
  display: inline-flex;
  align-items: center;
  min-height: 1.35rem;
  border-radius: 999px;
  padding: .18rem .45rem;
  font-size: .76rem;
  line-height: 1.1;
}
.fewo-unit-card__badge {
  flex: 0 0 auto;
  background: #eaf5ec;
  color: #23633a;
  font-weight: 800;
}
.fewo-unit-card__facts {
  display: flex;
  flex-wrap: wrap;
  gap: .28rem;
  margin: .1rem 0 0;
  padding: 0;
  list-style: none;
}
.fewo-unit-card__facts li {
  border: 1px solid rgba(31, 35, 32, .09);
  background: #f8f6f2;
  color: #4f5750;
}
.fewo-unit-card__amenities {
  display: flex;
  flex-wrap: wrap;
  gap: .28rem;
}
.fewo-unit-card__amenities span {
  background: #f1ebe4;
  color: #596158;
}
.fewo-unit-card__details {
  margin-top: .1rem;
}
.fewo-unit-card__details summary {
  width: max-content;
  cursor: pointer;
  color: #9a5637;
  font-size: .84rem;
  font-weight: 800;
}
.fewo-unit-card__details p {
  margin-top: .3rem;
}
.fewo-unit-card__price {
  display: grid;
  gap: .08rem;
  text-align: right;
}
.fewo-unit-card__price strong {
  color: var(--dark, #202624);
  font-size: 1.03rem;
  line-height: 1.2;
}
.fewo-unit-card__price span,
.fewo-unit-card__price small {
  color: #667066;
  font-size: .78rem;
  line-height: 1.3;
}
.fewo-unit-card__aside {
  display: grid;
  align-content: space-between;
  justify-items: end;
  gap: .55rem;
}
.fewo-unit-card__select {
  width: 100%;
  max-width: 180px;
  min-height: 2.35rem;
  border: 1px solid rgba(183, 109, 72, .42);
  border-radius: 999px;
  padding: .55rem .8rem;
  background: #fff;
  color: #9a5637;
  font: inherit;
  font-size: .86rem;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 5px 12px rgba(31, 35, 32, .07);
  transition: background .16s ease, color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.fewo-unit-card__select:hover,
.fewo-unit-card__select.is-selected {
  background: var(--dark, #202624);
  border-color: var(--dark, #202624);
  color: #fff;
  box-shadow: 0 9px 18px rgba(31, 35, 32, .14);
  transform: translateY(-1px);
}
.fewo-unit-status {
  margin: .55rem 0 0;
  color: #626a62;
  font-size: .88rem;
}
@media (max-width: 820px) {
  .fewo-unit-card {
    grid-template-columns: 86px minmax(0, 1fr);
  }
  .fewo-unit-card__aside {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .fewo-unit-card__price {
    text-align: left;
  }
}
@media (max-width: 560px) {
  .fewo-unit-picker {
    padding: .8rem;
  }
  .fewo-unit-picker__head {
    gap: .75rem;
  }
  .fewo-unit-sort {
    width: 100%;
  }
  .fewo-unit-card {
    grid-template-columns: 1fr;
  }
  .fewo-unit-card img,
  .fewo-unit-card__image-placeholder {
    height: 150px;
    min-height: 150px;
  }
  .fewo-unit-card__title-row,
  .fewo-unit-card__aside {
    align-items: flex-start;
    flex-direction: column;
  }
  .fewo-unit-card__select {
    max-width: none;
  }
}
.fewo-success-text {
  color: #1f6b38 !important;
  font-weight: 700;
}
.fewo-message {
  margin: .75rem 0;
  padding: .8rem 1rem;
  border-radius: 14px;
  display: none;
}
.fewo-message.fewo-error,
.fewo-message.fewo-success { display: block; }
.fewo-message.fewo-error,
.fewo-error { background: #fff0f0; color: #8f1d1d; }
.fewo-message.fewo-success,
.fewo-success { background: #effaf2; color: #1f6b38; }
.fewo-policy pre {
  white-space: pre-wrap;
  font-family: inherit;
  background: #f6f6f6;
  padding: .75rem;
  border-radius: 8px;
}

@media (max-width: 1080px) {
  .fewo-booking-widget { grid-template-columns: 1fr; }
  .fewo-calendar-card { max-width: 760px; }
}
@media (max-width: 720px) {
  .fewo-table,
  .fewo-table tbody,
  .fewo-table tr,
  .fewo-table td,
  .fewo-table th { display: block; }
  .fewo-table thead { display: none; }
}
@media (max-width: 640px) {
  .fewo-booking-form fieldset { grid-template-columns: 1fr; }
  .fewo-booking-widget .fewo-card { padding: 1rem; }
  .fewo-voucher__body { grid-template-columns: 1fr; }
  .fewo-voucher__body .fewo-button { width: 100%; text-align: center; }
  .fewo-calendar-controls { grid-template-columns: 2.2rem minmax(0, 1fr) 2.2rem; gap: .45rem; }
  .fewo-month-grid { gap: .3rem; }
  .fewo-day { border-radius: 10px; min-height: 2.25rem; font-size: .95rem; }
  .fewo-empty-day { min-height: 2.25rem; }
}

/* Booking UX refinement: compact 30-day calendar, visible date selection and transparent price details */
.fewo-period-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
  margin: 1.25rem 0 .55rem;
  padding: .9rem;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 18px;
  background: linear-gradient(135deg, #fff, var(--surface, #faf7f2));
}
.fewo-period-picker--hidden {
  display: none !important;
}
.fewo-period-picker label {
  display: grid;
  gap: .35rem;
}
.fewo-period-picker input[type="date"] {
  width: 100%;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 12px;
  padding: .75rem .85rem;
  font: inherit;
  background: #fff;
  color: var(--dark, #202624);
}
.fewo-period-picker input[type="date"]:focus {
  outline: 2px solid rgba(183,109,72,.25);
  border-color: var(--accent, #b76d48);
}
.fewo-selection-hint {
  margin: .35rem 0 1rem;
  color: var(--muted, #666);
  font-size: .95rem;
}
.fewo-error-text { color: #8f1d1d !important; font-weight: 700; }

.fewo-calendar-controls {
  margin-top: 1rem;
}
.fewo-calendar-controls button:disabled {
  opacity: .35;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}
.fewo-range-calendar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .55rem;
  width: 100%;
  max-width: 100%;
}
.fewo-day.fewo-range-day {
  aspect-ratio: auto;
  min-height: 4.35rem;
  padding: .45rem .25rem;
  display: grid;
  place-items: center;
  gap: .08rem;
  line-height: 1.05;
}
.fewo-day-weekday,
.fewo-day-month {
  display: block;
  font-size: .68rem;
  line-height: 1;
  color: var(--muted, #666);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.fewo-day strong {
  font-size: 1.18rem;
  line-height: 1;
}
.fewo-day.selected-start .fewo-day-weekday,
.fewo-day.selected-start .fewo-day-month,
.fewo-day.selected-end .fewo-day-weekday,
.fewo-day.selected-end .fewo-day-month {
  color: rgba(255,255,255,.78);
}
.fewo-day[aria-disabled="true"] {
  cursor: not-allowed;
}

.fewo-price {
  padding: 1.15rem;
  background: #fff;
  border: 1px solid rgba(183,109,72,.22);
  border-radius: 20px;
  box-shadow: 0 10px 30px rgba(32,32,32,.04);
}
.fewo-price-neutral {
  background: linear-gradient(135deg, #fffaf4, #fff);
}
.fewo-price-error {
  background: #fff7f4;
  border-color: rgba(143,29,29,.22);
}
.fewo-price-placeholder {
  margin: 0;
  color: var(--muted, #666);
}
.fewo-price-error .fewo-price-placeholder {
  color: #8f1d1d;
  font-weight: 700;
}
.fewo-price-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding-bottom: .8rem;
  margin-bottom: .85rem;
  border-bottom: 1px solid var(--line, #e5ddd4);
}
.fewo-price-head span {
  color: var(--muted, #666);
  font-size: .84rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.fewo-price-head strong {
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.6rem, 3vw, 2rem);
  line-height: 1;
  color: var(--dark, #202624);
}
.fewo-price-breakdown h3 {
  margin: 0 0 .55rem;
  font-size: .95rem;
  color: var(--dark, #202624);
}
.fewo-price-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(80px, .8fr) minmax(86px, auto);
  gap: .65rem;
  align-items: baseline;
  padding: .45rem 0;
  border-bottom: 1px solid rgba(229,221,212,.72);
  font-size: .95rem;
}
.fewo-price-row span:nth-child(2) {
  color: var(--muted, #666);
  font-size: .88rem;
}
.fewo-price-row strong {
  text-align: right;
  color: var(--dark, #202624);
}
.fewo-price-subtotal,
.fewo-price-total {
  font-weight: 800;
}
.fewo-price-total {
  border-top: 2px solid var(--line, #e5ddd4);
  margin-top: .35rem;
}
.fewo-price-note {
  margin: .75rem 0 0;
  color: var(--muted, #666);
  font-size: .85rem;
}

@media (max-width: 1080px) {
  .fewo-range-calendar { grid-template-columns: repeat(6, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .fewo-period-picker { grid-template-columns: 1fr; }
  .fewo-range-calendar { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .4rem; }
  .fewo-day.fewo-range-day { min-height: 3.85rem; border-radius: 11px; }
  .fewo-day strong { font-size: 1.02rem; }
  .fewo-day-weekday,
  .fewo-day-month { font-size: .6rem; }
  .fewo-price-row {
    grid-template-columns: 1fr auto;
    gap: .25rem .6rem;
  }
  .fewo-price-row span:nth-child(2) { grid-column: 1 / 2; }
  .fewo-price-row strong { grid-column: 2 / 3; grid-row: 1 / span 2; }
}
@media (max-width: 420px) {
  .fewo-range-calendar { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}


/* Booking usability refinements: compact date fields, smaller total and invalid-field feedback */
.fewo-period-picker {
  align-items: end;
  gap: .55rem;
  margin: .85rem 0 .45rem;
  padding: .55rem .65rem;
  border-radius: 14px;
}
.fewo-period-picker .fewo-field-label {
  font-size: .78rem;
  line-height: 1.2;
}
.fewo-period-picker input[type="date"] {
  min-height: 2.35rem;
  padding: .42rem .55rem;
  border-radius: 9px;
  font-size: .9rem;
}
.fewo-selection-hint {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  min-height: 2.1rem;
  margin: 0 0 .8rem;
  padding: .42rem .72rem;
  border: 1px solid rgba(183, 109, 72, .22);
  border-radius: 999px;
  background: rgba(183, 109, 72, .08);
  color: #9a5637;
  font-size: .88rem;
  font-weight: 750;
  line-height: 1.3;
}
.fewo-price {
  padding: .95rem;
}
.fewo-price-head {
  padding-bottom: .55rem;
  margin-bottom: .65rem;
}
.fewo-price-head span {
  font-size: .72rem;
  letter-spacing: .1em;
}
.fewo-price-head strong {
  font-family: inherit;
  font-size: clamp(1.12rem, 2vw, 1.38rem);
  font-weight: 900;
  letter-spacing: -.02em;
}
.fewo-price-breakdown h3 {
  font-size: .88rem;
}
.fewo-invalid-control,
.fewo-field-invalid input,
.fewo-field-invalid textarea,
.fewo-field-invalid select {
  border-color: #b42318 !important;
  box-shadow: 0 0 0 3px rgba(180, 35, 24, .12) !important;
}
.fewo-field-invalid .fewo-field-label,
.fewo-field-invalid a {
  color: #8f1d1d !important;
}
.fewo-checkbox.fewo-field-invalid,
.fewo-radio.fewo-field-invalid {
  color: #8f1d1d;
}
@keyframes fewo-invalid-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(180, 35, 24, 0); }
  35% { box-shadow: 0 0 0 6px rgba(180, 35, 24, .14); }
  70% { box-shadow: 0 0 0 2px rgba(180, 35, 24, .08); }
}
.fewo-pulse {
  animation: fewo-invalid-pulse 1.05s ease-out;
}
@media (max-width: 720px) {
  .fewo-period-picker {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .45rem;
    padding: .5rem;
  }
  .fewo-period-picker input[type="date"] {
    min-height: 2.15rem;
    padding: .34rem .45rem;
    font-size: .84rem;
  }
  .fewo-period-picker .fewo-field-label {
    font-size: .72rem;
  }
  .fewo-selection-hint {
    width: 100%;
    border-radius: 12px;
    white-space: normal;
  }
  .fewo-price-head strong {
    font-size: 1.1rem;
  }
}
@media (max-width: 390px) {
  .fewo-period-picker {
    grid-template-columns: 1fr;
  }
}

/* Standard month calendar layout: familiar 7-column calendar instead of rolling 30-day tiles */
.fewo-calendar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  align-items: start;
}
.fewo-month {
  min-width: 0;
}
.fewo-month h3 {
  margin: 0 0 .6rem;
  font-family: inherit;
  font-size: .95rem;
  font-weight: 850;
  color: var(--dark, #202624);
}
.fewo-month-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .24rem;
}
.fewo-weekday {
  display: block;
  padding: .1rem 0 .22rem;
  font-size: .64rem;
  color: var(--muted, #666);
  text-align: center;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.fewo-empty-day {
  min-height: 2.05rem;
}
.fewo-day {
  min-height: 2.05rem;
  aspect-ratio: 1 / .82;
  padding: .1rem;
  border-radius: 9px;
  font-size: .86rem;
  display: grid;
  place-items: center;
}
.fewo-day strong {
  font-size: .92rem;
  line-height: 1;
}
.fewo-day.past {
  color: #b4aca3;
  background: #f2eee9;
  cursor: not-allowed;
  opacity: .72;
}
.fewo-day.occupied,
.fewo-day.blocked,
.fewo-day.hold {
  color: #958b82;
  background: #eee9e2;
  cursor: not-allowed;
  text-decoration: none;
  opacity: .75;
}
.fewo-day.occupied strong,
.fewo-day.blocked strong,
.fewo-day.hold strong {
  text-decoration: line-through;
}
.fewo-calendar-controls {
  margin: .9rem 0 .9rem;
  grid-template-columns: 2.1rem minmax(0, 1fr) 2.1rem;
  padding: .28rem;
}
.fewo-calendar-controls button {
  width: 2.1rem;
  height: 2.1rem;
}
.fewo-calendar-controls strong {
  font-size: .98rem;
}
.fewo-price-head strong {
  font-size: clamp(1rem, 1.7vw, 1.18rem);
}

@media (max-width: 760px) {
  .fewo-calendar {
    grid-template-columns: 1fr;
  }
  .fewo-month-grid {
    gap: .2rem;
  }
  .fewo-day {
    min-height: 1.95rem;
    border-radius: 8px;
    font-size: .78rem;
  }
  .fewo-day strong {
    font-size: .86rem;
  }
  .fewo-empty-day {
    min-height: 1.95rem;
  }
  .fewo-weekday {
    font-size: .58rem;
  }
}

/* Booking confirmation refinement: replaces the raw management URL with a structured confirmation card. */
.fewo-message.fewo-success.fewo-confirmation-message {
  display: block;
  padding: 0;
  background: transparent;
  color: inherit;
}
.fewo-confirmation {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: clamp(1rem, 2vw, 1.35rem);
  padding: clamp(1.15rem, 2.4vw, 1.75rem);
  border: 1px solid rgba(47, 111, 68, .18);
  border-radius: 22px;
  background: linear-gradient(135deg, #effaf2, #ffffff);
  box-shadow: 0 16px 42px rgba(32, 32, 32, .08);
}
.fewo-confirmation-icon {
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #dff1e5;
  color: #2f6f44;
  font-size: 1.75rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: inset 0 0 0 1px rgba(47, 111, 68, .12);
}
.fewo-confirmation-body h3 {
  margin: .15rem 0 .45rem;
  color: #2f6f44;
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  line-height: 1.15;
}
.fewo-confirmation-body p {
  margin: 0 0 .9rem;
  color: #405148;
}
.fewo-confirmation-eyebrow {
  margin: 0 0 .25rem !important;
  color: #2f6f44 !important;
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-confirmation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem .75rem;
  margin: 1rem 0;
}
.fewo-confirmation-row {
  min-width: 0;
  padding: .75rem .85rem;
  border: 1px solid rgba(47, 111, 68, .12);
  border-radius: 14px;
  background: rgba(255,255,255,.72);
}
.fewo-confirmation-row dt {
  margin: 0 0 .2rem;
  color: #65766b;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.fewo-confirmation-row dd {
  margin: 0;
  color: var(--dark, #202624);
  font-weight: 850;
  line-height: 1.3;
  word-break: break-word;
}
.fewo-confirmation-note {
  padding: .85rem 1rem;
  border-radius: 14px;
  background: #fff7e9;
  border: 1px solid rgba(183,109,72,.18);
  color: #6d4a2d !important;
}
.fewo-confirmation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin: 1rem 0 .85rem;
}
.fewo-confirmation-primary,
.fewo-confirmation-secondary {
  min-height: 3rem;
  border-radius: 999px;
  padding: .85rem 1.15rem;
}
.fewo-confirmation-secondary {
  border: 1px solid rgba(47, 111, 68, .28);
  background: #fff;
  color: #2f6f44;
}
.fewo-confirmation-secondary:hover {
  background: #f6fbf7;
}
.fewo-confirmation-secondary.fewo-copy-done {
  background: #2f6f44;
  color: #fff;
}
.fewo-confirmation-hint {
  margin-bottom: 0 !important;
  color: #65766b !important;
  font-size: .95rem;
}
@media (max-width: 640px) {
  .fewo-confirmation {
    grid-template-columns: 1fr;
  }
  .fewo-confirmation-grid {
    grid-template-columns: 1fr;
  }
  .fewo-confirmation-actions .fewo-button {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

/* Aufenthaltsrabatte und finale Buchungsbestätigung */
.fewo-price-discount {
  color: #2f6f44;
  background: rgba(47, 111, 68, .055);
  border-radius: 10px;
  padding-left: .55rem;
  padding-right: .55rem;
}
.fewo-price-discount strong {
  color: #2f6f44;
}
.fewo-booking-completion[hidden] {
  display: none !important;
}
.fewo-booking-complete {
  grid-template-columns: minmax(0, 1fr);
}
.fewo-booking-complete .fewo-booking-completion {
  display: block;
  width: 100%;
}
.fewo-booking-complete .fewo-confirmation {
  max-width: 980px;
  margin: 0 auto;
}
.fewo-booking-complete .fewo-message {
  display: none !important;
}
.fewo-settings-heading {
  padding: .75rem 0 .15rem;
  border-top: 1px solid rgba(0,0,0,.08);
}
.fewo-settings-heading:first-child {
  border-top: 0;
  padding-top: 0;
}
.fewo-settings-heading h3 {
  margin: 0 0 .25rem;
  font-size: 1rem;
}

/* Admin usability + security polish */
body:has(.fewo-page) {
  margin: 0;
  background: linear-gradient(180deg, #fbf7f0 0%, #f7f1e8 100%);
  color: var(--dark, #202624);
}
.fewo-page {
  max-width: 1240px;
  padding: clamp(1rem, 2.4vw, 2.4rem);
}
.fewo-page > h1 {
  margin: 0 0 1rem;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 1;
}
.fewo-admin-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
  padding: clamp(1.2rem, 2.6vw, 2rem);
  border: 1px solid rgba(183,109,72,.16);
  border-radius: 26px;
  background:
    radial-gradient(circle at 100% 0%, rgba(183,109,72,.16), transparent 32%),
    linear-gradient(135deg, #fff, #fff8f1);
  box-shadow: 0 18px 46px rgba(32,32,32,.075);
}
.fewo-admin-hero h2 {
  margin: .15rem 0 .5rem;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.7rem, 3vw, 2.55rem);
  line-height: 1.08;
}
.fewo-admin-hero p {
  max-width: 720px;
  margin: 0;
  color: #5f625e;
  line-height: 1.6;
}
.fewo-admin-eyebrow {
  margin: 0 0 .35rem !important;
  color: var(--accent, #b76d48) !important;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.fewo-admin-hero-actions,
.fewo-admin-section-head {
  display: flex;
  gap: .75rem;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.fewo-admin-section-head {
  margin-bottom: 1rem;
}
.fewo-admin-section-head h2 {
  margin: .1rem 0 .35rem;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.45rem, 2.4vw, 2rem);
}
.fewo-admin-section-head p {
  margin: 0;
  max-width: 780px;
  line-height: 1.55;
}
.fewo-admin-nav {
  position: sticky;
  top: .5rem;
  z-index: 5;
  margin: 1rem 0;
  padding: .45rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 30px rgba(32,32,32,.07);
  backdrop-filter: blur(10px);
}
.fewo-admin-nav a {
  border: 0;
  background: transparent;
  color: var(--dark, #202624);
  font-weight: 800;
}
.fewo-admin-nav a:hover {
  background: #f6eee7;
}
.fewo-admin-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
  margin: 1rem 0;
}
.fewo-stat-card,
.fewo-admin-next {
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 20px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 12px 30px rgba(32,32,32,.055);
}
.fewo-stat-card {
  padding: 1rem;
}
.fewo-stat-card span,
.fewo-admin-next span {
  display: block;
  color: #73766f;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-stat-card strong {
  display: block;
  margin: .25rem 0 .2rem;
  font-size: 2rem;
  line-height: 1;
}
.fewo-stat-card p,
.fewo-admin-next p {
  margin: 0;
  color: #656861;
  font-size: .9rem;
}
.fewo-admin-next {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.fewo-admin-next strong {
  display: block;
  margin: .25rem 0;
  font-size: 1.45rem;
}
.fewo-admin-card {
  padding: clamp(1rem, 2vw, 1.35rem);
  border-radius: 24px;
  border-color: rgba(32,32,32,.08);
  box-shadow: 0 14px 38px rgba(32,32,32,.06);
}
.fewo-table-scroll {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.fewo-table {
  border-collapse: separate;
  border-spacing: 0;
}
.fewo-table th {
  color: #696c66;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: #faf7f2;
}
.fewo-table th,
.fewo-table td {
  border-bottom-color: rgba(32,32,32,.08);
}
.fewo-table tbody tr:hover:not(.fewo-details-row) {
  background: rgba(183,109,72,.035);
}
.fewo-details-row td {
  background: #fffdf9;
}
.fewo-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.65rem;
  padding: .2rem .55rem;
  border-radius: 999px;
  font-size: .76rem;
  font-weight: 900;
  line-height: 1;
  background: #eee9e2;
  color: #4d514b;
}
.fewo-badge-confirmed,
.fewo-badge-paid {
  background: #e4f4e8;
  color: #1f6b38;
}
.fewo-badge-draft,
.fewo-badge-awaiting_bank_transfer,
.fewo-badge-cash_on_arrival,
.fewo-badge-unpaid {
  background: #fff3d8;
  color: #7a4d10;
}
.fewo-badge-cancelled,
.fewo-badge-expired,
.fewo-badge-paypal_error {
  background: #fff0f0;
  color: #8f1d1d;
}
.fewo-actions {
  min-width: 260px;
}
.fewo-actions form {
  padding: .55rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 14px;
  background: #fff;
}
.fewo-actions select,
.fewo-actions input,
.fewo-grid-form input,
.fewo-grid-form select,
.fewo-grid-form textarea {
  border-color: rgba(32,32,32,.16);
  background: #fff;
}
.fewo-button-secondary {
  border: 1px solid rgba(32,32,32,.14);
  background: #fff;
  color: var(--dark, #202624);
}
.fewo-button-secondary:hover {
  background: #faf7f2;
}
.fewo-empty-state,
.fewo-warning-box,
.fewo-admin-security-note {
  padding: 1rem;
  border-radius: 16px;
  border: 1px solid rgba(32,32,32,.08);
  background: #fffaf4;
  color: #5f625e;
}
.fewo-warning-box {
  margin-bottom: 1rem;
  border-color: rgba(180,35,24,.16);
  background: #fff5f2;
  color: #71301f;
}
.fewo-warning-box p {
  margin: .35rem 0 0;
}
.fewo-admin-security-note {
  margin-top: 1rem;
  font-size: .92rem;
}
.fewo-admin-form {
  align-items: start;
  margin-bottom: 1.1rem;
  padding: 1rem;
  border: 1px solid rgba(32,32,32,.07);
  border-radius: 18px;
  background: #fffdf9;
}
.fewo-admin-form label {
  display: grid;
  gap: .35rem;
  color: #4f544e;
  font-weight: 800;
}
.fewo-admin-details summary {
  cursor: pointer;
  font-weight: 900;
  color: var(--accent, #b76d48);
}
.fewo-admin-detail-grid,
.fewo-admin-log-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin-top: .85rem;
}
.fewo-admin-log-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.fewo-admin-detail-grid p,
.fewo-admin-log-grid > div {
  margin: 0;
  padding: .8rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(32,32,32,.07);
}
.fewo-admin-log-grid ul {
  margin: .45rem 0 0;
  padding-left: 1.1rem;
  color: #5f625e;
  font-size: .86rem;
}
.fewo-ical-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
}
.fewo-ical-grid article {
  display: grid;
  gap: .45rem;
  padding: 1rem;
  border-radius: 16px;
  border: 1px solid rgba(32,32,32,.08);
  background: #fff;
}
.fewo-ical-grid code {
  display: block;
  white-space: normal;
  word-break: break-all;
}
.fewo-policy-copy {
  margin: 0 .85rem .85rem;
  max-height: 280px;
  overflow: auto;
  color: var(--muted, #666);
  font-size: .94rem;
  line-height: 1.55;
}
.fewo-policy-copy p {
  margin: 0 0 .7rem;
}
.fewo-policy-copy a {
  color: var(--accent, #b76d48);
  font-weight: 800;
}
@media (max-width: 980px) {
  .fewo-admin-hero,
  .fewo-admin-stats,
  .fewo-ical-grid,
  .fewo-admin-detail-grid,
  .fewo-admin-log-grid {
    grid-template-columns: 1fr;
  }
  .fewo-admin-hero-actions {
    justify-content: flex-start;
  }
}
@media (max-width: 720px) {
  .fewo-admin-nav {
    border-radius: 20px;
  }
  .fewo-admin-nav a {
    flex: 1 1 auto;
    text-align: center;
  }
  .fewo-table-scroll .fewo-table,
  .fewo-table-scroll .fewo-table tbody,
  .fewo-table-scroll .fewo-table tr,
  .fewo-table-scroll .fewo-table td,
  .fewo-table-scroll .fewo-table th {
    display: revert;
  }
}

/* Customer booking management refresh */
.fewo-page {
  padding: clamp(1rem, 3vw, 2rem);
}
.fewo-page > h1 {
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
  margin: 0 0 1rem;
}
.fewo-manage-page {
  display: grid;
  gap: 1rem;
}
.fewo-manage-hero {
  background: linear-gradient(135deg, rgba(249,245,239,.98), rgba(255,255,255,.98));
  border: 1px solid var(--line, #e5ddd4);
}
.fewo-manage-hero__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.fewo-eyebrow {
  margin: 0 0 .45rem;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-size: .78rem;
  font-weight: 800;
  color: var(--accent, #b76d48);
}
.fewo-lead {
  font-size: 1.02rem;
  line-height: 1.7;
  color: #555;
  margin: 0;
  max-width: 70ch;
}
.fewo-status-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: flex-end;
}
.fewo-status-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .55rem .85rem;
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 700;
  background: #f2efe9;
  color: #5d554c;
  border: 1px solid #e4ddd4;
}
.fewo-status-badge--confirmed { background: #edf8ef; color: #20663b; border-color: #cde8d4; }
.fewo-status-badge--draft { background: #fff7e7; color: #8a5a00; border-color: #efd69b; }
.fewo-status-badge--cancelled { background: #fff0f0; color: #8f1d1d; border-color: #efc7c7; }
.fewo-status-badge--payment { background: #f7f3ee; color: #6a5c4c; }
.fewo-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: .85rem;
  margin-top: 1.25rem;
}
.fewo-summary-item {
  background: rgba(255,255,255,.88);
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 18px;
  padding: .9rem 1rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}
.fewo-summary-item__label {
  display: block;
  color: #7a746b;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .28rem;
}
.fewo-summary-item strong {
  font-size: 1.05rem;
  color: #23201c;
}
.fewo-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.15rem;
}
.fewo-button-secondary {
  background: #fff;
  color: var(--accent, #b76d48);
  border: 1px solid var(--accent, #b76d48);
}
.fewo-button-secondary:hover {
  background: #fff8f4;
}
.fewo-card-accent {
  border: 1px solid #ead8cd;
  background: linear-gradient(180deg, #fffdfa, #fff);
}
.fewo-price-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .7rem;
}
.fewo-price-list li {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
  padding: .8rem 0;
  border-bottom: 1px solid #eee6de;
}
.fewo-price-list li:last-child { border-bottom: 0; }
.fewo-price-list strong {
  white-space: nowrap;
  color: #23201c;
}
.fewo-info-list {
  display: grid;
  gap: .75rem;
  margin: 1rem 0;
}
.fewo-info-list > div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  padding: .8rem 1rem;
  border-radius: 14px;
  border: 1px solid #eee4db;
  background: #fff;
}
.fewo-info-list strong + span,
.fewo-info-list > div span {
  white-space: nowrap;
  font-weight: 700;
  color: #23201c;
}
.fewo-stack {
  display: grid;
  gap: .85rem;
}
.fewo-stack textarea {
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 700px) {
  .fewo-manage-hero__head {
    flex-direction: column;
  }
  .fewo-status-wrap {
    justify-content: flex-start;
  }
  .fewo-price-list li,
  .fewo-info-list > div {
    flex-direction: column;
  }
}

/* PayPal checkout state: once PayPal payment options are shown, hide the original booking submit button to avoid duplicate/confusing actions. */
.fewo-paypal-checkout-active button[type="submit"],
.fewo-booking-widget [hidden] {
  display: none !important;
}


/* Final mobile/usability hardening for booking widget */
.fewo-booking-widget,
.fewo-booking-widget * {
  box-sizing: border-box;
}
.fewo-booking-widget,
.fewo-booking-widget .fewo-card,
.fewo-booking-form,
.fewo-calendar-card,
.fewo-price,
.fewo-paypal,
.fewo-booking-completion,
.fewo-confirmation,
.fewo-manage-page {
  min-width: 0;
  max-width: 100%;
}
.fewo-booking-widget input,
.fewo-booking-widget select,
.fewo-booking-widget textarea,
.fewo-booking-widget button,
.fewo-booking-widget .fewo-button {
  max-width: 100%;
}
.fewo-paypal {
  width: 100%;
  overflow: hidden;
}
.fewo-paypal iframe,
.fewo-paypal .paypal-buttons,
.fewo-paypal [id^="paypal"] {
  max-width: 100% !important;
}
.fewo-paypal-checkout-active [data-fewo-submit],
.fewo-booking-widget [hidden] {
  display: none !important;
}
@media (max-width: 760px) {
  .fewo-booking-widget {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 1rem;
  }
  .fewo-booking-widget .fewo-card {
    border-radius: 18px;
    padding: .95rem;
  }
  .fewo-booking-form fieldset {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: .75rem;
  }
  .fewo-confirmation-list,
  .fewo-booking-form label,
  .fewo-checkbox,
  .fewo-radio {
    min-width: 0;
  }
  .fewo-checkbox--compact {
    align-items: flex-start;
    line-height: 1.45;
  }
  .fewo-price-head,
  .fewo-price-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .fewo-price-row span,
  .fewo-price-head span {
    min-width: 0;
  }
  .fewo-price-row strong,
  .fewo-price-head strong {
    white-space: nowrap;
  }
  .fewo-booking-widget .fewo-button,
  .fewo-confirmation-actions .fewo-button {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .fewo-confirmation-actions,
  .fewo-action-row {
    gap: .6rem;
  }
}
@media (max-width: 390px) {
  .fewo-price-head,
  .fewo-price-row {
    grid-template-columns: minmax(0, 1fr);
  }
  .fewo-price-row strong,
  .fewo-price-head strong {
    text-align: left;
    white-space: normal;
  }
  .fewo-calendar-controls strong {
    font-size: .88rem;
  }
}

/* Final mobile usability hardening: prevent overlaps and horizontal overflow in the booking flow */
.fewo-booking-widget,
.fewo-booking-widget *,
.fewo-page,
.fewo-page * {
  box-sizing: border-box;
}
.fewo-booking-widget,
.fewo-booking-widget .fewo-card,
.fewo-booking-form,
.fewo-calendar-card,
.fewo-paypal {
  min-width: 0;
}
.fewo-paypal {
  width: 100%;
  overflow: hidden;
}
.fewo-paypal iframe,
.fewo-paypal .paypal-buttons,
.fewo-paypal div[role="button"] {
  max-width: 100% !important;
}
@media (max-width: 760px) {
  .fewo-booking-widget {
    gap: 1rem;
  }
  .fewo-booking-form fieldset {
    grid-template-columns: 1fr;
  }
  .fewo-price,
  .fewo-message,
  .fewo-confirmation,
  .fewo-card {
    overflow-wrap: anywhere;
  }
  .fewo-price-head {
    gap: .75rem;
  }
  .fewo-price-row {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .35rem .75rem;
    align-items: start;
  }
  .fewo-price-row span:nth-child(2) {
    min-width: 0;
  }
  .fewo-price-row strong {
    text-align: right;
    white-space: nowrap;
  }
  .fewo-confirmation-actions,
  .fewo-action-row {
    flex-direction: column;
    align-items: stretch;
  }
  .fewo-confirmation-actions .fewo-button,
  .fewo-action-row .fewo-button,
  .fewo-booking-form > .fewo-button {
    width: 100%;
  }
  .fewo-confirmation-list {
    gap: .75rem;
  }
  .fewo-checkbox--compact {
    align-items: flex-start;
  }
  .fewo-calendar,
  .fewo-range-calendar,
  .fewo-month,
  .fewo-month-grid {
    min-width: 0;
  }
}
@media (max-width: 430px) {
  .fewo-booking-widget .fewo-card,
  .fewo-page .fewo-card {
    border-radius: 18px;
    padding: .9rem;
  }
  .fewo-price-head {
    grid-template-columns: 1fr;
  }
  .fewo-price-head strong {
    text-align: left;
  }
  .fewo-price-row {
    grid-template-columns: 1fr;
  }
  .fewo-price-row strong {
    text-align: left;
  }
  .fewo-calendar-controls {
    grid-template-columns: 2.15rem minmax(0, 1fr) 2.15rem;
  }
}

/* Payment schedule / deposit workflow */
.fewo-price-schedule {
  margin-top: .85rem;
  padding-top: .85rem;
  border-top: 2px solid var(--line, #e5ddd4);
}
.fewo-price-schedule h3 {
  margin: 0 0 .55rem;
  font-size: 1rem;
}
.fewo-payment-schedule-row span:nth-child(2) {
  color: var(--muted, #6f756f);
  font-size: .92rem;
}
.fewo-admin-payment-plan {
  grid-column: 1 / -1;
  padding: 1rem;
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fffdfa;
}
.fewo-admin-payment-plan ul {
  margin: .6rem 0;
  padding-left: 1.1rem;
}
@media (max-width: 680px) {
  .fewo-payment-schedule-row span:nth-child(2) {
    grid-column: 1 / -1;
  }
}

/* Bank details in customer booking management and reminder controls */
.fewo-bank-card {
  border-color: #d9e7d9;
  background: linear-gradient(180deg, #f7fcf8, #fff);
}
.fewo-transfer-list small {
  color: var(--muted, #6f756f);
  font-size: .86rem;
}
.fewo-bank-details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: .75rem;
  margin-top: 1rem;
}
.fewo-bank-details > div {
  padding: .85rem 1rem;
  border: 1px solid #dcebdd;
  border-radius: 16px;
  background: #fff;
  min-width: 0;
}
.fewo-bank-details span {
  display: block;
  margin-bottom: .25rem;
  color: #6f756f;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 800;
}
.fewo-bank-details strong {
  display: block;
  color: #202624;
  font-size: .98rem;
  overflow-wrap: anywhere;
}
.fewo-inline-form {
  display: inline-flex;
  margin: 0;
}
.fewo-inline-form .fewo-button {
  margin: 0;
}
@media (max-width: 760px) {
  .fewo-bank-details {
    grid-template-columns: 1fr;
  }
  .fewo-inline-form,
  .fewo-inline-form .fewo-button {
    width: 100%;
  }
}


/* Admin: definitive booking deletion for test data */
.fewo-danger-zone {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid #f0c7c7;
  border-radius: 16px;
  background: #fff7f7;
}
.fewo-danger-zone h4 {
  margin: 0 0 .45rem;
  color: #8f1d1d;
}
.fewo-danger-zone p {
  margin: 0 0 .85rem;
  color: #6f3a3a;
  line-height: 1.55;
}
.fewo-danger-zone form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: .75rem;
  align-items: end;
}
.fewo-danger-zone input {
  width: 100%;
  box-sizing: border-box;
  padding: .55rem;
  border: 1px solid #d2a5a5;
  border-radius: 8px;
  background: #fff;
}

/* Payment due visibility in admin and customer booking management */
.fewo-table-bookings td.fewo-admin-payment-cell {
  min-width: 360px;
  width: 34%;
}
.fewo-table-bookings td.fewo-admin-amount-cell {
  min-width: 180px;
}
.fewo-admin-payment-overview {
  display: grid;
  gap: .65rem;
}
.fewo-admin-payment-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}
.fewo-admin-payment-head > div {
  display: flex;
  gap: .45rem;
  align-items: center;
  flex-wrap: wrap;
}
.fewo-admin-payment-head > strong {
  color: #202624;
  font-size: .95rem;
}
.fewo-payment-method-mini {
  color: #6f756f;
  font-size: .84rem;
  font-weight: 800;
}
.fewo-payment-steps {
  display: grid;
  gap: .65rem;
  margin-top: .75rem;
}
.fewo-payment-steps--compact {
  margin-top: 0;
  gap: .45rem;
}
.fewo-payment-step {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
  padding: .72rem .8rem;
  border-radius: 16px;
  border: 1px solid #e7e0d8;
  background: #fff;
  box-shadow: inset 4px 0 0 #d9d2ca;
}
.fewo-payment-steps--compact .fewo-payment-step {
  padding: .55rem .65rem;
  border-radius: 14px;
}
.fewo-payment-step__main,
.fewo-payment-step__amounts {
  min-width: 0;
  display: grid;
  gap: .18rem;
}
.fewo-payment-step__main strong {
  color: #202624;
  font-size: .96rem;
  line-height: 1.25;
}
.fewo-payment-step__main small,
.fewo-payment-step__amounts small {
  color: #6f756f;
  font-size: .82rem;
  line-height: 1.35;
}
.fewo-payment-step__amounts {
  text-align: right;
  white-space: nowrap;
}
.fewo-payment-step__amounts strong {
  color: #202624;
  font-size: .98rem;
}
.fewo-payment-step__status {
  width: fit-content;
  display: inline-flex;
  padding: .18rem .5rem;
  border-radius: 999px;
  font-size: .68rem;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 900;
  background: #eee9e2;
  color: #5f625e;
}
.fewo-payment-step--paid {
  border-color: #cfe9d3;
  background: #f5fbf6;
  box-shadow: inset 4px 0 0 #3b8a52;
}
.fewo-payment-step--paid .fewo-payment-step__status {
  background: #dff2e4;
  color: #1f6b38;
}
.fewo-payment-step--due,
.fewo-payment-step--soon {
  border-color: #f0d79d;
  background: #fffaf0;
  box-shadow: inset 4px 0 0 #d39b23;
}
.fewo-payment-step--due .fewo-payment-step__status,
.fewo-payment-step--soon .fewo-payment-step__status {
  background: #ffe8b0;
  color: #7a4d10;
}
.fewo-payment-step--overdue {
  border-color: #f1b6b6;
  background: #fff5f5;
  box-shadow: inset 4px 0 0 #b42318;
}
.fewo-payment-step--overdue .fewo-payment-step__status {
  background: #ffe0e0;
  color: #8f1d1d;
}
.fewo-payment-step--upcoming {
  border-color: #e5ddd4;
  background: #fffdf9;
  box-shadow: inset 4px 0 0 #b7aa9c;
}
.fewo-payment-step--cash {
  border-color: #d8e3ec;
  background: #f6fbff;
  box-shadow: inset 4px 0 0 #6d8aa0;
}
.fewo-payment-step--cash .fewo-payment-step__status {
  background: #e2edf5;
  color: #34566e;
}
.fewo-payment-step--cancelled {
  opacity: .7;
  background: #f7f4f0;
  box-shadow: inset 4px 0 0 #9c9186;
}
.fewo-admin-payment-summary {
  margin: .75rem 0 0;
  color: #5f625e;
  font-weight: 800;
}
.fewo-admin-amount-overview {
  display: grid;
  gap: .28rem;
  align-content: start;
}
.fewo-admin-amount-overview > strong {
  font-size: 1.12rem;
  color: #202624;
}
.fewo-admin-amount-overview > span {
  color: #4f544e;
  font-size: .88rem;
}
.fewo-admin-pay-chip {
  width: fit-content;
  display: inline-flex;
  padding: .22rem .55rem;
  border-radius: 999px;
  border: 1px solid #e5ddd4;
  background: #fffdf9;
  color: #5f625e !important;
  font-weight: 800;
}
.fewo-admin-pay-chip--bank {
  border-color: #f0d79d;
  background: #fff8e6;
  color: #7a4d10 !important;
}
.fewo-admin-pay-chip--cash {
  border-color: #d8e3ec;
  background: #f6fbff;
  color: #34566e !important;
}
.fewo-customer-payment-card {
  overflow: hidden;
}
.fewo-customer-payment-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin: 1rem 0;
}
.fewo-customer-payment-summary > div {
  padding: .9rem 1rem;
  border-radius: 16px;
  border: 1px solid #eee4db;
  background: #fff;
}
.fewo-customer-payment-summary span {
  display: block;
  margin-bottom: .25rem;
  color: #6f756f;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.fewo-customer-payment-summary strong {
  color: #202624;
  font-size: 1.08rem;
}
.fewo-payment-steps--customer .fewo-payment-step {
  padding: .95rem 1rem;
}
.fewo-payment-history-list {
  margin-top: .5rem;
}
@media (max-width: 980px) {
  .fewo-table-bookings td.fewo-admin-payment-cell {
    min-width: 320px;
  }
}
@media (max-width: 760px) {
  .fewo-payment-step,
  .fewo-payment-steps--customer .fewo-payment-step {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .fewo-payment-step__amounts {
    text-align: left;
    white-space: normal;
  }
  .fewo-customer-payment-summary {
    grid-template-columns: 1fr;
  }
}

/* Payment policy note */
.fewo-payment-policy-note {
  margin: .75rem 0 1rem;
  padding: .85rem 1rem;
  border-radius: 14px;
  background: #fff7e7;
  border: 1px solid #efd69b;
  color: #7a5200;
  font-weight: 650;
  line-height: 1.55;
}

/* Admin booking overview layout refresh */
.fewo-booking-list {
  display: grid;
  gap: .7rem;
}
.fewo-booking-card {
  border: 1px solid #eadfd4;
  border-radius: 18px;
  background: #fff;
  padding: 0;
  overflow: hidden;
  box-shadow: 0 14px 35px rgba(27, 32, 30, .04);
}
.fewo-booking-row__summary {
  list-style: none;
  display: grid;
  grid-template-columns: minmax(150px, 1.05fr) minmax(170px, 1.2fr) minmax(160px, 1fr) minmax(210px, 1.35fr) minmax(140px, .8fr) auto;
  gap: .75rem;
  align-items: center;
  padding: .9rem 1rem;
  cursor: pointer;
}
.fewo-booking-row__summary::-webkit-details-marker {
  display: none;
}
.fewo-booking-row__summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid #e4d7ca;
  border-radius: 50%;
  background: #fffaf6;
  color: #7a6048;
  font-weight: 900;
}
.fewo-booking-card[open] .fewo-booking-row__summary {
  border-bottom: 1px solid #efe6dd;
  background: #fffdf9;
}
.fewo-booking-card[open] .fewo-booking-row__summary::after {
  content: "-";
}
.fewo-booking-row__cell {
  min-width: 0;
  display: grid;
  gap: .18rem;
}
.fewo-booking-row__cell strong,
.fewo-booking-row__cell small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fewo-booking-row__cell strong {
  color: #202624;
  white-space: nowrap;
}
.fewo-booking-row__cell small {
  color: #666;
  white-space: nowrap;
  line-height: 1.35;
}
.fewo-booking-row__cell--amount {
  text-align: right;
}
.fewo-booking-row__cell--amount .fewo-booking-card__label {
  justify-self: end;
}
.fewo-booking-row__cell--amount small {
  color: #4f5f56;
  font-weight: 750;
}
.fewo-booking-card__body {
  display: grid;
  gap: .9rem;
  padding: 1rem 1.1rem 1.1rem;
}
.fewo-booking-card__grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.05fr) minmax(420px, 1.45fr) minmax(240px, .8fr);
  gap: 1rem;
  align-items: start;
}
.fewo-booking-card__meta,
.fewo-booking-card__payment,
.fewo-booking-card__actions {
  min-width: 0;
}
.fewo-booking-card__meta {
  display: grid;
  gap: .8rem;
  align-content: start;
}
.fewo-booking-card__block {
  border: 1px solid #efe6dd;
  background: #fffdfa;
  border-radius: 18px;
  padding: .8rem .95rem;
  display: grid;
  gap: .18rem;
}
.fewo-booking-card__label {
  color: #8b7e72;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-booking-card__number {
  font-size: 1.15rem;
  line-height: 1.15;
  word-break: break-word;
}
.fewo-booking-card__block strong {
  color: #202624;
  line-height: 1.25;
}
.fewo-booking-card__block small {
  color: #666;
  line-height: 1.45;
}
.fewo-booking-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}
.fewo-status-inline {
  color: #666;
  font-size: .85rem;
  font-weight: 700;
}
.fewo-booking-card__section-head {
  display: grid;
  gap: .15rem;
  margin-bottom: .65rem;
}
.fewo-booking-card__section-head h3 {
  margin: 0;
  font-size: 1rem;
  color: #202624;
}
.fewo-booking-card__section-head p {
  margin: 0;
  color: #6f756f;
  font-size: .84rem;
  line-height: 1.45;
}
.fewo-booking-card__payment {
  border: 1px solid #efe6dd;
  background: #fcfaf7;
  border-radius: 22px;
  padding: .9rem;
}
.fewo-booking-card__actions {
  border: 1px solid #efe6dd;
  background: #fffdfa;
  border-radius: 22px;
  padding: .9rem;
}
.fewo-booking-card__actions .fewo-actions {
  min-width: 0;
}
.fewo-booking-card__amounts .fewo-admin-amount-overview {
  gap: .32rem;
}
.fewo-booking-card__details {
  margin-top: 0;
}
.fewo-table-bookings td.fewo-admin-payment-cell,
.fewo-table-bookings td.fewo-admin-amount-cell {
  min-width: 0;
  width: auto;
}
.fewo-admin-amount-overview {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .35rem .45rem;
}
.fewo-admin-amount-overview > strong {
  grid-column: 1 / -1;
  font-size: 1.55rem;
  line-height: 1;
}
.fewo-admin-amount-overview > span,
.fewo-admin-pay-chip {
  width: auto;
}
.fewo-admin-pay-chip {
  justify-content: center;
}
.fewo-payment-steps--compact .fewo-payment-step {
  grid-template-columns: minmax(0, 1fr) auto;
}
.fewo-actions {
  display: grid;
  gap: .75rem;
  min-width: 0;
}
.fewo-actions form {
  gap: .45rem;
  padding: .7rem;
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fff;
}
.fewo-actions .fewo-button,
.fewo-actions .fewo-button-small {
  width: 100%;
  justify-content: center;
}
.fewo-actions small {
  color: #6f756f;
  line-height: 1.35;
}
.fewo-actions select,
.fewo-actions input {
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 1440px) {
  .fewo-booking-row__summary {
    grid-template-columns: minmax(150px, 1fr) minmax(170px, 1.1fr) minmax(150px, 1fr) minmax(180px, 1.2fr) auto;
  }
  .fewo-booking-row__cell--amount {
    display: none;
  }
  .fewo-booking-card__grid {
    grid-template-columns: minmax(220px, .95fr) minmax(340px, 1.35fr) minmax(220px, .8fr);
  }
}
@media (max-width: 1180px) {
  .fewo-booking-row__summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  }
  .fewo-booking-card__grid {
    grid-template-columns: 1fr;
  }
  .fewo-booking-card__payment,
  .fewo-booking-card__actions {
    padding: .85rem;
  }
  .fewo-admin-amount-overview {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-booking-card {
    border-radius: 22px;
  }
  .fewo-booking-row__summary {
    grid-template-columns: 1fr auto;
    padding: .8rem;
  }
  .fewo-booking-row__cell {
    grid-column: 1 / 2;
  }
  .fewo-booking-row__summary::after {
    grid-column: 2;
    grid-row: 1;
  }
  .fewo-booking-card__body {
    padding: .85rem;
  }
  .fewo-booking-card__block,
  .fewo-booking-card__payment,
  .fewo-booking-card__actions {
    border-radius: 16px;
  }
  .fewo-admin-amount-overview {
    grid-template-columns: 1fr;
  }
}

/* Booking form payment guidance: selection-aware bullet cards */
.fewo-payment-guidance {
  display: grid;
  gap: .75rem;
  margin-top: .15rem;
  padding: .85rem;
  border: 1px solid rgba(229, 221, 212, .95);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,253,250,.98), rgba(255,255,255,.98));
}
.fewo-payment-guidance__heading {
  margin: 0;
  color: var(--dark, #202624) !important;
  font-size: .92rem;
  font-weight: 850;
}
.fewo-payment-guidance-card {
  display: none;
  padding: .85rem .95rem;
  border-radius: 16px;
  border: 1px solid #ead8cd;
  background: #fff8f2;
  box-shadow: inset 4px 0 0 var(--accent, #b76d48);
}
.fewo-payment-guidance-card strong {
  display: block;
  margin-bottom: .45rem;
  color: var(--dark, #202624);
  font-size: .98rem;
  line-height: 1.25;
}
.fewo-payment-guidance-card ul {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: .35rem;
}
.fewo-payment-guidance-card li {
  color: var(--muted, #666);
  line-height: 1.5;
}
.fewo-booking-form fieldset:has(input[name="payment_method"][value="bank_transfer"]:checked) .fewo-payment-guidance-card--bank,
.fewo-booking-form fieldset:has(input[name="payment_method"][value="cash"]:checked) .fewo-payment-guidance-card--cash,
.fewo-booking-form fieldset:has(input[name="payment_method"][value="paypal"]:checked) .fewo-payment-guidance-card--paypal {
  display: block;
}
.fewo-payment-guidance-common {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
}
.fewo-payment-guidance-common span {
  display: grid;
  gap: .15rem;
  padding: .72rem .82rem;
  border-radius: 14px;
  border: 1px solid #efd69b;
  background: #fff7e7;
  color: #7a5200;
  line-height: 1.45;
}
.fewo-payment-guidance-common strong {
  color: #7a4d10;
  font-size: .76rem;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: .06em;
}
@supports not selector(:has(*)) {
  .fewo-payment-guidance-card--bank {
    display: block;
  }
}
@media (max-width: 720px) {
  .fewo-payment-guidance {
    padding: .75rem;
  }
  .fewo-payment-guidance-common {
    grid-template-columns: 1fr;
  }
}

/* Payment method guidance: dynamic, selection-based overview in the booking form */
.fewo-payment-fieldset {
  align-items: start;
}
.fewo-payment-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: .75rem;
}
.fewo-payment-option {
  margin: 0;
  padding: .9rem 1rem;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 16px;
  background: #fff;
  transition: border-color .18s ease, background-color .18s ease, box-shadow .18s ease;
}
.fewo-payment-option.is-active {
  border-color: var(--accent, #b76d48);
  background: #fff8f3;
  box-shadow: 0 10px 24px rgba(183, 109, 72, .09);
}
.fewo-payment-guidance {
  display: grid;
  gap: .9rem;
  padding: clamp(1rem, 2vw, 1.2rem);
  border-radius: 20px;
  border: 1px solid rgba(183, 109, 72, .26);
  background: linear-gradient(135deg, #fffdfa, #fff7ef);
}
.fewo-payment-guidance__head {
  display: flex;
  gap: .75rem;
  align-items: center;
}
.fewo-payment-guidance__icon {
  width: 2.15rem;
  height: 2.15rem;
  flex: 0 0 2.15rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--accent, #b76d48);
  color: #fff;
  font-weight: 900;
}
.fewo-payment-guidance__eyebrow {
  display: block;
  margin-bottom: .12rem;
  color: var(--accent-dark, #9b5837);
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.fewo-payment-guidance__head strong {
  display: block;
  color: var(--dark, #202624);
  font-size: 1.08rem;
  line-height: 1.2;
}
.fewo-payment-guidance__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.fewo-payment-guidance__item {
  display: grid;
  gap: .35rem;
  align-content: start;
  min-height: 100%;
  padding: .9rem;
  border-radius: 16px;
  border: 1px solid rgba(229, 221, 212, .95);
  background: rgba(255,255,255,.92);
  box-shadow: inset 0 4px 0 rgba(183, 109, 72, .16);
}
.fewo-payment-guidance__item[hidden] {
  display: none !important;
}
.fewo-payment-guidance__item span {
  width: fit-content;
  display: inline-flex;
  padding: .2rem .55rem;
  border-radius: 999px;
  background: #fff1cc;
  color: #8a5a00;
  font-size: .68rem;
  line-height: 1.15;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.fewo-payment-guidance__item strong {
  color: var(--dark, #202624);
  font-size: .98rem;
  line-height: 1.25;
}
.fewo-payment-guidance__item p {
  margin: 0;
  color: var(--muted, #666);
  font-size: .9rem;
  line-height: 1.5;
}
.fewo-payment-guidance__item--specific.is-active {
  border-color: rgba(183, 109, 72, .42);
  background: #fffaf3;
  box-shadow: inset 0 4px 0 var(--accent, #b76d48), 0 10px 24px rgba(183, 109, 72, .08);
}
.fewo-payment-guidance__item--urgent {
  box-shadow: inset 0 4px 0 #d39b23;
}
.fewo-payment-guidance__notice {
  margin: 0;
  padding: .8rem .95rem;
  border-radius: 14px;
  border: 1px solid #efd69b;
  background: #fff7e7;
  color: #7a5200;
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.55;
}
@media (max-width: 820px) {
  .fewo-payment-guidance__grid {
    grid-template-columns: 1fr;
  }
}

/* Simplified payment guidance in booking form */
.fewo-payment-guidance--simple {
  margin-top: .85rem;
  padding: 0 !important;
  border: 1px solid var(--line, #e5ddd4) !important;
  border-radius: 18px !important;
  background: #fffdf9 !important;
  box-shadow: none !important;
  overflow: hidden;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__summary {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .85rem 1rem;
  cursor: pointer;
  list-style: none;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__summary::-webkit-details-marker {
  display: none;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__summary::after {
  content: "›";
  margin-left: auto;
  transform: rotate(90deg);
  color: var(--accent, #b76d48);
  font-size: 1.25rem;
  font-weight: 900;
  transition: transform .18s ease;
}
.fewo-payment-guidance--simple:not([open]) .fewo-payment-guidance__summary::after {
  transform: rotate(0deg);
}
.fewo-payment-guidance--simple .fewo-payment-guidance__icon {
  width: 2rem;
  height: 2rem;
  flex: 0 0 2rem;
  font-size: .95rem;
  background: rgba(183, 109, 72, .12);
  color: var(--accent, #b76d48);
}
.fewo-payment-guidance--simple .fewo-payment-guidance__eyebrow {
  display: block;
  margin: 0 0 .1rem;
  font-size: .68rem;
  letter-spacing: .1em;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__summary strong {
  display: block;
  color: var(--dark, #202624);
  font-size: 1rem;
  line-height: 1.2;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__body {
  padding: 0 1rem .95rem;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__bullets {
  display: grid;
  gap: .55rem;
  margin: 0;
  padding: .2rem 0 0 1.25rem;
  color: var(--muted, #666);
  line-height: 1.48;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__bullets li {
  padding-left: .15rem;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__bullets li::marker {
  color: var(--accent, #b76d48);
}
.fewo-payment-guidance--simple .fewo-payment-guidance__bullets strong {
  color: var(--dark, #202624);
  font-weight: 850;
}
.fewo-payment-guidance--simple [data-fewo-payment-specific][hidden] {
  display: none !important;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__important {
  margin-top: .2rem;
  padding: .65rem .75rem;
  border: 1px solid #efd69b;
  border-radius: 12px;
  background: #fff7e7;
  color: #725000;
  list-style: none;
}
.fewo-payment-guidance--simple .fewo-payment-guidance__important::marker {
  content: "";
}
@media (max-width: 720px) {
  .fewo-payment-guidance--simple .fewo-payment-guidance__summary {
    padding: .8rem .85rem;
  }
  .fewo-payment-guidance--simple .fewo-payment-guidance__body {
    padding: 0 .85rem .85rem;
  }
}

/* Simpler payment guidance in booking form */
.fewo-payment-guidance {
  display: block;
  padding: 0;
  border-radius: 18px;
  border: 1px solid var(--line, #e5ddd4);
  background: #fffdf9;
  box-shadow: none;
  overflow: hidden;
}
.fewo-payment-guidance__summary {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .9rem 1rem;
  cursor: pointer;
  list-style: none;
}
.fewo-payment-guidance__summary::-webkit-details-marker {
  display: none;
}
.fewo-payment-guidance__summary::after {
  content: "";
  margin-left: auto;
  width: 1.85rem;
  height: 1.85rem;
  flex: 0 0 1.85rem;
  border-radius: 999px;
  background-color: #fff1e8;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23b96842'%20stroke-width='3.2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m6%209%206%206%206-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: .95rem;
  border: 1.5px solid rgba(185, 104, 66, .35);
  transform: rotate(0deg);
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease;
}
.fewo-payment-guidance__summary:hover::after {
  background-color: #ffe6d6;
  border-color: rgba(185, 104, 66, .55);
}
.fewo-payment-guidance[open] .fewo-payment-guidance__summary::after {
  transform: rotate(180deg);
}
.fewo-payment-guidance__icon {
  width: 1.95rem;
  height: 1.95rem;
  flex: 0 0 1.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #fff1e8;
  color: var(--accent, #b76d48);
  font-weight: 900;
}
.fewo-payment-guidance__eyebrow {
  display: block;
  margin-bottom: .08rem;
  color: var(--accent-dark, #9b5837);
  font-size: .68rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.fewo-payment-guidance__summary strong {
  display: block;
  color: var(--dark, #202624);
  font-size: 1rem;
  line-height: 1.2;
}
.fewo-payment-guidance__body {
  padding: 0 1rem 1rem;
  border-top: 1px solid rgba(229, 221, 212, .72);
}
.fewo-payment-guidance__list {
  margin: .85rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .55rem;
}
.fewo-payment-guidance__list[hidden] {
  display: none !important;
}
.fewo-payment-guidance__list li {
  position: relative;
  margin: 0;
  padding-left: 1.15rem;
  color: var(--muted, #666);
  font-size: .95rem;
  line-height: 1.5;
}
.fewo-payment-guidance__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .58em;
  width: .42rem;
  height: .42rem;
  border-radius: 999px;
  background: var(--accent, #b76d48);
}
.fewo-payment-guidance__list li strong {
  color: var(--dark, #202624);
}
.fewo-payment-guidance__list--common {
  margin-top: .75rem;
  padding-top: .75rem;
  border-top: 1px solid rgba(229, 221, 212, .72);
}
.fewo-payment-guidance__list--common li::before {
  background: #d39b23;
}
@media (max-width: 720px) {
  .fewo-payment-guidance__summary {
    padding: .8rem .85rem;
    gap: .6rem;
  }
  .fewo-payment-guidance__body {
    padding: 0 .85rem .9rem;
  }
  .fewo-payment-guidance__list li {
    font-size: .9rem;
  }
}

/* Bank transfer QR codes in customer booking management */
.fewo-bank-qr-section {
  margin-top: 1.2rem;
  padding-top: 1rem;
  border-top: 1px solid #eee4db;
}
.fewo-bank-qr-section h3 {
  margin: 0 0 .35rem;
  color: #202624;
}
.fewo-bank-qr-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: .85rem;
  margin-top: .85rem;
}
.fewo-bank-qr-card {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: .85rem;
  align-items: center;
  padding: .85rem;
  border: 1px solid #eadfd4;
  border-radius: 18px;
  background: #fff;
}
.fewo-bank-qr-card__image {
  display: grid;
  place-items: center;
  padding: .45rem;
  border: 1px solid #eee4db;
  border-radius: 14px;
  background: #fff;
}
.fewo-bank-qr-card__image svg {
  width: 116px !important;
  height: auto;
  display: block;
}
.fewo-bank-qr-card__text {
  min-width: 0;
  display: grid;
  gap: .18rem;
}
.fewo-bank-qr-card__text strong {
  color: #202624;
  font-size: 1rem;
}
.fewo-bank-qr-card__text span {
  color: #202624;
  font-size: 1.18rem;
  font-weight: 850;
}
.fewo-bank-qr-card__text small {
  color: #6f756f;
  line-height: 1.4;
  word-break: break-word;
}
@media (max-width: 560px) {
  .fewo-bank-qr-card {
    grid-template-columns: 1fr;
  }
  .fewo-bank-qr-card__image {
    width: fit-content;
  }
}

/* Customer payment plan status coloring */
.fewo-payment-steps--customer-management {
  margin: 1.1rem 0;
}
.fewo-payment-steps--customer-management .fewo-payment-step {
  border-width: 1px;
  box-shadow: inset 6px 0 0 #d9d2ca;
}
.fewo-payment-steps--customer-management .fewo-payment-step--paid {
  border-color: #bfe6c9;
  background: #f2fbf4;
  box-shadow: inset 6px 0 0 #2f8f4e;
}
.fewo-payment-steps--customer-management .fewo-payment-step--due,
.fewo-payment-steps--customer-management .fewo-payment-step--soon,
.fewo-payment-steps--customer-management .fewo-payment-step--upcoming {
  border-color: #efd69b;
  background: #fffaf0;
  box-shadow: inset 6px 0 0 #d9a11f;
}
.fewo-payment-steps--customer-management .fewo-payment-step--overdue {
  border-color: #efb7b7;
  background: #fff4f4;
  box-shadow: inset 6px 0 0 #b42318;
}
.fewo-payment-steps--customer-management .fewo-payment-step--cash {
  border-color: #c9dceb;
  background: #f4faff;
  box-shadow: inset 6px 0 0 #5e86a5;
}
.fewo-payment-steps--customer-management .fewo-payment-step__status {
  font-size: .72rem;
}
@media (max-width: 760px) {
  .fewo-payment-steps--customer-management .fewo-payment-step {
    box-shadow: inset 5px 0 0 #d9d2ca;
  }
}

/* Optional company / invoice fields in booking form */
.fewo-company-details {
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 18px;
  background: #fffdf9;
  overflow: hidden;
}
.fewo-company-details summary {
  cursor: pointer;
  padding: .95rem 1rem;
  font-weight: 850;
  color: var(--dark, #202624);
}
.fewo-company-details__body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  padding: 0 1rem 1rem;
  border-top: 1px solid rgba(229, 221, 212, .72);
}
.fewo-company-details__body .fewo-full,
.fewo-company-details__body p,
.fewo-company-details__body .fewo-checkbox {
  grid-column: 1 / -1;
}
.fewo-admin-invoice-details,
.fewo-invoice-card {
  border: 1px solid #d7ead9;
  background: #f6fbf7;
  border-radius: 18px;
  padding: .9rem 1rem;
}
.fewo-admin-invoice-list {
  margin: .55rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .45rem;
}
.fewo-admin-invoice-list li {
  display: grid;
  gap: .1rem;
}
.fewo-admin-invoice-list span {
  color: #68736b;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.fewo-admin-invoice-list strong {
  color: #202624;
  white-space: pre-line;
}
@media (max-width: 760px) {
  .fewo-company-details__body {
    grid-template-columns: 1fr;
  }
}

/* Company/private booking mode in the booking form */
.fewo-company-toggle {
  align-items: flex-start;
  padding: .9rem 1rem;
  border: 1px solid var(--line, #e5ddd4);
  border-radius: 16px;
  background: #fffdfa;
}
.fewo-company-toggle span {
  display: grid;
  gap: .18rem;
}
.fewo-company-toggle strong {
  color: var(--dark, #202624);
}
.fewo-company-toggle small {
  color: var(--muted, #666);
  line-height: 1.4;
}
.fewo-contact-mode {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: .25rem;
  padding: .95rem;
  border: 1px solid rgba(229, 221, 212, .9);
  border-radius: 18px;
  background: rgba(255,255,255,.72);
}
.fewo-contact-mode[hidden] {
  display: none !important;
}
.fewo-contact-mode__head,
.fewo-contact-mode__subhead {
  grid-column: 1 / -1;
}
.fewo-contact-mode__head h3 {
  margin: 0 0 .2rem;
  font-size: 1.05rem;
  color: var(--dark, #202624);
}
.fewo-contact-mode__head p {
  margin: 0;
  color: var(--muted, #666);
  line-height: 1.5;
}
.fewo-contact-mode__subhead {
  margin-top: .35rem;
  color: var(--accent-dark, #9b5837);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-contact-mode--company {
  background: linear-gradient(180deg, #fffdfa, #fff8f2);
  border-color: rgba(183, 109, 72, .28);
}
@media (max-width: 720px) {
  .fewo-contact-mode {
    grid-template-columns: 1fr;
    padding: .8rem;
  }
  .fewo-company-toggle {
    padding: .8rem;
  }
}

/* Admin dashboard tasks */
.fewo-task-dashboard {
  border-color: #eadfd4;
  background: linear-gradient(180deg, #fffdfa, #fff);
}
.fewo-task-total {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .6rem .9rem;
  border-radius: 999px;
  background: #f2eee8;
  border: 1px solid #e5ddd4;
  color: #5f625e;
  font-weight: 900;
  white-space: nowrap;
}
.fewo-task-total--active {
  background: #fff7e7;
  border-color: #efd69b;
  color: #7a5200;
}
.fewo-task-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .9rem;
  margin-top: 1rem;
}
.fewo-task-panel {
  min-width: 0;
  border: 1px solid #eee4db;
  border-radius: 22px;
  background: #fff;
  padding: .95rem;
  box-shadow: 0 10px 28px rgba(32, 38, 36, .04);
}
.fewo-task-panel header {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  padding-bottom: .75rem;
  border-bottom: 1px solid #f0e8df;
}
.fewo-task-panel header > span {
  width: 2.35rem;
  height: 2.35rem;
  flex: 0 0 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #f2eee8;
  color: #5f625e;
  font-weight: 950;
  font-size: 1.05rem;
}
.fewo-task-panel h3 {
  margin: 0 0 .15rem;
  color: #202624;
  font-size: 1rem;
}
.fewo-task-panel p {
  margin: 0;
  color: #6f756f;
  font-size: .83rem;
  line-height: 1.4;
}
.fewo-task-panel--overdue header > span,
.fewo-task-panel--deposit header > span {
  background: #fff0f0;
  color: #8f1d1d;
}
.fewo-task-panel--due header > span {
  background: #fff7e7;
  color: #8a5a00;
}
.fewo-task-panel--arrival header > span {
  background: #edf8ef;
  color: #20663b;
}
.fewo-task-none {
  padding: .85rem 0 0;
  color: #6f756f;
  font-weight: 750;
}
.fewo-task-list {
  list-style: none;
  margin: .75rem 0 0;
  padding: 0;
  display: grid;
  gap: .55rem;
}
.fewo-task-item a {
  display: grid;
  gap: .15rem;
  padding: .65rem .7rem;
  border-radius: 15px;
  border: 1px solid #eee4db;
  background: #fffdfa;
  text-decoration: none;
  color: inherit;
}
.fewo-task-item a:hover,
.fewo-task-item a:focus-visible {
  border-color: #c16b43;
  box-shadow: 0 0 0 3px rgba(193, 107, 67, .12);
  outline: 0;
}
.fewo-task-item strong {
  color: #202624;
  font-size: .9rem;
  line-height: 1.25;
}
.fewo-task-item span {
  color: #6f756f;
  font-size: .8rem;
  line-height: 1.35;
}
.fewo-task-item em {
  color: #202624;
  font-style: normal;
  font-weight: 900;
  font-size: .9rem;
}
.fewo-task-item--danger a {
  background: #fff5f5;
  border-color: #f1b6b6;
}
.fewo-task-item--warning a {
  background: #fffaf0;
  border-color: #f0d79d;
}
.fewo-task-more,
.fewo-task-empty {
  margin: .8rem 0 0;
  color: #6f756f;
  font-weight: 750;
}
@media (max-width: 1280px) {
  .fewo-task-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 720px) {
  .fewo-task-grid {
    grid-template-columns: 1fr;
  }
  .fewo-task-total {
    width: 100%;
  }
}

/* Deposit management */
.fewo-admin-deposit-panel {
  grid-column: 1 / -1;
  border: 1px solid #eee4db;
  border-radius: 18px;
  padding: 1rem;
  background: #fffdfa;
  display: grid;
  gap: .8rem;
}
.fewo-admin-deposit-panel--paid {
  border-color: #cfe9d3;
  background: #f5fbf6;
}
.fewo-admin-deposit-panel--due,
.fewo-admin-deposit-panel--upcoming {
  border-color: #efd69b;
  background: #fffaf0;
}
.fewo-admin-deposit-panel--overdue {
  border-color: #f1b6b6;
  background: #fff5f5;
}
.fewo-admin-deposit-panel--warning {
  border-color: #f0d79d;
  background: #fff8e6;
}
.fewo-admin-deposit-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.fewo-admin-deposit-head strong {
  color: #202624;
  font-size: 1.05rem;
}
.fewo-admin-deposit-head p {
  margin: .2rem 0 0;
  color: #6f756f;
  line-height: 1.45;
}
.fewo-admin-deposit-head > span {
  white-space: nowrap;
  font-weight: 900;
  color: #202624;
  font-size: 1.2rem;
}
.fewo-admin-deposit-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .6rem;
}
.fewo-admin-deposit-grid > div {
  border: 1px solid rgba(229, 221, 212, .95);
  border-radius: 14px;
  padding: .65rem .75rem;
  background: rgba(255,255,255,.78);
}
.fewo-admin-deposit-grid span {
  display: block;
  color: #8b7e72;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 900;
  margin-bottom: .15rem;
}
.fewo-admin-deposit-grid strong {
  color: #202624;
}
.fewo-admin-deposit-note {
  margin: 0;
  padding: .75rem .85rem;
  border-radius: 14px;
  background: rgba(255,255,255,.75);
  color: #5f625e;
  line-height: 1.5;
}
.fewo-admin-deposit-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}
.fewo-admin-deposit-actions form {
  display: grid;
  gap: .45rem;
  padding: .75rem;
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fff;
}
.fewo-admin-deposit-actions input {
  width: 100%;
  box-sizing: border-box;
  padding: .55rem;
  border: 1px solid #cfc5ba;
  border-radius: 10px;
}
.fewo-deposit-card {
  border-left: 5px solid #b7aa9c;
}
.fewo-deposit-card--paid {
  border-left-color: #3b8a52;
  background: #f7fcf8;
}
.fewo-deposit-card--due,
.fewo-deposit-card--upcoming {
  border-left-color: #d39b23;
  background: #fffaf0;
}
.fewo-deposit-card--overdue {
  border-left-color: #b42318;
  background: #fff5f5;
}
.fewo-deposit-card--warning {
  border-left-color: #d39b23;
  background: #fff8e6;
}
.fewo-deposit-summary {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
@media (max-width: 1000px) {
  .fewo-admin-deposit-actions,
  .fewo-admin-deposit-grid,
  .fewo-deposit-summary {
    grid-template-columns: 1fr;
  }
  .fewo-admin-deposit-head {
    display: grid;
  }
}

/* Admin filters and test booking mode */
.fewo-admin-filter-panel {
  display: grid;
  gap: .8rem;
  margin: 1rem 0 1.25rem;
  padding: 1rem;
  border: 1px solid #eadfd4;
  border-radius: 22px;
  background: #fffdf9;
}
.fewo-admin-filter-form {
  display: grid;
  grid-template-columns: minmax(220px, 1.2fr) repeat(4, minmax(150px, .8fr)) auto;
  gap: .75rem;
  align-items: end;
}
.fewo-admin-filter-form label {
  display: grid;
  gap: .3rem;
  font-weight: 800;
  color: #202624;
}
.fewo-admin-filter-form input,
.fewo-admin-filter-form select {
  width: 100%;
  box-sizing: border-box;
  padding: .68rem .75rem;
  border: 1px solid #ddd2c6;
  border-radius: 12px;
  background: #fff;
  color: #202624;
  font: inherit;
}
.fewo-admin-filter-actions {
  display: flex;
  gap: .45rem;
  flex-wrap: wrap;
}
.fewo-admin-filter-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  flex-wrap: wrap;
  color: #6f756f;
  font-weight: 750;
}
.fewo-admin-filter-summary form {
  margin: 0;
}
.fewo-badge-test {
  display: inline-flex;
  align-items: center;
  padding: .28rem .55rem;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  background: #efe8ff;
  color: #5f3aa5;
  border: 1px solid #dccbff;
}
.fewo-booking-card--test {
  border-style: dashed;
  border-color: #bda7f5;
  background: linear-gradient(180deg, #fff, #fbf8ff);
}
.fewo-booking-card--test .fewo-booking-card__number::after {
  content: " · TEST";
  color: #5f3aa5;
  font-size: .82rem;
  font-weight: 900;
}
@media (max-width: 1280px) {
  .fewo-admin-filter-form {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-admin-filter-form {
    grid-template-columns: 1fr;
  }
  .fewo-admin-filter-actions,
  .fewo-admin-filter-actions .fewo-button {
    width: 100%;
  }
  .fewo-admin-filter-actions .fewo-button {
    justify-content: center;
  }
}

/* Customer account: documents & links panel visual polish */
.fewo-documents-card {
  overflow: hidden;
  border-color: #e8ddd2;
  background: linear-gradient(180deg, rgba(255,253,250,.99), rgba(255,255,255,.99));
}
.fewo-documents-head {
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
  align-items: flex-start;
  margin-bottom: 1.25rem;
}
.fewo-documents-head h2 {
  margin-bottom: .45rem;
}
.fewo-documents-head .fewo-lead {
  max-width: 760px;
}
.fewo-print-button {
  flex: 0 0 auto;
  white-space: nowrap;
  margin-top: .35rem;
}
.fewo-document-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
  margin-top: .4rem;
}
.fewo-document-link {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "label arrow"
    "title arrow"
    "text arrow";
  gap: .24rem .85rem;
  align-items: center;
  min-height: 118px;
  padding: 1rem 1.05rem;
  border: 1px solid #eadfd4;
  border-radius: 18px;
  background: rgba(255, 255, 255, .92);
  color: #202624 !important;
  text-decoration: none !important;
  box-shadow: 0 10px 24px rgba(32, 38, 36, .035);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.fewo-document-link::after {
  grid-area: arrow;
  content: "→";
  width: 2.1rem;
  height: 2.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #fbefe8;
  color: var(--accent, #b76d48);
  font-weight: 900;
  line-height: 1;
}
.fewo-document-link:hover,
.fewo-document-link:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(183, 109, 72, .48);
  background: #fffdf9;
  box-shadow: 0 16px 36px rgba(32, 38, 36, .08);
}
.fewo-document-link:focus-visible {
  outline: 3px solid rgba(183, 109, 72, .22);
  outline-offset: 3px;
}
.fewo-document-link span {
  grid-area: label;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  padding: .24rem .55rem;
  border-radius: 999px;
  background: #fbefe8;
  color: var(--accent-dark, #9b5837);
  font-size: .72rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.fewo-document-link strong {
  grid-area: title;
  color: #202624;
  font-size: 1.02rem;
  line-height: 1.2;
}
.fewo-document-link small {
  grid-area: text;
  color: #6f756f;
  font-size: .88rem;
  line-height: 1.45;
}
.fewo-document-link[href^="#"]::after {
  content: "↓";
}
.fewo-document-link[target="_blank"]::after {
  content: "↗";
}
@media (max-width: 1180px) {
  .fewo-document-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-documents-head {
    display: grid;
    gap: .9rem;
  }
  .fewo-print-button {
    width: 100%;
    justify-content: center;
    white-space: normal;
  }
  .fewo-document-grid {
    grid-template-columns: 1fr;
  }
  .fewo-document-link {
    min-height: auto;
    padding: .95rem;
  }
}
@media print {
  .fewo-print-button,
  .fewo-document-link::after {
    display: none !important;
  }
  .fewo-document-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Invoice / PDF billing */
.fewo-admin-invoice-panel {
  grid-column: 1 / -1;
  border: 1px solid #ead8cd;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffdfa, #fff);
  padding: 1rem;
  display: grid;
  gap: .85rem;
}
.fewo-admin-invoice-panel--neutral {
  background: #fdfbf8;
  border-color: #e5ddd4;
}
.fewo-admin-invoice-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.fewo-admin-invoice-head strong {
  display: block;
  color: #202624;
  font-size: 1.05rem;
}
.fewo-admin-invoice-head p {
  margin: .2rem 0 0;
  color: #6f756f;
  line-height: 1.45;
}
.fewo-admin-invoice-head > span {
  white-space: nowrap;
  border-radius: 999px;
  padding: .35rem .65rem;
  background: #fff3e8;
  border: 1px solid #ead8cd;
  color: #9b5837;
  font-weight: 900;
}
.fewo-admin-invoice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .65rem;
}
.fewo-admin-invoice-grid > div {
  border: 1px solid #eee4db;
  border-radius: 14px;
  padding: .75rem .8rem;
  background: #fff;
}
.fewo-admin-invoice-grid span {
  display: block;
  margin-bottom: .22rem;
  color: #7a746b;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 900;
}
.fewo-admin-invoice-grid strong {
  color: #202624;
}
.fewo-admin-invoice-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  align-items: center;
}
.fewo-admin-invoice-actions form {
  margin: 0;
}
@media (max-width: 720px) {
  .fewo-admin-invoice-head {
    display: grid;
  }
  .fewo-admin-invoice-head > span {
    width: fit-content;
  }
  .fewo-admin-invoice-actions,
  .fewo-admin-invoice-actions .fewo-button {
    width: 100%;
  }
}

/* Invoice preview/final workflow */
.fewo-admin-invoice-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  align-items: center;
}
.fewo-admin-invoice-actions form {
  margin: 0;
}
.fewo-admin-invoice-note {
  margin: .75rem 0 0;
  color: #6f756f;
  font-size: .9rem;
  line-height: 1.5;
}

/* Admin booking details: nested accordion organization */
.fewo-admin-details--managed > summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  background: #fffaf5;
  border: 1px solid #ead8cd;
  cursor: pointer;
}
.fewo-admin-details--managed > summary span {
  color: var(--accent, #b76d48);
  font-weight: 900;
}
.fewo-admin-details--managed > summary small {
  color: #6f756f;
  font-size: .86rem;
  font-weight: 650;
  text-align: right;
}
.fewo-admin-detail-accordion {
  display: grid;
  gap: .75rem;
  margin-top: .9rem;
}
.fewo-admin-accordion-item {
  border: 1px solid #eadfd4;
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(32, 38, 36, .035);
}
.fewo-admin-accordion-item > summary {
  list-style: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .8rem;
  align-items: center;
  padding: .95rem 1rem;
  cursor: pointer;
  background: #fffdfa;
  border-bottom: 1px solid transparent;
}
.fewo-admin-accordion-item > summary::-webkit-details-marker,
.fewo-admin-details--managed > summary::-webkit-details-marker {
  display: none;
}
.fewo-admin-accordion-item > summary::after {
  content: '+';
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid #ead8cd;
  color: var(--accent, #b76d48);
  font-weight: 900;
  background: #fff;
}
.fewo-admin-accordion-item[open] > summary::after {
  content: '–';
}
.fewo-admin-accordion-item > summary span {
  color: #202624;
  font-size: 1rem;
  font-weight: 900;
}
.fewo-admin-accordion-item > summary small {
  display: block;
  color: #6f756f;
  font-size: .83rem;
  line-height: 1.35;
  font-weight: 650;
  margin-top: .16rem;
}
.fewo-admin-accordion-item[open] > summary {
  border-bottom-color: #eee4db;
}
.fewo-admin-accordion-body {
  padding: 1rem;
  display: grid;
  gap: .95rem;
}
.fewo-admin-accordion-subcard {
  margin-top: 0;
}
.fewo-admin-log-card {
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fffdfa;
  padding: .95rem;
}
.fewo-admin-log-card h4 {
  margin: 0 0 .55rem;
  color: #202624;
}
.fewo-admin-log-card ul {
  margin: 0;
  padding-left: 1.1rem;
}
.fewo-admin-accordion-item--danger {
  border-color: #efc4c4;
  background: #fff8f8;
}
.fewo-admin-accordion-item--danger > summary {
  background: #fff5f5;
}
.fewo-admin-accordion-item--danger > summary span,
.fewo-admin-accordion-item--danger > summary::after {
  color: #8f1d1d;
}
.fewo-admin-accordion-item--danger > summary::after {
  border-color: #efc4c4;
}
.fewo-admin-accordion-item .fewo-admin-payment-plan,
.fewo-admin-accordion-item .fewo-admin-invoice-panel,
.fewo-admin-accordion-item .fewo-admin-deposit-panel,
.fewo-admin-accordion-item .fewo-danger-zone {
  margin: 0;
}
@media (max-width: 760px) {
  .fewo-admin-details--managed > summary,
  .fewo-admin-accordion-item > summary {
    grid-template-columns: 1fr auto;
  }
  .fewo-admin-details--managed > summary {
    display: grid;
  }
  .fewo-admin-details--managed > summary small {
    text-align: left;
  }
  .fewo-admin-accordion-body {
    padding: .85rem;
  }
}

/* Central invoice management */
.fewo-admin-invoice-center {
  scroll-margin-top: 1rem;
}
.fewo-admin-invoice-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  margin: 1rem 0;
}
.fewo-admin-invoice-stats span {
  display: grid;
  gap: .15rem;
  padding: .9rem 1rem;
  border: 1px solid #eee4db;
  border-radius: 18px;
  background: #fffdfa;
  color: #6f756f;
  font-size: .88rem;
  font-weight: 700;
}
.fewo-admin-invoice-stats strong {
  color: #202624;
  font-size: 1.45rem;
  line-height: 1;
}
.fewo-invoice-list {
  display: grid;
  gap: .85rem;
  margin-top: 1rem;
}
.fewo-invoice-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(230px, .36fr);
  gap: .9rem;
  align-items: start;
  padding: .95rem;
  border: 1px solid #eadfd4;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(32, 38, 36, .045);
}
.fewo-invoice-card--open {
  border-color: #efd69b;
  background: #fffdf7;
}
.fewo-invoice-card--sent {
  border-color: #cfe9d3;
  background: #fbfffc;
}
.fewo-invoice-card__main {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
}
.fewo-invoice-card__main > div {
  min-width: 0;
  display: grid;
  gap: .16rem;
}
.fewo-invoice-card__label {
  color: #8b7e72;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-invoice-card__main strong {
  color: #202624;
  line-height: 1.22;
  word-break: break-word;
}
.fewo-invoice-card__main small {
  color: #6f756f;
  line-height: 1.35;
  word-break: break-word;
}
.fewo-invoice-card__status {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  align-items: flex-start;
}
.fewo-invoice-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .42rem .7rem;
  border-radius: 999px;
  border: 1px solid #e4ddd4;
  background: #f7f4f0;
  color: #5f625e;
  font-size: .76rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
}
.fewo-invoice-status--open {
  border-color: #f0d79d;
  background: #fff4d8;
  color: #7a4d10;
}
.fewo-invoice-status--created {
  border-color: #d8e3ec;
  background: #f0f7fc;
  color: #34566e;
}
.fewo-invoice-status--sent {
  border-color: #cfe9d3;
  background: #e8f7ec;
  color: #1f6b38;
}
.fewo-invoice-status--optional {
  border-color: #e4ddd4;
  background: #f7f4f0;
  color: #69635c;
}
.fewo-invoice-card__actions {
  min-width: 0;
}
.fewo-admin-invoice-panel--compact {
  border: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-head,
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-grid,
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-note {
  display: none;
}
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-actions {
  margin: 0;
  display: grid;
  gap: .45rem;
}
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-actions .fewo-button,
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-actions form,
.fewo-admin-invoice-panel--compact .fewo-admin-invoice-actions button {
  width: 100%;
}
.fewo-admin-inline-link {
  color: #b76d48;
  font-weight: 800;
  text-decoration: none;
}
.fewo-admin-inline-link:hover {
  text-decoration: underline;
}
@media (max-width: 1240px) {
  .fewo-invoice-card {
    grid-template-columns: 1fr;
  }
  .fewo-invoice-card__main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fewo-invoice-card__status {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
@media (max-width: 720px) {
  .fewo-admin-invoice-stats,
  .fewo-invoice-card__main {
    grid-template-columns: 1fr;
  }
  .fewo-invoice-card {
    padding: .8rem;
    border-radius: 18px;
  }
}

/* Admin Meldeschein status */
.fewo-admin-inline-status {
  display: inline-flex;
  margin-bottom: .25rem;
  padding: .24rem .55rem;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 850;
  border: 1px solid #e5ddd4;
  background: #fffdf9;
  color: #5f625e;
}
.fewo-admin-inline-status--ok {
  border-color: #cfe9d3;
  background: #f5fbf6;
  color: #1f6b38;
}
.fewo-admin-inline-status--open {
  border-color: #efd69b;
  background: #fff7e7;
  color: #7a5200;
}
.fewo-text-link {
  color: #b76d48;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: .18em;
}

/* Guest portal visual polish v2: robust layout for portal panels */
.fewo-guest-portal {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(.75rem, 2vw, 1.25rem);
  color: #202624;
}
.fewo-guest-portal .fewo-card {
  padding: clamp(1.15rem, 2.2vw, 1.7rem);
  border-radius: 24px;
  overflow: hidden;
}
.fewo-guest-portal .fewo-eyebrow {
  margin: 0 0 .45rem;
  color: #9b5837;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.fewo-guest-portal h2 {
  margin: 0 0 .55rem;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.75rem, 3.1vw, 3rem);
  line-height: 1.05;
  letter-spacing: -.03em;
  color: #202624;
}
.fewo-guest-portal h3 {
  margin: 0 0 .45rem;
  color: #202624;
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  line-height: 1.25;
}
.fewo-guest-portal .fewo-lead,
.fewo-guest-portal p {
  line-height: 1.62;
}
.fewo-guest-portal .fewo-lead {
  max-width: 76ch;
  margin: 0;
  color: #646a64;
  font-size: clamp(1rem, 1.45vw, 1.13rem);
}
.fewo-portal-section-head {
  margin-bottom: 1.15rem;
}
.fewo-portal-section-head h2 + .fewo-lead {
  margin-top: .35rem;
}
.fewo-portal-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.25rem;
  align-items: start;
}
.fewo-portal-hero h2 {
  font-size: clamp(2.1rem, 4vw, 3.65rem);
}
.fewo-portal-status {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  justify-content: flex-end;
}
.fewo-portal-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 1rem;
}
.fewo-portal-tags span {
  display: inline-flex;
  padding: .42rem .7rem;
  border-radius: 999px;
  border: 1px solid #eadfd4;
  background: #fff;
  color: #4f544e;
  font-size: .9rem;
  font-weight: 800;
}
.fewo-portal-nav {
  display: flex !important;
  flex-wrap: wrap;
  gap: .45rem;
  align-items: center;
  padding: .65rem;
  border: 1px solid #eadfd4;
  border-radius: 22px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 10px 28px rgba(32,38,36,.055);
}
.fewo-portal-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .5rem .75rem;
  border-radius: 999px;
  color: #9b5837;
  font-weight: 850;
  text-decoration: none;
}
.fewo-portal-nav a:hover,
.fewo-portal-nav a:focus-visible {
  background: #fff7ef;
}
.fewo-portal-overview .fewo-summary-grid,
.fewo-portal-summary-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.fewo-guest-portal .fewo-summary-item {
  padding: .9rem 1rem;
  border-radius: 16px;
  border: 1px solid #eee4db;
  background: #fffdfa;
}
.fewo-guest-portal .fewo-summary-item small,
.fewo-summary-item small {
  display: block;
  margin-top: .25rem;
  color: #6f756f;
  line-height: 1.35;
}
.fewo-portal-info-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
  align-items: stretch;
}
.fewo-portal-info-grid--compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fewo-portal-info-grid article {
  min-width: 0;
  display: grid !important;
  gap: .35rem;
  align-content: start;
  padding: .95rem 1rem;
  border: 1px solid #eee4db;
  border-radius: 18px;
  background: #fffdfa;
  box-shadow: 0 8px 18px rgba(32,38,36,.025);
}
.fewo-portal-info-grid article span,
.fewo-portal-info-grid article strong,
.fewo-portal-info-grid article small {
  display: block;
  min-width: 0;
}
.fewo-portal-info-grid article span {
  color: #9b5837;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1.2;
  text-transform: uppercase;
}
.fewo-portal-info-grid article strong {
  color: #202624;
  font-size: 1.04rem;
  line-height: 1.28;
}
.fewo-portal-info-grid article small {
  color: #6f756f;
  font-size: .9rem;
  line-height: 1.5;
}
.fewo-portal-route-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  margin-top: 1rem;
}
.fewo-portal-route-grid article {
  min-width: 0;
  padding: 1rem;
  border-radius: 20px;
  border: 1px solid #eadfd4;
  background: #fff;
}
.fewo-portal-route-grid p {
  margin: 0 0 .8rem;
  color: #60655f;
  line-height: 1.65;
}
.fewo-checkout-list {
  counter-reset: checkout;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.fewo-checkout-list li {
  counter-increment: checkout;
  display: grid;
  grid-template-columns: 2.15rem minmax(0,1fr);
  gap: .65rem;
  align-items: start;
  padding: .78rem .85rem;
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fff;
  color: #4f544e;
  line-height: 1.45;
}
.fewo-checkout-list li::before {
  content: counter(checkout);
  width: 2.15rem;
  height: 2.15rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #b76d48;
  color: #fff;
  font-weight: 900;
}
.fewo-help-card .fewo-portal-info-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fewo-help-card a {
  overflow-wrap: anywhere;
}
.fewo-registration-status {
  display: flex !important;
  flex-wrap: wrap;
  gap: .45rem .8rem;
  align-items: center;
}
.fewo-document-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: .85rem;
}
.fewo-document-link,
.fewo-document-link:visited {
  color: #202624 !important;
  text-decoration: none !important;
}
.fewo-document-link span,
.fewo-document-link strong,
.fewo-document-link small {
  display: block;
}
.fewo-bank-card,
.fewo-customer-payment-card,
.fewo-deposit-card,
.fewo-registration-notice,
.fewo-arrival-pass,
.fewo-help-card {
  border-color: #ead8cd;
}
@media (max-width: 980px) {
  .fewo-portal-hero,
  .fewo-portal-route-grid,
  .fewo-checkout-list {
    grid-template-columns: 1fr;
  }
  .fewo-portal-status {
    justify-content: flex-start;
  }
  .fewo-portal-info-grid,
  .fewo-portal-info-grid--compact,
  .fewo-help-card .fewo-portal-info-grid,
  .fewo-portal-overview .fewo-summary-grid,
  .fewo-portal-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .fewo-guest-portal {
    padding: .5rem;
  }
  .fewo-guest-portal .fewo-card {
    padding: 1rem;
    border-radius: 20px;
  }
  .fewo-portal-info-grid,
  .fewo-portal-info-grid--compact,
  .fewo-help-card .fewo-portal-info-grid,
  .fewo-portal-overview .fewo-summary-grid,
  .fewo-portal-summary-grid {
    grid-template-columns: 1fr;
  }
  .fewo-portal-nav {
    position: static;
  }
  .fewo-portal-nav a {
    flex: 1 1 calc(50% - .5rem);
    font-size: .88rem;
    padding: .55rem .45rem;
  }
  .fewo-checkout-list li {
    grid-template-columns: 1.9rem minmax(0,1fr);
  }
  .fewo-checkout-list li::before {
    width: 1.9rem;
    height: 1.9rem;
  }
}

/* Meldeschein customer form polish */
.fewo-registration-page {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: 1rem;
}
.fewo-registration-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.25rem;
  align-items: start;
  padding: clamp(1.25rem, 2.8vw, 2rem);
  border-radius: 28px;
  border: 1px solid #ead8cd;
  background: linear-gradient(135deg, #fffdfa, #fff7ef);
  box-shadow: 0 18px 48px rgba(32, 38, 36, .06);
}
.fewo-registration-hero h2 {
  margin: 0 0 .55rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2.1rem, 4.2vw, 4.2rem);
  line-height: .98;
  color: #202624;
}
.fewo-registration-hero .fewo-lead {
  max-width: 68ch;
}
.fewo-registration-hero__meta {
  min-width: 220px;
  display: grid;
  gap: .35rem;
  justify-items: end;
  padding: .85rem 1rem;
  border-radius: 18px;
  border: 1px solid #e7ddd4;
  background: #fff;
}
.fewo-registration-hero__meta span {
  color: #6f756f;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.fewo-registration-hero__meta strong {
  color: #202624;
  font-size: 1.05rem;
  word-break: break-word;
}
.fewo-registration-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
}
.fewo-registration-info-grid article {
  display: grid;
  gap: .35rem;
  padding: 1rem;
  border-radius: 20px;
  border: 1px solid #e8ded5;
  background: #fff;
}
.fewo-registration-info-grid span {
  width: 2.15rem;
  height: 2.15rem;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #f8e5d7;
  color: #9a5637;
  font-weight: 900;
  font-size: .78rem;
}
.fewo-registration-info-grid strong {
  color: #202624;
  font-size: 1rem;
}
.fewo-registration-info-grid p {
  margin: 0;
  color: #6f756f;
  line-height: 1.5;
  font-size: .95rem;
}
.fewo-registration-legal-note {
  padding: .95rem 1.1rem;
  border-radius: 18px;
  border: 1px solid #efd69b;
  background: #fff7e7;
  color: #775000;
  line-height: 1.55;
}
.fewo-registration-errors {
  border-radius: 18px;
}
.fewo-registration-form--clean {
  display: grid;
  gap: 1rem;
}
.fewo-registration-form--clean fieldset {
  all: unset;
}
.fewo-registration-panel {
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 2vw, 1.35rem);
  border-radius: 24px;
  border: 1px solid #e8ded5;
  background: #fff;
  box-shadow: 0 10px 28px rgba(32, 38, 36, .035);
}
.fewo-registration-panel--confirm {
  border-color: #ead8cd;
  background: linear-gradient(180deg, #fffdfa, #fff);
}
.fewo-registration-panel__head {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}
.fewo-registration-panel__head > span {
  width: 2.35rem;
  height: 2.35rem;
  flex: 0 0 2.35rem;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: #b76d48;
  color: #fff;
  font-weight: 900;
}
.fewo-registration-panel__head h3 {
  margin: 0;
  color: #202624;
  font-size: 1.28rem;
}
.fewo-registration-panel__head p {
  margin: .18rem 0 0;
  color: #6f756f;
  line-height: 1.5;
}
.fewo-registration-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
}
.fewo-registration-fields--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.fewo-reg-field {
  display: grid;
  gap: .42rem;
  min-width: 0;
  color: #202624;
  font-weight: 800;
}
.fewo-reg-field--wide,
.fewo-reg-field--textarea {
  grid-column: 1 / -1;
}
.fewo-reg-field > span {
  color: #6f756f;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.fewo-reg-field input,
.fewo-reg-field textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 3rem;
  padding: .75rem .85rem;
  border-radius: 14px;
  border: 1px solid #dcd5cf;
  background: #fff;
  color: #202624;
  font: inherit;
  font-weight: 650;
}
.fewo-reg-field input:focus,
.fewo-reg-field textarea:focus {
  outline: none;
  border-color: #b76d48;
  box-shadow: 0 0 0 4px rgba(183, 109, 72, .12);
}
.fewo-reg-field input[readonly] {
  background: #f7f3ee;
  color: #5f625e;
}
.fewo-registration-hint {
  margin: -.2rem 0 0;
  color: #6f756f;
  line-height: 1.55;
}
.fewo-registration-checks {
  display: grid;
  gap: .65rem;
}
.fewo-registration-checks label {
  display: flex;
  gap: .65rem;
  align-items: flex-start;
  padding: .85rem .95rem;
  border-radius: 16px;
  border: 1px solid #e8ded5;
  background: #fffdfa;
  color: #202624;
  font-weight: 750;
  line-height: 1.45;
}
.fewo-registration-checks--large label {
  background: #eef7ef;
  border-color: #d3ead7;
}
.fewo-registration-checks input {
  width: 1.15rem;
  height: 1.15rem;
  margin-top: .15rem;
  flex: 0 0 auto;
  accent-color: #b76d48;
}
.fewo-registration-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  align-items: center;
  padding: .4rem 0 0;
}
@media (max-width: 980px) {
  .fewo-registration-hero {
    grid-template-columns: 1fr;
  }
  .fewo-registration-hero__meta {
    justify-items: start;
    min-width: 0;
  }
  .fewo-registration-info-grid,
  .fewo-registration-fields--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 680px) {
  .fewo-registration-page {
    gap: .8rem;
  }
  .fewo-registration-info-grid,
  .fewo-registration-fields,
  .fewo-registration-fields--four {
    grid-template-columns: 1fr;
  }
  .fewo-registration-hero,
  .fewo-registration-panel {
    border-radius: 20px;
  }
  .fewo-registration-panel__head {
    gap: .65rem;
  }
  .fewo-registration-panel__head > span {
    width: 2rem;
    height: 2rem;
    flex-basis: 2rem;
  }
  .fewo-registration-actions .fewo-button {
    width: 100%;
    justify-content: center;
  }
}

/* Standalone Anreise-Pass */
.fewo-arrival-pass-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.fewo-arrival-pass-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  justify-content: flex-end;
  min-width: 220px;
}
.fewo-arrival-pass-page {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 2rem);
}
.fewo-arrival-pass-print {
  border-radius: 30px;
  padding: clamp(1.15rem, 2.6vw, 2rem);
  background: linear-gradient(180deg, #fffdfa, #fff);
}
.fewo-arrival-pass-print__header {
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
  align-items: flex-start;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid #eee4db;
}
.fewo-arrival-pass-print__header h1 {
  margin: 0;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(2.1rem, 5vw, 4rem);
  line-height: 1.02;
  color: #202624;
}
.fewo-arrival-pass-print__status {
  flex: 0 0 auto;
  display: grid;
  gap: .25rem;
  min-width: min(320px, 100%);
  padding: .9rem 1rem;
  border-radius: 18px;
  border: 1px solid #ead8cd;
  background: #fff7ef;
  text-align: right;
}
.fewo-arrival-pass-print__status span {
  color: #9b5837;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .78rem;
}
.fewo-arrival-pass-print__status strong {
  color: #202624;
  font-size: 1.05rem;
}
.fewo-arrival-pass-ready-grid,
.fewo-arrival-pass-main-grid,
.fewo-arrival-pass-route-grid {
  display: grid;
  gap: .8rem;
}
.fewo-arrival-pass-ready-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 1rem;
}
.fewo-arrival-pass-ready-grid article,
.fewo-arrival-pass-main-grid section,
.fewo-arrival-pass-route-grid article,
.fewo-pass-checklist,
.fewo-pass-open-payments {
  border: 1px solid #eee4db;
  border-radius: 20px;
  background: #fff;
  padding: 1rem;
}
.fewo-arrival-pass-ready-grid article {
  border-left: 6px solid #d39b23;
}
.fewo-arrival-pass-ready-grid article.is-done {
  border-left-color: #3b8a52;
  background: #f6fbf7;
}
.fewo-arrival-pass-ready-grid article.is-open {
  border-left-color: #d39b23;
  background: #fffaf0;
}
.fewo-arrival-pass-ready-grid span,
.fewo-pass-data-list dt {
  display: block;
  color: #7a746b;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.fewo-arrival-pass-ready-grid strong {
  display: block;
  margin: .2rem 0;
  color: #202624;
  font-size: 1.1rem;
}
.fewo-arrival-pass-ready-grid small {
  color: #6f756f;
  line-height: 1.45;
}
.fewo-arrival-pass-main-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: .8rem;
}
.fewo-arrival-pass-main-grid h2,
.fewo-pass-checklist h2,
.fewo-pass-open-payments h2 {
  margin: 0 0 .7rem;
  color: #202624;
  font-size: 1.28rem;
}
.fewo-pass-data-list {
  display: grid;
  gap: .65rem;
  margin: 0;
}
.fewo-pass-data-list div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: .75rem;
  padding-bottom: .55rem;
  border-bottom: 1px solid #f1e8df;
}
.fewo-pass-data-list div:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.fewo-pass-data-list dd {
  margin: 0;
  color: #202624;
  font-weight: 650;
  line-height: 1.45;
}
.fewo-pass-checklist {
  margin-bottom: .8rem;
  background: #fffdfa;
}
.fewo-pass-checklist ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .55rem;
}
.fewo-pass-checklist li {
  position: relative;
  padding-left: 1.35rem;
  color: #5f625e;
  line-height: 1.55;
}
.fewo-pass-checklist li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  color: #b76d48;
  font-weight: 900;
}
.fewo-arrival-pass-route-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fewo-arrival-pass-route-grid h3 {
  margin: 0 0 .45rem;
  color: #202624;
  font-size: 1.08rem;
}
.fewo-arrival-pass-route-grid p {
  margin: 0;
  color: #5f625e;
  line-height: 1.55;
}
.fewo-pass-open-payments {
  margin-top: .8rem;
  background: #fff7e7;
  border-color: #efd69b;
}
.fewo-arrival-pass-actions-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1rem;
}
@media (max-width: 900px) {
  .fewo-arrival-pass-head,
  .fewo-arrival-pass-print__header {
    display: grid;
  }
  .fewo-arrival-pass-actions,
  .fewo-arrival-pass-print__status {
    justify-content: flex-start;
    text-align: left;
  }
  .fewo-arrival-pass-ready-grid,
  .fewo-arrival-pass-main-grid,
  .fewo-arrival-pass-route-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .fewo-pass-data-list div {
    grid-template-columns: 1fr;
    gap: .2rem;
  }
  .fewo-arrival-pass-actions-bar .fewo-button,
  .fewo-arrival-pass-actions .fewo-button {
    width: 100%;
  }
}
@media print {
  .site-header,
  .site-footer,
  .fewo-portal-nav,
  .fewo-arrival-pass-actions-bar,
  .fewo-arrival-pass-actions,
  .whatsapp-floating {
    display: none !important;
  }
  .fewo-arrival-pass-page {
    padding: 0;
    max-width: none;
  }
  .fewo-arrival-pass-print {
    box-shadow: none !important;
    border: 0 !important;
    padding: 0;
  }
  .fewo-arrival-pass-print__header h1 {
    font-size: 34pt;
  }
  .fewo-arrival-pass-ready-grid,
  .fewo-arrival-pass-main-grid,
  .fewo-arrival-pass-route-grid {
    break-inside: avoid;
  }
}

/* Deposit protocol workflow */
.fewo-admin-deposit-protocol-form {
  display: grid;
  gap: 1rem;
}
.fewo-admin-deposit-protocol,
.fewo-admin-deposit-settlement {
  display: grid;
  gap: .85rem;
  padding: .9rem;
  border: 1px solid #eee4db;
  border-radius: 16px;
  background: #fff;
}
.fewo-admin-deposit-section-title {
  display: flex;
  justify-content: space-between;
  gap: .8rem;
  align-items: flex-start;
}
.fewo-admin-deposit-section-title strong {
  color: #202624;
  font-size: 1rem;
}
.fewo-admin-deposit-section-title span {
  color: #7a7169;
  font-size: .86rem;
  line-height: 1.45;
  text-align: right;
}
.fewo-admin-deposit-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .7rem;
}
.fewo-admin-deposit-fields--settlement {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.fewo-admin-deposit-fields label,
.fewo-admin-deposit-textareas label {
  display: grid;
  gap: .35rem;
  color: #202624;
  font-weight: 800;
  font-size: .88rem;
}
.fewo-admin-deposit-fields input,
.fewo-admin-deposit-fields select,
.fewo-admin-deposit-textareas textarea {
  width: 100%;
  box-sizing: border-box;
  padding: .62rem .68rem;
  border: 1px solid #cfc5ba;
  border-radius: 10px;
  background: #fff;
  color: #202624;
  font: inherit;
}
.fewo-admin-check-section {
  display: grid;
  gap: .45rem;
}
.fewo-admin-check-section > strong {
  color: #202624;
}
.fewo-admin-check-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .55rem;
}
.fewo-admin-check-grid label,
.fewo-admin-protocol-complete {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  padding: .58rem .65rem;
  border: 1px solid #eee4db;
  border-radius: 12px;
  background: #fffdfa;
  color: #4e564f;
  line-height: 1.4;
  font-weight: 750;
}
.fewo-admin-check-grid input,
.fewo-admin-protocol-complete input {
  margin-top: .18rem;
}
.fewo-admin-deposit-textareas {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}
.fewo-admin-deposit-textareas--wide {
  grid-column: 1 / -1;
}
.fewo-admin-protocol-complete {
  border-color: #ddc79d;
  background: #fff9ed;
}
.fewo-admin-deposit-action-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: center;
}
@media (max-width: 1100px) {
  .fewo-admin-deposit-fields,
  .fewo-admin-deposit-fields--settlement,
  .fewo-admin-check-grid,
  .fewo-admin-deposit-textareas {
    grid-template-columns: 1fr;
  }
  .fewo-admin-deposit-section-title {
    display: grid;
  }
  .fewo-admin-deposit-section-title span {
    text-align: left;
  }
  .fewo-admin-deposit-action-buttons .fewo-button {
    width: 100%;
    justify-content: center;
  }
}

/* Saisonpreise / Sonderpreise im Admin */
.fewo-pricing-rule-note {
  margin-bottom: 1rem;
}
.fewo-checkbox-line {
  display: flex !important;
  align-items: center;
  gap: .55rem;
  min-height: 2.75rem;
  font-weight: 800;
}
.fewo-checkbox-line input[type="checkbox"] {
  width: auto;
  min-width: 1.05rem;
}
.fewo-pricing-rule-list {
  display: grid;
  gap: .85rem;
  margin-top: .75rem;
}
.fewo-pricing-rule-card {
  padding: 1rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 18px;
  background: #fffdf9;
}
.fewo-pricing-rule-card--inactive {
  opacity: .72;
  background: #faf7f2;
}
.fewo-pricing-rule-card header,
.fewo-pricing-preview-result {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .8rem;
  align-items: start;
}
.fewo-pricing-rule-card header strong,
.fewo-pricing-rule-price strong,
.fewo-pricing-preview-result strong {
  display: block;
}
.fewo-pricing-rule-card header small,
.fewo-pricing-rule-price small,
.fewo-pricing-preview-result small {
  color: #6f736b;
}
.fewo-pricing-rule-status {
  display: inline-flex;
  align-items: center;
  margin: 0 0 .35rem;
  padding: .18rem .5rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.fewo-pricing-rule-status--active {
  background: #e4f4e8;
  color: #1f6b38;
}
.fewo-pricing-rule-status--inactive {
  background: #eee9e2;
  color: #686b65;
}
.fewo-pricing-rule-price {
  text-align: right;
}
.fewo-pricing-rule-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin: .8rem 0;
}
.fewo-pricing-rule-meta span {
  display: inline-flex;
  padding: .28rem .55rem;
  border-radius: 999px;
  background: #f6eee7;
  color: #50544d;
  font-size: .86rem;
  font-weight: 800;
}
.fewo-pricing-rule-edit {
  margin-top: .55rem;
}
.fewo-pricing-rule-edit summary {
  cursor: pointer;
  font-weight: 900;
}
.fewo-pricing-rule-edit form {
  margin-top: .75rem;
}
.fewo-pricing-rule-delete {
  margin-top: .7rem;
}
.fewo-pricing-preview-heading {
  margin-top: 1.25rem;
}
.fewo-pricing-preview-result {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: .85rem;
  padding: 1rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 18px;
  background: #fff;
}
.fewo-pricing-preview-result span {
  display: block;
  color: #73766f;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.fewo-pricing-preview-table {
  margin-top: .75rem;
}
@media (max-width: 760px) {
  .fewo-pricing-rule-card header,
  .fewo-pricing-preview-result {
    grid-template-columns: 1fr;
  }
  .fewo-pricing-rule-price {
    text-align: left;
  }
}

/* Angebotsfunktion vor Buchung */
.fewo-offer-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  margin-top: .5rem;
  border: 1px solid rgba(183,109,72,.24);
  border-radius: 18px;
  background: linear-gradient(135deg, #fffaf6, #f8efe7);
}
.fewo-offer-box strong {
  display: block;
  margin-bottom: .2rem;
  color: var(--dark, #202624);
}
.fewo-offer-box p {
  margin: 0;
  color: var(--muted, #666);
  font-size: .94rem;
  line-height: 1.5;
}
.fewo-confirmation--offer .fewo-confirmation-icon {
  background: #f1e7da;
  color: #7a4f32;
}
.fewo-offer-dashboard {
  scroll-margin-top: 1rem;
}
.fewo-offer-list {
  display: grid;
  gap: 1rem;
}
.fewo-offer-card {
  padding: 1rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(32,32,32,.06);
}
.fewo-offer-card--requested {
  border-color: rgba(183,109,72,.28);
}
.fewo-offer-card--sent {
  border-color: rgba(47,111,68,.26);
}
.fewo-offer-card--closed {
  opacity: .78;
}
.fewo-offer-card__main {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr 1.35fr 1fr .9fr;
  gap: 1rem;
  align-items: start;
}
.fewo-offer-card__main > div {
  min-width: 0;
}
.fewo-offer-card__main small {
  display: block;
  margin-top: .2rem;
  color: #74786f;
  line-height: 1.35;
  word-break: break-word;
}
.fewo-offer-card__note {
  margin: 1rem 0 0;
  padding: .75rem .9rem;
  border-radius: 14px;
  background: #f7f2ed;
  color: #4b504a;
  line-height: 1.5;
  white-space: pre-wrap;
}
.fewo-offer-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 1rem;
  align-items: center;
}
.fewo-offer-card__actions form {
  margin: 0;
}
.fewo-badge-offer {
  border: 1px solid rgba(32,32,32,.1);
}
.fewo-badge-requested {
  background: #fff7e7;
  color: #8a5a00;
  border-color: #efd69b;
}
.fewo-badge-sent {
  background: #edf8ef;
  color: #20663b;
  border-color: #cde8d4;
}
.fewo-badge-closed {
  background: #f3f3f0;
  color: #686d66;
  border-color: #ddd8d1;
}
.fewo-offer-page {
  max-width: 920px;
  margin: 2rem auto;
}
@media (max-width: 980px) {
  .fewo-offer-card__main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-offer-box {
    align-items: stretch;
    flex-direction: column;
  }
  .fewo-offer-box .fewo-button {
    width: 100%;
  }
  .fewo-offer-card__main {
    grid-template-columns: 1fr;
  }
  .fewo-offer-card__actions,
  .fewo-offer-card__actions form,
  .fewo-offer-card__actions .fewo-button {
    width: 100%;
  }
}
.fewo-offer-create {
  margin: 1rem 0;
  padding: .85rem 1rem;
  border: 1px dashed rgba(32,32,32,.18);
  border-radius: 16px;
  background: #fffaf6;
}
.fewo-offer-create summary,
.fewo-offer-send-panel summary {
  cursor: pointer;
  font-weight: 900;
}
.fewo-offer-create-form,
.fewo-offer-send-panel form {
  margin-top: .85rem;
}
.fewo-offer-send-panel {
  min-width: min(480px, 100%);
}
.fewo-badge-booked {
  background: #edf8ef;
  color: #20663b;
  border-color: #cde8d4;
}
@media (max-width: 760px) {
  .fewo-offer-send-panel {
    width: 100%;
  }
}

.fewo-offer-card--expired,
.fewo-offer-card--closed {
  opacity: .78;
}
.fewo-offer-card--booked {
  border-color: rgba(47,111,68,.26);
}
.fewo-badge-expired {
  background: #fff2e6;
  color: #8a4d00;
  border-color: #f0c89c;
}
.fewo-offer-hero {
  display: flex;
  justify-content: space-between;
  gap: 1.2rem;
  align-items: center;
}
.fewo-offer-total {
  min-width: 220px;
  padding: 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(32,32,32,.08);
  text-align: right;
}
.fewo-offer-total span,
.fewo-offer-total small {
  display: block;
  color: #6d716a;
  font-weight: 800;
}
.fewo-offer-total strong {
  display: block;
  margin: .25rem 0;
  font-size: 1.45rem;
  color: #202624;
}
.fewo-offer-note {
  margin-top: 1rem;
  padding: .85rem 1rem;
  border-radius: 16px;
  background: #f7f2ed;
  color: #4b504a;
  line-height: 1.55;
}
.fewo-offer-accept-card {
  border: 1px solid rgba(47,111,68,.18);
}
.fewo-offer-price-total-row {
  font-weight: 900;
  background: rgba(47,111,68,.07);
}
.fewo-offer-success {
  max-width: 760px;
  margin: 2rem auto;
}
@media (max-width: 760px) {
  .fewo-offer-hero {
    align-items: stretch;
    flex-direction: column;
  }
  .fewo-offer-total {
    min-width: 0;
    text-align: left;
  }
}

/* Gastkommunikation Timeline */
.fewo-communication-panel {
  display: grid;
  gap: 1rem;
}
.fewo-communication-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  padding: 1rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 18px;
  background: linear-gradient(135deg, #fffaf6, #f7f2ed);
}
.fewo-communication-head strong {
  display: block;
  margin-bottom: .25rem;
  color: #202624;
  font-size: 1.05rem;
}
.fewo-communication-head p {
  margin: 0;
  max-width: 72ch;
  color: #626862;
  line-height: 1.5;
}
.fewo-communication-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: flex-end;
}
.fewo-communication-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 1rem;
  align-items: start;
}
.fewo-communication-timeline-wrap,
.fewo-communication-form {
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(32,32,32,.045);
}
.fewo-communication-timeline-wrap {
  padding: 1rem;
}
.fewo-communication-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .85rem;
}
.fewo-communication-item {
  display: grid;
  grid-template-columns: 2.4rem minmax(0, 1fr);
  gap: .75rem;
  position: relative;
}
.fewo-communication-item + .fewo-communication-item::before {
  content: "";
  position: absolute;
  left: 1.18rem;
  top: -1rem;
  width: 2px;
  height: 1.05rem;
  background: rgba(32,32,32,.1);
}
.fewo-communication-marker {
  width: 2.4rem;
  height: 2.4rem;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #f7f2ed;
  border: 1px solid rgba(32,32,32,.08);
  color: #6b4b36;
  font-weight: 900;
  font-size: .78rem;
}
.fewo-communication-item--email .fewo-communication-marker,
.fewo-communication-item--manual .fewo-communication-marker {
  background: #f8efe7;
  color: #935b39;
}
.fewo-communication-item--payment .fewo-communication-marker,
.fewo-communication-item--guest_action .fewo-communication-marker,
.fewo-communication-item--deposit .fewo-communication-marker {
  background: #edf8ef;
  color: #24683d;
}
.fewo-communication-item--warning .fewo-communication-marker,
.fewo-communication-item--task .fewo-communication-marker {
  background: #fff7e7;
  color: #8a5a00;
}
.fewo-communication-content {
  min-width: 0;
  padding: .9rem 1rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 16px;
  background: #fff;
}
.fewo-communication-item-head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: flex-start;
}
.fewo-communication-item-head time,
.fewo-guest-communication-item time {
  display: block;
  margin-bottom: .16rem;
  color: #7a7f78;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.fewo-communication-item-head strong,
.fewo-guest-communication-item strong {
  display: block;
  color: #202624;
  line-height: 1.25;
}
.fewo-communication-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .35rem;
}
.fewo-communication-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 1.6rem;
  padding: .18rem .55rem;
  border-radius: 999px;
  border: 1px solid rgba(32,32,32,.08);
  background: #f7f2ed;
  color: #626862;
  font-size: .75rem;
  font-weight: 900;
}
.fewo-communication-badges .fewo-communication-visible {
  background: #edf8ef;
  color: #24683d;
  border-color: #cde8d4;
}
.fewo-communication-meta {
  display: block;
  margin-top: .4rem;
  color: #777c75;
  font-size: .84rem;
  line-height: 1.45;
}
.fewo-communication-content p {
  margin: .55rem 0 0;
  color: #4b504a;
  line-height: 1.55;
  white-space: normal;
}
.fewo-communication-followup {
  padding: .55rem .7rem;
  border-radius: 12px;
  background: #fff7e7;
  color: #775000 !important;
}
.fewo-communication-delete {
  margin-top: .45rem;
}
.fewo-communication-form {
  display: grid;
  gap: .75rem;
  padding: 1rem;
  position: sticky;
  top: 1rem;
}
.fewo-communication-form h4 {
  margin: 0;
  color: #202624;
}
.fewo-communication-form label {
  display: grid;
  gap: .35rem;
  font-weight: 900;
  color: #3d433d;
}
.fewo-communication-form input,
.fewo-communication-form select,
.fewo-communication-form textarea {
  width: 100%;
  border: 1px solid rgba(32,32,32,.14);
  border-radius: 12px;
  padding: .65rem .75rem;
  font: inherit;
  background: #fff;
}
.fewo-communication-form textarea {
  resize: vertical;
}
.fewo-communication-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
.fewo-communication-form-grid--bottom {
  align-items: end;
}
.fewo-communication-checkbox {
  align-self: end;
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: row;
  gap: .55rem !important;
  align-items: center;
  min-height: 2.65rem;
}
.fewo-communication-checkbox input {
  width: auto;
}
.fewo-guest-timeline-card {
  overflow: hidden;
}
.fewo-guest-communication-timeline {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  gap: .8rem;
}
.fewo-guest-communication-item {
  display: grid;
  grid-template-columns: 2.25rem minmax(0, 1fr);
  gap: .75rem;
  padding: .85rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 16px;
  background: #fff;
}
.fewo-guest-communication-marker {
  width: 2.25rem;
  height: 2.25rem;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #f8efe7;
  color: #935b39;
  font-weight: 900;
  font-size: .78rem;
}
.fewo-guest-communication-item--payment .fewo-guest-communication-marker,
.fewo-guest-communication-item--guest_action .fewo-guest-communication-marker,
.fewo-guest-communication-item--deposit .fewo-guest-communication-marker {
  background: #edf8ef;
  color: #24683d;
}
.fewo-guest-communication-item p {
  margin: .35rem 0 0;
  color: #626862;
  line-height: 1.5;
}
.fewo-guest-communication-item small {
  display: inline-block;
  margin-top: .45rem;
  padding: .15rem .5rem;
  border-radius: 999px;
  background: #f7f2ed;
  color: #626862;
  font-weight: 900;
}
@media (max-width: 1040px) {
  .fewo-communication-grid {
    grid-template-columns: 1fr;
  }
  .fewo-communication-form {
    position: static;
  }
}
@media (max-width: 720px) {
  .fewo-communication-head,
  .fewo-communication-item-head {
    flex-direction: column;
  }
  .fewo-communication-actions,
  .fewo-communication-actions .fewo-button {
    width: 100%;
  }
  .fewo-communication-badges {
    justify-content: flex-start;
  }
  .fewo-communication-form-grid {
    grid-template-columns: 1fr;
  }
}

/* Security & Mobile Hardening – kompaktere Smartphone-Ansicht */
@media (max-width: 760px) {
  .fewo-page {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
    padding: .75rem;
  }
  .fewo-page > h1 {
    margin-bottom: .75rem;
    font-size: clamp(1.65rem, 9vw, 2.15rem);
  }
  .fewo-admin-hero,
  .fewo-admin-card,
  .fewo-admin-next,
  .fewo-stat-card,
  .fewo-offer-card,
  .fewo-communication-head,
  .fewo-communication-timeline-wrap,
  .fewo-communication-form,
  .fewo-admin-deposit-protocol,
  .fewo-admin-deposit-settlement {
    border-radius: 18px;
  }
  .fewo-admin-hero,
  .fewo-admin-card,
  .fewo-offer-card,
  .fewo-communication-timeline-wrap,
  .fewo-communication-form,
  .fewo-admin-deposit-protocol,
  .fewo-admin-deposit-settlement {
    padding: .85rem;
  }
  .fewo-admin-hero h2,
  .fewo-admin-section-head h2 {
    font-size: clamp(1.35rem, 7vw, 1.75rem);
  }
  .fewo-admin-hero-actions,
  .fewo-admin-hero-actions .fewo-button,
  .fewo-admin-hero-actions .fewo-inline-form,
  .fewo-admin-hero-actions .fewo-inline-form .fewo-button,
  .fewo-admin-section-head,
  .fewo-admin-filter-actions,
  .fewo-admin-filter-actions .fewo-button,
  .fewo-admin-deposit-action-buttons,
  .fewo-admin-deposit-action-buttons .fewo-button,
  .fewo-admin-invoice-actions,
  .fewo-admin-invoice-actions form,
  .fewo-admin-invoice-actions .fewo-button,
  .fewo-actions,
  .fewo-actions form,
  .fewo-actions .fewo-button,
  .fewo-actions button,
  .fewo-actions select,
  .fewo-offer-card__actions,
  .fewo-offer-card__actions form,
  .fewo-offer-card__actions .fewo-button,
  .fewo-communication-actions,
  .fewo-communication-actions .fewo-button,
  .fewo-communication-form .fewo-button {
    width: 100%;
  }
  .fewo-admin-hero-actions,
  .fewo-admin-section-head,
  .fewo-admin-filter-actions,
  .fewo-admin-deposit-action-buttons,
  .fewo-admin-invoice-actions,
  .fewo-actions,
  .fewo-offer-card__actions,
  .fewo-communication-actions {
    align-items: stretch;
  }
  .fewo-button,
  .fewo-admin-nav a,
  .fewo-actions button {
    min-height: 44px;
    justify-content: center;
  }
  .fewo-admin-nav {
    display: flex;
    gap: .35rem;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    border-radius: 18px;
    padding: .35rem;
    -webkit-overflow-scrolling: touch;
  }
  .fewo-admin-nav a {
    flex: 0 0 auto;
    scroll-snap-align: start;
    white-space: nowrap;
    padding-inline: .75rem;
  }
  .fewo-admin-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .6rem;
  }
  .fewo-stat-card {
    padding: .75rem;
  }
  .fewo-stat-card strong {
    font-size: 1.45rem;
  }
  .fewo-table-scroll {
    margin-inline: -.85rem;
    padding-inline: .85rem;
  }
  .fewo-table th,
  .fewo-table td {
    padding: .62rem .55rem;
    vertical-align: top;
  }
  .fewo-table td {
    font-size: .9rem;
  }
  .fewo-admin-details--managed > summary,
  .fewo-admin-accordion-item > summary {
    align-items: flex-start;
    gap: .6rem;
    padding: .8rem .9rem;
  }
  .fewo-admin-accordion-body {
    padding: .8rem;
  }
  .fewo-admin-detail-grid,
  .fewo-admin-log-grid,
  .fewo-admin-filter-form,
  .fewo-admin-form,
  .fewo-grid-form,
  .fewo-admin-deposit-fields,
  .fewo-admin-deposit-fields--settlement,
  .fewo-admin-deposit-textareas,
  .fewo-admin-check-grid,
  .fewo-communication-form-grid,
  .fewo-offer-card__main,
  .fewo-pricing-preview-result {
    grid-template-columns: 1fr !important;
  }
  .fewo-admin-payment-head,
  .fewo-admin-deposit-head,
  .fewo-admin-invoice-head,
  .fewo-communication-head,
  .fewo-offer-hero,
  .fewo-pricing-rule-card header {
    display: grid;
    grid-template-columns: 1fr;
    text-align: left;
  }
  .fewo-admin-payment-head > strong,
  .fewo-admin-deposit-head > span,
  .fewo-admin-invoice-head > span,
  .fewo-offer-total,
  .fewo-pricing-rule-price {
    justify-self: stretch;
    text-align: left;
  }
  .fewo-communication-item {
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: .55rem;
  }
  .fewo-communication-item + .fewo-communication-item::before {
    left: .98rem;
  }
  .fewo-communication-marker,
  .fewo-guest-communication-marker {
    width: 2rem;
    height: 2rem;
  }
  .fewo-communication-content {
    padding: .75rem;
    border-radius: 14px;
  }
  .fewo-communication-item-head {
    gap: .45rem;
  }
  .fewo-communication-badges {
    justify-content: flex-start;
  }
  .fewo-guest-communication-item {
    grid-template-columns: 2rem minmax(0, 1fr);
    padding: .75rem;
  }
}

@media (max-width: 480px) {
  .fewo-admin-stats {
    grid-template-columns: 1fr;
  }
  .fewo-admin-next {
    display: grid;
    padding: .85rem;
  }
  .fewo-badge {
    white-space: normal;
    line-height: 1.2;
  }
  .fewo-communication-item,
  .fewo-guest-communication-item {
    grid-template-columns: 1fr;
  }
  .fewo-communication-item + .fewo-communication-item::before {
    display: none;
  }
}

/* Security/mobile hardening – kompakter Admin auf Smartphones */
@media (max-width: 760px) {
  .fewo-page {
    padding: .85rem;
  }
  .fewo-page > h1 {
    font-size: clamp(1.75rem, 10vw, 2.35rem);
    line-height: 1.05;
  }
  .fewo-admin-hero,
  .fewo-admin-card,
  .fewo-booking-card {
    border-radius: 18px;
  }
  .fewo-admin-hero {
    padding: 1rem;
    align-items: start;
  }
  .fewo-admin-hero-actions,
  .fewo-admin-section-head,
  .fewo-admin-payment-head,
  .fewo-admin-deposit-head {
    align-items: flex-start;
  }
  .fewo-admin-hero-actions .fewo-button,
  .fewo-admin-section-head .fewo-button,
  .fewo-admin-filter-actions .fewo-button,
  .fewo-admin-invoice-actions .fewo-button,
  .fewo-admin-deposit-actions .fewo-button,
  .fewo-offer-card__actions .fewo-button,
  .fewo-actions .fewo-button,
  .fewo-actions .fewo-button-small {
    width: 100%;
    min-height: 44px;
    justify-content: center;
  }
  .fewo-admin-nav {
    position: static;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: .35rem;
    overflow-x: auto;
    overflow-y: hidden;
    border-radius: 18px;
    padding: .35rem;
    scroll-snap-type: x proximity;
  }
  .fewo-admin-nav a {
    flex: 0 0 auto !important;
    white-space: nowrap;
    text-align: center;
    scroll-snap-align: start;
    padding: .55rem .75rem;
  }
  .fewo-admin-card,
  .fewo-booking-card__payment,
  .fewo-booking-card__actions,
  .fewo-communication-form,
  .fewo-admin-deposit-protocol-form {
    padding: .85rem;
  }
  .fewo-grid-form,
  .fewo-admin-form,
  .fewo-admin-filter-form,
  .fewo-pricing-preview-form,
  .fewo-pricing-rule-form,
  .fewo-offer-create-form,
  .fewo-admin-deposit-protocol-form,
  .fewo-admin-check-grid,
  .fewo-admin-invoice-grid {
    grid-template-columns: 1fr !important;
  }
  .fewo-table-scroll {
    margin-inline: -.25rem;
    padding-bottom: .35rem;
  }
  .fewo-table th,
  .fewo-table td {
    padding: .55rem;
  }
  .fewo-actions,
  .fewo-admin-deposit-actions,
  .fewo-admin-invoice-actions,
  .fewo-offer-card__actions {
    grid-template-columns: 1fr !important;
    width: 100%;
  }
  .fewo-actions form,
  .fewo-admin-deposit-actions form,
  .fewo-offer-card__actions form {
    width: 100%;
  }
  .fewo-communication-item {
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: .55rem;
  }
  .fewo-communication-marker,
  .fewo-guest-communication-marker {
    width: 2rem;
    height: 2rem;
  }
  .fewo-communication-content {
    padding: .75rem;
    border-radius: 14px;
  }
}

@media (max-width: 420px) {
  .fewo-page {
    padding: .65rem;
  }
  .fewo-admin-card,
  .fewo-booking-card,
  .fewo-card {
    border-radius: 16px;
  }
  .fewo-stat-card strong,
  .fewo-admin-amount-overview > strong {
    font-size: 1.45rem;
  }
  .fewo-communication-item,
  .fewo-guest-communication-item {
    grid-template-columns: 1fr;
  }
  .fewo-communication-marker,
  .fewo-guest-communication-marker {
    margin-bottom: -.15rem;
  }
}

/* Security & mobile hardening, 2026-06-01 */
@media (max-width: 760px) {
  .fewo-page {
    padding: .75rem;
  }
  .fewo-page > h1 {
    font-size: clamp(1.75rem, 9vw, 2.35rem);
  }
  .fewo-admin-hero,
  .fewo-admin-card,
  .fewo-booking-card,
  .fewo-card {
    border-radius: 18px;
  }
  .fewo-admin-hero {
    padding: 1rem;
  }
  .fewo-admin-hero-actions,
  .fewo-admin-section-head,
  .fewo-action-row,
  .fewo-admin-invoice-actions,
  .fewo-admin-deposit-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .fewo-action-row > *,
  .fewo-admin-hero-actions > *,
  .fewo-admin-invoice-actions > *,
  .fewo-admin-deposit-actions > *,
  .fewo-admin-invoice-actions form,
  .fewo-admin-deposit-actions form {
    width: 100%;
  }
  .fewo-button,
  .fewo-button-small,
  .fewo-actions .fewo-button,
  .fewo-actions .fewo-button-small {
    min-height: 44px;
    justify-content: center;
    text-align: center;
  }
  .fewo-admin-nav {
    display: flex;
    flex-wrap: nowrap;
    gap: .35rem;
    overflow-x: auto;
    border-radius: 16px;
    padding: .4rem;
    scroll-snap-type: x proximity;
  }
  .fewo-admin-nav a {
    flex: 0 0 auto;
    min-height: 42px;
    white-space: nowrap;
    scroll-snap-align: start;
  }
  .fewo-admin-details--managed > summary {
    align-items: flex-start;
    flex-direction: column;
    gap: .35rem;
    padding: .85rem;
  }
  .fewo-admin-details--managed > summary small {
    text-align: left;
  }
  .fewo-admin-accordion-item > summary {
    padding: .8rem .85rem;
  }
  .fewo-admin-accordion-body {
    padding: .8rem;
  }
  .fewo-admin-detail-grid,
  .fewo-admin-log-grid,
  .fewo-grid-form,
  .fewo-admin-form,
  .fewo-precheckin-fields,
  .fewo-registration-fields,
  .fewo-admin-invoice-grid,
  .fewo-admin-deposit-grid {
    grid-template-columns: 1fr !important;
  }
  .fewo-grid-form .fewo-full,
  .fewo-admin-form .fewo-full {
    grid-column: auto;
  }
  .fewo-admin-form,
  .fewo-actions form {
    padding: .75rem;
  }
  .fewo-communication-item,
  .fewo-guest-communication-item {
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: .6rem;
  }
  .fewo-communication-marker,
  .fewo-guest-communication-marker {
    width: 2rem;
    height: 2rem;
    font-size: .72rem;
  }
  .fewo-communication-content {
    padding: .75rem;
    border-radius: 14px;
  }
  .fewo-communication-item-head {
    gap: .45rem;
  }
  .fewo-communication-badges span {
    min-height: 1.45rem;
    font-size: .7rem;
  }
  .fewo-payment-step,
  .fewo-payment-steps--compact .fewo-payment-step {
    grid-template-columns: 1fr;
  }
  .fewo-table-scroll {
    margin-inline: -.35rem;
    padding-inline: .35rem;
  }
}

@media (max-width: 480px) {
  .fewo-admin-card,
  .fewo-card {
    padding: .8rem;
  }
  .fewo-admin-nav {
    margin: .75rem 0;
  }
  .fewo-admin-nav a {
    font-size: .86rem;
    padding-inline: .7rem;
  }
  .fewo-stat-card strong,
  .fewo-admin-amount-overview > strong {
    font-size: 1.45rem;
  }
  .fewo-booking-card__number {
    font-size: 1rem;
  }
  .fewo-communication-content p,
  .fewo-guest-communication-item p {
    font-size: .9rem;
  }
}

/* Owner open-tasks e-mail controls */
.fewo-task-mail-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .9rem;
  margin: 1rem 0 0;
  padding: .85rem .95rem;
  border: 1px solid #eee4db;
  border-radius: 18px;
  background: #fff;
}
.fewo-task-mail-status strong {
  display: block;
  color: #202624;
  font-size: .95rem;
}
.fewo-task-mail-status span {
  display: block;
  color: #6f756f;
  font-size: .84rem;
  line-height: 1.4;
}
.fewo-task-panel--docs header > span,
.fewo-task-panel--offer header > span {
  background: #fff7e7;
  color: #8a5a00;
}
.fewo-task-panel--invoice header > span {
  background: #f2eef7;
  color: #5b3a73;
}
@media (max-width: 760px) {
  .fewo-task-mail-status {
    align-items: stretch;
    flex-direction: column;
  }
  .fewo-task-mail-status .fewo-inline-form,
  .fewo-task-mail-status .fewo-button {
    width: 100%;
  }
}


/* Admin booking creation, 2026-06-01 */
.fewo-admin-booking-create {
  scroll-margin-top: 1rem;
}
.fewo-admin-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .45rem .7rem;
  border: 1px solid rgba(32,32,32,.12);
  border-radius: 999px;
  background: #f7f2ed;
  color: #4b504a;
  font-size: .86rem;
  font-weight: 800;
  white-space: nowrap;
}
.fewo-admin-booking-panel {
  margin-top: 1rem;
  padding: .9rem 1rem;
  border: 1px dashed rgba(32,32,32,.18);
  border-radius: 18px;
  background: #fffaf6;
}
.fewo-admin-booking-panel > summary,
.fewo-admin-subdetails > summary {
  cursor: pointer;
  font-weight: 900;
}
.fewo-admin-booking-form {
  margin-top: .9rem;
}
.fewo-admin-availability {
  display: grid;
  gap: .2rem;
  padding: .85rem .95rem;
  border: 1px solid #ddd2c6;
  border-radius: 14px;
  background: #fff;
  color: #4b504a;
  align-self: stretch;
}
.fewo-admin-availability strong {
  color: #202624;
}
.fewo-admin-availability span {
  color: #626962;
  line-height: 1.4;
}
.fewo-admin-availability--checking {
  border-color: #cfd8e3;
  background: #f7fbff;
}
.fewo-admin-availability--available {
  border-color: #9bc9aa;
  background: #f4fbf5;
}
.fewo-admin-availability--available strong {
  color: #1f6b37;
}
.fewo-admin-availability--unavailable {
  border-color: #df9c91;
  background: #fff6f4;
}
.fewo-admin-availability--unavailable strong {
  color: #9c3427;
}
.fewo-admin-availability--warning {
  border-color: #d9bd76;
  background: #fff9e8;
}
.fewo-admin-date-calendar {
  display: grid;
  gap: .65rem;
  padding: .9rem;
  border: 1px solid #ddd2c6;
  border-radius: 16px;
  background: #fff;
}
.fewo-admin-date-calendar__head {
  display: grid;
  grid-template-columns: 2.25rem minmax(0, 1fr) 2.25rem;
  gap: .6rem;
  align-items: center;
}
.fewo-admin-date-calendar__head strong {
  text-align: center;
  color: #202624;
  font-size: 1rem;
}
.fewo-admin-date-calendar__nav {
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid #e4d7ca;
  border-radius: 50%;
  background: #fffaf6;
  color: #604f42;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}
.fewo-admin-date-calendar__weekdays,
.fewo-admin-date-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .35rem;
}
.fewo-admin-date-calendar__weekdays span {
  text-align: center;
  color: #8b7e72;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
}
.fewo-admin-date-calendar__blank {
  min-height: 2.55rem;
}
.fewo-admin-date-calendar__day {
  min-width: 0;
  min-height: 2.55rem;
  border: 1px solid #e6ddd3;
  border-radius: 10px;
  background: #fbfaf7;
  color: #202624;
  font: inherit;
  font-weight: 850;
  cursor: pointer;
}
.fewo-admin-date-calendar__day:hover:not(:disabled) {
  border-color: #8e745d;
  box-shadow: 0 0 0 2px rgba(142, 116, 93, .12);
}
.fewo-admin-date-calendar__day.is-free {
  background: #f5fbf6;
  border-color: #c8dfce;
}
.fewo-admin-date-calendar__day.is-occupied {
  background: #fff0ed;
  border-color: #eba89e;
  color: #9c3427;
}
.fewo-admin-date-calendar__day.is-blocked {
  background: #f0efec;
  border-color: #cbc5bd;
  color: #625950;
}
.fewo-admin-date-calendar__day.is-hold {
  background: #fff8df;
  border-color: #e3c96b;
  color: #765a00;
}
.fewo-admin-date-calendar__day.is-loading {
  background: #f5f5f5;
  color: #999;
}
.fewo-admin-date-calendar__day.is-today {
  box-shadow: inset 0 0 0 2px #202624;
}
.fewo-admin-date-calendar__day.is-in-range {
  background: #e9f3ec;
  border-color: #8dbf99;
}
.fewo-admin-date-calendar__day.is-start,
.fewo-admin-date-calendar__day.is-end {
  background: #202624;
  border-color: #202624;
  color: #fff;
}
.fewo-admin-date-calendar__day:disabled {
  cursor: not-allowed;
  opacity: .62;
}
.fewo-admin-date-calendar__message {
  grid-column: 1 / -1;
  margin: 0;
  padding: .75rem;
  border: 1px dashed #ddd2c6;
  border-radius: 12px;
  color: #626962;
  text-align: center;
}
.fewo-admin-date-calendar__legend {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem .9rem;
  color: #626962;
  font-size: .84rem;
  font-weight: 750;
}
.fewo-admin-date-calendar__legend span {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
.fewo-admin-date-calendar__legend i {
  width: .75rem;
  height: .75rem;
  border-radius: 3px;
  border: 1px solid #ddd2c6;
}
.fewo-admin-date-calendar__legend .free {
  background: #f5fbf6;
  border-color: #c8dfce;
}
.fewo-admin-date-calendar__legend .occupied {
  background: #fff0ed;
  border-color: #eba89e;
}
.fewo-admin-date-calendar__legend .blocked {
  background: #f0efec;
  border-color: #cbc5bd;
}
.fewo-admin-date-calendar__legend .hold {
  background: #fff8df;
  border-color: #e3c96b;
}
.fewo-admin-booking-form button:disabled {
  opacity: .55;
  cursor: not-allowed;
}
.fewo-checkline {
  display: flex !important;
  align-items: flex-start;
  gap: .55rem;
  padding: .7rem .8rem;
  border: 1px solid rgba(32,32,32,.1);
  border-radius: 14px;
  background: #fff;
  line-height: 1.45;
}
.fewo-checkline input[type="checkbox"] {
  width: auto;
  min-width: 1.05rem;
  margin-top: .2rem;
}
.fewo-admin-subdetails {
  padding: .85rem;
  border: 1px solid rgba(32,32,32,.08);
  border-radius: 16px;
  background: #fff;
}
.fewo-admin-nested-form {
  margin-top: .75rem;
  padding: 0;
  background: transparent;
  border: 0;
}
.fewo-admin-booking-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  align-items: center;
}
@media (max-width: 760px) {
  .fewo-admin-pill {
    width: 100%;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }
  .fewo-admin-booking-panel {
    padding: .8rem;
  }
  .fewo-admin-booking-actions,
  .fewo-admin-booking-actions .fewo-button {
    width: 100%;
  }
  .fewo-checkline {
    padding: .75rem;
  }
}

/* Admin navigation cleanup, 2026-06-01 */
.fewo-admin-hero--compact {
  grid-template-columns: minmax(280px, .9fr) minmax(420px, 1.25fr);
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
  padding: clamp(1.1rem, 2.2vw, 1.55rem);
}
.fewo-admin-hero--compact .fewo-admin-hero-main {
  min-width: 0;
}
.fewo-admin-hero--compact h2 {
  margin-bottom: .35rem;
  font-size: clamp(1.75rem, 2.5vw, 2.3rem);
}
.fewo-admin-hero--compact p:not(.fewo-admin-eyebrow) {
  max-width: 46rem;
  line-height: 1.5;
}
.fewo-admin-hero--compact .fewo-admin-hero-actions {
  display: grid;
  gap: .6rem;
  justify-items: end;
  align-items: center;
}
.fewo-admin-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: flex-end;
  align-items: center;
}
.fewo-admin-quick-actions .fewo-inline-form {
  display: inline-flex;
  margin: 0;
}
.fewo-admin-hero--compact .fewo-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .62rem .95rem;
  line-height: 1.1;
  white-space: nowrap;
}
.fewo-admin-quick-actions--utility .fewo-button {
  min-height: 38px;
  padding: .55rem .8rem;
  font-size: .88rem;
}
.fewo-admin-nav--grouped {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .55rem;
  align-items: stretch;
  padding: .6rem;
  border-radius: 24px;
}
.fewo-admin-nav--grouped .fewo-admin-nav-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem;
  min-width: 0;
  padding: .38rem;
  border: 1px solid rgba(183,109,72,.12);
  border-radius: 18px;
  background: rgba(255,249,243,.92);
}
.fewo-admin-nav--grouped .fewo-admin-nav-group > span {
  flex: 1 0 100%;
  padding: .05rem .45rem 0;
  color: #8f5d42;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .1em;
  line-height: 1.1;
  text-transform: uppercase;
}
.fewo-admin-nav--grouped a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: .45rem .66rem;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  font-size: .9rem;
  line-height: 1.1;
  white-space: nowrap;
}
.fewo-admin-nav--grouped a:hover,
.fewo-admin-nav--grouped a:focus-visible {
  background: #f3e5d8;
  outline: none;
}

@media (max-width: 1080px) {
  .fewo-admin-hero--compact {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .fewo-admin-hero--compact .fewo-admin-hero-actions,
  .fewo-admin-quick-actions {
    justify-items: start;
    justify-content: flex-start;
  }
  .fewo-admin-nav--grouped {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .fewo-admin-hero--compact {
    padding: 1rem;
  }
  .fewo-admin-hero--compact .fewo-admin-hero-actions,
  .fewo-admin-quick-actions {
    width: 100%;
  }
  .fewo-admin-quick-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .fewo-admin-quick-actions .fewo-inline-form,
  .fewo-admin-hero--compact .fewo-button,
  .fewo-admin-hero--compact .fewo-inline-form .fewo-button {
    width: 100%;
  }
  .fewo-admin-nav--grouped {
    position: static;
    display: grid;
    grid-template-columns: 1fr;
    gap: .45rem;
    overflow: visible;
    padding: .45rem;
    border-radius: 18px;
  }
  .fewo-admin-nav--grouped .fewo-admin-nav-group {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
  }
  .fewo-admin-nav--grouped .fewo-admin-nav-group > span,
  .fewo-admin-nav--grouped a {
    flex: 0 0 auto !important;
  }
  .fewo-admin-nav--grouped .fewo-admin-nav-group > span {
    align-self: center;
    padding: .45rem .35rem;
  }
}

@media (max-width: 480px) {
  .fewo-admin-hero--compact h2 {
    font-size: clamp(1.45rem, 8vw, 1.85rem);
  }
  .fewo-admin-nav--grouped a {
    min-height: 38px;
    padding-inline: .6rem;
    font-size: .86rem;
  }
}

/* Admin navigation refresh, 2026-06-01 */
.fewo-admin-hero--navigation-refresh {
  grid-template-columns: minmax(320px, .95fr) minmax(420px, 1.05fr);
  align-items: stretch;
  gap: clamp(1rem, 2.2vw, 1.6rem);
}
.fewo-admin-hero--navigation-refresh .fewo-admin-hero-copy {
  align-self: center;
}
.fewo-admin-hero--navigation-refresh h2 {
  max-width: 560px;
  font-size: clamp(2rem, 3.2vw, 3rem);
}
.fewo-admin-hero--navigation-refresh p:not(.fewo-admin-eyebrow) {
  max-width: 620px;
}
.fewo-admin-toolbar {
  display: grid;
  gap: .7rem;
  align-self: stretch;
  padding: .85rem;
  border: 1px solid rgba(183,109,72,.13);
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}
.fewo-admin-toolbar-primary,
.fewo-admin-toolbar-secondary {
  display: grid;
  gap: .55rem;
}
.fewo-admin-toolbar-primary {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
}
.fewo-admin-toolbar-secondary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.fewo-admin-toolbar .fewo-button,
.fewo-admin-toolbar .fewo-inline-form,
.fewo-admin-toolbar .fewo-inline-form .fewo-button {
  width: 100%;
}
.fewo-admin-toolbar .fewo-button {
  min-height: 44px;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
}
.fewo-button-light {
  background: rgba(255,255,255,.92);
  border-color: rgba(183,109,72,.24);
  color: var(--accent, #b76d48);
}
.fewo-button-light:hover {
  background: #fff3e9;
  color: var(--dark, #202624);
}
.fewo-admin-nav--grouped {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  gap: .65rem;
  margin: 1rem 0;
  padding: .65rem;
  border-radius: 26px;
  background: rgba(255,255,255,.9);
}
.fewo-admin-nav-group {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: center;
  gap: .4rem;
  min-width: 0;
  padding: .55rem;
  border: 1px solid rgba(32,32,32,.06);
  border-radius: 19px;
  background: #fbf7f0;
}
.fewo-admin-nav-label {
  flex: 0 0 100%;
  margin: 0 0 .05rem;
  color: rgba(32,38,36,.62);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}
.fewo-admin-nav--grouped a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  min-height: 38px;
  padding: .52rem .74rem;
  border: 1px solid rgba(32,32,32,.07);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 1px 1px rgba(32,32,32,.03);
  line-height: 1.05;
  white-space: nowrap;
}
.fewo-admin-nav--grouped a:hover,
.fewo-admin-nav--grouped a:focus-visible {
  background: #fff4eb;
  border-color: rgba(183,109,72,.24);
}
.fewo-admin-nav--grouped a.fewo-admin-nav-primary {
  background: var(--dark, #202624);
  border-color: var(--dark, #202624);
  color: #fff;
}
.fewo-admin-nav--grouped a.fewo-admin-nav-primary:hover,
.fewo-admin-nav--grouped a.fewo-admin-nav-primary:focus-visible {
  background: #35413d;
  color: #fff;
}
.fewo-admin-nav-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  padding: 0 .35rem;
  border-radius: 999px;
  background: rgba(183,109,72,.14);
  color: var(--accent, #b76d48);
  font-size: .76rem;
  font-weight: 900;
  line-height: 1;
}
.fewo-admin-nav-primary .fewo-admin-nav-count {
  background: rgba(255,255,255,.18);
  color: #fff;
}
@media (max-width: 1080px) {
  .fewo-admin-hero--navigation-refresh {
    grid-template-columns: 1fr;
  }
  .fewo-admin-toolbar-primary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fewo-admin-nav--grouped {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    position: static;
  }
}
@media (max-width: 760px) {
  .fewo-admin-hero--navigation-refresh {
    padding: .95rem;
  }
  .fewo-admin-hero--navigation-refresh h2 {
    font-size: clamp(1.7rem, 8vw, 2.15rem);
  }
  .fewo-admin-toolbar {
    padding: .7rem;
    border-radius: 18px;
  }
  .fewo-admin-toolbar-primary,
  .fewo-admin-toolbar-secondary {
    grid-template-columns: 1fr;
  }
  .fewo-admin-toolbar .fewo-button {
    white-space: normal;
  }
  .fewo-admin-nav--grouped {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: .55rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    padding: .45rem;
    border-radius: 18px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }
  .fewo-admin-nav-group {
    flex: 0 0 min(82vw, 310px);
    scroll-snap-align: start;
    padding: .55rem;
  }
  .fewo-admin-nav--grouped a {
    flex: 0 0 auto !important;
    min-height: 40px;
    padding: .52rem .72rem;
  }
}
@media (max-width: 420px) {
  .fewo-admin-nav-group {
    flex-basis: min(88vw, 300px);
  }
  .fewo-admin-nav--grouped a {
    font-size: .88rem;
  }
}

/* Company booking / business travel enhancements */
.fewo-badge-company {
  background: #eef6f0;
  color: #23613d;
  border: 1px solid #cfe5d6;
}

.fewo-company-card-inline {
  display: block;
  color: #6b5a4d;
  font-weight: 700;
}

.fewo-company-admin-details > summary {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-weight: 900;
}

.fewo-company-admin-details > summary::before {
  content: "🏢";
  font-size: 1rem;
}

.fewo-admin-company-grid {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid #eadfd4;
  border-radius: 1.2rem;
  background: #fffaf5;
}

.fewo-admin-subheading {
  margin-top: .35rem;
  padding: .7rem .85rem;
  border-radius: .95rem;
  background: rgba(183, 109, 72, .08);
}

.fewo-admin-subheading h4 {
  margin: 0 0 .25rem;
  font-size: .95rem;
}

.fewo-admin-subheading p {
  margin: 0;
}

.fewo-offer-card__business {
  margin: 1rem 0 0;
  padding: 1rem;
  border: 1px solid #dceadd;
  border-radius: 1.1rem;
  background: #f7fbf8;
}

.fewo-offer-card__business > strong {
  display: block;
  margin-bottom: .65rem;
  color: #202624;
}

.fewo-offer-card__business dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem 1rem;
  margin: 0;
}

.fewo-offer-card__business div {
  min-width: 0;
}

.fewo-offer-card__business dt {
  margin: 0 0 .15rem;
  font-size: .72rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #7a7065;
  font-weight: 800;
}

.fewo-offer-card__business dd {
  margin: 0;
  color: #202624;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.fewo-business-summary .fewo-summary-list,
.fewo-admin-company-list {
  overflow-wrap: anywhere;
}

.fewo-contact-mode__subhead {
  margin-top: .35rem;
}

@media (max-width: 760px) {
  .fewo-admin-company-grid {
    padding: .85rem;
    border-radius: 1rem;
  }

  .fewo-offer-card__business dl {
    grid-template-columns: 1fr;
  }

  .fewo-badge-company {
    width: max-content;
  }
}

/* Privacy-friendly statistics dashboard */
.fewo-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: .35rem .72rem;
  border-radius: 999px;
  border: 1px solid #d9d1c8;
  background: #f7f3ed;
  color: #625548;
  font-size: .84rem;
  font-weight: 900;
  white-space: nowrap;
}
.fewo-status-pill-success {
  border-color: #cfe5d6;
  background: #eef8f1;
  color: #245f3d;
}
.fewo-status-pill-muted {
  border-color: #e1d8ce;
  background: #f2ede7;
  color: #7a6b60;
}
.fewo-privacy-stats .fewo-admin-section-head {
  align-items: flex-start;
}
.fewo-privacy-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin: .75rem 0 1rem;
}
.fewo-privacy-trust-row span {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: .35rem .68rem;
  border: 1px solid #e4d8ca;
  border-radius: 999px;
  background: #fffaf5;
  color: #6b5848;
  font-size: .84rem;
  font-weight: 800;
}
.fewo-privacy-stats-cards {
  margin-top: .75rem;
}
.fewo-privacy-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, .75fr);
  gap: .9rem;
  margin-top: 1rem;
}
.fewo-privacy-panel {
  min-width: 0;
  padding: 1rem;
  border: 1px solid #eadfd4;
  border-radius: 1.1rem;
  background: #fffaf5;
}
.fewo-privacy-panel-wide {
  grid-row: span 2;
}
.fewo-privacy-panel h3,
.fewo-privacy-panel-head h3 {
  margin: 0 0 .7rem;
  font-size: 1rem;
}
.fewo-privacy-panel-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .85rem;
}
.fewo-privacy-panel-head span {
  color: #786a5e;
  font-size: .84rem;
  font-weight: 700;
}
.fewo-privacy-chart {
  display: grid;
  gap: .45rem;
}
.fewo-privacy-chart-row {
  display: grid;
  grid-template-columns: 3.4rem minmax(0, 1fr) 3.2rem;
  gap: .6rem;
  align-items: center;
  min-width: 0;
}
.fewo-privacy-chart-date,
.fewo-privacy-chart-row strong {
  color: #6f6256;
  font-size: .78rem;
  font-weight: 850;
}
.fewo-privacy-chart-row strong {
  text-align: right;
}
.fewo-privacy-chart-track,
.fewo-privacy-mini-track {
  display: block;
  overflow: hidden;
  height: .58rem;
  border-radius: 999px;
  background: #eee4d9;
}
.fewo-privacy-chart-track span,
.fewo-privacy-mini-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: #b76d48;
}
.fewo-privacy-list {
  display: grid;
  gap: .7rem;
}
.fewo-privacy-list-item {
  display: grid;
  gap: .4rem;
}
.fewo-privacy-list-item > div {
  display: flex;
  justify-content: space-between;
  gap: .65rem;
  min-width: 0;
}
.fewo-privacy-list-item strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: #202624;
  font-size: .9rem;
}
.fewo-privacy-list-item span {
  color: #76695e;
  font-size: .8rem;
  font-weight: 800;
  white-space: nowrap;
}
.fewo-privacy-admin-note {
  margin-top: 1rem;
  padding: .85rem 1rem;
  border: 1px dashed #ddcfc0;
  border-radius: 1rem;
  background: #fffdf9;
}
.fewo-privacy-admin-note p {
  margin: .2rem 0;
}
.fewo-danger-details {
  margin-top: .9rem;
  padding: .8rem 1rem;
  border: 1px solid #ecd7d1;
  border-radius: 1rem;
  background: #fff8f6;
}
.fewo-danger-details > summary {
  cursor: pointer;
  font-weight: 900;
  color: #8b2f1f;
}
.fewo-empty-state-small {
  padding: .75rem;
  font-size: .9rem;
}
@media (max-width: 980px) {
  .fewo-privacy-dashboard-grid {
    grid-template-columns: 1fr;
  }
  .fewo-privacy-panel-wide {
    grid-row: auto;
  }
}
@media (max-width: 620px) {
  .fewo-privacy-trust-row {
    display: grid;
    grid-template-columns: 1fr;
  }
  .fewo-privacy-trust-row span {
    border-radius: .9rem;
  }
  .fewo-privacy-panel {
    padding: .82rem;
    border-radius: .95rem;
  }
  .fewo-privacy-panel-head {
    display: block;
  }
  .fewo-privacy-chart-row {
    grid-template-columns: 2.9rem minmax(0, 1fr) 2.55rem;
    gap: .42rem;
  }
  .fewo-privacy-list-item > div {
    display: grid;
    gap: .2rem;
  }
  .fewo-privacy-list-item span {
    white-space: normal;
  }
}


/* Admin stats + navigation polish, 2026-06-01 */
.fewo-admin-hero--navigation-refresh {
  grid-template-columns: minmax(320px, 1.08fr) minmax(430px, .92fr);
  align-items: center;
  padding: clamp(1rem, 2vw, 1.35rem);
}
.fewo-admin-hero--navigation-refresh h2 {
  font-size: clamp(1.8rem, 2.7vw, 2.55rem);
  line-height: .98;
}
.fewo-admin-hero--navigation-refresh p:not(.fewo-admin-eyebrow) {
  max-width: 680px;
  line-height: 1.48;
}
.fewo-admin-toolbar {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .55rem;
  align-self: center;
  padding: .75rem;
  border-radius: 20px;
}
.fewo-admin-toolbar-primary,
.fewo-admin-toolbar-secondary {
  display: contents;
}
.fewo-admin-toolbar .fewo-inline-form {
  display: block;
  width: 100%;
  margin: 0;
}
.fewo-admin-toolbar .fewo-button,
.fewo-admin-toolbar .fewo-inline-form .fewo-button {
  width: 100%;
  min-height: 40px;
  padding: .52rem .68rem;
  font-size: .9rem;
  line-height: 1.12;
  letter-spacing: 0;
  white-space: normal;
  text-align: center;
}
.fewo-admin-toolbar .fewo-button:not(.fewo-button-light),
.fewo-admin-toolbar .fewo-button-light {
  box-shadow: none;
}
.fewo-admin-nav--grouped {
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: .55rem;
  padding: .55rem;
  border-radius: 22px;
}
.fewo-admin-nav-group {
  gap: .35rem;
  padding: .48rem;
  border-radius: 17px;
}
.fewo-admin-nav-label {
  margin-bottom: .08rem;
  font-size: .68rem;
}
.fewo-admin-nav--grouped a {
  flex: 1 1 88px;
  min-height: 36px;
  min-width: 0;
  padding: .45rem .58rem;
  font-size: .88rem;
  line-height: 1.1;
  white-space: normal;
  text-align: center;
}
.fewo-admin-nav-count {
  min-width: 1.18rem;
  height: 1.18rem;
  padding: 0 .28rem;
  font-size: .7rem;
}
@media (max-width: 1080px) {
  .fewo-admin-hero--navigation-refresh {
    grid-template-columns: 1fr;
  }
  .fewo-admin-toolbar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: none;
  }
  .fewo-admin-nav--grouped {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-admin-hero--navigation-refresh {
    gap: .8rem;
    padding: .9rem;
  }
  .fewo-admin-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .45rem;
    padding: .6rem;
  }
  .fewo-admin-toolbar .fewo-button,
  .fewo-admin-toolbar .fewo-inline-form .fewo-button {
    min-height: 39px;
    font-size: .88rem;
  }
  .fewo-admin-nav--grouped {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: .5rem !important;
    overflow-x: auto;
    overflow-y: hidden;
  }
  .fewo-admin-nav-group {
    flex: 0 0 min(82vw, 310px);
  }
  .fewo-admin-nav--grouped a {
    flex: 1 1 86px !important;
    min-height: 36px;
    font-size: .86rem;
  }
}
@media (max-width: 420px) {
  .fewo-admin-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fewo-admin-toolbar .fewo-button,
  .fewo-admin-toolbar .fewo-inline-form .fewo-button {
    padding-inline: .48rem;
    font-size: .85rem;
  }
}

/* Admin navigation polish: balanced toolbar, consistent medium buttons */
.fewo-admin-hero--navigation-refresh {
  grid-template-columns: minmax(320px, 1fr) minmax(360px, .92fr);
  align-items: center;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: clamp(1.25rem, 2.2vw, 1.9rem);
}
.fewo-admin-hero--navigation-refresh h2 {
  max-width: 520px;
  font-size: clamp(1.9rem, 3vw, 2.65rem);
  line-height: .98;
}
.fewo-admin-hero--navigation-refresh p:not(.fewo-admin-eyebrow) {
  max-width: 660px;
  font-size: clamp(.98rem, 1.15vw, 1.06rem);
  line-height: 1.55;
}
.fewo-admin-toolbar {
  align-self: center;
  gap: .55rem;
  padding: .72rem;
  border-radius: 20px;
  background: rgba(255,255,255,.78);
}
.fewo-admin-toolbar-primary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.fewo-admin-toolbar-secondary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.fewo-admin-toolbar .fewo-button,
.fewo-admin-toolbar .fewo-inline-form .fewo-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .62rem .78rem;
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: 0;
  text-align: center;
  white-space: normal;
  overflow-wrap: normal;
  hyphens: auto;
}
.fewo-admin-toolbar-primary .fewo-button {
  min-height: 46px;
  font-size: .95rem;
}
.fewo-admin-toolbar-secondary .fewo-button {
  min-height: 40px;
  font-size: .88rem;
}
.fewo-admin-nav--grouped {
  grid-template-columns: minmax(190px, .85fr) minmax(250px, 1.15fr) minmax(190px, .85fr) minmax(250px, 1.15fr);
  gap: .6rem;
  padding: .55rem;
  border-radius: 22px;
}
.fewo-admin-nav-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(5.8rem, 1fr));
  align-items: stretch;
  gap: .38rem;
  padding: .52rem;
  border-radius: 16px;
}
.fewo-admin-nav-label {
  grid-column: 1 / -1;
  margin-bottom: .1rem;
  font-size: .68rem;
  letter-spacing: .075em;
}
.fewo-admin-nav--grouped a {
  width: 100%;
  min-height: 39px;
  padding: .48rem .55rem;
  border-radius: 14px;
  font-size: .9rem;
  font-weight: 800;
  line-height: 1.1;
  text-align: center;
  white-space: normal;
  overflow-wrap: normal;
  hyphens: auto;
}
.fewo-admin-nav-count {
  min-width: 1.22rem;
  height: 1.22rem;
  padding: 0 .28rem;
  font-size: .7rem;
}
@media (max-width: 1180px) {
  .fewo-admin-nav--grouped {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .fewo-admin-hero--navigation-refresh {
    padding: 1rem;
  }
  .fewo-admin-toolbar-primary,
  .fewo-admin-toolbar-secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fewo-admin-toolbar .fewo-button,
  .fewo-admin-toolbar .fewo-inline-form .fewo-button {
    min-height: 42px;
    font-size: .9rem;
  }
  .fewo-admin-nav--grouped {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    gap: .55rem !important;
    padding: .45rem;
    border-radius: 18px;
  }
  .fewo-admin-nav-group {
    flex: 0 0 min(82vw, 315px);
    grid-template-columns: repeat(3, minmax(0, 1fr));
    scroll-snap-align: start;
  }
  .fewo-admin-nav--grouped a {
    min-height: 40px;
    padding: .5rem .48rem;
    font-size: .88rem;
  }
}
@media (max-width: 480px) {
  .fewo-admin-toolbar-primary,
  .fewo-admin-toolbar-secondary {
    grid-template-columns: 1fr 1fr;
  }
  .fewo-admin-nav-group {
    flex-basis: min(88vw, 300px);
  }
}

/* Admin foldout organization, 2026-06-01 */
.fewo-admin-section-head--compact {
  margin-bottom: .9rem;
}
.fewo-admin-settings-card .fewo-admin-section-head p:not(.fewo-admin-eyebrow) {
  max-width: 760px;
}
.fewo-settings-form {
  display: block;
  padding: .85rem;
}
.fewo-settings-accordion {
  display: grid;
  gap: .8rem;
}
.fewo-settings-panel,
.fewo-admin-foldout {
  overflow: hidden;
  border: 1px solid rgba(32,38,36,.09);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,.85), 0 10px 26px rgba(32,38,36,.04);
}
.fewo-admin-foldout {
  margin-top: .9rem;
}
.fewo-settings-panel > summary,
.fewo-admin-foldout > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 58px;
  padding: .95rem 1.05rem;
  cursor: pointer;
  list-style: none;
  background: linear-gradient(135deg, #fff, #fff8f1);
  color: var(--dark, #202624);
}
.fewo-settings-panel > summary::-webkit-details-marker,
.fewo-admin-foldout > summary::-webkit-details-marker {
  display: none;
}
.fewo-settings-panel > summary span,
.fewo-admin-foldout > summary span {
  display: block;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.15;
}
.fewo-settings-panel > summary small,
.fewo-admin-foldout > summary small {
  display: block;
  max-width: 560px;
  margin-top: .18rem;
  color: rgba(32,38,36,.62);
  font-size: .86rem;
  font-weight: 750;
  line-height: 1.35;
}
.fewo-settings-panel > summary::after,
.fewo-admin-foldout > summary::after {
  content: "+";
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: rgba(183,109,72,.12);
  color: var(--accent, #b76d48);
  font-size: 1.3rem;
  font-weight: 900;
  line-height: 1;
}
.fewo-settings-panel[open] > summary,
.fewo-admin-foldout[open] > summary {
  border-bottom: 1px solid rgba(32,38,36,.08);
}
.fewo-settings-panel[open] > summary::after,
.fewo-admin-foldout[open] > summary::after {
  content: "–";
  background: var(--dark, #202624);
  color: #fff;
}
.fewo-settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  padding: 1rem;
}
.fewo-settings-grid label,
.fewo-admin-foldout .fewo-admin-form label {
  min-width: 0;
}
.fewo-settings-grid input,
.fewo-settings-grid select,
.fewo-settings-grid textarea,
.fewo-admin-foldout .fewo-admin-form input,
.fewo-admin-foldout .fewo-admin-form select,
.fewo-admin-foldout .fewo-admin-form textarea {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: .62rem .7rem;
  border: 1px solid rgba(32,32,32,.16);
  border-radius: 10px;
  background: #fff;
}
.fewo-settings-grid .fewo-checkbox-line {
  align-self: stretch;
  padding: .72rem .8rem;
  border: 1px solid rgba(32,38,36,.07);
  border-radius: 14px;
  background: #fffdf9;
}
.fewo-settings-subhead {
  padding: .2rem 0 .1rem;
}
.fewo-settings-subhead h3 {
  margin: 0 0 .18rem;
  font-size: .95rem;
}
.fewo-settings-subhead p {
  margin: 0;
  color: #686d67;
  font-size: .9rem;
}
.fewo-admin-unit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
  gap: 1rem;
}
.fewo-admin-unit-card {
  border: 1px solid rgba(32,38,36,.1);
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
}
.fewo-admin-unit-preview {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: .9rem;
  align-items: center;
  padding: 1rem;
  border-bottom: 1px solid rgba(32,38,36,.08);
  background: #fbf8f3;
}
.fewo-admin-unit-preview img,
.fewo-admin-unit-placeholder {
  display: block;
  width: 92px;
  height: 68px;
  border-radius: 6px;
  object-fit: cover;
  background: #e8e0d6;
}
.fewo-admin-unit-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6e746d;
  font-size: .85rem;
}
.fewo-admin-unit-preview strong,
.fewo-admin-unit-preview span {
  display: block;
  min-width: 0;
}
.fewo-admin-unit-preview span {
  color: #687068;
  font-size: .9rem;
}
.fewo-admin-unit-gallery-edit {
  display: grid;
  gap: .65rem;
  padding: .82rem;
  border: 1px solid rgba(32,38,36,.08);
  border-radius: 14px;
  background: #fffdf9;
}
.fewo-admin-unit-gallery-edit > strong {
  color: #202624;
  font-size: .96rem;
}
.fewo-admin-unit-gallery-edit .fewo-muted {
  margin: 0;
}
.fewo-admin-unit-image-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
.fewo-admin-unit-image-slot {
  display: grid;
  gap: .55rem;
  min-width: 0;
  padding: .65rem;
  border: 1px solid rgba(32,38,36,.08);
  border-radius: 12px;
  background: #fff;
}
.fewo-admin-unit-image-slot img,
.fewo-admin-unit-image-slot > span {
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 8px;
  object-fit: cover;
  background: #e8e0d6;
}
.fewo-admin-unit-image-slot > span {
  display: grid;
  place-items: center;
  color: #6e746d;
  font-size: .85rem;
  font-weight: 800;
}
.fewo-license-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  gap: 1rem;
  align-items: start;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid rgba(32,38,36,.09);
  border-radius: 16px;
  background: #fffdf9;
}
.fewo-license-panel strong,
.fewo-license-panel span {
  display: block;
}
.fewo-license-panel span {
  margin-top: .2rem;
  color: #687068;
  font-size: .9rem;
  line-height: 1.4;
}
.fewo-license-panel label {
  margin: 0;
}
.fewo-license-controls {
  display: grid;
  gap: .7rem;
}
.fewo-license-panel input:not([type="checkbox"]),
.fewo-license-panel select {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: .62rem .7rem;
  border: 1px solid rgba(32,32,32,.16);
  border-radius: 10px;
  background: #fff;
}
.fewo-booking-number-panel {
  align-items: start;
}
.fewo-booking-number-panel code {
  display: inline-block;
  margin-top: .55rem;
  padding: .32rem .46rem;
  border: 1px solid rgba(32,38,36,.08);
  border-radius: 8px;
  background: #fff;
  color: #202624;
  font-size: .86rem;
}
.fewo-booking-number-controls {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fewo-license-toggle {
  padding: .72rem .8rem;
  border: 1px solid rgba(32,38,36,.07);
  border-radius: 14px;
  background: #fff;
}
.fewo-license-toggle span {
  margin: 0;
  color: #26302b;
  font-weight: 760;
}
.fewo-settings-savebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: .9rem;
  padding: .9rem;
  border: 1px solid rgba(32,38,36,.09);
  border-radius: 18px;
  background: rgba(255,250,244,.96);
  box-shadow: 0 -8px 24px rgba(32,38,36,.035);
}
.fewo-settings-savebar strong,
.fewo-settings-savebar span {
  display: block;
}
.fewo-settings-savebar span {
  margin-top: .12rem;
  color: #686d67;
  font-size: .9rem;
}
.fewo-settings-savebar .fewo-button {
  flex: 0 0 auto;
}
.fewo-admin-foldout-body,
.fewo-admin-foldout > .fewo-grid-form,
.fewo-admin-foldout > .fewo-admin-form,
.fewo-admin-foldout > .fewo-table-scroll,
.fewo-admin-foldout > .fewo-empty-state,
.fewo-admin-foldout > .fewo-warning-box,
.fewo-admin-foldout > .fewo-pricing-rule-list,
.fewo-admin-foldout > .fewo-pricing-preview-result,
.fewo-admin-foldout > .fewo-pricing-preview-table {
  margin: 1rem;
}
.fewo-admin-foldout .fewo-admin-form {
  box-shadow: none;
}
.fewo-admin-foldout > .fewo-settings-heading {
  margin: 0 1rem;
  padding-top: .85rem;
  border-top: 0;
}
.fewo-admin-foldout > .fewo-settings-heading h3,
.fewo-admin-foldout .fewo-pricing-rule-form .fewo-settings-heading h3 {
  font-size: .92rem;
}
.fewo-admin-foldout--pricing .fewo-pricing-rule-form,
.fewo-admin-foldout--pricing .fewo-pricing-preview-form {
  margin: 1rem;
}

@media (max-width: 760px) {
  .fewo-settings-form {
    padding: .65rem;
  }
  .fewo-settings-panel > summary,
  .fewo-admin-foldout > summary {
    align-items: flex-start;
    min-height: 0;
    padding: .82rem .9rem;
  }
  .fewo-settings-panel > summary small,
  .fewo-admin-foldout > summary small {
    max-width: none;
    font-size: .82rem;
  }
  .fewo-settings-grid {
    grid-template-columns: 1fr;
    gap: .72rem;
    padding: .85rem;
  }
  .fewo-settings-savebar {
    position: sticky;
    bottom: .55rem;
    z-index: 5;
    display: grid;
    grid-template-columns: 1fr;
    padding: .82rem;
  }
  .fewo-settings-savebar .fewo-button {
    width: 100%;
  }
  .fewo-admin-foldout-body,
  .fewo-admin-foldout > .fewo-grid-form,
  .fewo-admin-foldout > .fewo-admin-form,
  .fewo-admin-foldout > .fewo-table-scroll,
  .fewo-admin-foldout > .fewo-empty-state,
  .fewo-admin-foldout > .fewo-warning-box,
  .fewo-admin-foldout > .fewo-pricing-rule-list,
  .fewo-admin-foldout > .fewo-pricing-preview-result,
  .fewo-admin-foldout > .fewo-pricing-preview-table,
  .fewo-admin-foldout--pricing .fewo-pricing-rule-form,
  .fewo-admin-foldout--pricing .fewo-pricing-preview-form {
    margin: .85rem;
  }
}

/* Reinigungs- und Übergabe-Dashboard */
.fewo-cleaning-dashboard {
    scroll-margin-top: 1.5rem;
}

.fewo-cleaning-summary {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 1rem 0 1.25rem;
}

.fewo-cleaning-summary article {
    border: 1px solid rgba(32, 38, 36, 0.1);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    padding: 0.9rem 1rem;
    box-shadow: 0 10px 24px rgba(32, 38, 36, 0.05);
}

.fewo-cleaning-summary span {
    display: block;
    color: #6f756f;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.fewo-cleaning-summary strong {
    display: block;
    margin-top: 0.15rem;
    color: #202624;
    font-size: 1.45rem;
    line-height: 1;
}

.fewo-cleaning-list {
    display: grid;
    gap: 1rem;
}

.fewo-cleaning-card {
    border: 1px solid rgba(32, 38, 36, 0.1);
    border-radius: 20px;
    background: #fffdf8;
    box-shadow: 0 14px 32px rgba(32, 38, 36, 0.07);
    overflow: hidden;
}

.fewo-cleaning-card--danger {
    border-color: rgba(162, 61, 44, 0.35);
    background: #fff8f5;
}

.fewo-cleaning-card--warning,
.fewo-cleaning-card--turnover {
    border-color: rgba(183, 109, 72, 0.32);
    background: #fffaf2;
}

.fewo-cleaning-card--done {
    border-color: rgba(47, 111, 68, 0.22);
}

.fewo-cleaning-card__head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: start;
    padding: 1.1rem 1.2rem;
}

.fewo-cleaning-card__label {
    display: block;
    color: #8f6b4f;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.fewo-cleaning-card__head h3 {
    margin: 0;
    font-size: 1.15rem;
    line-height: 1.25;
}

.fewo-cleaning-card__head p {
    margin: 0.25rem 0 0;
    color: #5f655f;
}

.fewo-cleaning-turnover-note {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.55rem !important;
    padding: 0.35rem 0.55rem;
    border-radius: 999px;
    background: rgba(183, 109, 72, 0.12);
    color: #8b5638 !important;
    font-weight: 800;
    font-size: 0.86rem;
}

.fewo-cleaning-card__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.4rem;
    max-width: 22rem;
}

.fewo-cleaning-status {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    border-radius: 999px;
    padding: 0.34rem 0.65rem;
    font-size: 0.82rem;
    font-weight: 900;
    line-height: 1.15;
    color: #202624;
    background: rgba(32, 38, 36, 0.07);
}

.fewo-cleaning-status--done {
    background: rgba(47, 111, 68, 0.12);
    color: #245436;
}

.fewo-cleaning-status--issue {
    background: rgba(162, 61, 44, 0.14);
    color: #8d3828;
}

.fewo-cleaning-status--active,
.fewo-cleaning-status--planned,
.fewo-cleaning-status--turnover {
    background: rgba(183, 109, 72, 0.13);
    color: #835133;
}

.fewo-cleaning-detail {
    border-top: 1px solid rgba(32, 38, 36, 0.08);
}

.fewo-cleaning-detail > summary {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.82rem 1.2rem;
    color: #202624;
    font-weight: 900;
    list-style: none;
}

.fewo-cleaning-detail > summary::-webkit-details-marker {
    display: none;
}

.fewo-cleaning-detail > summary small {
    color: #6f756f;
    font-weight: 700;
}

.fewo-cleaning-form {
    padding: 0 1.2rem 1.2rem;
}

.fewo-cleaning-form-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.8rem;
}

.fewo-cleaning-form-grid label,
.fewo-cleaning-notes label {
    display: grid;
    gap: 0.35rem;
    color: #3f4743;
    font-weight: 800;
}

.fewo-cleaning-checklists {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 1rem;
}

.fewo-cleaning-checklists section {
    border: 1px solid rgba(32, 38, 36, 0.1);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.68);
    padding: 0.9rem;
}

.fewo-cleaning-checklists strong {
    display: block;
    margin-bottom: 0.6rem;
    color: #202624;
}

.fewo-cleaning-check-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem 0.65rem;
}

.fewo-cleaning-check-grid label {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    color: #3f4743;
    font-size: 0.9rem;
    font-weight: 750;
    line-height: 1.3;
}

.fewo-cleaning-notes {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 1rem;
}

.fewo-cleaning-footer {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-top: 1rem;
    padding-top: 0.85rem;
    border-top: 1px solid rgba(32, 38, 36, 0.08);
    color: #6f756f;
    font-size: 0.88rem;
}

@media (max-width: 980px) {
    .fewo-cleaning-summary {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .fewo-cleaning-card__head {
        grid-template-columns: 1fr;
    }

    .fewo-cleaning-card__badges {
        justify-content: flex-start;
        max-width: none;
    }

    .fewo-cleaning-form-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .fewo-cleaning-summary,
    .fewo-cleaning-checklists,
    .fewo-cleaning-notes {
        grid-template-columns: 1fr;
    }

    .fewo-cleaning-card__head,
    .fewo-cleaning-form,
    .fewo-cleaning-detail > summary {
        padding-left: 0.9rem;
        padding-right: 0.9rem;
    }

    .fewo-cleaning-form-grid,
    .fewo-cleaning-check-grid {
        grid-template-columns: 1fr;
    }

    .fewo-cleaning-detail > summary,
    .fewo-cleaning-footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .fewo-cleaning-footer .fewo-action-row {
        width: 100%;
    }

    .fewo-cleaning-footer .fewo-button {
        flex: 1 1 auto;
    }
}

/* External iCal import dashboard */
.fewo-ical-import-panel {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(15, 23, 42, .08);
}

.fewo-admin-subhead {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fewo-admin-subhead h3 {
    margin: .15rem 0 .25rem;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
}

.fewo-ical-import-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .75rem;
    margin: 1rem 0;
}

.fewo-ical-import-summary article {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    padding: .85rem 1rem;
    background: rgba(255, 255, 255, .76);
}

.fewo-ical-import-summary span,
.fewo-ical-import-meta span {
    display: block;
    color: var(--fewo-muted, #64748b);
    font-size: .86rem;
}

.fewo-ical-import-summary strong {
    display: block;
    margin-top: .15rem;
    font-size: 1.35rem;
}

.fewo-ical-import-list {
    display: grid;
    gap: .85rem;
    margin-top: 1rem;
}

.fewo-ical-import-item {
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 18px;
    background: #fff;
    overflow: hidden;
}

.fewo-ical-import-item > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    cursor: pointer;
    list-style: none;
}

.fewo-ical-import-item > summary::-webkit-details-marker {
    display: none;
}

.fewo-ical-import-item > summary small {
    display: block;
    margin-top: .2rem;
    color: var(--fewo-muted, #64748b);
    font-size: .86rem;
}

.fewo-ical-import-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .35rem;
}

.fewo-ical-import-badges em {
    border-radius: 999px;
    padding: .25rem .55rem;
    background: rgba(15, 23, 42, .06);
    color: #334155;
    font-size: .78rem;
    font-style: normal;
    white-space: nowrap;
}

.fewo-warning-text {
    color: #92400e !important;
    background: rgba(245, 158, 11, .12) !important;
}

.fewo-error-text {
    color: #991b1b !important;
    background: rgba(239, 68, 68, .12) !important;
}

.fewo-ical-import-detail {
    border-top: 1px solid rgba(15, 23, 42, .08);
    padding: 1rem 1.1rem 1.1rem;
}

.fewo-ical-import-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 1.25rem;
    margin-bottom: 1rem;
}

.fewo-ical-import-actions,
.fewo-ical-import-danger-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: .55rem;
}

.fewo-ical-import-danger-row {
    margin-top: .75rem;
    padding-top: .75rem;
    border-top: 1px dashed rgba(15, 23, 42, .12);
}

.fewo-ical-import-help {
    margin-top: 1rem;
    padding: .9rem 1rem;
    border-radius: 16px;
    background: rgba(241, 245, 249, .8);
    color: #334155;
}

.fewo-ical-import-help p {
    margin: .25rem 0 0;
}

.fewo-ical-import-help code {
    display: inline-block;
    max-width: 100%;
    overflow-wrap: anywhere;
}

@media (max-width: 760px) {
    .fewo-admin-subhead,
    .fewo-ical-import-item > summary {
        align-items: stretch;
        flex-direction: column;
    }

    .fewo-ical-import-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fewo-ical-import-badges {
        justify-content: flex-start;
    }
}

@media (max-width: 460px) {
    .fewo-ical-import-summary {
        grid-template-columns: 1fr;
    }
}

/* Admin cockpit split layout */
.fewo-admin-hero--cockpit {
    align-items: stretch;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fewo-admin-hero--cockpit .fewo-admin-hero-copy p:last-child {
    max-width: 760px;
}

.fewo-admin-cockpit-nav {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: .55rem;
    margin: 1rem 0;
}

.fewo-admin-cockpit-nav a {
    position: relative;
    display: flex;
    min-height: 66px;
    flex-direction: column;
    justify-content: center;
    gap: .12rem;
    border: 1px solid rgba(15, 23, 42, .09);
    border-radius: 16px;
    padding: .72rem .82rem;
    background: rgba(255, 255, 255, .82);
    color: #26302b;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .045);
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.fewo-admin-cockpit-nav a:hover,
.fewo-admin-cockpit-nav a:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(85, 112, 96, .34);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
}

.fewo-admin-cockpit-nav a.is-active {
    border-color: rgba(70, 98, 82, .55);
    background: linear-gradient(135deg, rgba(244, 248, 245, .98), rgba(255, 255, 255, .92));
    box-shadow: inset 0 0 0 1px rgba(70, 98, 82, .12), 0 14px 32px rgba(15, 23, 42, .08);
}

.fewo-admin-cockpit-nav span {
    font-size: .94rem;
    font-weight: 850;
    letter-spacing: -.01em;
    line-height: 1.15;
}

.fewo-admin-cockpit-nav small {
    color: #6b756f;
    font-size: .74rem;
    font-weight: 720;
    line-height: 1.18;
}

.fewo-admin-cockpit-nav em {
    position: absolute;
    top: .45rem;
    right: .5rem;
    min-width: 1.35rem;
    border-radius: 999px;
    padding: .12rem .38rem;
    background: #2f5f46;
    color: #fff;
    font-size: .72rem;
    font-style: normal;
    font-weight: 850;
    line-height: 1.15;
    text-align: center;
}

.fewo-admin-cockpit-intro {
    margin: 1rem 0;
    padding: 1.05rem 1.15rem;
}

.fewo-admin-cockpit-intro h2 {
    margin: .12rem 0 .25rem;
    font-size: clamp(1.2rem, 2.5vw, 1.7rem);
}

.fewo-admin-cockpit-intro p:last-child {
    max-width: 860px;
    margin-bottom: 0;
    color: #606b64;
}

.fewo-admin-cockpit-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .85rem;
    margin: 1rem 0 1.25rem;
}

.fewo-admin-cockpit-tile {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: .2rem .75rem;
    align-items: start;
    min-height: 104px;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 20px;
    padding: 1rem 1.05rem;
    background: #fff;
    color: #26302b;
    text-decoration: none;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .05);
}

.fewo-admin-cockpit-tile:hover,
.fewo-admin-cockpit-tile:focus-visible {
    border-color: rgba(85, 112, 96, .32);
    box-shadow: 0 16px 34px rgba(15, 23, 42, .08);
}

.fewo-admin-cockpit-tile span {
    font-size: 1rem;
    font-weight: 850;
}

.fewo-admin-cockpit-tile strong {
    align-self: start;
    border-radius: 999px;
    padding: .25rem .52rem;
    background: rgba(70, 98, 82, .1);
    color: #284c39;
    font-size: .8rem;
    font-weight: 900;
    line-height: 1;
}

.fewo-admin-cockpit-tile small {
    grid-column: 1 / -1;
    color: #68736d;
    font-size: .86rem;
    font-weight: 720;
    line-height: 1.35;
}

@media (max-width: 1180px) {
    .fewo-admin-cockpit-nav {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .fewo-admin-cockpit-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .fewo-admin-cockpit-nav {
        display: flex;
        overflow-x: auto;
        gap: .5rem;
        padding-bottom: .25rem;
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
    }

    .fewo-admin-cockpit-nav a {
        flex: 0 0 138px;
        min-height: 62px;
        scroll-snap-align: start;
        padding: .68rem .74rem;
    }

    .fewo-admin-cockpit-nav span {
        font-size: .9rem;
    }

    .fewo-admin-cockpit-nav small {
        font-size: .72rem;
    }

    .fewo-admin-cockpit-grid {
        grid-template-columns: 1fr;
    }

  .fewo-admin-cockpit-intro {
        padding: .95rem 1rem;
    }
}

@media (max-width: 680px) {
  .fewo-admin-unit-image-grid {
    grid-template-columns: 1fr;
  }

  .fewo-license-panel {
    grid-template-columns: 1fr;
  }

  .fewo-booking-number-controls {
    grid-template-columns: 1fr;
  }
}

/* Bookings cockpit refinement, 2026-06-10 */
#bookings .fewo-admin-section-head {
  gap: .95rem;
  align-items: flex-start;
}

#bookings .fewo-admin-eyebrow {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
}

#bookings .fewo-admin-section-head h2 {
  margin: .15rem 0 .35rem;
  font-size: clamp(1.55rem, 2.35vw, 2.05rem);
  line-height: 1.08;
}

#bookings .fewo-admin-section-head p {
  max-width: 760px;
  color: #5e645f;
  font-size: .95rem;
  line-height: 1.5;
}

#bookings .fewo-admin-section-actions .fewo-button {
  min-height: 0;
  padding: .62rem .95rem;
  border-radius: 999px;
  font-size: .88rem;
  font-weight: 700;
  box-shadow: none;
}

#bookings .fewo-admin-section-actions .fewo-button:hover,
#bookings .fewo-admin-filter-actions .fewo-button:hover,
#bookings .fewo-actions .fewo-button:hover {
  transform: none;
  box-shadow: none;
}

#bookings .fewo-admin-filter-panel {
  gap: .58rem;
  margin: .8rem 0 1rem;
  padding: .78rem .86rem;
  border-color: #e7e0d8;
  border-radius: 14px;
  background: #fff;
  box-shadow: none;
}

#bookings .fewo-admin-filter-form {
  grid-template-columns: minmax(210px, 1.25fr) repeat(4, minmax(130px, .75fr)) auto;
  gap: .55rem;
}

#bookings .fewo-admin-filter-form label {
  gap: .22rem;
  color: #3f4540;
  font-size: .82rem;
  font-weight: 650;
}

#bookings .fewo-admin-filter-form input,
#bookings .fewo-admin-filter-form select {
  padding: .48rem .56rem;
  border-color: #d9d1c8;
  border-radius: 9px;
  color: #272d29;
  font-size: .88rem;
  font-weight: 500;
}

#bookings .fewo-admin-filter-form input::placeholder {
  color: #9a9e9a;
  font-weight: 500;
}

#bookings .fewo-admin-filter-actions {
  gap: .4rem;
}

#bookings .fewo-admin-filter-actions .fewo-button {
  min-height: 0;
  padding: .48rem .7rem;
  font-size: .82rem;
  font-weight: 700;
}

#bookings .fewo-admin-filter-summary {
  color: #68716a;
  font-size: .86rem;
  font-weight: 600;
}

#bookings .fewo-booking-list {
  gap: .52rem;
}

#bookings .fewo-booking-card {
  border-color: #e8e1da;
  border-radius: 12px;
  background: #fff;
  box-shadow: none;
}

#bookings .fewo-booking-row__summary {
  grid-template-columns: minmax(150px, 1.05fr) minmax(165px, 1.15fr) minmax(150px, .95fr) minmax(205px, 1.35fr) minmax(130px, .78fr) auto;
  gap: .62rem;
  padding: .68rem .78rem;
}

#bookings .fewo-booking-row__summary::after {
  width: 1.58rem;
  height: 1.58rem;
  border-color: #d9d1c8;
  background: #fff;
  color: #736d65;
  font-size: .9rem;
  font-weight: 700;
}

#bookings .fewo-booking-card[open] .fewo-booking-row__summary {
  border-bottom-color: #eee7df;
  background: #fff;
}

#bookings .fewo-booking-row__cell {
  gap: .12rem;
}

#bookings .fewo-booking-row__cell strong {
  color: #252b27;
  font-size: .94rem;
  font-weight: 650;
}

#bookings .fewo-booking-row__cell--number strong {
  font-size: 1rem;
}

#bookings .fewo-booking-row__cell small {
  color: #676d68;
  font-size: .8rem;
}

#bookings .fewo-booking-card__body {
  gap: .7rem;
  padding: .72rem .8rem .82rem;
}

#bookings .fewo-booking-card__grid {
  grid-template-columns: minmax(210px, .92fr) minmax(340px, 1.35fr) minmax(210px, .75fr);
  gap: .72rem;
}

#bookings .fewo-booking-card__meta {
  gap: .55rem;
}

#bookings .fewo-booking-card__block,
#bookings .fewo-booking-card__payment,
#bookings .fewo-booking-card__actions {
  border-color: #e8e1da;
  border-radius: 12px;
  background: #fff;
  padding: .62rem .68rem;
}

#bookings .fewo-booking-card__label {
  color: #8a8279;
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .065em;
}

#bookings .fewo-booking-card__number {
  font-size: 1.02rem;
  font-weight: 650;
}

#bookings .fewo-booking-card__block strong {
  font-weight: 650;
}

#bookings .fewo-booking-card__block small {
  color: #666d68;
  font-size: .82rem;
  line-height: 1.35;
}

#bookings .fewo-booking-card__badges {
  gap: .34rem;
}

#bookings .fewo-badge,
#bookings .fewo-badge-test,
#bookings .fewo-badge-company {
  min-height: 1.3rem;
  padding: .15rem .42rem;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}

#bookings .fewo-status-inline {
  color: #69706a;
  font-size: .78rem;
  font-weight: 500;
}

#bookings .fewo-booking-card__section-head {
  gap: .08rem;
  margin-bottom: .48rem;
}

#bookings .fewo-booking-card__section-head h3 {
  font-size: .94rem;
  font-weight: 650;
}

#bookings .fewo-booking-card__section-head p {
  color: #6f756f;
  font-size: .78rem;
  line-height: 1.35;
}

#bookings .fewo-admin-amount-overview {
  gap: .28rem .38rem;
}

#bookings .fewo-admin-amount-overview > strong {
  font-size: 1.25rem;
  font-weight: 650;
}

#bookings .fewo-admin-amount-overview > span,
#bookings .fewo-admin-pay-chip {
  font-size: .78rem;
  font-weight: 550;
}

#bookings .fewo-payment-steps,
#bookings .fewo-payment-steps--compact {
  gap: .38rem;
}

#bookings .fewo-payment-step,
#bookings .fewo-payment-steps--compact .fewo-payment-step {
  padding: .48rem .55rem;
  border-radius: 10px;
  border-color: #e8e1da;
  box-shadow: inset 3px 0 0 #d9d2ca;
}

#bookings .fewo-payment-step__main strong,
#bookings .fewo-payment-step__amounts strong {
  font-size: .9rem;
  font-weight: 650;
}

#bookings .fewo-payment-step__main small,
#bookings .fewo-payment-step__amounts small {
  font-size: .76rem;
}

#bookings .fewo-payment-step__status {
  padding: .13rem .38rem;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .045em;
}

#bookings .fewo-actions {
  gap: .5rem;
}

#bookings .fewo-actions form {
  gap: .34rem;
  padding: .52rem;
  border-color: #e8e1da;
  border-radius: 11px;
  background: #fff;
}

#bookings .fewo-actions .fewo-button,
#bookings .fewo-actions .fewo-button-small {
  min-height: 0;
  padding: .56rem .68rem;
  font-size: .84rem;
  font-weight: 700;
}

#bookings .fewo-actions small {
  color: #707770;
  font-size: .78rem;
  line-height: 1.3;
}

#bookings .fewo-actions select,
#bookings .fewo-actions input {
  padding: .46rem .52rem;
  border-radius: 8px;
  font-size: .82rem;
}

@media (max-width: 760px) {
  #bookings .fewo-booking-card__grid,
  #bookings .fewo-booking-row__summary {
    grid-template-columns: 1fr;
  }

  #bookings .fewo-booking-row__summary::after {
    position: absolute;
    right: .75rem;
    top: .7rem;
  }

  #bookings .fewo-booking-row__summary {
    position: relative;
    padding-right: 2.85rem;
  }
}

/* Compact admin and guest portal refinement, 2026-06-10 */
:root {
  --fewo-ui-line: #e4ddd5;
  --fewo-ui-line-soft: #eee8e1;
  --fewo-ui-surface: #fff;
  --fewo-ui-surface-soft: #fbfaf8;
  --fewo-ui-text: #252b27;
  --fewo-ui-muted: #666d68;
  --fewo-ui-label: #7b837c;
  --fewo-ui-accent: #9b5837;
  --fewo-ui-ok: #2f7d46;
  --fewo-ui-ok-bg: #f1f8f3;
  --fewo-ui-ok-line: #bedfc7;
  --fewo-ui-warn: #a46c10;
  --fewo-ui-warn-bg: #fff8ea;
  --fewo-ui-warn-line: #edd39a;
  --fewo-ui-danger: #9f1f1f;
  --fewo-ui-danger-bg: #fff3f3;
  --fewo-ui-danger-line: #ecc0c0;
  --fewo-ui-info: #49677b;
  --fewo-ui-info-bg: #f2f7fb;
  --fewo-ui-info-line: #cbdcea;
  --fewo-ui-radius: 12px;
  --fewo-ui-radius-small: 9px;
}

.fewo-admin-hero,
.fewo-admin-card,
.fewo-admin-cockpit-intro,
.fewo-admin-next,
.fewo-stat-card,
.fewo-guest-portal .fewo-card,
.fewo-manage-page .fewo-card {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius);
  background: var(--fewo-ui-surface);
  box-shadow: none;
}

.fewo-admin-hero {
  align-items: start;
  padding: 1rem 1.1rem;
  background: var(--fewo-ui-surface);
}

.fewo-admin-card,
.fewo-admin-cockpit-intro {
  padding: clamp(.85rem, 1.6vw, 1.15rem);
}

.fewo-admin-hero h2,
.fewo-admin-section-head h2,
.fewo-admin-cockpit-intro h2,
.fewo-admin-card h2,
.fewo-admin-card h3,
.fewo-admin-card h4,
.fewo-guest-portal h2,
.fewo-guest-portal h3,
.fewo-manage-page h2,
.fewo-manage-page h3 {
  font-family: inherit;
  color: var(--fewo-ui-text);
  font-weight: 650;
  letter-spacing: 0;
}

.fewo-admin-hero h2,
.fewo-admin-section-head h2,
.fewo-admin-cockpit-intro h2 {
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  line-height: 1.13;
}

.fewo-admin-section-head {
  gap: .75rem;
  align-items: flex-start;
  margin-bottom: .75rem;
}

.fewo-admin-section-head p,
.fewo-admin-hero p,
.fewo-admin-cockpit-intro p,
.fewo-admin-card p,
.fewo-guest-portal p,
.fewo-guest-portal .fewo-lead,
.fewo-manage-page p,
.fewo-manage-page .fewo-lead {
  color: var(--fewo-ui-muted);
  font-size: .92rem;
  line-height: 1.5;
}

.fewo-admin-eyebrow,
.fewo-eyebrow,
.fewo-booking-card__label,
.fewo-invoice-card__label,
.fewo-portal-info-grid article span,
.fewo-summary-item__label {
  color: var(--fewo-ui-label) !important;
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .065em;
  line-height: 1.2;
}

.fewo-admin-toolbar,
.fewo-admin-toolbar-primary,
.fewo-admin-toolbar-secondary,
.fewo-action-row,
.fewo-admin-section-actions {
  gap: .45rem;
}

.fewo-admin-card .fewo-button,
.fewo-admin-hero .fewo-button,
.fewo-admin-cockpit-intro .fewo-button,
.fewo-manage-page .fewo-button,
.fewo-guest-portal .fewo-button,
.fewo-button-small {
  min-height: 0;
  padding: .52rem .78rem;
  border-radius: 999px;
  font-size: .83rem;
  font-weight: 700;
  letter-spacing: 0;
  box-shadow: none;
}

.fewo-admin-card .fewo-button:hover,
.fewo-admin-hero .fewo-button:hover,
.fewo-admin-cockpit-intro .fewo-button:hover,
.fewo-manage-page .fewo-button:hover,
.fewo-guest-portal .fewo-button:hover {
  transform: none;
  box-shadow: none;
}

.fewo-button-secondary,
.fewo-button-light {
  border-color: var(--fewo-ui-line);
  background: var(--fewo-ui-surface);
  color: var(--fewo-ui-text);
}

.fewo-button-danger {
  background: #a01919;
}

.fewo-admin-cockpit-nav,
.fewo-admin-nav,
.fewo-admin-nav--grouped,
.fewo-portal-nav {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius);
  background: rgba(255,255,255,.96);
  box-shadow: none;
}

.fewo-admin-cockpit-nav {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  padding: .45rem;
  margin: .8rem 0;
}

.fewo-admin-cockpit-nav a,
.fewo-admin-nav a,
.fewo-admin-nav--grouped a,
.fewo-portal-nav a {
  border-radius: var(--fewo-ui-radius-small);
  color: var(--fewo-ui-text);
  font-weight: 650;
  letter-spacing: 0;
  box-shadow: none;
}

.fewo-admin-cockpit-nav a {
  display: grid;
  gap: .08rem;
  min-width: 7.25rem;
  padding: .48rem .6rem;
  border: 1px solid transparent;
  text-decoration: none;
}

.fewo-admin-cockpit-nav a span {
  font-size: .86rem;
}

.fewo-admin-cockpit-nav a small,
.fewo-admin-nav--grouped a small,
.fewo-admin-nav-label {
  color: var(--fewo-ui-muted);
  font-size: .68rem;
  font-weight: 500;
  letter-spacing: 0;
}

.fewo-admin-cockpit-nav a em,
.fewo-admin-nav-count,
.fewo-task-total,
.fewo-admin-pill {
  min-height: 1.35rem;
  padding: .14rem .42rem;
  border-radius: 999px;
  border: 1px solid var(--fewo-ui-warn-line);
  background: var(--fewo-ui-warn-bg);
  color: var(--fewo-ui-warn);
  font-size: .68rem;
  font-style: normal;
  font-weight: 700;
}

.fewo-admin-cockpit-nav a:hover,
.fewo-admin-cockpit-nav a:focus-visible,
.fewo-admin-nav a:hover,
.fewo-admin-nav--grouped a:hover,
.fewo-portal-nav a:hover,
.fewo-portal-nav a:focus-visible {
  border-color: var(--fewo-ui-line);
  background: var(--fewo-ui-surface-soft);
  outline: 0;
}

.fewo-admin-cockpit-nav a.is-active,
.fewo-admin-nav a[aria-current="page"],
.fewo-admin-nav--grouped a.fewo-admin-nav-primary {
  border-color: #d8ccc1;
  background: #f7f4f0;
  color: var(--fewo-ui-text);
}

.fewo-admin-cockpit-grid,
.fewo-admin-stats,
.fewo-task-grid,
.fewo-admin-invoice-stats,
.fewo-admin-unit-grid,
.fewo-offer-list,
.fewo-invoice-list {
  gap: .62rem;
}

.fewo-admin-cockpit-tile,
.fewo-stat-card,
.fewo-task-panel,
.fewo-admin-unit-card,
.fewo-offer-card,
.fewo-invoice-card,
.fewo-admin-details--managed,
.fewo-admin-foldout,
.fewo-settings-panel,
.fewo-offer-create,
.fewo-admin-booking-panel,
.fewo-company-details,
.fewo-admin-subdetails,
.fewo-admin-accordion-item,
.fewo-voucher-card,
.fewo-pricing-rule-card,
.fewo-admin-deposit-panel,
.fewo-deposit-card,
.fewo-document-link,
.fewo-portal-phase-overview,
.fewo-portal-phase,
.fewo-portal-phase-card,
.fewo-portal-info-grid article,
.fewo-portal-route-grid article,
.fewo-summary-item {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius);
  background: var(--fewo-ui-surface);
  box-shadow: none;
}

.fewo-admin-cockpit-tile,
.fewo-stat-card,
.fewo-task-panel,
.fewo-admin-unit-card,
.fewo-offer-card,
.fewo-invoice-card,
.fewo-admin-deposit-panel,
.fewo-portal-phase-card,
.fewo-portal-info-grid article,
.fewo-summary-item {
  padding: .72rem .78rem;
}

.fewo-admin-cockpit-tile:hover,
.fewo-admin-cockpit-tile:focus-visible,
.fewo-offer-card:hover,
.fewo-invoice-card:hover,
.fewo-portal-phase-card:hover,
.fewo-portal-phase-card:focus-visible,
.fewo-document-link:hover,
.fewo-document-link:focus-visible {
  transform: none;
  border-color: #d7ccc1;
  box-shadow: 0 0 0 3px rgba(37,43,39,.045);
}

.fewo-stat-card strong,
.fewo-admin-next strong,
.fewo-admin-amount-overview > strong,
.fewo-admin-deposit-head > span,
.fewo-invoice-card__main strong,
.fewo-offer-card__main strong,
.fewo-portal-info-grid article strong,
.fewo-summary-item strong {
  color: var(--fewo-ui-text);
  font-weight: 650;
}

.fewo-stat-card strong {
  font-size: 1.55rem;
}

.fewo-admin-next {
  padding: .82rem .9rem;
}

.fewo-admin-filter-panel,
.fewo-admin-alert,
.fewo-empty-state,
.fewo-warning-box,
.fewo-admin-security-note,
.fewo-payment-policy-note,
.fewo-bank-card,
.fewo-customer-payment-card,
.fewo-registration-notice,
.fewo-arrival-pass,
.fewo-help-card {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius);
  background: var(--fewo-ui-surface);
  box-shadow: none;
}

.fewo-admin-filter-panel {
  gap: .55rem;
  margin: .75rem 0 1rem;
  padding: .72rem .78rem;
}

.fewo-admin-filter-form {
  gap: .5rem;
}

.fewo-admin-form label,
.fewo-admin-filter-form label,
.fewo-grid-form label,
.fewo-actions label {
  color: var(--fewo-ui-text);
  font-size: .8rem;
  font-weight: 600;
}

.fewo-admin-form input,
.fewo-admin-form select,
.fewo-admin-form textarea,
.fewo-admin-filter-form input,
.fewo-admin-filter-form select,
.fewo-admin-filter-form textarea,
.fewo-grid-form input,
.fewo-grid-form select,
.fewo-grid-form textarea,
.fewo-actions input,
.fewo-actions select,
.fewo-actions textarea {
  padding: .46rem .54rem;
  border-color: #d7d0c8;
  border-radius: var(--fewo-ui-radius-small);
  background: #fff;
  color: var(--fewo-ui-text);
  font-size: .84rem;
  font-weight: 500;
}

.fewo-admin-form textarea,
.fewo-grid-form textarea {
  line-height: 1.45;
}

.fewo-admin-form input:focus,
.fewo-admin-form select:focus,
.fewo-admin-form textarea:focus,
.fewo-admin-filter-form input:focus,
.fewo-admin-filter-form select:focus,
.fewo-admin-filter-form textarea:focus,
.fewo-grid-form input:focus,
.fewo-grid-form select:focus,
.fewo-grid-form textarea:focus {
  border-color: #bcaea1;
  box-shadow: 0 0 0 3px rgba(37,43,39,.06);
  outline: 0;
}

.fewo-admin-details--managed > summary,
.fewo-admin-foldout > summary,
.fewo-settings-panel > summary,
.fewo-offer-create > summary,
.fewo-admin-booking-panel > summary,
.fewo-admin-subdetails > summary,
.fewo-company-details summary,
.fewo-admin-accordion-item > summary {
  padding: .62rem .72rem;
  border-color: var(--fewo-ui-line-soft);
  border-radius: var(--fewo-ui-radius-small);
  background: var(--fewo-ui-surface);
  color: var(--fewo-ui-text);
  font-size: .9rem;
  font-weight: 650;
}

.fewo-admin-details--managed[open] > summary,
.fewo-admin-foldout[open] > summary,
.fewo-settings-panel[open] > summary,
.fewo-offer-create[open] > summary,
.fewo-admin-booking-panel[open] > summary,
.fewo-admin-subdetails[open] > summary,
.fewo-company-details[open] summary {
  border-bottom-color: var(--fewo-ui-line);
  background: var(--fewo-ui-surface-soft);
}

.fewo-badge,
.fewo-status-badge,
.fewo-admin-inline-status,
.fewo-invoice-status,
.fewo-payment-step__status,
.fewo-registration-status,
.fewo-portal-phase-card__status,
.fewo-portal-phase-task > span,
.fewo-admin-pay-chip {
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}

.fewo-badge,
.fewo-status-badge,
.fewo-invoice-status,
.fewo-admin-inline-status,
.fewo-admin-pay-chip {
  min-height: 1.28rem;
  padding: .15rem .42rem;
  border: 1px solid var(--fewo-ui-line);
  background: #f7f4f0;
  color: #5b625c;
}

.fewo-badge-confirmed,
.fewo-badge-paid,
.fewo-badge-booked,
.fewo-badge-sent,
.fewo-badge-completed,
.fewo-badge-ready,
.fewo-status-badge--confirmed,
.fewo-status-badge--paid,
.fewo-invoice-status--sent,
.fewo-admin-inline-status--ok,
.fewo-payment-step--paid .fewo-payment-step__status {
  border-color: var(--fewo-ui-ok-line);
  background: var(--fewo-ui-ok-bg);
  color: var(--fewo-ui-ok);
}

.fewo-badge-draft,
.fewo-badge-requested,
.fewo-badge-unpaid,
.fewo-badge-awaiting_bank_transfer,
.fewo-badge-cash_on_arrival,
.fewo-badge-open,
.fewo-badge-pending,
.fewo-task-total--active,
.fewo-status-badge--draft,
.fewo-status-badge--payment,
.fewo-invoice-status--open,
.fewo-admin-inline-status--open,
.fewo-payment-step--due .fewo-payment-step__status,
.fewo-payment-step--soon .fewo-payment-step__status,
.fewo-payment-step--upcoming .fewo-payment-step__status {
  border-color: var(--fewo-ui-warn-line);
  background: var(--fewo-ui-warn-bg);
  color: var(--fewo-ui-warn);
}

.fewo-badge-cancelled,
.fewo-badge-expired,
.fewo-badge-paypal_error,
.fewo-badge-declined,
.fewo-status-badge--cancelled,
.fewo-payment-step--overdue .fewo-payment-step__status {
  border-color: var(--fewo-ui-danger-line);
  background: var(--fewo-ui-danger-bg);
  color: var(--fewo-ui-danger);
}

.fewo-payment-step,
.fewo-payment-steps--compact .fewo-payment-step,
.fewo-payment-steps--customer-management .fewo-payment-step {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius-small);
  background: var(--fewo-ui-surface);
  box-shadow: inset 3px 0 0 #d7d0c8;
}

.fewo-payment-step--paid,
.fewo-payment-steps--customer-management .fewo-payment-step--paid {
  border-color: var(--fewo-ui-ok-line);
  background: var(--fewo-ui-ok-bg);
  box-shadow: inset 3px 0 0 var(--fewo-ui-ok);
}

.fewo-payment-step--due,
.fewo-payment-step--soon,
.fewo-payment-step--upcoming,
.fewo-payment-steps--customer-management .fewo-payment-step--due,
.fewo-payment-steps--customer-management .fewo-payment-step--soon,
.fewo-payment-steps--customer-management .fewo-payment-step--upcoming {
  border-color: var(--fewo-ui-warn-line);
  background: var(--fewo-ui-warn-bg);
  box-shadow: inset 3px 0 0 var(--fewo-ui-warn);
}

.fewo-payment-step--overdue,
.fewo-payment-steps--customer-management .fewo-payment-step--overdue,
.fewo-task-item--danger a,
.fewo-task-panel--overdue,
.fewo-admin-deposit-panel--overdue,
.fewo-deposit-card--overdue {
  border-color: var(--fewo-ui-danger-line);
  background: var(--fewo-ui-danger-bg);
  box-shadow: inset 3px 0 0 var(--fewo-ui-danger);
}

.fewo-task-item--warning a,
.fewo-task-panel--due,
.fewo-admin-deposit-panel--due,
.fewo-admin-deposit-panel--upcoming,
.fewo-admin-deposit-panel--warning,
.fewo-deposit-card--due,
.fewo-deposit-card--upcoming,
.fewo-deposit-card--warning,
.fewo-invoice-card--open {
  border-color: var(--fewo-ui-warn-line);
  background: var(--fewo-ui-warn-bg);
  box-shadow: inset 3px 0 0 var(--fewo-ui-warn);
}

.fewo-task-panel--arrival,
.fewo-admin-deposit-panel--paid,
.fewo-deposit-card--paid,
.fewo-invoice-card--sent {
  border-color: var(--fewo-ui-ok-line);
  background: var(--fewo-ui-ok-bg);
  box-shadow: inset 3px 0 0 var(--fewo-ui-ok);
}

.fewo-task-panel header {
  gap: .55rem;
  padding-bottom: .55rem;
  border-bottom-color: var(--fewo-ui-line-soft);
}

.fewo-task-panel header > span {
  width: 1.85rem;
  height: 1.85rem;
  flex-basis: 1.85rem;
  font-size: .88rem;
}

.fewo-task-item a {
  padding: .52rem .58rem;
  border-radius: var(--fewo-ui-radius-small);
}

.fewo-offer-card__main,
.fewo-invoice-card__main,
.fewo-admin-deposit-grid,
.fewo-portal-info-grid,
.fewo-portal-summary-grid,
.fewo-summary-grid {
  gap: .55rem;
}

.fewo-offer-card__main > div,
.fewo-invoice-card__main > div,
.fewo-admin-deposit-grid > div,
.fewo-info-list > div,
.fewo-booking-card__block {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius-small);
  background: var(--fewo-ui-surface);
}

.fewo-guest-portal {
  gap: .75rem;
}

.fewo-guest-portal .fewo-card,
.fewo-manage-page .fewo-card {
  padding: clamp(.85rem, 1.7vw, 1.15rem);
}

.fewo-portal-hero,
.fewo-manage-hero,
.fewo-card-accent {
  background: var(--fewo-ui-surface);
}

.fewo-portal-hero h2 {
  font-size: clamp(1.55rem, 2.7vw, 2.35rem);
}

.fewo-portal-tags,
.fewo-portal-status {
  gap: .36rem;
}

.fewo-portal-tags span {
  padding: .24rem .48rem;
  border-color: var(--fewo-ui-line);
  background: var(--fewo-ui-surface-soft);
  color: var(--fewo-ui-muted);
  font-size: .78rem;
  font-weight: 600;
}

.fewo-portal-nav {
  gap: .32rem;
  padding: .4rem;
}

.fewo-portal-nav a {
  padding: .42rem .58rem;
  color: var(--fewo-ui-text);
  font-size: .82rem;
}

.fewo-portal-phase-overview,
.fewo-portal-phase {
  padding: .85rem;
  background: var(--fewo-ui-surface);
}

.fewo-portal-phase-overview__head,
.fewo-portal-phase__head {
  gap: .65rem;
  margin-bottom: .7rem;
}

.fewo-portal-phase-card {
  gap: .3rem;
}

.fewo-portal-phase-card__status {
  min-height: 1.32rem;
  padding: .16rem .42rem;
  background: #f7f4f0;
  color: var(--fewo-ui-muted);
}

.fewo-portal-phase-card--done {
  border-color: var(--fewo-ui-ok-line);
  background: var(--fewo-ui-ok-bg);
}

.fewo-portal-phase-card--active,
.fewo-portal-phase-card--open {
  border-color: var(--fewo-ui-warn-line);
  background: var(--fewo-ui-warn-bg);
}

.fewo-portal-phase-task {
  grid-template-columns: 1rem minmax(0, 1fr);
  gap: .28rem;
  font-size: .78rem;
}

.fewo-portal-phase-task > span {
  width: 1rem;
  height: 1rem;
  font-size: .68rem;
}

.fewo-portal-phase-task--done > span {
  background: var(--fewo-ui-ok-bg);
  color: var(--fewo-ui-ok);
}

.fewo-portal-phase-task--open > span,
.fewo-portal-phase-task--active > span {
  background: var(--fewo-ui-warn-bg);
  color: var(--fewo-ui-warn);
}

.fewo-document-link {
  min-height: 0;
  padding: .7rem .76rem;
}

.fewo-checkout-list li {
  grid-template-columns: 1.55rem minmax(0, 1fr);
  padding: .58rem .62rem;
  border-radius: var(--fewo-ui-radius-small);
}

.fewo-checkout-list li::before {
  width: 1.55rem;
  height: 1.55rem;
  background: #f0ebe5;
  color: var(--fewo-ui-text);
  font-size: .78rem;
}

.fewo-guest-communication-item {
  border-color: var(--fewo-ui-line);
  border-radius: var(--fewo-ui-radius-small);
  background: var(--fewo-ui-surface);
}

.fewo-guest-communication-marker {
  background: #f0ebe5;
  color: var(--fewo-ui-text);
}

@media (max-width: 760px) {
  .fewo-admin-cockpit-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .fewo-admin-cockpit-nav a {
    min-width: 8.4rem;
  }

  .fewo-admin-card,
  .fewo-admin-cockpit-intro,
  .fewo-guest-portal .fewo-card,
  .fewo-manage-page .fewo-card {
    border-radius: 11px;
  }
}

/* Button and tab clarity refinement, 2026-06-10 */
.fewo-page .fewo-button,
.fewo-admin-hero .fewo-button,
.fewo-admin-card .fewo-button,
.fewo-admin-cockpit-intro .fewo-button,
.fewo-manage-page .fewo-button,
.fewo-guest-portal .fewo-button,
#bookings .fewo-button,
#bookings .fewo-actions .fewo-button,
.fewo-actions .fewo-button,
.fewo-button-small {
  min-height: 2.18rem;
  padding: .58rem .9rem;
  border: 1px solid #202624;
  border-radius: 999px;
  background: linear-gradient(180deg, #2b322e, #202624);
  color: #fff;
  font-size: .84rem;
  font-weight: 750;
  line-height: 1.15;
  text-decoration: none;
  box-shadow: 0 5px 12px rgba(32, 38, 36, .16);
  transition: transform .16s ease, box-shadow .16s ease, background-color .16s ease, border-color .16s ease, color .16s ease;
}

.fewo-page .fewo-button:hover,
.fewo-page .fewo-button:focus-visible,
.fewo-admin-hero .fewo-button:hover,
.fewo-admin-hero .fewo-button:focus-visible,
.fewo-admin-card .fewo-button:hover,
.fewo-admin-card .fewo-button:focus-visible,
.fewo-admin-cockpit-intro .fewo-button:hover,
.fewo-admin-cockpit-intro .fewo-button:focus-visible,
.fewo-manage-page .fewo-button:hover,
.fewo-manage-page .fewo-button:focus-visible,
.fewo-guest-portal .fewo-button:hover,
.fewo-guest-portal .fewo-button:focus-visible,
#bookings .fewo-button:hover,
#bookings .fewo-button:focus-visible,
#bookings .fewo-actions .fewo-button:hover,
#bookings .fewo-actions .fewo-button:focus-visible,
.fewo-actions .fewo-button:hover,
.fewo-actions .fewo-button:focus-visible {
  transform: translateY(-1px);
  border-color: #111614;
  background: linear-gradient(180deg, #343b37, #171c19);
  color: #fff;
  box-shadow: 0 8px 18px rgba(32, 38, 36, .22);
  outline: 0;
}

.fewo-page .fewo-button-secondary,
.fewo-page .fewo-button-light,
.fewo-admin-hero .fewo-button-secondary,
.fewo-admin-hero .fewo-button-light,
.fewo-admin-card .fewo-button-secondary,
.fewo-admin-card .fewo-button-light,
.fewo-admin-cockpit-intro .fewo-button-secondary,
.fewo-admin-cockpit-intro .fewo-button-light,
.fewo-manage-page .fewo-button-secondary,
.fewo-manage-page .fewo-button-light,
.fewo-guest-portal .fewo-button-secondary,
.fewo-guest-portal .fewo-button-light,
#bookings .fewo-button-secondary,
#bookings .fewo-button-light,
.fewo-actions .fewo-button-secondary,
.fewo-actions .fewo-button-light {
  border-color: #cbbfb4;
  background: linear-gradient(180deg, #fff, #fbfaf8);
  color: #202624;
  box-shadow: 0 4px 10px rgba(32, 38, 36, .09);
}

.fewo-page .fewo-button-secondary:hover,
.fewo-page .fewo-button-secondary:focus-visible,
.fewo-page .fewo-button-light:hover,
.fewo-page .fewo-button-light:focus-visible,
.fewo-admin-card .fewo-button-secondary:hover,
.fewo-admin-card .fewo-button-secondary:focus-visible,
.fewo-admin-card .fewo-button-light:hover,
.fewo-admin-card .fewo-button-light:focus-visible,
.fewo-manage-page .fewo-button-secondary:hover,
.fewo-manage-page .fewo-button-secondary:focus-visible,
.fewo-guest-portal .fewo-button-secondary:hover,
.fewo-guest-portal .fewo-button-secondary:focus-visible,
#bookings .fewo-button-secondary:hover,
#bookings .fewo-button-secondary:focus-visible,
.fewo-actions .fewo-button-secondary:hover,
.fewo-actions .fewo-button-secondary:focus-visible {
  border-color: #9b5837;
  background: linear-gradient(180deg, #fff, #fff6ef);
  color: #202624;
  box-shadow: 0 7px 16px rgba(32, 38, 36, .15);
}

.fewo-page .fewo-button-danger,
.fewo-admin-card .fewo-button-danger,
.fewo-manage-page .fewo-button-danger,
.fewo-guest-portal .fewo-button-danger,
#bookings .fewo-button-danger,
.fewo-actions .fewo-button-danger {
  border-color: #9f1f1f;
  background: linear-gradient(180deg, #b32525, #941818);
  color: #fff;
  box-shadow: 0 5px 12px rgba(159, 31, 31, .2);
}

.fewo-page .fewo-button-danger:hover,
.fewo-page .fewo-button-danger:focus-visible,
.fewo-admin-card .fewo-button-danger:hover,
.fewo-admin-card .fewo-button-danger:focus-visible,
.fewo-manage-page .fewo-button-danger:hover,
.fewo-manage-page .fewo-button-danger:focus-visible,
.fewo-guest-portal .fewo-button-danger:hover,
.fewo-guest-portal .fewo-button-danger:focus-visible,
#bookings .fewo-button-danger:hover,
#bookings .fewo-button-danger:focus-visible,
.fewo-actions .fewo-button-danger:hover,
.fewo-actions .fewo-button-danger:focus-visible {
  border-color: #7f1111;
  background: linear-gradient(180deg, #c02b2b, #841111);
  color: #fff;
  box-shadow: 0 8px 18px rgba(159, 31, 31, .26);
}

.fewo-page .fewo-button:disabled,
.fewo-admin-card .fewo-button:disabled,
.fewo-guest-portal .fewo-button:disabled,
#bookings .fewo-button:disabled {
  transform: none;
  opacity: .55;
  cursor: not-allowed;
  box-shadow: none;
}

.fewo-admin-cockpit-nav a,
.fewo-admin-nav a,
.fewo-admin-nav--grouped a,
.fewo-portal-nav a,
.fewo-portal-nav--phases a {
  border: 1px solid #d9d1c8;
  background: linear-gradient(180deg, #fff, #fbfaf8);
  box-shadow: 0 3px 8px rgba(32, 38, 36, .07);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease, color .16s ease;
}

.fewo-admin-cockpit-nav a:hover,
.fewo-admin-cockpit-nav a:focus-visible,
.fewo-admin-nav a:hover,
.fewo-admin-nav a:focus-visible,
.fewo-admin-nav--grouped a:hover,
.fewo-admin-nav--grouped a:focus-visible,
.fewo-portal-nav a:hover,
.fewo-portal-nav a:focus-visible,
.fewo-portal-nav--phases a:hover,
.fewo-portal-nav--phases a:focus-visible {
  transform: translateY(-1px);
  border-color: #bfae9f;
  background: #fff;
  box-shadow: 0 7px 16px rgba(32, 38, 36, .13);
}

.fewo-admin-cockpit-nav a.is-active,
.fewo-admin-nav a[aria-current="page"],
.fewo-admin-nav--grouped a.fewo-admin-nav-primary {
  border-color: #202624;
  background: linear-gradient(180deg, #2b322e, #202624);
  color: #fff;
  box-shadow: 0 7px 16px rgba(32, 38, 36, .18);
}

.fewo-admin-cockpit-nav a.is-active small,
.fewo-admin-nav--grouped a.fewo-admin-nav-primary small,
.fewo-admin-nav--grouped a.fewo-admin-nav-primary .fewo-admin-nav-label {
  color: rgba(255,255,255,.72);
}

.fewo-admin-cockpit-tile,
.fewo-offer-card,
.fewo-invoice-card,
.fewo-portal-phase-card,
.fewo-document-link {
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.fewo-admin-cockpit-tile:hover,
.fewo-admin-cockpit-tile:focus-visible,
.fewo-offer-card:hover,
.fewo-invoice-card:hover,
.fewo-portal-phase-card:hover,
.fewo-portal-phase-card:focus-visible,
.fewo-document-link:hover,
.fewo-document-link:focus-visible {
  transform: translateY(-1px);
  border-color: #cbbfb4;
  box-shadow: 0 8px 18px rgba(32, 38, 36, .1);
}

/* Admin tab collision guard, 2026-06-10 */
.fewo-admin-cockpit-nav a {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto auto;
  column-gap: .42rem;
  row-gap: .12rem;
  align-content: center;
  align-items: start;
  min-width: 7.85rem;
  padding-right: .62rem;
  overflow: hidden;
}

.fewo-admin-cockpit-nav a span {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-admin-cockpit-nav a small {
  grid-column: 1 / -1;
  grid-row: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-admin-cockpit-nav a em {
  position: static;
  grid-column: 2;
  grid-row: 1;
  align-self: start;
  justify-self: end;
  min-width: 1.25rem;
  max-width: 3.8rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Admin search / quick finder, 2026-06-11 */
.fewo-admin-search {
  position: relative;
  z-index: 30;
  margin: .75rem 0 .85rem;
}

.fewo-admin-search__box {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  align-items: center;
  gap: .55rem;
  padding: .52rem .62rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fff;
  box-shadow: 0 6px 18px rgba(32, 38, 36, .06);
}

.fewo-admin-search__box > span {
  display: grid;
  width: 1.72rem;
  height: 1.72rem;
  place-items: center;
  border: 1px solid rgba(19, 65, 58, .1);
  border-radius: 999px;
  background: rgba(19, 65, 58, .06);
  color: #13413a;
  font-size: 1rem;
  font-weight: 750;
  line-height: 1;
}

.fewo-admin-search__box label {
  color: var(--fewo-ui-text, #252b27);
  font-size: .82rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.fewo-admin-search__box input {
  min-width: 0;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--fewo-ui-text, #252b27);
  font: inherit;
  font-size: .9rem;
  outline: 0;
}

.fewo-admin-search__box input::placeholder {
  color: #9a9f99;
}

.fewo-admin-search__box kbd {
  padding: .16rem .38rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 7px;
  background: var(--fewo-ui-surface-soft, #fbfaf8);
  color: var(--fewo-ui-muted, #666d68);
  font: inherit;
  font-size: .68rem;
  font-weight: 650;
  white-space: nowrap;
}

.fewo-admin-search:focus-within .fewo-admin-search__box {
  border-color: #c8b8aa;
  box-shadow: 0 8px 22px rgba(32, 38, 36, .09);
}

.fewo-admin-search__results {
  position: absolute;
  top: calc(100% + .42rem);
  right: 0;
  left: 0;
  z-index: 70;
  padding: .62rem;
  border: 1px solid #d8ccc1;
  border-radius: 16px;
  background: rgba(255, 255, 255, .98);
  box-shadow: 0 20px 52px rgba(32, 38, 36, .16);
}

.fewo-admin-search__results[hidden] {
  display: none;
}

.fewo-admin-search__results-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .12rem .18rem .5rem;
}

.fewo-admin-search__results-head strong {
  color: var(--fewo-ui-text, #252b27);
  font-size: .86rem;
  font-weight: 750;
}

.fewo-admin-search__results-head button {
  display: grid;
  width: 1.75rem;
  height: 1.75rem;
  place-items: center;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 999px;
  background: #fff;
  color: var(--fewo-ui-muted, #666d68);
  cursor: pointer;
  font: inherit;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, color .16s ease;
}

.fewo-admin-search__results-head button:hover,
.fewo-admin-search__results-head button:focus-visible {
  transform: translateY(-1px);
  border-color: #bfae9f;
  color: var(--fewo-ui-text, #252b27);
  box-shadow: 0 6px 14px rgba(32, 38, 36, .12);
  outline: 0;
}

.fewo-admin-search__list {
  display: grid;
  gap: .42rem;
  max-height: min(520px, 58vh);
  overflow: auto;
  padding-right: .12rem;
}

.fewo-admin-search__item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .12rem .75rem;
  align-items: start;
  padding: .62rem .68rem;
  border: 1px solid var(--fewo-ui-line-soft, #eee8e1);
  border-radius: 12px;
  background: #fff;
  color: var(--fewo-ui-text, #252b27);
  text-decoration: none;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.fewo-admin-search__item:hover,
.fewo-admin-search__item:focus-visible {
  transform: translateY(-1px);
  border-color: #cdbfb3;
  background: var(--fewo-ui-surface-soft, #fbfaf8);
  box-shadow: 0 8px 18px rgba(32, 38, 36, .1);
  outline: 0;
}

.fewo-admin-search__item strong {
  min-width: 0;
  overflow: hidden;
  color: inherit;
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-admin-search__item small {
  grid-column: 1 / -1;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  font-weight: 500;
  line-height: 1.35;
}

.fewo-admin-search__item span {
  grid-column: 2;
  grid-row: 1;
  align-self: start;
  border-radius: 999px;
  padding: .14rem .42rem;
  background: var(--fewo-ui-surface-soft, #fbfaf8);
  color: var(--fewo-ui-label, #7b837c);
  font-size: .66rem;
  font-weight: 750;
  line-height: 1.1;
  white-space: nowrap;
}

.fewo-admin-search__empty {
  margin: .25rem .18rem .15rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .84rem;
}

.fewo-admin-search-hit {
  outline: 2px solid rgba(19, 65, 58, .28);
  outline-offset: 4px;
  animation: fewo-admin-search-hit 1.9s cubic-bezier(.2, .85, .25, 1);
}

@keyframes fewo-admin-search-hit {
  0% {
    background-color: rgba(255, 248, 234, .95);
    box-shadow: 0 0 0 0 rgba(19, 65, 58, .22);
  }
  38% {
    background-color: rgba(255, 248, 234, .95);
    box-shadow: 0 0 0 10px rgba(19, 65, 58, .08);
  }
  100% {
    background-color: inherit;
    box-shadow: none;
  }
}

@media (max-width: 760px) {
  .fewo-admin-search__box {
    grid-template-columns: auto minmax(0, 1fr);
    gap: .42rem;
  }

  .fewo-admin-search__box label,
  .fewo-admin-search__box kbd {
    display: none;
  }

  .fewo-admin-search__results {
    position: fixed;
    top: 1rem;
    right: .75rem;
    left: .75rem;
    max-height: calc(100vh - 2rem);
    overflow: hidden;
  }

  .fewo-admin-search__list {
    max-height: calc(100vh - 8rem);
  }

  .fewo-admin-search__item {
    grid-template-columns: minmax(0, 1fr);
  }

  .fewo-admin-search__item span {
    grid-column: 1;
    grid-row: auto;
    justify-self: start;
  }

  .fewo-admin-search__item strong {
    white-space: normal;
  }
}

/* Units list refinement, 2026-06-10 */
#units .fewo-admin-unit-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .55rem;
  margin: .7rem 0 .9rem;
}

#units .fewo-admin-unit-overview article {
  min-width: 0;
  display: grid;
  gap: .12rem;
  padding: .65rem .72rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fff;
}

#units .fewo-admin-unit-overview span {
  color: var(--fewo-ui-label, #7b837c);
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .065em;
  text-transform: uppercase;
}

#units .fewo-admin-unit-overview strong {
  color: var(--fewo-ui-text, #252b27);
  font-size: 1.28rem;
  font-weight: 650;
  line-height: 1;
}

#units .fewo-admin-unit-overview small {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#units .fewo-admin-unit-list {
  display: grid;
  gap: .52rem;
  margin: .75rem 0 1rem;
}

#units .fewo-admin-unit-row {
  padding: 0;
  overflow: hidden;
  border-color: var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fff;
  box-shadow: none;
}

#units .fewo-admin-unit-row.is-inactive {
  background: #fbfaf8;
}

#units .fewo-admin-unit-row__summary {
  list-style: none;
  display: grid;
  grid-template-columns: 3.4rem minmax(170px, 1.2fr) minmax(180px, .95fr) minmax(155px, .82fr) minmax(130px, .7fr) auto 1.6rem;
  gap: .58rem;
  align-items: center;
  padding: .62rem .72rem;
  cursor: pointer;
}

#units .fewo-admin-unit-row__summary::-webkit-details-marker {
  display: none;
}

#units .fewo-admin-unit-row__summary::after {
  content: "+";
  display: inline-grid;
  grid-column: 7;
  place-items: center;
  width: 1.55rem;
  height: 1.55rem;
  border: 1px solid #d9d1c8;
  border-radius: 50%;
  background: #fff;
  color: #736d65;
  font-size: .9rem;
  font-weight: 750;
}

#units .fewo-admin-unit-row[open] .fewo-admin-unit-row__summary {
  border-bottom: 1px solid var(--fewo-ui-line-soft, #eee8e1);
  background: #fff;
}

#units .fewo-admin-unit-row[open] .fewo-admin-unit-row__summary::after {
  content: "-";
}

#units .fewo-admin-unit-row__media {
  width: 3.4rem;
  height: 2.75rem;
  overflow: hidden;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 8px;
  background: #f4f1ed;
}

#units .fewo-admin-unit-row__media img,
#units .fewo-admin-unit-row__media .fewo-admin-unit-placeholder {
  width: 100%;
  height: 100%;
}

#units .fewo-admin-unit-row__media img {
  display: block;
  object-fit: cover;
}

#units .fewo-admin-unit-row__media .fewo-admin-unit-placeholder {
  display: grid;
  place-items: center;
  color: #8b837a;
  font-size: .72rem;
  font-weight: 700;
}

#units .fewo-admin-unit-row__main,
#units .fewo-admin-unit-row__status,
#units .fewo-admin-unit-row__price,
#units .fewo-admin-unit-row__deposit,
#units .fewo-admin-unit-row__actions {
  min-width: 0;
}

#units .fewo-admin-unit-row__main {
  display: grid;
  gap: .1rem;
}

#units .fewo-admin-unit-row__main strong {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-text, #252b27);
  font-size: .96rem;
  font-weight: 650;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#units .fewo-admin-unit-row__main small,
#units .fewo-admin-unit-row__price small,
#units .fewo-admin-unit-row__deposit small {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  line-height: 1.3;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#units .fewo-admin-unit-row__status {
  display: flex;
  flex-wrap: wrap;
  gap: .32rem;
}

#units .fewo-admin-unit-status-toggle {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  min-height: 1.7rem;
  padding: .28rem .52rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 999px;
  background: #fff;
  color: var(--fewo-ui-muted, #666d68);
  box-shadow: 0 5px 12px rgba(32,38,36,.04);
  font: inherit;
  font-size: .72rem;
  font-weight: 740;
  line-height: 1;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease, transform .18s ease;
  white-space: nowrap;
}

#units .fewo-admin-unit-status-toggle span {
  width: .46rem;
  height: .46rem;
  border-radius: 50%;
  background: currentColor;
}

#units .fewo-admin-unit-status-toggle.is-on {
  border-color: rgba(66,150,91,.28);
  background: #f2fbf4;
  color: #287542;
}

#units .fewo-admin-unit-status-toggle.is-off {
  border-color: rgba(138,131,121,.26);
  background: #fbfaf8;
  color: #7c756c;
}

#units .fewo-admin-unit-status-toggle:hover,
#units .fewo-admin-unit-status-toggle:focus-visible {
  border-color: rgba(185,104,66,.48);
  box-shadow: 0 10px 22px rgba(32,38,36,.08);
  color: #9a4f31;
  transform: translateY(-1px);
}

#units .fewo-admin-unit-row__price,
#units .fewo-admin-unit-row__deposit {
  display: grid;
  gap: .1rem;
}

#units .fewo-admin-unit-row__price span,
#units .fewo-admin-unit-row__deposit span {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-text, #252b27);
  font-size: .88rem;
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#units .fewo-admin-unit-row__actions {
  display: flex;
  justify-content: flex-end;
}

#units .fewo-admin-unit-copy {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: .42rem .68rem;
  border: 1px solid rgba(185,104,66,.34);
  border-radius: 999px;
  background: #fffaf6;
  color: #9a4f31;
  box-shadow: 0 6px 16px rgba(32,38,36,.06);
  font: inherit;
  font-size: .76rem;
  font-weight: 720;
  line-height: 1;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease;
  white-space: nowrap;
}

#units .fewo-admin-unit-copy:hover:not(:disabled),
#units .fewo-admin-unit-copy:focus-visible {
  border-color: rgba(185,104,66,.62);
  background: #fff3ea;
  box-shadow: 0 10px 22px rgba(32,38,36,.1);
  transform: translateY(-1px);
}

#units .fewo-admin-unit-copy:disabled {
  opacity: .48;
  cursor: not-allowed;
  box-shadow: none;
}

#units .fewo-admin-unit-row__body {
  padding: .74rem .78rem .82rem;
  background: #fff;
}

#units .fewo-admin-unit-row__body .fewo-settings-grid {
  gap: .62rem;
}

.fewo-cancellation-rule-editor {
  display: grid;
  gap: .48rem;
}

.fewo-cancellation-rule-row {
  display: grid;
  grid-template-columns: minmax(8.5rem, .62fr) minmax(7.5rem, .5fr) minmax(0, 1.5fr);
  gap: .52rem;
  align-items: end;
  padding: .58rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius-small, 9px);
  background: #fffdf9;
}

.fewo-cancellation-rule-label {
  min-width: 0;
}

.fewo-settings-readonly-inline {
  display: flex;
  min-height: 2.42rem;
  align-items: center;
  padding: .54rem .62rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 9px;
  background: var(--fewo-ui-surface-soft, #fbfaf8);
  color: var(--fewo-ui-muted, #666d68);
  font-size: .82rem;
  font-weight: 550;
}

@media (max-width: 860px) {
  .fewo-cancellation-rule-row {
    grid-template-columns: 1fr;
  }
}

#units .fewo-admin-amenity-picker {
  display: grid;
  gap: .72rem;
  padding: .8rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fffdf9;
}

#units .fewo-admin-amenity-picker__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .7rem;
}

#units .fewo-admin-amenity-picker__head strong {
  color: var(--fewo-ui-text, #252b27);
  font-size: .92rem;
  font-weight: 680;
}

#units .fewo-admin-amenity-picker__head span {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
}

#units .fewo-admin-amenity-groups {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .55rem;
}

#units .fewo-admin-amenity-group {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: .32rem;
  margin: 0;
  padding: .58rem;
  border: 1px solid rgba(32,38,36,.08);
  border-radius: 10px;
  background: #fff;
}

#units .fewo-admin-amenity-group legend {
  padding: 0 .18rem;
  color: var(--fewo-ui-label, #7b837c);
  font-size: .68rem;
  font-weight: 750;
  letter-spacing: .055em;
  text-transform: uppercase;
}

#units .fewo-admin-amenity-group .fewo-checkbox-line--compact {
  min-height: auto;
  padding: .32rem .38rem;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--fewo-ui-text, #252b27);
  font-size: .8rem;
}

#units .fewo-admin-amenity-group .fewo-checkbox-line--compact:hover {
  background: rgba(185,104,66,.07);
}

#units .fewo-admin-unit-card#unit-create {
  margin-top: .65rem;
}

.fewo-admin-review-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .62rem;
  margin: .85rem 0;
}

.fewo-admin-review-overview article {
  min-width: 0;
  padding: .78rem .9rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fffdf9;
}

.fewo-admin-review-overview span,
.fewo-admin-review-original span {
  display: block;
  color: var(--fewo-ui-label, #7b837c);
  font-size: .68rem;
  font-weight: 760;
  letter-spacing: .055em;
  line-height: 1.2;
  text-transform: uppercase;
}

.fewo-admin-review-overview strong {
  display: block;
  margin-top: .18rem;
  color: var(--fewo-ui-text, #252b27);
  font-size: 1.45rem;
  font-weight: 690;
  line-height: 1.05;
}

.fewo-admin-review-overview small {
  display: block;
  margin-top: .18rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
}

.fewo-admin-review-filter {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  margin: .2rem 0 .8rem;
}

.fewo-admin-review-filter a {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  min-height: 2rem;
  padding: .36rem .62rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 999px;
  background: #fff;
  color: var(--fewo-ui-text, #252b27);
  font-size: .78rem;
  font-weight: 650;
  text-decoration: none;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.fewo-admin-review-filter a:hover,
.fewo-admin-review-filter a.is-active {
  border-color: rgba(185,104,66,.36);
  background: #fff6ef;
  box-shadow: 0 8px 18px rgba(32,38,36,.06);
}

.fewo-admin-review-filter em {
  min-width: 1.25rem;
  padding: .08rem .32rem;
  border-radius: 999px;
  background: rgba(32,38,36,.08);
  color: var(--fewo-ui-muted, #666d68);
  font-size: .72rem;
  font-style: normal;
  text-align: center;
}

.fewo-admin-review-list {
  display: grid;
  gap: .52rem;
}

.fewo-admin-review-row {
  overflow: hidden;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: var(--fewo-ui-radius, 12px);
  background: #fff;
}

.fewo-admin-review-row > summary {
  list-style: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(7rem, auto) minmax(9rem, auto) 1.6rem;
  gap: .65rem;
  align-items: center;
  padding: .68rem .76rem;
  cursor: pointer;
}

.fewo-admin-review-row > summary::-webkit-details-marker {
  display: none;
}

.fewo-admin-review-row > summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  width: 1.55rem;
  height: 1.55rem;
  border: 1px solid #d9d1c8;
  border-radius: 50%;
  color: #736d65;
  font-size: .9rem;
  font-weight: 750;
}

.fewo-admin-review-row[open] > summary {
  border-bottom: 1px solid var(--fewo-ui-line-soft, #eee8e1);
}

.fewo-admin-review-row[open] > summary::after {
  content: "-";
}

.fewo-admin-review-row__main {
  min-width: 0;
  display: grid;
  gap: .12rem;
}

.fewo-admin-review-row__main strong,
.fewo-admin-review-original strong {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-text, #252b27);
  font-size: .95rem;
  font-weight: 660;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-admin-review-row__main small,
.fewo-admin-review-meta small {
  min-width: 0;
  overflow: hidden;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-admin-review-stars {
  white-space: nowrap;
}

.fewo-admin-review-stars span {
  color: rgba(32,38,36,.18);
  font-size: .95rem;
}

.fewo-admin-review-stars .is-filled {
  color: #b96842;
}

.fewo-admin-review-meta {
  display: grid;
  justify-items: end;
  gap: .18rem;
}

.fewo-admin-review-body {
  display: grid;
  gap: .78rem;
  padding: .82rem;
  background: #fff;
}

.fewo-admin-review-original {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .52rem;
}

.fewo-admin-review-original > div {
  min-width: 0;
  padding: .58rem .66rem;
  border: 1px solid rgba(32,38,36,.08);
  border-radius: 10px;
  background: #fffdf9;
}

@media (max-width: 900px) {
  .fewo-admin-review-overview,
  .fewo-admin-review-original {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fewo-admin-review-row > summary {
    grid-template-columns: minmax(0, 1fr) 1.6rem;
  }

  .fewo-admin-review-stars,
  .fewo-admin-review-meta {
    grid-column: 1 / -1;
    justify-items: start;
  }
}

@media (max-width: 560px) {
  .fewo-admin-review-overview,
  .fewo-admin-review-original {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1180px) {
  #units .fewo-admin-unit-row__summary {
    grid-template-columns: 3.2rem minmax(0, 1fr) auto 1.6rem;
  }

  #units .fewo-admin-unit-row__summary::after {
    grid-column: 4;
    grid-row: 1;
  }

  #units .fewo-admin-unit-row__actions {
    grid-column: 3;
    grid-row: 1;
  }

  #units .fewo-admin-unit-row__status,
  #units .fewo-admin-unit-row__price,
  #units .fewo-admin-unit-row__deposit {
    grid-column: 2 / 4;
  }

  #units .fewo-admin-unit-row__status {
    grid-row: 2;
  }

  #units .fewo-admin-unit-row__price {
    grid-row: 3;
  }

  #units .fewo-admin-unit-row__deposit {
    grid-row: 4;
  }

  #units .fewo-admin-amenity-groups {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  #units .fewo-admin-unit-overview {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #units .fewo-admin-unit-row__summary {
    grid-template-columns: 3rem minmax(0, 1fr) 1.55rem;
    gap: .48rem;
    padding: .58rem .62rem;
  }

  #units .fewo-admin-unit-row__summary::after {
    grid-column: 3;
  }

  #units .fewo-admin-unit-row__actions {
    grid-column: 1 / -1;
    grid-row: auto;
    justify-content: flex-start;
  }

  #units .fewo-admin-unit-row__media {
    width: 3rem;
    height: 2.55rem;
  }

  #units .fewo-admin-unit-row__status,
  #units .fewo-admin-unit-row__price,
  #units .fewo-admin-unit-row__deposit {
    grid-column: 1 / -1;
  }

  #units .fewo-admin-unit-row__price,
  #units .fewo-admin-unit-row__deposit {
    grid-template-columns: minmax(0, 1fr);
  }

  #units .fewo-admin-amenity-picker__head {
    display: grid;
  }

  #units .fewo-admin-amenity-groups {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 480px) {
  #units .fewo-admin-unit-overview {
    grid-template-columns: 1fr;
  }

  #units .fewo-admin-amenity-groups {
    grid-template-columns: 1fr;
  }
}

/* Heading scale and portal head collision guard, 2026-06-10 */
.fewo-page > h1 {
  font-size: clamp(1.65rem, 3vw, 2.45rem);
  line-height: 1.12;
}

.fewo-card h2,
.fewo-admin-hero h2,
.fewo-admin-section-head h2,
.fewo-admin-cockpit-intro h2,
.fewo-admin-card h2,
.fewo-guest-portal h2,
.fewo-manage-page h2 {
  font-size: clamp(1.25rem, 1.85vw, 1.75rem);
  line-height: 1.16;
}

.fewo-portal-hero h2,
.fewo-offer-hero h2 {
  font-size: clamp(1.45rem, 2.35vw, 2.1rem);
  line-height: 1.14;
}

.fewo-card h3,
.fewo-admin-card h3,
.fewo-admin-card h4,
.fewo-guest-portal h3,
.fewo-manage-page h3,
.fewo-portal-phase-card > strong {
  font-size: clamp(1rem, 1.25vw, 1.14rem);
  line-height: 1.22;
}

.fewo-portal-phase-overview__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: .35rem;
  max-width: 760px;
  margin-bottom: .78rem;
}

.fewo-portal-phase-overview__copy {
  min-width: 0;
  display: grid;
  gap: .32rem;
}

.fewo-portal-phase-overview__head h2 {
  max-width: 880px;
  margin: 0;
  font-size: clamp(1.35rem, 2.15vw, 1.95rem);
}

.fewo-portal-phase-overview__head .fewo-eyebrow,
.fewo-portal-phase-overview__head .fewo-lead {
  margin: 0;
}

.fewo-portal-phase-overview__head .fewo-lead {
  max-width: 68ch;
}

/* Feature activation readability, 2026-06-10 */
#features .fewo-settings-accordion {
  display: grid;
  gap: .72rem;
}

#features .fewo-settings-panel {
  overflow: hidden;
}

#features .fewo-settings-panel > summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 1.85rem;
  gap: .7rem;
  align-items: center;
  padding: .72rem .78rem;
}

#features .fewo-settings-panel > summary span {
  min-width: 0;
  font-size: .96rem;
  font-weight: 650;
}

#features .fewo-settings-panel > summary small {
  justify-self: center;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .84rem;
  font-weight: 600;
}

#features .fewo-settings-panel > summary::after {
  justify-self: end;
}

#features .fewo-settings-grid {
  gap: .62rem;
  padding: .72rem .78rem .86rem;
}

#features .fewo-settings-grid .fewo-checkbox-line {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  gap: .55rem;
  align-items: start;
  padding: .68rem .74rem;
  border-color: var(--fewo-ui-line, #e4ddd5);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-settings-grid .fewo-checkbox-line input[type="checkbox"] {
  width: .88rem;
  height: .88rem;
  margin-top: .12rem;
}

#features .fewo-settings-grid .fewo-checkbox-line > span {
  min-width: 0;
  display: grid;
  gap: .18rem;
}

#features .fewo-settings-grid .fewo-checkbox-line strong {
  display: block;
  color: var(--fewo-ui-text, #252b27);
  font-size: .88rem;
  font-weight: 650;
  line-height: 1.25;
}

#features .fewo-settings-grid .fewo-checkbox-line small {
  display: block;
  max-width: 80ch;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  font-weight: 500;
  line-height: 1.38;
}

#features .fewo-settings-savebar {
  margin-top: .85rem;
}

#features .fewo-operator-settings {
  margin-top: .85rem;
  margin-bottom: .85rem;
}

#features .fewo-operator-settings .fewo-settings-subhead {
  padding: .18rem 0 .25rem;
}

#features .fewo-operator-settings .fewo-settings-subhead h3 {
  margin: 0 0 .18rem;
  font-size: .92rem;
}

#features .fewo-operator-settings .fewo-settings-subhead p {
  max-width: 78ch;
  margin: 0;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .82rem;
  line-height: 1.45;
}

#features .fewo-operator-settings textarea {
  min-height: 4.4rem;
  resize: vertical;
}

#features .fewo-operator-settings input[type="file"] {
  padding: .46rem;
  background: #fff;
}

#features .fewo-billing-accordion {
  margin-top: .85rem;
}

#features .fewo-billing-current,
#features .fewo-billing-cron {
  display: grid;
  gap: .28rem;
  padding: .72rem .78rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-billing-current strong,
#features .fewo-billing-cron strong {
  font-size: .86rem;
}

#features .fewo-billing-current span,
#features .fewo-billing-cron span {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .8rem;
  line-height: 1.42;
}

#features .fewo-billing-current small {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .74rem;
  line-height: 1.42;
}

#features .fewo-billing-cron code {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  padding: .45rem .55rem;
  border-radius: 8px;
  background: rgba(32,38,36,.06);
  color: var(--fewo-ui-text, #252b27);
  font-size: .78rem;
}

#features .fewo-billing-matrix {
  max-width: 100%;
  overflow-x: auto;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-billing-matrix table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
}

#features .fewo-billing-matrix th,
#features .fewo-billing-matrix td {
  padding: .58rem .62rem;
  border-bottom: 1px solid var(--fewo-ui-line, #e4ddd5);
  text-align: left;
  vertical-align: middle;
}

#features .fewo-billing-matrix tr:last-child th,
#features .fewo-billing-matrix tr:last-child td {
  border-bottom: 0;
}

#features .fewo-billing-matrix th {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .75rem;
  font-weight: 700;
  line-height: 1.25;
}

#features .fewo-billing-matrix tbody th {
  color: var(--fewo-ui-text, #252b27);
  font-size: .82rem;
}

#features .fewo-billing-matrix input {
  width: 100%;
  min-width: 5.4rem;
  padding: .42rem .5rem;
  font-size: .82rem;
}

#features .fewo-tariff-feature-matrix {
  max-width: 100%;
  overflow-x: auto;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-tariff-feature-matrix table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

#features .fewo-tariff-feature-matrix th,
#features .fewo-tariff-feature-matrix td {
  padding: .56rem .62rem;
  border-bottom: 1px solid var(--fewo-ui-line, #e4ddd5);
  text-align: left;
  vertical-align: middle;
}

#features .fewo-tariff-feature-matrix thead th {
  color: var(--fewo-ui-text, #252b27);
  font-size: .78rem;
  font-weight: 750;
}

#features .fewo-tariff-feature-matrix thead th small {
  display: block;
  margin-top: .12rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .68rem;
  font-weight: 600;
}

#features .fewo-tariff-feature-group th {
  padding: .46rem .62rem;
  background: rgba(32,38,36,.045);
  color: var(--fewo-ui-muted, #666d68);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

#features .fewo-tariff-feature-matrix tbody tr:last-child td,
#features .fewo-tariff-feature-matrix tbody tr:last-child th {
  border-bottom: 0;
}

#features .fewo-tariff-feature-matrix td:first-child {
  min-width: 18rem;
}

#features .fewo-tariff-feature-matrix td:first-child strong {
  display: block;
  color: var(--fewo-ui-text, #252b27);
  font-size: .84rem;
  font-weight: 700;
  line-height: 1.25;
}

#features .fewo-tariff-feature-matrix td:first-child small {
  display: block;
  max-width: 48ch;
  margin-top: .14rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .74rem;
  line-height: 1.34;
}

#features .fewo-tariff-check {
  display: inline-grid;
  place-items: center;
  width: 2.15rem;
  height: 2.15rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 9px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 5px 13px rgba(32,38,36,.05);
  cursor: pointer;
}

#features .fewo-tariff-check:hover {
  border-color: rgba(185,104,66,.45);
  box-shadow: 0 8px 18px rgba(32,38,36,.08);
}

#features .fewo-tariff-check input {
  width: .95rem;
  height: .95rem;
  margin: 0;
}

#features .fewo-tariff-check span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

#features .fewo-manual-feature-list {
  display: grid;
  gap: .62rem;
}

#features .fewo-manual-feature-group {
  display: grid;
  gap: .48rem;
  padding: .62rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-manual-feature-group > strong {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

#features .fewo-language-toggle-list {
  display: grid;
  gap: .52rem;
  padding: .62rem;
  border: 1px solid rgba(228,221,213,.86);
  border-radius: 11px;
  background: #fff;
}

#features .fewo-language-toggle-list .fewo-checkbox-line {
  margin: 0;
  padding: .56rem .62rem;
  border: 1px solid rgba(228,221,213,.76);
  border-radius: 9px;
  background: rgba(250,248,244,.42);
}

.fewo-website-dashboard {
  gap: .82rem;
}

.fewo-website-price-source {
  display: grid;
  gap: .85rem;
  padding: .82rem;
}

.fewo-website-source-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.fewo-website-unit-price-list {
  display: grid;
  gap: .6rem;
}

.fewo-website-unit-price-list article {
  display: grid;
  grid-template-columns: minmax(180px, .8fr) minmax(0, 1.2fr);
  gap: .75rem;
  padding: .7rem;
  border: 1px solid rgba(228,221,213,.86);
  border-radius: 11px;
  background: #fff;
}

.fewo-website-unit-price-list strong {
  display: block;
  color: var(--fewo-ui-text, #252b27);
  font-size: .92rem;
}

.fewo-website-unit-price-list small {
  display: block;
  margin-top: .12rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .74rem;
}

.fewo-website-unit-price-list dl {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .45rem;
  margin: 0;
}

.fewo-website-unit-price-list dl div {
  min-width: 0;
  padding: .45rem;
  border: 1px solid rgba(228,221,213,.72);
  border-radius: 9px;
  background: rgba(250,248,244,.46);
}

.fewo-website-unit-price-list dt {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.fewo-website-unit-price-list dd {
  margin: .1rem 0 0;
  color: var(--fewo-ui-text, #252b27);
  font-weight: 800;
  overflow-wrap: anywhere;
}

:where(#settings, #website-content) .fewo-homepage-content-editor {
  gap: .85rem;
}

:where(#settings, #website-content) .fewo-homepage-hero-card,
:where(#settings, #website-content) .fewo-homepage-translate-card {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, .9fr) minmax(220px, .9fr) auto;
  align-items: end;
  gap: .75rem;
  padding: .82rem;
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 12px;
  background: #fff;
}

:where(#settings, #website-content) .fewo-homepage-translate-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

:where(#settings, #website-content) .fewo-homepage-hero-card h4,
:where(#settings, #website-content) .fewo-homepage-translate-card h4,
:where(#settings, #website-content) .fewo-homepage-section-head h4 {
  margin: 0 0 .18rem;
  color: var(--fewo-ui-text, #252b27);
  font-size: .92rem;
  line-height: 1.25;
}

:where(#settings, #website-content) .fewo-homepage-hero-card p,
:where(#settings, #website-content) .fewo-homepage-translate-card p,
:where(#settings, #website-content) .fewo-homepage-section-head p {
  margin: 0;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .78rem;
  line-height: 1.45;
}

:where(#settings, #website-content) .fewo-homepage-translate-card small {
  display: inline-block;
  margin-top: .28rem;
  color: var(--fewo-ui-muted, #666d68);
  font-size: .72rem;
  font-weight: 700;
}

:where(#settings, #website-content) .fewo-homepage-translation-notice {
  margin: 0;
  padding: .72rem .82rem;
  border-radius: 12px;
}

:where(#settings, #website-content) .fewo-homepage-translation-notice p {
  margin: .24rem 0 0;
  font-size: .8rem;
  line-height: 1.45;
}

:where(#settings, #website-content) .fewo-website-content-languages {
  display: grid;
  gap: .62rem;
}

:where(#settings, #website-content) .fewo-website-content-language {
  border: 1px solid var(--fewo-ui-line, #e4ddd5);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

:where(#settings, #website-content) .fewo-website-content-language > summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 2rem;
  align-items: center;
  gap: .75rem;
  min-height: 3.25rem;
  padding: .58rem .72rem;
  cursor: pointer;
  list-style: none;
}

:where(#settings, #website-content) .fewo-website-content-language > summary::-webkit-details-marker {
  display: none;
}

:where(#settings, #website-content) .fewo-website-content-language > summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: rgba(164, 79, 51, .1);
  color: var(--fewo-ui-accent, #a44f33);
  font-size: 1.1rem;
  font-weight: 800;
}

:where(#settings, #website-content) .fewo-website-content-language[open] > summary::after {
  content: "-";
  background: var(--fewo-ui-dark, #1f2722);
  color: #fff;
}

:where(#settings, #website-content) .fewo-website-content-language > summary span {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  min-width: 0;
}

:where(#settings, #website-content) .fewo-website-content-language > summary strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--fewo-ui-text, #252b27);
  font-size: .92rem;
}

:where(#settings, #website-content) .fewo-website-content-language > summary small {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .05em;
}

:where(#settings, #website-content) .fewo-homepage-language-body {
  display: grid;
  gap: .75rem;
  padding: .72rem;
  border-top: 1px solid var(--fewo-ui-line, #e4ddd5);
  background: rgba(250,248,244,.42);
}

:where(#settings, #website-content) .fewo-homepage-editor-section {
  display: grid;
  gap: .58rem;
  padding: .72rem;
  border: 1px solid rgba(228,221,213,.86);
  border-radius: 11px;
  background: #fff;
}

:where(#settings, #website-content) .fewo-website-page-panel {
  padding: 0;
  gap: 0;
  overflow: hidden;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 1.95rem;
  align-items: center;
  gap: .75rem;
  min-height: 3rem;
  padding: .58rem .72rem;
  cursor: pointer;
  list-style: none;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary::-webkit-details-marker {
  display: none;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 1.95rem;
  height: 1.95rem;
  border-radius: 999px;
  background: rgba(164, 79, 51, .1);
  color: var(--fewo-ui-accent, #a44f33);
  font-size: 1rem;
  font-weight: 800;
}

:where(#settings, #website-content) .fewo-website-page-panel[open] > summary {
  border-bottom: 1px solid var(--fewo-ui-line, #e4ddd5);
  background: rgba(250,248,244,.58);
}

:where(#settings, #website-content) .fewo-website-page-panel[open] > summary::after {
  content: "-";
  background: var(--fewo-ui-dark, #1f2722);
  color: #fff;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary span {
  display: grid;
  gap: .12rem;
  min-width: 0;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary strong {
  color: var(--fewo-ui-text, #252b27);
  font-size: .9rem;
  line-height: 1.2;
}

:where(#settings, #website-content) .fewo-website-page-panel > summary small {
  color: var(--fewo-ui-muted, #666d68);
  font-size: .72rem;
  line-height: 1.35;
  font-weight: 700;
}

:where(#settings, #website-content) .fewo-website-page-body {
  display: grid;
  gap: .58rem;
  padding: .72rem;
}

:where(#settings, #website-content) .fewo-homepage-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

:where(#settings, #website-content) .fewo-homepage-repeater {
  display: grid;
  gap: .48rem;
}

:where(#settings, #website-content) .fewo-homepage-row {
  display: grid;
  gap: .5rem;
  padding: .52rem;
  border: 1px solid rgba(228,221,213,.82);
  border-radius: 9px;
  background: rgba(250,248,244,.48);
}

:where(#settings, #website-content) .fewo-homepage-row--two {
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
}

:where(#settings, #website-content) .fewo-homepage-row--three {
  grid-template-columns: minmax(86px, .42fr) minmax(0, .85fr) minmax(0, 1.35fr);
}

#website-content .fewo-homepage-icon-field {
  min-width: 0;
}

#website-content .fewo-homepage-icon-control {
  display: grid;
  grid-template-columns: 2.35rem minmax(0, 1fr);
  align-items: center;
  gap: .4rem;
}

#website-content .fewo-homepage-icon-trigger {
  display: grid;
  place-items: center;
  width: 2.35rem;
  height: 2.35rem;
  padding: 0;
  border: 1px solid rgba(164, 79, 51, .22);
  border-radius: 10px;
  background: rgba(250, 248, 244, .82);
  color: var(--fewo-ui-accent, #a44f33);
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(32, 38, 34, .05);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

#website-content .fewo-homepage-icon-trigger:hover,
#website-content .fewo-homepage-icon-trigger:focus-visible {
  border-color: rgba(164, 79, 51, .44);
  background: #fff;
  box-shadow: 0 10px 24px rgba(32, 38, 34, .1);
  transform: translateY(-1px);
  outline: none;
}

#website-content .fewo-homepage-icon-trigger svg,
.fewo-homepage-icon-popover svg {
  width: 1.1rem;
  height: 1.1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.fewo-homepage-icon-popover {
  position: fixed;
  z-index: 9999;
  width: min(360px, calc(100vw - 24px));
  padding: .72rem;
  border: 1px solid rgba(228, 221, 213, .95);
  border-radius: 14px;
  background: rgba(255, 255, 255, .98);
  box-shadow: 0 22px 55px rgba(32, 38, 34, .18);
}

.fewo-homepage-icon-popover.is-open {
  animation: fewo-icon-popover-in .14s ease-out;
}

.fewo-homepage-icon-popover__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .55rem;
}

.fewo-homepage-icon-popover__head strong {
  color: var(--fewo-ui-text, #252b27);
  font-size: .88rem;
}

.fewo-homepage-icon-popover__head button {
  display: grid;
  place-items: center;
  width: 1.9rem;
  height: 1.9rem;
  border: 0;
  border-radius: 999px;
  background: rgba(31, 39, 34, .08);
  color: var(--fewo-ui-dark, #1f2722);
  cursor: pointer;
  font-size: 1.2rem;
  line-height: 1;
}

.fewo-homepage-icon-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .45rem;
  max-height: min(430px, 62vh);
  overflow: auto;
  padding: .1rem;
}

.fewo-homepage-icon-grid button {
  display: grid;
  justify-items: center;
  gap: .3rem;
  min-height: 4.2rem;
  padding: .58rem .34rem;
  border: 1px solid rgba(228, 221, 213, .86);
  border-radius: 12px;
  background: #fff;
  color: var(--fewo-ui-text, #252b27);
  cursor: pointer;
  font: inherit;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

.fewo-homepage-icon-grid button:hover,
.fewo-homepage-icon-grid button:focus-visible,
.fewo-homepage-icon-grid button.is-active {
  border-color: rgba(164, 79, 51, .38);
  background: rgba(250, 248, 244, .92);
  box-shadow: 0 10px 24px rgba(32, 38, 34, .08);
  transform: translateY(-1px);
  outline: none;
}

.fewo-homepage-icon-grid button.is-active {
  color: var(--fewo-ui-accent, #a44f33);
}

.fewo-homepage-icon-grid small {
  max-width: 100%;
  color: inherit;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1.15;
  text-align: center;
}

@keyframes fewo-icon-popover-in {
  from {
    opacity: 0;
    transform: translateY(-.25rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 760px) {
  #features .fewo-settings-panel > summary {
    grid-template-columns: minmax(0, 1fr) 1.85rem;
  }

  #features .fewo-settings-panel > summary small {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
  }

  #features .fewo-settings-panel > summary::after {
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  :where(#settings, #website-content) .fewo-homepage-hero-card,
  :where(#settings, #website-content) .fewo-homepage-translate-card,
  :where(#settings, #website-content) .fewo-homepage-row--two,
  :where(#settings, #website-content) .fewo-homepage-row--three {
    grid-template-columns: 1fr;
  }

  .fewo-homepage-icon-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  :where(#settings, #website-content) .fewo-website-content-language > summary {
    grid-template-columns: minmax(0, 1fr) 2rem;
  }

  :where(#settings, #website-content) .fewo-website-content-language > summary > small {
    grid-column: 1;
    grid-row: 2;
  }

  :where(#settings, #website-content) .fewo-website-content-language > summary::after {
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  .fewo-website-unit-price-list article,
  .fewo-website-unit-price-list dl {
    grid-template-columns: 1fr;
  }
}

/* Booking accommodation chooser polish, 2026-06-10 */
.fewo-booking-widget .fewo-unit-picker {
  padding: .85rem;
  border-radius: 14px;
  background: #fff;
}

.fewo-booking-widget .fewo-unit-picker__eyebrow {
  margin: 0 0 .18rem;
  font-size: .72rem;
  letter-spacing: .13em;
}

.fewo-booking-widget .fewo-unit-picker__head {
  margin-bottom: .7rem;
}

.fewo-booking-widget .fewo-unit-picker__head h3 {
  margin: 0 .3rem 0 0;
  font-family: inherit;
  font-size: 1.08rem;
  line-height: 1.22;
}

.fewo-booking-widget .fewo-unit-picker__head p {
  max-width: 620px;
  margin-top: .22rem;
  font-size: .94rem;
  line-height: 1.45;
}

.fewo-booking-widget .fewo-unit-card {
  grid-template-columns: 88px minmax(0, 1fr) minmax(168px, auto);
  align-items: start;
  gap: .7rem;
  padding: .68rem;
  border-radius: 13px;
}

.fewo-booking-widget .fewo-unit-card--single {
  grid-template-columns: 82px minmax(0, 1fr) minmax(148px, auto);
  padding: .72rem .82rem;
}

.fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
  grid-template-columns: minmax(0, 1fr) minmax(112px, auto);
}

.fewo-booking-widget .fewo-unit-card--no-image .fewo-unit-card__media {
  display: none;
}

.fewo-booking-widget .fewo-unit-card img,
.fewo-booking-widget .fewo-unit-card__image-placeholder {
  width: 88px;
  height: 88px;
  min-height: 0;
  border-radius: 11px;
}

.fewo-booking-widget .fewo-unit-card--single img,
.fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
  width: 82px;
  height: 82px;
}

.fewo-booking-widget .fewo-unit-card h4 {
  font-size: .98rem;
  line-height: 1.22;
}

.fewo-booking-widget .fewo-unit-card p {
  max-width: 42rem;
  font-size: .86rem;
  line-height: 1.38;
}

.fewo-booking-widget .fewo-unit-card__facts,
.fewo-booking-widget .fewo-unit-card__amenities {
  gap: .22rem;
}

.fewo-booking-widget .fewo-unit-card__facts li,
.fewo-booking-widget .fewo-unit-card__amenities span {
  min-height: 1.24rem;
  padding: .14rem .42rem;
  font-size: .72rem;
}

.fewo-booking-widget .fewo-unit-card__aside {
  align-content: start;
  justify-items: end;
  gap: .45rem;
}

.fewo-booking-widget .fewo-unit-card__price {
  gap: .02rem;
  text-align: right;
}

.fewo-booking-widget .fewo-unit-card__price strong {
  white-space: nowrap;
  font-size: 1.02rem;
  line-height: 1.12;
}

.fewo-booking-widget .fewo-unit-card__price span,
.fewo-booking-widget .fewo-unit-card__price small {
  font-size: .75rem;
  line-height: 1.25;
}

.fewo-booking-widget .fewo-unit-card__select {
  max-width: 210px;
  min-height: 2.08rem;
  padding: .45rem .72rem;
  font-size: .78rem;
  white-space: nowrap;
}

.fewo-booking-widget .fewo-unit-card__details {
  grid-column: 1 / -1;
  margin: .08rem 0 0;
  padding: .62rem 0 0;
  border: 0;
  border-top: 1px solid rgba(32, 38, 34, .1);
  border-radius: 0;
  background: transparent;
}

.fewo-booking-widget .fewo-unit-card__details summary {
  display: inline-flex;
  align-items: center;
  gap: .34rem;
  width: auto;
  min-height: 1.9rem;
  padding: .22rem .62rem;
  border: 1px solid rgba(154, 86, 55, .22);
  border-radius: 999px;
  background: rgba(250, 248, 244, .82);
  color: #9a5637;
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.2;
  box-shadow: none;
  cursor: pointer;
  list-style: none;
  transition: color .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.fewo-booking-widget .fewo-unit-card__details summary::-webkit-details-marker {
  display: none;
}

.fewo-booking-widget .fewo-unit-card__details summary::after {
  content: "";
  width: .42rem;
  height: .42rem;
  margin-left: .08rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transform-origin: center;
  transition: transform .2s ease;
}

.fewo-booking-widget .fewo-unit-card__details summary:hover {
  border-color: rgba(154, 86, 55, .38);
  background: #fff;
  box-shadow: 0 8px 18px rgba(32, 38, 34, .06);
}

.fewo-booking-widget .fewo-unit-card__details[open] summary {
  background: #fff;
  border-color: rgba(154, 86, 55, .36);
}

.fewo-booking-widget .fewo-unit-card__details[open] summary::after {
  transform: rotate(225deg) translateY(-1px);
}

.fewo-booking-widget .fewo-unit-card__details p {
  padding-top: .25rem;
  font-size: .82rem;
}

.fewo-booking-widget .fewo-unit-card__details-body {
  display: grid;
  gap: .65rem;
  padding-top: .62rem;
}

.fewo-booking-widget .fewo-unit-card__details[open] .fewo-unit-card__details-body {
  animation: fewo-unit-details-in .18s ease-out;
}

@keyframes fewo-unit-details-in {
  from {
    opacity: 0;
    transform: translateY(-.2rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fewo-booking-widget .fewo-unit-card__details-intro {
  display: grid;
  grid-template-columns: minmax(146px, 220px) minmax(0, 1fr);
  align-items: center;
  gap: .72rem;
  padding: .64rem;
  border: 1px solid rgba(32, 38, 34, .08);
  border-radius: 12px;
  background: rgba(250, 248, 244, .6);
}

.fewo-booking-widget .fewo-unit-card__details .fewo-unit-card__details-text {
  margin: 0;
  padding: 0;
  color: var(--fewo-muted, #6c746c);
  font-size: .82rem;
  line-height: 1.42;
}

.fewo-booking-widget .fewo-unit-card__thumbs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .38rem;
  width: 100%;
}

.fewo-booking-widget .fewo-unit-card__thumbs span {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid rgba(32, 38, 34, .1);
  border-radius: 8px;
  background: #eee9e2;
}

.fewo-booking-widget .fewo-unit-card__thumbs img {
  width: 100%;
  height: 100%;
  border-radius: 0;
  object-fit: cover;
}

.fewo-booking-widget .fewo-unit-card__detail-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
  gap: .46rem .72rem;
  margin: 0;
}

.fewo-booking-widget .fewo-unit-card__detail-section {
  display: grid;
  gap: .38rem;
  padding: .62rem;
  border: 1px solid rgba(32, 38, 34, .08);
  border-radius: 12px;
  background: #fff;
}

.fewo-booking-widget .fewo-unit-card__detail-section > strong,
.fewo-booking-widget .fewo-unit-card__detail-amenities > strong {
  color: var(--fewo-muted, #6c746c);
  font-size: .64rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.fewo-booking-widget .fewo-unit-card__detail-list div {
  min-width: 0;
}

.fewo-booking-widget .fewo-unit-card__detail-list dt {
  margin: 0 0 .08rem;
  color: var(--fewo-muted, #6c746c);
  font-size: .64rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.fewo-booking-widget .fewo-unit-card__detail-list dd {
  margin: 0;
  color: var(--fewo-ink, #1d231f);
  font-size: .78rem;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.fewo-booking-widget .fewo-unit-card__detail-amenities {
  display: grid;
  gap: .38rem;
  padding: .62rem;
  border: 1px solid rgba(32, 38, 34, .08);
  border-radius: 12px;
  background: #fff;
}

.fewo-booking-widget .fewo-unit-card__detail-amenities > div {
  display: flex;
  flex-wrap: wrap;
  gap: .24rem;
}

.fewo-booking-widget .fewo-unit-card__detail-amenities span {
  padding: .16rem .44rem;
  border: 1px solid rgba(32, 38, 34, .1);
  border-radius: 999px;
  color: var(--fewo-muted, #6c746c);
  font-size: .68rem;
  line-height: 1.2;
  background: rgba(250, 248, 244, .86);
}

.fewo-booking-widget .fewo-unit-card__detail-amenities .fewo-unit-card__amenity-more {
  border-color: rgba(19, 65, 58, .18);
  color: #13413a;
  font-weight: 800;
  background: rgba(19, 65, 58, .06);
}

@media (max-width: 900px) {
  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 74px minmax(0, 1fr);
  }

  .fewo-booking-widget .fewo-unit-card--no-image,
  .fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    justify-items: stretch;
  }

  .fewo-booking-widget .fewo-unit-card__price {
    text-align: left;
  }

  .fewo-booking-widget .fewo-unit-card__details {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  .fewo-booking-widget .fewo-unit-picker {
    padding: .7rem;
  }

  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 100%;
    height: 136px;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    align-items: stretch;
  }

  .fewo-booking-widget .fewo-unit-card__select {
    max-width: none;
  }

  .fewo-booking-widget .fewo-unit-card__details-intro {
    grid-template-columns: 1fr;
  }
}

/* Booking checkout redesign, 2026-06-11: one-column flow with full-width room cards */
.fewo-booking-widget {
  width: min(100%, 920px);
  max-width: 920px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(1rem, 2.2vw, 1.35rem);
  align-items: stretch;
}

.fewo-booking-widget .fewo-card,
.fewo-booking-widget .fewo-calendar-card,
.fewo-booking-widget .fewo-booking-form {
  width: 100%;
  max-width: 100%;
}

.fewo-booking-widget .fewo-card {
  border-radius: 20px;
  padding: clamp(1rem, 2vw, 1.45rem);
  box-shadow: 0 16px 38px rgba(31, 35, 32, .06);
}

.fewo-booking-widget .fewo-calendar-card {
  max-width: none;
}

.fewo-booking-widget .fewo-calendar-card > .eyebrow {
  margin-bottom: .18rem;
  font-size: .72rem;
  letter-spacing: .12em;
}

.fewo-booking-widget .fewo-calendar-card h2 {
  margin-bottom: .48rem;
  font-size: clamp(1.45rem, 2.4vw, 2.05rem);
}

.fewo-booking-widget .fewo-calendar-card > p:not(.eyebrow):not(.fewo-selection-hint):not(.fewo-legend) {
  max-width: 62ch;
  margin-bottom: .8rem;
  font-size: .94rem;
  line-height: 1.5;
}

.fewo-booking-widget .fewo-period-picker {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 560px;
}

.fewo-booking-widget .fewo-calendar {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(.8rem, 2vw, 1.15rem);
}

.fewo-booking-widget .fewo-booking-form {
  display: grid;
  gap: .95rem;
}

.fewo-booking-widget .fewo-booking-form fieldset,
.fewo-booking-widget .fewo-unit-picker,
.fewo-booking-widget .fewo-price,
.fewo-booking-widget .fewo-voucher {
  margin: 0;
}

.fewo-booking-widget .fewo-booking-form fieldset {
  border-radius: 16px;
  padding: .9rem;
}

.fewo-booking-widget .fewo-booking-form fieldset:first-of-type {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: end;
}

.fewo-booking-widget .fewo-guests-fieldset {
  padding: .78rem .85rem;
  gap: .62rem .8rem;
}

.fewo-booking-widget .fewo-booking-form fieldset:first-of-type legend,
.fewo-booking-widget .fewo-unit-picker__head h3,
.fewo-booking-widget .fewo-contact-mode__head h3,
.fewo-booking-widget .fewo-price-breakdown h3 {
  font-size: 1rem;
}

.fewo-booking-widget .fewo-guests-fieldset .fewo-muted {
  margin: -.15rem 0 0;
  color: #776f68;
  font-size: .82rem;
  line-height: 1.4;
}

.fewo-booking-widget .fewo-unit-picker {
  padding: .95rem;
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, rgba(250, 248, 244, .58));
}

.fewo-booking-widget .fewo-unit-picker__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(130px, auto);
  align-items: end;
  gap: .85rem;
}

.fewo-booking-widget .fewo-unit-picker__head p {
  max-width: 62ch;
}

.fewo-booking-widget .fewo-unit-sort {
  justify-self: end;
  width: min(180px, 100%);
}

.fewo-booking-widget .fewo-unit-results {
  gap: .75rem;
}

.fewo-booking-widget .fewo-unit-card,
.fewo-booking-widget .fewo-unit-card--single {
  grid-template-columns: 112px minmax(0, 1fr) minmax(190px, 220px);
  gap: .9rem;
  align-items: start;
  padding: .82rem;
  border-radius: 15px;
}

.fewo-booking-widget .fewo-unit-card--no-image,
.fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
  grid-template-columns: minmax(0, 1fr) minmax(190px, 220px);
}

.fewo-booking-widget .fewo-unit-card img,
.fewo-booking-widget .fewo-unit-card__image-placeholder,
.fewo-booking-widget .fewo-unit-card--single img,
.fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
  width: 112px;
  height: 96px;
  min-height: 96px;
  border-radius: 12px;
}

.fewo-booking-widget .fewo-unit-card h4 {
  font-size: 1.03rem;
}

.fewo-booking-widget .fewo-unit-card p {
  font-size: .9rem;
  line-height: 1.43;
}

.fewo-booking-widget .fewo-unit-card__title-row {
  align-items: flex-start;
}

.fewo-booking-widget .fewo-unit-card__aside {
  min-height: 96px;
  align-content: start;
  justify-items: stretch;
  gap: .62rem;
}

.fewo-booking-widget .fewo-unit-card__price {
  text-align: right;
}

.fewo-booking-widget .fewo-unit-card__price strong {
  font-size: 1.12rem;
}

.fewo-booking-widget .fewo-unit-card__select {
  width: 100%;
  max-width: none;
  min-height: 2.28rem;
  padding-inline: .8rem;
  white-space: normal;
  line-height: 1.18;
}

.fewo-booking-widget .fewo-unit-card__details {
  margin-top: .18rem;
}

.fewo-booking-widget .fewo-price {
  border-radius: 16px;
}

.fewo-booking-widget .fewo-voucher {
  border-radius: 16px;
}

.fewo-booking-widget .fewo-guide-focus {
  outline: 1px solid rgba(19, 65, 58, .28);
  outline-offset: 6px;
  animation: fewo-guide-focus-glow 1.8s cubic-bezier(.2, .85, .25, 1);
}

.fewo-booking-widget .fewo-guide-back {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .58rem .7rem;
  border: 1px solid rgba(19, 65, 58, .18);
  border-radius: 13px;
  background: rgba(19, 65, 58, .055);
  color: #31443f;
  font-size: .84rem;
  line-height: 1.35;
}

.fewo-booking-widget .fewo-guide-back[hidden] {
  display: none;
}

.fewo-booking-widget .fewo-guide-back span {
  min-width: 0;
  font-weight: 700;
}

.fewo-booking-widget .fewo-guide-back button {
  flex: 0 0 auto;
  min-height: 2rem;
  border: 1px solid rgba(19, 65, 58, .28);
  border-radius: 999px;
  padding: .34rem .72rem;
  background: #fff;
  color: #13413a;
  font: inherit;
  font-size: .78rem;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 6px 14px rgba(31, 35, 32, .07);
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}

.fewo-booking-widget .fewo-guide-back button:hover,
.fewo-booking-widget .fewo-guide-back button:focus-visible {
  background: #f7fbf8;
  box-shadow: 0 10px 22px rgba(31, 35, 32, .12);
  transform: translateY(-1px);
  outline: none;
}

.fewo-booking-widget .fewo-unit-card {
  position: relative;
  overflow: hidden;
}

.fewo-booking-widget .fewo-unit-card.is-selected {
  border-color: rgba(19, 65, 58, .64);
  background: linear-gradient(135deg, rgba(19, 65, 58, .075), #fff 54%);
  box-shadow: 0 14px 34px rgba(19, 65, 58, .14);
}

.fewo-booking-widget .fewo-unit-card.is-selected::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: #13413a;
}

.fewo-booking-widget .fewo-unit-card.is-selected .fewo-unit-card__badge {
  background: #13413a;
  color: #fff;
}

@keyframes fewo-guide-focus-glow {
  0% {
    box-shadow: 0 0 0 0 rgba(19, 65, 58, 0), 0 0 0 rgba(19, 65, 58, 0);
    filter: saturate(1);
  }

  18% {
    box-shadow: 0 0 0 7px rgba(19, 65, 58, .08), 0 18px 44px rgba(19, 65, 58, .13);
    filter: saturate(1.04);
  }

  62% {
    box-shadow: 0 0 0 10px rgba(183, 109, 72, .06), 0 14px 34px rgba(19, 65, 58, .09);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(19, 65, 58, 0), 0 0 0 rgba(19, 65, 58, 0);
    filter: saturate(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .fewo-booking-widget .fewo-guide-focus {
    animation: none;
  }
}

@media (max-width: 760px) {
  .fewo-booking-widget {
    width: 100%;
    gap: .9rem;
  }

  .fewo-booking-widget .fewo-card {
    border-radius: 18px;
    padding: .95rem;
  }

  .fewo-booking-widget .fewo-calendar {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-period-picker,
  .fewo-booking-widget .fewo-booking-form fieldset,
  .fewo-booking-widget .fewo-booking-form fieldset:first-of-type,
  .fewo-booking-widget .fewo-unit-picker__head {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .fewo-booking-widget .fewo-unit-sort {
    justify-self: stretch;
    width: 100%;
  }

  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 92px minmax(0, 1fr);
    gap: .72rem;
  }

  .fewo-booking-widget .fewo-unit-card--no-image,
  .fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 92px;
    height: 86px;
    min-height: 86px;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    grid-column: 1 / -1;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(138px, auto);
    align-items: center;
    gap: .7rem;
  }

  .fewo-booking-widget .fewo-unit-card__price {
    text-align: left;
  }

  .fewo-booking-widget .fewo-unit-card__select {
    min-height: 2.42rem;
  }

  .fewo-booking-widget .fewo-guide-back {
    align-items: stretch;
    flex-direction: column;
  }

  .fewo-booking-widget .fewo-guide-back button {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .fewo-booking-widget .fewo-card {
    padding: .86rem;
  }

  .fewo-booking-widget .fewo-unit-picker {
    padding: .78rem;
  }

  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 76px minmax(0, 1fr);
    padding: .68rem;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 76px;
    height: 76px;
    min-height: 76px;
  }

  .fewo-booking-widget .fewo-unit-card h4 {
    font-size: .95rem;
  }

  .fewo-booking-widget .fewo-unit-card p {
    font-size: .84rem;
  }

  .fewo-booking-widget .fewo-unit-card__facts li {
    font-size: .68rem;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }

  .fewo-booking-widget .fewo-unit-card__price {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .55rem;
    flex-wrap: wrap;
  }

  .fewo-booking-widget .fewo-unit-card__price span {
    font-size: .72rem;
  }

  .fewo-booking-widget .fewo-unit-card__price strong {
    font-size: 1rem;
  }

  .fewo-booking-widget .fewo-unit-card__price small {
    flex-basis: 100%;
  }
}

@media (max-width: 390px) {
  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 100%;
    height: 142px;
  }
}

/* Compact booking unit list, 2026-06-21 */
.fewo-booking-widget .fewo-unit-picker {
  padding: .78rem;
}

.fewo-booking-widget .fewo-unit-results {
  display: grid;
  gap: .48rem;
}

.fewo-booking-widget .fewo-unit-picker.is-unit-selected .fewo-unit-card:not(.is-selected) {
  display: none;
}

.fewo-booking-widget .fewo-unit-picker.is-unit-selected .fewo-unit-status:not(.fewo-error-text) {
  display: none;
}

.fewo-booking-widget .fewo-unit-card,
.fewo-booking-widget .fewo-unit-card--single {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) minmax(174px, 210px);
  align-items: center;
  gap: .62rem;
  min-height: 0;
  padding: .56rem .64rem;
  border-radius: 12px;
}

.fewo-booking-widget .fewo-unit-card--no-image,
.fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
  grid-template-columns: minmax(0, 1fr) minmax(174px, 210px);
}

.fewo-booking-widget .fewo-unit-card img,
.fewo-booking-widget .fewo-unit-card__image-placeholder,
.fewo-booking-widget .fewo-unit-card--single img,
.fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
  width: 74px;
  height: 66px;
  min-height: 66px;
  border-radius: 10px;
}

.fewo-booking-widget .fewo-unit-card__main {
  display: grid;
  align-content: center;
  gap: .18rem;
  min-width: 0;
}

.fewo-booking-widget .fewo-unit-card__title-row {
  display: flex;
  align-items: center;
  gap: .42rem;
  min-width: 0;
}

.fewo-booking-widget .fewo-unit-card h4 {
  min-width: 0;
  overflow: hidden;
  font-size: .95rem;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fewo-booking-widget .fewo-unit-card p {
  display: -webkit-box;
  max-width: 100%;
  margin: 0;
  overflow: hidden;
  color: var(--fewo-muted, #6c746c);
  font-size: .78rem;
  line-height: 1.28;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.fewo-booking-widget .fewo-unit-card__facts {
  gap: .2rem;
}

.fewo-booking-widget .fewo-unit-card__facts li {
  min-height: 1.12rem;
  padding: .1rem .38rem;
  font-size: .66rem;
  line-height: 1.12;
}

.fewo-booking-widget .fewo-unit-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .28rem;
  margin-top: .05rem;
}

.fewo-booking-widget .fewo-unit-card__details-button {
  appearance: none;
  min-height: 1.45rem;
  padding: .14rem .5rem;
  border: 1px solid rgba(154, 86, 55, .24);
  border-radius: 999px;
  background: #fff;
  color: #9a5637;
  font: inherit;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1.1;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(31, 35, 32, .04);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.fewo-booking-widget .fewo-unit-card__details-button:hover,
.fewo-booking-widget .fewo-unit-card__details-button:focus-visible {
  border-color: rgba(154, 86, 55, .46);
  box-shadow: 0 8px 18px rgba(31, 35, 32, .08);
  outline: none;
  transform: translateY(-1px);
}

.fewo-booking-widget .fewo-unit-card__aside {
  min-height: 0;
  display: grid;
  align-content: center;
  justify-items: stretch;
  gap: .38rem;
}

.fewo-booking-widget .fewo-unit-card__price {
  display: grid;
  gap: 0;
  text-align: right;
}

.fewo-booking-widget .fewo-unit-card__price span,
.fewo-booking-widget .fewo-unit-card__price small {
  font-size: .68rem;
  line-height: 1.15;
}

.fewo-booking-widget .fewo-unit-card__price strong {
  font-size: 1rem;
  line-height: 1.06;
}

.fewo-booking-widget .fewo-unit-card__select {
  min-height: 1.95rem;
  padding: .32rem .64rem;
  border-radius: 999px;
  font-size: .72rem;
  line-height: 1.12;
  white-space: nowrap;
}

.fewo-booking-widget .fewo-unit-card.is-selected {
  background: #fff;
}

.fewo-booking-widget .fewo-unit-card.is-selected::before {
  height: 2px;
}

.fewo-booking-widget .fewo-unit-card__badge {
  flex: 0 0 auto;
  padding: .14rem .42rem;
  font-size: .62rem;
}

.fewo-unit-modal[hidden] {
  display: none !important;
}

.fewo-unit-modal {
  position: fixed;
  z-index: 9999;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(20, 24, 22, .42);
  opacity: 0;
  transition: opacity .16s ease;
}

.fewo-unit-modal.is-open {
  opacity: 1;
}

.fewo-unit-modal__panel {
  position: relative;
  width: min(680px, 100%);
  max-height: min(86vh, 720px);
  overflow: auto;
  padding: 1rem;
  border: 1px solid rgba(228, 221, 213, .92);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(20, 24, 22, .26);
  transform: translateY(.35rem) scale(.985);
  transition: transform .16s ease;
}

.fewo-unit-modal.is-open .fewo-unit-modal__panel {
  transform: translateY(0) scale(1);
}

.fewo-unit-modal__close {
  position: absolute;
  top: .7rem;
  right: .7rem;
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid rgba(32, 38, 34, .12);
  border-radius: 999px;
  background: #fff;
  color: var(--fewo-ink, #1d231f);
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
}

.fewo-unit-modal__head {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  align-items: center;
  gap: .75rem;
  padding-right: 2.4rem;
  margin-bottom: .85rem;
}

.fewo-unit-modal__head h4 {
  margin: 0;
  color: var(--fewo-ink, #1d231f);
  font-size: 1.12rem;
  line-height: 1.18;
}

.fewo-unit-modal__eyebrow {
  margin: 0 0 .18rem;
  color: var(--fewo-muted, #6c746c);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.fewo-unit-modal__image {
  display: block;
  width: 96px;
  height: 76px;
  overflow: hidden;
  border-radius: 12px;
  background: #eee9e2;
}

.fewo-unit-modal__image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.fewo-unit-modal .fewo-unit-card__details-body {
  padding-top: 0;
}

@media (min-width: 761px) {
  .fewo-booking-widget .fewo-unit-results {
    max-height: 560px;
    overflow: auto;
    padding-right: .14rem;
  }

  .fewo-booking-widget .fewo-unit-picker.is-unit-selected .fewo-unit-results {
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }
}

@media (max-width: 760px) {
  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 68px minmax(0, 1fr);
    gap: .5rem;
    padding: .54rem;
  }

  .fewo-booking-widget .fewo-unit-card--no-image,
  .fewo-booking-widget .fewo-unit-card--single.fewo-unit-card--no-image {
    grid-template-columns: 1fr;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 68px;
    height: 64px;
    min-height: 64px;
  }

  .fewo-booking-widget .fewo-unit-card p {
    -webkit-line-clamp: 2;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(132px, auto);
    align-items: center;
    gap: .5rem;
  }

  .fewo-booking-widget .fewo-unit-card__price {
    text-align: left;
  }
}

@media (max-width: 520px) {
  .fewo-booking-widget .fewo-unit-card,
  .fewo-booking-widget .fewo-unit-card--single {
    grid-template-columns: 62px minmax(0, 1fr);
    padding: .5rem;
  }

  .fewo-booking-widget .fewo-unit-card img,
  .fewo-booking-widget .fewo-unit-card__image-placeholder,
  .fewo-booking-widget .fewo-unit-card--single img,
  .fewo-booking-widget .fewo-unit-card--single .fewo-unit-card__image-placeholder {
    width: 62px;
    height: 60px;
    min-height: 60px;
  }

  .fewo-booking-widget .fewo-unit-card__aside {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }

  .fewo-booking-widget .fewo-unit-card__select {
    width: 100%;
  }

  .fewo-unit-modal {
    align-items: end;
    padding: .5rem;
  }

  .fewo-unit-modal__panel {
    width: 100%;
    max-height: 88vh;
    border-radius: 18px 18px 12px 12px;
  }

  .fewo-unit-modal__head {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .fewo-unit-modal__image {
    width: 72px;
    height: 58px;
  }
}

/* Booking unit selector: table-like ultra compact rows, 2026-06-21 */
.fewo-booking-widget .fewo-unit-picker {
  padding: .68rem;
}

.fewo-booking-widget .fewo-unit-picker__head {
  margin-bottom: .5rem;
}

.fewo-booking-widget .fewo-unit-picker__head p {
  margin-top: .12rem;
  font-size: .78rem;
  line-height: 1.28;
}

.fewo-booking-widget .fewo-unit-results {
  gap: .32rem;
}

.fewo-booking-widget .fewo-unit-card--compact,
.fewo-booking-widget .fewo-unit-card--compact.fewo-unit-card--single {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: .55rem;
  min-height: 2.8rem;
  padding: .36rem .45rem;
  border-radius: 9px;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__media,
.fewo-booking-widget .fewo-unit-card--compact p {
  display: none !important;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__main {
  display: flex;
  align-items: center;
  gap: .58rem;
  min-width: 0;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__title-row {
  min-width: 110px;
  max-width: 220px;
}

.fewo-booking-widget .fewo-unit-card--compact h4 {
  font-size: .84rem;
  line-height: 1.12;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__badge {
  padding: .1rem .34rem;
  font-size: .56rem;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__facts {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: nowrap;
  gap: .42rem;
  min-width: 0;
  overflow: hidden;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__facts li {
  flex: 0 0 auto;
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: #687169;
  font-size: .68rem;
  line-height: 1.1;
  white-space: nowrap;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__aside {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .36rem;
  min-height: 0;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__price {
  min-width: 5.9rem;
  text-align: right;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__price span,
.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__price small {
  display: none;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__price strong {
  display: block;
  font-size: .86rem;
  line-height: 1.05;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__actions {
  margin: 0;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__details-button {
  display: grid;
  place-items: center;
  width: 1.64rem;
  height: 1.64rem;
  min-height: 0;
  padding: 0;
  border-color: rgba(32, 38, 34, .15);
  color: #5f6a62;
  font-size: .75rem;
  font-style: italic;
  font-weight: 800;
}

.fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__select {
  min-height: 1.68rem;
  padding: .24rem .58rem;
  font-size: .68rem;
  line-height: 1.05;
}

.fewo-booking-widget .fewo-unit-picker.is-unit-selected .fewo-unit-card--compact {
  grid-template-columns: minmax(0, 1fr) auto;
}

@media (min-width: 761px) {
  .fewo-booking-widget .fewo-unit-results {
    max-height: 16.4rem;
    overflow: auto;
    overscroll-behavior: contain;
    padding-right: .1rem;
  }
}

@media (max-width: 760px) {
  .fewo-booking-widget .fewo-unit-card--compact,
  .fewo-booking-widget .fewo-unit-card--compact.fewo-unit-card--single {
    grid-template-columns: minmax(0, 1fr);
    gap: .38rem;
    min-height: 0;
    padding: .44rem;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__main {
    justify-content: space-between;
    gap: .45rem;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__title-row {
    min-width: 0;
    max-width: none;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__facts {
    justify-content: flex-end;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__facts li:nth-child(n+3) {
    display: none;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__aside {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 1.64rem minmax(5.4rem, auto);
    width: 100%;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__price {
    min-width: 0;
    text-align: left;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__select {
    width: 100%;
  }
}

@media (max-width: 420px) {
  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__main {
    display: grid;
    gap: .2rem;
  }

  .fewo-booking-widget .fewo-unit-card--compact .fewo-unit-card__facts {
    justify-content: flex-start;
  }
}
