
:root{--green:#173b28;--green2:#245947;--gold:#c58b23;--cream:#f5eee2;--paper:#fffaf4;--line:#eadbc8;--text:#2e251f;--muted:#66756c;--shadow:0 18px 48px rgba(30,54,42,.12)}
*{box-sizing:border-box}body{margin:0;background:var(--cream);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif;line-height:1.6}h1,h2,h3{font-family:Georgia,serif;color:var(--green);line-height:1.08}h1{font-size:clamp(2.8rem,5vw,5.8rem);margin:.18em 0}h2{font-size:clamp(2rem,3.1vw,3.7rem)}h3{font-size:1.7rem}.eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--gold);font-weight:900}.topbar{height:34px;background:#fffaf4;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;padding:0 5vw;color:#315041;font-size:.92rem}header{position:sticky;top:0;z-index:30;background:rgba(255,250,244,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.nav{height:92px;display:flex;align-items:center;gap:28px;padding:0 5vw}.logo-img{height:72px;width:auto;display:block}.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--green);font-family:Georgia,serif;font-weight:800;font-size:1.16rem}.logo-mark{width:50px;height:42px;border-radius:50% 50% 8px 8px;background:linear-gradient(135deg,#2e8a44,#9acb80);display:grid;place-items:center;color:white;font-family:Georgia,serif}.menu{display:flex;gap:24px;margin-left:auto}.menu a{text-decoration:none;color:#2e251f;font-weight:800}.book,.btn{border:0;border-radius:18px;padding:15px 24px;background:var(--gold);color:white;text-decoration:none;font-weight:900;display:inline-block;box-shadow:0 10px 24px rgba(197,139,35,.24);cursor:pointer}.btn.secondary,.book.secondary{background:#fffaf4;color:var(--green);border:1px solid var(--line);box-shadow:none}.hero{min-height:72vh;background-size:cover;background-position:center;position:relative;display:flex;align-items:center}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(11,34,24,.72),rgba(11,34,24,.28),rgba(11,34,24,.04))}.fade{position:relative;max-width:780px;margin-left:6vw;color:white}.fade h1,.fade p{color:white}.fade p{font-size:1.25rem}.buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}.booking{position:relative;z-index:5;margin:-42px auto 50px;max-width:1180px;background:#fffaf4;border:1px solid var(--line);border-radius:26px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:12px;padding:18px;box-shadow:var(--shadow)}.field{background:#f8f1e8;border:1px solid var(--line);border-radius:18px;padding:14px 16px}.field label{display:block;color:var(--muted);font-size:.82rem;font-weight:800;text-transform:uppercase}.field strong{color:var(--green)}section{padding:64px 6vw}.center{text-align:center}.narrow{max-width:1160px;margin:auto}.lead{font-size:1.23rem;color:var(--muted)}.grid{display:grid;gap:28px}.three{grid-template-columns:repeat(3,1fr)}.card{background:var(--paper);border:1px solid var(--line);border-radius:34px;overflow:hidden;box-shadow:var(--shadow)}.card img{width:100%;height:280px;object-fit:cover;display:block}.pad{padding:28px}.quote{min-height:430px;border-radius:42px;background-image:linear-gradient(rgba(20,50,35,.55),rgba(20,50,35,.55)),var(--bg);background-size:cover;background-position:center;display:grid;place-items:center;text-align:center;color:white;padding:40px}.quote h2,.quote p{color:white}.page-hero{min-height:64vh;display:grid;grid-template-columns:1.05fr .95fr;background:var(--paper)}.page-hero .hero-img{background-size:cover;background-position:center}.page-hero .hero-copy{display:flex;flex-direction:column;justify-content:center;padding:6vw}.subnav-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin:-34px 6vw 35px;position:relative;z-index:6}.subnav-strip a{background:#fffaf4;border:1px solid var(--line);border-radius:22px;padding:18px 22px;box-shadow:0 12px 28px rgba(38,58,50,.09);font-weight:900;color:var(--green);text-decoration:none}.room-showcase{display:grid;grid-template-columns:1fr 1fr;gap:32px}.room-card{background:var(--paper);border:1px solid var(--line);border-radius:34px;overflow:hidden;box-shadow:var(--shadow)}.room-card img{width:100%;height:360px;object-fit:cover}.room-features{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:18px 0}.room-features span{background:#f7f1e8;border:1px solid var(--line);border-radius:16px;padding:12px;font-weight:800;color:var(--green)}.wellness-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:30px}.wellness-large{min-height:620px;border-radius:38px;background-size:cover;background-position:center;box-shadow:var(--shadow)}.wellness-stack{display:grid;gap:20px}.wellness-tile{background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:28px;box-shadow:0 12px 30px rgba(38,58,50,.08)}.gallery-line{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.gallery-line img{height:290px;width:100%;object-fit:cover;border-radius:30px;box-shadow:0 12px 30px rgba(38,58,50,.10)}.feature-list{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.feature{background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:30px;box-shadow:0 12px 30px rgba(38,58,50,.08)}.price-table{width:100%;border-collapse:collapse;background:white;border-radius:24px;overflow:hidden}.price-table th,.price-table td{padding:18px;border-bottom:1px solid var(--line);text-align:left}.price-table th{background:#f1e6d5;color:var(--green)}footer{background:#173b28;color:#fff;padding:58px 6vw}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px}.cms{position:fixed;right:20px;bottom:20px;z-index:60;background:var(--gold);color:white;border:0;border-radius:999px;padding:14px 20px;font-weight:900;box-shadow:var(--shadow)}
.admin-page{background:#f5eee2}.admin-shell{display:grid;grid-template-columns:290px 1fr 34vw;gap:24px;padding:30px}.admin-sidebar,.admin-editor,.admin-preview{background:#fffaf4;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:22px}.admin-sidebar button,.admin-tabs button{display:block;width:100%;text-align:left;border:0;background:transparent;padding:13px 14px;border-radius:16px;font-weight:900;color:var(--green);cursor:pointer}.admin-sidebar button.active,.admin-tabs button.active{background:#eaf4e7}.admin-toolbar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}.admin-field{margin:16px 0}.admin-field label{display:block;font-weight:900;color:#7f5711;text-transform:uppercase;font-size:.82rem;letter-spacing:.08em;margin-bottom:8px}.admin-field input,.admin-field textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px;background:#fff;font-size:1rem}.admin-field textarea{min-height:110px}.edit-block{border:1px dashed #d2b98e;border-radius:20px;padding:16px;margin:14px 0;background:#fff}.edit-block img{width:100%;height:160px;object-fit:cover;border-radius:16px}.preview-frame{width:100%;height:72vh;border:1px solid var(--line);border-radius:18px;background:white}.small{font-size:.9rem;color:var(--muted)}.inline-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.hidden{display:none}
@media(max-width:1050px){.menu{display:none}.booking,.three,.room-showcase,.wellness-layout,.gallery-line,.feature-list,.footer-grid,.page-hero{grid-template-columns:1fr}.booking{margin:0 4vw 30px}.page-hero .hero-img{min-height:42vh}.room-card img{height:260px}.admin-shell{grid-template-columns:1fr}.admin-preview{display:none}}


/* Poolbilder natürlich und professionell: keine Farbstiche/Transparenzen */
.hero, .page-hero .hero-img, .wellness-large, .quote { background-blend-mode: normal !important; filter: none !important; }
.card img, .room-card img { filter:none !important; opacity:1 !important; }
.grid.three .card img { height:260px; object-fit:cover; width:100%; }
.room-card img { height:300px; object-fit:cover; width:100%; }
.wellness-large { min-height:520px; background-size:cover; background-position:center; border-radius:28px; }
@media (max-width: 780px){ .grid.three .card img{height:220px}.room-card img{height:240px}.wellness-large{min-height:320px} }

/* Ein-Datei-CMS: stabile Adminansicht ohne Live-Vorschau */
.admin-no-preview{grid-template-columns:290px minmax(0,1fr)!important}
.admin-save-note{margin:0 0 18px;padding:14px 18px;border-radius:16px;background:#fff7dc;border:1px solid #e8d49b;color:#4a3a16;font-weight:700}
.save-status{display:none;margin:10px 0 18px;padding:12px 16px;border-radius:14px;background:#eaf7ef;color:#17452d;font-weight:800;border:1px solid #cfe8d8}
.save-status.visible{display:block}
@media(max-width:1050px){.admin-no-preview{grid-template-columns:1fr!important}}

/* Ein-Datei-CMS v2: stabile Adminansicht ohne Live-Vorschau */
.admin-no-preview{grid-template-columns:290px minmax(0,1fr)!important}
.admin-save-note{margin:0 0 18px;padding:14px 18px;border-radius:16px;background:#fff7dc;border:1px solid #e8d49b;color:#4a3a16;font-weight:700}
.save-status{display:none;margin:10px 0 18px;padding:12px 16px;border-radius:14px;background:#eaf7ef;color:#17452d;font-weight:800;border:1px solid #cfe8d8}
.save-status.visible{display:block}
@media(max-width:1050px){.admin-no-preview{grid-template-columns:1fr!important}}

/* ============================================================
   BUCHUNGSMODAL
   ============================================================ */
.bk-modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(15,35,25,.62);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px}
.bk-modal{background:var(--paper);border-radius:32px;max-width:680px;width:100%;max-height:90vh;overflow-y:auto;padding:36px 40px;position:relative;box-shadow:0 32px 80px rgba(10,30,20,.28)}
.bk-close{position:absolute;top:18px;right:20px;border:0;background:transparent;font-size:1.4rem;color:var(--muted);cursor:pointer;line-height:1;padding:6px}
.bk-title{font-size:2rem;margin:.1em 0 .3em;color:var(--green)}
.bk-sub{color:var(--muted);margin:0 0 22px;font-size:1.05rem}
.bk-steps>.bk-step{display:none}.bk-steps>.bk-step.active{display:block}
.bk-step-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.bk-step-num{width:34px;height:34px;border-radius:50%;background:var(--gold);color:white;display:grid;place-items:center;font-weight:900;font-size:1rem;flex-shrink:0}
.bk-step-header span:last-child{font-weight:900;color:var(--green);font-size:1.05rem;text-transform:uppercase;letter-spacing:.08em}
.bk-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bk-field{margin:0 0 16px}.bk-field label{display:block;font-weight:900;color:#7f5711;text-transform:uppercase;font-size:.8rem;letter-spacing:.08em;margin-bottom:6px}
.bk-field input,.bk-field select,.bk-field textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 15px;background:#fff;font-size:1rem;font-family:inherit}
.bk-field--small input{max-width:100px}
.bk-field textarea{min-height:72px;resize:vertical}
.bk-nav{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}
.bk-summary{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 0 20px}
.bk-sum-block{background:#f7f1e8;border:1px solid var(--line);border-radius:18px;padding:18px}
.bk-sum-title{font-weight:900;color:var(--gold);text-transform:uppercase;font-size:.82rem;letter-spacing:.1em;margin-bottom:12px}
.bk-sum-row{display:flex;justify-content:space-between;font-size:.95rem;padding:5px 0;border-bottom:1px solid #e8ddd0}
.bk-sum-row:last-child{border-bottom:0}
.bk-sum-row span{color:var(--muted)}.bk-sum-row strong{color:var(--text);text-align:right;max-width:55%}
.bk-agb{margin:18px 0 0}.bk-check-label{display:flex;gap:10px;align-items:flex-start;cursor:pointer;font-size:.93rem;line-height:1.5}
.bk-check-label input{margin-top:3px;flex-shrink:0}
.bk-success{text-align:center;padding:40px 20px}
.bk-check-icon{font-size:3.5rem;color:var(--gold);margin-bottom:16px}
/* Schnellsuche-Inputs */
.bk-input{width:100%;border:0;background:transparent;font-size:1rem;font-weight:700;color:var(--green);font-family:inherit;outline:none;padding:0}
.bk-input option{color:var(--text)}

/* ============================================================
   KONTAKTFORMULAR
   ============================================================ */
.contact-layout{grid-template-columns:1fr 1.1fr!important;gap:48px!important}
.contact-side{display:flex;flex-direction:column;justify-content:center}
.contact-info-block{margin-top:32px;display:flex;flex-direction:column;gap:20px}
.contact-info-item{display:flex;align-items:flex-start;gap:16px}
.contact-info-icon{font-size:1.5rem;color:var(--gold);flex-shrink:0;margin-top:2px}
.contact-form-card{min-width:0}
.ct-row{display:grid;grid-template-columns:auto 1fr 1fr;gap:12px}
.ct-row .admin-field:first-child{min-width:110px}
.ct-agb{margin:14px 0 0;font-size:.92rem}
.ct-status{display:none;margin-top:14px;padding:12px 16px;border-radius:14px;background:#eaf7ef;color:#17452d;font-weight:800;border:1px solid #cfe8d8}

@media(max-width:1050px){
  .bk-modal{padding:24px 18px;border-radius:22px}
  .bk-row,.bk-summary{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr!important}
  .ct-row{grid-template-columns:1fr 1fr}
  .ct-row .admin-field:first-child{grid-column:1/-1}
}

/* ============================================================
   FEATURES-GRID (Inklusive-Liste Startseite)
   ============================================================ */
.features-section{padding:48px 6vw}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1180px;margin:28px auto 0}
.feature-item{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:20px 18px;display:flex;align-items:flex-start;gap:14px;box-shadow:0 6px 18px rgba(30,54,42,.07)}
.feature-icon{font-size:1.5rem;flex-shrink:0;line-height:1.2}
.feature-item span:last-child{font-size:.97rem;font-weight:700;color:var(--green);line-height:1.4}
@media(max-width:1050px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.features-grid{grid-template-columns:1fr}}

/* ============================================================
   PREISE – ALLGEMEIN
   ============================================================ */
.preise-section{padding:48px 6vw}
.preise-section .narrow{max-width:1180px;margin:auto}
.price-block{margin:32px 0}
.price-block-head{display:flex;align-items:baseline;gap:16px;margin-bottom:12px;padding:14px 20px;background:var(--green);color:white;border-radius:18px 18px 0 0}
.price-block-head strong{font-size:1.15rem;color:white}
.price-block-head span{font-size:.9rem;color:#a8c8b8}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.pt-modern{width:100%;border-collapse:collapse;background:white;border-radius:0 0 18px 18px;overflow:hidden;box-shadow:0 8px 24px rgba(30,54,42,.10)}
.pt-modern thead tr{background:#f1e6d5}
.pt-modern th{padding:14px 16px;text-align:center;color:var(--green);font-size:.88rem;font-weight:900;white-space:nowrap;border-bottom:2px solid var(--line)}
.pt-modern th:first-child,.pt-modern td:first-child{text-align:left;padding-left:20px}
.pt-modern td{padding:13px 16px;text-align:center;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--text)}
.pt-modern tbody tr:last-child td{border-bottom:0}
.pt-modern tbody tr:nth-child(even){background:#fdf8f2}
.pt-modern tbody tr:hover{background:#f7f0e6}
.pt-dauer{font-weight:800;color:var(--green);white-space:nowrap}
.pt-hinweis{font-size:.9rem;color:var(--muted);margin-top:12px;padding:12px 16px;background:#fdf8f2;border-radius:12px;border:1px solid var(--line)}

/* ============================================================
   SPEZIALWOCHEN
   ============================================================ */
.sw-section{background:var(--paper)}
.sw-rabatt{background:#fff7dc;border:1px solid #e8d49b;color:#4a3a16;font-weight:700;padding:14px 18px;border-radius:14px;margin:16px 0 28px;font-size:.95rem}
.sw-card{background:white;border:1px solid var(--line);border-radius:30px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:36px}
.sw-card-head{display:grid;grid-template-columns:280px 1fr;min-height:180px}
.sw-card-head img{width:100%;height:100%;object-fit:cover;display:block}
.sw-card-title{padding:28px 32px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(135deg,var(--green),var(--green2))}
.sw-card-title h2{color:white;margin:0 0 8px;font-size:1.8rem}
.sw-card-title p{color:#c8e0d0;margin:0;font-size:1rem}
.sw-card-body{display:grid;grid-template-columns:1fr 1fr;gap:0}
.sw-leistungen,.sw-prices{padding:24px 28px}
.sw-leistungen{border-right:1px solid var(--line)}
.sw-leistungen h4,.sw-prices h4{color:var(--gold);text-transform:uppercase;font-size:.82rem;letter-spacing:.1em;margin:0 0 14px}
.sw-leistungen ul{margin:0;padding-left:18px;color:var(--text);font-size:.93rem;line-height:1.9}
.sw-leistungen li{padding:1px 0}
.storno-box{background:#fff7dc;border:1px solid #e8d49b;border-radius:20px;padding:22px 26px;margin-top:8px}
.storno-box strong{display:block;color:#4a3a16;margin-bottom:8px;font-size:1.05rem}
.storno-box p{color:#5a4a26;margin:0}
@media(max-width:1050px){
  .sw-card-head{grid-template-columns:1fr}
  .sw-card-head img{height:220px}
  .sw-card-body{grid-template-columns:1fr}
  .sw-leistungen{border-right:0;border-bottom:1px solid var(--line)}
}

/* ============================================================
   FOTO-GALERIE (Europa Therme)
   ============================================================ */
.gallery-section{padding:48px 6vw}
.gallery-masonry{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:16px;max-width:1180px;margin:28px auto 0}
.gallery-item img{width:100%;height:100%;object-fit:cover;border-radius:22px;display:block;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 10px 30px rgba(20,50,35,.15)}
.gallery-item img:hover{transform:scale(1.015);box-shadow:0 18px 48px rgba(20,50,35,.22)}
.gi-0{grid-column:1;grid-row:1 2;height:420px}
.gi-1{grid-column:2;grid-row:1;height:200px}
.gi-2{grid-column:2;grid-row:2;height:200px}
.gi-3{grid-column:1 / span 2;height:320px}
@media(max-width:1050px){
  .gallery-masonry{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gi-0,.gi-1,.gi-2,.gi-3{grid-column:auto;grid-row:auto;height:220px}
}
@media(max-width:600px){
  .gallery-masonry{grid-template-columns:1fr}
  .gi-0,.gi-1,.gi-2,.gi-3{height:200px}
}
/* Feature-Icons als stilvolle Kreise statt Emojis */
.feature-icon{width:36px;height:36px;border-radius:50%;background:var(--gold);color:white;display:grid;place-items:center;font-size:.75rem;font-weight:900;flex-shrink:0}

/* ============================================================
   ADMIN EXPORT-BUTTONS
   ============================================================ */
.export-btn{background:var(--green2)!important;box-shadow:0 8px 20px rgba(36,89,71,.25)!important}
.export-btn:hover{background:var(--green)!important}
.admin-toolbar{flex-wrap:wrap;gap:10px}
.admin-toolbar .btn{font-size:.9rem;padding:12px 18px}

/* ============================================================
   ADMIN LOGIN
   ============================================================ */
.admin-login-wrap{min-height:70vh;display:grid;place-items:center;padding:40px 20px;background:var(--cream)}
.admin-login-card{background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:40px 44px;max-width:420px;width:100%;box-shadow:var(--shadow);text-align:left}
.admin-login-logo{margin-bottom:20px}
.admin-login-logo .logo-mark{width:54px;height:46px;border-radius:50% 50% 8px 8px;background:linear-gradient(135deg,#2e8a44,#9acb80);display:grid;place-items:center;color:white;font-family:Georgia,serif;font-size:1.4rem;font-weight:800}
.admin-login-card h2{margin:0 0 6px;font-size:1.7rem}
.admin-login-card .small{color:var(--muted);margin:0 0 22px}
.admin-pw-error{background:#fdecea;border:1px solid #f5c0bb;color:#8b1a1a;border-radius:12px;padding:10px 14px;font-size:.92rem;margin-bottom:10px}

/* ============================================================
   FOOTER – verlinkt
   ============================================================ */
.footer-links{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer-links a{color:#a8c8b8;text-decoration:none;font-size:.95rem;transition:color .2s}
.footer-links a:hover{color:white}
footer strong{color:var(--gold);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em}
.footer-contact-inline{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.footer-contact-inline a{color:#a8c8b8;text-decoration:none;font-size:.92rem}
.footer-contact-inline a:hover{color:white}
.footer-newsletter{text-align:center;padding:40px 0 10px;border-top:1px solid rgba(255,255,255,.12);margin-top:40px}.footer-newsletter h3{color:white;margin:0 0 8px;font-size:1.3rem}.footer-newsletter p{color:#7a9e8e;margin:0 0 18px;font-size:.95rem}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#7a9e8e}
.footer-bottom a{color:#7a9e8e;text-decoration:none}.footer-bottom a:hover{color:white}
@media(max-width:1050px){.footer-newsletter{text-align:center;padding:40px 0 10px;border-top:1px solid rgba(255,255,255,.12);margin-top:40px}.footer-newsletter h3{color:white;margin:0 0 8px;font-size:1.3rem}.footer-newsletter p{color:#7a9e8e;margin:0 0 18px;font-size:.95rem}.footer-bottom{flex-direction:column;text-align:center}}

/* ============================================================
   RECHTSSEITEN
   ============================================================ */
.legal-section{background:var(--paper);padding:60px 6vw 80px}
.legal-inner{max-width:820px;margin:0 auto}
.legal-inner h1{font-size:clamp(2rem,3vw,3rem);margin-bottom:.2em}
.legal-inner h2{font-size:1.3rem;margin:2em 0 .5em;color:var(--green);border-bottom:2px solid var(--line);padding-bottom:.3em}
.legal-inner p,.legal-inner li{font-size:1rem;line-height:1.8;color:var(--text)}
.legal-inner ul{padding-left:1.4em;margin:.5em 0 1em}
.legal-inner ul li{margin-bottom:.4em}
.legal-inner address{font-style:normal;line-height:1.9;margin:.5em 0 1em;padding:18px 22px;background:#f7f1e8;border-radius:14px;border-left:4px solid var(--gold)}
.legal-inner a{color:var(--green2);text-decoration:underline}
.legal-inner a:hover{color:var(--gold)}
.legal-pflicht{color:var(--muted);font-size:.92rem;margin-bottom:2em;font-style:italic}

/* ============================================================
   BARRIEREFREIHEIT – GLOBAL
   ============================================================ */

/* Skip-Link */
.skip-link{position:absolute;top:-100px;left:16px;z-index:9999;background:var(--green);color:white;padding:12px 20px;border-radius:0 0 12px 12px;font-weight:900;text-decoration:none;font-size:1rem;transition:top .15s}
.skip-link:focus{top:0}

/* Fokus-Stile – alle interaktiven Elemente klar sichtbar */
*:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--green2);outline-offset:0;border-color:var(--green2)}

/* Kontrast-Verbesserungen */
.lead{color:#4a5c52}           /* war #66756c – jetzt AA-konform */
.small{color:#4a5c52}
.eyebrow{color:#8a6010}        /* war #c58b23 auf hellem Hintergrund – jetzt dunkler */
.muted-text{color:#4a5c52}

/* Mindestgröße für Touch-Targets */
.btn,.book,.menu a,.footer-links a,.bk-close,.admin-sidebar button{min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center}
.menu a{padding:0 4px}

/* Bilder: Alt-Text wird per HTML gesetzt; decorative images via role */
.hero,.page-hero .hero-img,.wellness-large,.quote{position:relative}

/* Tabellen: responsive + zugänglich */
.pt-modern{border:1px solid var(--line)}
.pt-modern th{scope:col}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-scroll:focus-within{outline:2px solid var(--gold);outline-offset:2px}

/* Formulare: Label-Kontrast */
.admin-field label,.bk-field label{color:#5a3e0a}   /* erhöhter Kontrast */
.bk-step-header span:last-child{color:#173b28}

/* Animationen: respektiert Nutzer-Präferenz */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .gallery-item img:hover{transform:none}
}

/* Hoch-Kontrast-Modus */
@media(forced-colors:active){
  .btn,.book{border:2px solid ButtonText}
  .card,.room-card,.sw-card{border:1px solid CanvasText}
}

/* Schriftgröße: niemals kleiner als 14px für Lesbarkeit */
.topbar,.small,.legal-pflicht{font-size:max(.85rem,14px)}

/* Tabellen-Scope für Screenreader – via CSS-Attr nicht möglich,
   wird im JS-Renderer als data-attr gesetzt und per attr() genutzt */

/* Screenreader-only (für Caption etc.) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.legal-inner ol.legal-list{padding-left:1.5em;margin:.5em 0 1.5em}
.legal-inner ol.legal-list li{margin-bottom:1em;line-height:1.8;color:var(--text)}

/* Kontaktformular Status-Meldungen */
.ct-status--ok{background:#eaf7ef;color:#17452d;border:1px solid #cfe8d8;font-weight:600}
.ct-status--err{background:#fdecea;color:#8b1a1a;border:1px solid #f5c0bb}
.ct-status--ok a,.ct-status--err a{color:inherit;font-weight:700}

.img-editor-block{background:#f5efe6;border-radius:16px;padding:16px}
.img-preview-wrap{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-bottom:12px;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.img-preview-frame{width:100%;height:100%;background-size:cover;background-position:center;transition:background-position .15s,background-size .15s}
.img-controls{display:flex;flex-direction:column;gap:8px}
.img-ctrl-row{display:grid;grid-template-columns:140px 1fr;align-items:center;gap:10px;font-size:.85rem;font-weight:700;color:#315041}
.img-ctrl-row input[type=range]{width:100%;accent-color:#c58b23}
.btn-small{background:#173b28;color:white;border:none;border-radius:10px;padding:7px 14px;font-size:.82rem;font-weight:700;cursor:pointer}
.btn-small:hover{background:#c58b23}

/* ── Newsletter Footer ───────────────────────────────────────────────────── */
.footer-nl-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:40px;align-items:center;padding:40px 0 10px}
.footer-nl-title{color:white;font-size:1.5rem;margin:6px 0 8px}
.footer-nl-sub{color:#7a9e8e;font-size:.95rem;margin:0;line-height:1.5}
.footer-nl-form{display:none}
/* ── Newsletter Section (standalone, light) ─────────────────────────────── */
.nl-section{background:var(--paper);padding:80px 6vw;border-top:1px solid var(--line)}
.nl-section-inner{max-width:1160px;margin:auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.nl-section-title{font-family:Georgia,serif;color:var(--green);font-size:clamp(1.8rem,2.5vw,2.8rem);margin:.3em 0 .6em}
.nl-section-sub{color:var(--muted);font-size:1.1rem;line-height:1.7;margin:0 0 24px}
.nl-benefits{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.nl-benefits li{display:flex;align-items:center;gap:10px;color:var(--green);font-weight:700;font-size:.97rem}
.nl-benefits li::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--gold);color:white;font-size:.75rem;font-weight:900;flex-shrink:0}
.nl-card{background:#fff;border:1px solid var(--line);border-radius:32px;padding:38px 36px;box-shadow:var(--shadow)}
.nl-card-title{font-family:Georgia,serif;color:var(--green);font-size:1.5rem;margin:0 0 24px}
.nl-fields{display:flex;flex-direction:column;gap:16px}
.nl-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.nl-field{display:flex;flex-direction:column;gap:6px}
.nl-label{font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:#7f5711}
.nl-field-input{border:1px solid var(--line);border-radius:14px;padding:13px 16px;background:var(--cream);font-size:1rem;color:var(--text);font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}
.nl-field-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(197,139,35,.12);background:#fff}
.nl-dsgvo{font-size:.8rem;color:var(--muted);line-height:1.5;margin:0}
.nl-dsgvo a{color:var(--gold);text-decoration:none}
.nl-submit-btn{width:100%;padding:16px;font-size:1rem;border-radius:16px;margin-top:4px}
.nl-status{margin-top:8px;padding:12px 16px;border-radius:12px;font-size:.9rem}
.nl-success{background:rgba(80,160,80,.1);color:#2a6a2a;border:1px solid rgba(80,160,80,.25)}
.nl-error{background:#fdecea;color:#8b1a1a;border:1px solid #f5c0bb}
.nl-success-msg{text-align:center;padding:20px 0}
.nl-check{width:56px;height:56px;border-radius:50%;background:var(--gold);color:white;font-size:1.6rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.nl-success-msg h3{color:var(--green);font-family:Georgia,serif;margin:0 0 8px}
.nl-success-msg p{color:var(--muted);font-size:.95rem}
@media(max-width:1050px){.nl-section-inner{grid-template-columns:1fr;gap:36px}.nl-field-row{grid-template-columns:1fr}}

/* ── Buchungsformular: Gastdaten ─────────────────────────────────────────── */
.bk-section-title{font-size:1rem;font-weight:900;color:var(--green);margin:24px 0 4px;text-transform:uppercase;letter-spacing:.08em;border-top:1px solid var(--line);padding-top:18px}
.bk-hint{font-size:.87rem;color:var(--muted);margin:0 0 14px}
.bk-guest-block{background:#f7f1e8;border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:14px}
.bk-guest-title{font-weight:900;color:var(--green);margin-bottom:12px;font-size:.95rem}

/* HAMBURGER */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:transparent;border:0;cursor:pointer;padding:10px;min-height:44px;min-width:44px}
.burger span{display:block;width:24px;height:2px;background:var(--green);border-radius:2px;transition:transform .25s,opacity .25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(255,250,244,.98);z-index:40;padding:100px 28px 40px;overflow-y:auto}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px}
.mobile-menu nav a{font-family:Georgia,serif;font-size:1.5rem;font-weight:800;color:var(--green);text-decoration:none;padding:14px 0;border-bottom:1px solid var(--line)}
.mobile-menu.open{display:block}
@media(max-width:1050px){.menu{display:none}.burger{display:flex}}

/* MOBILE ALLGEMEIN */
@media(max-width:700px){
  .hero{min-height:80vh}.fade{margin-left:5vw;margin-right:5vw}
  .fade h1{font-size:clamp(2rem,9vw,3.2rem)}
  .buttons{flex-direction:column;gap:10px}
  .buttons .btn,.buttons .book{width:100%;text-align:center;justify-content:center}
  .page-hero{grid-template-columns:1fr}.page-hero .hero-img{min-height:50vw}
  .page-hero .hero-copy{padding:28px 20px}
  section{padding:40px 16px}
  .booking{grid-template-columns:1fr 1fr;margin:0 12px 24px}
  .booking .field:last-child{grid-column:1/-1}
  .booking button{grid-column:1/-1;width:100%}
  .topbar span:last-child{display:none}
  .footer-grid{grid-template-columns:1fr}
  footer{padding:40px 20px 30px}
  .footer-bottom{flex-direction:column;text-align:center;gap:8px}
  .contact-layout,.ct-row{grid-template-columns:1fr}
  input,select,textarea{font-size:16px!important}
}
@media(max-width:500px){.booking{grid-template-columns:1fr}}

/* BUCHUNGS-BANNER */
.bk-prefill-banner{background:linear-gradient(135deg,#eaf5ec,#f0f8f1);border:1.5px solid #9acb80;border-radius:18px;padding:16px 20px;margin-bottom:20px;font-size:.95rem;line-height:1.5}
.bk-prefill-banner strong{color:var(--green);display:block;margin-bottom:4px}

/* ============================================================
   BOOKING WIDGET ERWEITERT
   ============================================================ */
.booking{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))!important}
.bk-children-ages{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;grid-column:1/-1;padding:0 4px}
.bk-submit-btn{grid-column:1/-1;width:100%}
@media(max-width:900px){
  .booking{grid-template-columns:1fr 1fr!important}
  .bk-room-selects{grid-template-columns:1fr 1fr}
  .bk-children-ages{grid-template-columns:1fr 1fr}
}
@media(max-width:500px){
  .booking{grid-template-columns:1fr!important}
  .bk-room-selects{grid-template-columns:1fr}
  .bk-children-ages{grid-template-columns:1fr}
  .bk-children-ages{grid-template-columns:1fr}
}

/* ZIMMER-SELECTS GRID */
.bk-room-selects{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;grid-column:1/-1}
@media(max-width:700px){.booking .bk-room-selects .field{grid-column:1/-1}}

/* ============================================================
   ZIMMER-DETAILSEITE
   ============================================================ */
.room-detail-wrap{max-width:1180px;margin:0 auto;padding:40px 6vw 60px}
.room-detail-breadcrumb{margin-bottom:24px}
.room-detail-breadcrumb a{color:var(--gold);font-weight:800;text-decoration:none;font-size:.95rem}
.room-detail-breadcrumb a:hover{text-decoration:underline}
.room-detail-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.room-detail-hero{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.room-detail-hero img{width:100%;height:100%;object-fit:cover;display:block}
.room-detail-gallery{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rdg-main{grid-column:1/-1}
.rdg-item{border-radius:22px;overflow:hidden;box-shadow:0 8px 24px rgba(20,50,35,.12)}
.rdg-item img{width:100%;height:260px;object-fit:cover;display:block}
.rdg-main img{height:380px}
.room-detail-img-hint{font-size:.82rem;color:var(--muted);margin-top:10px;padding:8px 12px;background:#f7f1e8;border-radius:10px}
.room-detail-img-hint a{color:var(--gold)}
.room-detail-info{display:flex;flex-direction:column;gap:20px;padding-top:8px}
.room-detail-title{font-size:clamp(1.8rem,3vw,2.8rem);margin:.2em 0 0}
.room-detail-text{color:var(--muted);font-size:1.08rem;line-height:1.7;margin:0}
.room-detail-features{display:flex;flex-wrap:wrap;gap:10px}
.room-feat-tag{background:#f7f1e8;border:1px solid var(--line);border-radius:14px;padding:8px 16px;font-weight:800;color:var(--green);font-size:.9rem}
.room-detail-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.room-card-btns{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.room-card-btns .btn{padding:12px 18px;font-size:.9rem}
@media(max-width:900px){
  .room-detail-layout{grid-template-columns:1fr}
  .room-detail-gallery{grid-template-columns:1fr}
  .rdg-main{grid-column:auto}
  .rdg-item img,.rdg-main img{height:220px}
}

/* ============================================================
   ADMIN FOTO-EDITOR (verbessert)
   ============================================================ */
.img-editor-block{background:#f5efe6;border-radius:16px;padding:16px;margin-top:6px}
.img-preview-wrap{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-bottom:12px;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.img-preview-frame{width:100%;height:100%;background-size:cover;background-position:center;transition:background-position .1s,background-size .1s}
.img-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.img-ctrl-row{display:grid;grid-template-columns:100px 1fr;align-items:center;gap:10px;font-size:.85rem;font-weight:700;color:#315041}
.img-ctrl-row input[type=range]{width:100%;accent-color:var(--gold)}
.btn-small{background:var(--green);color:white;border:none;border-radius:10px;padding:7px 14px;font-size:.82rem;font-weight:700;cursor:pointer;margin-top:4px}
.btn-small:hover{background:var(--gold)}

/* ============================================================
   COOKIE-CONSENT-BANNER
   ============================================================ */
#tn-cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  padding:0 0 env(safe-area-inset-bottom);
  background:rgba(20,42,32,.97);
  backdrop-filter:blur(12px);
  border-top:2px solid var(--gold);
  box-shadow:0 -8px 40px rgba(0,0,0,.35);
  animation:cbSlideUp .35s cubic-bezier(.22,1,.36,1);
}
@keyframes cbSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cb-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;gap:28px;
  padding:20px 6vw;
  flex-wrap:wrap;
}
.cb-text{flex:1;min-width:220px}
.cb-text strong{color:#fff;font-size:1.05rem;display:block;margin-bottom:6px}
.cb-text p{color:rgba(255,255,255,.75);font-size:.88rem;line-height:1.6;margin:0}
.cb-text a{color:var(--gold);text-decoration:underline}
.cb-actions{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}
.cb-btn{padding:12px 24px;border-radius:14px;border:none;font-weight:800;font-size:.92rem;cursor:pointer;transition:opacity .15s}
.cb-accept{background:var(--gold);color:#fff}
.cb-accept:hover{opacity:.88}
.cb-decline{background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);border:1.5px solid rgba(255,255,255,.2)}
.cb-decline:hover{background:rgba(255,255,255,.2)}
@media(max-width:600px){
  .cb-inner{flex-direction:column;align-items:stretch}
  .cb-actions{justify-content:stretch}
  .cb-btn{flex:1;text-align:center}
}

/* ── GA Test-Panel ─────────────────────────────────────────── */
.ga-test-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ga-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px rgba(20,50,35,.08);border:1px solid var(--line)}
.ga-card h3{margin:0 0 16px;font-size:1.05rem;color:var(--green)}
.ga-card-full{grid-column:1/-1}
.ga-row{padding:7px 0;border-bottom:1px solid var(--line);font-size:.9rem;display:flex;align-items:center;gap:10px}
.ga-row:last-of-type{border:none}
.ga-ok{color:#27ae60;font-weight:900;font-size:1.1rem}
.ga-fail{color:#e74c3c;font-weight:900;font-size:1.1rem}
.ga-muted{color:var(--muted);font-size:.84rem;padding-top:8px}
.ga-btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.ga-dl-wrap{max-height:280px;overflow-y:auto;background:#f8f5ef;border-radius:12px;padding:12px}
.ga-dl-entry{font-size:.78rem;margin:0 0 8px;background:#fff;border-radius:8px;padding:8px 10px;border:1px solid var(--line);white-space:pre-wrap;word-break:break-all}
.ga-steps{padding-left:20px;line-height:1.9;font-size:.95rem}
.ga-steps a{color:var(--gold)}
@media(max-width:700px){.ga-test-grid{grid-template-columns:1fr}}
