/* JackReport — Luxus in Wien | Relaunch-Pilot */

@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-500-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-500-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-500-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-500-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/cormorant-garamond-600-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/cormorant-garamond-600-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Jost';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/jost-300-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Jost';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/jost-300-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/jost-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/jost-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jost-500-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jost-500-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

:root{
  --black:#0B0B0C;
  --panel:#1A1916;
  --panel-deep:#100F0D;
  --line:#26241F;
  --line-soft:#3A372F;
  --gold:#C5A572;
  --gold-soft:#D9C9A3;
  --ivory:#F2EDE3;
  --muted:#B5AFA2;
  --dim:#8A8374;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--black);color:var(--ivory);font-family:var(--sans);font-weight:400;font-size:18px;line-height:1.75;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:var(--gold);text-decoration:none;transition:color .25s;}
a:hover{color:var(--gold-soft);}
::selection{background:var(--gold);color:var(--black);}

.wrap{max-width:1180px;margin:0 auto;padding:0 28px;}
.narrow{max-width:780px;margin:0 auto;padding:0 28px;}

.kicker{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:400;}
.rule{width:36px;height:1px;background:var(--gold);border:none;margin:26px auto;}
.rule.left{margin:26px 0;}

h1,h2,h3{font-family:var(--serif);font-weight:500;color:var(--ivory);line-height:1.18;}
h1{font-size:clamp(38px,5.5vw,62px);}
h2{font-size:clamp(28px,3.6vw,40px);}
h3{font-size:clamp(22px,2.6vw,27px);}

/* ---------- Header ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .35s,border-color .35s;border-bottom:1px solid transparent;}
.topbar.solid{background:rgba(11,11,12,.96);border-bottom-color:var(--line);}
.topbar .inner{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;max-width:1320px;margin:0 auto;}
.logo{font-family:var(--serif);font-size:22px;letter-spacing:5px;color:var(--ivory);font-weight:500;white-space:nowrap;}
.logo span{color:var(--gold);}
.nav{display:flex;align-items:center;gap:30px;}
.nav a{font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:400;}
.nav a:hover,.nav a.active{color:var(--ivory);}
.nav a.cta{color:var(--gold);border:1px solid var(--gold);padding:10px 20px;transition:all .25s;}
.nav a.cta:hover{background:var(--gold);color:var(--black);}
.burger{display:none;background:none;border:none;cursor:pointer;width:34px;height:26px;position:relative;z-index:60;}
.burger span{display:block;height:1px;background:var(--ivory);margin:7px 0;transition:all .3s;}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:86vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;}
.hero.small{min-height:54vh;}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.hero .shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,12,.38) 0%,rgba(11,11,12,.20) 50%,var(--black) 100%);}
.hero .content{position:relative;z-index:2;padding:140px 28px 90px;max-width:820px;}
.hero p.sub{font-size:19px;font-weight:400;color:#E4DECF;max-width:540px;margin:24px auto 0;}
.hero .actions{margin-top:40px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

.btn{display:inline-block;font-family:var(--sans);font-size:13px;letter-spacing:2.5px;text-transform:uppercase;font-weight:400;padding:15px 32px;cursor:pointer;transition:all .25s;border:1px solid var(--gold);background:var(--gold);color:var(--black);}
.btn:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--black);}
.btn.ghost{background:transparent;color:var(--ivory);border-color:rgba(197,165,114,.55);}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);background:rgba(197,165,114,.08);}

/* ---------- Sections ---------- */
.section{padding:96px 0;}
.section.deep{background:var(--panel-deep);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-head{text-align:center;max-width:680px;margin:0 auto 64px;padding:0 28px;}
.section-head p{color:var(--muted);margin-top:18px;}

/* ---------- Cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:34px;}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr));}
.card{display:block;color:inherit;}
.card .frame{overflow:hidden;background:var(--panel);aspect-ratio:3/2;}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;}
.card:hover img{transform:scale(1.045);}
.card .meta{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin:18px 0 10px;font-weight:400;}
.card .meta .date{color:var(--dim);letter-spacing:1.5px;text-transform:none;}
.card h3{font-size:23px;transition:color .25s;}
.card:hover h3{color:var(--gold-soft);}
.card p.excerpt{font-size:17px;color:var(--muted);margin-top:10px;}

/* ---------- Split feature ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.feature .frame{aspect-ratio:4/3;overflow:hidden;background:var(--panel);}
.feature img{width:100%;height:100%;object-fit:cover;}
.feature h2{margin:16px 0 20px;}
.feature p{color:var(--muted);margin-bottom:14px;}

/* ---------- Article ---------- */
.article-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;}
.article-hero .content{padding:160px 28px 64px;max-width:880px;margin:0 auto;text-align:center;width:100%;}
.article-body{max-width:760px;margin:0 auto;padding:64px 28px 40px;}
.article-body p{margin:0 0 26px;color:#DDD7CA;}
.article-body h2{font-size:32px;margin:64px 0 20px;padding-top:28px;position:relative;}
.article-body h2::before{content:"";position:absolute;top:0;left:0;width:42px;height:1px;background:var(--gold);}
.article-body h3,.article-body h4{font-size:25px;margin:46px 0 16px;font-family:var(--serif);}
.article-body ul,.article-body ol{margin:0 0 26px 22px;color:#DDD7CA;}
.article-body li{margin-bottom:10px;}
.article-body strong,.article-body b{font-weight:500;color:var(--ivory);}
.article-body em{font-style:italic;}
.article-body figure{margin:44px 0;}
.article-body figure img{width:100%;}
.article-body a{border-bottom:1px solid var(--line-soft);}
.article-body a:hover{border-color:var(--gold);}
.article-meta{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:22px;}
.article-meta .date{color:var(--muted);letter-spacing:1.5px;}

/* ---------- Cercle band & forms ---------- */
/* Cercle-Privé „Einladungskarte“ (vor dem Footer) */
.cercle-band{background:var(--black);border-top:1px solid var(--line);text-align:center;padding:100px 28px;position:relative;overflow:hidden;}
.cercle-band::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 56% 72% at 50% 48%,rgba(197,165,114,.08),transparent 72%);pointer-events:none;}
.ci-card{position:relative;max-width:600px;margin:0 auto;background:linear-gradient(160deg,#18130C 0%,#0E0D0B 72%);border:1px solid rgba(197,165,114,.55);padding:58px 50px;box-shadow:0 30px 70px rgba(0,0,0,.55);}
.ci-card::before{content:"";position:absolute;inset:9px;border:1px solid rgba(197,165,114,.26);pointer-events:none;}
.ci-seal{position:relative;display:inline-block;width:62px;height:62px;line-height:60px;border:1px solid rgba(197,165,114,.55);border-radius:50%;font-family:var(--serif);font-size:25px;letter-spacing:3px;color:var(--gold);margin-bottom:18px;}
.ci-card .kicker{position:relative;}
.cercle-band h2{position:relative;font-size:clamp(30px,4vw,42px);margin:8px 0 14px;}
.cercle-band p{position:relative;color:var(--muted);max-width:430px;margin:0 auto;}
.ci-card form{position:relative;margin-top:30px;}
.cercle-band .form-note{position:relative;}
@media(max-width:680px){
  .cercle-band{padding:64px 16px;}
  .ci-card{padding:42px 22px;}
}
.form-row{display:flex;max-width:460px;margin:34px auto 0;}
.form-row input[type=email]{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(197,165,114,.6);border-right:none;color:var(--ivory);font-family:var(--sans);font-weight:400;font-size:15px;padding:15px 18px;min-width:0;}
.form-row input[type=email]::placeholder{color:#C9C2B2;}
.form-row input[type=email]:focus{border-color:var(--gold);background:rgba(255,255,255,.1);}
.form-row .btn{border-left:none;}
.form-note{font-size:13.5px;color:var(--dim);margin-top:16px;}
.consent{display:flex;gap:10px;align-items:flex-start;justify-content:center;max-width:460px;margin:18px auto 0;font-size:14px;color:var(--muted);text-align:left;}
.consent input{margin-top:5px;accent-color:#C5A572;}
.form-success{display:none;margin-top:30px;color:var(--gold);font-size:16px;letter-spacing:.5px;}

.bigform{max-width:560px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr);gap:18px;background:rgba(16,15,13,.72);border:1px solid rgba(197,165,114,.42);padding:42px 40px;box-shadow:0 22px 55px rgba(0,0,0,.4);}
.bigform .consent{display:block;position:relative;padding-left:28px;min-width:0;font-size:14.5px;letter-spacing:normal;text-transform:none;color:var(--muted);line-height:1.6;margin-bottom:0;}
.bigform .consent a{text-transform:none;letter-spacing:normal;}
.bigform .consent input{position:absolute;left:0;top:6px;margin:0;}
.bigform label{font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px;}
.bigform input,.bigform textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(197,165,114,.5);color:var(--ivory);font-family:var(--sans);font-weight:400;font-size:15px;padding:14px 16px;}
.bigform input::placeholder,.bigform textarea::placeholder{color:#C9C2B2;}
.bigform input:focus,.bigform textarea:focus{border-color:var(--gold);background:rgba(255,255,255,.09);}
.bigform .btn{width:100%;}

/* ---------- Benefits ---------- */
.benefits{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line);}
.benefit{background:var(--black);padding:44px 34px;text-align:center;}
.benefit .num{font-family:var(--serif);font-size:30px;color:var(--gold);}
.benefit h3{font-size:22px;margin:14px 0 12px;}
.benefit p{font-size:16.5px;color:var(--muted);}

/* ---------- Filter ---------- */
.filter{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:56px;}
.filter button{background:transparent;border:1px solid var(--line-soft);color:var(--muted);font-family:var(--sans);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;padding:10px 22px;cursor:pointer;transition:all .25s;}
.filter button:hover{color:var(--ivory);border-color:var(--gold);}
.filter button.active{background:var(--gold);border-color:var(--gold);color:var(--black);}

/* ---------- CTA box in articles ---------- */
.cta-box{border:1px solid var(--line);background:var(--panel-deep);text-align:center;padding:52px 36px;margin:64px 0 0;}
.cta-box h3{font-size:26px;}
.cta-box p{color:var(--muted);font-size:15px;max-width:420px;margin:14px auto 26px;}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);padding:64px 0 40px;background:var(--black);}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;}
footer .brand p{color:var(--dim);font-size:14px;max-width:300px;margin-top:14px;}
footer h4{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);font-weight:400;margin-bottom:18px;}
footer ul{list-style:none;}
footer li{margin-bottom:10px;}
footer li a{color:var(--dim);font-size:14.5px;letter-spacing:.5px;}
footer li a:hover{color:var(--gold);}
.footline{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:54px;padding-top:28px;font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);}
.footline a{color:var(--dim);}
.footline a:hover{color:var(--gold);}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .grid,.benefits{grid-template-columns:repeat(2,minmax(0,1fr));}
  .feature{grid-template-columns:1fr;gap:36px;}
  footer .cols{grid-template-columns:1fr 1fr;}
}
@media(max-width:680px){
  .nav{position:fixed;inset:0;background:rgba(11,11,12,.98);flex-direction:column;justify-content:center;gap:34px;display:none;}
  .nav.open{display:flex;}
  .nav a{font-size:16px;}
  .burger{display:block;}
  .grid,.grid.two,.benefits{grid-template-columns:1fr;}
  footer .cols{grid-template-columns:1fr;}
  .form-row{flex-direction:column;}
  .form-row input[type=email]{border-right:1px solid var(--line-soft);}
  .form-row .btn{border-left:1px solid var(--gold);}
  .section{padding:64px 0;}
}

/* ---------- Editorial-Artikel ---------- */
.article-body p.lead{font-family:var(--serif);font-size:23px;line-height:1.6;color:var(--ivory);}
.article-body p.dropcap::first-letter{font-family:var(--serif);font-size:66px;line-height:.85;color:var(--gold);float:left;padding:8px 14px 0 0;}
.article-body .duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:48px 0;}
.article-body .duo figure{margin:0;}
.article-body .duo img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;}
.article-body figure img{width:100%;}
.cta-inline{position:relative;background:linear-gradient(158deg,#1A1712 0%,#100F0D 60%);border:1px solid rgba(197,165,114,.45);padding:54px 44px;margin:72px 0;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.45);overflow:hidden;}
.cta-inline::before{content:"";position:absolute;inset:9px;border:1px solid rgba(197,165,114,.28);pointer-events:none;}
.cta-inline::after{content:"";position:absolute;top:-40%;left:50%;width:120%;height:80%;transform:translateX(-50%);background:radial-gradient(ellipse at 50% 0%,rgba(197,165,114,.14) 0%,rgba(197,165,114,0) 70%);pointer-events:none;}
.cta-inline .kicker{position:relative;}
.cta-inline .seal{position:relative;font-family:var(--serif);font-size:26px;color:var(--gold);letter-spacing:6px;margin-bottom:6px;}
.cta-inline h3{position:relative;font-size:clamp(26px,3.4vw,34px);margin:6px 0 14px;font-weight:500;line-height:1.22;}
.cta-inline p{position:relative;color:var(--gold-soft);font-size:16px;max-width:460px;margin:0 auto 30px;}
.cta-inline .btn{position:relative;box-shadow:0 8px 26px rgba(197,165,114,.22);}
@media(max-width:680px){
  .article-body .duo{grid-template-columns:1fr;}
  .article-body p.lead{font-size:20px;}
}


/* ---------- Feine Animationen ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1);}
.reveal.in{opacity:1;transform:none;}
.grid .card:nth-child(3n+2){transition-delay:.12s;}
.grid .card:nth-child(3n){transition-delay:.24s;}
.benefits .benefit:nth-child(2){transition-delay:.12s;}
.benefits .benefit:nth-child(3){transition-delay:.24s;}
.hero .bg{animation:heroZoom 18s ease-out forwards;}
@keyframes heroZoom{from{transform:scale(1.06)}to{transform:scale(1)}}
.hero .content>*{opacity:0;animation:fadeUp 1.1s cubic-bezier(.22,.61,.36,1) forwards;}
.hero .content>*:nth-child(2){animation-delay:.12s;}
.hero .content>*:nth-child(3){animation-delay:.24s;}
.hero .content>*:nth-child(4){animation-delay:.36s;}
.hero .content>*:nth-child(5){animation-delay:.48s;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.nav a:not(.cta){position:relative;}
.nav a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s ease;}
.nav a:not(.cta):hover::after,.nav a.active:not(.cta)::after{transform:scaleX(1);}
.btn{transition:all .3s ease,letter-spacing .3s ease;}
.btn:hover{letter-spacing:3.5px;}

/* ---------- Bild-Veredelung ---------- */
.card img{filter:saturate(.82);transition:transform .8s ease,filter .8s ease;}
.card:hover img{filter:saturate(1.05);}
.article-body figure img{filter:saturate(.92) contrast(1.02);transition:filter .6s ease;}
.article-body figure:hover img{filter:saturate(1.08);}
.article-body figure.wide{width:min(1020px,calc(100vw - 48px));position:relative;left:50%;margin-left:calc(min(1020px,100vw - 48px)/-2);}
.feature img,.benefit img{filter:saturate(.88);}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .hero .bg{animation:none;}
  .hero .content>*{opacity:1;animation:none;}
}

/* ---------- Fix: Header-Bilder auf Artikel-Seiten ---------- */
.article-hero{overflow:hidden;}
.article-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:heroZoom 18s ease-out forwards;}
.article-hero .shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,12,.28) 0%,rgba(11,11,12,.34) 55%,var(--black) 100%);}
.article-hero .content{position:relative;z-index:2;}
@media(prefers-reduced-motion:reduce){.article-hero .bg{animation:none;}}

/* ---------- Concierge: Feature-Reihen & Zitatband ---------- */
.feature{margin-bottom:88px;}
.feature:last-child{margin-bottom:0;}
.feature.rev .frame{order:2;}
.feature .kicker{display:block;margin-bottom:6px;}
.feature img{filter:saturate(.9);transition:filter .6s ease,transform .8s ease;}
.feature:hover img{filter:saturate(1.05);}
.quoteband{text-align:center;padding:84px 28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--panel-deep);}
.quoteband p{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3vw,32px);color:var(--ivory);max-width:640px;margin:0 auto;line-height:1.4;}
.quoteband .who{font-family:var(--sans);font-style:normal;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-top:22px;}
@media(max-width:920px){.feature.rev .frame{order:0;}.feature{margin-bottom:56px;}}

/* ---------- Lesbarkeit auf hellen Hero-Bildern ---------- */
.hero .shade,.article-hero .shade{background:linear-gradient(180deg,rgba(11,11,12,.6) 0%,rgba(11,11,12,.34) 30%,rgba(11,11,12,.34) 60%,var(--black) 100%);}
.hero .shade::after,.article-hero .shade::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 64% 60% at 50% 52%,rgba(11,11,12,.6) 0%,rgba(11,11,12,0) 100%);}
.article-hero .shade::after{background:radial-gradient(ellipse 75% 55% at 50% 78%,rgba(11,11,12,.55) 0%,rgba(11,11,12,0) 100%);}
.hero .content h1,.article-hero .content h1{text-shadow:0 1px 3px rgba(0,0,0,.55),0 10px 44px rgba(0,0,0,.5);}
.hero .content .kicker,.hero .content p.sub,.article-hero .article-meta{text-shadow:0 1px 3px rgba(0,0,0,.6),0 4px 18px rgba(0,0,0,.5);}
.topbar:not(.solid) .nav a,.topbar:not(.solid) .logo{text-shadow:0 1px 3px rgba(0,0,0,.55);}

/* ---------- Cercle-Privé Feature (Startseite, mittig) ---------- */
.cercle-feature{position:relative;overflow:hidden;text-align:center;padding:110px 28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.cercle-feature .bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(.85);}
.cercle-feature .shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,12,.82) 0%,rgba(11,11,12,.7) 50%,rgba(11,11,12,.86) 100%);}
.cercle-feature .shade::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 50% 50%,rgba(11,11,12,.55) 0%,rgba(11,11,12,0) 75%);}
.cercle-feature .inner{position:relative;z-index:2;max-width:760px;margin:0 auto;}
.cercle-feature .seal{font-family:var(--serif);font-size:30px;letter-spacing:7px;color:var(--gold);margin-bottom:10px;}
.cercle-feature h2{font-size:clamp(32px,4.4vw,48px);margin:6px 0 0;text-shadow:0 2px 20px rgba(0,0,0,.5);}
.cercle-feature .intro{color:#E4DECF;font-size:18px;max-width:520px;margin:20px auto 0;}
.cercle-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin:48px auto 8px;max-width:680px;}
.cercle-trio .item{padding:0 6px;}
.cercle-trio .num{font-family:var(--serif);font-size:22px;color:var(--gold);}
.cercle-trio h4{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--ivory);font-weight:400;margin:10px 0 8px;}
.cercle-trio p{font-size:16px;color:var(--muted);line-height:1.6;}
.cercle-feature form{margin-top:40px;max-width:540px;margin-left:auto;margin-right:auto;background:rgba(16,15,13,.82);border:1px solid rgba(197,165,114,.5);box-shadow:0 24px 60px rgba(0,0,0,.5);padding:34px 30px 28px;}
.cercle-feature form .form-row{margin-top:0;}
.cercle-feature .invite{margin-bottom:18px;}
.cercle-feature .invite{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
@media(max-width:680px){
  .cercle-feature{padding:80px 24px;}
  .cercle-trio{grid-template-columns:1fr;gap:30px;max-width:320px;}
}

/* ========== Accessibility & Bedienbarkeit (UX-Audit) ========== */
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

/* Skip-Link */
.skip{position:absolute;left:16px;top:-60px;z-index:120;background:var(--gold);color:var(--black);padding:12px 22px;font-size:13px;letter-spacing:2px;text-transform:uppercase;transition:top .2s;}
.skip:focus{top:16px;color:var(--black);}

/* Sichtbarer Tastatur-Fokus */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,
.btn:focus-visible,.burger:focus-visible,.filter button:focus-visible,.nav a:focus-visible{
  outline:2px solid var(--gold-soft);outline-offset:3px;border-radius:1px;
}
input:focus-visible,textarea:focus-visible{outline-offset:0;border-color:var(--gold);}

/* Telefon im Header (Persona „Jack“ ruft an) */
.nav a.tel{display:inline-flex;align-items:center;gap:8px;color:var(--gold);font-size:13px;letter-spacing:1.5px;}
.nav a.tel svg{flex:none;}
.nav a.tel span{font-variant-numeric:tabular-nums;}
.nav a.tel:hover{color:var(--gold-soft);}
.nav a.tel::after{display:none;}

/* Schwebender Kontakt-Button (Telefon + WhatsApp) */
/* Exklusiver Sticky-Button → Cercle Privé */
.cercle-fab{position:fixed;right:20px;bottom:20px;z-index:90;display:inline-flex;align-items:center;gap:11px;padding:12px 20px 12px 15px;background:rgba(16,15,13,.94);border:1px solid var(--gold);color:var(--gold);box-shadow:0 10px 30px rgba(0,0,0,.5);transition:background .25s,color .25s,transform .25s;}
.cercle-fab .cf-seal{font-family:var(--serif);font-size:18px;letter-spacing:1px;line-height:1;}
.cercle-fab .cf-label{font-size:12px;letter-spacing:2.5px;text-transform:uppercase;white-space:nowrap;}
.cercle-fab:hover{background:var(--gold);color:var(--black);transform:translateY(-2px);}

/* Footer-Lesbarkeit (kleine Schrift heller) */
footer li a{color:var(--muted);}
.form-note{color:var(--muted);}
.footline,.footline a{color:var(--muted);}

/* Touch-Ziel Burger ≥44px */
.burger{width:44px;height:44px;padding:9px 5px;}

/* Formular-Fehler + Erfolg für Screenreader */
.form-error{display:none;color:#E8B4A0;font-size:14px;margin-top:14px;}
.form-error.show{display:block;}
input[aria-invalid="true"]{border-color:#C98B6F !important;}
.consent.invalid{color:#E8B4A0;}

@media(max-width:680px){
  .nav a.tel{order:-1;font-size:16px;}
  .cercle-fab{right:14px;bottom:14px;padding:11px 16px 11px 13px;}
  .cercle-fab .cf-label{font-size:11px;letter-spacing:2px;}
}

/* ========== Artikel-Block-Design ========== */
/* Standfirst / Lead */
.article-body p.lead{font-family:var(--serif);font-size:25px;line-height:1.5;color:var(--ivory);margin-bottom:38px;}
.article-body p.lead.dropcap::first-letter{font-size:74px;padding:10px 16px 2px 0;}

/* Pull-Quote (aus einer hervorgehobenen Aussage des Artikels) */
.article-body .pull{margin:60px 0;text-align:center;border:none;padding:0;}
.article-body .pull::before{content:"\201E";display:block;font-family:var(--serif);font-size:60px;line-height:.5;color:var(--gold);margin:0 0 18px;}
.article-body .pull p{font-family:var(--serif);font-style:italic;font-size:clamp(25px,3.3vw,33px);line-height:1.36;color:var(--ivory);max-width:620px;margin:0 auto;}
.article-body .pull::after{content:"";display:block;width:40px;height:1px;background:var(--gold);margin:24px auto 0;}

/* Echtes Zitat im Inhalt */
.article-body blockquote{margin:48px 0;padding:6px 0 6px 28px;border-left:2px solid var(--gold);font-family:var(--serif);font-style:italic;font-size:24px;line-height:1.45;color:var(--ivory);}

/* Bildunterschrift (optional) */
.article-body figure figcaption{margin-top:12px;font-size:13px;letter-spacing:.3px;color:var(--dim);text-align:center;}

@media(max-width:680px){
  .article-body p.lead{font-size:21px;}
  .article-body .pull p{font-size:23px;}
}

/* ========== Mobile-Feinschliff ========== */
@media(max-width:680px){
  /* Große Formulare (Cercle-Anmeldung, Concierge-Anfrage): kompakter, randsicher */
  .bigform{padding:30px 22px;}
  .bigform .grid.two{gap:14px;}
  /* Anfrage-/Anmelde-Sektionen: etwas Luft, falls direkt in .section */
  .section > .bigform{margin-top:8px;}
  /* Inline-CTA im Artikel kompakter */
  .cta-inline{padding:38px 24px;margin:52px 0;}
  .cta-inline .seal{font-size:22px;}
  /* Cercle-Feature kompakter, Trio-Abstände */
  .cercle-feature{padding:72px 22px;}
  .cercle-trio{margin:36px auto 4px;}
  /* Concierge Feature-Reihen: Bild nicht zu hoch, Text Abstand */
  .feature .frame{aspect-ratio:3/2;}
  /* Quote-Band Innenabstand */
  .quoteband{padding:64px 24px;}
  /* Section-Heads & Narrow konsistent eingerückt */
  .section-head{padding-left:22px;padding-right:22px;}
  /* Hero-Buttons volle Breite, sauber untereinander */
  .hero .actions{flex-direction:column;align-items:stretch;gap:12px;width:100%;max-width:320px;margin-left:auto;margin-right:auto;}
  .hero .actions .btn{text-align:center;}
  /* Kontakt-FAB etwas kleiner, damit er mobil nicht stört */
  .cercle-feature form{padding:26px 20px 24px;}
}
@media(max-width:380px){
  .logo{font-size:19px;letter-spacing:4px;}
  h1{font-size:34px;}
  .article-body{padding-left:20px;padding-right:20px;}
}

/* Navigation: bis Tablet-Breite (≤980px) Burger-Menü, damit der Header nie gedrängt wirkt */
@media(max-width:980px){
  .nav{position:fixed;inset:0;background:rgba(11,11,12,.98);flex-direction:column;justify-content:center;gap:34px;display:none;}
  .nav.open{display:flex;}
  .nav a{font-size:16px;}
  .nav a.cta{padding:12px 26px;}
  .burger{display:block;}
}

/* ========== Große Bildschirme (4K / Ultrawide): breitere Spalten + größere Schrift ========== */
@media(min-width:1600px){
  body{font-size:19.5px;}
  .wrap{max-width:1360px;}
  .narrow{max-width:880px;}
  .topbar .inner{max-width:1560px;}
  .nav a{font-size:14px;}
  .logo{font-size:24px;}
  .hero p.sub{font-size:21px;max-width:600px;}
  .hero .content{max-width:920px;}
  .section-head{max-width:760px;}
  .section-head p{font-size:19px;}
  .benefit p,.card p.excerpt{font-size:18px;}
  .cercle-trio p{font-size:17.5px;}
  .cercle-feature .intro,.cercle-band p{font-size:19px;}
  .cercle-feature .inner{max-width:1040px;}
  .cercle-feature h2{font-size:54px;}
  .cercle-feature .intro{max-width:640px;}
  .cercle-trio{max-width:940px;gap:44px;}
  .cercle-trio h4{font-size:14px;}
  .cercle-feature form{max-width:620px;}
  .article-body{max-width:840px;}
  .article-body h2{font-size:36px;}
  .article-body p.lead{font-size:27px;}
}
@media(min-width:2100px){
  body{font-size:22px;}
  .wrap{max-width:1620px;}
  .narrow{max-width:1000px;}
  .topbar .inner{max-width:1840px;}
  .nav a{font-size:15px;letter-spacing:3px;}
  .logo{font-size:27px;}
  h1{font-size:clamp(38px,5.5vw,88px);}
  .hero p.sub{font-size:24px;max-width:680px;}
  .hero .content{max-width:1040px;}
  .section-head p{font-size:21px;}
  .benefit p,.card p.excerpt{font-size:20px;}
  .cercle-trio p{font-size:19px;}
  .cercle-feature .intro,.cercle-band p{font-size:21px;}
  .cercle-feature .inner{max-width:1280px;}
  .cercle-feature h2{font-size:64px;}
  .cercle-feature .intro{max-width:720px;}
  .cercle-trio{max-width:1140px;gap:60px;}
  .cercle-trio h4{font-size:15px;}
  .cercle-feature form{max-width:680px;}
  .ci-card{max-width:720px;}
  .benefit{padding:54px 40px;}
  .article-body{max-width:920px;}
  .article-body h2{font-size:40px;}
  .article-body p.lead{font-size:30px;}
}

/* ========== Handy: kleine Texte etwas größer für bessere Lesbarkeit ========== */
@media(max-width:680px){
  .benefit p,.card p.excerpt,.cercle-trio p{font-size:17px;}
  .cercle-feature .intro,.cercle-band p,.section-head p{font-size:17px;}
  .consent{font-size:14.5px;}
  .form-note{font-size:14px;}
  .article-body p{font-size:18.5px;}
}

/* ========== FAQ (Fragen & Antworten) ========== */
.faq .faq-item{border-top:1px solid var(--line);}
.faq .faq-item:last-child{border-bottom:1px solid var(--line);}
.faq summary{list-style:none;cursor:pointer;padding:24px 44px 24px 0;position:relative;font-family:var(--serif);font-size:23px;color:var(--ivory);transition:color .25s;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-weight:300;font-size:26px;color:var(--gold);transition:transform .3s;}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg);}
.faq summary:hover{color:var(--gold-soft);}
.faq .faq-a{padding:0 44px 26px 0;}
.faq .faq-a p{margin:0;color:var(--muted);}
.faq summary:focus-visible{outline:2px solid var(--gold-soft);outline-offset:3px;}
@media(max-width:680px){
  .faq summary{font-size:20px;padding-right:36px;}
}

/* ----- Cookie-Consent-Banner (DSGVO, Opt-in, Consent Mode v2) ----- */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:300;background:rgba(11,11,12,.975);border-top:1px solid rgba(197,165,114,.35);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:16px clamp(16px,4vw,40px);box-shadow:0 -10px 40px rgba(0,0,0,.45)}
.cc-banner[hidden]{display:none}
.cc-inner{max-width:1120px;margin:0 auto;display:flex;gap:24px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cc-text{margin:0;color:#C9C2B4;font-size:14px;line-height:1.55;max-width:720px}
.cc-text a{color:#C5A572;text-decoration:underline}
.cc-actions{display:flex;gap:10px;flex-shrink:0}
.cc-btn{font-family:inherit;font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;padding:12px 24px;border:1px solid rgba(197,165,114,.5);background:transparent;color:#E9E2D4;cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.cc-btn:hover{border-color:#C5A572}
.cc-accept{background:#C5A572;color:#0B0B0C;border-color:#C5A572}
.cc-accept:hover{background:#d4b884;border-color:#d4b884}
.cc-reopen{background:none;border:0;padding:0;color:inherit;font:inherit;cursor:pointer;text-decoration:underline}
.cc-reopen:hover{color:#C5A572}
@media(max-width:680px){.cc-inner{flex-direction:column;align-items:stretch;gap:14px}.cc-actions{justify-content:stretch}.cc-btn{flex:1}}

/* ----- Wien-Guide Landingpage (Lead-Magnet) ----- */
.guide-lead{display:grid;grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);gap:clamp(28px,5vw,64px);align-items:center}
.guide-cover{margin:0}
.guide-cover img{width:100%;height:auto;display:block;box-shadow:0 30px 70px rgba(0,0,0,.55);border:1px solid rgba(197,165,114,.25)}
.guide-pitch .kicker{color:#C5A572;letter-spacing:2px;text-transform:uppercase;font-size:12.5px}
.guide-pitch h2{margin:.35em 0 .55em}
.guide-toc{list-style:none;padding:0;margin:22px 0 30px;border-top:1px solid rgba(197,165,114,.25)}
.guide-toc li{padding:11px 0 11px 28px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;color:#C9C2B4}
.guide-toc li::before{content:"—";position:absolute;left:0;color:#C5A572}
.guide-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:6px}
.guide-gallery img{width:100%;height:auto;display:block;box-shadow:0 16px 40px rgba(0,0,0,.45);border:1px solid rgba(197,165,114,.18);transition:transform .3s ease}
.guide-gallery img:hover{transform:translateY(-6px)}
@media(max-width:900px){.guide-lead{grid-template-columns:1fr;max-width:540px;margin:0 auto}.guide-gallery{grid-template-columns:repeat(2,1fr)}}

/* Fix: .narrow verlor durch den .section-Shorthand (padding:96px 0) seinen Seitenabstand
   → auf Mobil klebte der Text am Rand. Longhand nach .section stellt ihn wieder her. */
.narrow{padding-left:28px;padding-right:28px;}
@media(max-width:680px){
  .narrow{padding-left:24px;padding-right:24px;}
  .article-body{padding-left:24px;padding-right:24px;}
}

/* Fix: Consent-Checkbox erbte sonst width:100% von .bigform input → Haken saß zentriert */
.bigform .consent input[type=checkbox]{width:auto;height:auto;}

/* Funktionierende Sprungmarken: Abstand unter dem Sticky-Header (kein smooth — unterdrückt sonst den Sprung) */
.article-body h2[id]{scroll-margin-top:96px;}

/* ----- Startseiten-Pop-up: Gratis Wien-Guide ----- */
.guide-pop{position:fixed;inset:0;z-index:400;background:rgba(8,8,9,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:gp-fade .45s ease;}
.guide-pop[hidden]{display:none;}
@keyframes gp-fade{from{opacity:0}to{opacity:1}}
.guide-pop-box{position:relative;display:flex;width:100%;max-width:640px;background:#0F0E0C;border:1px solid rgba(197,165,114,.42);box-shadow:0 40px 100px rgba(0,0,0,.6);animation:gp-rise .5s cubic-bezier(.2,.7,.2,1);}
@keyframes gp-rise{from{transform:translateY(16px);opacity:.4}to{transform:none;opacity:1}}
.guide-pop-cover{width:42%;object-fit:cover;display:block;border-right:1px solid rgba(197,165,114,.2);}
.guide-pop-body{padding:38px 34px;display:flex;flex-direction:column;justify-content:center;}
.guide-pop-body .kicker{color:#C5A572;letter-spacing:2px;text-transform:uppercase;font-size:11.5px;}
.guide-pop-body h3{font-family:var(--serif);font-size:30px;margin:.3em 0 .45em;line-height:1.1;}
.guide-pop-body p{color:#C9C2B4;font-size:15px;line-height:1.6;margin:0 0 24px;}
.guide-pop-body .btn{align-self:flex-start;}
.guide-pop-x{position:absolute;top:8px;right:14px;background:none;border:0;color:#C9C2B4;font-size:30px;line-height:1;cursor:pointer;z-index:2;}
.guide-pop-x:hover{color:#C5A572;}
.guide-pop-later{background:none;border:0;color:var(--muted);font-size:13px;cursor:pointer;margin-top:16px;text-decoration:underline;align-self:flex-start;padding:0;}
.guide-pop-later:hover{color:#C5A572;}
@media(max-width:680px){
  .guide-pop-box{flex-direction:column;max-width:330px;max-height:90vh;overflow:auto;text-align:center;}
  .guide-pop-cover{width:auto;max-width:158px;height:auto;margin:30px auto 2px;border:1px solid rgba(197,165,114,.32);box-shadow:0 14px 34px rgba(0,0,0,.5);}
  .guide-pop-body{padding:16px 26px 26px;align-items:center;}
  .guide-pop-body h3{font-size:26px;}
  .guide-pop-body .btn{align-self:center;}
  .guide-pop-later{align-self:center;}
  .guide-pop-x{top:6px;right:10px;}
}

/* Honeypot-Feld (Bot-Schutz) — für Menschen komplett unsichtbar, niemals interaktiv */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none;}
