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

/* =============================================================
 * Kronjuwelier — main.css
 * Front-end styles. theme.json handles design tokens (colors,
 * typography, spacing); this file handles layout, components,
 * navigation, animations, custom blocks.
 * ============================================================= */

/* ---- 1. base reset + globals ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
.wp-block-image img{display:block}
button{font:inherit;cursor:pointer}
:root{
  --line:rgba(201,161,74,0.22);
  --line-strong:rgba(201,161,74,0.45);
  --muted:rgba(245,239,226,0.62);
  --shadow:0 30px 80px -20px rgba(0,0,0,0.6);
}

/* ---- 2. site header & navigation ---- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  background:linear-gradient(to bottom, rgba(10,15,31,0.55), rgba(10,15,31,0));
  transition:background .35s ease, padding .35s ease, backdrop-filter .35s ease;
}
.site-header-inner{
  max-width:1560px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;
}
.site-header.scrolled,
.site-header.solid{
  background:rgba(10,15,31,0.92);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  padding:12px 0;border-bottom:1px solid var(--line);
}
@media (max-width:1100px){
  .site-header-inner{padding:0 24px}
}
@media (max-width:880px){
  .site-header{
    background:rgba(10,15,31,0.94);
    backdrop-filter:blur(14px) saturate(140%);
    -webkit-backdrop-filter:blur(14px) saturate(140%);
    border-bottom:1px solid var(--line);
  }
}
.standort-notice{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:200;
  background:linear-gradient(135deg, rgba(20,26,48,0.96) 0%, rgba(12,20,40,0.96) 100%);
  color:#f5efe2;
  font-size:14px;letter-spacing:.02em;line-height:1.5;
  padding:14px 56px 14px 24px;
  border:1px solid rgba(201,161,74,0.45);border-radius:4px;
  box-shadow:0 24px 56px -16px rgba(0,0,0,0.7), 0 0 0 1px rgba(0,0,0,0.4);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  display:inline-flex;align-items:center;gap:12px;flex-wrap:nowrap;
  width:auto;max-width:760px;
  transition:opacity .3s ease, transform .3s ease;
}
@media (max-width:780px){
  .standort-notice{
    position:relative;top:auto;left:auto;transform:none;
    width:100%;max-width:none;border-radius:0;
    border-left-width:0;border-right-width:0;
    padding:10px 56px 10px 24px;
    box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;
    flex-wrap:wrap;justify-content:center;text-align:center;font-size:13px;
  }
}
.standort-notice.out{opacity:0;transform:translate(-50%, -16px) scale(.96);pointer-events:none}
@media (max-width:780px){.standort-notice.out{transform:translateY(-12px)}}
.standort-close{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:transparent;border:0;color:#f5efe2;opacity:.55;
  width:32px;height:32px;font-size:22px;line-height:1;
  cursor:pointer;transition:opacity .2s, color .2s;
  display:inline-flex;align-items:center;justify-content:center;
}
.standort-close:hover{opacity:1;color:#e6c879}
.standort-notice strong{color:#e6c879;font-weight:600}
.standort-notice a{color:#e6c879;text-decoration:none;border-bottom:1px solid rgba(230,200,121,0.4)}
.standort-notice a:hover{border-bottom-color:#e6c879}
.standort-notice .dot{
  width:8px;height:8px;border-radius:50%;background:#e6c879;
  box-shadow:0 0 0 0 rgba(230,200,121,0.6);animation:standort-pulse 2.2s ease-out infinite;
  flex-shrink:0;
}
@keyframes standort-pulse{0%{box-shadow:0 0 0 0 rgba(230,200,121,0.6)}70%{box-shadow:0 0 0 10px rgba(230,200,121,0)}100%{box-shadow:0 0 0 0 rgba(230,200,121,0)}}
@media (max-width:680px){.standort-notice{font-size:12px;padding:8px 14px;text-align:left}}

.site-brand{
  display:flex;align-items:center;text-decoration:none;
  height:88px;flex-shrink:0;
}
.site-brand img{
  height:100%;width:auto;display:block;
}
@media (max-width:880px){
  .site-brand{height:60px}
}

.primary-nav{display:flex;gap:38px;align-items:center;font-size:14px}
.primary-nav .menu-item{position:relative;list-style:none}
.primary-nav a{
  color:var(--wp--preset--color--cream);opacity:.88;
  font-size:14px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  padding:10px 0;display:inline-flex;align-items:center;gap:6px;
  transition:opacity .2s,color .2s;text-decoration:none;
}
.primary-nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--wp--preset--color--gold);transform:scaleX(0);transform-origin:center;
  transition:transform .3s ease;
}
.primary-nav .menu-item:hover > a,
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-ancestor > a{opacity:1;color:var(--wp--preset--color--gold-bright)}
.primary-nav .menu-item:hover > a::after,
.primary-nav .current-menu-item > a::after,
.primary-nav .current-menu-ancestor > a::after{transform:scaleX(1)}

/* Dropdown */
.primary-nav .sub-menu{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:280px;padding:18px 0;margin:0;list-style:none;
  background:rgba(10,15,31,0.97);backdrop-filter:blur(18px);
  border:1px solid var(--line);border-radius:2px;
  opacity:0;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
}
.primary-nav .menu-item:hover > .sub-menu,
.primary-nav .menu-item:focus-within > .sub-menu{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.primary-nav .sub-menu li{margin:0;list-style:none}
.primary-nav .sub-menu a{
  display:block;padding:10px 24px;
  font-size:13px;letter-spacing:.04em;text-transform:none;
  color:var(--wp--preset--color--cream);opacity:.85;font-weight:400;
  transition:background .2s,color .2s,padding-left .2s;
}
.primary-nav .sub-menu a:hover{
  background:rgba(201,161,74,0.06);
  color:var(--wp--preset--color--gold-bright);
  padding-left:28px;
}
.primary-nav .sub-menu a::after{display:none}

.nav-phone{
  padding:10px 20px;border:1px solid var(--wp--preset--color--gold);
  color:var(--wp--preset--color--gold-bright);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  transition:background .25s,color .25s;border-radius:1px;text-decoration:none;
}
.nav-phone:hover{background:var(--wp--preset--color--gold);color:var(--wp--preset--color--ink)}

.nav-burger{
  display:none;width:36px;height:28px;
  flex-direction:column;justify-content:center;align-items:center;gap:7px;
  cursor:pointer;z-index:301;position:relative;background:transparent;border:0;
}
.nav-burger span{
  display:block;width:24px;height:1.5px;
  background:var(--wp--preset--color--cream);
  transition:transform .35s cubic-bezier(.7,.2,.3,1), opacity .25s;
}
body.drawer-open .nav-burger span:nth-child(1){transform:translateY(4px) rotate(45deg)}
body.drawer-open .nav-burger span:nth-child(2){opacity:0}
body.drawer-open .nav-burger span:nth-child(3){transform:translateY(-4px) rotate(-45deg)}

@media (max-width: 980px){
  .site-header{padding:14px 20px}
  .primary-nav{display:none}
  .nav-burger{display:flex}
  .nav-phone{padding:8px 14px;font-size:11px}
}

/* ---- 3. mobile drawer ---- */
.drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:100%;max-width:520px;z-index:300;
  background:linear-gradient(180deg, var(--wp--preset--color--ink) 0%, var(--wp--preset--color--velvet-2) 100%);
  border-left:1px solid var(--line);
  transform:translateX(100%);
  transition:transform .55s cubic-bezier(.7,.2,.2,1);
  display:flex;flex-direction:column;overflow-y:auto;
  padding:96px 32px 40px;
}
body.drawer-open .drawer{transform:translateX(0)}
.drawer-backdrop{
  position:fixed;inset:0;z-index:299;
  background:rgba(10,15,31,0.65);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .35s;
}
body.drawer-open .drawer-backdrop{opacity:1;pointer-events:auto}
body.drawer-open{overflow:hidden}

.drawer-eyebrow{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--wp--preset--color--gold-bright);
  margin-bottom:24px;font-weight:500;
}
.drawer-pillar{
  display:block;font-family:var(--wp--preset--font-family--serif);
  font-weight:400;font-size:48px;line-height:1;letter-spacing:-.005em;
  color:var(--wp--preset--color--cream);
  padding:18px 0;border-bottom:1px solid var(--line);
  position:relative;transition:color .25s, padding-left .35s;text-decoration:none;
}
.drawer-pillar em{font-style:italic;color:var(--wp--preset--color--gold-bright)}
.drawer-pillar:hover,.drawer-pillar.active{color:var(--wp--preset--color--gold-bright);padding-left:12px}
.drawer-pillar::after{
  content:"→";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:24px;color:var(--wp--preset--color--gold);opacity:.5;
  font-family:var(--wp--preset--font-family--sans);font-weight:300;
}
.drawer-pillar .sub{
  display:block;font-family:var(--wp--preset--font-family--sans);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-top:6px;font-weight:500;
}
.drawer-secondary{
  margin-top:36px;padding-top:32px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:18px;
}
.drawer-secondary a{
  font-size:14px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  color:var(--wp--preset--color--cream);opacity:.85;text-decoration:none;
  transition:color .2s,opacity .2s;
}
.drawer-secondary a:hover{color:var(--wp--preset--color--gold-bright);opacity:1}
.drawer-cta{margin-top:auto;padding-top:48px}
.drawer-cta-label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.drawer-cta-num{
  font-family:var(--wp--preset--font-family--serif);font-size:32px;font-weight:600;
  color:var(--wp--preset--color--gold-bright);
  display:block;letter-spacing:.02em;text-decoration:none;
}
.drawer-cta-mob{font-size:13px;color:var(--muted);margin-top:14px;display:block}
.drawer-cta-mob a{color:var(--wp--preset--color--gold-bright);text-decoration:none}
@media (max-width: 560px){
  .drawer{padding:88px 24px 32px}
  .drawer-pillar{font-size:40px;padding:14px 0}
}

/* ---- 4. hero variants ---- */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  display:flex;align-items:center;overflow:hidden;
  background:var(--wp--preset--color--velvet);
}
.hero__image{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);
  animation:hero-zoom 24s ease-in-out infinite alternate;
  filter:brightness(.92);
}
@keyframes hero-zoom{from{transform:scale(1) translateX(0)}to{transform:scale(1.12) translateX(-2%)}}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg, rgba(10,15,31,0.85) 0%, rgba(10,15,31,0.6) 40%, rgba(10,15,31,0.2) 65%, rgba(10,15,31,0) 100%),
             linear-gradient(180deg, rgba(10,15,31,0.0) 60%, rgba(10,15,31,0.7) 100%);
}
.hero__content{
  position:relative;z-index:2;width:100%;
  max-width:1280px;margin:0 auto;
  padding:140px 48px 100px;
  display:grid;grid-template-columns:minmax(0,640px) 1fr;gap:48px;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--wp--preset--color--gold-bright);
  margin-bottom:32px;font-weight:500;
}
.hero__eyebrow::before{content:"";width:40px;height:1px;background:var(--wp--preset--color--gold)}
.hero h1{
  font-family:var(--wp--preset--font-family--serif);font-weight:500;
  font-size:clamp(40px, 5.4vw, 76px);line-height:1.04;letter-spacing:-.005em;
  margin:0 0 32px;color:var(--wp--preset--color--cream);
}
.hero h1 em{font-style:italic;color:var(--wp--preset--color--gold-bright)}
.hero__sub{
  font-size:18px;line-height:1.7;color:var(--wp--preset--color--cream);
  opacity:.86;max-width:540px;margin:0 0 20px;font-weight:300;
}
.hero__tv{
  font-size:13px;color:var(--muted);margin:0 0 36px;
  font-style:italic;border-left:2px solid var(--wp--preset--color--gold);
  padding:4px 0 4px 16px;
}
.hero__tv strong{color:var(--wp--preset--color--gold-bright);font-style:normal;font-weight:500}

/* Hub hero (taller image, content bottom) */
.hub-hero{
  position:relative;min-height:80vh;min-height:80svh;
  display:flex;align-items:flex-end;overflow:hidden;
  background:var(--wp--preset--color--velvet);
}
.hub-hero__image{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.05);
  animation:hero-zoom 26s ease-in-out infinite alternate;
  filter:brightness(.95);
}
.hub-hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(10,15,31,0.3) 0%, rgba(10,15,31,0.0) 30%, rgba(10,15,31,0.6) 100%);
}
.hub-hero__content{
  position:relative;z-index:2;width:100%;max-width:1280px;margin:0 auto;
  padding:160px 48px 80px;
  display:grid;grid-template-columns:1fr minmax(0, 540px);gap:48px;align-items:end;
}
.breadcrumb{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--muted);margin-bottom:24px;
}
.breadcrumb a{color:var(--muted);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--wp--preset--color--gold-bright)}
.breadcrumb span{color:var(--wp--preset--color--gold-bright)}
.hub-hero h1{
  font-family:var(--wp--preset--font-family--serif);font-weight:400;
  font-size:clamp(56px, 8vw, 120px);line-height:0.95;letter-spacing:-.01em;
  margin:0;color:var(--wp--preset--color--cream);
}
.hub-hero h1 em{font-style:italic;color:var(--wp--preset--color--gold-bright)}

@media (max-width: 980px){
  .hero__image{
    background-position: 72% 55%;
    animation: hero-zoom-mobile 28s ease-in-out infinite alternate;
  }
  @keyframes hero-zoom-mobile{from{transform:scale(1.05)}to{transform:scale(1.18) translateX(-3%)}}
  .hero__content{padding:130px 20px 80px;grid-template-columns:1fr;align-content:end}
  .hero__overlay{background:linear-gradient(180deg, rgba(10,15,31,0.55) 0%, rgba(10,15,31,0.25) 35%, rgba(10,15,31,0.55) 65%, rgba(10,15,31,0.95) 100%)}
  .hero h1{font-size:42px}
  .hub-hero__content{padding:140px 20px 60px;grid-template-columns:1fr;gap:24px}
  .hub-hero h1{font-size:54px}
}

/* ---- 5. sections base ---- */
.section{padding:120px 32px}
.section--lg{padding:140px 32px}
.section--narrow{padding:80px 32px}
.section--ink{background:var(--wp--preset--color--ink)}
.section--ink-2{background:var(--wp--preset--color--ink-2)}
.section--velvet{background:var(--wp--preset--color--velvet)}
.section--gradient-ink{background:linear-gradient(180deg, var(--wp--preset--color--velvet) 0%, var(--wp--preset--color--ink) 100%)}
.wrap{max-width:1280px;margin:0 auto}
.wrap--narrow{max-width:860px;margin:0 auto}
.eyebrow{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--wp--preset--color--gold-bright);
  margin-bottom:18px;font-weight:500;
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--wp--preset--color--gold)}
.eyebrow.centered{justify-content:center}
.eyebrow.centered::before{display:none}
.lead{
  font-size:17px;line-height:1.75;
  color:var(--wp--preset--color--cream);opacity:.78;
  max-width:680px;margin:0 0 56px;font-weight:300;
}

/* ---- 6. bekannt aus strip ---- */
.bekannt{
  background:var(--wp--preset--color--ink);
  border-block:1px solid var(--line);
  padding:40px 32px;text-align:center;
}
.bekannt__label{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);margin:0 0 20px;font-weight:500}
.bekannt__logos{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:52px;
  font-family:var(--wp--preset--font-family--serif);font-weight:700;font-size:28px;
  color:var(--wp--preset--color--cream);opacity:.85;letter-spacing:.04em;
}
@media (max-width: 600px){.bekannt__logos{gap:26px;font-size:22px}}

/* ---- 7. editorial intro ---- */
.editorial-intro{
  background:linear-gradient(180deg, var(--wp--preset--color--velvet) 0%, var(--wp--preset--color--ink) 100%);
  padding:140px 32px;
}
.editorial-intro__grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;
}
.editorial-intro__image{
  position:relative;border-radius:2px;overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:4/5;
}
.editorial-intro__image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s cubic-bezier(.2,.7,.2,1);
}
.editorial-intro__image:hover img{transform:scale(1.04)}
.editorial-intro h2{
  font-family:var(--wp--preset--font-family--serif);font-weight:500;
  font-size:clamp(34px, 4vw, 54px);line-height:1.1;
  margin:24px 0 28px;color:var(--wp--preset--color--cream);letter-spacing:-.003em;
}
.editorial-intro h2 em{font-style:italic;color:var(--wp--preset--color--gold-bright)}
.editorial-intro p{font-size:17px;line-height:1.85;color:var(--wp--preset--color--cream);opacity:.86;margin:0 0 18px;font-weight:300}
.editorial-intro .signature{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--line);
  font-family:var(--wp--preset--font-family--serif);font-style:italic;
  font-size:20px;color:var(--wp--preset--color--gold-bright);
}
@media (max-width: 880px){
  .editorial-intro__grid{grid-template-columns:1fr;gap:48px}
  .editorial-intro__image{aspect-ratio:16/10}
}

/* ---- 8. three pillars ---- */
.pillars-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;margin-top:56px}
.pillar-card{
  position:relative;aspect-ratio:3/4;overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;justify-content:flex-end;
  border:1px solid var(--line);transition:border-color .35s;
  text-decoration:none;color:inherit;
}
.pillar-card:hover{border-color:var(--wp--preset--color--gold)}
.pillar-card__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.pillar-card:hover .pillar-card__bg{transform:scale(1.05)}
.pillar-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,15,31,0.0) 25%, rgba(10,15,31,0.65) 70%, rgba(10,15,31,0.95) 100%)}
.pillar-card__content{position:relative;z-index:1;padding:48px 36px 44px}
.pillar-card__content .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);margin-bottom:12px;font-weight:500;display:block}
.pillar-card__content h3{font-family:var(--wp--preset--font-family--serif);font-weight:500;font-size:36px;line-height:1.1;margin:0 0 12px;color:var(--wp--preset--color--cream)}
.pillar-card__content p{font-size:14px;line-height:1.65;color:var(--wp--preset--color--cream);opacity:.82;margin:0 0 18px;font-weight:300}
.pillar-card__content .more{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:gap .25s}
.pillar-card:hover .pillar-card__content .more{gap:14px}
@media (max-width: 880px){.pillars-grid{grid-template-columns:1fr;gap:16px}.pillar-card{aspect-ratio:16/9}}

/* ---- 9. featured articles grid ---- */
.features-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
.feature-card{
  position:relative;overflow:hidden;
  border:1px solid var(--line);background:var(--wp--preset--color--velvet);
  transition:border-color .35s ease, transform .35s ease;
  cursor:pointer;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
}
.feature-card:hover{border-color:var(--wp--preset--color--gold)}
.feature-card__img{position:relative;overflow:hidden;aspect-ratio:16/10}
.feature-card--big .feature-card__img{aspect-ratio:5/4}
.feature-card__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.feature-card:hover .feature-card__bg{transform:scale(1.06)}
.feature-card__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,15,31,0) 50%, rgba(10,15,31,0.7) 100%)}
.feature-card__body{padding:30px 32px 36px;flex-grow:1;display:flex;flex-direction:column}
.feature-card .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);margin-bottom:14px;font-weight:500}
.feature-card h3{font-family:var(--wp--preset--font-family--serif);font-weight:600;font-size:24px;line-height:1.22;color:var(--wp--preset--color--cream);margin:0 0 14px}
.feature-card--big h3{font-size:30px}
.feature-card p{font-size:14px;line-height:1.65;color:var(--muted);margin:0 0 24px;flex-grow:1}
.feature-card .more{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:gap .25s}
.feature-card:hover .more{gap:14px}
.feature-card .coming{display:inline-block;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--wp--preset--color--gold-soft);border:1px solid var(--wp--preset--color--gold-soft);padding:3px 8px;border-radius:1px;margin-bottom:14px}
@media (max-width: 980px){.features-grid{grid-template-columns:1fr 1fr}.feature-card--big{grid-column:span 2}}
@media (max-width: 660px){.features-grid{grid-template-columns:1fr}.feature-card--big{grid-column:span 1}}

/* ---- 10. knowledge hub grid ---- */
.know-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin-top:48px}
.know-card{
  background:var(--wp--preset--color--ink-2);
  padding:36px 32px;transition:background .35s;cursor:pointer;
  text-decoration:none;color:inherit;display:block;
}
.know-card:hover{background:var(--wp--preset--color--velvet-2)}
.know-card .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);margin-bottom:14px;font-weight:500;display:block}
.know-card h4{font-family:var(--wp--preset--font-family--serif);font-weight:600;font-size:22px;line-height:1.25;margin:0 0 10px;color:var(--wp--preset--color--cream)}
.know-card p{font-size:13px;line-height:1.65;color:var(--muted);margin:0 0 16px}
.know-card .more{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);font-weight:500}

/* ---- 11. subpage grid (hub pages) ---- */
.sub-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;margin-top:48px}
.sub-card{
  position:relative;overflow:hidden;background:var(--wp--preset--color--velvet);
  border:1px solid var(--line);
  transition:border-color .35s, transform .35s;
  cursor:pointer;text-decoration:none;color:inherit;
}
.sub-card:hover{border-color:var(--wp--preset--color--gold);transform:translateY(-3px)}
.sub-card__img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--wp--preset--color--ink)}
.sub-card__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,15,31,0) 50%, rgba(10,15,31,0.7) 100%)}
.sub-card__body{padding:24px 28px 28px}
.sub-card h3{font-family:var(--wp--preset--font-family--serif);font-weight:600;font-size:22px;line-height:1.25;color:var(--wp--preset--color--cream);margin:0 0 8px}
.sub-card p{font-size:13px;line-height:1.6;color:var(--muted);margin:0 0 16px}
.sub-card .more{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--wp--preset--color--gold-bright);font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:gap .25s}
.sub-card:hover .more{gap:14px}
@media (max-width: 880px){.sub-grid{grid-template-columns:1fr;gap:16px}}

/* ---- 12. standort übergang banner ---- */
.standort-uebergang{
  display:block;padding:14px 24px;
  background:rgba(201,161,74,0.08);
  border-block:1px solid var(--line);
  font-size:13px;line-height:1.6;color:var(--wp--preset--color--cream);
  text-align:center;
}
.standort-uebergang strong{color:var(--wp--preset--color--gold-bright);font-weight:600}
.standort-uebergang__contact{display:inline-block;margin-left:16px}
.standort-uebergang__contact a{color:var(--wp--preset--color--gold-bright);text-decoration:none;margin:0 6px;border-bottom:1px solid transparent;transition:border-color .2s}
.standort-uebergang__contact a:hover{border-bottom-color:var(--wp--preset--color--gold-bright)}

/* ---- 13. floating phone button ---- */
.floating-phone{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:56px;height:56px;
  background:var(--wp--preset--color--gold);
  color:var(--wp--preset--color--ink);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -10px rgba(0,0,0,0.5), 0 0 0 3px rgba(230,200,121,0.15);
  transition:transform .25s, background .2s, box-shadow .25s;
  text-decoration:none;
}
.floating-phone:hover{
  background:var(--wp--preset--color--gold-bright);
  transform:translateY(-2px);
  box-shadow:0 20px 40px -10px rgba(0,0,0,0.5), 0 0 0 6px rgba(230,200,121,0.18);
}
.floating-phone svg{width:24px;height:24px}
.floating-phone::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:1px solid var(--wp--preset--color--gold);
  animation:pulse 2.4s ease-out infinite;opacity:0;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.6);opacity:0}
}

/* ---- 14. FAQ blocks (used by [faq] shortcode) ---- */
details.faq{
  border:1px solid var(--line);border-radius:2px;
  margin-bottom:12px;padding:0 24px;
  background:rgba(10,15,31,0.4);
  transition:border-color .25s;
}
details.faq[open]{border-color:var(--line-strong);background:rgba(20,26,48,0.5)}
details.faq summary{
  padding:20px 0;font-family:var(--wp--preset--font-family--serif);
  font-size:20px;font-weight:600;color:var(--wp--preset--color--cream);
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";color:var(--wp--preset--color--gold-bright);font-size:22px;font-weight:300;transition:transform .25s}
details.faq[open] summary::after{content:"−"}
details.faq .faq-body{padding:0 0 20px}
details.faq .faq-body p{font-size:16px;line-height:1.75;color:var(--wp--preset--color--cream);opacity:.85;font-weight:300;margin:0 0 12px}

/* ---- 15. cookie consent banner ---- */
.cookie-consent{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:200;
  max-width:760px;margin:0 auto;
  padding:24px 28px;
  background:rgba(10,15,31,0.96);backdrop-filter:blur(14px);
  border:1px solid var(--line-strong);
  border-radius:2px;
  box-shadow:0 30px 80px -10px rgba(0,0,0,0.7);
  display:none;
}
.cookie-consent.is-visible{display:block;animation:cc-in .4s ease}
@keyframes cc-in{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-consent h3{font-family:var(--wp--preset--font-family--serif);font-size:20px;font-weight:600;margin:0 0 10px;color:var(--wp--preset--color--cream)}
.cookie-consent p{font-size:13px;line-height:1.65;color:var(--wp--preset--color--cream);opacity:.85;margin:0 0 20px;font-weight:300}
.cookie-consent p a{color:var(--wp--preset--color--gold-bright);text-decoration:underline}
.cookie-consent__buttons{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie-consent__btn{
  padding:11px 18px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  border-radius:1px;cursor:pointer;border:1px solid var(--line-strong);
  background:transparent;color:var(--wp--preset--color--cream);
  transition:background .2s,color .2s,border-color .2s;
  font-family:var(--wp--preset--font-family--sans);
}
.cookie-consent__btn:hover{border-color:var(--wp--preset--color--gold);color:var(--wp--preset--color--gold-bright)}
.cookie-consent__btn--primary{
  background:var(--wp--preset--color--gold);color:var(--wp--preset--color--ink);
  border-color:var(--wp--preset--color--gold);
}
.cookie-consent__btn--primary:hover{background:var(--wp--preset--color--gold-bright);color:var(--wp--preset--color--ink);border-color:var(--wp--preset--color--gold-bright)}
.cookie-consent__btn--reject{margin-right:auto}
.cookie-consent__detail{margin-top:14px;font-size:12px;color:var(--muted)}
.cookie-consent__detail a{color:var(--wp--preset--color--gold-bright);text-decoration:none}
@media (max-width: 600px){
  .cookie-consent{left:12px;right:12px;bottom:12px;padding:20px}
  .cookie-consent__buttons{flex-direction:column;align-items:stretch}
  .cookie-consent__btn{width:100%;text-align:center}
}

/* ---- 16. footer ---- */
.site-footer{background:var(--wp--preset--color--ink);padding:80px 32px 32px;border-top:1px solid var(--line)}
.footer-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:48px}
.footer-col h4{font-family:var(--wp--preset--font-family--serif);font-size:17px;font-weight:600;color:var(--wp--preset--color--gold-bright);margin:0 0 18px;letter-spacing:.04em}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:9px;font-size:13px}
.footer-col a{color:var(--muted);transition:color .2s;text-decoration:none}
.footer-col a:hover{color:var(--wp--preset--color--gold-bright)}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.7;margin:14px 0 0;max-width:280px}
.footer-contact{margin-top:18px;font-size:13px;color:var(--wp--preset--color--cream);opacity:.78}
.footer-contact a{color:var(--wp--preset--color--gold-bright);display:block;margin-bottom:6px;text-decoration:none}
.footer-bottom{
  max-width:1280px;margin:64px auto 0;padding-top:32px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:12px;color:var(--muted);letter-spacing:.05em;
}
@media (max-width: 980px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width: 520px){.footer-grid{grid-template-columns:1fr}}

/* ---- 17. reveal-on-scroll ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}
.reveal-d2{transition-delay:.15s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.45s}

/* ---- 18. utility ---- */
.quiet-link{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--wp--preset--color--gold-bright);font-weight:500;
  border-bottom:1px solid var(--wp--preset--color--gold);
  padding-bottom:3px;text-decoration:none;
  transition:color .25s,border-color .25s;
}
.quiet-link:hover{color:var(--wp--preset--color--cream);border-bottom-color:var(--wp--preset--color--cream)}

/* ---- 19. responsive baseline ---- */
@media (max-width: 880px){
  .section{padding:80px 20px}
  .section--lg{padding:100px 20px}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .hero__image{animation:none}
  .hub-hero__image{animation:none}
}
