:root{
  --petrol:#234B47;--petrol-deep:#15302C;--petrol-mid:#2C5A55;
  --gold:#B0894C;--gold-lt:#CBA869;--cream:#F5EFE1;--paper:#FBF8F1;
  --olive:#474C42;--stone:#7A7163;--ink:#262219;
  --hair:rgba(38,34,25,.14);--hair-lt:rgba(245,239,225,.20);
  --shadow:0 24px 60px -20px rgba(21,48,44,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hanken Grotesk",sans-serif;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.6}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.display{font-family:"Cormorant Garamond",serif;font-weight:500;line-height:1.0;letter-spacing:-.01em}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:"Hanken Grotesk",sans-serif;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:16px 30px;border:none;cursor:pointer;transition:.25s}
.btn-gold{background:var(--gold);color:var(--paper)}
.btn-gold:hover{background:#9c7740}
.btn-outline{background:transparent;border:1px solid currentColor;color:inherit}
.btn-outline:hover{background:rgba(176,137,76,.12)}
.link-u{font-size:13px;font-weight:600;color:var(--gold);border-bottom:1px solid currentColor;padding-bottom:3px}
.wrap{max-width:1320px;margin:0 auto;padding:0 48px}
.section{padding:104px 0}
/* util + header */
.util{background:var(--petrol-deep);color:var(--cream)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;font-size:12.5px}
.util .right{display:flex;gap:22px;align-items:center;color:rgba(245,239,225,.82)}
.util .right a:hover{color:var(--gold-lt)}
.util .lang b{color:var(--gold-lt)}
@media(max-width:980px){.util .wrap>span:first-child{display:none}.util .wrap{justify-content:flex-end}.util .right{gap:0}.util .right>a{display:none}.util .lang{display:inline-flex}}
.header{position:sticky;top:0;z-index:40;background:var(--paper);box-shadow:0 1px 0 var(--hair)}
.header .wrap{display:flex;justify-content:space-between;align-items:center;height:84px}
.brand{display:flex;align-items:center;gap:15px;flex-shrink:0}
.brand img{height:42px}
.brand>span{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;white-space:nowrap}
.brand>span br{display:none}
.brand .nm{font-family:"Cormorant Garamond",serif;font-size:20px;font-weight:600;letter-spacing:.06em;color:var(--olive);line-height:1}
.brand .sb{font-size:9px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--stone);margin-top:3px}
nav.main{display:flex;gap:30px}
nav.main a{font-size:13.5px;font-weight:500;color:var(--ink);opacity:.82}
nav.main a:hover{opacity:1;color:var(--gold)}
nav.main .navitem{position:relative;display:flex;align-items:center}
nav.main .navitem::after{content:"";position:absolute;top:100%;left:-12px;right:-12px;height:16px}
nav.main .navitem .caret{font-size:8px;margin-left:5px;opacity:.7}
nav.main .dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);background:var(--paper);box-shadow:0 16px 44px rgba(21,48,44,.22);padding:8px;min-width:210px;opacity:0;visibility:hidden;transition:opacity .18s,transform .18s;border-top:2px solid var(--gold);z-index:60}
nav.main .navitem:hover .dropdown,nav.main .navitem:focus-within .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(12px)}
nav.main .dropdown a{display:block;padding:11px 16px;font-size:14px;font-weight:500;color:var(--ink);opacity:1;white-space:nowrap}
nav.main .dropdown a:hover{background:var(--cream);color:var(--gold)}
nav.main .dropdown a .d-sub{display:block;font-size:11px;font-weight:500;color:var(--stone);letter-spacing:.03em;margin-top:2px}
.header .cta{display:flex;gap:14px;align-items:center}
/* hero */
.dhero{position:relative;height:64vh;min-height:520px;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.dhero .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03)}
.dhero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,48,44,.30) 0%,rgba(21,48,44,.05) 38%,rgba(21,48,44,.78) 100%)}
.dhero .inner{position:relative;z-index:2;width:100%;padding-bottom:54px}
.crumb{font-size:12px;font-weight:600;letter-spacing:.04em;color:rgba(245,239,225,.78);margin-bottom:18px}
.crumb a:hover{color:var(--gold-lt)}
.dhero h1{font-size:clamp(54px,8vw,108px);line-height:.92;margin-bottom:14px}
.dhero .meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-family:"Cormorant Garamond",serif;font-style:italic;font-size:clamp(18px,2vw,24px);color:rgba(245,239,225,.92)}
.dhero .meta .dot{width:5px;height:5px;border-radius:50%;background:var(--gold-lt)}
/* facts */
.facts{background:var(--petrol);color:var(--cream)}
.facts .wrap{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--hair-lt)}
.fact{background:var(--petrol);padding:30px 26px;text-align:center}
.fact .v{font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:600;color:var(--gold-lt);line-height:1}
.fact .l{font-size:11px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:rgba(245,239,225,.72);margin-top:8px}
/* desc + amenities */
.desc-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:start}
.desc-grid h2{font-size:clamp(32px,3.8vw,50px);color:var(--ink);margin-bottom:26px}
.desc-grid h2 em{color:var(--gold);font-style:italic}
.desc-grid p{font-size:16.5px;color:var(--stone);margin-bottom:20px;max-width:54ch}
.desc-grid p.first{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:22px;line-height:1.5;color:var(--petrol)}
.amen{background:var(--cream);padding:38px 36px}
.amen h3{font-family:"Cormorant Garamond",serif;font-size:24px;font-weight:600;margin-bottom:22px;color:var(--ink)}
.amen ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.amen li{font-size:14.5px;color:var(--ink);padding-left:26px;position:relative;line-height:1.45}
.amen li svg{position:absolute;left:0;top:3px;color:var(--gold)}
/* gallery */
.gallery{background:var(--cream)}
.gallery .head{margin-bottom:46px}
.gallery .head h2{font-size:clamp(30px,3.6vw,48px);color:var(--ink);margin-top:10px}
.galgrid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:12px}
.gcell{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--petrol-mid),var(--petrol-deep))}
.gcell img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gcell:hover img{transform:scale(1.05)}
.gcell .lab{position:absolute;left:15px;bottom:13px;font-size:10.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:rgba(245,239,225,.85);text-shadow:0 1px 8px rgba(21,48,44,.6)}
.gcell.tall{grid-row:span 2}.gcell.wide{grid-column:span 2}
/* grundriss */
.grundriss{background:var(--paper)}
.gr-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:60px;align-items:center}
.gr-text h2{font-size:clamp(30px,3.4vw,46px);color:var(--ink);margin:12px 0 22px}
.gr-text h2 em{color:var(--gold);font-style:italic}
.gr-text p{font-size:16px;color:var(--stone);margin-bottom:24px;max-width:44ch}
.gr-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.gr-list li{font-size:15px;color:var(--ink);padding-left:22px;position:relative}
.gr-list li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;background:var(--gold)}
.gr-list b{font-family:"Cormorant Garamond",serif;font-size:18px;font-weight:600;color:var(--petrol)}
.gr-plan{margin:0;background:var(--cream);padding:20px;box-shadow:var(--shadow)}
.gr-plan figcaption{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-top:13px;text-align:center}
/* booking */
.cta-book{position:relative;background:var(--petrol);color:var(--cream);overflow:hidden}
.cta-book .grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.cta-book h2{font-size:clamp(32px,4vw,52px);margin-bottom:22px}
.cta-book h2 em{color:var(--gold-lt);font-style:italic}
.cta-book p{font-size:16.5px;color:rgba(245,239,225,.8);max-width:42ch;margin-bottom:30px}
.checks{display:flex;flex-direction:column;gap:13px}
.checks div{display:flex;align-items:center;gap:13px;font-size:14.5px;color:rgba(245,239,225,.9)}
.checks svg{color:var(--gold-lt);flex-shrink:0}
.channels{border-top:1px solid var(--hair-lt);padding-top:22px;margin-top:26px}
.channels .lab{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:11px}
.channels .logos{display:flex;flex-wrap:wrap;gap:10px}
.channels .logos span,.channels .logos a{font-size:13px;font-weight:600;color:rgba(245,239,225,.92);border:1px solid var(--hair-lt);padding:8px 14px;transition:.2s}
.channels .logos a:hover{border-color:var(--gold-lt);color:var(--gold-lt)}
/* Ausstattung im Detail */
.amenities-full{background:var(--paper)}
.amenities-full .ah{margin-bottom:44px;max-width:60ch}
.amenities-full .ah p{font-size:16px;color:var(--stone);margin-top:14px;line-height:1.65}
.amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 48px}
.amen-cat h4{display:flex;align-items:center;gap:11px;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;padding-bottom:13px;border-bottom:1px solid var(--hair)}
.amen-cat h4 svg{width:19px;height:19px;color:var(--gold);flex-shrink:0}
.amen-cat ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.amen-cat li{position:relative;padding-left:19px;font-size:14.5px;color:var(--ink);line-height:1.45}
.amen-cat li::before{content:"";position:absolute;left:1px;top:8px;width:5px;height:5px;border-radius:50%;background:var(--gold-lt)}
@media(max-width:900px){.amen-grid{grid-template-columns:repeat(2,1fr);gap:34px 36px}}
@media(max-width:560px){.amen-grid{grid-template-columns:1fr;gap:30px}}
.smoobu{background:var(--paper);color:var(--ink);box-shadow:var(--shadow)}
.smoobu .sh{padding:20px 26px;border-bottom:1px solid var(--hair);display:flex;justify-content:space-between;align-items:center}
.smoobu .sh .t{font-family:"Cormorant Garamond",serif;font-size:20px;font-weight:600}
.smoobu .sh .tag{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--stone)}
#apartmentIframe{min-height:520px}
.sb-ph{padding:24px 26px}
.sb-ph .row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.sb-ph .ip{border:1px solid var(--hair);padding:12px 14px}
.sb-ph .ip label{display:block;font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:5px}
.sb-ph .ip .v{font-family:"Cormorant Garamond",serif;font-size:17px}
.sb-ph .go{width:100%;background:var(--gold);color:var(--paper);border:none;padding:15px;font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;margin-top:6px}
.sb-ph .note{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);text-align:center;margin-top:13px}
/* related */
.related{background:var(--cream)}
.related .card{display:grid;grid-template-columns:1fr 1.2fr;background:var(--paper);box-shadow:0 18px 50px -28px rgba(21,48,44,.4);overflow:hidden;align-items:stretch}
.related .card img{width:100%;height:100%;object-fit:cover;min-height:300px}
.related .card .body{padding:48px 52px;display:flex;flex-direction:column;justify-content:center}
.related .card h3{font-family:"Cormorant Garamond",serif;font-size:44px;font-weight:600;color:var(--ink);margin-bottom:8px}
.related .card .sub{font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.related .card p{font-size:15.5px;color:var(--stone);margin-bottom:26px;max-width:42ch}
/* footer */
.footer{background:var(--petrol-deep);color:rgba(245,239,225,.72);padding:72px 0 30px}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:46px;padding-bottom:50px;border-bottom:1px solid var(--hair-lt)}
.footer .brand-f img{height:74px;margin-bottom:20px}
.footer .brand-f p{font-size:14px;line-height:1.8;max-width:30ch}
.footer .brand-f a:hover{color:var(--gold-lt)}
.footer h5{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:16px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px}
.footer a:hover{color:var(--cream)}
.footer .bottom{display:flex;justify-content:space-between;padding-top:26px;font-size:12px;color:rgba(245,239,225,.5)}
@media(max-width:980px){
  .wrap{padding:0 26px}.section{padding:72px 0}
  .facts .wrap{grid-template-columns:1fr 1fr 1fr}
  .desc-grid,.gr-grid,.cta-book .grid,.related .card{grid-template-columns:1fr;gap:34px}
  .galgrid{grid-template-columns:1fr 1fr}
  .galgrid .gcell.tall{grid-row:span 1}
  .galgrid .gcell.wide{grid-column:span 1}
  .related .card img{min-height:220px}
  .footer .top{grid-template-columns:1fr 1fr}
}

@media(max-width:560px){
  .wrap{padding:0 20px}
  .section{padding:56px 0}
  .dhero{height:auto;min-height:420px}
  .dhero .inner{padding-bottom:40px}
  .dhero h1{font-size:clamp(44px,13vw,62px)}
  .facts .wrap{grid-template-columns:1fr 1fr}
  .facts .fact:last-child{grid-column:1 / -1}
  .fact{padding:18px 10px}
  .fact .v{font-size:22px}
  .fact .l{font-size:9.5px;letter-spacing:.1em}
  .desc-grid h2{font-size:clamp(30px,8vw,38px)}
  .amen{padding:30px 22px}
  .related .card img{min-height:200px}
  .footer .top{grid-template-columns:1fr 1fr;gap:30px}
}

/* ── Mobile menu ── */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:30px;height:24px;background:none;border:none;padding:0;cursor:pointer;position:relative;z-index:110}
.burger span{display:block;width:100%;height:2px;background:var(--olive);border-radius:2px;transition:transform .3s,opacity .2s,background .3s}
.burger.is-open span{background:var(--cream)}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mnav{position:fixed;inset:0;z-index:100;background:var(--petrol-deep);color:var(--cream);display:flex;flex-direction:column;padding:120px 34px 44px;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(-12px);opacity:0;visibility:hidden;transition:transform .4s cubic-bezier(.45,0,.15,1),opacity .3s}
.mnav.open{transform:translateY(0);opacity:1;visibility:visible}
.mnav .mclose{position:absolute;top:20px;right:22px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--hair-lt);border-radius:50%;color:var(--cream);font-size:20px;line-height:1;cursor:pointer;transition:.2s;z-index:5}
.mnav .mclose:hover{color:var(--gold-lt);border-color:var(--gold-lt)}
body.menu-open{overflow:hidden}
.mnav .mlink{font-family:"Cormorant Garamond",serif;font-size:29px;font-weight:500;color:var(--cream);padding:14px 0;border-bottom:1px solid var(--hair-lt);display:flex;justify-content:space-between;align-items:baseline;gap:16px;transition:color .2s}
.mnav .mlink .ms{font-family:"Hanken Grotesk",sans-serif;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt);white-space:nowrap}
.mnav .mlink:hover,.mnav .mlink:active{color:var(--gold-lt)}
.mnav .mfoot{margin-top:auto;padding-top:30px;display:flex;flex-direction:column;gap:20px}
.mnav .mfoot .btn{justify-content:center}
.mnav .mmeta{font-size:12.5px;letter-spacing:.03em;color:rgba(245,239,225,.62);line-height:1.8}
.mnav .mmeta a{color:var(--gold-lt)}
@media(max-width:1200px){.burger{display:flex}nav.main{display:none}.header .cta .btn-gold{display:none}}
@media(max-height:480px){.mnav{padding:64px 34px 28px}.mnav .mclose{top:14px}.mnav .mlink{font-size:23px;padding:9px 0}.mnav .mfoot{padding-top:18px;gap:12px}}

/* ── Lightbox ── */
.gcell{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(15,29,26,.95);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:90vw;max-height:82vh;object-fit:contain;box-shadow:0 30px 90px -20px rgba(0,0,0,.7)}
.lightbox .lb-cap{position:absolute;bottom:30px;left:0;right:0;text-align:center;font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(245,239,225,.82)}
.lightbox .lb-close{position:absolute;top:24px;right:28px;width:46px;height:46px;border:1px solid rgba(245,239,225,.4);background:none;color:var(--cream);font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s}
.lightbox .lb-close:hover{background:rgba(245,239,225,.14)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:1px solid rgba(245,239,225,.4);background:rgba(15,29,26,.4);color:var(--cream);font-size:24px;line-height:1;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s}
.lightbox .lb-nav:hover{background:rgba(245,239,225,.16)}
.lightbox .lb-prev{left:28px}.lightbox .lb-next{right:28px}
@media(max-width:600px){.lightbox .lb-nav{width:42px;height:42px}.lightbox .lb-prev{left:10px}.lightbox .lb-next{right:10px}.lightbox img{max-width:94vw}}