/* ============================================================================
   DSR Brandhub Satellite — Komponenten-Layer auf den ECHTEN --dt-* Tokens.
   Geladen NACH themes/<brand>.css. Nachgebaut anhand der Live-Seiten:
   Container bis 1920px, Header 144/104px, Bento-Named-Grid, heller Footer,
   Menü-Drawer mit Seiten-Shift. Nichts erfunden — Werte aus dem Live-System.
   ============================================================================ */

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--dt-color-background-page-1-light);
  color:var(--dt-color-text-primary-light);
  font-family:var(--dt-font-family-body),system-ui,sans-serif;
  font-weight:var(--dt-font-weight-body-md,300);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* gemeinsame Außenränder wie Live (24 / 32 / 56 / 64), Inhalt bis 1920px */
.shell{transition:transform .3s ease;}
body.nav-open .shell{transform:translateX(min(-488px,-100vw));}
@media(min-width:768px){body.nav-open .shell{transform:translateX(-488px);}}

.bound{max-width:1920px;margin:0 auto;padding-inline:24px;}
@media(min-width:768px){.bound{padding-inline:32px;}}
@media(min-width:1024px){.bound{padding-inline:56px;}}
@media(min-width:1536px){.bound{padding-inline:64px;}}

/* ---------------- Typografie ---------------- */
.t-category{
  font-family:var(--dt-font-family-category),system-ui,sans-serif;
  font-weight:var(--dt-font-weight-category-md,400);
  font-size:var(--dt-text-size-category-md);line-height:var(--dt-spacing-line-height-category-md);
  letter-spacing:.12em;text-transform:uppercase;color:var(--dt-color-text-category-light);
}
.t-body{font-family:var(--dt-font-family-body),sans-serif;font-weight:var(--dt-font-weight-body-md,300);
  font-size:var(--dt-text-size-body-md);line-height:var(--dt-spacing-line-height-body-md);}
.t-body-lg{font-family:var(--dt-font-family-body),sans-serif;font-weight:var(--dt-font-weight-body-lg,300);
  font-size:var(--dt-text-size-body-lg);line-height:var(--dt-spacing-line-height-body-lg);}
.t-display{font-family:var(--dt-font-family-display),Georgia,serif;font-weight:var(--dt-font-weight-display-display,500);
  font-size:var(--dt-text-size-display-md);line-height:var(--dt-spacing-line-height-display-md);letter-spacing:-.01em;margin:0;}
.t-h2{font-family:var(--dt-font-family-heading),sans-serif;font-weight:var(--dt-font-weight-heading-heading,500);
  font-size:var(--dt-text-size-heading-h4);line-height:var(--dt-spacing-line-height-heading-h4);margin:0;}

/* ---------------- Buttons (Radius je Marke aus --dt-radius-button) ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--dt-font-family-body),sans-serif;font-weight:var(--dt-font-weight-button-button,600);
  font-size:var(--dt-text-size-element-sm,14px);letter-spacing:.04em;text-transform:uppercase;
  height:52px;padding:0 28px;cursor:pointer;white-space:nowrap;
  border:0 solid transparent;border-radius:var(--dt-radius-button,0px);
  transition:filter .2s ease,background-color .2s ease,color .2s ease,border-color .2s ease;}
.btn--primary{background:var(--dt-color-background-button-primary-light);color:var(--dt-color-text-button-primary-light);
  border-width:var(--dt-border-border-button-primary,0px);border-color:var(--dt-color-background-button-primary-light);}
.btn--primary:hover{filter:brightness(1.08);}
.btn--secondary{background:transparent;color:var(--dt-color-text-primary-light);
  border-width:var(--dt-border-border-button-secondary,2px);border-color:var(--dt-color-background-button-secondary-light);}
.btn--secondary:hover{background:var(--dt-color-background-button-secondary-hover-light);color:#fff;border-color:transparent;}
.btn .ico{width:20px;height:20px;}

.iconbtn{width:44px;height:44px;border-radius:999px;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  background:var(--dt-color-background-button-primary-light);color:#fff;}
.iconbtn .ico{filter:brightness(0) invert(1);width:20px;height:20px;}

/* ---------------- Promo-Bar ---------------- */
.promo{background:var(--dt-color-background-button-primary-light);color:var(--dt-color-text-button-primary-light);font-size:14px;}
.promo .bound{padding-block:9px;display:flex;align-items:center;justify-content:center;gap:12px;}

/* ---------------- Header (Höhe wie Live: 144 / 104) ---------------- */
.hdr{position:sticky;top:0;z-index:50;background:var(--dt-color-background-page-1-light);transition:background .2s ease;}
.hdr__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;height:96px;transition:height .25s ease;}
@media(min-width:1024px){.hdr__inner{height:144px;}}
.hdr.is-compact .hdr__inner{height:72px;}
@media(min-width:1024px){.hdr.is-compact .hdr__inner{height:104px;}}
.hdr__logo img{width:var(--logo-w,160px);height:auto;transition:width .25s ease;}
.hdr.is-compact .hdr__logo img{width:calc(var(--logo-w,160px) * .8);}
.hdr__right{display:flex;align-items:center;gap:20px;}
.hdr__lang,.hdr__menu{display:inline-flex;align-items:center;gap:8px;background:none;border:0;cursor:pointer;
  font-family:var(--dt-font-family-body),sans-serif;font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--dt-color-text-primary-light);padding:8px 4px;}
.hdr__lang:hover,.hdr__menu:hover{opacity:.6;}
.hdr__lang svg{width:16px;height:16px;display:block;}
.hdr__menu svg{width:24px;height:24px;display:block;}  /* echtes dünnes Hamburger-Icon */
.hdr__menu .ico,.hdr__lang .ico{width:24px;height:24px;}
@media(max-width:560px){.hdr__lang span:first-of-type{display:none;}}

/* ---------------- Menü-Drawer ---------------- */
.drawer{position:fixed;inset:0;z-index:80;pointer-events:none;}
.drawer__scrim{position:absolute;inset:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity .3s ease;}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(488px,100vw);
  background:var(--dt-color-background-page-1-light);transform:translateX(100%);transition:transform .3s ease;
  padding:24px 32px;overflow-y:auto;display:flex;flex-direction:column;box-shadow:-12px 0 40px rgba(0,0,0,.12);}
body.nav-open .drawer{pointer-events:auto;}
body.nav-open .drawer__scrim{opacity:1;}
body.nav-open .drawer__panel{transform:none;}
.drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;height:96px;}
.drawer__nav{display:flex;flex-direction:column;}
.drawer__link{font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-lg);
  letter-spacing:.06em;text-transform:uppercase;padding:16px 0;border-bottom:1px solid var(--dt-color-border-disabled-light,rgba(0,0,0,.12));transition:color .2s;}
.drawer__link:hover{color:var(--dt-color-text-secondary-light);}
.drawer__foot{margin-top:auto;padding-top:24px;display:flex;align-items:center;gap:10px;font-size:14px;color:var(--dt-color-text-secondary-light);}
.drawer__foot .ico{width:18px;height:18px;}

/* ---------------- Bento-Hero (Named Grid wie Live) ---------------- */
.bento{display:grid;gap:8px;padding-block:8px 24px;grid-template-columns:1fr 1fr;grid-auto-rows:160px;}
.bento__title{grid-column:1 / -1;grid-row:auto;display:flex;flex-direction:column;justify-content:center;gap:20px;
  padding:24px 8px;min-height:auto;}
@media(min-width:1024px){
  .bento{grid-template-columns:repeat(12,1fr);grid-auto-rows:210px;
    grid-template-areas:
      "t t t t t a a a a g g g"
      "t t t t t b b b c c c c"
      "d d d d k k k e e e e e";}
  .bento__title{grid-area:t;padding:8px 40px 8px 8px;}
  .b-a{grid-area:a;} .b-b{grid-area:b;} .b-c{grid-area:c;} .b-d{grid-area:d;} .b-e{grid-area:e;}
  .b-g{grid-area:g;} .b-k{grid-area:k;}
}
.bento__overline{margin:0;}
.bento__h1{font-family:var(--dt-font-family-display),Georgia,serif;font-weight:var(--dt-font-weight-display-display,500);
  font-size:clamp(34px,3.6vw,var(--dt-text-size-display-md));line-height:1.04;letter-spacing:-.01em;margin:0;
  color:var(--dt-color-text-primary-light);}
.bento__bar{height:2px;width:100%;background:var(--dt-color-text-primary-light);margin:4px 0;}   /* Balken unter Headline */
.bento__resv{display:inline-flex;align-items:center;gap:10px;font-size:15px;color:var(--dt-color-text-secondary-light);}
.bento__resv .ico{width:18px;height:18px;}
.tile{position:relative;overflow:hidden;background:var(--dt-color-background-card-light,#fff);min-height:150px;}
.tile img{width:100%;height:100%;object-fit:cover;}
.tile__plus{position:absolute;right:14px;bottom:14px;}
.tile--action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;}
.tile--a1{background:var(--dt-color-background-bento-tile-1-light);color:var(--dt-color-text-bento-tile-1-light,#fff);}
.tile--a1:hover{background:var(--dt-color-background-bento-tile-1-hover-light);}
.tile--a2{background:var(--dt-color-background-bento-tile-2-light);color:var(--dt-color-text-bento-tile-2-light,#fff);}
.tile--a2:hover{background:var(--dt-color-background-bento-tile-2-hover-light);}
.tile--action .ico{width:36px;height:36px;filter:brightness(0) invert(1);}
.tile--action span{font-size:14px;letter-spacing:.08em;text-transform:uppercase;}

/* ---------------- Section ---------------- */
.sec{padding-block:80px;}
@media(min-width:1024px){.sec{padding-block:112px;}}
.sec__cat{margin-bottom:12px;}
.sec__title{font-family:var(--dt-font-family-display),Georgia,serif;font-weight:var(--dt-font-weight-display-display,500);
  font-size:clamp(30px,3vw,var(--dt-text-size-display-sm));line-height:1.08;margin:0 0 20px;}
.sec__lead{max-width:760px;}
.cards{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-top:40px;}
.card{background:var(--dt-color-background-card-light,#fff);padding:32px;display:flex;flex-direction:column;gap:12px;
  border-radius:var(--dt-border-radius-md,0);box-shadow:0 6px 16px rgba(0,0,0,.06);}

/* ---------------- Footer (HELL, mit Spalten-Trennlinien wie Live) ---------------- */
.ft{background:var(--dt-color-background-page-1-light);color:var(--dt-color-text-primary-light);}
.ft__cols{padding-block:48px 32px;display:grid;gap:16px 32px;grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.ft__cols{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.ft__cols{grid-template-columns:1fr;}}
.ft__col{border-top:1px solid var(--dt-color-border-disabled-dark,rgba(0,0,0,.3));padding-top:12px;}
.ft__h{font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-sm);letter-spacing:.06em;
  text-transform:uppercase;color:var(--dt-color-text-primary-light);margin-bottom:24px;}
.ft__col a,.ft__col p{display:block;color:var(--dt-color-text-link-light,inherit);font-size:var(--dt-text-size-body-sm);line-height:1.7;margin:0;}
.ft__col a:hover{color:var(--dt-color-text-primary-light);}
.ft__lang{display:flex;gap:12px;margin-top:8px;}
.ft__lang span{color:var(--dt-color-text-secondary-light);}
.ft__social{display:flex;gap:8px;flex-wrap:wrap;}
.ft__social a{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;}
.ft__social .ico{width:24px;height:24px;}
.ft__brandlogo img{width:120px;height:auto;margin-bottom:16px;}
.ft__legal{border-top:1px solid var(--dt-color-border-disabled-dark,rgba(0,0,0,.3));padding-block:24px 40px;
  display:flex;flex-wrap:wrap;gap:8px 24px;align-items:center;}
.ft__legal a{font-size:var(--dt-text-size-body-sm);letter-spacing:.04em;text-transform:uppercase;color:var(--dt-color-text-link-light,inherit);}
.ft__legal a:hover{color:var(--dt-color-text-primary-light);}
.ft__legal .ft__copy{margin-left:auto;color:var(--dt-color-text-secondary-light);text-transform:none;letter-spacing:0;}

/* ---------------- Dev-Markenleiste ---------------- */
.devbar{background:#14181b;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:8px 24px;flex-wrap:wrap;font-family:system-ui,sans-serif;}
.devbar__label{font-size:12px;letter-spacing:.04em;color:#9098a0;}
.devbar__pills{display:flex;gap:6px;flex-wrap:wrap;}
.devbar__pill{font-size:13px;color:#c9ced3;background:transparent;border:1px solid #333a40;padding:6px 12px;cursor:pointer;}
.devbar__pill.is-active{background:#fff;color:#14181b;border-color:#fff;font-weight:600;}

/* ---------------- Styleguide ---------------- */
.sg-block{padding:40px 0;border-bottom:1px solid rgba(0,0,0,.1);}
.sg-block__t{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--dt-color-text-secondary-light);margin:0 0 20px;}
.sg-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center;}
.sg-swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;}
.sg-sw__chip{height:80px;border:1px solid rgba(0,0,0,.08);}
.sg-sw__meta{font-size:12px;padding:8px 2px;color:var(--dt-color-text-secondary-light);}
.sg-sw__meta b{display:block;color:var(--dt-color-text-primary-light);font-family:monospace;}

/* ============================================================================
   ELEMENTE-BIBLIOTHEK — alle Werte aus echten --dt-* Tokens (Farbe/Radius/Font).
   ============================================================================ */

/* ---- Buttons: Größen & States (ergänzt .btn oben) ---- */
.btn--sm{height:40px;padding:0 18px;font-size:12px;}
.btn--lg{height:60px;padding:0 32px;font-size:16px;}
.btn[disabled],.btn--disabled{background:var(--dt-color-background-disabled-light,#ccd0d4);color:var(--dt-color-text-disabled-light,#8a9196);border-color:transparent;cursor:not-allowed;pointer-events:none;}

/* ---- Formularfelder ---- */
.fld{display:flex;flex-direction:column;gap:8px;}
.fld__label{font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);}
.fld__hint{font-size:var(--dt-text-size-body-xs);color:var(--dt-color-text-disabled-light);}
.input,.select,.textarea{
  font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-md);
  color:var(--dt-color-text-primary-light);background:var(--dt-color-background-input-light);
  border:1px solid var(--dt-color-border-input-enabled-light);border-radius:var(--dt-border-radius-none,0);
  padding:14px 16px;width:100%;outline:none;transition:border-color .15s ease;}
.input:focus,.select:focus,.textarea:focus{border-color:var(--dt-color-border-input-edited-light);}
.input::placeholder,.textarea::placeholder{color:var(--dt-color-text-disabled-light);}
.input--error{border-color:var(--dt-color-background-flag-alert-light);}
.textarea{min-height:128px;resize:vertical;line-height:1.5;}
.select{appearance:none;-webkit-appearance:none;padding-right:44px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23766646'><path d='M12 14.7 4.4 7.1a1 1 0 0 0-1.4 1.4l8.3 8.3a1 1 0 0 0 1.4 0l8.3-8.3a1 1 0 1 0-1.4-1.4z'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px;}

/* ---- Checkbox / Radio / Toggle ---- */
.ctrl{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-family:var(--dt-font-family-body),sans-serif;
  font-size:var(--dt-text-size-body-md);color:var(--dt-color-text-primary-light);position:relative;}
.ctrl input{position:absolute;opacity:0;width:0;height:0;}
.ctrl__box{width:22px;height:22px;border:2px solid var(--dt-color-border-disabled-light);background:var(--dt-color-background-input-light);
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;transition:background .15s,border-color .15s;}
.ctrl__box svg{width:14px;height:14px;fill:var(--dt-color-text-button-primary-light,#fff);opacity:0;}
.ctrl input:checked + .ctrl__box{background:var(--dt-color-background-button-primary-light);border-color:var(--dt-color-background-button-primary-light);}
.ctrl input:checked + .ctrl__box svg{opacity:1;}
.ctrl__box--radio{border-radius:999px;}
.ctrl__box--radio::after{content:"";width:10px;height:10px;border-radius:999px;background:var(--dt-color-text-button-primary-light,#fff);transform:scale(0);transition:transform .15s;}
.ctrl input:checked + .ctrl__box--radio{background:var(--dt-color-background-button-primary-light);border-color:var(--dt-color-background-button-primary-light);}
.ctrl input:checked + .ctrl__box--radio::after{transform:scale(1);}
.tgl{width:48px;height:26px;border-radius:999px;background:var(--dt-color-background-toggle-field-enabled);position:relative;flex:0 0 auto;transition:background .2s;}
.tgl::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:999px;background:var(--dt-color-background-toggle-dot,#fff);box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s;}
.ctrl input:checked + .tgl{background:var(--dt-color-background-toggle-field-active);}
.ctrl input:checked + .tgl::after{transform:translateX(22px);}

/* ---- Tags / Chips ---- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-sm);
  padding:4px 12px;border-radius:var(--dt-radius-tag,0);background:var(--dt-color-background-tag-light);color:#fff;}
.chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-md);
  padding:9px 18px;border-radius:var(--dt-radius-tag,0);background:var(--dt-color-background-chip-result);color:var(--dt-color-text-primary-light);cursor:pointer;transition:background .15s;}
.chip:hover{background:var(--dt-color-background-chip-result-hover);}
.chip--primary{background:var(--dt-color-background-chip-primary-enabled);}
.chip--primary:hover{background:var(--dt-color-background-chip-primary-hover);}
.chip--active{background:var(--dt-color-background-button-primary-light);color:var(--dt-color-text-button-primary-light);}
.badge{display:inline-flex;align-items:center;padding:3px 10px;font-family:var(--dt-font-family-body),sans-serif;font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  background:var(--dt-color-background-button-primary-light);color:var(--dt-color-text-button-primary-light);border-radius:var(--dt-radius-tag,0);}

/* ---- Cards ---- */
.ecard{background:var(--dt-color-background-card-light);border:1px solid var(--dt-color-border-card-light);display:flex;flex-direction:column;overflow:hidden;max-width:360px;transition:background .2s;}
.ecard:hover{background:var(--dt-color-background-card-hover-light);}
.ecard__media{aspect-ratio:3/2;object-fit:cover;width:100%;}
.ecard__body{padding:24px;display:flex;flex-direction:column;gap:12px;}
.ecard__title{font-family:var(--dt-font-family-display),Georgia,serif;font-size:var(--dt-text-size-heading-h6);line-height:1.1;margin:0;color:var(--dt-color-text-primary-light);}

/* ---- Flags / Hinweise ---- */
.flag{display:flex;gap:12px;align-items:flex-start;padding:16px;border-radius:var(--dt-radius-flag,0);
  background:var(--dt-color-background-flag-light);color:var(--dt-color-text-primary-light);
  font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-sm);
  border-left:4px solid var(--dt-color-text-secondary-light);}
.flag svg{width:22px;height:22px;flex:0 0 auto;}
.flag--alert{background:#fdecec;border-left-color:var(--dt-color-background-flag-alert-light);}
.flag--success{background:#e7f6e5;border-left-color:#0f8903;}
.flag--info{background:#daf1ff;border-left-color:#005ba5;}

/* ---- Accordion (details/summary, ohne JS) ---- */
.acc{border-top:1px solid var(--dt-color-border-disabled-light);max-width:760px;}
.acc details{border-bottom:1px solid var(--dt-color-border-disabled-light);}
.acc summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;cursor:pointer;
  font-family:var(--dt-font-family-heading),sans-serif;font-weight:var(--dt-font-weight-heading-heading,500);font-size:var(--dt-text-size-body-lg);color:var(--dt-color-text-primary-light);transition:color .2s;}
.acc summary::-webkit-details-marker{display:none;}
.acc summary:hover{color:var(--dt-color-text-accordion-hover-light);}
.acc summary svg{width:22px;height:22px;flex:0 0 auto;transition:transform .25s;fill:currentColor;}
.acc details[open] summary svg{transform:rotate(180deg);}
.acc__body{padding:0 0 20px;color:var(--dt-color-text-secondary-light);font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-md);line-height:1.55;}

/* ---- Links ---- */
.elink{color:var(--dt-color-text-link-light);text-decoration:underline;text-underline-offset:3px;transition:color .15s;}
.elink:hover{color:var(--dt-color-text-link-hover-light);}

/* ---- Tabelle ---- */
.etable{width:100%;border-collapse:collapse;font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-md);}
.etable th,.etable td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--dt-color-border-disabled-light);}
.etable th{font-weight:600;color:var(--dt-color-text-primary-light);}
.etable td{color:var(--dt-color-text-secondary-light);}

/* ---- Slider (Scroll-Snap, touch-fähig, ohne JS-Lib) ---- */
.hslider{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;padding:4px 4px 14px;margin:0 -4px;}
.hslider::-webkit-scrollbar{display:none;}
.hslider > *{scroll-snap-align:start;flex:0 0 auto;}
/* Angebotskarte */
.ocard{width:min(440px,86vw);background:var(--dt-color-background-card-light,#fff);box-shadow:0 6px 16px rgba(0,0,0,.08);
  display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:background-color .2s;}
.ocard:hover{background:var(--dt-color-background-card-hover-light,#f4f2ec);}
@media(min-width:768px){.ocard{flex-direction:row;width:min(460px,86vw);}}
.ocard__img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;}
@media(min-width:768px){.ocard__img{width:200px;flex:0 0 200px;aspect-ratio:1;height:auto;}}
.ocard__body{padding:24px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;flex:1;min-width:0;}
.ocard__cat{font-family:var(--dt-font-family-category),sans-serif;font-size:var(--dt-text-size-category-sm);letter-spacing:.12em;text-transform:uppercase;color:var(--dt-color-text-category-light);}
.ocard__title{font-family:var(--dt-font-family-display),serif;font-size:var(--dt-text-size-body-lg);line-height:1.2;margin:6px 0 0;color:var(--dt-color-text-primary-light);}
.ocard__info{font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);line-height:1.5;}
.ocard__price{display:flex;align-items:baseline;justify-content:flex-end;gap:6px;}
.ocard__price .old{text-decoration:line-through;color:var(--dt-color-text-secondary-light);font-size:var(--dt-text-size-body-md);}
.ocard__price .now{font-family:var(--dt-font-family-heading),sans-serif;font-weight:600;font-size:var(--dt-text-size-heading-h6);color:var(--dt-color-text-primary-light);}
.ocard__price .unit{font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);}
/* Bild-Slider-Kachel */
.tcard{position:relative;height:360px;display:block;overflow:hidden;text-decoration:none;}
.tcard img{height:100%;width:auto;display:block;object-fit:cover;}
.tcard__cap{position:absolute;inset:0;display:flex;align-items:flex-end;padding:20px;
  background:linear-gradient(0deg,rgba(0,0,0,.6),rgba(0,0,0,0) 55%);}
.tcard__cap h3{color:#fff;font-family:var(--dt-font-family-heading),sans-serif;font-weight:500;font-size:var(--dt-text-size-heading-h6);margin:0;}
.tcard__plus{position:absolute;bottom:12px;right:12px;color:#fff;}
.tcard__plus svg{width:24px;height:24px;}

/* ---- Kontaktformular ---- */
.kf{margin-top:32px;background:var(--dt-color-background-card-light,#fff);border:1px solid var(--dt-color-border-card-light,rgba(0,0,0,.08));padding:32px;}
@media(min-width:768px){.kf{padding:40px;}}
.kf-step{display:none;}
.kf-step.is-active{display:block;}
.kf-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px;}
.kf-verify{margin-top:24px;max-width:340px;}
.kf-verify altcha-widget{
  --altcha-border-width:1px;
  --altcha-border-radius:var(--dt-border-radius-none,0);
  --altcha-color-border:var(--dt-color-border-input-enabled-light);
  --altcha-color-base:var(--dt-color-background-input-light,#fff);
  --altcha-color-text:var(--dt-color-text-primary-light);
  --altcha-color-border-focus:var(--dt-color-border-input-edited-light);
  --altcha-color-checkbox-checked:var(--dt-color-background-button-primary-light);
  font-family:var(--dt-font-family-body),sans-serif;
}
.kf-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px 24px;}
.kf-fields .fld--full{grid-column:1/-1;}
/* gerendertes Markup aus get_fields.php auf Brandhub-Tokens stylen */
.kf-fields .form-group{display:flex;flex-direction:column;gap:8px;}
.kf-fields .form-group label{font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);}
.kf-fields .required{color:var(--dt-color-background-flag-alert-light);}
.kf-fields input[type=text],.kf-fields input[type=email],.kf-fields input[type=tel],
.kf-fields input[type=number],.kf-fields input[type=date],.kf-fields select,.kf-fields textarea{
  font-family:var(--dt-font-family-body),sans-serif;font-size:var(--dt-text-size-body-md);color:var(--dt-color-text-primary-light);
  background:var(--dt-color-background-input-light);border:1px solid var(--dt-color-border-input-enabled-light);
  border-radius:var(--dt-border-radius-none,0);padding:14px 16px;width:100%;outline:none;transition:border-color .15s ease;}
.kf-fields input:focus,.kf-fields select:focus,.kf-fields textarea:focus{border-color:var(--dt-color-border-input-edited-light);}
.kf-fields select{appearance:none;-webkit-appearance:none;padding-right:44px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23766646'><path d='M12 14.7 4.4 7.1a1 1 0 0 0-1.4 1.4l8.3 8.3a1 1 0 0 0 1.4 0l8.3-8.3a1 1 0 1 0-1.4-1.4z'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px;}
.kf-fields .helper-text{font-size:var(--dt-text-size-body-xs);color:var(--dt-color-text-disabled-light);margin-top:2px;}
.kf-fields .info-message{font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);}
/* volle Breite für große Blöcke */
.kf-fields .form-group:has(textarea),
.kf-fields .form-group:has(.person-count-group),
.kf-fields .privacy-notice{grid-column:1/-1;}
.kf-fields .person-count-group{display:flex;flex-direction:column;gap:12px;border:1px solid var(--dt-color-border-card-light,rgba(0,0,0,.1));padding:16px;}
.kf-fields .count-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.kf-fields .count-row label{min-width:120px;margin:0;}
.kf-fields .count-row input,.kf-fields .count-row select{max-width:160px;}
.kf-fields #children_ages{display:flex;flex-direction:column;gap:10px;}
.kf-fields .privacy-notice{font-size:var(--dt-text-size-body-sm);color:var(--dt-color-text-secondary-light);line-height:1.5;}
.kf-fields .privacy-notice a{color:var(--dt-color-text-link-light);text-decoration:underline;text-underline-offset:3px;}
/* Anliegen-Hinweise (concern_info) + dynamische Kinder-Alter */
.kf-fields #concern_info,.kf-fields .age-select{grid-column:auto;}
.kf-fields .info-box{grid-column:1/-1;padding:16px 20px;border-left:4px solid var(--dt-color-text-secondary-light);
  background:var(--dt-color-background-page-3-light,#f4f2ec);}
.kf-fields .info-box.warning{border-left-color:var(--dt-color-background-flag-alert-light);}
.kf-fields .info-box h4{margin:0 0 6px;font-family:var(--dt-font-family-heading),sans-serif;font-size:var(--dt-text-size-body-lg);color:var(--dt-color-text-primary-light);}
.kf-fields .info-box p{margin:4px 0;font-size:var(--dt-text-size-body-md);color:var(--dt-color-text-secondary-light);}
.kf-fields .info-link{color:var(--dt-color-text-link-light);text-decoration:underline;text-underline-offset:3px;font-weight:500;}
.kf-fields .newsletter-notice{grid-column:1/-1;}
.kf-fields .age-select{display:flex;align-items:center;gap:12px;}
.kf-fields .age-select label{min-width:80px;}
.form-fields-hidden{display:none !important;}

/* ---- Text + Bild (Kampagnenbaustein) ---- */
.textimg{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;}
@media(min-width:900px){.textimg{grid-template-columns:1.1fr 1fr;gap:64px;}.textimg--rev .textimg__media{order:-1;}}
.textimg__media img{width:100%;aspect-ratio:4/3;object-fit:cover;}
