
  /* ============ Self-hosted Fonts (DSGVO, kein CDN) ============ */
  @font-face {
    font-family: 'Fraunces';
    src: url('/assets/fonts/fraunces-full.woff2') format('woff2-variations');
    font-weight: 100 900; font-display: swap; font-style: normal;
  }
  @font-face {
    font-family: 'Mulish';
    src: url('/assets/fonts/mulish.woff2') format('woff2-variations');
    font-weight: 200 900; font-display: swap; font-style: normal;
  }

  :root {
    --paper:   #F3ECDF;   /* warmes Büttenpapier */
    --paper-2: #EAE0CE;
    --ink:     #271F17;   /* warmes Braun-Schwarz */
    --ink-soft:#4A3F33;
    --clay:    #A85B33;   /* Terrakotta / Lehmputz */
    --ochre:   #C4974F;   /* Ocker */
    --sage:    #6A7257;   /* Salbeigrün (die Tür) */
    --rust:    #8F3E2A;   /* gedämpftes Rot */
    --stone:   #9B9081;   /* Bruchstein */
    --line:    rgba(39,31,23,.16);
    --display: 'Fraunces', Georgia, serif;
    --body:    'Mulish', system-ui, sans-serif;
  }

  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--body);
    font-weight: 380;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }
  ::selection { background: var(--clay); color: var(--paper); }

  /* Grain / Papierhaptik */
  body::after {
    content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
    opacity: .035; mix-blend-mode: multiply;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }

  h1, h2, h3 { font-family: var(--display); font-weight: 420; line-height: 1.04; letter-spacing: -.01em; font-optical-sizing: auto; }
  .eyebrow {
    font-family: var(--body); font-weight: 700; font-size: .72rem;
    letter-spacing: .32em; text-transform: uppercase; color: var(--clay);
  }
  a { color: inherit; text-decoration: none; }

  .wrap { max-width: 1280px; margin: 0 auto; padding: 0 clamp(1.4rem, 4vw, 4.5rem); }

  /* ============ Reveal-Animation ============ */
  .reveal { opacity: 0; transform: translateY(26px); transition: opacity 1s cubic-bezier(.22,.61,.36,1), transform 1s cubic-bezier(.22,.61,.36,1); }
  .reveal.in { opacity: 1; transform: none; }

  /* ============ Header ============ */
  header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.3rem clamp(1.4rem, 4vw, 4.5rem);
    transition: background .5s, padding .5s, box-shadow .5s;
  }
  header.solid { background: rgba(243,236,223,.92); backdrop-filter: blur(10px); box-shadow: 0 1px 0 var(--line); padding-top: .9rem; padding-bottom: .9rem; }
  .brand { font-family: var(--display); font-weight: 500; font-size: 1.18rem; letter-spacing: -.01em; color: var(--paper); transition: color .5s; line-height: 1.05; }
  .brand small { display: block; font-family: var(--body); font-weight: 600; font-size: .58rem; letter-spacing: .3em; text-transform: uppercase; opacity: .8; margin-top: 2px; }
  header.solid .brand { color: var(--ink); }
  nav { display: flex; align-items: center; gap: 2.1rem; }
  nav a { font-size: .82rem; font-weight: 600; letter-spacing: .04em; color: var(--paper); opacity: .9; transition: color .5s, opacity .3s; position: relative; }
  header.solid nav a { color: var(--ink-soft); }
  nav a:not(.pill)::after { content: ""; position: absolute; left: 0; bottom: -5px; height: 1px; width: 0; background: var(--clay); transition: width .35s; }
  nav a:not(.pill):hover::after { width: 100%; }
  nav a.pill { border: 1px solid currentColor; padding: .5rem 1.1rem; border-radius: 40px; opacity: .85; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; }
  nav a.pill:hover { background: var(--clay); border-color: var(--clay); color: var(--paper); opacity: 1; }
  @media (max-width: 880px){ nav .navlink { display:none; } }

  /* ============ Hero ============ */
  .hero { position: relative; min-height: 100vh; display: flex; align-items: flex-end; color: var(--paper); overflow: hidden; }
  .hero-img { position: absolute; inset: 0; }
  .hero-img img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.08); animation: heroZoom 9s ease-out forwards; }
  @keyframes heroZoom { to { transform: scale(1); } }
  .hero::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(20,15,10,.42) 0%, rgba(20,15,10,.05) 32%, rgba(20,15,10,.12) 60%, rgba(20,15,10,.82) 100%); z-index: 1; }
  .hero-content { position: relative; z-index: 2; padding-bottom: clamp(3rem, 8vh, 7rem); width: 100%; }
  .hero .eyebrow { color: #E9C9A6; }
  .hero h1 { font-size: clamp(3.1rem, 9vw, 8.4rem); font-weight: 360; margin: 1.2rem 0 1.4rem; max-width: 16ch; text-shadow: 0 2px 40px rgba(0,0,0,.35); }
  .hero h1 em { font-style: italic; font-weight: 380; color: #F0D7B8; }
  .hero-sub { display: flex; gap: 2.5rem; align-items: flex-end; flex-wrap: wrap; max-width: 56ch; }
  .hero-sub p { font-size: 1.06rem; font-weight: 420; opacity: .94; max-width: 40ch; }
  .hero-meta { font-family: var(--body); font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; opacity: .85; border-left: 1px solid rgba(255,255,255,.4); padding-left: 1rem; }
  .scrollcue { position: absolute; left: 50%; bottom: 1.6rem; transform: translateX(-50%); z-index: 3; font-size: .68rem; letter-spacing: .3em; text-transform: uppercase; opacity: .7; animation: bob 2.4s ease-in-out infinite; }
  @keyframes bob { 0%,100%{ transform: translate(-50%,0);} 50%{ transform: translate(-50%,7px);} }

  /* ============ Press ============ */
  .press { border-bottom: 1px solid var(--line); }
  .press .wrap { display: flex; align-items: center; gap: clamp(1.5rem,4vw,3.5rem); flex-wrap: wrap; padding-top: 1.5rem; padding-bottom: 1.5rem; }
  .press .label { font-size: .68rem; letter-spacing: .26em; text-transform: uppercase; color: var(--stone); font-weight: 700; }
  .press .names { display: flex; gap: clamp(1.4rem,3.5vw,3rem); flex-wrap: wrap; }
  .press .names span { font-family: var(--display); font-weight: 500; font-size: 1.16rem; color: var(--ink-soft); font-style: italic; }

  /* ============ Manifest / Intro ============ */
  .manifest { padding: clamp(5rem, 13vh, 9.5rem) 0 clamp(3rem,7vh,5rem); }
  .manifest .grid { display: grid; grid-template-columns: 1fr 1.25fr; gap: clamp(2rem,6vw,6rem); align-items: start; }
  @media (max-width: 860px){ .manifest .grid { grid-template-columns: 1fr; } }
  .manifest .left .eyebrow { display:block; margin-bottom: 1.4rem; }
  .manifest .left h2 { font-size: clamp(2rem, 4.2vw, 3.4rem); font-weight: 380; }
  .manifest .left h2 em { font-style: italic; color: var(--clay); }
  .lede { font-size: clamp(1.12rem, 1.7vw, 1.42rem); line-height: 1.62; color: var(--ink-soft); font-weight: 400; }
  .lede .dropcap::first-letter { font-family: var(--display); font-weight: 460; font-size: 3.9em; float: left; line-height: .8; padding: .06em .12em .02em 0; color: var(--clay); }
  .lede p + p { margin-top: 1.3rem; }

  /* ============ Section heading ============ */
  .sec-head { display: flex; align-items: baseline; gap: 1.4rem; margin-bottom: 2.6rem; }
  .sec-head .num { font-family: var(--display); font-style: italic; font-size: 1.1rem; color: var(--clay); }
  .sec-head h2 { font-size: clamp(1.8rem, 3.6vw, 3rem); font-weight: 380; }
  .sec-head .rule { flex: 1; height: 1px; background: var(--line); transform: translateY(-.4rem); }

  /* ============ Geschichte (Story) ============ */
  .story { padding: clamp(3rem,7vh,5rem) 0; }
  .story .cols { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,5vw,5rem); align-items: center; }
  @media (max-width: 860px){ .story .cols { grid-template-columns: 1fr; } }
  .story figure { position: relative; }
  .story figure img { width: 100%; border-radius: 2px; box-shadow: 0 30px 60px -30px rgba(39,31,23,.5); }
  .story figcaption, .cap { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--stone); margin-top: .8rem; font-weight: 600; }
  .story p { font-size: 1.05rem; color: var(--ink-soft); }
  .story p + p { margin-top: 1.15rem; }
  .markers { display: flex; gap: 2.4rem; margin-top: 2.2rem; flex-wrap: wrap; }
  .markers .m { }
  .markers .m b { font-family: var(--display); font-weight: 460; font-size: 2.3rem; color: var(--clay); display: block; line-height: 1; }
  .markers .m span { font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); }

  /* ============ Sanierung (Gallery) ============ */
  .resto { padding: clamp(4rem,9vh,7rem) 0; }
  .gal { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(.8rem,1.6vw,1.5rem); }
  .gal figure { overflow: hidden; border-radius: 2px; position: relative; }
  .gal figure img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.1s cubic-bezier(.22,.61,.36,1); }
  .gal figure:hover img { transform: scale(1.06); }
  .gal .g1 { grid-column: span 7; aspect-ratio: 3/2.05; }
  .gal .g2 { grid-column: span 5; aspect-ratio: 3/2.05; }
  .gal .g3 { grid-column: span 5; aspect-ratio: 4/3; }
  .gal .g4 { grid-column: span 7; aspect-ratio: 16/9; }
  .gal figure .tag { position: absolute; left: .9rem; bottom: .9rem; background: rgba(243,236,223,.92); color: var(--ink); font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; padding: .35rem .7rem; border-radius: 2px; }
  @media (max-width: 720px){ .gal .g1,.gal .g2,.gal .g3,.gal .g4 { grid-column: span 12; } }

  /* ============ Kultur ============ */
  .culture { padding: clamp(4rem,9vh,7rem) 0; }
  .events { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
  @media (max-width: 820px){ .events { grid-template-columns: 1fr; } }
  .ev { border-top: 2px solid var(--ink); padding-top: 1.1rem; }
  .ev .when { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--clay); font-weight: 700; }
  .ev h3 { font-size: 1.42rem; font-weight: 440; margin: .5rem 0 .5rem; }
  .ev p { font-size: .95rem; color: var(--ink-soft); }

  /* ============ Garten (Quote band) ============ */
  .garden { position: relative; margin: clamp(3rem,7vh,5rem) 0 0; color: var(--paper); overflow: hidden; }
  .garden-bg { position: absolute; inset: 0; }
  .garden-bg img { width: 100%; height: 100%; object-fit: cover; }
  .garden::before { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(31,28,18,.86), rgba(31,28,18,.45)); }
  .garden .wrap { position: relative; z-index: 2; padding-top: clamp(5rem,13vh,9rem); padding-bottom: clamp(5rem,13vh,9rem); }
  .garden blockquote { font-family: var(--display); font-weight: 380; font-style: italic; font-size: clamp(1.7rem,3.6vw,3rem); line-height: 1.2; max-width: 20ch; }
  .garden .by { margin-top: 1.6rem; font-size: .78rem; letter-spacing: .18em; text-transform: uppercase; opacity: .82; }

  /* ============ Inner Circle ============ */
  .inner { background: var(--ink); color: var(--paper); padding: clamp(4rem,10vh,7rem) 0; }
  .inner .grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
  @media (max-width: 820px){ .inner .grid { grid-template-columns: 1fr; } }
  .inner .eyebrow { color: var(--ochre); }
  .inner h2 { font-size: clamp(1.9rem,3.8vw,3rem); font-weight: 380; margin: 1rem 0 1rem; }
  .inner h2 em { font-style: italic; color: var(--ochre); }
  .inner p { color: rgba(243,236,223,.78); max-width: 46ch; }
  .inner .cta { display: inline-flex; align-items: center; gap: .7rem; margin-top: 1.8rem; border: 1px solid rgba(243,236,223,.45); padding: .85rem 1.6rem; border-radius: 40px; font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; transition: background .35s, color .35s, border-color .35s; }
  .inner .cta:hover { background: var(--ochre); border-color: var(--ochre); color: var(--ink); }
  .inner .keyline { border-left: 1px solid rgba(243,236,223,.25); padding-left: 1.6rem; }
  .inner .keyline p { font-style: italic; font-family: var(--display); font-size: 1.15rem; color: rgba(243,236,223,.9); }

  /* ============ Footer ============ */
  footer { background: #1E1810; color: rgba(243,236,223,.72); padding: clamp(3.5rem,8vh,5.5rem) 0 2.5rem; }
  footer .grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 2.5rem; }
  @media (max-width: 760px){ footer .grid { grid-template-columns: 1fr; gap: 1.8rem; } }
  footer .brand2 { font-family: var(--display); font-size: 1.7rem; color: var(--paper); font-weight: 460; line-height: 1.1; }
  footer h4 { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ochre); margin-bottom: 1rem; font-weight: 700; }
  footer a { display: block; padding: .25rem 0; opacity: .85; font-size: .92rem; }
  footer a:hover { opacity: 1; color: var(--ochre); }
  footer .addr { font-size: .92rem; line-height: 1.8; }
  footer .base { margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid rgba(243,236,223,.14); display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: .76rem; opacity: .6; }

  .pad { padding-top: clamp(4rem,9vh,6.5rem); padding-bottom: clamp(4rem,9vh,6.5rem); }

/* ============ Unterseiten / Artikel ============ */
.page-hero { background: var(--paper-2); border-bottom: 1px solid var(--line); padding: clamp(7rem,16vh,9rem) 0 clamp(2rem,5vh,3rem); }
.page-hero.tall { padding-bottom: clamp(2.5rem,6vh,3.5rem); }
.page-hero .eyebrow { display:block; margin-bottom:1rem; }
.page-hero h1 { font-size: clamp(2.4rem,6vw,5rem); font-weight: 360; }
.page-hero .ph-lede { font-size: clamp(1.05rem,1.6vw,1.3rem); color: var(--ink-soft); max-width: 52ch; margin-top:1.3rem; }
.page-hero .back { font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--clay); font-weight:700; display:inline-block; margin-bottom:1.2rem; }
header.lighthdr .brand, header.lighthdr nav a { color: var(--ink-soft); }
header.lighthdr .brand { color: var(--ink); }
.prose { max-width: 760px; margin: clamp(2.5rem,6vh,4rem) auto; font-size: 1.08rem; line-height: 1.8; color: var(--ink-soft); }
.prose.narrow { max-width: 680px; }
.prose p { margin: 0 0 1.2rem; }
.prose h2,.prose h3 { font-family: var(--display); color: var(--ink); margin: 2rem 0 .8rem; font-weight:440; }
.prose img { width: 100%; border-radius: 2px; margin: 1.6rem 0; box-shadow: 0 24px 50px -28px rgba(39,31,23,.45); }
.prose a { color: var(--clay); border-bottom: 1px solid var(--line); }
.prose strong { color: var(--ink); }
.artnav { max-width:760px; margin: 0 auto clamp(4rem,8vh,6rem); padding-top:2rem; border-top:1px solid var(--line); }
.artnav a { color: var(--clay); font-weight:700; font-size:.85rem; letter-spacing:.04em; }
/* Baublog-Grid */
.bgrid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.2rem,2.4vw,2rem); padding: clamp(2.5rem,6vh,4rem) 0 clamp(5rem,10vh,7rem); }
@media (max-width:880px){ .bgrid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:560px){ .bgrid{ grid-template-columns: 1fr;} }
.bcard { display:block; background:var(--paper); border:1px solid var(--line); border-radius:3px; overflow:hidden; transition:transform .5s cubic-bezier(.22,.61,.36,1), box-shadow .5s; }
.bcard:hover { transform: translateY(-5px); box-shadow: 0 30px 55px -30px rgba(39,31,23,.45); }
.bc-img { aspect-ratio: 4/3; overflow:hidden; }
.bc-img img { width:100%; height:100%; object-fit:cover; transition:transform 1s cubic-bezier(.22,.61,.36,1); }
.bcard:hover .bc-img img { transform: scale(1.06); }
.bc-noimg { background: linear-gradient(135deg,var(--paper-2),var(--stone)); }
.bc-body { padding: 1.2rem 1.3rem 1.5rem; }
.bc-date { font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--clay); font-weight:700; }
.bc-body h3 { font-size:1.32rem; font-weight:440; margin-top:.45rem; line-height:1.15; }
/* Kultur-Karten als Links */
a.ev { display:block; color:inherit; text-decoration:none; transition:transform .4s cubic-bezier(.22,.61,.36,1); }
a.ev:hover { transform: translateY(-4px); }
a.ev h3 { transition: color .3s; }
a.ev:hover h3 { color: var(--clay); }
/* Presse-Namen als Links (gleiche Optik wie span, mit dezentem Hover) */
.press .names a { font-family: var(--display); font-weight: 500; font-size: 1.16rem; color: var(--ink-soft); font-style: italic; text-decoration: none; border-bottom: 1px solid var(--line); transition: color .3s, border-color .3s; }
.press .names a:hover { color: var(--clay); border-color: var(--clay); }
/* Sanierung — kurzer Faktentext über der Galerie */
.resto .resto-lede { max-width: 60ch; margin: 0 0 clamp(2rem,4.5vh,3rem); color: var(--ink-soft); font-size: clamp(1.02rem,1.5vw,1.18rem); line-height: 1.75; }
/* Bildnachweis Hero */
.hero-credit { position:absolute; right:1rem; bottom:1rem; z-index:3; font-family:var(--body); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(243,236,223,.78); text-shadow:0 1px 6px rgba(0,0,0,.5); }
/* Inhalte ohne JS sichtbar (Progressive Enhancement) */
html:not(.js) .reveal { opacity:1 !important; transform:none !important; }
