@font-face {
  font-family: 'Playfair Display Local';
  src: url('fonts/Playfair_Display/PlayfairDisplay-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display Local';
  src: url('fonts/Playfair_Display/PlayfairDisplay-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Lora Local';
  src: url('fonts/Lora/Lora-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Lora Local';
  src: url('fonts/Lora/Lora-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root{
  --bg:#0c1324;--surface:rgba(255,255,255,.045);--border:rgba(255,255,255,.12);--primary:#adc8f5;--text:#dce1fb;--text-soft:#c5c6d2;--muted:rgba(197,198,210,.68);--shadow:0 22px 54px rgba(0,0,0,.32);--header-height:78px;--container:1180px;--font-headline:'Playfair Display Local',Georgia,'Times New Roman',serif;--font-body:'Lora Local',Georgia,'Times New Roman',serif
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at 50% 0%,rgba(173,200,245,.08),transparent 32rem),var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit}.container{width:min(calc(100% - 2rem),var(--container));margin:0 auto}.narrow{max-width:760px}
.site-header{position:sticky;top:0;z-index:1000;height:var(--header-height);background:rgba(12,19,36,.86);border-bottom:1px solid rgba(173,200,245,.22);backdrop-filter:blur(16px)}.header-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-header .container.header-inner{width:100%;max-width:none;margin:0;padding-left:clamp(1.05rem,2.2vw,2rem);padding-right:clamp(1.05rem,2.2vw,2rem)}.brand{font-family:var(--font-headline);font-style:italic;color:rgba(173,200,245,.92);font-size:clamp(1.15rem,1.7vw,1.35rem);letter-spacing:.01em;white-space:nowrap}.site-nav ul{list-style:none;display:flex;align-items:center;gap:clamp(1.1rem,2.5vw,2.2rem);margin:0;padding:0}.site-nav a{display:inline-block;font-family:var(--font-headline);font-size:1.04rem;line-height:1;color:var(--text-soft);transition:color .2s ease}.site-nav a:hover,.site-nav a:focus-visible{color:var(--primary)}.site-nav a.is-active{color:var(--primary);font-style:italic;letter-spacing:.06em}.nav-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:5px;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:rgba(255,255,255,.03);cursor:pointer}.nav-toggle span{display:block;width:18px;height:1.5px;background:var(--text-soft);border-radius:999px}
.page-section{padding:clamp(4.4rem,8vw,7rem) 0 clamp(3.6rem,7vw,5.5rem)}.page-kicker{margin:0 0 .9rem;color:var(--primary);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase}.page-title{margin:0;color:var(--primary);font-family:var(--font-headline);font-weight:400;line-height:1.05;font-size:clamp(2.25rem,5.2vw,4.5rem)}.section-title{margin:0 0 1.4rem;color:var(--text);font-family:var(--font-headline);font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:400;line-height:1.1}.lead{margin:1.2rem 0 0;color:var(--text-soft);font-size:clamp(1rem,1.6vw,1.16rem);line-height:1.72;max-width:68ch}.copy p{margin:0 0 1.15rem;color:var(--text-soft);font-size:1rem;line-height:1.76}.about-copy{margin-top:2rem}.copy strong{color:var(--text);font-weight:600}
.hero{position:relative;min-height:calc(100vh - var(--header-height));display:grid;place-items:center;overflow:hidden}.hero-media{position:absolute;inset:0}.hero-media img{width:calc(100% + 13%);height:100%;margin-left:8.5%;object-fit:cover;object-position:50% 18%;opacity:.50;filter:grayscale(100%) blur(1.0px) brightness(.95) contrast(.96);transform:scale(1.08)}.hero:before,.image-blueprint:before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(12,19,36,.20),rgba(12,19,36,.46) 58%,rgba(12,19,36,.72)),radial-gradient(circle at center,rgba(173,200,245,.05),rgba(12,19,36,.58) 68%)}.hero:after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to right,rgba(12,19,36,.40),transparent 22%,transparent 78%,rgba(12,19,36,.40))}.hero-content{position:relative;z-index:2;text-align:center;padding:1.2rem 0}.hero-kicker{margin:0 0 1.15rem;color:var(--primary);text-transform:uppercase;letter-spacing:.34em;font-size:.72rem}.hero-title{margin:0;color:var(--primary);font-family:var(--font-headline);font-weight:400;line-height:.96;font-size:clamp(3.0rem,7vw,5.4rem)}.hero-subtitle{margin:1.15rem 0 0;color:var(--text-soft);font-family:var(--font-headline);font-style:italic;font-size:clamp(1.05rem,1.8vw,1.45rem)}.hero-actions{margin-top:2.4rem;display:flex;justify-content:center;gap:.85rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 1.2rem;border:1px solid rgba(173,200,245,.32);border-radius:999px;background:rgba(255,255,255,.03);color:var(--text);cursor:pointer;transition:transform .2s ease,border-color .2s ease,background-color .2s ease,color .2s ease}.btn:hover,.btn:focus-visible{transform:translateY(-1px);border-color:rgba(173,200,245,.55);color:var(--primary)}.btn-primary{background:var(--primary);color:#132e50;border-color:transparent;font-weight:600}.btn-primary:hover,.btn-primary:focus-visible{background:#c2d6f8;color:#132e50}
.grid-2{display:grid;grid-template-columns:minmax(0,1.03fr) minmax(320px,.97fr);gap:clamp(2rem,5vw,4.8rem);align-items:center}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow)}.image-panel{position:relative;overflow:hidden;background:#07101f;min-height:480px}.image-panel img{width:100%;height:100%;object-fit:cover}.image-panel--portrait{height:min(64vh,650px)}.image-panel--portrait img{object-position:center center}.image-blueprint:before{pointer-events:none}.image-blueprint:after{content:'';position:absolute;inset:0;z-index:2;background:rgba(118,162,224,.18);mix-blend-mode:color;pointer-events:none}.image-blueprint img{opacity:.66;filter:grayscale(100%) blur(.7px) brightness(.82) contrast(.94)}.divider{height:1px;background:rgba(173,200,245,.28);margin:2.2rem 0}.gallery-section{margin-top:3rem}.gallery-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.gallery-tile{position:relative;overflow:hidden;min-height:150px;background:#090f1d;border:1px solid var(--border)}.gallery-tile img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%) brightness(.78) contrast(1.06);transition:transform .45s ease,filter .45s ease}.gallery-tile:after{content:'';position:absolute;inset:0;background:rgba(143,179,232,.25);mix-blend-mode:color;transition:opacity .45s ease}.gallery-tile:hover img{transform:scale(1.045);filter:grayscale(0) brightness(1) contrast(1)}.gallery-tile:hover:after{opacity:0}
.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:1.2rem}.projects-intro{margin-top:2.4rem}.project-card{overflow:hidden;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow)}.project-thumb{aspect-ratio:4/3;overflow:hidden;background:#070d18}.project-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}.project-card:hover img{transform:scale(1.04)}.project-body{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.05rem 1.12rem}.project-title{margin:0;font-family:var(--font-headline);font-size:1.12rem;line-height:1.18;font-weight:400;color:var(--text)}.project-arrow{color:var(--primary);opacity:.72;transition:transform .2s ease,opacity .2s ease}.project-card:hover .project-arrow{transform:translateX(4px);opacity:1}
.back-link{display:inline-flex;gap:.55rem;align-items:center;margin-bottom:1.4rem;color:var(--text-soft);font-family:var(--font-headline)}.back-link:hover{color:var(--primary)}.meta-box{padding:clamp(1.2rem,3vw,1.9rem)}.meta-box h2{margin:0 0 1.1rem;font-family:var(--font-headline);font-size:1.8rem;font-weight:400}.meta-list{display:grid;gap:.75rem;color:var(--text-soft)}.meta-list strong{color:var(--primary);font-weight:600}.media-frame{overflow:hidden;background:rgba(255,255,255,.035);border:1px solid var(--border);box-shadow:var(--shadow)}.media-frame img{width:100%;height:auto}.lignum-grid{margin-top:2.4rem;align-items:start}.lignum-text{margin-top:2.5rem;max-width:760px}.lignum-album-link{margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.1)}.lignum-video{margin-top:2.8rem;max-width:820px}.video-consent,.video-frame{position:relative;overflow:hidden;aspect-ratio:16/9;border:1px solid var(--border);background:#07101f;box-shadow:var(--shadow)}.video-consent iframe,.video-frame iframe{width:100%;height:100%;border:0}.video-consent__placeholder{position:absolute;inset:0;background-size:cover;background-position:center;cursor:pointer}.video-consent__placeholder:before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.5)}.video-consent__content{position:absolute;inset:0;display:grid;place-content:center;gap:1rem;text-align:center;padding:1.5rem;z-index:1}.video-consent__play{width:70px;height:50px;justify-self:center;border:0;border-radius:14px;background:#f0002c;color:white;cursor:pointer}.video-consent__title{margin:0;font-family:var(--font-headline);font-size:1.8rem}.video-consent__text{margin:0;color:var(--text-soft);max-width:42ch}.video-consent__button{justify-self:center;padding:.75rem 1.1rem;border:1px solid rgba(255,255,255,.2);background:rgba(12,19,36,.85);cursor:pointer}.video-consent--lignum .video-consent__placeholder{background-image:url('https://i.ytimg.com/vi/Qq2VmMApovo/hqdefault.jpg')}
.schedule-head,.schedule-row{display:grid;grid-template-columns:140px 1.25fr 1fr 90px 64px;gap:1rem;align-items:center}.schedule-head{margin-top:2.4rem;padding:0 1rem .8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.2em;font-size:.76rem}.schedule-table{border-top:1px solid rgba(255,255,255,.1)}.schedule-row{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.schedule-row:hover{background:rgba(255,255,255,.025)}.schedule-date .day{color:var(--primary);font-family:var(--font-headline);font-size:1.25rem}.schedule-date .month-year,.schedule-meta{color:var(--text-soft)}.schedule-project,.schedule-venue,.schedule-time{font-family:var(--font-headline);font-size:1.08rem}.link-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:var(--text-soft);transition:color .2s ease,transform .2s ease,border-color .2s ease}.link-icon:hover{color:var(--primary);transform:translate(2px,-2px);border-color:rgba(173,200,245,.35)}.link-icon.is-disabled{opacity:.35;pointer-events:none}.schedule-mobile{display:none}.schedule-card{padding:1.25rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.schedule-card-top{display:flex;justify-content:space-between;gap:1rem}.schedule-mobile-date{color:var(--primary);font-family:var(--font-headline)}.schedule-card-title{margin:.45rem 0 0;font-family:var(--font-headline);font-size:1.22rem}.schedule-card-panel{margin-top:.9rem;padding:.95rem;border:1px solid var(--border);background:rgba(255,255,255,.03)}.schedule-card-panel p{margin:0}.schedule-card-panel p+p{margin-top:.2rem}
.contact-card{max-width:720px;padding:clamp(1.3rem,3vw,2rem)}.contact-card--compact{margin-top:2.4rem}.contact-grid{display:grid;gap:1rem;margin-top:1.4rem}.contact-item{padding:1rem;border:1px solid var(--border);background:rgba(255,255,255,.03)}.contact-label{margin:0 0 .3rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;font-size:.76rem}.contact-value{margin:0;color:var(--text);font-size:1rem}
.site-footer{padding:2rem 0 2.6rem}.home-page .site-footer{position:fixed;left:0;right:0;bottom:.8rem;z-index:20;padding:0;pointer-events:none}.footer-inner{display:flex;justify-content:center;gap:.9rem;flex-wrap:wrap;color:rgba(197,198,210,.72);font-size:.88rem}.home-footer .footer-inner{display:grid;justify-items:center}.legal-links{display:flex;gap:.8rem;align-items:center;pointer-events:auto}.footer-inner a,.footer-inner button{background:none;border:0;padding:0;cursor:pointer;color:inherit}.footer-inner a:hover,.footer-inner button:hover{color:var(--primary)}.social-bar{display:flex;justify-content:center;gap:.65rem;margin-bottom:1.15rem;padding:.42rem .55rem;border-radius:999px;background:rgba(12,19,36,.46);border:1px solid rgba(173,200,245,.16);box-shadow:0 12px 26px rgba(0,0,0,.16);backdrop-filter:blur(14px);pointer-events:auto}.social-link{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:999px;background:rgba(12,19,36,.72);border:1px solid rgba(255,255,255,.11);color:var(--text-soft);backdrop-filter:blur(14px);transition:color .2s ease,transform .2s ease,border-color .2s ease,background-color .2s ease}.social-link svg{width:22px;height:22px}.social-link:hover{color:var(--primary);transform:translateY(-1px);border-color:rgba(173,200,245,.35);background:rgba(12,19,36,.80)}.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.58);backdrop-filter:blur(7px);opacity:0;pointer-events:none;transition:opacity .2s ease}.modal{position:fixed;inset:0;z-index:2001;display:none;align-items:center;justify-content:center;padding:1rem}.modal.is-open{display:flex}.modal-overlay.is-open{opacity:1;pointer-events:auto}.modal-box{width:min(100%,680px);max-height:78vh;overflow:hidden;background:rgba(15,23,43,.97);border:1px solid var(--border);box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-head h2{margin:0;color:var(--primary);font-family:var(--font-headline);font-weight:400}.modal-head button{border:0;background:none;cursor:pointer;font-size:1.7rem;line-height:1}.modal-content{max-height:calc(78vh - 68px);overflow-y:auto;padding:1.2rem;color:var(--text-soft);font-size:.95rem}.modal-content h3{margin:1rem 0 .35rem;color:var(--text);font-family:var(--font-headline)}.modal-content p{margin:0 0 .8rem}
@media(max-width:900px){.nav-toggle{display:flex}.site-header{height:auto;min-height:var(--header-height)}.header-inner{min-height:var(--header-height);position:relative}.site-nav{display:none;position:absolute;top:calc(100% + .6rem);left:1rem;right:1rem;padding:.45rem;border:1px solid rgba(255,255,255,.12);background:rgba(16,24,43,.97);box-shadow:var(--shadow)}.site-header.is-open .site-nav{display:block}.site-nav ul{display:grid;gap:.1rem}.site-nav a{display:block;padding:.75rem .85rem}.grid-2{grid-template-columns:1fr}.image-panel--portrait{height:auto;min-height:420px}.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.schedule-head,.schedule-table{display:none}.schedule-mobile{display:block;border-top:1px solid rgba(255,255,255,.1)}.home-page .site-footer{position:static;padding:0 0 1.6rem}.hero{min-height:calc(100vh - var(--header-height))}}
@media(max-width:620px){.container{width:min(calc(100% - 1.2rem),var(--container))}.page-section{padding-top:4.2rem}.hero-title{font-size:clamp(3rem,17vw,4.8rem)}.projects-grid,.gallery-grid{grid-template-columns:1fr}.gallery-tile{min-height:180px}.social-bar{flex-wrap:wrap}.social-link{width:42px;height:42px}}


/* Über mich */
.about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.03fr) minmax(320px, .97fr);
  gap: clamp(2rem, 5vw, 4.8rem);
  align-items: start;
}

.about-text {
  max-width: 760px;
}

.about-text p {
  margin: 0 0 1.05rem;
  color: var(--text-soft);
  font-size: clamp(.95rem, 1vw, 1.02rem);
  line-height: 1.72;
}

.about-portrait {
  position: sticky;
  top: calc(var(--header-height) + 2rem);
  min-height: min(68vh, 640px);
  overflow: hidden;
  background: #07101f;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}

.about-portrait img {
  width: 100%;
  height: 100%;
  min-height: min(68vh, 640px);
  object-fit: cover;
  object-position: center center;
  opacity: .62;
  filter: grayscale(100%) blur(.7px) brightness(.86) contrast(.95);
}

.about-portrait::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(12,19,36,.72), rgba(12,19,36,.22) 34%, rgba(12,19,36,.28) 68%, rgba(12,19,36,.82)),
    radial-gradient(circle at center, rgba(173,200,245,.08), rgba(12,19,36,.58) 70%);
}

.about-gallery {
  padding: 0 0 5rem;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.gallery-tile {
  position: relative;
  overflow: hidden;
  min-height: clamp(165px, 14vw, 215px);
  background: #090f1d;
  border: 1px solid var(--border);
}

.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%) brightness(.78) contrast(1.06);
  transition: transform .45s ease, filter .45s ease;
}

.gallery-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(143,179,232,.22);
  mix-blend-mode: color;
  transition: opacity .45s ease;
}

.gallery-tile:hover img {
  transform: scale(1.045);
  filter: grayscale(0) brightness(1) contrast(1);
}

.gallery-tile:hover::after {
  opacity: 0;
}

@media(max-width:900px) {
  .about-layout {
    grid-template-columns: 1fr;
  }

  .about-portrait {
    position: relative;
    top: auto;
    min-height: 420px;
  }

  .about-portrait img {
    min-height: 420px;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:620px) {
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .gallery-tile {
    min-height: 180px;
  }
}


/* Über mich – Feinschliff */
.about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
  gap: clamp(2rem, 5vw, 4.8rem);
  align-items: start;
}

.about-text {
  max-width: 760px;
}

.about-title {
  margin-bottom: 2.2rem;
}

.about-text p {
  margin: 0 0 .55rem;
  color: var(--text-soft);
  font-size: clamp(.93rem, .95vw, 1rem);
  line-height: 1.58;
}

.about-text .page-kicker {
  margin: 0 0 .9rem;
}

.about-text .about-gap-after {
  margin-bottom: 1.95rem;
}

.about-portrait {
  position: sticky;
  top: calc(var(--header-height) + 2rem);
  min-height: min(68vh, 640px);
  overflow: hidden;
  background: #07101f;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}

.about-portrait img {
  width: 100%;
  height: 100%;
  min-height: min(68vh, 640px);
  object-fit: cover;
  object-position: center center;
  opacity: .62;
  filter: grayscale(100%) blur(.7px) brightness(.86) contrast(.95);
}

.about-portrait::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(12,19,36,.72), rgba(12,19,36,.22) 34%, rgba(12,19,36,.28) 68%, rgba(12,19,36,.82)),
    radial-gradient(circle at center, rgba(173,200,245,.08), rgba(12,19,36,.58) 70%);
}

.about-gallery {
  padding: 0 0 5rem;
}

.about-gallery .container {
  border-top: 1px solid rgba(173,200,245,.24);
  padding-top: 1.35rem;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.gallery-tile {
  position: relative;
  overflow: hidden;
  height: clamp(135px, 10.5vw, 175px);
  min-height: 0;
  background: #090f1d;
  border: 1px solid var(--border);
}

.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%) brightness(.78) contrast(1.06);
  transition: transform .45s ease, filter .45s ease;
}

.gallery-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(143,179,232,.22);
  mix-blend-mode: color;
  transition: opacity .45s ease;
}

.gallery-tile:hover img {
  transform: scale(1.045);
  filter: grayscale(0) brightness(1) contrast(1);
}

.gallery-tile:hover::after {
  opacity: 0;
}

@media(max-width:900px) {
  .about-layout {
    grid-template-columns: 1fr;
  }

  .about-portrait {
    position: relative;
    top: auto;
    min-height: 420px;
  }

  .about-portrait img {
    min-height: 420px;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .gallery-tile {
    height: clamp(150px, 26vw, 210px);
  }
}

@media(max-width:620px) {
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .gallery-tile {
    height: 185px;
  }
}


/* Über mich – Textstruktur final */
.about-title {
  margin-bottom: 2rem;
}

.about-text p {
  margin: 0 0 1.55rem;
}

.about-text p:last-of-type {
  margin-bottom: 0;
}

.about-text .about-gap-after {
  margin-bottom: 1.95rem;
}

.about-text br {
  display: block;
  content: "";
  margin-top: .18rem;
}


/* Über mich – Designcheck: Blocksatz, Portrait, Bildstrecke */
.about-layout {
  align-items: center;
}

.about-text p {
  text-align: left;
  text-align-last: left;
  hyphens: manual;
}

.about-portrait {
  position: relative;
  top: auto;
  align-self: center;
  height: min(66vh, 620px);
  min-height: 500px;
  overflow: hidden;
}

.about-portrait img {
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center center;
}

.about-gallery {
  padding-top: .5rem;
}

.about-gallery .container {
  border-top: 1px solid rgba(173,200,245,.24);
  padding-top: 1.45rem;
}

.about-gallery .gallery-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(.8rem, 1.3vw, 1.15rem);
}

.about-gallery .gallery-tile {
  height: clamp(125px, 9.5vw, 165px);
  min-height: 0;
  aspect-ratio: 16 / 9;
}

.about-gallery .gallery-tile img {
  object-fit: cover;
  object-position: center center;
}

@media(max-width:900px) {
  .about-layout {
    align-items: start;
  }

  .about-portrait {
    height: 460px;
    min-height: 0;
  }

  .about-gallery .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-gallery .gallery-tile {
    height: auto;
    aspect-ratio: 16 / 9;
  }
}

@media(max-width:620px) {
  .about-text p {
    text-align: left;
  }

  .about-gallery .gallery-grid {
    grid-template-columns: 1fr;
  }
}


/* Über mich – Bildverlauf und zentrierte Bildstrecke */
.about-portrait {
  border: 0;
  box-shadow: none;
  background: transparent;
}

.about-portrait img {
  display: block;
}

.about-portrait::before {
  z-index: 2;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.10) 0%,
      rgba(12,19,36,.10) 50%,
      rgba(12,19,36,.48) 78%,
      var(--bg) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.07), rgba(12,19,36,.42) 68%);
}

.about-portrait::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 34%;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(12,19,36,0), var(--bg) 82%);
}

.about-gallery .container {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
}

.about-gallery .gallery-grid {
  justify-content: center;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
}

.about-gallery .gallery-tile {
  height: auto;
  aspect-ratio: 16 / 9;
  min-height: 0;
}

@media(max-width:900px) {
  .about-gallery .container {
    max-width: 760px;
  }
}


/* Über mich – Bildstrecke größer, Portrait-Verlauf dezenter */
.about-portrait::before {
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.08) 0%,
      rgba(12,19,36,.08) 56%,
      rgba(12,19,36,.34) 82%,
      rgba(12,19,36,.72) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.36) 70%);
}

.about-portrait::after {
  height: 24%;
  background: linear-gradient(to bottom, rgba(12,19,36,0), var(--bg) 92%);
}

.about-gallery .container {
  max-width: 1180px;
}

.about-gallery .gallery-grid {
  gap: clamp(1rem, 1.6vw, 1.35rem);
}

.about-gallery .gallery-tile {
  aspect-ratio: 16 / 9;
  height: clamp(170px, 13vw, 220px);
}

@media(max-width:900px) {
  .about-gallery .container {
    max-width: 860px;
  }

  .about-gallery .gallery-tile {
    height: auto;
    aspect-ratio: 16 / 9;
  }
}


/* Über mich – Bildstrecke final ausrichten */
.about-gallery .container {
  width: min(calc(100% - 2rem), 1180px);
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
  border-top: 1px solid rgba(173,200,245,.24);
  padding-top: 1.55rem;
}

.about-gallery .gallery-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(.9rem, 1.15vw, 1.15rem) !important;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
}

.about-gallery .gallery-tile {
  height: clamp(170px, 12.2vw, 210px);
  min-height: 0;
  aspect-ratio: auto;
}

.about-gallery .gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media(max-width:900px) {
  .about-gallery .container {
    width: min(calc(100% - 1.5rem), 860px);
  }

  .about-gallery .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .about-gallery .gallery-tile {
    height: auto;
    aspect-ratio: 16 / 9;
  }
}

@media(max-width:620px) {
  .about-gallery .gallery-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Über mich – Text breiter, Bildstrecke rechteckig */
.about-layout {
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, .72fr);
  gap: clamp(2rem, 4vw, 4rem);
}

.about-text {
  max-width: 880px;
}

.about-gallery .gallery-tile {
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
}

.about-gallery .gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media(max-width:900px) {
  .about-layout {
    grid-template-columns: 1fr;
  }

  .about-text {
    max-width: 100%;
  }
}


/* Über mich – Textbreite zurücknehmen, Portrait stabil, Bildstrecke größer */
.about-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  gap: clamp(2.2rem, 4.6vw, 4.8rem);
}

.about-text {
  max-width: 780px;
}

.about-portrait {
  width: 100%;
  max-width: 520px;
  justify-self: end;
}

.about-gallery .container {
  width: min(calc(100% - 2rem), 1280px);
  max-width: 1280px;
}

.about-gallery .gallery-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(1rem, 1.35vw, 1.4rem) !important;
}

.about-gallery .gallery-tile {
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
}

@media(max-width:900px) {
  .about-layout {
    grid-template-columns: 1fr;
  }

  .about-text {
    max-width: 100%;
  }

  .about-portrait {
    max-width: 100%;
    justify-self: stretch;
  }

  .about-gallery .container {
    width: min(calc(100% - 1.5rem), 920px);
  }

  .about-gallery .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media(max-width:620px) {
  .about-gallery .gallery-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Über mich – Portrait-Rahmen mit Ausfade nach unten */
.about-portrait {
  position: relative;
}

.about-portrait::before {
  z-index: 2;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.08) 0%,
      rgba(12,19,36,.08) 56%,
      rgba(12,19,36,.34) 82%,
      rgba(12,19,36,.72) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.36) 70%);
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 62%, rgba(173,200,245,0) 100%) left top / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 62%, rgba(173,200,245,0) 100%) right top / 1px 100% no-repeat,
    linear-gradient(to right, rgba(173,200,245,.24), rgba(173,200,245,.24)) left top / 100% 1px no-repeat;
}

.about-portrait .portrait-bottom-fade {
  display: none;
}


/* Über mich – Korrektur: Abstand, sauberer Fade, größere Galerie */
.about-layout {
  gap: clamp(3.2rem, 6.2vw, 6.4rem);
}

.about-portrait::before {
  z-index: 2;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.08) 0%,
      rgba(12,19,36,.08) 58%,
      rgba(12,19,36,.28) 78%,
      rgba(12,19,36,.78) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.36) 70%);
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 60%, rgba(173,200,245,0) 100%) left top / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 60%, rgba(173,200,245,0) 100%) right top / 1px 100% no-repeat,
    linear-gradient(to right, rgba(173,200,245,.24), rgba(173,200,245,.24)) left top / 100% 1px no-repeat;
}

.about-gallery .container {
  width: min(calc(100% - 1rem), 1460px);
  max-width: 1460px;
}

.about-gallery .gallery-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(.9rem, 1.05vw, 1.2rem) !important;
}

.about-gallery .gallery-tile {
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
}

@media(max-width:900px) {
  .about-layout {
    gap: 2.4rem;
  }

  .about-gallery .container {
    width: min(calc(100% - 1rem), 960px);
  }

  .about-gallery .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media(max-width:620px) {
  .about-gallery .gallery-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Über mich – final: mehr Abstand zwischen Text und Foto, Galerie etwas größer */
.about-layout {
  gap: clamp(4.2rem, 8vw, 8.2rem);
}

.about-gallery .container {
  width: min(calc(100% - .5rem), 1520px);
  max-width: 1520px;
}

.about-gallery .gallery-grid {
  gap: clamp(.85rem, 1vw, 1.15rem) !important;
}

@media(min-width:901px) {
  .about-gallery .gallery-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media(max-width:900px) {
  .about-layout {
    gap: 2.6rem;
  }
}


/* Über mich – Textblock breiter, Foto weiter rechts, Abstand bleibt groß */
.about-container {
  width: min(calc(100% - 2rem), 1380px);
  max-width: 1380px;
}

.about-layout {
  grid-template-columns: minmax(0, 1.32fr) minmax(360px, .68fr);
  gap: clamp(4.6rem, 8.8vw, 9rem);
}

.about-text {
  max-width: 900px;
}

.about-portrait {
  justify-self: end;
  max-width: 520px;
}

@media(max-width:900px) {
  .about-container {
    width: min(calc(100% - 1.5rem), 900px);
  }

  .about-layout {
    grid-template-columns: 1fr;
    gap: 2.6rem;
  }

  .about-text {
    max-width: 100%;
  }

  .about-portrait {
    max-width: 100%;
    justify-self: stretch;
  }
}


/* Über mich – Foto minimal tiefer setzen */
.about-portrait {
  margin-top: clamp(1.2rem, 2.2vw, 2rem);
}


/* Über mich – finale Balance: Foto vollständig sichtbar, Text wieder harmonischer */
.about-container {
  width: min(calc(100% - 2rem), 1320px);
  max-width: 1320px;
}

.about-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(420px, .92fr);
  gap: clamp(4rem, 7.2vw, 7.2rem);
  align-items: center;
}

.about-text {
  max-width: 800px;
}

.about-portrait {
  width: 100%;
  max-width: 560px;
  justify-self: end;
  align-self: center;
  margin-top: clamp(1.2rem, 2vw, 1.8rem);
  height: auto;
  min-height: 0;
  overflow: hidden;
  background: transparent;
}

.about-portrait img {
  width: 100%;
  height: auto;
  min-height: 0;
  object-fit: contain;
  object-position: center center;
  opacity: .72;
  filter: grayscale(100%) blur(.55px) brightness(.86) contrast(.95);
}

.about-portrait::before {
  z-index: 2;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.08) 0%,
      rgba(12,19,36,.08) 58%,
      rgba(12,19,36,.22) 80%,
      rgba(12,19,36,.58) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.28) 72%);
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 66%, rgba(173,200,245,0) 100%) left top / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 66%, rgba(173,200,245,0) 100%) right top / 1px 100% no-repeat,
    linear-gradient(to right, rgba(173,200,245,.24), rgba(173,200,245,.24)) left top / 100% 1px no-repeat;
}

@media(max-width:900px) {
  .about-container {
    width: min(calc(100% - 1.5rem), 900px);
  }

  .about-layout {
    grid-template-columns: 1fr;
    gap: 2.8rem;
  }

  .about-text {
    max-width: 100%;
  }

  .about-portrait {
    max-width: 100%;
    justify-self: stretch;
    margin-top: 0;
  }
}


/* Über mich – Foto wieder leicht beschnitten, Fade bleibt erhalten */
.about-layout {
  grid-template-columns: minmax(0, 1.05fr) minmax(400px, .95fr);
  gap: clamp(4rem, 7.4vw, 7.4rem);
}

.about-text {
  max-width: 790px;
}

.about-portrait {
  max-width: 540px;
  height: min(66vh, 620px);
  min-height: 520px;
  overflow: hidden;
}

.about-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  opacity: .70;
  filter: grayscale(100%) blur(.55px) brightness(.86) contrast(.95);
}

.about-portrait::before {
  z-index: 2;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,.08) 0%,
      rgba(12,19,36,.08) 54%,
      rgba(12,19,36,.24) 78%,
      rgba(12,19,36,.70) 100%
    ),
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.32) 72%);
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 62%, rgba(173,200,245,0) 100%) left top / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(173,200,245,.24), rgba(173,200,245,.24) 62%, rgba(173,200,245,0) 100%) right top / 1px 100% no-repeat,
    linear-gradient(to right, rgba(173,200,245,.24), rgba(173,200,245,.24)) left top / 100% 1px no-repeat,
    linear-gradient(to bottom, rgba(12,19,36,0) 0%, var(--bg) 100%) left bottom / 100% 24% no-repeat;
}

@media(max-width:900px) {
  .about-layout {
    grid-template-columns: 1fr;
    gap: 2.8rem;
  }

  .about-portrait {
    max-width: 100%;
    height: 460px;
    min-height: 0;
  }
}


/* Über mich – Korrektur Bildfehler: getrennte Ebenen für Foto-Fade und Rahmen */
.about-portrait {
  position: relative;
  isolation: isolate;
  background: var(--bg);
}

.about-portrait img {
  position: relative;
  z-index: 1;
}

.about-portrait::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(circle at center, rgba(173,200,245,.06), rgba(12,19,36,.30) 72%),
    linear-gradient(to bottom,
      rgba(12,19,36,.04) 0%,
      rgba(12,19,36,.04) 58%,
      rgba(12,19,36,.22) 80%,
      var(--bg) 100%
    );
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  border-top: 1px solid rgba(173,200,245,.24);
  border-left: 1px solid rgba(173,200,245,.24);
  border-right: 1px solid rgba(173,200,245,.24);
  border-bottom: 0;
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 64%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 64%, transparent 100%);
}


/* Über mich – elegante Bildeinfassung */
.about-portrait::after {
  border-top: 1px solid rgba(173,200,245,.24);
  border-left: 1px solid rgba(173,200,245,.24);
  border-right: 1px solid rgba(173,200,245,.24);
  border-bottom: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 66%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 66%, transparent 100%);
}

.about-gallery .gallery-tile {
  border: 1px solid rgba(173,200,245,.16);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.018);
  background: rgba(255,255,255,.025);
}

.about-gallery .gallery-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255,255,255,.045), rgba(255,255,255,0) 38%, rgba(12,19,36,.18));
}

.about-gallery .gallery-tile::after {
  z-index: 3;
  background: rgba(143,179,232,.20);
}

.about-gallery .gallery-tile:hover {
  border-color: rgba(173,200,245,.28);
}

.about-gallery .gallery-tile:hover::before {
  opacity: .55;
}


/* Über mich – Korrektur: Streifen im Portrait entfernen */
.about-portrait::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(12,19,36,0) 0%,
    rgba(12,19,36,0) 68%,
    rgba(12,19,36,.22) 84%,
    var(--bg) 100%
  );
}

.about-portrait::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  border-top: 1px solid rgba(173,200,245,.24);
  border-left: 1px solid rgba(173,200,245,.24);
  border-right: 1px solid rgba(173,200,245,.24);
  border-bottom: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 68%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 68%, transparent 100%);
}


/* Über mich – saubere Portrait-Ebene ohne Stirn-Streifen */
.about-portrait {
  position: relative;
  background: transparent;
  overflow: visible;
}

.about-portrait::before,
.about-portrait::after {
  display: none !important;
  content: none !important;
}

.portrait-frame {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--bg);
}

.portrait-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  opacity: .70;
  filter: grayscale(100%) blur(.55px) brightness(.86) contrast(.95);
}

.portrait-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(to bottom,
      rgba(12,19,36,0) 0%,
      rgba(12,19,36,0) 66%,
      rgba(12,19,36,.22) 84%,
      var(--bg) 100%
    );
}

.portrait-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  border-top: 1px solid rgba(173,200,245,.24);
  border-left: 1px solid rgba(173,200,245,.24);
  border-right: 1px solid rgba(173,200,245,.24);
  border-bottom: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 68%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 68%, transparent 100%);
}

@media(max-width:900px) {
  .portrait-frame {
    height: 100%;
  }
}

/* Termine – an Masterdesign angeglichen */
.schedule-page {
  padding-top: clamp(4.8rem, 7vw, 6.8rem);
}

.schedule-container {
  width: min(calc(100% - 2rem), 1180px);
  max-width: 1180px;
}

.schedule-lead {
  max-width: 62ch;
}

.schedule-shell {
  margin-top: clamp(2.4rem, 4vw, 3.4rem);
  border-top: 1px solid rgba(173,200,245,.24);
  padding-top: 1.2rem;
}

.schedule-head,
.schedule-row {
  display: grid;
  grid-template-columns: 150px minmax(220px, 1.35fr) minmax(220px, 1fr) 100px 70px;
  gap: clamp(.8rem, 1.8vw, 1.25rem);
  align-items: center;
}

.schedule-head {
  padding: 0 1rem .9rem;
  color: rgba(197,198,210,.64);
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: .74rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.schedule-table {
  border-top: 0;
}

.schedule-row {
  position: relative;
  padding: 1.3rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,.10);
  transition: background-color .2s ease, border-color .2s ease;
}

.schedule-row::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(to right, rgba(173,200,245,.045), transparent 48%);
  opacity: 0;
  transition: opacity .2s ease;
}

.schedule-row:hover {
  background: rgba(255,255,255,.025);
  border-bottom-color: rgba(173,200,245,.20);
}

.schedule-row:hover::before {
  opacity: 1;
}

.schedule-date .day {
  color: var(--primary);
  font-family: var(--font-headline);
  font-size: 1.42rem;
  line-height: 1;
}

.schedule-date .month-year,
.schedule-meta {
  color: var(--text-soft);
  font-size: .92rem;
}

.schedule-project,
.schedule-venue,
.schedule-time {
  font-family: var(--font-headline);
  font-weight: 400;
}

.schedule-project {
  color: var(--text);
  font-size: clamp(1.08rem, 1.3vw, 1.24rem);
  line-height: 1.18;
}

.schedule-venue {
  color: var(--text);
  font-size: 1.05rem;
  line-height: 1.2;
}

.schedule-time {
  color: var(--text-soft);
  font-size: 1.06rem;
}

.link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(173,200,245,.18);
  color: var(--text-soft);
  background: rgba(255,255,255,.025);
  transition: color .2s ease, transform .2s ease, border-color .2s ease, background-color .2s ease;
}

.link-icon svg {
  width: 18px;
  height: 18px;
}

.link-icon:hover {
  color: var(--primary);
  transform: translate(2px,-2px);
  border-color: rgba(173,200,245,.38);
  background: rgba(173,200,245,.055);
}

.link-icon.is-disabled {
  opacity: .34;
  pointer-events: none;
}

.schedule-mobile {
  display: none;
}

.schedule-card {
  padding: 1.35rem 0;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.schedule-card-top {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 1rem;
}

.schedule-mobile-date {
  color: var(--primary);
  font-family: var(--font-headline);
  font-size: 1.05rem;
}

.schedule-card-title {
  margin: .45rem 0 0;
  font-family: var(--font-headline);
  font-size: 1.28rem;
  font-weight: 400;
  line-height: 1.15;
}

.schedule-card-panel {
  margin-top: .95rem;
  padding: 1rem;
  border: 1px solid rgba(173,200,245,.14);
  background: rgba(255,255,255,.025);
}

.schedule-card-panel p {
  margin: 0;
}

.schedule-card-panel p + p {
  margin-top: .25rem;
}

.empty-state {
  margin: 1.6rem 0 0;
  color: var(--text-soft);
}

@media(max-width:900px) {
  .schedule-head,
  .schedule-table {
    display: none;
  }

  .schedule-mobile {
    display: block;
  }

  .schedule-container {
    width: min(calc(100% - 1.5rem), 900px);
  }
}

/* Kontakt – an Masterdesign angeglichen */
.contact-page {
  padding-top: clamp(4.8rem, 7vw, 6.8rem);
}

.contact-container {
  width: min(calc(100% - 2rem), 1120px);
  max-width: 1120px;
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .85fr);
  gap: clamp(3rem, 7vw, 6.5rem);
  align-items: center;
}

.contact-copy-block .page-title {
  margin-bottom: 1.25rem;
}

.contact-panel {
  position: relative;
  border-top: 1px solid rgba(173,200,245,.24);
  border-left: 1px solid rgba(173,200,245,.18);
  border-right: 1px solid rgba(173,200,245,.18);
  padding: clamp(1.4rem, 3vw, 2rem);
  background:
    linear-gradient(to bottom, rgba(255,255,255,.035), rgba(255,255,255,.015)),
    rgba(255,255,255,.018);
  box-shadow: var(--shadow);
}

.contact-panel::after {
  content: "";
  position: absolute;
  left: -1px;
  right: -1px;
  bottom: -1px;
  height: 34%;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(12,19,36,0), var(--bg) 92%);
}

.contact-item {
  position: relative;
  z-index: 1;
  padding: 0 0 1.35rem;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: transparent;
}

.contact-item + .contact-item {
  padding-top: 1.35rem;
}

.contact-label {
  margin: 0 0 .5rem;
  color: rgba(197,198,210,.68);
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: .74rem;
}

.contact-value {
  margin: 0;
  font-family: var(--font-headline);
  color: var(--text);
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.contact-value a:hover {
  color: var(--primary);
}

.contact-note {
  position: relative;
  z-index: 1;
  margin: 1.35rem 0 0;
  color: var(--text-soft);
  font-size: .98rem;
  line-height: 1.65;
}

.contact-socials {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
}

.contact-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  color: var(--text-soft);
  border: 1px solid rgba(173,200,245,.18);
  background: rgba(255,255,255,.025);
  transition: color .2s ease, transform .2s ease, border-color .2s ease, background-color .2s ease;
}

.contact-social-link svg {
  width: 21px;
  height: 21px;
}

.contact-social-link:hover {
  color: var(--primary);
  transform: translateY(-1px);
  border-color: rgba(173,200,245,.36);
  background: rgba(173,200,245,.055);
}

@media(max-width:900px) {
  .contact-container {
    width: min(calc(100% - 1.5rem), 900px);
  }

  .contact-layout {
    grid-template-columns: 1fr;
    gap: 2.6rem;
  }
}


/* Kontakt – nur relevante Kontaktfelder */
.contact-panel .contact-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.contact-panel .contact-value {
  font-size: clamp(1.05rem, 1.7vw, 1.35rem);
}


/* Kontakt – klare Kontaktfelder */
.contact-page {
  padding-top: clamp(4.8rem, 7vw, 6.8rem);
}

.contact-container {
  width: min(calc(100% - 2rem), 980px);
  max-width: 980px;
}

.contact-field-list {
  margin-top: clamp(2rem, 3.5vw, 3rem);
  display: grid;
  gap: 1.35rem;
  padding: clamp(1.1rem, 2.3vw, 1.6rem);
  border: 1px solid rgba(173,200,245,.16);
  background: rgba(255,255,255,.018);
}

.contact-field {
  display: block;
  padding: clamp(1.3rem, 2.6vw, 1.85rem);
  border: 1px solid rgba(173,200,245,.18);
  background: rgba(255,255,255,.028);
  transition: border-color .2s ease, background-color .2s ease, transform .2s ease;
}

.contact-field:hover {
  border-color: rgba(173,200,245,.34);
  background: rgba(173,200,245,.045);
  transform: translateY(-1px);
}

.contact-field .contact-label {
  display: block;
  margin: 0 0 .55rem;
  color: rgba(197,198,210,.78);
  letter-spacing: .26em;
  text-transform: uppercase;
  font-size: .78rem;
}

.contact-field .contact-value {
  display: block;
  margin: 0;
  font-family: var(--font-headline);
  color: var(--text);
  font-size: clamp(1.18rem, 2.3vw, 1.65rem);
  line-height: 1.22;
  overflow-wrap: anywhere;
}

.contact-field:hover .contact-value {
  color: var(--primary);
}

@media(max-width:640px) {
  .contact-container {
    width: min(calc(100% - 1.5rem), 980px);
  }

  .contact-field-list {
    padding: .8rem;
    gap: .9rem;
  }

  .contact-field {
    padding: 1.1rem;
  }
}


/* Kontakt – links bündig wie Termine */
.contact-container {
  width: min(calc(100% - 2rem), 1180px);
  max-width: 1180px;
}

.contact-field-list {
  max-width: 980px;
  margin-left: 0;
  margin-right: auto;
}

/* NAV-DROPDOWN-PRETTY START */
/* Aufgeräumtes Projekt-Dropdown mit Trennlinien */
.site-nav li {
  position: relative;
}

.site-nav > ul > li > ul,
.site-nav > ul > li > .dropdown-menu,
.site-nav > ul > li > .submenu,
.site-nav > ul > li > .sub-menu,
.site-nav > ul > li > .nav-dropdown,
.site-nav > ul > li > .projects-dropdown,
.site-nav > ul > li > .dropdown {
  display: none !important;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
  min-width: 245px;
  max-width: 320px;
  margin: 0;
  padding: .65rem 0 .45rem;
  list-style: none;
  flex-direction: column !important;
  gap: 0 !important;
  background: rgba(10,18,34,.96);
  border: 1px solid rgba(173,200,245,.26);
  box-shadow: 0 22px 48px rgba(0,0,0,.38);
  backdrop-filter: blur(16px);
  z-index: 1200;
}

.site-nav > ul > li > ul::before,
.site-nav > ul > li > .dropdown-menu::before,
.site-nav > ul > li > .submenu::before,
.site-nav > ul > li > .sub-menu::before,
.site-nav > ul > li > .nav-dropdown::before,
.site-nav > ul > li > .projects-dropdown::before,
.site-nav > ul > li > .dropdown::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: rgba(173,200,245,.55);
}

.site-nav > ul > li:hover > ul,
.site-nav > ul > li:focus-within > ul,
.site-nav > ul > li:hover > .dropdown-menu,
.site-nav > ul > li:focus-within > .dropdown-menu,
.site-nav > ul > li:hover > .submenu,
.site-nav > ul > li:focus-within > .submenu,
.site-nav > ul > li:hover > .sub-menu,
.site-nav > ul > li:focus-within > .sub-menu,
.site-nav > ul > li:hover > .nav-dropdown,
.site-nav > ul > li:focus-within > .nav-dropdown,
.site-nav > ul > li:hover > .projects-dropdown,
.site-nav > ul > li:focus-within > .projects-dropdown,
.site-nav > ul > li:hover > .dropdown,
.site-nav > ul > li:focus-within > .dropdown {
  display: flex !important;
}

.site-nav > ul > li > ul > li,
.site-nav > ul > li > .dropdown-menu > li,
.site-nav > ul > li > .submenu > li,
.site-nav > ul > li > .sub-menu > li,
.site-nav > ul > li > .nav-dropdown > li,
.site-nav > ul > li > .projects-dropdown > li,
.site-nav > ul > li > .dropdown > li {
  width: 100%;
}

.site-nav > ul > li > ul > li + li,
.site-nav > ul > li > .dropdown-menu > li + li,
.site-nav > ul > li > .submenu > li + li,
.site-nav > ul > li > .sub-menu > li + li,
.site-nav > ul > li > .nav-dropdown > li + li,
.site-nav > ul > li > .projects-dropdown > li + li,
.site-nav > ul > li > .dropdown > li + li {
  border-top: 1px solid rgba(173,200,245,.13);
}

.site-nav > ul > li > ul a,
.site-nav > ul > li > .dropdown-menu a,
.site-nav > ul > li > .submenu a,
.site-nav > ul > li > .sub-menu a,
.site-nav > ul > li > .nav-dropdown a,
.site-nav > ul > li > .projects-dropdown a,
.site-nav > ul > li > .dropdown a {
  display: block !important;
  width: 100%;
  padding: .68rem .95rem;
  white-space: nowrap;
  font-family: var(--font-headline);
  font-size: .96rem;
  line-height: 1.15;
  letter-spacing: .01em;
  font-style: normal;
  color: rgba(220,225,251,.86);
  background: transparent;
}

.site-nav > ul > li > ul a:hover,
.site-nav > ul > li > ul a:focus-visible,
.site-nav > ul > li > .dropdown-menu a:hover,
.site-nav > ul > li > .dropdown-menu a:focus-visible,
.site-nav > ul > li > .submenu a:hover,
.site-nav > ul > li > .submenu a:focus-visible,
.site-nav > ul > li > .sub-menu a:hover,
.site-nav > ul > li > .sub-menu a:focus-visible,
.site-nav > ul > li > .nav-dropdown a:hover,
.site-nav > ul > li > .nav-dropdown a:focus-visible,
.site-nav > ul > li > .projects-dropdown a:hover,
.site-nav > ul > li > .projects-dropdown a:focus-visible,
.site-nav > ul > li > .dropdown a:hover,
.site-nav > ul > li > .dropdown a:focus-visible {
  color: var(--primary);
  background: rgba(173,200,245,.075);
}

/* Mobile: Projektlinks sauber eingerückt, mit feinen Linien, nicht seitlich. */
@media (max-width: 900px) {
  .site-nav > ul > li > ul,
  .site-nav > ul > li > .dropdown-menu,
  .site-nav > ul > li > .submenu,
  .site-nav > ul > li > .sub-menu,
  .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li > .projects-dropdown,
  .site-nav > ul > li > .dropdown {
    position: static;
    transform: none;
    width: 100%;
    min-width: 0;
    max-width: none;
    margin: .15rem 0 .45rem;
    padding: .15rem 0 .15rem .85rem;
    border: 0;
    border-left: 1px solid rgba(173,200,245,.22);
    box-shadow: none;
    background: transparent;
    backdrop-filter: none;
  }

  .site-nav > ul > li > ul::before,
  .site-nav > ul > li > .dropdown-menu::before,
  .site-nav > ul > li > .submenu::before,
  .site-nav > ul > li > .sub-menu::before,
  .site-nav > ul > li > .nav-dropdown::before,
  .site-nav > ul > li > .projects-dropdown::before,
  .site-nav > ul > li > .dropdown::before {
    display: none;
  }

  .site-header.is-open .site-nav > ul > li > ul,
  .site-header.is-open .site-nav > ul > li > .dropdown-menu,
  .site-header.is-open .site-nav > ul > li > .submenu,
  .site-header.is-open .site-nav > ul > li > .sub-menu,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .projects-dropdown,
  .site-header.is-open .site-nav > ul > li > .dropdown {
    display: grid !important;
  }

  .site-nav > ul > li > ul > li + li,
  .site-nav > ul > li > .dropdown-menu > li + li,
  .site-nav > ul > li > .submenu > li + li,
  .site-nav > ul > li > .sub-menu > li + li,
  .site-nav > ul > li > .nav-dropdown > li + li,
  .site-nav > ul > li > .projects-dropdown > li + li,
  .site-nav > ul > li > .dropdown > li + li {
    border-top: 1px solid rgba(173,200,245,.10);
  }

  .site-nav > ul > li > ul a,
  .site-nav > ul > li > .dropdown-menu a,
  .site-nav > ul > li > .submenu a,
  .site-nav > ul > li > .sub-menu a,
  .site-nav > ul > li > .nav-dropdown a,
  .site-nav > ul > li > .projects-dropdown a,
  .site-nav > ul > li > .dropdown a {
    padding: .55rem .65rem;
    white-space: normal;
    font-size: .96rem;
  }
}

/* Dropdown-Hover-Brücke: verhindert, dass das Menü beim Hinunterfahren mit der Maus sofort schließt. */
.site-nav > ul > li:has(> ul)::after,
.site-nav > ul > li:has(> .dropdown-menu)::after,
.site-nav > ul > li:has(> .submenu)::after,
.site-nav > ul > li:has(> .sub-menu)::after,
.site-nav > ul > li:has(> .nav-dropdown)::after,
.site-nav > ul > li:has(> .projects-dropdown)::after,
.site-nav > ul > li:has(> .dropdown)::after {
  content: "";
  display: none;
  position: absolute;
  left: -1rem;
  right: -1rem;
  top: 100%;
  height: 1rem;
}
.site-nav > ul > li:hover::after,
.site-nav > ul > li:focus-within::after {
  display: block;
}

/* NAV-DROPDOWN-PRETTY END */

/* Projektunterseiten – gemeinsames Raster
   Referenz: Lignum Vitae. Für neue Projekte nur Inhalt austauschen:
   Titel, optional Untertitel, Bild, Besetzung, Text, optional Album/Link, optional Video. */
.project-detail-page {
  padding-top: clamp(4.8rem, 7vw, 6.8rem);
}

.project-detail-container {
  width: min(calc(100% - 2rem), 1120px);
  max-width: 1120px;
}

.project-detail-title {
  max-width: none;
  margin-bottom: .65rem;
  white-space: nowrap;
  font-size: clamp(1.85rem, 3.25vw, 3.15rem);
  line-height: 1.06;
}

.project-detail-subtitle {
  margin: 0 0 1.8rem;
}

.project-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .75fr);
  gap: clamp(2rem, 4.6vw, 3.8rem);
  align-items: center;
}

.project-detail-image {
  margin: 0;
  overflow: visible;
}

.project-detail-image img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  border: 1px solid rgba(173,200,245,.22);
  box-shadow: 0 16px 30px rgba(0,0,0,.18);
  background: #07101f;
}

.project-detail-image figcaption {
  margin-top: .42rem;
  color: rgba(197,198,210,.68);
  font-size: .74rem;
  line-height: 1.35;
  letter-spacing: .02em;
  text-align: right;
}

.project-detail-meta {
  align-self: center;
  padding: clamp(1.45rem, 2.5vw, 1.85rem);
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.project-detail-meta h2 {
  margin: 0 0 1rem;
  font-family: var(--font-headline);
  font-size: clamp(1.7rem, 3vw, 2.25rem);
  font-weight: 400;
}

.project-detail-list {
  display: grid;
  gap: .85rem;
  color: var(--text-soft);
  font-size: 1.02rem;
  line-height: 1.55;
}

.project-detail-list p {
  margin: 0;
  padding-bottom: .75rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.project-detail-list p:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.project-detail-list strong {
  color: var(--primary);
  font-weight: 500;
}

.project-detail-action {
  margin-top: 1.35rem;
  padding-top: 1.15rem;
  border-top: 1px solid rgba(255,255,255,.10);
}

.project-detail-action a {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  padding: 0 1rem;
  border: 1px solid rgba(173,200,245,.32);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
}

.project-detail-copy {
  margin-top: clamp(2rem, 3.4vw, 2.7rem);
  max-width: 82ch;
  border-top: 1px solid rgba(173,200,245,.18);
  padding-top: 1.35rem;
  color: var(--text-soft);
}

.project-detail-copy p {
  margin: 0 0 1.15rem;
  font-size: 1rem;
  line-height: 1.7;
  text-align: justify;
  hyphens: auto;
  text-align-last: left;
}

.project-detail-copy p:last-child {
  margin-bottom: 0;
}

.project-detail-video {
  margin-top: clamp(2rem, 3.6vw, 2.8rem);
  max-width: 760px;
}

.project-detail-video h2 {
  font-family: var(--font-headline);
  font-size: clamp(2rem, 4vw, 3rem);
  margin: 0 0 1rem;
  font-weight: 400;
}

.project-detail-video-player,
.project-youtube {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 9;
  background: #060b15;
  border: 1px solid rgba(173,200,245,.20);
  box-shadow: 0 18px 34px rgba(0,0,0,.20);
}

.project-detail-video-copy {
  margin: .8rem 0 0;
  color: rgba(197,198,210,.72);
  font-size: .88rem;
  line-height: 1.45;
}

.project-youtube {
  position: relative;
  overflow: hidden;
}

.project-youtube-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(.48) contrast(1.08);
}

.project-youtube-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .85rem;
  padding: clamp(1rem, 3vw, 2rem);
  text-align: center;
  color: #fff;
  background: linear-gradient(to bottom, rgba(12,19,36,.22), rgba(12,19,36,.56)), rgba(12,19,36,.20);
}

.project-youtube-title {
  margin: 0;
  font-family: var(--font-headline);
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  color: #fff;
}

.project-youtube-copy {
  margin: 0;
  max-width: 74ch;
  color: rgba(255,255,255,.88);
  font-size: clamp(.86rem, 1.35vw, 1rem);
  line-height: 1.55;
}

.project-youtube-copy a {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: .18em;
}

.project-youtube-button {
  width: auto !important;
  height: auto !important;
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin-top: .15rem;
  padding: 0 1.05rem !important;
  border: 1px solid rgba(173,200,245,.34);
  border-radius: .28rem;
  background: rgba(11,116,174,.92);
  color: #fff;
  font-family: var(--font-headline);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
}

.project-youtube iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.project-detail-title--solo {
  margin-bottom: clamp(2.2rem, 3.6vw, 3.15rem);
}

.project-video-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}

.project-detail-page--wide-meta .project-detail-grid {
  grid-template-columns: minmax(0, 1fr) minmax(430px, .92fr);
  gap: clamp(1.8rem, 3.8vw, 3.2rem);
}

.project-detail-list-item--nowrap {
  white-space: nowrap;
}

@media(max-width:900px) {
  .project-detail-grid,
  .project-detail-page--wide-meta .project-detail-grid {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .project-detail-title {
    white-space: normal;
  }

  .project-detail-title--solo {
    margin-bottom: clamp(1.75rem, 6vw, 2.35rem);
  }

  .project-detail-video {
    max-width: 100%;
  }

  .project-detail-list-item--nowrap {
    white-space: normal;
  }
}

@media(max-width:760px) {
  .project-video-grid {
    grid-template-columns: 1fr;
  }
}


/* NAV-FINAL-OVERRIDE START */
.site-nav > ul > li > .nav-dropdown {
  display: none !important;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  min-width: 245px;
  max-width: 330px;
  margin: 0;
  padding: .65rem 0 .45rem;
  list-style: none;
  flex-direction: column !important;
  gap: 0 !important;
  background: rgba(10,18,34,.96);
  border: 1px solid rgba(173,200,245,.26);
  box-shadow: 0 22px 48px rgba(0,0,0,.38);
  backdrop-filter: blur(16px);
  z-index: 1200;
}
.site-nav > ul > li:hover > .nav-dropdown,
.site-nav > ul > li:focus-within > .nav-dropdown {
  display: flex !important;
}
.site-nav > ul > li > .nav-dropdown > li + li {
  border-top: 1px solid rgba(173,200,245,.13);
}
.site-nav > ul > li > .nav-dropdown a {
  display: block !important;
  width: 100%;
  padding: .68rem .95rem;
  white-space: nowrap;
  font-family: var(--font-headline);
  font-size: .96rem;
  line-height: 1.15;
  letter-spacing: .01em;
  font-style: normal;
  color: rgba(220,225,251,.86);
  background: transparent;
}
.site-nav > ul > li > .nav-dropdown a:hover,
.site-nav > ul > li > .nav-dropdown a:focus-visible {
  color: var(--primary);
  background: rgba(173,200,245,.075);
}
@media (max-width: 900px) {
  .site-nav > ul > li > .nav-dropdown {
    position: static;
    transform: none;
    width: 100%;
    min-width: 0;
    max-width: none;
    margin: .15rem 0 .45rem;
    padding: .15rem 0 .15rem .85rem;
    border: 0;
    border-left: 1px solid rgba(173,200,245,.22);
    box-shadow: none;
    background: transparent;
    backdrop-filter: none;
  }
  .site-header.is-open .site-nav > ul > li > .nav-dropdown {
    display: grid !important;
  }
  .site-nav > ul > li > .nav-dropdown a {
    padding: .55rem .65rem;
    white-space: normal;
  }
}
/* NAV-FINAL-OVERRIDE END */


/* VIDEO-SIZES-FINAL START */
/* Einheitlichere Größenordnung für Projektvideos; Gemischtes bleibt unberührt. */
.lignum-video,
.numaqam-video {
  max-width: 820px !important;
}

.project-detail-video {
  max-width: 980px !important;
}

.project-video-grid {
  gap: clamp(1rem, 2vw, 1.35rem) !important;
}

.project-detail-video-player,
.project-youtube,
.lignum-youtube,
.numaqam-video-player {
  width: 100%;
  aspect-ratio: 16 / 9;
}

@media (max-width: 900px) {
  .lignum-video,
  .numaqam-video,
  .project-detail-video {
    max-width: 100% !important;
  }
}
/* VIDEO-SIZES-FINAL END */


/* FINAL-PREUPLOAD-ADJUSTMENTS START */
/* Kontaktseite: Box angemessen kompakter */
.contact-field-list {
  max-width: 760px !important;
  padding: clamp(.75rem, 1.5vw, 1.05rem) !important;
  gap: .85rem !important;
  margin-top: clamp(1.65rem, 2.7vw, 2.25rem) !important;
}

.contact-field {
  padding: clamp(.95rem, 1.85vw, 1.25rem) !important;
}

.contact-field .contact-label {
  margin-bottom: .38rem !important;
  font-size: .72rem !important;
}

.contact-field .contact-value {
  font-size: clamp(1.02rem, 1.7vw, 1.28rem) !important;
}

/* Unterer Zurück-Link auf Projektunterseiten */
.project-bottom-link {
  display: inline-flex;
  margin-top: clamp(2.4rem, 4vw, 3.3rem);
  padding-top: .9rem;
  border-top: 1px solid rgba(173,200,245,.20);
  color: var(--text-soft);
  font-family: var(--font-headline);
  font-size: .98rem;
  text-decoration: none;
}

.project-bottom-link:hover,
.project-bottom-link:focus-visible {
  color: var(--primary);
}
/* FINAL-PREUPLOAD-ADJUSTMENTS END */


/* NAV-DROPDOWN-COMPACT-ELEGANT START */
/* Kompakteres, ruhigeres Projekt-Dropdown */
.site-nav > ul > li > .nav-dropdown {
  left: 50% !important;
  top: 100% !important;
  transform: translateX(-50%) !important;
  width: auto !important;
  min-width: 210px !important;
  max-width: 250px !important;
  padding: .42rem 0 !important;
  background: rgba(9,17,32,.97) !important;
  border: 1px solid rgba(173,200,245,.20) !important;
  box-shadow: 0 18px 34px rgba(0,0,0,.32) !important;
}

.site-nav > ul > li > .nav-dropdown > li + li {
  border-top: 1px solid rgba(173,200,245,.11) !important;
}

.site-nav > ul > li > .nav-dropdown a {
  padding: .56rem .82rem !important;
  font-size: .90rem !important;
  line-height: 1.16 !important;
  white-space: normal !important;
  color: rgba(220,225,251,.82) !important;
}

.site-nav > ul > li > .nav-dropdown a:hover,
.site-nav > ul > li > .nav-dropdown a:focus-visible {
  color: var(--primary) !important;
  background: rgba(173,200,245,.065) !important;
}

.site-nav > ul > li > .nav-dropdown::before {
  content: "";
  position: absolute;
  left: .55rem;
  right: .55rem;
  top: 0;
  height: 1px;
  background: rgba(173,200,245,.38);
}

@media (max-width: 900px) {
  .site-nav > ul > li > .nav-dropdown {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    transform: none !important;
    padding: .15rem 0 .15rem .85rem !important;
    background: transparent !important;
    border: 0 !important;
    border-left: 1px solid rgba(173,200,245,.20) !important;
    box-shadow: none !important;
  }

  .site-nav > ul > li > .nav-dropdown::before {
    display: none;
  }

  .site-nav > ul > li > .nav-dropdown a {
    padding: .52rem .65rem !important;
    font-size: .96rem !important;
  }
}
/* NAV-DROPDOWN-COMPACT-ELEGANT END */


/* NAV-DROPDOWN-NO-TOP-LINE START */
/* Keine zusätzliche dickere Schmucklinie oben im Dropdown */
.site-nav > ul > li > .nav-dropdown::before {
  display: none !important;
  content: none !important;
}
/* NAV-DROPDOWN-NO-TOP-LINE END */


/* PROJECT-BOTTOM-LINK-PLAIN START */
/* Ausnahme Gemischtes: Seite endet bereits mit Trennlinie, daher keine zweite Linie über dem Zurück-Link. */
.project-bottom-link--plain {
  border-top: 0 !important;
  padding-top: 0 !important;
}
/* PROJECT-BOTTOM-LINK-PLAIN END */


/* GEMISCHTES-BACKLINK-TIGHT START */
/* Gemischtes: unterer Zurück-Link näher an die vorhandene Abschlusslinie rücken. */
.project-bottom-link--tight {
  margin-top: .9rem !important;
}
/* GEMISCHTES-BACKLINK-TIGHT END */

/* PROJECT-MEDIA-UNIFORM-TRIAL START
   Reversibler Testblock:
   - Nur Videos werden vereinheitlicht
   - Bildgrößen bleiben unangetastet, damit keine Beschnitte,
     dunklen Rahmenboxen oder verrutschten Copyright-Zeilen entstehen
*/

/* Videos: einheitliches, kompakteres Format auf Projekt-Unterseiten */
.project-detail-video,
.fp-videos,
.lignum-video,
.numaqam-video {
  width: 100%;
  max-width: 760px !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}

.project-video-grid,
.fp-video-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 760px) !important;
  justify-content: start !important;
  gap: 1.25rem !important;
}

.project-youtube,
.fp-youtube,
.lignum-youtube,
.numaqam-video-player {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
}

@media (max-width: 900px) {
  .project-video-grid,
  .fp-video-grid {
    grid-template-columns: 1fr !important;
  }
}
/* PROJECT-MEDIA-UNIFORM-TRIAL END */

/* PAGE-TITLE-SPACING-FIX START
   Einheitliche Abstände:
   - Projekte: Überschrift bis Trennlinie
   - Termine: Überschrift bis Tabellenkopf/Linie
   - Kontakt: Überschrift bis Kontaktbox
*/
.projects-clean-grid {
  margin-top: 2.4rem !important;
}

.schedule-head {
  margin-top: 2.4rem !important;
}

.contact-field-list,
.contact-card,
.contact-card--compact,
.contact-grid {
  margin-top: 2.4rem !important;
}
/* PAGE-TITLE-SPACING-FIX END */

/* PAGE-TITLE-SPACING-FIX START
   Finaler Abstandsausgleich:
   - Projekte: Linie sitzt 2.4rem unter der Überschrift
   - Termine: Linie sitzt ebenfalls 2.4rem unter der Überschrift
     (der Tabellenkopf beginnt erst darunter)
   - Kontakt: Kontaktbox beginnt im gleichen Abstand wie die Linien
*/

.projects-clean-grid {
  margin-top: 2.4rem !important;
}

/* Termine: Linie direkt auf gleiche Höhe wie bei Projekte */
.schedule-shell {
  margin-top: 2.4rem !important;
  border-top: 1px solid rgba(173,200,245,.24) !important;
}

.schedule-head {
  margin-top: 0 !important;
  padding-top: .85rem !important;
  padding-bottom: .8rem !important;
}

.schedule-table {
  border-top: 0 !important;
}

/* Kontakt: Box im gleichen Abstand unter der Überschrift */
.contact-field-list {
  margin-top: 2.4rem !important;
}

/* Falls ältere Kontakt-Varianten noch greifen */
.contact-card,
.contact-card--compact,
.contact-grid {
  margin-top: 2.4rem !important;
}
/* PAGE-TITLE-SPACING-FIX END */

/* PAGE-TITLE-SPACING-FINAL START
   Finaler harter Fix:
   Projekte / Termine / Kontakt optisch gleicher Abstand.
   Muss ganz am Ende der styles.css stehen.
*/

/* Projekte: Linie unter Überschrift */
.projects-clean-grid {
  margin-top: 2.4rem !important;
  padding-top: 1.35rem !important;
  border-top: 1px solid rgba(173,200,245,.24) !important;
}

/* Termine: Linie gehört an den Shell-Container, nicht an die Tabelle */
.schedule-shell {
  margin-top: 2.4rem !important;
  border-top: 1px solid rgba(173,200,245,.24) !important;
}

/* alten Tabellenstrich neutralisieren, damit nicht zwei Systeme konkurrieren */
.schedule-table {
  border-top: 0 !important;
}

/* Tabellenkopf erst nach der Linie beginnen lassen */
.schedule-head {
  margin-top: 0 !important;
  padding-top: 1.35rem !important;
  padding-bottom: .8rem !important;
}

/* Mobile Terminansicht ebenfalls nicht mit eigener Linie konkurrieren lassen */
.schedule-mobile {
  border-top: 0 !important;
}

/* Kontakt: Box im gleichen Abstand unter der Überschrift */
.contact-field-list {
  margin-top: 2.4rem !important;
}

/* ältere Kontakt-Varianten absichern */
.contact-card,
.contact-card--compact,
.contact-grid {
  margin-top: 2.4rem !important;
}
/* PAGE-TITLE-SPACING-FINAL END */

/* ABOUT-PORTRAIT-CROP-MOBILE-FIX START
   Über mich: Foto-Ausschnitt desktop fein nach links, Portrait auf Mobilgeräten zentriert.
   HTML und Layoutstruktur bleiben unverändert.
*/
.portrait-frame img {
  object-position: 42% center !important;
}

@media (max-width: 900px) {
  .about-portrait {
    width: min(100%, 540px) !important;
    max-width: 540px !important;
    justify-self: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .portrait-frame img {
    object-position: 42% center !important;
  }
}
/* ABOUT-PORTRAIT-CROP-MOBILE-FIX END */

/* ÜBER-MICH-FLOAT-RESTORE START
   Desktop: Portrait rechts, Text fließt daran vorbei.
   Mobile bleibt einspaltig. Silbentrennung bleibt deaktiviert.
*/
@media (min-width: 901px) {
  .about-layout {
    display: block;
    position: relative;
    align-items: initial;
  }

  .about-text {
    max-width: none;
  }

  .about-text::before {
    content: "";
    float: right;
    width: min(40vw, 540px);
    height: min(66vh, 620px);
    min-height: 520px;
    margin: clamp(2rem, 3vw, 2.8rem) 0 2.6rem clamp(2.8rem, 5vw, 5.4rem);
  }

  .about-portrait {
    position: absolute;
    top: clamp(2rem, 3vw, 2.8rem);
    right: 0;
    width: min(40vw, 540px);
    max-width: 540px;
    height: min(66vh, 620px);
    min-height: 520px;
    margin: 0;
    float: none;
  }

  .about-portrait .portrait-frame {
    width: 100%;
    height: 100%;
  }
}

.about-text p {
  text-align: left;
  text-align-last: left;
  hyphens: manual;
}

.about-text a {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: .18em;
}

.about-text a:hover,
.about-text a:focus-visible {
  color: #c2d6f8;
}

@media (max-width: 900px) {
  .about-layout {
    display: grid;
    grid-template-columns: 1fr;
  }

  .about-text::before {
    content: none;
  }

  .about-portrait {
    position: relative;
    top: auto;
  }
}
/* ÜBER-MICH-FLOAT-RESTORE END */

/* ÜBER-MICH-TYPO-FEINJUSTIERUNG START
   Nur Abstand unter Zwischenüberschriften und ruhigerer Abstand nach dem Portrait-Umfluss.
*/
.about-text h2 {
  margin: 2.15rem 0 .85rem;
  color: var(--primary);
  font-family: var(--font-headline);
  font-size: clamp(1.39rem, 2.04vw, 1.80rem);
  font-weight: 400;
  line-height: 1.15;
}
/* ÜBER-MICH-TYPO-FEINJUSTIERUNG END */

/* ÜBER-MICH-BALANCE-KORREKTUR START
   Rücknahme der zu starken letzten Verschiebung: Portrait wieder ruhiger tiefer,
   Abstand zum Text moderat, Float-Umfluss bleibt erhalten.
*/
@media (min-width: 901px) {
  .about-text::before {
    width: min(38vw, 520px) !important;
    height: min(62vh, 590px) !important;
    min-height: 500px !important;
    margin: clamp(5.4rem, 7.2vw, 7.2rem) 0 3.8rem clamp(3.6rem, 6.2vw, 6.4rem) !important;
  }

  .about-portrait {
    top: clamp(5.4rem, 7.2vw, 7.2rem) !important;
    width: min(38vw, 520px) !important;
    max-width: 520px !important;
    height: min(62vh, 590px) !important;
    min-height: 500px !important;
  }
}
/* ÜBER-MICH-BALANCE-KORREKTUR END */

/* ÜBER-MICH-FEINJUSTIERUNG-PORTRAIT-LINKSATZ START
   Nur zwei Korrekturen: Portrait im Desktop-Float etwas nach links,
   kurzer Kulturprojekte-Absatz ohne auseinandergezogenen Blocksatz.
*/
@media (min-width: 901px) {
  .about-text::before {
    margin-right: clamp(1.8rem, 2.8vw, 3.2rem) !important;
  }

  .about-portrait {
    right: clamp(1.8rem, 2.8vw, 3.2rem) !important;
  }
}

.about-text p:has(a[href*="kulturprojekte"]) {
  text-align: left;
  text-align-last: left;
}
/* ÜBER-MICH-FEINJUSTIERUNG-PORTRAIT-LINKSATZ END */

/* Sprachumschalter – dezent, aber sichtbar */
.lang-switch {
  border: 1px solid rgba(173,200,245,.28);
  border-radius: 999px;
  padding: .35rem .65rem !important;
  font-size: .9rem !important;
  letter-spacing: .08em;
  line-height: 1 !important;
}

.lang-switch:hover,
.lang-switch:focus-visible {
  border-color: rgba(173,200,245,.48);
  background: rgba(255,255,255,.035);
}

@media (max-width: 900px) {
  .lang-switch {
    display: inline-block;
    width: auto;
    margin-top: .25rem;
  }
}

/* Sprachumschalter – Mobile-Korrektur: nicht volle Menübreite */
@media (max-width: 900px) {
  .site-nav a.lang-switch {
    display: inline-flex !important;
    width: auto !important;
    align-items: center;
    justify-content: center;
    margin: .25rem .85rem .35rem;
    padding: .42rem .72rem !important;
  }
}

/* Startseite mobil fixieren: kein vertikales Scrollen */
@media (max-width: 900px) {
  body.home-page {
    height: 100svh;
    min-height: 100svh;
    overflow: hidden;
  }

  .home-page .hero {
    min-height: calc(100svh - var(--header-height));
    height: calc(100svh - var(--header-height));
  }

  .home-page .site-footer {
    position: fixed;
    left: 0;
    right: 0;
    bottom: max(.7rem, env(safe-area-inset-bottom));
    z-index: 20;
    padding: 0;
    pointer-events: none;
  }

  .home-page .site-footer .footer-inner,
  .home-page .social-bar,
  .home-page .legal-links {
    pointer-events: auto;
  }
}

/* Startseite mobil: Hero-Text exakt vertikal zentrieren */
@media (max-width: 900px) {
  .home-page .hero {
    position: relative;
    display: block;
  }

  .home-page .hero-content {
    position: absolute;
    left: 50%;
    top: 50%;
    width: min(calc(100% - 2rem), var(--container));
    transform: translate(-50%, -50%);
    padding: 0;
  }
}

/* MOBILE-NAV-PROJECT-DROPDOWN-HIDE START */
/* Mobil wird die Projektübersicht als normaler Menüpunkt genutzt; die Dropdown-Unterpunkte bleiben dort ausgeblendet. Desktop-Hover bleibt unverändert. */
@media (max-width: 900px) {
  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* MOBILE-NAV-PROJECT-DROPDOWN-HIDE END */

/* STARTSEITE-MOBIL-TEXTBLOCK-HOEHER START */
/* Optische Zentrierung: gesamter Hero-Textblock auf Mobilgeräten etwas höher, damit er trotz fixem Footer/Social-Bar mittig wirkt. */
@media (max-width: 900px) {
  .home-page .hero-content {
    top: 43% !important;
    transform: translate(-50%, -50%) !important;
  }
}
/* STARTSEITE-MOBIL-TEXTBLOCK-HOEHER END */

/* MOBILE-NAV-PROJECT-DROPDOWN-HIDE FINAL START */
/* Sicherheits-Override: Projekt-Dropdown mobil endgültig ausblenden. */
@media (max-width: 900px) {
  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* MOBILE-NAV-PROJECT-DROPDOWN-HIDE FINAL END */

/* STARTSEITE-MOBIL-ECHT-ZENTRIERT FINAL START */
/* Mobil: gesamter Hero-Textblock exakt in die sichtbare Mitte setzen – ohne festen Hoch-/Runter-Versatz. */
@media (max-width: 900px) {
  body.home-page {
    height: 100svh;
    min-height: 100svh;
    overflow: hidden;
  }

  .home-page .hero {
    min-height: calc(100svh - var(--header-height));
    height: calc(100svh - var(--header-height));
    display: grid;
    place-items: center;
  }

  .home-page .hero-content {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: min(calc(100% - 2rem), var(--container));
    transform: none !important;
    padding: 0 !important;
  }

  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* STARTSEITE-MOBIL-ECHT-ZENTRIERT FINAL END */

/* STARTSEITE-MOBIL-HEADER-KORREKT-ZENTRIERT FINAL START */
/* Mobil: Header wird sauber aus der verfügbaren Höhe herausgerechnet. Der Hero-Textblock sitzt dadurch mittig in der sichtbaren Fläche unter dem Menü. */
@media (max-width: 900px) {
  body.home-page {
    height: 100svh !important;
    min-height: 100svh !important;
    overflow: hidden !important;
  }

  .home-page main {
    height: calc(100svh - var(--header-height)) !important;
    min-height: calc(100svh - var(--header-height)) !important;
    overflow: hidden !important;
  }

  .home-page .hero {
    min-height: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .home-page .hero-content {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: min(calc(100% - 2rem), var(--container)) !important;
    padding: 0 !important;
    transform: none !important;
    text-align: center !important;
  }

  .home-page .site-footer {
    display: none !important;
  }

  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* STARTSEITE-MOBIL-HEADER-KORREKT-ZENTRIERT FINAL END */

/* STARTSEITE-MOBIL-FINAL-FREE-AREA-CENTER START */
/* Mobil: Hero-Text mittig im freien Bereich zwischen Header und Footer/Social-Bar; Footer bleibt sichtbar. */
@media (max-width: 900px) {
  body.home-page {
    height: 100svh !important;
    min-height: 100svh !important;
    overflow: hidden !important;
  }

  .home-page main {
    --home-mobile-footer-space: 112px;
    height: calc(100svh - var(--header-height) - var(--home-mobile-footer-space)) !important;
    min-height: calc(100svh - var(--header-height) - var(--home-mobile-footer-space)) !important;
    overflow: hidden !important;
  }

  .home-page .hero {
    height: 100% !important;
    min-height: 100% !important;
    display: grid !important;
    place-items: center !important;
  }

  .home-page .hero-content {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: min(calc(100% - 2rem), var(--container)) !important;
    margin: 0 auto !important;
    padding: 0 !important;
    transform: none !important;
    text-align: center !important;
  }

  .home-page .site-footer {
    display: block !important;
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: .8rem !important;
    z-index: 20 !important;
    padding: 0 !important;
    pointer-events: none !important;
  }

  .home-page .footer-inner {
    display: grid !important;
    justify-items: center !important;
  }

  .home-page .social-bar,
  .home-page .legal-links {
    pointer-events: auto !important;
  }

  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* STARTSEITE-MOBIL-FINAL-FREE-AREA-CENTER END */

/* STARTSEITE-MOBIL-QUERFORMAT-KORREKTUR START */
/* Sehr flache Handy-Ansichten im Querformat: Hero-Text und Social-Bar dürfen sich nicht überlagern. */
@media (orientation: landscape) and (max-height: 520px) {
  body.home-page {
    height: 100svh !important;
    min-height: 100svh !important;
    overflow: hidden !important;
  }

  .home-page main {
    --home-mobile-footer-space: 76px;
    height: calc(100svh - var(--header-height) - var(--home-mobile-footer-space)) !important;
    min-height: calc(100svh - var(--header-height) - var(--home-mobile-footer-space)) !important;
    overflow: hidden !important;
  }

  .home-page .hero {
    height: 100% !important;
    min-height: 100% !important;
    display: grid !important;
    place-items: center !important;
  }

  .home-page .hero-content {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: min(calc(100% - 2rem), var(--container)) !important;
    margin: 0 auto !important;
    padding: 0 !important;
    transform: none !important;
    text-align: center !important;
  }

  .home-page .hero-kicker {
    margin-bottom: .35rem !important;
    font-size: .58rem !important;
    letter-spacing: .24em !important;
  }

  .home-page .hero-title {
    font-size: clamp(2.15rem, 7.2vw, 3.25rem) !important;
    line-height: .92 !important;
  }

  .home-page .hero-subtitle {
    margin-top: .45rem !important;
    font-size: .92rem !important;
  }

  .home-page .site-footer {
    display: block !important;
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: .25rem !important;
    z-index: 20 !important;
    padding: 0 !important;
    pointer-events: none !important;
  }

  .home-page .footer-inner {
    display: grid !important;
    justify-items: center !important;
    gap: .25rem !important;
    font-size: .72rem !important;
  }

  .home-page .social-bar {
    gap: .38rem !important;
    margin-bottom: .28rem !important;
    padding: .28rem .42rem !important;
    pointer-events: auto !important;
  }

  .home-page .social-link {
    width: 34px !important;
    height: 34px !important;
  }

  .home-page .social-link svg {
    width: 17px !important;
    height: 17px !important;
  }

  .home-page .legal-links {
    pointer-events: auto !important;
  }

  .site-nav > ul > li > .nav-dropdown,
  .site-header.is-open .site-nav > ul > li > .nav-dropdown,
  .site-nav > ul > li:hover > .nav-dropdown,
  .site-nav > ul > li:focus-within > .nav-dropdown {
    display: none !important;
  }
}
/* STARTSEITE-MOBIL-QUERFORMAT-KORREKTUR END */

/* HERO mobil ausblenden + sauber zentrieren */
@media (max-width: 900px) {
  .hero-media,
  .hero-media img {
    display: none !important;
  }
  .hero {
    background: #0c1324;
  }
  .home-page .hero-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

/* Handy quer: zu wenig Höhe für ein sinnvolles Hero-Bild */
@media (orientation: landscape) and (max-height: 500px) {
  .hero-media,
  .hero-media img {
    display: none !important;
  }
  .hero {
    background: #0c1324;
  }
}

@media (max-width: 900px) and (orientation: landscape) {
  .home-page .hero-content {
    font-size: 0.9rem;
    gap: 0.4rem;
  }
}

/* Final micro-polish: about image spacing and credits */
.image-credit {
  margin-top: 0.65rem;
  font-size: 0.72rem;
  line-height: 1.4;
  color: rgba(229, 235, 245, 0.55);
  text-align: center;
}

@media (max-width: 768px) {
  .about-portrait {
    margin-bottom: 1.2rem;
  }
}

/* MOBILE ABOUT PORTRAIT SPACING – hard fix
   Abstand nach dem Portrait auf Über-mich/About erzwingen.
   Die zusätzliche Regel am ersten Textabsatz greift auch dann,
   wenn frühere Margin-Regeln des Portraits überschrieben werden. */
@media (max-width: 900px) {
  body.about-flow .about-text > figure.about-portrait {
    display: block !important;
    margin: 0 auto 1.45rem auto !important;
  }

  body.about-flow .about-text > figure.about-portrait + p {
    margin-top: 1.45rem !important;
  }
}
