
:root{
  --ink:#17120f;
  --muted:#6f625c;
  --paper:#fbf6ef;
  --paper2:#fffaf4;
  --rose:#a66a66;
  --rose-dark:#704246;
  --gold:#c49a55;
  --line:rgba(23,18,15,.12);
  --shadow:0 24px 70px rgba(41,27,20,.12);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{margin:0 0 1.05rem}
small,.eyebrow,nav,.button,.meta,footer,.form-note{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,239,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.15em;text-transform:uppercase}
.logo img{height:86px;width:auto;display:block;border-radius:0;box-shadow:none;filter:drop-shadow(0 10px 22px rgba(23,18,15,.10))}
.logo-mark{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--rose),#231712);display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.4)}
.nav{display:flex;align-items:center;gap:18px;font-size:.92rem;color:#40332f}
.nav a{padding:8px 2px;border-bottom:1px solid transparent}
.nav a:hover{border-color:var(--gold)}
.header-cta{display:flex;align-items:center;gap:12px}
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:1px solid var(--ink);border-radius:999px;padding:12px 20px;
  background:var(--ink);color:#fff;font-weight:650;font-size:.92rem;
  transition:.2s ease;white-space:nowrap;
}
.button:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(23,18,15,.16)}
.button.secondary{background:transparent;color:var(--ink);border-color:var(--line)}
.button.gold{background:linear-gradient(135deg,var(--gold),#e2c37e);color:#231712;border:0}
.menu-btn{display:none;background:transparent;border:1px solid var(--line);border-radius:999px;padding:10px 14px}
.hero{
  position:relative;overflow:hidden;
  min-height:calc(100vh - 82px);
  display:grid;align-items:center;
  padding:82px 0 54px;
  background:
    radial-gradient(circle at 84% 22%,rgba(196,154,85,.24),transparent 28%),
    linear-gradient(120deg,rgba(112,66,70,.11),transparent 52%),
    var(--paper);
}
.hero:before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(251,246,239,.95) 0%,rgba(251,246,239,.76) 45%,rgba(251,246,239,.18) 100%),
    url("../images/gallery/couple-embrace.webp") center/cover no-repeat;
  z-index:0;
}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:end}
.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;font-weight:700;color:var(--rose-dark);margin-bottom:16px}
h1,h2,h3{line-height:1.08;margin:0 0 18px;font-weight:500}
h1{font-size:clamp(2.45rem,5vw,5.6rem);letter-spacing:-.045em}
h2{font-size:clamp(2.1rem,4.2vw,4.8rem);letter-spacing:-.045em}
h3{font-size:clamp(1.45rem,2vw,2rem);letter-spacing:-.02em}
.lead{font-size:clamp(1.15rem,1.7vw,1.45rem);color:#493a35;max-width:740px}
.hero-card{
  background:rgba(255,250,244,.84);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:28px;
}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px}
.stat{border-top:1px solid var(--line);padding-top:14px}
.stat strong{display:block;font-size:1.5rem}
.stat span{font-size:.82rem;color:var(--muted)}
.section{padding:88px 0}
.section.tight{padding:54px 0}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{
  background:var(--paper2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:0 16px 44px rgba(41,27,20,.06);
}
.card.lift{min-height:100%}
.card .meta{color:var(--muted);font-size:.9rem;margin-bottom:10px}
.muted{color:var(--muted)}
.kicker{font-size:1.2rem;color:#3c2f2b}
.band{
  background:var(--ink);
  color:#fff;
  border-radius:42px;
  padding:56px;
  overflow:hidden;
  position:relative;
}
.band:after{content:"";position:absolute;right:-140px;top:-140px;width:360px;height:360px;border-radius:50%;background:rgba(196,154,85,.18)}
.band p{color:rgba(255,255,255,.78)}
.city-list,.link-list{display:flex;flex-wrap:wrap;gap:10px}
.pill{
  display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:9px 14px;
  background:rgba(255,250,244,.7);
  font-family:ui-sans-serif, system-ui, sans-serif;
  font-size:.91rem;
}
.pill:hover{border-color:var(--gold);background:#fff}
.service-list{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.service-tile{padding:20px;border:1px solid var(--line);border-radius:22px;background:#fffaf4}
.service-tile strong{display:block;margin-bottom:8px}
.page-hero{
  padding:82px 0 44px;
  background:
    radial-gradient(circle at 86% 18%,rgba(196,154,85,.18),transparent 28%),
    linear-gradient(135deg,rgba(166,106,102,.14),transparent 56%);
  border-bottom:1px solid var(--line);
}
.breadcrumbs{font-family:ui-sans-serif,system-ui,sans-serif;font-size:.88rem;color:var(--muted);margin-bottom:28px}
.content{font-size:1.08rem}
.content ul{padding-left:1.2rem}
.content li{margin:.42rem 0}
.faq-item{border-top:1px solid var(--line);padding:22px 0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.cta-box{
  background:linear-gradient(135deg,var(--rose-dark),#1d1513);
  color:#fff;border-radius:42px;padding:48px;
  display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;
}
.cta-box p{color:rgba(255,255,255,.82)}
form{display:grid;gap:14px}
.input, textarea{
  width:100%;border:1px solid var(--line);border-radius:18px;padding:14px 16px;
  background:#fff;color:var(--ink);font:inherit;
}
textarea{min-height:140px;resize:vertical}
.footer{
  background:#120d0c;color:rgba(255,255,255,.78);padding:58px 0 34px;
  font-family:ui-sans-serif,system-ui,sans-serif;
}
.footer h3{font-family:ui-serif,Georgia,serif;color:#fff;font-size:2rem}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:38px}
.footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:38px;padding-top:20px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.88rem}
.cookie{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:90;
  max-width:760px;margin:auto;background:#fffaf4;border:1px solid var(--line);
  box-shadow:var(--shadow);border-radius:24px;padding:18px;display:none;
}
.cookie.show{display:block}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
@media (max-width: 920px){
  .hero-grid,.split,.grid-2,.cta-box{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .service-list{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .menu-btn{display:inline-flex}
  .nav.open{display:flex;position:fixed;inset:75px 20px auto;flex-direction:column;align-items:flex-start;background:#fffaf4;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow)}
}
@media (max-width: 620px){
  .container{width:min(100% - 28px,1180px)}
  .hero{min-height:auto;padding:60px 0 36px}
  .hero-grid{gap:24px}
  h1{font-size:2.55rem}
  .grid-3,.service-list,.stats{grid-template-columns:1fr}
  .section{padding:58px 0}
  .band,.cta-box{padding:30px;border-radius:28px}
  .header-cta .button.secondary{display:none}
  .footer-grid{grid-template-columns:1fr}
}

@media (max-width: 620px){
  .logo img{height:44px}
}


/* Premium additions */
.top-banner-wedding{border-bottom:1px solid var(--line);background:linear-gradient(90deg,rgba(23,18,15,.94),rgba(112,66,70,.88)),url("../images/gallery/hero-rings.webp") center/cover no-repeat;color:#fff6e6}
.top-banner-inner{width:min(1180px,calc(100% - 40px));margin:0 auto;min-height:138px;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;padding:26px 0}
.top-banner-inner strong{display:block;font-size:clamp(1.35rem,2.2vw,2.4rem);font-family:ui-serif,Georgia,serif;font-weight:500;letter-spacing:-.03em}
.top-banner-inner span{font-family:ui-sans-serif,system-ui,sans-serif;color:rgba(255,246,230,.78)}
.wedding-tag{font-family:ui-sans-serif,system-ui,sans-serif;border:1px solid rgba(255,246,230,.38);border-radius:999px;padding:9px 14px;color:#fff6e6;background:rgba(255,255,255,.06)}
.external-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}
.external-card{display:flex;flex-direction:column;gap:10px;background:#fffaf4;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 16px 44px rgba(41,27,20,.055)}
.external-card .external-name{font-size:1.18rem;font-weight:700;line-height:1.15}
.external-card p{color:var(--muted);font-size:.98rem;margin:0}
.external-card .external-link{font-family:ui-sans-serif,system-ui,sans-serif;font-size:.9rem;color:var(--rose-dark);margin-top:auto}
.disclaimer{font-family:ui-sans-serif,system-ui,sans-serif;color:var(--muted);font-size:.88rem;margin-top:14px}
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.video-card{background:#fffaf4;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:0 16px 44px rgba(41,27,20,.055)}
.video-frame{aspect-ratio:16/9;background:url("../images/video-placeholder.svg") center/cover no-repeat;display:grid;place-items:center;color:#fff6e6}
.video-card-content{padding:24px}
.video-card-content .meta{font-size:.82rem;color:var(--muted)}
.about-photo{min-height:680px;border-radius:42px;overflow:hidden;background:url("../images/gallery/alexej-profile-final.webp") center/cover no-repeat;border:1px solid var(--line);box-shadow:var(--shadow)}
.provider-note{padding:16px 18px;border-left:3px solid var(--gold);background:rgba(196,154,85,.12);border-radius:14px;margin:20px 0}
@media (max-width: 920px){.top-banner-inner{grid-template-columns:1fr}.external-grid{grid-template-columns:1fr 1fr}.video-grid{grid-template-columns:1fr}}
@media (max-width: 620px){.top-banner-inner{width:min(100% - 28px,1180px);min-height:120px}.external-grid{grid-template-columns:1fr}.logo img{height:54px}}

/* Startseiten-Video-Banner und Hochzeitspakete */
.home-video-banner{
  background:#17120f;
  color:#fff6e6;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.home-video-banner__media{
  position:relative;
  min-height:clamp(420px, 62vw, 760px);
  background:url("../images/gallery/hero-rings.webp") center/cover no-repeat;
  display:grid;
  align-items:end;
  isolation:isolate;
}
.home-video-banner__iframe{
  position:absolute;
  top:50%;
  left:50%;
  width:100vw;
  height:56.25vw;
  min-width:177.78vh;
  min-height:100%;
  transform:translate(-50%,-50%);
  border:0;
  pointer-events:none;
  z-index:0;
}
.home-video-banner__shade{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg,rgba(23,18,15,.86),rgba(23,18,15,.32) 58%,rgba(23,18,15,.58)),
    linear-gradient(180deg,rgba(23,18,15,.18),rgba(23,18,15,.66));
}
.home-video-banner__overlay{
  position:relative;
  z-index:2;
  width:100%;
  padding:clamp(52px,8vw,110px) 0;
}
.home-video-banner h2{
  max-width:920px;
  color:#fff6e6;
  text-shadow:0 18px 60px rgba(0,0,0,.38);
}
.home-video-banner p{
  max-width:720px;
  color:rgba(255,246,230,.86);
  font-size:1.12rem;
}
.home-video-banner__actions{
  margin-top:26px;
}
@media (prefers-reduced-motion: reduce){
  .home-video-banner__iframe{display:none}
}
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:30px;
}
.pricing-card{
  background:#fffaf4;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:0 16px 44px rgba(41,27,20,.06);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.pricing-card.featured{
  border-color:rgba(196,154,85,.72);
  box-shadow:0 26px 70px rgba(196,154,85,.18);
  transform:translateY(-8px);
}
.price{
  font-size:clamp(2rem,3.2vw,3.4rem);
  line-height:1;
  letter-spacing:-.05em;
  margin:0;
  color:var(--rose-dark);
}
.pricing-card ul{
  padding-left:1.1rem;
  margin:0 0 8px;
}
.pricing-card li{
  margin:.36rem 0;
}
@media (max-width: 920px){
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card.featured{transform:none}
}

/* Four pricing collections: readable 2x2 desktop layout */
.pricing-grid--four{
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:stretch;
}
.pricing-grid--four .pricing-card.featured{
  transform:none;
}
@media (max-width: 920px){
  .pricing-grid--four{grid-template-columns:1fr;}
}



/* Vimeo-Einbettungen auf SEO-Stadtseiten */
.city-vimeo-section{
  background:linear-gradient(180deg,rgba(196,154,85,.08),rgba(255,250,244,0));
}
.vimeo-embed{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  border-radius:28px;
  background:#17120f;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.vimeo-embed iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

/* 5er Premium-Dienstleister-Listen */
.external-grid .external-card:nth-child(4),
.external-grid .external-card:nth-child(5){
  min-height:100%;
}

/* Kleinere H1 Headlines */
.page-hero h1{
  max-width:980px;
}
@media (max-width: 620px){
  .page-hero h1,
  .hero h1{
    font-size:2.55rem;
    letter-spacing:-.035em;
  }
}


/* Großes Premium-Logo */
.premium-logo-showcase{
  padding:34px 0 18px;
  background:linear-gradient(180deg,rgba(196,154,85,.08),rgba(255,250,244,0));
}
.premium-logo-card{
  display:grid;
  gap:18px;
  justify-items:center;
  text-align:center;
  background:#fffaf4;
  border:1px solid var(--line);
  border-radius:36px;
  padding:34px 26px 28px;
  box-shadow:0 18px 52px rgba(41,27,20,.08);
}
.premium-logo-card img{
  width:min(100%, 980px);
  height:auto;
  display:block;
}
.premium-logo-card p{
  max-width:760px;
  color:var(--muted);
  margin:0 auto;
}
@media (max-width: 920px){
  .logo img{height:64px}
}
@media (max-width: 620px){
  .logo img{height:50px;max-width:210px}
  .premium-logo-showcase{padding:22px 0 8px}
  .premium-logo-card{padding:22px 16px 18px;border-radius:26px}
}

/* Grüner WhatsApp-Sticky-Button */
.sticky-whatsapp{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:120;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:14px 22px;
  border-radius:999px;
  background:#25D366;
  color:#0b2514;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 52px rgba(18,140,75,.32);
  font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight:800;
  font-size:1rem;
  letter-spacing:.01em;
  text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease;
}
.sticky-whatsapp:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 70px rgba(18,140,75,.42);
}
.sticky-whatsapp__icon{
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  border-radius:50%;
  background:rgba(255,255,255,.78);
  color:#128C7E;
  font-size:1rem;
  line-height:1;
}
@media (max-width:720px){
  .sticky-whatsapp{
    right:14px;
    bottom:14px;
    min-height:52px;
    padding:13px 18px;
  }
}
@media print{
  .sticky-whatsapp{display:none}
}

/* Echte Bildgalerie */
.real-wedding-gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:28px;
}
.real-wedding-gallery figure{
  margin:0;
  position:relative;
  overflow:hidden;
  border-radius:24px;
  border:1px solid var(--line);
  background:#fffaf4;
  min-height:220px;
  box-shadow:0 16px 44px rgba(41,27,20,.055);
}
.real-wedding-gallery img{
  width:100%;
  height:100%;
  min-height:220px;
  object-fit:cover;
  transition:transform .35s ease;
}
.real-wedding-gallery figure:hover img{
  transform:scale(1.035);
}
.real-wedding-gallery figcaption{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:28px 16px 14px;
  color:#fff;
  font-family:ui-sans-serif, system-ui, sans-serif;
  font-size:.82rem;
  background:linear-gradient(180deg,transparent,rgba(23,18,15,.72));
}
.real-wedding-gallery .wide{
  grid-column:span 2;
}
.real-wedding-gallery .tall{
  grid-row:span 2;
}
.premium-logo-card.real-logo img{
  width:min(100%, 520px);
  border-radius:50%;
  box-shadow:0 24px 70px rgba(23,18,15,.14);
}
@media (max-width: 920px){
  .real-wedding-gallery{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 620px){
  .real-wedding-gallery{grid-template-columns:1fr}
  .real-wedding-gallery .wide,
  .real-wedding-gallery .tall{grid-column:auto;grid-row:auto}
}

/* final-logo-showcase-adjustment */
.premium-logo-card.real-logo img{
  width:min(100%, 560px);
  max-width:560px;
  height:auto;
  border-radius:50%;
  box-shadow:0 24px 80px rgba(23,18,15,.16);
}

/* Wedding Look final polish */
:root{
  --ivory:#fffaf4;
  --blush:#ead6cf;
  --blush-soft:#f6e9e3;
  --champagne:#d9b875;
  --silk:#fffdf8;
}
body{
  background:
    radial-gradient(circle at 12% 6%, rgba(234,214,207,.55), transparent 30vw),
    radial-gradient(circle at 88% 18%, rgba(217,184,117,.22), transparent 32vw),
    linear-gradient(180deg,#fffaf4 0%,#fbf6ef 46%,#fffaf4 100%);
}
.site-header{
  background:rgba(255,250,244,.88);
}
.home-video-banner__media::after{
  content:"";
  position:absolute;
  left:clamp(20px,4vw,64px);
  bottom:clamp(22px,4vw,60px);
  width:min(24vw,260px);
  aspect-ratio:1;
  z-index:1;
  border:1px solid rgba(217,184,117,.28);
  border-radius:50%;
  opacity:.45;
  pointer-events:none;
  box-shadow:0 0 0 22px rgba(217,184,117,.035), inset 0 0 60px rgba(255,250,244,.08);
}
.home-video-banner__overlay .eyebrow,
.hero .eyebrow,
.page-hero .eyebrow{
  color:var(--champagne);
  text-shadow:0 10px 30px rgba(23,18,15,.18);
}
.hero .eyebrow,
.page-hero .eyebrow,
.section .eyebrow{
  color:var(--rose-dark);
}
.hero:before{
  background:
    linear-gradient(90deg,rgba(255,250,244,.95) 0%,rgba(255,250,244,.78) 42%,rgba(255,250,244,.18) 100%),
    url("../images/gallery/couple-embrace.webp") center/cover no-repeat;
}
.hero-card,
.card,
.external-card,
.pricing-card,
.video-card,
.service-tile,
.premium-logo-card{
  background:linear-gradient(180deg,rgba(255,253,248,.96),rgba(255,250,244,.9));
  border-color:rgba(112,66,70,.13);
}
.card:hover,
.external-card:hover,
.service-tile:hover,
.video-card:hover{
  border-color:rgba(217,184,117,.52);
  box-shadow:0 24px 70px rgba(65,38,31,.1);
}
.section:nth-of-type(even){
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(246,233,227,.22),rgba(255,255,255,0));
}
.band,
.cta-box{
  background:
    radial-gradient(circle at 86% 18%,rgba(217,184,117,.2),transparent 30%),
    linear-gradient(135deg,#704246,#1d1513);
}
.pill{
  background:rgba(255,253,248,.72);
}
.real-wedding-gallery figure{
  border-radius:28px;
}
.video-frame--embed{
  position:relative;
  background:#17120f;
  display:block;
}
.video-frame--embed iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.wedding-tag{
  display:none;
}
.footer{
  background:
    radial-gradient(circle at 85% 10%,rgba(217,184,117,.15),transparent 26%),
    #120d0c;
}
@media (max-width:620px){
  .home-video-banner__media::after{display:none}
}


/* Graf-Video final brand polish */
.site-header{box-shadow:0 12px 34px rgba(65,38,31,.05)}
.header-inner{padding:14px 0}
.logo{letter-spacing:0;text-transform:none}
.home-video-banner__media{min-height:clamp(520px,64vw,820px)}
.home-video-banner h2{font-size:clamp(2.45rem,5.2vw,5.8rem);letter-spacing:-.05em}
.home-video-banner__overlay:before{content:"";display:block;width:92px;height:1px;background:linear-gradient(90deg,transparent,var(--champagne),transparent);margin:0 0 22px}
.external-name{font-family:ui-serif, Georgia, Cambria, "Times New Roman", serif;font-size:1.35rem;color:#2b1f1b}
.cookie strong{font-family:ui-serif, Georgia, Cambria, "Times New Roman", serif;font-size:1.1rem}
@media (max-width:620px){.home-video-banner h2{font-size:2.55rem}.header-inner{padding:12px 0}}


/* Exclusive Wedding Look refinement */
:root{
  --velvet:#120d0c;
  --cream:#fffdf8;
  --soft-gold:#d9b875;
  --private-rose:#8b555a;
}
body{
  letter-spacing:.002em;
}
.site-header{
  border-bottom:1px solid rgba(217,184,117,.22);
}
.logo img{
  height:96px;
}
.hero-card,
.pricing-card.featured,
.premium-logo-card{
  position:relative;
  overflow:hidden;
}
.hero-card:before,
.pricing-card.featured:before,
.premium-logo-card:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(217,184,117,.16),transparent 42%);
}
.button.gold{
  box-shadow:0 18px 46px rgba(217,184,117,.22);
}
.button.secondary{
  background:rgba(255,253,248,.42);
}
.page-hero{
  background:
    radial-gradient(circle at 88% 8%,rgba(217,184,117,.22),transparent 30%),
    radial-gradient(circle at 10% 0%,rgba(139,85,90,.15),transparent 28%),
    linear-gradient(180deg,#fffdf8,#fbf6ef);
}
.eyebrow{
  letter-spacing:.22em;
}
.price{
  color:#704246;
}
.pricing-card .meta,
.card .meta,
.external-card .external-link{
  letter-spacing:.08em;
  text-transform:uppercase;
}
.footer-bottom span:last-child{
  color:rgba(255,250,244,.72);
}
@media (max-width:920px){
  .logo img{height:72px;}
}
@media (max-width:620px){
  .logo img{height:54px;max-width:230px;}
}


/* Banner-Fix: Vimeo-Fehlerbox im Hero entfernt, Bild füllt den kompletten Premium-Banner */
.home-video-banner--poster .home-video-banner__media{
  min-height:clamp(620px,56.25vw,920px);
  background:#17120f;
  overflow:hidden;
}
.home-video-banner__poster{
  position:absolute;
  inset:0;
  z-index:0;
  background:url("../images/gallery/hero-rings.webp") center center / cover no-repeat;
  transform:scale(1.01);
}
.home-video-banner--poster .home-video-banner__iframe{
  display:none!important;
}
.home-video-banner--poster .home-video-banner__shade{
  background:
    linear-gradient(90deg,rgba(23,18,15,.72),rgba(23,18,15,.22) 56%,rgba(23,18,15,.35)),
    linear-gradient(180deg,rgba(23,18,15,.08),rgba(23,18,15,.62));
}
@media (max-width:920px){
  .home-video-banner--poster .home-video-banner__media{min-height:calc(100vw * .9);}
  .home-video-banner__poster{background-position:center top;}
}
@media (max-width:620px){
  .home-video-banner--poster .home-video-banner__media{min-height:760px;}
  .home-video-banner__poster{background-position:58% center;}
}



/* Foto-Upgrade auf der Investment-Seite */
.photo-upgrade{
  margin-top:34px;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);
  gap:24px;
  align-items:stretch;
  background:
    radial-gradient(circle at 80% 18%,rgba(196,154,85,.18),transparent 30%),
    linear-gradient(135deg,rgba(112,66,70,.09),rgba(255,250,244,.92));
  border:1px solid var(--line);
  border-radius:34px;
  padding:clamp(24px,4vw,42px);
  box-shadow:0 24px 70px rgba(41,27,20,.08);
}
.photo-upgrade-copy{display:flex;flex-direction:column;align-items:flex-start;justify-content:center}
.photo-upgrade-copy .lead{max-width:780px}
.soft-list{padding-left:1.1rem;margin:4px 0 22px;color:#493a35}
.soft-list li{margin:.42rem 0}
.photo-upgrade-panel{
  background:#fffaf4;
  border:1px solid rgba(196,154,85,.32);
  border-radius:28px;
  padding:26px;
  box-shadow:0 18px 50px rgba(41,27,20,.07);
}
.upgrade-tiers{display:grid;gap:10px;margin:18px 0}
.upgrade-tier{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:#493a35;
}
.upgrade-tier:last-child{border-bottom:0}
.upgrade-tier strong{color:var(--rose-dark);white-space:nowrap}
.fineprint{font-size:.94rem;color:var(--muted);margin-bottom:0}
@media (max-width: 920px){
  .photo-upgrade{grid-template-columns:1fr;border-radius:28px}
}


/* FINAL: Vimeo-Frames füllen den kompletten Video-Platzhalter.
   Kein kleines Fenster in der Mitte, keine sichtbaren Vimeo-Weiterleitungsbuttons. */
.video-frame.video-frame--embed,
.video-card .video-frame.video-frame--embed,
.vimeo-embed{
  position:relative !important;
  display:block !important;
  width:100% !important;
  aspect-ratio:16 / 9 !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0 !important;
  overflow:hidden !important;
  background:#17120f !important;
  border:0 !important;
}
.video-frame.video-frame--embed > iframe,
.video-card .video-frame.video-frame--embed > iframe,
.vimeo-embed > iframe{
  position:absolute !important;
  inset:0 !important;
  top:0 !important;
  left:0 !important;
  width:100% !important;
  height:100% !important;
  min-width:100% !important;
  min-height:100% !important;
  max-width:none !important;
  max-height:none !important;
  display:block !important;
  border:0 !important;
  padding:0 !important;
  margin:0 !important;
  background:#17120f !important;
}
.video-card{overflow:hidden !important;}
.video-card .video-frame::before,
.video-card .video-frame::after{display:none !important;content:none !important;}


/* FINAL: Keine sichtbaren Vimeo-/Portfolio-Texte unter eingebetteten Videos. */
.video-frame.video-frame--embed,
.video-card .video-frame.video-frame--embed,
.vimeo-embed{
  background:#17120f !important;
  background-image:none !important;
}
.video-frame.video-frame--embed svg,
.video-card .video-frame.video-frame--embed svg{
  display:none !important;
}


/* FINAL FIX 2026-05-17: Vimeo-Banner auf der Hauptseite vollflächig und in voller Breite. */
.home-video-banner--vimeo{
  width:100%;
  margin:0;
  background:#17120f;
  overflow:hidden;
}
.home-video-banner--vimeo .home-video-banner__media{
  position:relative;
  min-height:clamp(620px,56.25vw,920px);
  width:100%;
  overflow:hidden;
  background:#17120f url("../images/gallery/hero-rings.webp") center center / cover no-repeat;
}
.home-video-banner--vimeo .home-video-banner__iframe{
  display:block !important;
  position:absolute !important;
  top:50% !important;
  left:50% !important;
  width:100vw !important;
  height:56.25vw !important;
  min-width:177.78vh !important;
  min-height:100% !important;
  transform:translate(-50%,-50%) !important;
  border:0 !important;
  pointer-events:none !important;
  z-index:0 !important;
  background:#17120f !important;
}
.home-video-banner--vimeo .home-video-banner__poster{display:none !important;}
.home-video-banner--vimeo .home-video-banner__shade{
  z-index:1;
  background:
    linear-gradient(90deg,rgba(23,18,15,.72),rgba(23,18,15,.20) 56%,rgba(23,18,15,.36)),
    linear-gradient(180deg,rgba(23,18,15,.08),rgba(23,18,15,.60));
}
.home-video-banner--vimeo .home-video-banner__overlay{z-index:2;}
@media (max-width:920px){
  .home-video-banner--vimeo .home-video-banner__media{min-height:calc(100vw * .9);}
}
@media (max-width:620px){
  .home-video-banner--vimeo .home-video-banner__media{min-height:760px;}
  .home-video-banner--vimeo .home-video-banner__iframe{height:100%;min-width:177.78vw;min-height:100%;}
}


/* Final logo/photo update 2026-05-17 */
.logo img{
  height:112px!important;
  width:112px!important;
  max-width:112px!important;
  object-fit:contain;
  border-radius:50%!important;
  filter:drop-shadow(0 14px 28px rgba(65,38,31,.18));
}
.header-inner{padding:12px 0;}
.about-photo{
  background-image:url("../images/gallery/alexej-profile-final.webp")!important;
  background-position:center center!important;
  min-height:720px;
}
@media (max-width:920px){
  .logo img{height:86px!important;width:86px!important;max-width:86px!important;}
  .about-photo{min-height:620px;}
}
@media (max-width:620px){
  .logo img{height:68px!important;width:68px!important;max-width:68px!important;}
  .about-photo{min-height:520px;}
}

/* Über-mich Galerie: breites Hauptbild, keine weißen Bildbeschriftungen */
.about-gallery{
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
  margin-top:32px;
}
.about-gallery figure{
  min-height:340px;
}
.about-gallery .gallery-hero{
  grid-column:1 / -1;
  aspect-ratio:16 / 7;
  min-height:360px;
}
.about-gallery img{
  min-height:340px;
}
.about-gallery .gallery-hero img{
  min-height:360px;
}
.about-gallery figcaption{
  display:none;
}
@media (max-width: 760px){
  .about-gallery{
    grid-template-columns:1fr;
    gap:18px;
  }
  .about-gallery .gallery-hero{
    grid-column:auto;
    aspect-ratio:4 / 3;
    min-height:260px;
  }
  .about-gallery figure,
  .about-gallery img,
  .about-gallery .gallery-hero img{
    min-height:260px;
  }
}
