@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;--off:#faf9f7;--ink:#0d0d0b;--ink2:#3a3a36;
  --muted:#8a8a82;--line:#e8e6e0;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--ink);font-size:16px;line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:var(--sans)}


/* ── LANG TOGGLE ── */
.lang-toggle{display:flex;gap:0;border:1px solid rgba(255,255,255,.3);overflow:hidden;margin-left:16px}
.nav.scrolled .lang-toggle{border-color:rgba(255,255,255,.3)}
.lang-btn{font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;background:none;border:none;color:rgba(255,255,255,.5);font-family:var(--sans);cursor:pointer;transition:all .2s}
.nav.scrolled .lang-btn{color:rgba(255,255,255,.5)}
.lang-btn.active{background:rgba(255,255,255,.15);color:var(--white)}
.nav.scrolled .lang-btn.active{background:rgba(255,255,255,.15);color:var(--white)}
[data-en]{} /* elements with translations */


/* ── EDIT MODE ── */
.edit-mode [contenteditable]{outline:1px dashed rgba(0,100,255,.3);cursor:text;min-width:20px;min-height:1em}
.edit-mode [contenteditable]:focus{outline:2px solid rgba(0,100,255,.6);background:rgba(0,100,255,.03)}
.edit-bar{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--white);display:flex;gap:0;z-index:9000;border-radius:4px;overflow:hidden;opacity:0;pointer-events:none;transition:opacity .3s;font-family:var(--sans)}
.edit-bar.show{opacity:1;pointer-events:all}
.edit-bar-btn{font-size:11px;letter-spacing:.06em;padding:10px 18px;background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;border-right:1px solid rgba(255,255,255,.1);transition:background .2s;font-family:var(--sans)}
.edit-bar-btn:hover{background:rgba(255,255,255,.1);color:var(--white)}
.edit-bar-btn.active{background:rgba(255,255,255,.15);color:var(--white)}
.edit-bar-btn:last-child{border-right:none}

/* Photo repositioning */
.photo-wrap{position:relative;overflow:hidden}
.photo-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:object-position .2s}
.photo-controls{position:absolute;inset:0;z-index:10;display:none;align-items:center;justify-content:center}
.edit-mode .photo-wrap:hover .photo-controls{display:flex}
.photo-ctrl-grid{display:grid;grid-template-columns:repeat(3,36px);gap:2px}
.photo-ctrl-btn{width:36px;height:36px;background:rgba(0,0,0,.6);border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);border-radius:2px}
.photo-ctrl-btn:hover{background:rgba(0,0,0,.85)}


.galerie-item{transition:transform .2s}
.galerie-item:hover{transform:scale(1.01)}
.galerie-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:16px}
.galerie-overlay span{color:var(--white);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-family:var(--sans)}
.galerie-item:hover .galerie-overlay{opacity:1}
.galerie-tab:hover{background:var(--line)!important;color:var(--ink)!important}


/* ── FULL FOOTER ── */
.footer-full{background:var(--ink)}
.footer-top{padding:72px 0 52px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-col{display:flex;flex-direction:column;gap:12px}
.footer-logo{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--white)}
.footer-logo span{font-weight:400}
.footer-tagline{font-size:16px;color:rgba(255,255,255,.4);line-height:1.75;font-weight:300;margin-top:4px}
.footer-col-title{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:4px}
.footer-link{font-size:15px;color:rgba(255,255,255,.5);text-decoration:none;cursor:pointer;transition:color .2s;background:none;border:none;font-family:var(--sans);text-align:left;padding:0}
.footer-link:hover{color:var(--white)}
.footer-cta{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.3);padding:12px 20px;background:none;color:rgba(255,255,255,.7);font-family:var(--sans);cursor:pointer;margin-top:8px;transition:all .2s;text-align:left}
.footer-cta:hover{background:var(--white);color:var(--ink)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0}
.footer-copy{font-size:11px;color:rgba(255,255,255,.22)}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:15px;color:var(--ink);cursor:pointer;font-weight:400;font-family:var(--sans)}
.faq-q:hover{color:var(--ink2)}
.faq-icon{font-size:20px;color:var(--muted);transition:transform .3s;flex-shrink:0;margin-left:20px}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{font-size:14px;color:var(--muted);line-height:1.85;font-weight:300;max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:200px;padding-bottom:22px}

@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr}}


/* ── LIGHTBOX MODAL ── */
.lb{display:none;position:fixed;inset:0;background:rgba(8,8,6,.96);z-index:8000;overflow-y:auto}
.lb.open{display:block}
.lb-header{position:sticky;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:20px 40px;z-index:10;background:rgba(8,8,6,.9);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.07)}
.lb-title{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--white);letter-spacing:-.01em}
.lb-subtitle{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:3px}
.lb-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:26px;cursor:pointer;transition:color .2s;line-height:1;padding:4px}
.lb-close:hover{color:var(--white)}
.lb-body{padding:3px;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:3px;max-width:1400px;margin:0 auto;grid-auto-flow:dense}
.lb-item{position:relative;overflow:hidden;cursor:pointer;background:#111}
.lb-item.r169{grid-column:span 2;grid-row:span 1}
.lb-item.r916{grid-column:span 1;grid-row:span 2}
.lb-item.r43{grid-column:span 1;grid-row:span 1}
.lb-item.r34{grid-column:span 1;grid-row:span 2}
.lb-item img,.lb-item video,.lb-item iframe{width:100%;height:100%;object-fit:cover;display:block}
.lb-item-ph{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;background:linear-gradient(135deg,#1e1e18,#141410);width:100%;height:100%}
.lb-item-label{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;background:linear-gradient(to top,rgba(0,0,0,.75),transparent);opacity:0;transition:opacity .3s}
.lb-item:hover .lb-item-label{opacity:1}
.lb-item-cat{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);font-family:var(--sans)}
.lb-item-name{font-family:var(--serif);font-size:15px;font-weight:300;color:var(--white);margin-top:2px}
.lb-item-ph-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18);font-family:var(--sans)}
.lb-item-ph-icon{font-size:28px;color:rgba(255,255,255,.08)}
.lb-item-ph-type{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.12);font-family:var(--sans);margin-top:4px}
@media(max-width:900px){.lb-body{grid-template-columns:repeat(2,1fr)}.lb-item.r169{grid-column:span 2}}
@media(max-width:560px){.lb-body{grid-template-columns:1fr;grid-auto-rows:180px}.lb-item.r169,.lb-item.r916,.lb-item.r34{grid-column:span 1;grid-row:span 1}.lb-header{padding:16px 20px}}




/* ── FAQ SECTION ── */
.faq-sec{padding:120px 0;background:var(--off)}
.faq-sec.dark{background:var(--ink)}
.faq-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:64px}
.faq-intro{font-size:14px;color:var(--muted);line-height:1.85;font-weight:300;max-width:400px}
.faq-sec.dark .faq-intro{color:rgba(255,255,255,.4)}
.faq-sec.dark .sec-label{color:rgba(255,255,255,.3)}
.faq-sec.dark .sec-h{color:var(--white)}
.faq-sec.dark .sec-h em{color:rgba(255,255,255,.35)}
.faq-list{border-top:1px solid var(--line)}
.faq-sec.dark .faq-list{border-color:rgba(255,255,255,.1)}
.faq-item{border-bottom:1px solid var(--line);overflow:hidden}
.faq-sec.dark .faq-item{border-color:rgba(255,255,255,.08)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:24px 0;font-size:16px;color:var(--ink);cursor:pointer;font-weight:400;font-family:var(--sans);background:none;border:none;width:100%;text-align:left;gap:24px;transition:color .2s}
.faq-sec.dark .faq-q{color:rgba(255,255,255,.75)}
.faq-q:hover{color:var(--ink2)}
.faq-sec.dark .faq-q:hover{color:var(--white)}
.faq-icon{font-size:22px;color:var(--muted);transition:transform .35s cubic-bezier(.16,1,.3,1);flex-shrink:0;line-height:1;font-weight:300}
.faq-sec.dark .faq-icon{color:rgba(255,255,255,.3)}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--ink)}
.faq-sec.dark .faq-item.open .faq-icon{color:var(--white)}
.faq-a{font-size:14px;color:var(--muted);line-height:1.9;font-weight:300;max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.16,1,.3,1),padding .3s}
.faq-sec.dark .faq-a{color:rgba(255,255,255,.4)}
.faq-item.open .faq-a{max-height:600px;padding-bottom:28px}
.faq-a-inner{padding-right:48px}

/* ── TEXT EDITOR ── */
.edit-mode .editable-text{position:relative;cursor:text}
.edit-mode .editable-text:hover::before{content:'';position:absolute;inset:-4px;border:1px dashed rgba(0,100,255,.3);pointer-events:none;z-index:100}
.edit-mode .editable-text:hover .text-editor{display:flex}
.text-editor{display:none;position:absolute;top:-48px;left:0;z-index:300;background:rgba(13,13,11,.92);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);padding:6px 10px;gap:6px;align-items:center;font-family:var(--sans);white-space:nowrap;border-radius:2px}
.text-editor::after{content:'';position:absolute;bottom:-5px;left:16px;width:8px;height:8px;background:rgba(13,13,11,.92);border-right:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);transform:rotate(45deg)}
.te-group{display:flex;gap:2px;align-items:center}
.te-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-right:2px}
.te-btn{width:22px;height:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;border-radius:1px;font-family:var(--sans)}
.te-btn:hover{background:rgba(255,255,255,.2);color:#fff}
.te-val{font-size:10px;color:rgba(255,255,255,.4);min-width:32px;text-align:center}
.te-divider{width:1px;height:20px;background:rgba(255,255,255,.1)}
.te-btn-arrow{font-size:10px}

/* ── SECTION PADDING EDITOR ── */
.sec-editor{display:none;position:absolute;top:8px;right:8px;z-index:2000;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border:1px solid var(--line);padding:8px 12px;gap:8px;align-items:center;font-family:var(--sans);box-shadow:0 4px 20px rgba(0,0,0,.15);pointer-events:all}
.edit-mode .editable-sec{position:relative}
.edit-mode .editable-sec:hover>.sec-editor{display:flex}
.sec-editor-label{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.sec-editor-group{display:flex;flex-direction:column;gap:3px;align-items:center}
.sec-editor-btns{display:flex;gap:2px}
.sec-editor-btn{width:24px;height:24px;background:var(--off);border:1px solid var(--line);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink2);transition:background .15s;font-family:var(--sans)}
.sec-editor-btn:hover{background:var(--ink);color:var(--white)}
.sec-editor-val{font-size:10px;color:var(--muted);text-align:center;min-width:28px}
.sec-editor-divider{width:1px;height:32px;background:var(--line)}

/* ── PAGE SYSTEM ── */
.page{display:none}
.page.active{display:block}


/* ── LOGO SVG ── */
.jf-logo{display:block;transition:opacity .3s}
.nav-logo-wrap{cursor:pointer;display:flex;align-items:center}
.nav-logo-wrap .jf-logo-dark{display:block}
.nav-logo-wrap .jf-logo-light{display:none}
.nav.scrolled .nav-logo-wrap .jf-logo-dark{display:block}
.nav.scrolled .nav-logo-wrap .jf-logo-light{display:none}
.nav.light .nav-logo-wrap .jf-logo-dark{display:block}
.nav.light .nav-logo-wrap .jf-logo-light{display:none}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:500;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 48px;transition:background .4s;background:rgba(10,10,8,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06)}
/* Nav immer dunkel — auch beim Scrollen */
.nav.scrolled{background:rgba(10,10,8,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav.light{background:rgba(10,10,8,.88) !important;border-bottom:1px solid rgba(255,255,255,.06) !important}
.nav-logo{font-family:var(--serif);font-size:22px;font-weight:300;letter-spacing:.04em;color:var(--white);transition:color .4s;cursor:pointer}
.nav.scrolled .nav-logo,.nav.light .nav-logo{color:var(--white)}
.nav-logo span{font-weight:400}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:400;transition:color .2s;cursor:pointer}
.nav.scrolled .nav-links a,.nav.light .nav-links a{color:rgba(255,255,255,.75)}
.nav-links a:hover,.nav.scrolled .nav-links a:hover,.nav.light .nav-links a:hover{color:#ffffff}
.nav-links a.active{color:var(--white)}
.nav.scrolled .nav-links a.active,.nav.light .nav-links a.active{color:var(--white);font-weight:500}
.nav-slash{color:rgba(255,255,255,.18);font-size:10px}
.nav.scrolled .nav-slash,.nav.light .nav-slash{color:rgba(255,255,255,.18)}
.nav-cta{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.45);padding:10px 22px;background:none;color:rgba(255,255,255,.75);font-family:var(--sans);transition:all .2s}
.nav.scrolled .nav-cta,.nav.light .nav-cta{border-color:rgba(255,255,255,.45);color:rgba(255,255,255,.75)}
.nav-cta:hover{background:var(--white);color:var(--ink)}
.nav.scrolled .nav-cta:hover,.nav.light .nav-cta:hover{background:var(--white);color:var(--ink)}

/* ── SHARED ── */
.w{max-width:1280px;margin:0 auto;padding:0 48px}
.sec{padding:120px 0}
.sec-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.sec-h{font-family:var(--serif);font-size:clamp(36px,4.5vw,68px);font-weight:300;line-height:1.02;letter-spacing:-.015em}
.sec-h em{font-style:italic;color:var(--muted)}
.btn-primary{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--ink);padding:13px 30px;background:none;color:var(--ink);font-family:var(--sans);transition:all .2s;display:inline-block;cursor:pointer}
.btn-primary:hover{background:var(--ink);color:var(--white)}
.btn-ghost{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:none;border:none;font-family:var(--sans);transition:color .2s;cursor:pointer}
.btn-ghost:hover{color:var(--ink)}
.reveal,.reveal-l,.reveal-r{opacity:0;transition:opacity .75s ease,transform .75s ease}
.reveal{transform:translateY(28px)}.reveal-l{transform:translateX(-28px)}.reveal-r{transform:translateX(28px)}
.reveal.in,.reveal-l.in,.reveal-r.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(18px);transition:opacity .5s,transform .5s}
.stagger.in>*:nth-child(1){opacity:1;transform:none;transition-delay:.04s}
.stagger.in>*:nth-child(2){opacity:1;transform:none;transition-delay:.11s}
.stagger.in>*:nth-child(3){opacity:1;transform:none;transition-delay:.18s}
.stagger.in>*:nth-child(4){opacity:1;transform:none;transition-delay:.25s}
.stagger.in>*:nth-child(5){opacity:1;transform:none;transition-delay:.32s}
.stagger.in>*:nth-child(6){opacity:1;transform:none;transition-delay:.39s}
.stagger.in>*:nth-child(n+7){opacity:1;transform:none;transition-delay:.46s}

/* ── HERO (HOME) ── */
.hero{position:relative;width:100%;height:75vh;min-height:480px;overflow:hidden;background:#0d0d0b;display:flex;align-items:flex-end;padding-bottom:5%}
.hero iframe{position:absolute;inset:0;width:100%;height:100%;border:none;pointer-events:none}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1c1c15 0%,#0d0d0b 60%)}
#hero-video-wrap{position:absolute;inset:0;display:block;font-size:0;line-height:0}
#hero-thumb{position:absolute;inset:0;width:100%;height:100%;border:none;display:block;object-fit:cover}
#hero-iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;border:none;pointer-events:none;display:block}
.hero-noise{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}
.hero-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.07)}
.hero-content{position:relative;z-index:2;width:100%;padding:0 var(--hero-pad, 48px);overflow:visible}
.hero-eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:24px}
.hero-h1{font-family:var(--serif);font-size:clamp(32px,4.5vw,58px);font-weight:300;line-height:1.1;color:var(--white);margin-bottom:32px;letter-spacing:-.015em}
.hero-h1 em{font-style:italic;color:rgba(255,255,255,.4)}
.hero-sub{font-size:15px;color:rgba(255,255,255,.4);max-width:380px;line-height:1.8;margin-bottom:44px;font-weight:300}
.hero-actions{display:flex;gap:16px;align-items:center}
.hero-btn{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.55);padding:13px 30px;color:var(--white);background:none;font-family:var(--sans);transition:all .25s}
.hero-btn:hover{background:var(--white);color:var(--ink)}
.hero-btn-text{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.28);background:none;border:none;font-family:var(--sans);transition:color .2s}
.hero-btn-text:hover{color:rgba(255,255,255,.65)}
.hero-scroll{position:absolute;bottom:40px;right:48px;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,.18);font-size:9px;letter-spacing:.2em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:52px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.18))}

/* ── PAGE HERO (subpages) ── */
.page-hero{position:relative;width:100%;height:72vh;min-height:480px;overflow:hidden;background:#0d0d0b;display:flex;align-items:flex-end;padding-bottom:72px}
.ph-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1c1c15 0%,#0d0d0b 60%)}
.ph-noise{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}
.ph-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.07)}
.ph-content{position:relative;z-index:2;width:100%;padding:0 var(--hotel-pad, 48px)}
.ph-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:20px}
.ph-h1{font-family:var(--serif);font-size:clamp(44px,6.5vw,96px);font-weight:300;line-height:.98;color:var(--white);margin-bottom:24px;letter-spacing:-.015em}
.ph-h1 em{font-style:italic;color:rgba(255,255,255,.4)}
.ph-sub{font-size:15px;color:rgba(255,255,255,.38);max-width:520px;line-height:1.8;font-weight:300;margin-bottom:32px}
.ph-btn{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.45);padding:12px 28px;color:var(--white);background:none;font-family:var(--sans);transition:all .25s}
.ph-btn:hover{background:var(--white);color:var(--ink)}

/* ── IPHONE FEED ── */
.iphone-feed-sec{background:var(--white);padding:120px 0 280px;position:relative;z-index:2;overflow:visible}
.iphone-feed-sec .sec-editor{z-index:2001}
.feed-layout{position:relative;max-width:1280px;margin:0 auto;padding:0 48px 0 48px;min-height:520px}
.feed-iphone-wrap{position:absolute;left:calc(48px + 6vw);bottom:-196px;z-index:3}
.feed-text{max-width:420px;padding-top:40px;order:unset}
.feed-iphone{width:260px;filter:drop-shadow(0 24px 48px rgba(0,0,0,.15))}
.feed-shell{position:relative;background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border-radius:38px;padding:10px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1),inset 0 0 0 2px rgba(0,0,0,.9),0 0 0 1px rgba(0,0,0,.3)}
.feed-screen{position:relative;width:100%;height:442px;border-radius:24px;overflow:hidden;background:#000}

.feed-shell::before{content:'';position:absolute;left:-3px;top:22%;width:3px;height:7%;background:#222;border-radius:2px 0 0 2px;box-shadow:0 180% 0 #222,0 280% 0 #222}
.feed-shell::after{content:'';position:absolute;right:-3px;top:28%;width:3px;height:12%;background:#222;border-radius:0 2px 2px 0}
.feed-island{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:88px;height:26px;background:#000;border-radius:20px;z-index:10}
.feed-status{position:absolute;top:14px;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 22px;z-index:9;height:26px}
.feed-time{font-size:11px;font-weight:600;color:rgba(255,255,255,.85);font-family:var(--sans)}
.feed-icons{display:flex;gap:5px;align-items:center}
.feed-battery{width:22px;height:11px;border:1.5px solid rgba(255,255,255,.6);border-radius:2px;position:relative}
.feed-battery::after{content:'';position:absolute;right:-4px;top:50%;transform:translateY(-50%);width:3px;height:5px;background:rgba(255,255,255,.4);border-radius:0 1px 1px 0}
.feed-battery::before{content:'';position:absolute;inset:1.5px;background:rgba(255,255,255,.75);border-radius:1px;width:65%}

.feed-scroll-inner{display:flex;flex-direction:column}
.feed-reel{flex-shrink:0;background:#111}
.feed-reel-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#000}
.feed-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#e0c080,#c06020);flex-shrink:0}
.feed-meta{flex:1}
.feed-username{font-size:10px;font-weight:600;color:#fff;font-family:var(--sans);line-height:1.2}
.feed-location{font-size:9px;color:rgba(255,255,255,.45);font-family:var(--sans)}
.feed-more{font-size:14px;color:rgba(255,255,255,.6);font-family:var(--sans)}
.feed-reel-video{position:relative;width:100%;aspect-ratio:9/16}
.feed-reel-video iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
/* Lazy-Load Thumbnail-Layer (nur sichtbar auf Mobile, durch JS gesteuert) */
.feed-reel-thumb-layer{position:absolute;inset:0;width:100%;height:100%;z-index:5;cursor:pointer;background:#000;display:none;transition:opacity .35s ease}
.feed-reel-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.feed-reel-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:rgba(0,0,0,.55);border-radius:50%;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(255,255,255,.6)}
@media(max-width:768px){.feed-reel-thumb-layer{display:block}}
.feed-reel-actions{position:absolute;right:8px;bottom:40px;display:flex;flex-direction:column;gap:14px;align-items:center;z-index:2}
.feed-action{display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff;font-size:18px;cursor:pointer}
.feed-action span{font-size:8px;font-family:var(--sans);font-weight:500}
.feed-reel-caption{background:#000;padding:6px 10px 8px;font-size:9px;color:rgba(255,255,255,.7);font-family:var(--sans);line-height:1.4}
.feed-reel-caption strong{color:#fff}
.feed-home{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:rgba(255,255,255,.3);border-radius:2px}
/* Text rechts */
.feed-text{max-width:360px;padding-top:40px}
.feed-title{font-family:var(--serif);font-size:clamp(24px,2.5vw,38px);font-weight:300;line-height:1.1;letter-spacing:-.015em;margin:14px 0 16px}
.feed-title em{font-style:italic;color:var(--muted)}
.feed-body{font-size:13px;color:var(--muted);line-height:1.85;font-weight:300;max-width:320px}
.feed-facts{display:flex;gap:24px;margin-top:28px;padding-top:28px;border-top:1px solid var(--line)}
.feed-fact{display:flex;flex-direction:column;gap:4px}
.feed-fact-n{font-family:var(--serif);font-size:30px;font-weight:300;color:var(--ink)}
.feed-fact-l{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media(max-width:1024px){.feed-layout{grid-template-columns:1fr;gap:48px}.feed-iphone-wrap{order:1}.feed-text{order:2}}
@media(max-width:640px){.feed-iphone{width:220px}.feed-screen{height:400px}}
.socials-hero{position:relative;background:#0d0d0b;overflow:visible;width:100%;aspect-ratio:16/9}
.sh-left{position:absolute;inset:0}
.sh-left-media{position:absolute;inset:0;width:100%;height:100%}
.sh-left-media .sh-ph-landscape{position:absolute;inset:0;width:100%;height:100%}
.sh-ph{display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.sh-ph-landscape{background:linear-gradient(135deg,#1c1c15,#0d0d0b);color:rgba(255,255,255,.07)}
.sh-ph-portrait{background:linear-gradient(160deg,#28281e,#141410);color:rgba(255,255,255,.1);width:100%;height:100%}
.sh-left-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:44px 52px;padding-right:calc(28vw + 80px);background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 55%,transparent 100%)}
.sh-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:18px}
.sh-h1{font-family:var(--serif);font-size:clamp(38px,5vw,76px);font-weight:300;line-height:.98;color:var(--white);margin-bottom:16px;letter-spacing:-.015em}
.sh-h1 em{font-style:italic;color:rgba(255,255,255,.4)}
.sh-sub{font-size:14px;color:rgba(255,255,255,.36);max-width:420px;line-height:1.8;font-weight:300;margin-bottom:28px}

/* ── iPHONE FRAME ── */
.sh-right{position:absolute;right:48px;z-index:10;bottom:calc(-28vw * (16/9) * 0.5)}
.sh-iphone{position:relative;width:28vw;max-width:380px;min-width:220px;filter:drop-shadow(-16px 16px 64px rgba(0,0,0,.65))}
.sh-iphone-shell{position:relative;width:100%;aspect-ratio:9/16;background:linear-gradient(145deg,#2a2a2a 0%,#1a1a1a 40%,#222 100%);border-radius:min(8%,36px);padding:min(1.8%,7px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),inset 0 0 0 2px rgba(0,0,0,.8)}
/* Side buttons */
.sh-iphone-shell::before{content:'';position:absolute;left:-3px;top:22%;width:3px;height:8%;background:#2a2a2a;border-radius:2px 0 0 2px;box-shadow:0 calc(100%/3) 0 #2a2a2a,0 calc(200%/3) 0 #2a2a2a}
.sh-iphone-shell::after{content:'';position:absolute;right:-3px;top:28%;width:3px;height:14%;background:#2a2a2a;border-radius:0 2px 2px 0}
/* Screen */
.sh-iphone-screen{position:relative;width:100%;height:100%;border-radius:min(9%,40px);overflow:hidden;background:#000}
/* Dynamic island */
.sh-iphone-island{position:absolute;top:min(2.5%,10px);left:50%;transform:translateX(-50%);width:min(28%,90px);height:min(4%,14px);background:#000;border-radius:20px;z-index:5}
/* Screen content */
.sh-iphone-content{position:absolute;inset:0}
.sh-iphone-content .sh-ph-portrait{border-radius:min(9%,40px)}
.sh-iphone-content iframe{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:min(9%,40px)}
/* Status bar */
.sh-iphone-status{position:absolute;top:0;left:0;right:0;height:min(7%,28px);display:flex;align-items:flex-end;justify-content:space-between;padding:0 min(6%,20px) min(1%,4px);z-index:4;pointer-events:none}
.sh-status-time{font-size:min(2.8%,11px);font-weight:600;color:rgba(255,255,255,.85);font-family:var(--sans);letter-spacing:-.01em}
.sh-status-icons{display:flex;gap:min(1%,4px);align-items:center}
.sh-status-icon{width:min(2.5%,9px);height:min(2.5%,9px);background:rgba(255,255,255,.8);border-radius:1px}
.sh-status-icon.signal{clip-path:polygon(0 100%,25% 60%,50% 30%,75% 10%,100% 0,100% 100%)}
.sh-status-icon.wifi{border-radius:50%;clip-path:polygon(50% 100%,10% 40%,90% 40%)}
.sh-status-icon.battery{width:min(3.5%,13px);height:min(2%,7px);border:1px solid rgba(255,255,255,.7);border-radius:1px;position:relative}
.sh-status-icon.battery::after{content:'';position:absolute;right:-3px;top:50%;transform:translateY(-50%);width:2px;height:40%;background:rgba(255,255,255,.5);border-radius:0 1px 1px 0}
.sh-status-icon.battery::before{content:'';position:absolute;inset:1px;background:rgba(255,255,255,.8);border-radius:1px;width:70%}
/* Home indicator */
.sh-iphone-home{position:absolute;bottom:min(2%,8px);left:50%;transform:translateX(-50%);width:min(28%,100px);height:min(1%,4px);background:rgba(255,255,255,.35);border-radius:3px;z-index:4}
/* Reel overlay label */
.sh-reel-overlay{position:absolute;inset:0;z-index:3;pointer-events:none;display:flex;flex-direction:column;justify-content:flex-end;padding:min(4%,16px)}
.sh-reel-overlay::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 50%);border-radius:min(9%,40px)}
.sh-reel-tag{font-size:min(2.2%,9px);letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.2);padding:3px 10px;align-self:flex-start;background:rgba(0,0,0,.2);backdrop-filter:blur(4px);border-radius:20px;position:relative;z-index:1}
.sh-reel-bottom{position:relative;z-index:1;display:flex;flex-direction:column;gap:3px;margin-top:auto}
.sh-reel-client{font-size:min(2.2%,9px);letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.sh-reel-title{font-family:var(--serif);font-size:min(3.5%,15px);font-weight:300;color:rgba(255,255,255,.85);line-height:1.2}
.sh-reel iframe,.sh-reel .sh-ph-portrait{position:absolute;inset:0;width:100%;height:100%;border:none}
.sh-reel-overlay{position:absolute;inset:0;z-index:2;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;padding:16px}
.sh-reel-tag{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.2);padding:3px 10px;align-self:flex-start;background:rgba(0,0,0,.2);backdrop-filter:blur(4px)}
.sh-reel-bottom{display:flex;flex-direction:column;gap:3px}
.sh-reel-client{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.sh-reel-title{font-family:var(--serif);font-size:14px;font-weight:300;color:rgba(255,255,255,.85);line-height:1.2}
.sh-reel::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 50%);z-index:1}

@media(max-width:900px){


}
@media(max-width:640px){
  .socials-hero{grid-template-columns:1fr}
  .sh-right{display:none}
}

/* ── LOGO STRIP ── */
.logo-strip{background:var(--off);border-bottom:1px solid var(--line);position:relative;z-index:1;margin-top:-4px}
.ls-inner{display:grid;grid-template-columns:repeat(8,1fr);background:var(--off);gap:0}
.ls-item{background:var(--off);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:rgba(0,0,0,.22);font-weight:500;transition:color .25s;cursor:default;min-width:0;overflow:hidden;padding:8px}
.ls-item img{max-width:100%;height:auto;display:block}
.ls-item:hover{color:rgba(0,0,0,.52)}
@media(max-width:1024px){.ls-inner{grid-template-columns:repeat(4,1fr)}.ls-item:nth-child(n+5){display:none}}
@media(max-width:640px){.ls-inner{grid-template-columns:repeat(3,1fr) !important}.ls-item:nth-child(n+4){display:none !important}.ls-item{aspect-ratio:3/2;padding:12px}}

/* ── SERVICES LIST ── */
.svc-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:72px}
.svc-list{border-top:1px solid var(--line)}
.svc-item{display:grid;grid-template-columns:72px 1fr 1fr 64px;gap:32px;align-items:center;padding:36px 0;border-bottom:1px solid var(--line);cursor:pointer;transition:padding .25s,background .2s;background:transparent}
.svc-item:hover{padding-left:16px;padding-right:16px;background:var(--off)}
.svc-num{font-size:11px;letter-spacing:.1em;color:var(--muted)}
.svc-title{font-family:var(--serif);font-size:clamp(22px,2.2vw,34px);font-weight:300;letter-spacing:-.01em}
.svc-desc-t{font-size:13px;color:var(--muted);line-height:1.75;font-weight:300}
.svc-arrow{font-size:16px;color:var(--muted);justify-self:end;transition:transform .3s,color .3s}
.svc-item:hover .svc-arrow{transform:translateX(6px);color:var(--ink)}

/* ── BIG TYPE ── */
.bt-line{font-family:var(--serif);font-size:clamp(48px,8vw,128px);font-weight:300;line-height:1.05;letter-spacing:-.02em;overflow:visible;padding-bottom:0.05em}
.bt-line span{display:block;transform:translateY(105%);animation:bt-up .85s cubic-bezier(.16,1,.3,1) forwards;animation-play-state:paused}
.bt-line:nth-child(2) span{animation-delay:.14s;padding-left:6vw}
.bt-line:nth-child(3) span{animation-delay:.28s;padding-left:13vw}
.bt-line:nth-child(4) span{animation-delay:.42s;padding-left:4vw}
@keyframes bt-up{to{transform:translateY(0)}}
.bt-line em{font-style:italic;color:var(--muted)}
.bt-footer{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:28px;padding-top:28px;border-top:1px solid var(--line)}
.bt-stat-n{font-family:var(--serif);font-size:32px;font-weight:300;line-height:1;font-variant-numeric:lining-nums tabular-nums;display:block}
.bt-stat-l{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ── SHOWREEL GRID ── */
.sr-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px}
.sr-viewall{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .2s,border-color .2s}
.sr-viewall:hover{color:var(--ink);border-color:var(--ink)}

/* Toggle */
.sr-toggle{display:flex;gap:0;border:1px solid var(--line);overflow:hidden}
.sr-toggle-btn{font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:8px 18px;background:none;border:none;color:var(--muted);font-family:var(--sans);cursor:pointer;transition:all .2s}
.sr-toggle-btn.active{background:var(--ink);color:var(--white)}
.sr-toggle-btn:not(.active):hover{background:var(--off);color:var(--ink)}

.sr-grid-16{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.sr-grid-916{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.sr-cell{position:relative;overflow:hidden;background:#111;cursor:pointer;transform:translateZ(0)}
.sr-cell.wide{grid-column:span 2}

/* Video grid — same structure, no wide cells */
.sr-grid-video-16{display:none;grid-template-columns:repeat(2,1fr);gap:6px}
.sr-grid-video-916{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;display:none}
.sr-video-cell{position:relative;overflow:hidden;background:#111}
.sr-video-cell .r169{aspect-ratio:16/9}
.sr-video-cell .r916{aspect-ratio:9/16}
.sr-video-cell iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.sr-video-cell .sr-video-label{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);opacity:0;transition:opacity .3s;pointer-events:none}
.sr-video-cell:hover .sr-video-label{opacity:1}
.sr-video-client{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:3px}
.sr-video-title{font-family:var(--serif);font-size:15px;font-weight:300;color:var(--white)}
.r169{aspect-ratio:16/9;position:relative;width:100%;height:100%;overflow:hidden}.r916{aspect-ratio:9/16;position:relative;width:100%;height:100%;overflow:hidden}.r11{aspect-ratio:1;position:relative;width:100%;height:100%;overflow:hidden}
.sr-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,#e8e6e0,#d4d2ca)}
.sr-ph-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(0,0,0,.28)}
.sr-ph-n{font-family:var(--serif);font-size:32px;font-weight:300;color:rgba(0,0,0,.12)}
.sr-hover{position:absolute;inset:0;opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:20px}
.sr-hover::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%)}
.sr-cell:hover .sr-hover{opacity:1}
.sr-hi{position:relative;z-index:1}
.sr-client{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:3px}
.sr-project{font-family:var(--serif);font-size:17px;font-weight:300;color:var(--white);letter-spacing:-.01em}
.sr-tag{position:absolute;top:14px;left:14px;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.2);padding:3px 9px;opacity:0;transition:opacity .3s}
.sr-cell:hover .sr-tag{opacity:1}

/* ── OVERFLOW PULLQUOTE ── */
.overflow-img{width:100%;aspect-ratio:16/7;background:linear-gradient(135deg,#181810,#2a2a20);display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.09)}
.overflow-pq{max-width:1280px;margin:-52px auto 0;padding:0 48px;position:relative;z-index:2}
.overflow-pq-text{font-family:var(--serif);font-size:clamp(28px,4vw,56px);font-weight:300;line-height:1.1;letter-spacing:-.015em;max-width:860px}
.overflow-pq-text em{font-style:italic;color:var(--muted)}
.overflow-body{max-width:1280px;margin:28px auto 0;padding:0 48px 120px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.overflow-body p{font-size:14px;color:var(--muted);line-height:1.9;font-weight:300}
.overflow-cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start}

/* ── PROJECT DOUBLE ── */
.pd-item{display:grid;gap:3px;margin-bottom:3px}
.pd-item.l{grid-template-columns:2fr 1fr}
.pd-item.r{grid-template-columns:1fr 2fr}
.pd-big-inner{aspect-ratio:4/3;background:linear-gradient(135deg,#d8d6d0,#c8c6c0);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px}
.pd-big-cat{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(0,0,0,.25)}
.pd-big-title{font-family:var(--serif);font-size:22px;font-weight:300;color:rgba(0,0,0,.2)}
.pd-side{display:flex;flex-direction:column;gap:3px}
.pd-text{background:var(--white);padding:40px 36px;display:flex;flex-direction:column;gap:14px;flex:1;justify-content:center}
.pd-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.pd-title{font-family:var(--serif);font-size:clamp(20px,2vw,28px);font-weight:300;line-height:1.15;letter-spacing:-.01em}
.pd-desc{font-size:13px;color:var(--muted);line-height:1.8;font-weight:300}
.pd-link{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:2px;display:inline-block;transition:border-color .2s}
.pd-link:hover{border-color:var(--ink)}
.pd-small{aspect-ratio:1;background:linear-gradient(135deg,#d0cec8,#c0beb8);display:flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(0,0,0,.2)}


/* Testimonial photo */
.tc-photo{width:52px;height:52px;border-radius:4px;background:linear-gradient(135deg,#e8e6e0,#d4d2cc);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(0,0,0,.2)}
.tc-photo.tc-photo-has{background:#f1efe8}
.tc-photo img{width:100%;height:100%;object-fit:cover;display:block}
.tc-author-row{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:18px}
.tc-author-info{display:flex;flex-direction:column;gap:3px;min-width:0}

/* ── IMAGE STACK ── */
.stack-inner{display:grid;grid-template-columns:460px 1fr;gap:80px;align-items:start}
.stack-imgs{display:flex;flex-direction:column;gap:4px}
.stack-img{overflow:hidden}
.stack-img:nth-child(1){aspect-ratio:16/9;background:linear-gradient(135deg,#ece9e2,#d8d6d0)}
.stack-img:nth-child(2){aspect-ratio:4/3;margin-left:36px;background:linear-gradient(135deg,#e4e2dc,#d0cec8)}
.stack-img:nth-child(3){aspect-ratio:1;margin-left:72px;background:linear-gradient(135deg,#dcdad4,#c8c6c0)}
.stack-img:nth-child(4){aspect-ratio:16/9;margin-left:18px;background:linear-gradient(135deg,#e8e6e0,#d4d2cc)}
.stack-img-ph{width:100%;height:100%;min-height:150px;display:flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(0,0,0,.2)}
.stack-content{position:sticky;top:112px}
.stack-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.stack-h{font-family:var(--serif);font-size:clamp(28px,3.2vw,50px);font-weight:300;line-height:1.08;letter-spacing:-.015em;margin-bottom:22px}
.stack-h em{font-style:italic;color:var(--muted)}
.stack-body{font-size:14px;color:var(--muted);line-height:1.9;font-weight:300;margin-bottom:28px}
.stack-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:36px;padding:0;margin-left:0;margin-right:0}
.stack-list li{font-size:13px;color:var(--ink2);display:flex;gap:14px;align-items:baseline;font-weight:300;line-height:1.7;letter-spacing:.005em}
.stack-list li::before{content:'—';color:var(--muted);flex-shrink:0;font-size:11px}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-portrait{width:100%;aspect-ratio:3/4;background:linear-gradient(145deg,#d8d6d0,#c4c2bc);position:relative;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;overflow:hidden}
.about-ph-name{font-family:var(--serif);font-size:24px;font-weight:300;color:rgba(0,0,0,.2)}
.about-ph-role{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(0,0,0,.22)}
.about-badge{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.92);padding:14px 18px}
.about-badge-name{font-family:var(--serif);font-size:17px;font-weight:400}
.about-badge-role{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.about-h{font-family:var(--serif);font-size:clamp(28px,3.5vw,48px);font-weight:300;line-height:1.08;letter-spacing:-.015em;margin-bottom:22px}
.about-h em{font-style:italic;color:var(--muted)}
.about-body{font-size:14px;color:var(--ink2);line-height:1.9;font-weight:300;margin-bottom:14px}
.about-facts{margin-top:32px;border-top:1px solid var(--line)}
.about-fact{display:grid;grid-template-columns:110px 1fr;gap:20px;padding:15px 0;border-bottom:1px solid var(--line)}
.af-lbl{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-top:2px}
.af-val{font-size:14px;color:var(--ink)}

/* ── TESTIMONIALS ── */
.tc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:60px}
.tc-card{background:var(--white);padding:44px 36px;display:flex;flex-direction:column;gap:22px}
.tc-stars{display:flex;gap:3px}
.tc-star{width:9px;height:9px;background:var(--ink);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.tc-text{font-family:var(--serif);font-size:18px;font-weight:300;line-height:1.55;color:var(--ink);font-style:italic;flex:1}
.tc-name{font-size:13px;font-weight:500;color:var(--ink)}
.tc-role{font-size:11px;color:var(--muted);margin-top:3px}

/* ── LOGO WALL ── */
.lw-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line)}
.lw-cell{background:var(--white);aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;cursor:pointer;transition:background .25s}
.lw-cell:hover{background:var(--off)}
.lw-name{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(0,0,0,.2);font-weight:500;transition:color .25s}
.lw-cell:hover .lw-name{color:rgba(0,0,0,.5)}
.lw-hint{position:absolute;bottom:10px;left:0;right:0;text-align:center;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .25s}
.lw-cell:hover .lw-hint{opacity:1}

/* ── PRICING ── */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:60px}
.pkg{background:var(--white);padding:44px 36px;display:flex;flex-direction:column;gap:18px;position:relative}
.pkg.featured{background:var(--ink)}
.pkg-badge{position:absolute;top:20px;right:20px;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--white);background:var(--ink2);padding:4px 10px}
.pkg.featured .pkg-badge{background:rgba(255,255,255,.15)}
.pkg-name{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.pkg.featured .pkg-name{color:rgba(255,255,255,.45)}
.pkg-price{font-family:var(--serif);font-size:48px;font-weight:300;color:var(--ink);line-height:1}
.pkg.featured .pkg-price{color:var(--white)}
.pkg-price small{font-size:14px;color:var(--muted)}
.pkg.featured .pkg-price small{color:rgba(255,255,255,.4)}
.pkg-desc{font-size:13px;color:var(--muted);line-height:1.75;font-weight:300}
.pkg.featured .pkg-desc{color:rgba(255,255,255,.45)}
.pkg-hr{border:none;border-top:1px solid var(--line)}
.pkg.featured .pkg-hr{border-color:rgba(255,255,255,.12)}
.pkg-feats{list-style:none;display:flex;flex-direction:column;gap:10px}
.pkg-feats li{font-size:13px;color:var(--ink2);display:flex;gap:12px;align-items:baseline}
.pkg.featured .pkg-feats li{color:rgba(255,255,255,.7)}
.pkg-feats li::before{content:'—';color:var(--muted);flex-shrink:0;font-size:11px}
.pkg.featured .pkg-feats li::before{color:rgba(255,255,255,.3)}
.pkg-cta{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);padding:13px;background:none;color:var(--ink2);font-family:var(--sans);transition:all .2s;margin-top:auto;cursor:pointer}
.pkg-cta:hover{border-color:var(--ink);color:var(--ink)}
.pkg.featured .pkg-cta{border-color:rgba(255,255,255,.3);color:var(--white)}
.pkg.featured .pkg-cta:hover{background:var(--white);color:var(--ink)}

/* ── CTA DARK ── */
.cta-dark{padding:160px 0;background:var(--ink);position:relative;overflow:hidden}
.cta-wm{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--serif);font-size:clamp(80px,18vw,260px);font-weight:300;color:rgba(255,255,255,.025);white-space:nowrap;pointer-events:none;font-style:italic}
.cta-inner{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:28px}
.cta-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.cta-h{font-family:var(--serif);font-size:clamp(38px,6vw,90px);font-weight:300;color:var(--white);line-height:1.02;letter-spacing:-.02em;max-width:840px}
.cta-h em{font-style:italic;color:rgba(255,255,255,.38)}
.cta-body{font-size:14px;color:rgba(255,255,255,.38);max-width:420px;line-height:1.8;font-weight:300}
.cta-btn{font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.45);padding:14px 40px;color:var(--white);background:none;font-family:var(--sans);transition:all .25s;cursor:pointer}
.cta-btn:hover{background:var(--white);color:var(--ink)}
.cta-info{font-size:11px;color:rgba(255,255,255,.2)}

/* ── STUDIO SPECIFIC ── */
.studio-process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);margin-top:60px}
.sp-step{background:var(--white);padding:36px 28px;display:flex;flex-direction:column;gap:14px}
.sp-num{font-family:var(--serif);font-size:48px;font-weight:300;color:rgba(0,0,0,.08);line-height:1}
.sp-title{font-family:var(--serif);font-size:20px;font-weight:300}
.sp-desc{font-size:13px;color:var(--muted);line-height:1.75}

/* ── FOOTER ── */

.footer-logo{font-family:var(--serif);font-size:18px;font-weight:300;cursor:pointer}
.footer-logo span{font-weight:400}
.footer-links{display:flex;gap:24px}
.footer-links a{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.footer-links a:hover{color:var(--ink)}
.footer-copy{font-size:11px;color:var(--muted)}

/* ── STICKY BAR ── */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:14px 48px;display:flex;justify-content:space-between;align-items:center;z-index:400;transform:translateY(100%);transition:transform .45s cubic-bezier(.16,1,.3,1)}
.sticky-bar.show{transform:translateY(0)}
.sb-text{font-size:13px;color:var(--ink)}
.sb-text span{font-size:11px;color:var(--muted);display:block;margin-top:1px}
.sb-btns{display:flex;gap:10px}
.sb-btn{font-size:11px;letter-spacing:.07em;text-transform:uppercase;border:1px solid var(--line);padding:10px 22px;background:none;color:var(--ink2);font-family:var(--sans);transition:all .2s;cursor:pointer}
.sb-btn:hover{border-color:var(--ink2)}
.sb-btn.p{background:var(--ink);color:var(--white);border-color:var(--ink)}
.sb-btn.p:hover{background:var(--ink2)}

/* ── POPUP ── */
.popup{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;align-items:center;justify-content:center}
.popup.open{display:flex}
.popup-box{background:var(--white);max-width:480px;width:90%;padding:52px;position:relative}
.popup-close{position:absolute;top:18px;right:22px;background:none;border:none;font-size:22px;color:var(--muted);line-height:1;cursor:pointer}
.popup-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.popup-h{font-family:var(--serif);font-size:32px;font-weight:300;line-height:1.1;margin-bottom:10px}
.popup-sub{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:30px}
.popup-opts{display:flex;flex-direction:column;gap:10px}
.popup-opt{display:flex;align-items:center;gap:16px;padding:15px 20px;border:1px solid var(--line);transition:all .2s;text-decoration:none;color:inherit}
.popup-opt:hover{border-color:var(--ink);background:var(--off)}
.popup-opt-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.popup-opt-lbl{font-size:13px;font-weight:500}
.popup-opt-desc{font-size:11px;color:var(--muted);margin-top:1px}
.popup-info{margin-top:18px;text-align:center;font-size:11px;color:var(--muted);line-height:2.1}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .nav,.w,.sticky-bar{padding-left:32px;padding-right:32px}
  .ph-content,.overflow-pq,.overflow-body{padding-left:32px;padding-right:32px}
  .overflow-body{padding-bottom:80px}
  .svc-header,.about-grid,.stack-inner,.overflow-body{grid-template-columns:1fr;gap:40px}
  .stack-content{position:static}
  .svc-item{grid-template-columns:60px 1fr 64px}
  .svc-desc-t{display:none}
  .pd-item.l,.pd-item.r{grid-template-columns:1fr}
  .bt-footer{grid-template-columns:repeat(2,1fr)}
  .pkg-grid,.studio-process{grid-template-columns:1fr}
}
@media(max-width:768px){
  /* Erzwinge horizontales Mobile-Padding auf allen Page-Hero-Inhalten */
  .nav,.sticky-bar{padding-left:16px !important;padding-right:16px !important}
  .ph-content,.overflow-pq,.overflow-body{padding-left:24px !important;padding-right:24px !important}
  .w,.feed-layout{padding-left:24px !important;padding-right:24px !important}
  /* Nav 2-zeilig: Zeile 1 = Logo + DE/EN + Anfragen, Zeile 2 = Menü scrollbar */
  .nav{height:auto !important;padding:10px 16px !important;flex-wrap:wrap;gap:8px;align-items:center}
  .nav-logo-wrap{order:1;flex:1;min-width:0}
  .nav-logo-wrap .jf-logo,.nav-logo-wrap svg{width:120px !important;height:30px !important}
  .nav > div:last-child{order:2;display:flex;align-items:center;gap:8px}
  .lang-toggle{margin-left:0 !important}
  .lang-btn{padding:6px 9px !important;font-size:10px !important}
  .nav-cta{margin-left:0 !important;padding:7px 12px !important;font-size:10px !important;letter-spacing:.06em !important}
  .nav-links{order:3 !important;display:flex !important;width:100%;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:18px;padding:6px 0 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-top:1px solid rgba(255,255,255,.08);margin-top:6px}
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{font-size:11px !important;letter-spacing:.12em !important;white-space:nowrap;flex-shrink:0;padding:4px 0}
  .nav-slash{display:none}
  
  /* Globale Section-Abstände auf Mobile: deutlich kompakter — 60px statt 120-280px */
  .sec{padding:60px 0 !important}
  .faq-sec{padding:60px 0 !important}
  .cta-dark{padding:70px 0 !important}
  .iphone-feed-sec{padding:60px 0 !important}
  .feed-layout{min-height:auto !important;padding:0 24px}
  .feed-iphone-wrap{position:static !important;left:auto !important;bottom:auto !important;margin:40px auto 0 !important;display:flex;justify-content:center}
  
  .sr-grid-16{grid-template-columns:1fr 1fr}
  .sr-cell.wide{grid-column:span 1}
  .sr-grid-916{grid-template-columns:repeat(2,1fr)}
  .tc-grid{grid-template-columns:1fr}
  .lw-grid{grid-template-columns:repeat(3,1fr)}
  
  .sr-header{flex-direction:column;align-items:flex-start;gap:20px}
  .sr-header > div:last-child{flex-wrap:wrap;width:100%;justify-content:flex-start !important;gap:14px !important}
  .sr-toggle-btn{padding:8px 14px}
  
  .sticky-bar{padding:10px 12px;gap:8px}
  .sb-text span:nth-child(2){display:none}
  .sb-text{font-size:11px;line-height:1.3;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .sb-btn{padding:9px 12px;font-size:10px;letter-spacing:.05em;white-space:nowrap}
  .sb-btns{flex-shrink:0;gap:6px}
}
@media(max-width:480px){
  .sb-text{display:none}
  .sb-btns{width:100%;justify-content:stretch}
  .sb-btn{flex:1;text-align:center}
}
/* ══ INLINE EDITOR (nur Admin) ══ */
.jf-editable-wrap{position:relative;display:inline}
.jf-edit-btn{position:absolute;top:-8px;right:-28px;width:22px;height:22px;background:rgba(0,100,255,.85);color:#fff;border:none;border-radius:50%;font-size:12px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:9000;line-height:1;padding:0;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.edit-mode .jf-editable-wrap:hover .jf-edit-btn{display:flex}
.edit-mode .jf-editing{outline:2px solid rgba(0,100,255,.5)!important;background:rgba(0,100,255,.04)!important;border-radius:2px}
#jf-edit-toolbar{position:absolute;z-index:9500;background:#0d0d0b;border-radius:4px;padding:6px 8px;display:none;gap:4px;align-items:center;box-shadow:0 4px 24px rgba(0,0,0,.4);white-space:nowrap}
#jf-edit-toolbar.show{display:flex}
#jf-edit-toolbar button{background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.8);padding:4px 10px;border-radius:3px;cursor:pointer;font-size:12px;font-family:inherit;transition:background .15s}
#jf-edit-toolbar button:hover{background:rgba(255,255,255,.2);color:#fff}
#jf-edit-toolbar .jf-tb-save{background:#0066ff;color:#fff}
#jf-edit-toolbar .jf-tb-save:hover{background:#0052cc}
#jf-edit-toolbar .jf-tb-cancel{background:rgba(255,0,0,.2)}
.jf-tb-sep{width:1px;height:16px;background:rgba(255,255,255,.15);margin:0 2px}
#jf-toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:#0d0d0b;color:#fff;padding:10px 24px;border-radius:4px;font-size:13px;font-family:var(--sans,'DM Sans',sans-serif);z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none}
#jf-toast.show{opacity:1}

/* ── IPHONE CONTROLLER (nur im Edit-Mode) ── */
.iphone-ctrl{display:none;position:absolute;top:-48px;left:50%;transform:translateX(-50%);z-index:1000;background:rgba(13,13,11,.92);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:3px;padding:6px 10px;white-space:nowrap;gap:6px;align-items:center;font-family:var(--sans,'DM Sans',sans-serif)}
.edit-mode .iphone-wrap:hover .iphone-ctrl{display:flex}
.ic-btn{width:24px;height:24px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.8);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:2px;transition:background .15s}
.ic-btn:hover{background:rgba(255,255,255,.25);color:#fff}
.ic-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin:0 2px}
.ic-val{font-size:10px;color:rgba(255,255,255,.4);min-width:36px;text-align:center}
.ic-divider{width:1px;height:18px;background:rgba(255,255,255,.12)}

/* iPhone Controller — standardmäßig KOMPLETT versteckt */
.iphone-ctrl { display: none !important; }
.edit-mode .iphone-wrap:hover .iphone-ctrl { display: flex !important; }

/* iPhone Controller — nur im Edit-Mode */
.iphone-ctrl{display:none !important}
.edit-mode .iphone-wrap:hover .iphone-ctrl{display:flex !important}
.ic-btn{width:24px;height:24px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.8);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:2px}
.ic-btn:hover{background:rgba(255,255,255,.25)}
.ic-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin:0 2px}
.ic-val{font-size:10px;color:rgba(255,255,255,.4);min-width:36px;text-align:center}
.ic-divider{width:1px;height:18px;background:rgba(255,255,255,.12)}
/* Section editor — nur im Edit-Mode */
.sec-editor{display:none !important}
.edit-mode .editable-sec:hover > .sec-editor{display:flex !important}
/* Edit buttons */
.jf-edit-btn{display:none}
.edit-mode .jf-editable-wrap:hover .jf-edit-btn{display:flex}

/* Logo blend mode — entfernt weißen Hintergrund bei nicht-transparenten PNGs */
.ls-item img { mix-blend-mode: multiply; }
.lw-cell img { mix-blend-mode: multiply; }
/* Logo strip hintergrund */
.logo-strip { background: #ffffff !important; }

/* ── TEXT EDITOR ── */
.jf-editable { cursor: text !important; }
.edit-mode .jf-editable:hover { outline: 1px dashed rgba(0,100,255,.35) !important; }
.jf-editing { outline: 2px solid #0066ff !important; background: rgba(0,100,255,.04) !important; border-radius: 2px; }

#jf-toolbar { position:absolute;z-index:9999;background:#0d0d0b;border-radius:4px;padding:5px 8px;display:none;gap:4px;align-items:center;box-shadow:0 4px 24px rgba(0,0,0,.5);white-space:nowrap;pointer-events:all; }
#jf-toolbar.show { display:flex; }
#jf-toolbar button { background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.8);padding:4px 10px;border-radius:3px;cursor:pointer;font-size:12px;font-family:inherit; }
#jf-toolbar button:hover { background:rgba(255,255,255,.2);color:#fff; }
#jf-toolbar .tb-save { background:#0066ff;color:#fff; }
#jf-toolbar .tb-cancel { background:rgba(255,60,60,.25); }
.tb-sep { width:1px;height:16px;background:rgba(255,255,255,.15);margin:0 2px; }

#jf-toast { position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:#0d0d0b;color:#fff;padding:10px 24px;border-radius:4px;font-size:13px;font-family:var(--sans,'DM Sans',sans-serif);z-index:9998;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap; }
#jf-toast.show { opacity:1; }

#jf-edit-bar { display:none;position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#0d0d0b;color:#fff;padding:10px 20px;z-index:9997;font-family:var(--sans,'DM Sans',sans-serif);font-size:12px;gap:16px;align-items:center;border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,.4); }
#jf-edit-bar button { background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.7);padding:4px 12px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit; }

/* ── MOBILE ── */
.nav-hamburger{display:none !important}
@media(max-width:768px){
  .nav{padding:0 10px;height:auto;min-height:56px;flex-wrap:wrap;gap:0}
  /* Alle Nav-Links immer sichtbar, horizontal scrollbar */
  .nav-links{display:flex !important;flex-direction:row !important;flex-wrap:nowrap !important;overflow-x:auto !important;-webkit-overflow-scrolling:touch !important;gap:0 !important;width:100% !important;order:3;padding:6px 0 6px 0;border-top:1px solid rgba(255,255,255,.08);scrollbar-width:none}
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{font-size:9px !important;letter-spacing:.06em !important;padding:6px 10px !important;white-space:nowrap !important;color:rgba(255,255,255,.7) !important;flex-shrink:0 !important}
  .nav-links a:hover,.nav-links a.active{color:#fff !important}
  .nav-slash{display:none !important}
  .nav-hamburger{display:none !important}
  .w{padding-left:16px !important;padding-right:16px !important}
  .hero{height:auto !important;min-height:auto !important;padding:110px 0 0 0 !important;background:#0a0a08 !important;display:block !important}
  .hero-h1{font-size:30px !important;color:var(--ink) !important}
  .hero-h1 em{color:var(--muted) !important}
  .hero-eyebrow{color:var(--muted) !important;letter-spacing:.18em}
  .hero-sub{color:var(--muted) !important;max-width:none !important}
  .hero-btn{color:var(--ink) !important;border-color:rgba(0,0,0,.4) !important}
  .hero-btn-text{color:var(--ink) !important}
  /* Hero Video Mobile: aspect-ratio 16/9 — Safari rendert das zuverlässiger als padding-bottom */
  #hero-video-wrap{position:relative !important;inset:auto !important;width:100% !important;max-width:100vw !important;height:auto !important;aspect-ratio:16/9 !important;padding-bottom:0 !important;background:#000;display:block;overflow:hidden;box-sizing:border-box;margin-left:0 !important;margin-right:0 !important}
  #hero-thumb{position:absolute !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;width:100% !important;height:100% !important;object-fit:contain !important;pointer-events:none;box-sizing:border-box;margin:0 !important;padding:0 !important}
  #hero-iframe{position:absolute !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;width:100% !important;height:100% !important;max-width:none !important;border:0 !important;transform:none !important;min-width:0 !important;min-height:0 !important;inset:0 !important;box-sizing:border-box;margin:0 !important;padding:0 !important}
  #hero-play-btn{pointer-events:none !important;z-index:25 !important}
  #hero-play-btn > div{pointer-events:auto !important}
  .hero-bg,.hero-noise{display:none !important}
  /* hero-content wird per JS nach logo-strip verschoben — eigener Block */
  .hero-content{position:relative !important;z-index:auto !important;padding:48px 24px !important;background:#fff !important;display:block !important}
  #hero-sound-btn{display:none !important}
  .hero-actions{flex-direction:column;gap:10px;margin-top:24px}
  #iphone-wrap-home{position:relative !important;left:auto !important;top:auto !important;width:100% !important;display:flex !important;justify-content:center !important;margin-top:60px !important}
  #iphone-wrap-socials{position:relative !important;left:auto !important;top:auto !important;width:100% !important;display:flex !important;justify-content:center !important;margin:16px auto 80px !important;transform:none !important}
  .feed-iphone{width:200px !important}
  .about-grid{display:block !important}
  .about-portrait{height:72vw !important;max-height:380px;margin-bottom:24px;position:relative !important}
  .sr-photos{grid-template-columns:1fr 1fr !important;gap:6px !important}
  .sr-videos.sr-grid-video-916,.sr-videos.sr-grid-video-16{grid-template-columns:1fr !important;gap:6px !important}
  .sr-cell.wide{grid-column:span 2 !important}
  .footer-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:28px 16px !important}
  .footer-col:first-child{grid-column:span 2}
  .pkg-grid{display:block !important}
  .lw-grid{grid-template-columns:repeat(2,1fr) !important}
  .page-hero{min-height:52vw !important}
  /* Hotel-Hero Mobile: gleiches Verhalten wie Startseite */
  #page-hotel .page-hero{height:auto !important;min-height:auto !important;padding:110px 0 0 0 !important;background:#0a0a08 !important;display:block !important;align-items:initial !important}
  #page-hotel #hotel-video-wrap{position:relative !important;inset:auto !important;width:100% !important;max-width:100vw !important;height:auto !important;aspect-ratio:16/9 !important;background:#000 !important;overflow:hidden !important;display:block !important}
  #page-hotel #hotel-hero-iframe{position:absolute !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;width:100% !important;height:100% !important;min-width:0 !important;min-height:0 !important;max-width:none !important;transform:none !important;inset:0 !important;border:0 !important;margin:0 !important;padding:0 !important}
  #page-hotel #hotel-hero-thumb{object-fit:contain !important;background:#000}
  #page-hotel .ph-bg,#page-hotel .ph-noise,#page-hotel #hotel-sound-btn{display:none !important}
  /* ph-content nach Reorder als eigener Block auf weiß */
  #page-hotel .ph-content{position:relative !important;z-index:auto !important;padding:48px 24px !important;background:#fff !important;display:block !important}
  #page-hotel .ph-h1{color:var(--ink) !important}
  #page-hotel .ph-h1 em{color:var(--muted) !important}
  #page-hotel .ph-label{color:var(--muted) !important}
  #page-hotel .ph-sub{color:var(--muted) !important}
  #page-hotel .ph-btn{color:var(--ink) !important;border-color:rgba(0,0,0,.4) !important}
  /* Hotel Lizenz/Stimmungsbild-Section: einspaltig auf Mobile */
  .jf-hotel-lic-grid{grid-template-columns:1fr !important;min-height:auto !important}
  .jf-hotel-lic-left{padding:48px 24px !important}
  .jf-hotel-lic-right{min-height:0 !important;aspect-ratio:16/9 !important;overflow:hidden !important}
  .jf-hotel-lic-right iframe{position:absolute !important;top:0 !important;left:0 !important;width:100% !important;height:100% !important;min-width:0 !important;min-height:0 !important;transform:none !important}
  .jf-hotel-lic-right img{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;object-fit:cover !important}
  .ph-h1{font-size:26px !important}
  /* Socials Hero: padding-top für fixe Nav */
  #page-socials .socials-hero{padding-top:110px !important;background:#0a0a08 !important;aspect-ratio:auto !important;height:auto !important;display:block !important}
  #page-socials .sh-left{position:relative !important;inset:auto !important;width:100% !important;aspect-ratio:16/9 !important;height:auto !important}
  #page-socials .sh-left-media{position:relative !important;width:100% !important;height:100% !important}
  /* Overlay-Text (Eventbegleitung etc.) raus aus absolute, kommt unter das Video */
  #page-socials .sh-left-overlay{position:relative !important;inset:auto !important;padding:32px 24px !important;background:#0a0a08 !important;color:#fff;justify-content:flex-start !important}
  #page-socials .sh-label{color:rgba(255,255,255,.6) !important}
  #page-socials .sh-h1{color:#fff !important}
  #page-socials .sh-sub{color:rgba(255,255,255,.7) !important;max-width:none !important}
  /* Socials Stimmungssatz: Mobile kleiner — Inline font-size aus Customizer überschreiben */
  #page-socials .stim-satz{font-size:38px !important;line-height:1.15 !important}
  #page-socials .stim-text{padding:32px 24px !important}
  /* About-Facts (Lieferung etc.): einspaltig, linksbündig */
  .about-fact{grid-template-columns:1fr !important;gap:6px !important}
  .af-val{text-align:left !important}
  /* Hotel Projekt-Sections Mobile: einspaltig mit Text oben, dann Medien */
  #page-hotel .pd-item.l,#page-hotel .pd-item.r{display:flex !important;flex-direction:column !important;gap:3px}
  #page-hotel .pd-side{display:contents !important}
  /* Reihenfolge erzwingen */
  #page-hotel .pd-item .pd-text{order:1 !important;padding:32px 24px !important}
  #page-hotel .pd-item.l .pd-big{order:2 !important}
  #page-hotel .pd-item.l .pd-small{order:3 !important}
  #page-hotel .pd-item.r .pd-small{order:2 !important}
  #page-hotel .pd-item.r .pd-big{order:3 !important}
  /* pd-big: jetzt volle Breite, kein 4:3 Korsett, 16:9 für Videos */
  #page-hotel .pd-big{aspect-ratio:16/9 !important;background:#0d0d0b;width:100% !important}
  #page-hotel .pd-small{aspect-ratio:1/1 !important;width:100% !important}
  #page-hotel .pd-small img{object-fit:cover !important}
  /* iframes innerhalb pd-big: cover statt contain → keine schwarzen Balken */
  #page-hotel .pd-big iframe,#page-hotel .pd-small iframe{position:absolute !important;top:0 !important;left:0 !important;width:100% !important;height:100% !important;min-width:0 !important;min-height:0 !important;max-width:none !important;transform:none !important;inset:0 !important;border:0 !important;object-fit:cover}
  #page-hotel .jf-pd-list{max-width:none !important;padding:0 !important;margin:0 !important}
  /* Hotel Suite-bis-Teller Section: Text zuerst, dann Bilder/Videos */
  #page-hotel .stack-inner{display:flex !important;flex-direction:column !important;gap:32px}
  #page-hotel .stack-content{order:1 !important;position:relative !important;top:auto !important}
  #page-hotel .stack-imgs{order:2 !important;width:100% !important;gap:12px !important}
  #page-hotel .stack-img{width:100% !important;margin-left:0 !important}
  .overflow-pq-text{font-size:22px !important}
  .cta-h{font-size:24px !important}
  .stack-grid{display:block !important}
  .sh-layout{grid-template-columns:1fr !important}
  .tc-grid{display:block !important}
  /* Generelle Mobile-Abstände drosseln */
  .sec-header,.faq-header{margin-bottom:32px !important}
  .footer-full{padding:60px 0 40px !important}
}

/* Socials iPhone Feed — länglicheres 9:16 Format */
#iphone-wrap-socials .feed-screen{height:auto;aspect-ratio:9/16}

/* Socials Hero — Jetzt-Anfragen-Button nur so breit wie nötig */
.sh-left-overlay .ph-btn{align-self:flex-start}

/* Socials Projekte — Foto-Slideshow pro Zelle */
.sr-slides{position:absolute;inset:0;width:100%;height:100%}
.sr-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .35s ease}
.sr-slide.is-active{opacity:1}
.sr-slide-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;border:none;background:rgba(0,0,0,.18);color:#fff;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;z-index:3;padding:0;font-family:inherit}
.sr-slide-arrow:hover{background:rgba(0,0,0,.5)}
.sr-slide-prev{left:8px}
.sr-slide-next{right:8px}
@media(max-width:768px){.sr-slide-arrow{width:28px;height:28px;font-size:16px}}

/* Socials Stimmungsbild — 60% Foto/Video links + 40% Text rechts */
.stim-section{width:100%}
.stim-satz{font-family:var(--serif);font-size:clamp(28px,3.4vw,56px);font-weight:300;line-height:1.15;letter-spacing:-.015em;max-width:520px;margin:0}
.stim-satz em{font-style:italic;opacity:.75}
@media(max-width:900px){.stim-section{grid-template-columns:1fr !important;height:auto !important}.stim-media{aspect-ratio:16/9;height:auto}.stim-text{padding:48px 32px !important}.stim-satz{font-size:24px;max-width:none}}

/* Studio Mosaik — Headline + 2 Querformate oben, Liste + 2 Hochformate unten */
.mos-cell{position:relative;overflow:hidden;background:linear-gradient(135deg,#1c1c15,#0d0d0b)}
.mos-cell img,.mos-cell iframe{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:none;pointer-events:none}
.mos-cell.mos-q{aspect-ratio:16/9}
.mos-cell.mos-h{aspect-ratio:9/16}
.mos-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.18);text-align:center;padding:12px}

/* Top: Text links, Querformate rechts — Höhe = Text-Höhe, Breite ergibt sich aus 16:9 */
.mos-top{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:stretch;margin-bottom:48px}
.mos-top-text{display:flex;flex-direction:column}
.mos-top-text .mos-body{margin:24px 0 0 0;max-width:none}
.mos-top-media{display:grid;grid-template-columns:auto auto;gap:8px;height:100%}
.mos-top-media .mos-cell{aspect-ratio:16/9;height:100%;width:auto}

/* Body in voller Breite mit Einrückung der Text-Spalte */
.mos-body{font-size:14px;color:var(--muted);line-height:1.9;font-weight:300}

/* Bottom: Hochformate LINKS (2.4fr, kann nach links ausbrechen via margin-left), Liste RECHTS (1fr) */
.mos-bottom{display:grid;grid-template-columns:minmax(0,2.4fr) minmax(280px,1fr);gap:48px;align-items:stretch}
.mos-bottom-text{display:flex;flex-direction:column;justify-content:flex-start;min-width:280px}
.mos-bottom-text .stack-list{margin-top:0;margin-bottom:0}
.mos-bottom-text .stack-list li{transition:font-size .2s;font-family:var(--sans),'DM Sans',-apple-system,'Helvetica Neue',sans-serif !important;font-style:normal !important;font-weight:300 !important;line-height:1.7 !important;color:var(--ink2) !important;letter-spacing:.005em !important}
.mos-bottom-media{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:0}

@media(max-width:980px){
  .mos-top,.mos-bottom{grid-template-columns:1fr !important;gap:32px;margin-left:0 !important}
  .mos-bottom-text{height:auto;justify-content:flex-start}
  .mos-body{max-width:none;margin-bottom:40px}
}

/* Studio Wunsch-Location — Foto links 30% größer, beide unten bündig */
.wunsch-grid{display:grid;grid-template-columns:60% 40%;gap:32px;align-items:end;max-width:1280px;margin:0 auto}
.wunsch-media{position:relative;overflow:hidden;background:#181810;aspect-ratio:16/9;width:130%;justify-self:end}
.wunsch-media img,.wunsch-media iframe{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:none;pointer-events:none}
.wunsch-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.18);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.wunsch-card{background:var(--white);border:1px solid var(--line);padding:52px 48px;display:flex;flex-direction:column;gap:22px}
.wunsch-card-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.wunsch-card-h{font-family:var(--serif);font-size:clamp(32px,3.2vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.015em;color:var(--ink);margin:0}
.wunsch-card-h em{font-style:italic;color:var(--muted)}
.wunsch-card-body{font-size:15px;color:var(--muted);line-height:1.7;font-weight:300;margin:0}
.wunsch-facts{display:flex;flex-direction:column;border-top:1px solid var(--line);margin-top:4px}
.wunsch-fact{display:grid;grid-template-columns:120px 1fr;gap:20px;padding:15px 0;border-bottom:1px solid var(--line)}
.wf-lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-top:2px}
.wf-val{font-size:15px;color:var(--ink);font-weight:300}
.wunsch-card .btn-primary{align-self:flex-start;margin-top:12px}
@media(max-width:980px){.wunsch-grid{grid-template-columns:1fr;gap:24px;align-items:start}.wunsch-media{width:100%}.wunsch-card{padding:36px 28px}}

/* Globale Bühnen-Begrenzung — alles auf max 1400px symmetrisch zentriert */
html,body{background:var(--off)}
body{overflow-x:hidden}
.jf-stage{max-width:1400px;margin:0 auto;background:var(--off);position:relative;min-height:100vh}

/* Wasserzeichen-Wort in CTAs global aus (war zu aufdringlich über Fotos) */
.cta-wm{display:none !important}

/* ===== BLEED-LOGIK ===== */
/* .jf-fullbleed: Element bricht aus der 1400px-Bühne aus und nimmt volle Browser-Breite ein */
.jf-stage .jf-fullbleed{
  width:100vw;
  margin-left:calc(50% - 50vw);
  position:relative;
}

/* 1400px-Sections (ohne .jf-fullbleed): Bleed in eigener Farbe damit kein heller Außenrand sichtbar */
.jf-stage section:not(.jf-fullbleed):not(.hero):not(.iphone-feed-sec):not(.stim-section),
.jf-stage .cta-dark:not(.jf-fullbleed){
  box-shadow:0 0 0 100vmax var(--bleed,var(--off));
  clip-path:inset(0 -100vmax);
  position:relative;
}
.jf-stage section[style*="--white"]:not(.jf-fullbleed){--bleed:var(--white)}
.jf-stage section[style*="--off"]:not(.jf-fullbleed){--bleed:var(--off)}
.jf-stage section[style*="#f5f4f2"]:not(.jf-fullbleed){--bleed:#f5f4f2}
.jf-stage .faq-sec.dark:not(.jf-fullbleed){--bleed:var(--ink)}
.jf-stage .cta-dark:not(.jf-fullbleed){--bleed:#0d0d0b}

/* Navi voll-breit (war früher position:fixed,left:0,right:0) */
.nav{left:0 !important;right:0 !important;transform:none !important;width:auto !important;max-width:none !important}

/* Sticky-Bar (unten) zentriert auf der 1400px-Bühne */
.sticky-bar{left:50% !important;right:auto !important;transform:translateX(-50%) translateY(100%);max-width:1400px;width:100%}
.sticky-bar.show{transform:translateX(-50%) translateY(0)}
@media(max-width:1440px){.jf-stage{max-width:100%}.sticky-bar{transform:translateY(100%);left:0 !important}.sticky-bar.show{transform:translateY(0)}}

/* ── KUNDEN SETCARD LIGHTBOX ── */
.setcard-lb{position:fixed;inset:0;background:rgba(13,13,11,.92);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;pointer-events:none;transition:opacity .25s ease;padding:24px;overflow-y:auto}
.setcard-lb.open{opacity:1;pointer-events:auto}
.sc-shell{background:#fff;width:100%;max-width:1100px;max-height:calc(100vh - 48px);overflow-y:auto;position:relative}
.sc-topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;background:#0d0d0b;position:sticky;top:0;z-index:2}
.sc-brand{font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.7);font-family:var(--sans)}
.sc-close{background:none;border:0;color:rgba(255,255,255,.85);font-size:24px;cursor:pointer;line-height:1;padding:0 4px;font-family:var(--sans)}
.sc-close:hover{color:#fff}
.sc-body{padding:48px 56px 56px}
.sc-meta{margin-bottom:32px}
.sc-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;font-family:var(--sans)}
.sc-head{font-family:var(--serif);font-size:clamp(28px,3.6vw,42px);font-weight:300;font-style:italic;color:var(--ink);letter-spacing:-.015em;line-height:1.05;margin:0 0 24px}
.sc-divider{height:1px;background:var(--line);margin:0}
.sc-text{font-size:14px;color:var(--muted);line-height:1.75;font-weight:300;margin:24px 0 0;max-width:680px;font-family:var(--sans)}
.sc-website{position:relative;z-index:5;display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:10px 16px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:12px;letter-spacing:.08em;text-transform:lowercase;text-decoration:none;font-family:var(--sans);transition:all .2s;cursor:pointer;pointer-events:auto}
.sc-website:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}
.sc-website-icon{font-size:14px;line-height:1}
.sc-tabs-bar{display:flex;gap:32px;border-bottom:1px solid var(--line);margin-bottom:24px}
.sc-tab{background:none;border:0;padding:14px 0;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);cursor:pointer;font-family:var(--sans);position:relative;font-weight:400}
.sc-tab.active{color:var(--ink)}
.sc-tab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--ink)}
/* ══ NUTZEN-SEKTION ══ */
.jf-nutzen-sec{padding-top:80px;padding-bottom:80px}
.jf-nutzen-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto auto;gap:12px;margin-top:0}
.jf-nutzen-card{background:#fff;border:1px solid #e8e4db;border-radius:8px;padding:24px 20px;display:flex;flex-direction:column;gap:8px}
.jf-nutzen-num{font-size:11px;color:#b0956e;letter-spacing:.12em;font-weight:500}
.jf-nutzen-title{font-size:13px;font-weight:500;color:#1a1a16;line-height:1.35}
.jf-nutzen-text{font-size:12px;color:#999;line-height:1.65;font-weight:300}
.jf-nutzen-foto-wrap{grid-column:3;grid-row:1/4;border-radius:8px;overflow:hidden;background:#e4dfd5;border:1px solid #ddd7cc;min-height:200px}
.jf-nutzen-foto-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
@media(max-width:768px){
  .jf-nutzen-grid{grid-template-columns:1fr 1fr}
  .jf-nutzen-foto-wrap{grid-column:1/3;grid-row:auto;min-height:220px}
}
@media(max-width:480px){
  .jf-nutzen-grid{grid-template-columns:1fr}
  .jf-nutzen-foto-wrap{grid-column:1;min-height:200px}
}
.sc-tab .sc-count{margin-left:6px;color:var(--muted)}
/* Auto-Grid mit 4 Spalten: Quer = 2 Spalten 16:9, Hoch = 1 Spalte 9:16 */
.sc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;grid-auto-flow:dense}
.sc-item{position:relative;overflow:hidden;background:#f1efe8}
.sc-item.sc-quer{grid-column:span 2;padding-bottom:56.25%;height:0}
.sc-item.sc-hoch{grid-column:span 1;padding-bottom:177.78%;height:0}
.sc-item img,.sc-item iframe{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
.sc-item iframe{background:#000}
@media(max-width:900px){
  .sc-grid{grid-template-columns:repeat(2,1fr)}
  .sc-item.sc-quer{grid-column:span 2;padding-bottom:56.25%}
  .sc-item.sc-hoch{grid-column:span 1;padding-bottom:177.78%}
}
@media(max-width:560px){
  .sc-body{padding:32px 24px}
  .sc-grid{grid-template-columns:1fr}
  .sc-item.sc-quer{grid-column:span 1;padding-bottom:56.25%}
  .sc-item.sc-hoch{grid-column:span 1;padding-bottom:177.78%}
  .sc-tabs-bar{gap:20px}
}
