*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--forest:#2C3E2D;--forest-deep:#1a2b1b;--sage:#7A8B6F;--sage-light:#A8B89E;--sand:#E8DFD0;--sand-light:#F5F0E8;--cream:#FAF8F4;--warm:#C4986A;--warm-dark:#A67B4F;--warm-light:#E6C9A8;--text:#2A2A28;--text-light:#6B6B66;--white:#FFFFFF}
html{scroll-behavior:smooth;font-size:16px}
.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}
body{font-family:'Outfit',sans-serif;color:var(--text);background:var(--cream);overflow-x:hidden;-webkit-font-smoothing:antialiased}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.section-label{font-family:'Outfit',sans-serif;font-weight:500;font-size:.75rem;letter-spacing:.25em;text-transform:uppercase;color:var(--warm);display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.section-label::before{content:'';width:40px;height:1px;background:var(--warm)}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(2rem,4vw,3.2rem);line-height:1.15;color:var(--forest);margin-bottom:1.5rem}
.section-title em{font-style:italic;color:var(--sage)}
.centered{text-align:center}
.centered .section-label{justify-content:center}
.centered .section-label::before{display:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideLeft{from{opacity:0;transform:translateX(-60px)}to{opacity:1;transform:translateX(0)}}
@keyframes lineGrow{from{width:0}to{width:80px}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes heroZoom{from{transform:scale(1.05)}to{transform:scale(1.12)}}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.15s}.reveal-delay-2{transition-delay:.3s}.reveal-delay-3{transition-delay:.45s}.reveal-delay-4{transition-delay:.6s}

.header-bar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s ease}
.header-bar .container{display:flex;justify-content:space-between;align-items:center;min-height:60px}
.header-bar.scrolled{background:rgba(250,248,244,.97);backdrop-filter:blur(20px);box-shadow:0 1px 30px rgba(0,0,0,.06)}
.nav-logo-wrap{display:flex;align-items:flex-start;text-decoration:none;flex-shrink:0;transition:all .4s ease}
.header-bar.scrolled .nav-logo-wrap{align-items:center}
.nav-logo-box{background:var(--white);padding:1rem 2rem 2rem;clip-path:polygon(0 0,100% 0,100% calc(100% - 26px),50% 100%,0 calc(100% - 26px));box-shadow:0 12px 40px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;transition:all .5s cubic-bezier(.25,.46,.45,.94)}
.nav-logo-box img{height:120px;width:auto;display:block}
.header-bar.scrolled .nav-logo-box{display:none}
.nav-logo-text{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;color:var(--forest);white-space:nowrap;opacity:0;pointer-events:none;transition:all .4s ease;display:none}
.header-bar.scrolled .nav-logo-text{opacity:1;pointer-events:auto;display:block}
.nav-links{display:flex;gap:1.25rem;list-style:none;align-items:center}
.nav-links a{font-size:.78rem;font-weight:400;color:rgba(255,255,255,.85);text-decoration:none;letter-spacing:.04em;transition:color .3s;position:relative;white-space:nowrap}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--warm);transition:width .3s ease}
.nav-links a:hover::after{width:100%}
.header-bar.scrolled .nav-links a{color:var(--text-light)}
.header-bar.scrolled .nav-links a:hover{color:var(--forest)}
.nav-cta{background:var(--warm)!important;color:var(--white)!important;padding:.6rem 1.5rem;border-radius:100px;font-weight:500!important;transition:background .3s,transform .2s!important}
.nav-cta:hover{background:var(--warm-dark)!important;transform:translateY(-1px)}
.nav-cta::after{display:none!important}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.menu-toggle span{width:24px;height:2px;background:var(--white);transition:all .3s}
.header-bar.scrolled .menu-toggle span{background:var(--forest)}

.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--forest-deep)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.05);animation:heroZoom 20s ease-in-out infinite alternate}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(26,43,27,.82) 0%,rgba(26,43,27,.5) 50%,rgba(26,43,27,.2) 100%)}
.hero-content{position:relative;z-index:2;text-align:left;max-width:650px;padding:0 6% 12vh;width:100%}
.hero-location{font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--warm-light);margin-bottom:2rem;animation:fadeIn 1s .2s both;display:flex;align-items:center;gap:1rem}
.hero-location::after{content:'';display:block;height:1px;background:var(--warm-light);animation:lineGrow 1.2s .6s both}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.5rem,5vw,4.2rem);font-weight:300;color:var(--white);line-height:1.1;margin-bottom:.5rem;animation:slideLeft 1s .3s both}
.hero h1 em{font-style:italic;font-weight:400;color:var(--warm-light);display:block;font-size:.6em;margin-top:.3em}
.hero-sub{display:none}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;animation:fadeIn 1s .8s both}
.hero-bestpreis{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.55rem 1.25rem;background:rgba(196,152,106,.15);border:1px solid rgba(196,152,106,.35);border-radius:100px;font-size:.78rem;font-weight:500;color:var(--warm-light);letter-spacing:.03em;animation:fadeIn 1s 1s both;backdrop-filter:blur(8px)}
.hero-badge{display:none}
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2.5rem;background:var(--warm);color:var(--white);border:none;border-radius:100px;font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:all .3s ease;text-decoration:none}
.btn-primary:hover{background:var(--warm-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(196,152,106,.3)}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2.5rem;background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.3);border-radius:100px;font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:400;cursor:pointer;transition:all .3s ease;text-decoration:none}
.btn-secondary:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;animation:float 3s ease-in-out infinite}
.hero-scroll svg{width:24px;height:24px;stroke:rgba(255,255,255,.5)}
.features-ribbon{background:var(--forest);padding:3.5rem 0;margin-top:-1px}
.ribbon-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem 1.5rem}
.ribbon-item{text-align:center;padding:.6rem .25rem}
.ribbon-icon{width:44px;height:44px;margin:0 auto .6rem;background:rgba(196,152,106,.15);border-radius:50%;display:flex;align-items:center;justify-content:center}
.ribbon-icon svg{width:20px;height:20px;stroke:var(--warm-light);fill:none;stroke-width:1.5}
.ribbon-item h3{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:500;color:var(--white);margin-bottom:.2rem;line-height:1.3}
.ribbon-item p{font-size:.7rem;color:rgba(255,255,255,.5);line-height:1.35}

.about{padding:7rem 0;background:var(--cream);overflow:hidden}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-gallery{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.12)}
.about-gallery-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.about-gallery-slide{min-width:100%;height:420px;position:relative}
.about-gallery-slide img{width:100%;height:100%;object-fit:cover}
.about-gallery-nav{position:absolute;bottom:1.25rem;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:5}
.about-gallery-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:all .3s ease;padding:0}
.about-gallery-dot.active{background:var(--white);transform:scale(1.2)}
.about-gallery-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.85);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:all .3s ease;box-shadow:0 4px 15px rgba(0,0,0,.15)}
.about-gallery-btn:hover{background:var(--white);transform:translateY(-50%) scale(1.08)}
.about-gallery-btn svg{width:20px;height:20px;stroke:var(--forest);fill:none;stroke-width:2}
.about-gallery-btn.prev{left:1rem}
.about-gallery-btn.next{right:1rem}
.about-gallery-counter{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,.45);backdrop-filter:blur(8px);color:var(--white);font-size:.75rem;font-weight:500;padding:.35rem .85rem;border-radius:100px;z-index:5;letter-spacing:.04em}
.about-gallery-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-top:.75rem}
.about-gallery-thumb{height:65px;border-radius:8px;overflow:hidden;cursor:pointer;opacity:.5;transition:all .3s ease;border:2px solid transparent}
.about-gallery-thumb.active{opacity:1;border-color:var(--warm)}
.about-gallery-thumb:hover{opacity:.85}
.about-gallery-thumb img{width:100%;height:100%;object-fit:cover}
.about-text p{font-size:1.05rem;line-height:1.85;color:var(--text-light);margin-bottom:1.5rem}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--sand)}
.stat-item h4{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:400;color:var(--warm)}
.stat-item p{font-size:.8rem;color:var(--text-light);margin-bottom:0;line-height:1.4}
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem}
.usp-card{background:var(--white);border-radius:20px;padding:2.5rem 2rem;text-align:center;box-shadow:0 8px 40px rgba(0,0,0,.06);border:1px solid transparent;transition:all .4s ease;position:relative;overflow:hidden}
.usp-card::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--warm);border-radius:0 0 3px 3px}
.usp-card:hover{border-color:var(--warm-light);transform:translateY(-6px);box-shadow:0 16px 50px rgba(0,0,0,.1)}
.usp-icon-wrap{width:64px;height:64px;margin:0 auto 1.5rem;background:var(--sand);border-radius:50%;display:flex;align-items:center;justify-content:center}
.usp-icon-wrap svg{width:28px;height:28px;stroke:var(--warm);fill:none;stroke-width:1.5}
.usp-fact{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:500;color:var(--forest);line-height:1.1}
.usp-fact-label{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);margin-bottom:1.25rem}
.usp-card h3{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:500;color:var(--forest);margin-bottom:.75rem}
.usp-card p{font-size:.88rem;color:var(--text-light);line-height:1.75}

.rooms{padding:7rem 0;background:var(--sand-light);position:relative}
.rooms::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(to bottom,var(--cream),var(--sand-light))}
.rooms .container{position:relative;z-index:1}
.rooms-header{max-width:600px;margin:0 auto 4rem}
.rooms-header p{font-size:1.05rem;color:var(--text-light);line-height:1.75}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;align-items:stretch}
.room-card{background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 5px 30px rgba(0,0,0,.05);transition:transform .4s ease,box-shadow .4s ease;display:flex;flex-direction:column}
.room-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.1)}
.room-card-img{position:relative;height:240px;overflow:hidden}
.room-slider{display:flex;height:100%;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}
.room-slider img{min-width:100%;height:100%;object-fit:cover}
.room-card-badge{position:absolute;top:1rem;left:1rem;background:var(--white);padding:.4rem 1rem;border-radius:100px;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--forest);z-index:3}
.room-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.8);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;transition:all .2s ease;opacity:0;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.room-card:hover .room-slider-btn{opacity:1}
.room-slider-btn:hover{background:var(--white);transform:translateY(-50%) scale(1.1)}
.room-slider-btn svg{width:16px;height:16px;stroke:var(--forest);fill:none;stroke-width:2}
.room-slider-btn.prev{left:.6rem}
.room-slider-btn.next{right:.6rem}
.room-slider-dots{position:absolute;bottom:.75rem;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:3}
.room-slider-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.45);border:none;cursor:pointer;padding:0;transition:all .3s}
.room-slider-dot.active{background:var(--white);transform:scale(1.25)}
.room-card-body{padding:1.75rem;flex:1;display:flex;flex-direction:column}
.room-card-body h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;color:var(--forest);margin-bottom:.75rem}
.room-card-body p{font-size:.86rem;color:var(--text-light);line-height:1.65;margin-bottom:1.25rem}
.room-amenities{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.room-amenity{display:flex;align-items:center;gap:.35rem;font-size:.73rem;color:var(--sage);background:var(--sand-light);padding:.35rem .8rem;border-radius:100px}
.room-amenity svg{width:13px;height:13px;stroke:var(--sage);fill:none;stroke-width:1.5}
.room-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;border-top:1px solid var(--sand-light);margin-top:auto}
.room-price{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--warm)}
.room-price span{font-family:'Outfit',sans-serif;font-size:.75rem;font-weight:300;color:var(--text-light)}
.btn-room{padding:.6rem 1.25rem;font-size:.8rem;background:var(--forest);color:var(--white);border:none;border-radius:100px;font-family:'Outfit',sans-serif;font-weight:500;cursor:pointer;text-decoration:none;transition:all .3s ease}
.btn-room:hover{background:var(--forest-deep);transform:translateY(-1px)}

.food{padding:7rem 0;background:var(--cream)}
.food-header{text-align:center;max-width:650px;margin:0 auto 4rem}
.food-header .section-label{justify-content:center}
.food-header .section-label::before{display:none}
.food-header p{font-size:1.05rem;color:var(--text-light);line-height:1.85;margin-top:1rem}
.food-rows{display:flex;flex-direction:column;gap:3rem}
.food-row{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:center}
.food-row.reverse{grid-template-columns:1.4fr 1fr}
.food-row.reverse .food-row-img{order:2}
.food-row-img{border-radius:16px;overflow:hidden;height:300px;box-shadow:0 12px 40px rgba(0,0,0,.08);position:relative}
.food-row-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.food-row:hover .food-row-img img{transform:scale(1.04)}
.food-row-img .food-row-badge{position:absolute;top:1rem;left:1rem;background:var(--white);padding:.35rem .9rem;border-radius:100px;font-size:.68rem;font-weight:600;letter-spacing:.06em;color:var(--warm);text-transform:uppercase}
.food-row-content{padding:.5rem 0}
.food-row-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);margin-bottom:.5rem}
.food-row-content h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--forest);margin-bottom:.75rem;line-height:1.25}
.food-row-content p{font-size:.92rem;color:var(--text-light);line-height:1.8;margin-bottom:.75rem}
.food-row-content .food-detail{font-size:.84rem;color:var(--text-light);line-height:1.7;padding-left:1rem;border-left:2px solid var(--warm-light);margin:.75rem 0}
.food-row-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;background:var(--sand-light);border-radius:100px;font-size:.72rem;font-weight:500;color:var(--sage);margin-top:.25rem}
.food-row-tag svg{width:14px;height:14px;stroke:var(--sage);fill:none;stroke-width:1.5}
.food-divider{width:60px;height:2px;background:var(--sand);margin:0 auto}
.experience{padding:7rem 0;background:var(--sand-light);position:relative}
.experience::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(to bottom,var(--cream),var(--sand-light))}
.experience .container{position:relative;z-index:1}
.exp-header{text-align:center;max-width:680px;margin:0 auto 4rem}
.exp-header .section-label{justify-content:center}
.exp-header .section-label::before{display:none}
.exp-header p{font-size:1.05rem;color:var(--text-light);line-height:1.85;margin-top:1rem}
.exp-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.exp-sticky{position:sticky;top:100px}
.exp-sticky-img{border-radius:16px;overflow:hidden;height:480px;box-shadow:0 16px 50px rgba(0,0,0,.1);position:relative}
.exp-sticky-img img{width:100%;height:100%;object-fit:cover;transition:opacity .5s ease,transform .5s ease;position:absolute;inset:0;opacity:0}
.exp-sticky-img img.active{opacity:1}
.exp-sticky-counter{position:absolute;bottom:1rem;left:1rem;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);color:var(--white);font-size:.7rem;font-weight:500;padding:.35rem .85rem;border-radius:100px;z-index:2;letter-spacing:.04em}
.exp-sticky-dots{display:flex;gap:.5rem;margin-top:1rem;justify-content:center}
.exp-sticky-dot{width:10px;height:10px;border-radius:50%;background:var(--sand);border:none;cursor:pointer;transition:all .3s;padding:0}
.exp-sticky-dot.active{background:var(--warm);transform:scale(1.2)}
.exp-list{display:flex;flex-direction:column;gap:0}
.exp-item{padding:2rem 0;border-bottom:1px solid var(--sand);transition:all .3s}
.exp-item:first-child{padding-top:0}
.exp-item:last-child{border-bottom:none}
.exp-item.active{background:transparent}
.exp-item-head{display:flex;align-items:center;gap:1rem;margin-bottom:0;cursor:pointer;transition:margin .3s;position:relative}
.exp-item-head::after{content:'';width:10px;height:10px;border-right:2px solid var(--sage);border-bottom:2px solid var(--sage);transform:rotate(45deg);transition:transform .3s;margin-left:auto;flex-shrink:0}
.exp-item.active .exp-item-head::after{transform:rotate(-135deg)}
.exp-item.active .exp-item-head{margin-bottom:.75rem}
.exp-item-icon{width:48px;height:48px;background:var(--sand);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.exp-item.active .exp-item-icon{background:var(--warm);box-shadow:0 4px 15px rgba(196,152,106,.3)}
.exp-item-icon svg{width:22px;height:22px;stroke:var(--warm);fill:none;stroke-width:1.5;transition:stroke .3s}
.exp-item.active .exp-item-icon svg{stroke:var(--white)}
.exp-item-head h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;color:var(--forest);line-height:1.25}
.exp-item-head h3 small{display:block;font-family:'Outfit',sans-serif;font-size:.7rem;font-weight:500;color:var(--warm);letter-spacing:.08em;text-transform:uppercase;margin-top:.2rem}
.exp-item-body{padding-left:calc(48px + 1rem);max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.25,.46,.45,.94),opacity .4s ease;opacity:0}
.exp-item.active .exp-item-body{max-height:600px;opacity:1}
.exp-item-body p{font-size:.9rem;color:var(--text-light);line-height:1.8;margin-bottom:.6rem}
.exp-item-body .exp-detail{font-size:.84rem;color:var(--text-light);line-height:1.7;padding-left:1rem;border-left:2px solid var(--warm-light);margin:.6rem 0}
.exp-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;background:var(--white);border-radius:100px;font-size:.7rem;font-weight:500;color:var(--sage);margin-top:.25rem;margin-right:.35rem}
.exp-tag svg{width:13px;height:13px;stroke:var(--sage);fill:none;stroke-width:1.5}

.services{padding:7rem 0;background:var(--cream)}
.services-header{text-align:center;max-width:650px;margin:0 auto 3.5rem}
.services-header .section-label{justify-content:center}
.services-header .section-label::before{display:none}
.services-header p{font-size:1.05rem;color:var(--text-light);line-height:1.85;margin-top:1rem}
.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:auto;gap:1.25rem}
.bento-card{background:var(--white);border-radius:16px;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,.04);transition:all .3s ease;border:1px solid transparent;position:relative;overflow:hidden}
.bento-card:hover{border-color:var(--warm-light);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.bento-card.span2{grid-column:span 2}
.bento-card.span3{grid-column:span 3}
.bento-card.featured{background:var(--forest);border-color:transparent}
.bento-card.featured:hover{border-color:rgba(196,152,106,.4)}
.bento-card.featured h3{color:var(--white)}
.bento-card.featured p{color:rgba(255,255,255,.65)}
.bento-card.featured .bento-icon{background:rgba(196,152,106,.15)}
.bento-card.featured .bento-icon svg{stroke:var(--warm-light)}
.bento-card.featured .bento-tag{background:rgba(255,255,255,.1);color:var(--warm-light)}
.bento-card.sand-bg{background:var(--sand-light)}
.bento-icon{width:48px;height:48px;background:var(--sand);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;flex-shrink:0}
.bento-icon svg{width:22px;height:22px;stroke:var(--warm);fill:none;stroke-width:1.5}
.bento-card h3{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:500;color:var(--forest);margin-bottom:.6rem;line-height:1.3}
.bento-card p{font-size:.85rem;color:var(--text-light);line-height:1.7;margin-bottom:.4rem}
.bento-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;background:var(--sand-light);border-radius:100px;font-size:.68rem;font-weight:500;color:var(--sage);margin-top:.5rem;margin-right:.3rem}
.bento-tag svg{width:12px;height:12px;stroke:var(--sage);fill:none;stroke-width:1.5}
.bento-card.featured .bento-tag svg{stroke:var(--warm-light)}
.bento-row-layout{display:flex;gap:1.5rem;align-items:flex-start}
.bento-row-layout .bento-icon{margin-bottom:0}

.pricing{padding:7rem 0;background:var(--forest);position:relative;overflow:hidden}
.pricing::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(196,152,106,.08) 0%,transparent 70%);border-radius:50%}
.pricing .container{position:relative;z-index:1}
.pricing .section-label{color:var(--warm-light)}
.pricing .section-label::before{background:var(--warm-light)}
.pricing .section-title{color:var(--white)}
.pricing .section-title em{color:var(--warm-light)}
.pricing-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:3rem}
.price-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem;backdrop-filter:blur(10px);transition:all .4s ease}
.price-card:hover{background:rgba(255,255,255,.08);border-color:rgba(196,152,106,.3);transform:translateY(-4px)}
.price-card h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;color:var(--white);margin-bottom:.5rem}
.price-card .subtitle{font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:2rem}
.price-rows{list-style:none}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.07)}
.price-row:last-child{border-bottom:none}
.price-row .nights{font-size:.9rem;color:rgba(255,255,255,.7)}
.price-row .amount{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;color:var(--warm-light)}
.price-row .amount span{font-family:'Outfit',sans-serif;font-size:.7rem;font-weight:300;color:rgba(255,255,255,.4)}
.price-note{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.7;text-align:center;max-width:700px;margin:0 auto}
.storno-details{max-width:520px;margin:1.5rem auto 0;text-align:center}
.storno-details summary{font-size:.82rem;color:rgba(255,255,255,.45);cursor:pointer;padding:.6rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:all .3s;list-style:none;display:inline-flex;align-items:center;gap:.4rem}
.storno-details summary::before{content:"▸";transition:transform .3s}
.storno-details[open] summary::before{transform:rotate(90deg)}
.storno-details summary:hover{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.2)}
.storno-details summary::-webkit-details-marker{display:none}
.storno-content{margin-top:1rem;background:rgba(255,255,255,.05);border-radius:12px;padding:1.25rem 1.5rem;border:1px solid rgba(255,255,255,.08)}
.storno-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.storno-row:last-of-type{border-bottom:none}
.storno-days{font-size:.82rem;color:rgba(255,255,255,.6);font-weight:500;min-width:140px;text-align:left}
.storno-label{font-size:.75rem;color:rgba(255,255,255,.3);flex:1;text-align:center}
.storno-pct{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--warm-light);min-width:50px;text-align:right}
.storno-note{font-size:.72rem;color:rgba(255,255,255,.3);margin-top:.75rem;text-align:center}
.direct-booking-badge{display:flex;align-items:center;gap:1.25rem;background:linear-gradient(135deg,rgba(196,152,106,.15),rgba(196,152,106,.08));border:1px solid rgba(196,152,106,.25);border-radius:16px;padding:1.5rem 2rem;margin:0 auto 3rem;max-width:750px;flex-wrap:wrap}
.direct-booking-icon{width:44px;height:44px;background:rgba(196,152,106,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--warm-light)}
.direct-booking-text{flex:1;min-width:200px}
.direct-booking-text strong{display:block;font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:500;color:var(--white);margin-bottom:.25rem}
.direct-booking-text span{font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.5}
.direct-booking-cta{flex-shrink:0;padding:.7rem 1.5rem;background:var(--warm);color:var(--white);border-radius:100px;font-size:.82rem;font-weight:500;text-decoration:none;transition:all .3s ease;white-space:nowrap}
.direct-booking-cta:hover{background:var(--warm-dark);transform:translateY(-2px);box-shadow:0 8px 20px rgba(196,152,106,.3)}

.reviews{padding:7rem 0;background:var(--sand-light);overflow:hidden}
.trust-bar{display:flex;align-items:center;justify-content:center;gap:2.5rem;margin-bottom:3rem;flex-wrap:wrap}
.trust-award-img{height:80px;width:auto;object-fit:contain}
.trust-divider{width:1px;height:50px;background:var(--sand)}
.trust-scores{display:flex;gap:2rem;align-items:center}
.trust-score-item{text-align:center}
.trust-score-value{display:block;font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;color:var(--forest);line-height:1}
.trust-score-label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light)}
.reviews-slider{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.review-card{background:var(--white);border-radius:16px;padding:2.5rem;box-shadow:0 4px 20px rgba(0,0,0,.04);position:relative;transition:transform .3s ease}
.review-card:hover{transform:translateY(-4px)}
.review-stars{display:flex;gap:3px;margin-bottom:1.5rem}
.review-stars svg{width:16px;height:16px;fill:var(--warm)}
.review-card blockquote{font-size:1rem;color:var(--text-light);line-height:1.75;margin-bottom:1.5rem;font-style:italic}
.review-author{font-size:.85rem;font-weight:500;color:var(--forest)}
.review-author span{display:block;font-weight:300;color:var(--text-light);font-size:.78rem;margin-top:.2rem}
.review-quote-mark{position:absolute;top:1.5rem;right:2rem;font-family:'Cormorant Garamond',serif;font-size:5rem;color:var(--sand);line-height:1}

.region{padding:7rem 0;background:var(--cream)}
.region-header{text-align:center;max-width:700px;margin:0 auto 3rem}
.region-header .section-label{justify-content:center}
.region-header .section-label::before{display:none}
.region-header p{font-size:1.05rem;color:var(--text-light);line-height:1.75;margin-top:1rem}
.region-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}
.region-tab{padding:.6rem 1.25rem;border:1px solid var(--sand);border-radius:100px;background:var(--white);font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:500;color:var(--text-light);cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:.4rem}
.region-tab svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}
.region-tab:hover{border-color:var(--warm-light);color:var(--forest)}
.region-tab.active{background:var(--forest);color:var(--white);border-color:var(--forest)}
.region-tab .tab-count{font-size:.6rem;background:rgba(0,0,0,.1);padding:.1rem .4rem;border-radius:100px;margin-left:.15rem}
.region-tab.active .tab-count{background:rgba(255,255,255,.2)}
.region-panel{display:none}
.region-panel.active{display:block}
.region-entries{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.region-entry{background:var(--white);border-radius:14px;padding:1.5rem;border:1px solid var(--sand-light);transition:all .3s;display:flex;gap:1.25rem;align-items:flex-start}
.region-entry:hover{border-color:var(--warm-light);box-shadow:0 8px 30px rgba(0,0,0,.05);transform:translateY(-2px)}
.region-entry-icon{width:42px;height:42px;background:var(--sand);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.region-entry-icon svg{width:20px;height:20px;stroke:var(--warm);fill:none;stroke-width:1.5}
.region-entry-body{flex:1;min-width:0}
.region-entry h4{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:500;color:var(--forest);margin-bottom:.15rem;line-height:1.3}
.region-entry .entry-location{font-size:.7rem;font-weight:500;color:var(--warm);letter-spacing:.04em;margin-bottom:.4rem}
.region-entry .entry-age{display:inline-block;font-size:.6rem;font-weight:600;color:var(--sage);background:var(--sand-light);padding:.15rem .5rem;border-radius:100px;margin-left:.4rem}
.region-entry p{font-size:.82rem;color:var(--text-light);line-height:1.65;margin:0}
.angebote{padding:7rem 0;background:var(--white)}
.angebote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.angebot-placeholder{border:2px dashed var(--sage-light);background:var(--sand-light)}
.angebot-highlight-placeholder{opacity:.5}
.angebot-placeholder-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;gap:1rem;padding:2rem 0}
.angebot-placeholder-content h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--sage);font-weight:500}
.angebot-placeholder-content p{font-size:.88rem;color:var(--text-light);line-height:1.6;max-width:220px}
.angebot-card{background:var(--sand-light);border-radius:16px;padding:2.5rem;position:relative;transition:transform .3s,box-shadow .3s}
.angebot-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08)}
.angebot-card-alt{background:var(--forest);color:var(--sand-light)}
.angebot-card-alt p{color:rgba(255,255,255,.85)}
.angebot-card-alt .angebot-detail{color:rgba(255,255,255,.65) !important}
.angebot-card-alt .angebot-icon svg{stroke:var(--warm-light)}
.angebot-card-alt h3{color:var(--white)}
.angebot-card-alt .angebot-subtitle{color:rgba(255,255,255,.8)}
.angebot-badge{position:absolute;top:1.5rem;right:1.5rem;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;padding:.35rem .9rem;border-radius:100px;background:var(--warm);color:var(--white);font-weight:500}
.angebot-icon{margin-bottom:1.5rem}
.angebot-icon svg{stroke:var(--forest)}
.angebot-card h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;color:var(--forest);margin-bottom:1rem;line-height:1.2}
.angebot-title-label{display:block;font-family:'Outfit',sans-serif;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-bottom:.25rem}
.angebot-card p{font-size:.95rem;line-height:1.7;color:var(--text);margin-bottom:.75rem}
.angebot-detail{font-size:.85rem !important;color:var(--text-light) !important;font-style:italic}
.angebot-cta{display:inline-block;margin-top:1rem;font-size:.88rem;font-weight:500;color:var(--warm);text-decoration:none;transition:gap .3s}
.angebot-list{list-style:none;padding:0;margin:.75rem 0 0}
.angebot-list li{display:flex;align-items:center;gap:.6rem;font-size:.95rem;padding:.45rem 0;color:var(--text)}
.angebot-list li svg{flex-shrink:0;stroke:var(--sage)}
.angebot-subtitle{font-size:1rem;color:var(--text-light);line-height:1.6;margin-bottom:1.5rem}
.angebot-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.angebot-highlight-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding:1rem .5rem;background:var(--white);border-radius:12px;font-size:.82rem;line-height:1.4;color:var(--text)}
.angebot-card-alt .angebot-highlight-item{background:rgba(255,255,255,.1)}
.highlight-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--sand);border-radius:50%}
.highlight-icon svg{stroke:var(--warm)}
.angebot-card-alt .highlight-icon{background:rgba(255,255,255,.1)}
.angebot-card-alt .highlight-icon svg{stroke:var(--warm-light)}
.angebot-preis-box{display:flex;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;background:var(--white);border-radius:12px;margin-bottom:1rem;flex-wrap:wrap;justify-content:center}
.angebot-preis-left,.angebot-preis-right{display:flex;flex-direction:column;align-items:center}
.angebot-preis-arrow svg{stroke:var(--text-light)}
.preis-strike{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--text-light);text-decoration:line-through;text-decoration-color:var(--warm);text-decoration-thickness:2px;line-height:1.2}
.preis-value{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:var(--forest);line-height:1.1}
.preis-label{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light);margin-bottom:.15rem}
.angebot-ersparnis{font-size:.78rem;font-weight:600;color:var(--white);background:var(--warm);padding:.35rem .9rem;border-radius:100px}
@media(max-width:600px){.angebot-highlights{grid-template-columns:1fr}}
.angebot-card-alt .angebot-cta{color:var(--warm-light)}
.angebot-cta:hover{text-decoration:underline}
@media(max-width:1024px){.angebote-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.angebote-grid{grid-template-columns:1fr}}
.contact{padding:7rem 0;background:var(--sand-light)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem}
.contact-form-wrap{background:var(--white);border-radius:20px;padding:3rem;box-shadow:0 8px 40px rgba(0,0,0,.06)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text);letter-spacing:.03em;margin-bottom:.5rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.85rem 1.15rem;border:1px solid var(--sand);border-radius:10px;font-family:'Outfit',sans-serif;font-size:.9rem;color:var(--text);background:var(--sand-light);transition:all .3s ease;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--warm);background:var(--white);box-shadow:0 0 0 3px rgba(196,152,106,.1)}
.form-group textarea{height:120px;resize:vertical}
.form-submit{width:100%;padding:1rem;background:var(--warm);color:var(--white);border:none;border-radius:12px;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:all .3s ease;margin-top:.5rem}
.form-submit:hover{background:var(--warm-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(196,152,106,.3)}
.contact-info h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--forest);margin-bottom:1.5rem;margin-top:2rem}
.contact-info h3:first-of-type{margin-top:0}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.25rem}
.contact-detail-icon{flex-shrink:0;width:42px;height:42px;background:var(--sand);border-radius:12px;display:flex;align-items:center;justify-content:center}
.contact-detail-icon svg{width:18px;height:18px;stroke:var(--warm);fill:none;stroke-width:1.5}
.contact-detail-text p{font-size:.9rem;color:var(--text-light);line-height:1.6}
.contact-detail-text strong{color:var(--text);font-weight:500}
.contact-detail-text a{color:var(--warm);text-decoration:none}
.contact-detail-text a:hover{text-decoration:underline}
.season-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--sand);border-radius:100px;font-size:.82rem;color:var(--forest);font-weight:500;margin-top:1.5rem}
.season-badge svg{width:16px;height:16px;stroke:var(--warm);fill:none;stroke-width:1.5}

.map-section{height:400px;background:var(--sand)}
.map-section iframe{width:100%;height:100%;border:none;filter:saturate(.7) contrast(1.05)}

.footer{background:var(--forest-deep);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-grid-3{grid-template-columns:2fr 1fr 1fr}
.footer-brand p{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.7;max-width:360px}
.footer-bestpreis{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;padding:.4rem .9rem;background:rgba(196,152,106,.12);border:1px solid rgba(196,152,106,.25);border-radius:100px;font-size:.75rem;font-weight:500;color:var(--warm-light)}
.footer-logo-box{background:var(--white);border-radius:12px;padding:1rem 1.5rem;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.footer-logo-box img{height:120px;width:auto;display:block}
.footer h4{font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warm-light);margin-bottom:1.25rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.75rem}
.footer a{color:rgba(255,255,255,.5);text-decoration:none;transition:color .3s}
.footer a:hover{color:var(--white)}
.footer-links a{font-size:.88rem}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin-bottom:.75rem;font-size:.88rem;color:rgba(255,255,255,.5)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.35);text-decoration:none}
.footer-bottom a:hover{color:rgba(255,255,255,.6)}

@media(max-width:1024px){
.ribbon-grid{grid-template-columns:repeat(5,1fr)}
.rooms-grid{grid-template-columns:repeat(2,1fr)}
.about-grid,.contact-grid{grid-template-columns:1fr;gap:3rem}
.usp-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}
.food-row,.food-row.reverse{grid-template-columns:1fr}
.food-row.reverse .food-row-img{order:0}
.pricing-cards{grid-template-columns:1fr}
.exp-layout{grid-template-columns:1fr}
.exp-sticky{position:relative;top:0}
.exp-sticky-img{height:300px}
.bento-grid{grid-template-columns:repeat(2,1fr)}
.bento-card.span3{grid-column:span 2}
.region-grid{grid-template-columns:repeat(2,1fr)}
.footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
.nav-links{display:none}
.menu-toggle{display:flex}
.nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--white);padding:2rem;gap:1.5rem;box-shadow:0 20px 40px rgba(0,0,0,.1)}
.nav-links.open a{color:var(--text)!important}
.nav-logo-box{padding:.75rem 1.5rem 1.6rem}
.nav-logo-box img{height:80px}
.hero h1{font-size:2.4rem}
.ribbon-grid{grid-template-columns:repeat(3,1fr);gap:1rem}
.rooms-grid,.reviews-slider{grid-template-columns:1fr}
.region-entries{grid-template-columns:1fr}
.bento-grid{grid-template-columns:1fr}
.bento-card.span2,.bento-card.span3{grid-column:span 1}
.exp-row-img{height:250px}
.exp-sticky-img{height:250px}
.form-row{grid-template-columns:1fr}
.about-gallery-slide{height:300px}
.about-gallery-thumbs{grid-template-columns:repeat(5,1fr)}
.about-gallery-thumb{height:50px}
.usp-grid{grid-template-columns:1fr;gap:1.25rem}
.usp-card{padding:2rem 1.5rem}
.footer-grid{grid-template-columns:1fr}
.footer-bottom{flex-direction:column;gap:1rem;text-align:center}
}
@media(max-width:480px){
.ribbon-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
.hero-actions{flex-direction:column;align-items:flex-start}
.hero-content{padding:0 2rem 8vh !important}
}
