/*
Theme Name:  NIR Design
Theme URI:   https://nir-design.de
Author:      Nico Rauser – NIR Design
Version:     2.6.0
Description: GEO + SEO + DSGVO-optimiertes Custom Theme für NIR Design.
License:     GNU General Public License v2 or later
Text Domain: nir-design
*/

/* ── LOKALE FONTS (DSGVO-konform, kein Google CDN) ────────────────────────────
   Download: https://gwfh.madebylouis.com/
   Benötigt: Montserrat 800+900 | Inter 300+400+500+600 | Playfair Display 400i
   Ablage: /wp-content/themes/nir-design/fonts/*.woff2
   ──────────────────────────────────────────────────────────────────────────── */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('fonts/montserrat-800.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:900;font-display:swap;src:url('fonts/montserrat-900.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/inter-300.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/playfair-400i.woff2') format('woff2')}

/* ── RESET & TOKENS ───────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F4F2EE;
  --dark:#111111;
  --accent:#B62731;
  --muted:#6B6560;
  --border:rgba(17,17,17,0.13);
  /* WCAG 2.2: Kontrastprüfung bestand für alle Farbkombinationen */
  --focus-ring:2px solid #B62731;
  --focus-offset:3px;
  color-scheme:light; /* verhindert kurzen Dark-Mode-Flash */
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--dark);font-family:'Inter',sans-serif;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(17,17,17,.25);border-radius:3px}
::selection{background:rgba(182,39,49,.2)}
img{display:block;max-width:100%;height:auto}
a{color:inherit}

/* ── ACCESSIBILITY (WCAG 2.2) ─────────────────────────────────────────────── */
:focus-visible{outline:var(--focus-ring);outline-offset:var(--focus-offset);border-radius:2px}
.skip-link{position:absolute;top:-100px;left:16px;z-index:9999;padding:12px 20px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;text-decoration:none;border-radius:4px;transition:top .2s}
.skip-link:focus{top:16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── UTILITY ───────────────────────────────────────────────────────────────── */
.hd{font-family:'Montserrat',sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:-.03em;line-height:.92}
.lbl{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-family:'Inter',sans-serif}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");z-index:1}
.grain-fixed{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── BUTTONS ──────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;background:var(--accent);color:#fff;font-family:'Inter',sans-serif;font-weight:500;font-size:12px;letter-spacing:.06em;border:none;border-radius:5px;cursor:pointer;text-decoration:none;transition:all .2s ease;min-height:44px}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(182,39,49,.3);color:#fff}
.btn-ghost{background:transparent;border:1.5px solid var(--dark);color:var(--dark)}
.btn-ghost:hover{background:var(--dark);color:var(--bg);box-shadow:none;transform:none}

/* ── NAV ──────────────────────────────────────────────────────────────────── */
.site-nav{position:sticky;top:0;z-index:99;background:rgba(244,242,238,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:0 6%;height:72px;display:flex;align-items:center;border-bottom:.5px solid var(--border);gap:32px}

/* Logo: hart links, fest verankert */
.nav-logo{display:flex;align-items:center;justify-content:flex-start;text-decoration:none;height:72px;max-height:72px;overflow:hidden;flex-shrink:0;flex-grow:0}

/* WordPress custom-logo-link + custom-logo – alle Varianten abdecken */
.nav-logo a,
.nav-logo .custom-logo-link{display:flex!important;align-items:center!important;height:40px!important;max-height:40px!important;overflow:hidden!important;padding:0!important;margin:0!important}

.nav-logo img,
.nav-logo .custom-logo,
.nav-logo .custom-logo-link img,
.site-nav img,
.site-nav .custom-logo{
  height:36px!important;
  width:auto!important;
  max-width:140px!important;
  max-height:36px!important;
  min-height:0!important;
  min-width:0!important;
  object-fit:contain!important;
  display:block!important;
  padding:0!important;
  margin:0!important;
}

.nav-logo-text{font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;letter-spacing:-.03em;color:var(--dark);text-transform:uppercase;transition:color .2s;text-decoration:none}
.nav-logo-text:hover{color:var(--accent)}
.nav-links{display:flex;gap:32px;align-items:center;list-style:none;margin:0 auto}
.nav-links a{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s;min-height:44px;display:flex;align-items:center}
.nav-links a:hover{color:var(--dark)}
.nav-right{display:flex;align-items:center;gap:16px;flex-shrink:0;margin-left:auto}
.nav-shop{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--accent);color:#fff;font-size:11px;font-weight:500;border-radius:5px;text-decoration:none;transition:all .2s;min-height:44px}
.nav-shop:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(182,39,49,.3);color:#fff}

/* ── REVIEWS (legacy) ─────────────────────────────────────────────────────── */
.reviews{padding:48px 0 0;position:relative;z-index:1}
.reviews-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review-card{background:var(--bg);border:.5px solid var(--border);border-radius:8px;padding:24px;display:flex;flex-direction:column;gap:12px}
.review-stars{color:var(--accent);font-size:13px;letter-spacing:2px}
.review-card p{font-family:'Playfair Display',serif;font-style:italic;font-size:15px;line-height:1.65;color:var(--dark);flex:1}
.review-card cite{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-style:normal}

/* ── HAMBURGER ────────────────────────────────────────────────────────────── */
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;width:44px;height:44px;align-items:center;justify-content:center}
.nav-burger span{display:block;height:2px;width:22px;background:var(--dark);border-radius:2px;transition:all .3s ease}

/* ── MOBILE MENU ──────────────────────────────────────────────────────────── */
.mobile-menu{position:fixed;top:0;right:-100%;width:min(320px,90vw);height:100vh;background:var(--bg);z-index:200;padding:80px 40px 40px;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 40px rgba(0,0,0,.12);visibility:hidden}
.mobile-menu.open{right:0;visibility:visible}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:0}
.mobile-menu ul li{border-bottom:.5px solid var(--border)}
.mobile-menu ul li a{display:flex;align-items:center;padding:18px 0;font-family:'Montserrat',sans-serif;font-weight:900;font-size:22px;text-transform:uppercase;letter-spacing:-.02em;color:var(--dark);text-decoration:none;transition:color .2s;min-height:56px}
.mobile-menu ul li a:hover{color:var(--accent)}
.mobile-menu-close{position:absolute;top:20px;right:20px;background:none;border:none;cursor:pointer;color:var(--dark);padding:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.mobile-menu-close:hover{color:var(--accent)}
.mobile-menu-backdrop{position:fixed;inset:0;background:rgba(17,17,17,.5);z-index:199;opacity:0;pointer-events:none;transition:opacity .35s ease;backdrop-filter:blur(2px)}
.mobile-menu-backdrop.open{opacity:1;pointer-events:all}

/* ── SCROLL TO TOP ────────────────────────────────────────────────────────── */
.scroll-top{position:fixed;bottom:24px;right:24px;z-index:98;width:44px;height:44px;background:var(--dark);color:var(--bg);border:none;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(17,17,17,.25);opacity:0;pointer-events:none;transition:opacity .3s,transform .2s}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{transform:translateY(-2px);color:var(--bg)}

/* ── COOKIE BANNER ────────────────────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:var(--dark);color:#F4F2EE;padding:20px 6%;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:2px solid var(--accent);font-size:13px;line-height:1.55;transform:translateY(0);transition:transform .3s ease}
.cookie-banner.hidden{transform:translateY(110%)}
.cookie-banner-text{flex:1;min-width:280px}
.cookie-banner p{color:rgba(244,242,238,.85);max-width:680px;margin-top:4px}
.cookie-banner a{color:#F4F2EE;text-decoration:underline;text-underline-offset:2px}
.cookie-banner a:hover{color:#fff}
.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{padding:10px 20px;border-radius:4px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;transition:all .2s;min-height:44px}
.cookie-btn-accept{background:var(--accent);color:#fff}
.cookie-btn-accept:hover{background:#8a1d25}
.cookie-btn-decline{background:transparent;color:rgba(244,242,238,.6);border:1px solid rgba(244,242,238,.3)}
.cookie-btn-decline:hover{color:#F4F2EE;border-color:rgba(244,242,238,.6)}
.footer-cookie-btn{background:none;border:none;font-size:13px;color:var(--muted);cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.footer-cookie-btn:hover{color:var(--accent)}

/* ── HERO ─────────────────────────────────────────────────────────────────── */
.hero{min-height:90vh;background:var(--bg);display:grid;grid-template-columns:56% 44%;position:relative;overflow:hidden}
.hero-img{position:relative;overflow:hidden;min-height:90vh}
.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-hairline{position:absolute;left:56%;top:10vh;width:1px;height:80vh;background:var(--border);z-index:2}
.hero-text{display:flex;flex-direction:column;justify-content:center;padding:0 6vw;position:relative;z-index:2}
.hero-title{font-size:clamp(56px,9vw,128px);color:var(--dark);margin-bottom:24px;word-break:break-word;hyphens:auto;overflow-wrap:break-word}
.hero-sub{font-size:16px;line-height:1.7;color:var(--muted);max-width:320px;margin-bottom:32px;font-weight:300}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.hero-trust{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:32px;font-size:13px;color:var(--muted);font-weight:400}
.hero-trust strong{color:var(--dark);font-weight:700}
.hero-trust span{white-space:nowrap}
.hero-trust-stars{color:var(--accent);letter-spacing:2px;font-size:13px}
.hero-trust-divider{color:var(--border);font-weight:400}
.hero-line{margin-top:40px;width:1px;height:44px;background:rgba(17,17,17,.2)}
.hero-title-accent{color:var(--accent)}
.hero-title-dot{color:var(--dark)}
.hero-lbl-spaced{margin-bottom:20px}

/* ── STATEMENT ────────────────────────────────────────────────────────────── */
.statement{min-height:85vh;background:var(--bg);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:80px 6vw;position:relative;overflow:hidden;gap:60px}
.statement-headline{font-size:clamp(56px,10vw,128px);line-height:.9;margin-bottom:36px}
.statement-headline span{color:var(--accent)}
.statement-img{position:relative;z-index:1;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.12)}
.statement-img img{width:100%;max-height:68vh;object-fit:cover;display:block}
.statement-img-label{position:absolute;bottom:0;left:0;right:0;padding:16px 20px;display:flex;justify-content:space-between;background:linear-gradient(to top,rgba(17,17,17,.5),transparent)}
.statement-img-label span{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:#F4F2EE;font-weight:600}
.statement-inner{position:relative;z-index:1}
.statement-tagline{font-size:17px;color:var(--dark);font-weight:500;line-height:1.4;margin:20px 0 14px;max-width:420px}
.statement-body{font-size:16px;color:var(--muted);max-width:420px;line-height:1.7;margin:0 0 28px;font-weight:300}

/* ── GALLERY ──────────────────────────────────────────────────────────────── */
.gallery{padding:80px 6vw;background:#F0EDE8;position:relative;overflow:hidden}
.gallery-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;position:relative;z-index:1}
.gallery-header h2{font-size:clamp(32px,6vw,72px)}
.gallery-header > div p{font-size:15px;color:var(--muted);margin-top:12px;max-width:460px;line-height:1.65;font-weight:300}
.gallery-header a{font-size:12px;color:var(--dark);text-decoration:underline;text-underline-offset:4px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;z-index:1}
.gallery-item{
  cursor:pointer;
  display:block;
  color:inherit;
  text-decoration:none;
  position:relative;
}
.gallery-item:hover .gallery-img-wrap img{transform:scale(1.04)}
.gallery-item:nth-child(2){margin-top:60px}
.gallery-img-wrap{overflow:hidden;aspect-ratio:3/4;margin-bottom:14px}
.gallery-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-meta{display:flex;justify-content:space-between;align-items:baseline}
.gallery-meta h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px}
.gallery-meta p{font-size:12px;color:var(--muted);margin-top:2px}
.gallery-meta .lbl-year{font-size:9px}
.gallery-cta{text-align:center;margin-top:60px;position:relative;z-index:1}
.gallery-cta p{font-size:14px;color:var(--muted);margin-bottom:20px}

/* Dual-Button-Zeile unter Galerie-Karten */
.gallery-meta-btns{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
  padding-top:12px;
  border-top:.5px solid rgba(26,26,26,.15);
}

.gallery-btn-secondary{
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--dark);
  text-decoration:none;
  padding:10px 6px;
  border-bottom:1px solid rgba(26,26,26,.4);
  transition:color .25s ease, border-color .25s ease;
}
article.gallery-item:hover .gallery-btn-secondary,
.gallery-btn-secondary:hover{
  color:#000;
  border-color:#000;
}

.gallery-btn-primary{
  font-family:'Inter',sans-serif;
  font-weight:700;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
  background:var(--accent);
  text-decoration:none;
  padding:11px 16px;
  border:1px solid var(--accent);
  border-radius:2px;
  transition:background .25s ease, transform .25s ease;
  white-space:nowrap;
  position:relative;
  z-index:2;
  min-height:40px;
  display:inline-flex;
  align-items:center;
}
.gallery-btn-primary:hover{
  background:#9a1f28;
  border-color:#9a1f28;
  transform:translateY(-1px);
}
.gallery-btn-primary:focus-visible{
  outline:2px solid var(--dark);
  outline-offset:2px;
}

.gallery-stretched::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
}
.gallery-stretched:focus-visible::after{
  outline:2px solid var(--accent);
  outline-offset:-2px;
}

.btn--outline{
  background:transparent;
  border:2px solid var(--dark);
  color:var(--dark);
}
.btn--outline:hover{background:var(--dark);color:var(--cream)}

/* ── PRINTS SHOP ──────────────────────────────────────────────────────────── */
.prints-shop{padding:80px 6vw;background:var(--bg);position:relative;overflow:hidden}
.prints-shop-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:52px;gap:24px;position:relative;z-index:1}
.prints-shop-header > div p{font-size:16px;color:var(--muted);margin-top:12px;font-weight:300;max-width:520px;line-height:1.65}
.prints-shop-header > a{align-self:flex-end}
.prints-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px}
.print-card{background:#fff;border:.5px solid var(--border);border-radius:8px;overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.print-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(17,17,17,.1)}
.print-card--featured{border-color:var(--accent);border-width:1.5px}
.print-card-img{position:relative;overflow:hidden;aspect-ratio:4/3}
.print-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.print-card:hover .print-card-img img{transform:scale(1.04)}
.print-card-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:3px}
.print-card--featured .print-card-badge{background:var(--dark)}
.print-card-body{padding:20px;display:flex;flex-direction:column;justify-content:space-between;flex:1;gap:16px}
.print-card-body h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:18px;margin-bottom:6px}
.print-card-body p{font-size:13px;color:var(--muted);line-height:1.55;font-weight:300}
.print-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:.5px solid var(--border)}
.print-price{font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;color:var(--dark)}

/* Social Proof */
.social-proof{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;padding:40px;background:#F0EDE8;border-radius:8px}
.social-proof-stats{display:flex;align-items:center;gap:24px}
.stat{display:flex;flex-direction:column;align-items:center;gap:4px}
.stat-number{font-family:'Montserrat',sans-serif;font-weight:900;font-size:28px;color:var(--dark)}
.stat-divider{width:1px;height:40px;background:var(--border)}
.social-proof-quote p{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(15px,1.5vw,19px);line-height:1.6;color:var(--dark);margin-bottom:10px}
.social-proof-quote cite{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-style:normal}

/* ── QUOTE ────────────────────────────────────────────────────────────────── */
.quote-section{background:#111111;color:#F4F2EE;padding:120px 6vw;text-align:center;position:relative;overflow:hidden}
.quote-grain{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.quote-inner{position:relative;z-index:1;max-width:820px;margin:0 auto}
.quote-inner blockquote{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(22px,3.5vw,40px);line-height:1.5;margin-bottom:32px;color:#F4F2EE}

/* ── ABOUT ────────────────────────────────────────────────────────────────── */
.about{background:var(--bg);display:grid;grid-template-columns:38% 62%;align-items:center;position:relative;overflow:hidden;min-height:70vh}
.about-img{position:relative;overflow:hidden;min-height:70vh}
.about-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.about-hairline{position:absolute;left:38%;top:12vh;width:1px;height:76vh;background:var(--border);z-index:2}
.about-text{padding:60px 6vw;position:relative;z-index:2}
.about-text h2{font-size:clamp(44px,7vw,88px);margin-bottom:24px}
.about-text p{font-size:16px;line-height:1.75;color:var(--muted);max-width:400px;margin-bottom:16px;font-weight:300}
.about-tagline{font-size:17px!important;color:var(--dark)!important;font-weight:500!important;line-height:1.45!important;margin-top:12px!important;max-width:400px}
.about-lbl-spaced{display:block;margin-bottom:16px}
.about-location{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;margin-bottom:24px}
.about-socials{display:flex;gap:10px;margin-bottom:28px}
.about-socials a{width:44px;height:44px;border:1px solid rgba(17,17,17,.2);display:flex;align-items:center;justify-content:center;color:var(--dark);transition:all .2s;text-decoration:none;border-radius:4px}
.about-socials a:hover{background:var(--dark);color:var(--bg)}

.about-credentials{display:flex;gap:24px;margin:20px 0 24px;flex-wrap:wrap}
.credential{display:flex;flex-direction:column}
.credential-number{font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;color:var(--accent)}
.credential-label{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ── JOURNAL ──────────────────────────────────────────────────────────────── */
.journal{padding:80px 6vw;background:#F0EDE8;position:relative;overflow:hidden}
.journal-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;position:relative;z-index:1}
.journal-header h2{font-size:clamp(32px,6vw,72px)}
.journal-header p{font-family:'Playfair Display',serif;font-style:italic;font-size:15px;color:var(--muted);margin-bottom:4px}
.journal-header a{font-size:12px;color:var(--dark);text-decoration:underline;text-underline-offset:4px}
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;z-index:1}
.journal-item{cursor:pointer}
.journal-item:nth-child(2){margin-top:60px}
.journal-img-wrap{overflow:hidden;aspect-ratio:4/5;margin-bottom:18px}
.journal-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.journal-img-wrap:hover img{transform:scale(1.04)}
.journal-date{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.journal-title{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(17px,1.6vw,22px);font-weight:400;line-height:1.35;color:var(--dark);transition:color .2s;text-decoration:none;display:block}
.journal-item:hover .journal-title{color:var(--accent)}
.journal-read{margin-top:12px;font-size:12px;color:var(--muted);text-decoration:underline;text-underline-offset:3px}
.journal-empty{grid-column:1/-1;color:var(--muted);font-size:15px;text-align:center;padding:40px 0}

/* ── JOURNAL ARCHIVE ──────────────────────────────────────────────────────── */
.journal-archive{padding:100px 6vw 80px;background:var(--bg);min-height:70vh}
.journal-archive-inner{max-width:820px;margin:0 auto}
.journal-archive-title{font-size:clamp(40px,7vw,80px);margin-bottom:16px}
.journal-archive-intro{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--muted);margin-bottom:60px;line-height:1.5}
.journal-archive-list{display:flex;flex-direction:column;gap:48px}
.journal-post{display:grid;grid-template-columns:240px 1fr;gap:36px;align-items:start;padding-bottom:48px;border-bottom:.5px solid var(--border)}
.journal-post:last-child{border-bottom:none}
.journal-post-img{overflow:hidden;aspect-ratio:3/2}
.journal-post-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.journal-post:hover .journal-post-img img{transform:scale(1.03)}
.journal-post-date{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:block}
.journal-post-title{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(20px,2.2vw,28px);font-weight:400;line-height:1.3;color:var(--dark);text-decoration:none;display:block;margin-bottom:12px;transition:color .2s}
.journal-post-title:hover{color:var(--accent)}
.journal-post-excerpt{font-size:15px;line-height:1.7;color:var(--muted);font-weight:300;max-width:520px;margin-bottom:16px}
.journal-post-read{font-size:12px;color:var(--dark);text-decoration:underline;text-underline-offset:3px}
.journal-pagination{margin-top:60px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.journal-pagination a,.journal-pagination span{padding:10px 16px;font-size:13px;border:.5px solid var(--border);text-decoration:none;color:var(--dark);transition:all .2s;min-height:44px;display:flex;align-items:center}
.journal-pagination a:hover{background:var(--dark);color:var(--bg)}
.journal-pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── SINGLE POST ──────────────────────────────────────────────────────────── */
.single-post-wrap{padding:100px 6vw 80px;background:var(--bg)}
.single-post-inner{max-width:700px;margin:0 auto}
.single-post-back{font-size:12px;color:var(--muted);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;font-weight:600;margin-bottom:32px;display:inline-flex;align-items:center;gap:6px;min-height:44px}
.single-post-back:hover{color:var(--accent)}
.single-post-date{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;display:block}
.single-post-title{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(28px,4vw,52px);font-weight:400;line-height:1.2;margin-bottom:32px}
.single-post-hero{width:100%;aspect-ratio:16/9;overflow:hidden;margin-bottom:40px}
.single-post-hero img{width:100%;height:100%;object-fit:cover}
.single-post-content{font-size:17px;line-height:1.85;color:var(--dark);font-weight:300}
.single-post-content p{margin-bottom:24px}
.single-post-content h2{font-family:'Montserrat',sans-serif;font-weight:800;text-transform:uppercase;font-size:20px;margin:40px 0 16px}
.single-post-content h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:16px;margin:28px 0 12px}
.single-post-content img{width:100%;height:auto;margin:32px 0}
.single-post-content a{color:var(--accent);text-decoration:underline}
.single-post-content blockquote{font-family:'Playfair Display',serif;font-style:italic;font-size:22px;padding:24px 0 24px 24px;border-left:3px solid var(--accent);margin:32px 0;color:var(--muted)}
.single-post-content ul,.single-post-content ol{margin:0 0 24px 24px}
.single-post-content li{margin-bottom:8px;line-height:1.7}

/* Author Box */
.author-box{display:flex;gap:20px;align-items:flex-start;padding:28px;background:#F0EDE8;border-radius:8px;margin:48px 0 0}
.author-box img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box strong{display:block;font-family:'Montserrat',sans-serif;font-weight:900;font-size:14px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.author-box span{display:block;font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:8px}
.author-box a{font-size:12px;color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* ── NEWSLETTER ───────────────────────────────────────────────────────────── */
.newsletter{padding:80px 6vw;background:var(--dark);position:relative;overflow:hidden}
.newsletter-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.newsletter-title{font-size:clamp(40px,7vw,96px);color:#F4F2EE;margin-bottom:20px}
.newsletter-text p{font-size:16px;line-height:1.65;color:rgba(244,242,238,.6);max-width:360px;font-weight:300}
.newsletter-input-row{display:flex;gap:0;margin-bottom:14px}
.newsletter-input-row input{flex:1;padding:14px 18px;background:rgba(244,242,238,.08);border:1px solid rgba(244,242,238,.2);color:#F4F2EE;font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;border-radius:5px 0 0 5px;border-right:none;min-height:44px}
.newsletter-input-row input::placeholder{color:rgba(244,242,238,.35)}
.newsletter-input-row input:focus{border-color:rgba(244,242,238,.5)}
.newsletter-input-row .btn{border-radius:0 5px 5px 0;white-space:nowrap}
.newsletter-note{font-size:11px;color:rgba(244,242,238,.35);line-height:1.55}
.newsletter-note a{color:rgba(244,242,238,.5);text-decoration:underline}
.newsletter-success{display:flex;align-items:center;gap:10px;padding:14px 18px;background:rgba(244,242,238,.08);border:1px solid rgba(244,242,238,.2);border-radius:5px;color:#F4F2EE;font-size:14px;margin-top:12px}

/* ── FAQ (legacy auf Startseite) ──────────────────────────────────────────── */
.faq-section{padding:80px 6vw;background:var(--bg);position:relative;overflow:hidden}
.faq-inner{max-width:840px}
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:.5px solid var(--border)}
.faq-item:first-child{border-top:.5px solid var(--border)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px 0;font-size:16px;font-weight:500;cursor:pointer;list-style:none;user-select:none;gap:16px}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{content:'';width:18px;height:18px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0;transition:transform .3s}
.faq-item[open] .faq-question::after{transform:rotate(180deg)}
.faq-answer{padding:0 0 20px;font-size:16px;line-height:1.75;color:var(--muted);font-weight:300;max-width:680px}
.faq-answer p{margin-bottom:8px}
.faq-answer a{color:var(--accent);text-decoration:underline}

/* ── CONTACT BANNER ───────────────────────────────────────────────────────── */
.contact-banner{background:var(--accent);padding:100px 6vw;text-align:center;position:relative;overflow:hidden}
.contact-banner h2{font-size:clamp(22px,7vw,88px);color:#fff;margin-bottom:20px;word-break:break-word;hyphens:auto}
.contact-banner p{font-size:18px;color:rgba(255,255,255,.92);font-weight:300;max-width:480px;margin:0 auto 48px;line-height:1.65}
.email-link{display:inline-block;background:#fff;color:var(--accent);font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(12px,3.5vw,15px);letter-spacing:.06em;text-transform:uppercase;padding:18px 44px;text-decoration:none;border-radius:4px;transition:all .2s;word-break:break-all;min-height:44px;display:inline-flex;align-items:center}
.email-link:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2);color:var(--accent)}

/* ── FOOTER ───────────────────────────────────────────────────────────────── */
.site-footer{background:var(--bg);color:var(--dark);padding:56px 6vw 28px;border-top:.5px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand{font-size:28px;display:block;margin-bottom:14px;color:var(--dark);text-decoration:none}
.footer-brand img{height:36px;width:auto;aspect-ratio:auto}
.footer-desc{font-size:13px;color:var(--muted);line-height:1.65;max-width:260px}
.footer-nap{
  font-size:12px;
  color:var(--muted);
  line-height:1.8;
  font-style:normal;
  margin-top:14px;
  max-width:260px;
}
.footer-nap a{
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:3px;
}
.footer-nap a:hover{color:var(--dark)}
.footer-col h4,
.footer-col-heading{font-family:'Inter',sans-serif;font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px;color:var(--dark)}
.footer-col a{display:block;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:9px;transition:color .2s;min-height:28px;display:flex;align-items:center}
.footer-col a:hover{color:var(--accent)}
.footer-social-link{width:36px;height:36px;border:.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s;border-radius:4px;text-decoration:none}
.footer-social-link:hover{background:var(--dark);color:#F4F2EE;border-color:var(--dark)}
.footer-bottom{border-top:.5px solid var(--border);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-bottom span,
.footer-bottom a{font-size:11px;color:var(--muted);text-decoration:none;transition:color .2s}
.footer-bottom a:hover{color:var(--accent)}
.footer-legal{display:flex;gap:20px}
.footer-legal span,
.footer-legal a{color:var(--muted);font-size:11px}

/* ── STATIC PAGE (Impressum / Datenschutz) ────────────────────────────────── */
.page-wrap{padding:100px 6vw 80px;background:var(--bg);min-height:70vh}
.page-inner{max-width:780px;margin:0 auto}
.page-inner h1{font-size:clamp(32px,6vw,64px);margin-bottom:40px}
.page-inner h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:18px;text-transform:uppercase;letter-spacing:.03em;margin:40px 0 14px}
.page-inner p{font-size:16px;line-height:1.8;color:var(--muted);margin-bottom:20px;font-weight:300}
.page-inner a{color:var(--accent);text-decoration:underline}
.page-inner ul,.page-inner ol{margin:0 0 20px 24px;color:var(--muted)}
.page-inner li{font-size:16px;line-height:1.8;margin-bottom:6px}
.page-back{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;margin-bottom:40px;transition:color .2s;min-height:44px}
.page-back:hover{color:var(--accent)}

/* ── 404 ──────────────────────────────────────────────────────────────────── */
.notfound{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:80px 6vw;text-align:center;background:var(--bg)}
.notfound-inner{max-width:560px}
.notfound-number{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(100px,20vw,200px);line-height:1;color:var(--bg);-webkit-text-stroke:2px var(--border);letter-spacing:-.05em;margin-bottom:-20px}
.notfound h1{font-size:clamp(24px,4vw,48px);margin-bottom:20px}
.notfound p{font-size:16px;color:var(--muted);line-height:1.65;margin-bottom:36px;font-weight:300}
.notfound-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── SECTION-HEADLINE-PUNKTE (rot/dunkel) ─────────────────────────────────── */
.hd-dot::after{
  content:".";
  color:var(--accent);
  display:inline;
}
.hd-dot-dark::after{
  content:".";
  color:var(--dark);
  display:inline;
}

/* ── Etsy-Button unter Original-Werken (legacy) ───────────────────────────── */
.gallery-etsy-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:12px;
  padding:9px 16px;
  background:transparent;
  border:1px solid var(--dark);
  color:var(--dark);
  font-family:'Inter',sans-serif;
  font-weight:500;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  border-radius:3px;
  transition:all .2s ease;
  min-height:36px;
}
.gallery-etsy-btn:hover{
  background:var(--dark);
  color:var(--bg);
}
.gallery-etsy-btn svg{flex-shrink:0}

/* ── PRINT CARDS V2 ───────────────────────────────────────────────────────── */
.prints-cards--immersive{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-top:40px;
  position:relative;
  z-index:1;
}

@media (max-width:900px){
  .prints-cards--immersive{
    grid-template-columns:1fr;
    gap:20px;
  }
}

article.print-card-v2,
.print-card-v2{
  position:relative;
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  text-decoration:none;
  color:#F4F2EE;
  background:#1a1a1a;
  border-radius:2px;
  isolation:isolate;
  transition:transform .4s ease;
  cursor:pointer;
}

.print-card-v2:hover{transform:translateY(-4px)}

.print-card-v2 img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
  transition:transform .6s ease, filter .4s ease;
}

article.print-card-v2:hover img{
  transform:scale(1.04);
  filter:brightness(.85);
}

.print-card-v2-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.05) 35%,
    rgba(0,0,0,.05) 55%,
    rgba(0,0,0,.85) 100%
  );
}

.print-card-v2-top{display:flex;flex-direction:column;gap:4px}

.print-card-v2-title{
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:18px;
  letter-spacing:-.01em;
  color:#F4F2EE;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  line-height:1.15;
}

.print-card-v2-size{
  font-family:'Inter',sans-serif;
  font-weight:500;
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(244,242,238,.92);
  text-shadow:0 1px 4px rgba(0,0,0,.6);
}

.print-card-v2-bottom{display:flex;flex-direction:column;gap:14px}

.print-card-v2-price{
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:22px;
  color:#F4F2EE;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}

.print-card-v2-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-top:12px;
  border-top:.5px solid rgba(244,242,238,.25);
  gap:12px;
}

.print-card-v2-btns{
  display:flex;
  align-items:center;
  gap:10px;
  position:relative;
  z-index:3;
}

.print-card-v2-link-secondary{
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(244,242,238,.92);
  text-decoration:none;
  padding:10px 6px;
  border-bottom:1px solid rgba(244,242,238,.5);
  transition:color .25s ease, border-color .25s ease;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
}
article.print-card-v2:hover .print-card-v2-link-secondary,
.print-card-v2-link-secondary:hover{
  color:#F4F2EE;
  border-color:#F4F2EE;
}

.print-card-v2-stretched::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
}

.print-card-v2-link-primary{
  font-family:'Inter',sans-serif;
  font-weight:700;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
  background:var(--accent);
  text-decoration:none;
  padding:11px 16px;
  border:1px solid var(--accent);
  border-radius:2px;
  transition:background .25s ease, transform .25s ease;
  white-space:nowrap;
  position:relative;
  z-index:4;
  min-height:40px;
  display:inline-flex;
  align-items:center;
}
.print-card-v2-link-primary:hover{
  background:#9a1f28;
  border-color:#9a1f28;
  transform:translateY(-1px);
}
.print-card-v2-link-primary:focus-visible{
  outline:2px solid #fff;
  outline-offset:2px;
}

.print-card-v2-stretched:focus-visible::before{
  outline:2px solid var(--accent);
  outline-offset:-2px;
}

.print-card-v2:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
}

/* ── REVIEWS SECTION (V2) ─────────────────────────────────────────────────── */
.reviews-section{
  padding:80px 6vw;
  background:#F0EDE8;
  position:relative;
  overflow:hidden;
}
.reviews-section-inner{
  position:relative;
  z-index:1;
}
.reviews-section .reviews-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:48px;
  gap:32px;
  flex-wrap:wrap;
}
.reviews-section .reviews-header h2{
  font-size:clamp(32px,6vw,72px);
}
.reviews-section .reviews-header > div p{
  font-size:15px;color:var(--muted);margin-top:14px;max-width:460px;line-height:1.65;font-weight:300;
}
.reviews-section .reviews-header .lbl{
  display:block;margin-bottom:14px;
}

.reviews-aggregate{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  text-align:right;
}
.reviews-aggregate-stars{
  color:var(--accent);
  letter-spacing:3px;
  font-size:18px;
  line-height:1;
}
.reviews-aggregate-meta{
  font-size:13px;
  color:var(--muted);
  font-weight:400;
}
.reviews-aggregate-meta strong{
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  font-size:18px;
  color:var(--dark);
  letter-spacing:-.01em;
}
.reviews-aggregate-link{
  font-size:11px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dark);
  text-decoration:underline;
  text-underline-offset:4px;
  margin-top:4px;
  transition:color .2s;
}
.reviews-aggregate-link:hover{color:var(--accent)}

.reviews-section .reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.reviews-section .review-card{
  background:var(--bg);
  border:.5px solid var(--border);
  border-radius:6px;
  padding:28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .3s ease, box-shadow .3s ease;
}
.reviews-section .review-card:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(17,17,17,.06);
}
.reviews-section .review-card .review-stars{
  color:var(--accent);
  font-size:14px;
  letter-spacing:2px;
  line-height:1;
}
.reviews-section .review-card p{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:16px;
  line-height:1.6;
  color:var(--dark);
  flex:1;
  margin:0;
}
.reviews-section .review-card cite{
  font-size:11px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  font-style:normal;
}

@media(max-width:900px){
  .reviews-section .reviews-grid{grid-template-columns:1fr 1fr}
  .reviews-section .reviews-header{align-items:flex-start}
  .reviews-aggregate{align-items:flex-start;text-align:left}
}
@media(max-width:600px){
  .reviews-section{padding:60px 6%}
  .reviews-section .reviews-grid{grid-template-columns:1fr}
  .reviews-section .review-card{padding:24px}
  .reviews-section .review-card p{font-size:15px}
}

/* ── ETSY CTA – Final Push ────────────────────────────────────────────────── */
.etsy-cta{
  background:#111111;
  color:#F4F2EE;
  padding:120px 6vw;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.etsy-cta-grain{
  position:absolute;
  inset:0;
  opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  pointer-events:none;
}
.etsy-cta-inner{
  position:relative;
  z-index:1;
  max-width:1100px;
  margin:0 auto;
}
.etsy-cta-headline{
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  font-size:clamp(48px,11vw,160px);
  line-height:.95;
  letter-spacing:-.03em;
  margin:0 0 36px;
  text-transform:uppercase;
}
.etsy-cta-headline span{display:block}
.etsy-cta-line-1{color:#F4F2EE}
.etsy-cta-line-2{color:#888888}  /* von #555 auf #888 für besseren Kontrast auf #111 */
.etsy-cta-sub{
  font-family:'Inter',sans-serif;
  font-size:clamp(16px,1.6vw,20px);
  line-height:1.6;
  color:rgba(244,242,238,.85);
  font-weight:300;
  max-width:620px;
  margin:0 auto 48px;
}
.etsy-cta-btn{
  display:inline-block;
  background:#F4F2EE;
  color:#111111;
  padding:20px 56px;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  text-decoration:none;
  border:none;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.etsy-cta-btn:hover,
.etsy-cta-btn:focus-visible{
  transform:translateY(-3px);
  box-shadow:0 14px 40px rgba(0,0,0,.5);
  background:#fff;
  outline:none;
}
.etsy-cta-btn:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
}

@media(max-width:600px){
  .etsy-cta{padding:90px 6%}
  .etsy-cta-headline{margin-bottom:28px}
  .etsy-cta-sub{margin-bottom:36px}
  .etsy-cta-btn{padding:18px 40px;font-size:12px;letter-spacing:.16em}
}

/* ── FAQ PAGE ─────────────────────────────────────────────────────────────── */
.faq-hero{
  padding:120px 6vw 60px;
  max-width:1400px;
  margin:0 auto;
}
.faq-hero-inner{max-width:780px}
.faq-hero h1{font-size:clamp(48px,8vw,96px);margin:14px 0 24px}
.faq-hero-sub{
  font-size:clamp(15px,1.5vw,18px);
  color:var(--muted);
  line-height:1.7;
  font-weight:300;
  max-width:620px;
}
.faq-hero-sub a{color:var(--dark);text-decoration:underline;text-underline-offset:3px}
.faq-hero-sub a:hover{color:var(--accent)}
.faq-list-section{padding:0 6vw 120px;max-width:1400px;margin:0 auto}
.faq-list{max-width:880px;margin:0 auto;border-top:.5px solid var(--border)}
.faq-item summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:24px 0;
  cursor:pointer;
  list-style:none;
  font-family:'Inter',sans-serif;
  transition:color .2s ease;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--accent)}
.faq-item .faq-question{
  font-size:clamp(16px,1.8vw,19px);
  font-weight:500;
  color:var(--dark);
  letter-spacing:-.005em;
  flex:1;
}
.faq-item:hover .faq-question{color:inherit}
.faq-icon{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-icon::before,
.faq-icon::after{content:'';position:absolute;background:var(--dark);transition:transform .25s ease}
.faq-icon::before{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%)}
.faq-icon::after{top:0;bottom:0;left:50%;width:1.5px;transform:translateX(-50%)}
.faq-item[open] .faq-icon::after{transform:translateX(-50%) rotate(90deg);opacity:0}
.faq-answer{padding:0 0 28px;max-width:740px}
.faq-answer p{font-family:'Inter',sans-serif;font-size:16px;line-height:1.75;color:var(--muted);font-weight:300}
.faq-item summary:focus-visible{outline:2px solid var(--accent);outline-offset:4px}

@media(max-width:600px){
  .faq-hero{padding:80px 6% 40px}
  .faq-list-section{padding:0 6% 80px}
  .faq-item summary{padding:20px 0;gap:16px}
  .faq-item .faq-question{font-size:16px}
  .faq-answer{padding:0 0 24px}
  .faq-answer p{font-size:15px}
}

/* ── PRINT DETAIL PAGE ────────────────────────────────────────────────────── */
.print-detail{padding-top:32px}
.print-detail-breadcrumb{padding:0 6%;margin-bottom:32px}
.print-detail-breadcrumb ol{list-style:none;display:flex;gap:10px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;align-items:center}
.print-detail-breadcrumb a{color:var(--muted);text-decoration:none;transition:color .2s}
.print-detail-breadcrumb a:hover{color:var(--accent)}
.print-detail-breadcrumb [aria-hidden]{color:var(--border)}
.print-detail-breadcrumb [aria-current] span{color:var(--dark)}
.print-detail-hero{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0;min-height:680px;overflow:hidden;border-top:.5px solid var(--border);border-bottom:.5px solid var(--border)}
.print-detail-hero-img{position:relative;overflow:hidden;background:#E8E5E0}
.print-detail-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.print-detail-hero-info{padding:80px 6% 80px 8%;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2;background:var(--bg)}
.print-detail-title{font-size:clamp(48px,8vw,96px);margin:14px 0 18px}
.print-detail-tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:22px;line-height:1.3;color:var(--dark);margin-bottom:18px;max-width:480px}
.print-detail-short{font-size:16px;line-height:1.7;color:var(--muted);font-weight:300;margin-bottom:32px;max-width:480px}
.print-detail-buy{display:flex;align-items:center;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.print-detail-price{font-family:'Montserrat',sans-serif;font-weight:900;font-size:42px;letter-spacing:-.02em;color:var(--accent);line-height:1}
.print-detail-cta{padding:16px 32px;font-size:13px}
.print-detail-specs{display:grid;grid-template-columns:1fr;gap:0;border-top:.5px solid var(--border);max-width:480px}
.print-detail-specs > div{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:14px 0;border-bottom:.5px solid var(--border)}
.print-detail-specs dt{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);align-self:center}
.print-detail-specs dd{font-size:14px;color:var(--dark);font-weight:400;line-height:1.5}
.print-detail-story{position:relative;padding:120px 6%;background:#EDE9E3;border-bottom:.5px solid var(--border)}
.print-detail-story-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:80px;align-items:start}
.print-detail-story .lbl{display:block;margin-bottom:18px}
.print-detail-story .hd{font-size:clamp(40px,5vw,64px)}
.print-detail-prose{font-size:17px;line-height:1.8;color:var(--dark);font-weight:300;max-width:680px}
.print-detail-prose p{margin-bottom:1.4em}
.print-detail-prose p:first-of-type::first-letter{font-family:'Montserrat',sans-serif;font-weight:900;float:left;font-size:78px;line-height:.85;padding:6px 12px 0 0;color:var(--accent)}
.print-detail-prose p:last-child{margin-bottom:0}
.print-detail-related{position:relative;padding:120px 6%}
.print-detail-related-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto}
.print-detail-related-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;gap:24px;flex-wrap:wrap}
.print-detail-related-header .hd{font-size:clamp(32px,4vw,52px)}
.print-detail-related-header > a{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.print-detail-related-header > a:hover{color:var(--accent)}
.print-detail-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.print-detail-related-card{display:block;text-decoration:none;color:inherit;position:relative;overflow:hidden;background:#E8E5E0;aspect-ratio:1/1}
.print-detail-related-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.6,.2,1)}
.print-detail-related-card:hover img{transform:scale(1.04)}
.print-detail-related-meta{position:absolute;left:0;right:0;bottom:0;padding:20px 24px;background:linear-gradient(to top,rgba(17,17,17,.9),transparent);color:#fff}
.print-detail-related-meta h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:18px;letter-spacing:-.02em;text-transform:uppercase;margin:0 0 4px}
.print-detail-related-meta p{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin:0;opacity:.85}

@media(max-width:900px){
  .print-detail-hero{grid-template-columns:1fr;min-height:auto}
  .print-detail-hero-img{aspect-ratio:1/1}
  .print-detail-hero-info{padding:48px 6% 64px}
  .print-detail-title{font-size:clamp(40px,10vw,64px)}
  .print-detail-tagline{font-size:19px}
  .print-detail-story{padding:80px 6%}
  .print-detail-story-inner{grid-template-columns:1fr;gap:32px}
  .print-detail-prose{font-size:16px}
  .print-detail-prose p:first-of-type::first-letter{font-size:64px}
  .print-detail-related{padding:80px 6%}
  .print-detail-related-grid{grid-template-columns:1fr;gap:16px}
}
@media(max-width:600px){
  .print-detail-breadcrumb{padding:0 5%}
  .print-detail-hero-info{padding:40px 5% 56px}
  .print-detail-buy{gap:16px}
  .print-detail-price{font-size:36px}
  .print-detail-specs > div{grid-template-columns:100px 1fr;gap:16px;padding:12px 0}
  .print-detail-story{padding:64px 5%}
  .print-detail-related{padding:64px 5%}
}

/* ╔══════════════════════════════════════════════════════════════════════════
 *  v2.6 — WCAG-Color-Contrast-Helper (ersetzt Inline-Styles im Template)
 *  Verwendung im PHP statt `style="color:rgba(...)"`:
 *    → Auf dunklem Grund (#111):     class="lbl lbl-on-dark"
 *    → Auf rotem Akzent (#B62731):   class="lbl lbl-on-accent"
 * ════════════════════════════════════════════════════════════════════════ */
.lbl-on-dark{
  color:rgba(244,242,238,.85);  /* ~5.6:1 auf #111 — WCAG AA */
}
.lbl-on-accent{
  display:block;
  margin-bottom:16px;
  color:#fff;                    /* 5.5:1 auf #B62731 — WCAG AA */
}

/* ── HERO-Title-Helper (statt inline style="color:var(...)") ──────────────── */
.hero-title .accent{color:var(--accent)}
.hero-title .dark{color:var(--dark)}

/* ── Statement-Inhalt (statt inline styles) ───────────────────────────────── */
.statement-inner h2{color:var(--dark)}

/* ╔══════════════════════════════════════════════════════════════════════════
 *  v2.6.1 — Helper-Klassen für ehemals-inline-styles aus header.php / footer.php
 * ════════════════════════════════════════════════════════════════════════ */

/* Mobile-Menu Etsy-Button (war inline style margin-top:36px;width:100%;...) */
.btn-mobile-menu{
  margin-top:36px;
  width:100%;
  justify-content:center;
  font-size:13px;
}

/* Footer-Social-Row (war inline style display:flex;gap:10px;margin-top:20px) */
.footer-social{
  display:flex;
  gap:10px;
  margin-top:20px;
}

/* Cookie-Banner-Titel (war inline style auf <strong>) */
.cookie-banner-title{
  display:block;
  margin-bottom:6px;
  font-size:14px;
  color:#F4F2EE;
}

/* ── RESPONSIVE ───────────────────────────────────────────────────────────── */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .hero{grid-template-columns:1fr}
  .hero-img{min-height:50vh}
  .hero-hairline{display:none}
  .hero-text{padding:48px 6%}
  .statement{grid-template-columns:1fr;min-height:auto;padding:60px 6%}
  .prints-cards{grid-template-columns:1fr 1fr}
  .social-proof{grid-template-columns:1fr}
  .social-proof-stats{justify-content:center}
  .about{grid-template-columns:1fr;min-height:auto}
  .about-img{min-height:auto}
  .about-img img{position:relative;inset:auto;width:100%;height:auto;max-height:70vw;object-fit:cover;object-position:center top}
  .about-hairline{display:none}
  .about-text{padding:40px 6%}
  .gallery-grid,.journal-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}
  .gallery-item:nth-child(2),.journal-item:nth-child(2){margin-top:0}
  .newsletter-inner{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .journal-post{grid-template-columns:1fr}
  .journal-post-img{aspect-ratio:16/9}
  .prints-shop-header{flex-direction:column}
  .faq-inner{max-width:100%}
}
@media(max-width:600px){
  .gallery-grid,.journal-grid{grid-template-columns:1fr}
  .prints-cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-banner{padding:60px 5vw}
  .email-link{padding:16px 24px}
  .newsletter-input-row{flex-direction:column}
  .newsletter-input-row input{border-radius:5px 5px 0 0;border-right:1px solid rgba(244,242,238,.2);border-bottom:none}
  .newsletter-input-row .btn{border-radius:0 0 5px 5px;justify-content:center}
  .cookie-banner{flex-direction:column;align-items:flex-start;padding:14px 5%;font-size:12px;gap:12px}
  .cookie-banner-text{min-width:0}
  .cookie-banner p{font-size:12px;line-height:1.5}
  .cookie-banner-actions{width:100%}
  .cookie-btn{width:100%;justify-content:center}
  .hero-trust{font-size:11px}
  .about-credentials{gap:16px}
  .hero-trust{font-size:12px;gap:8px}
  .hero-trust-stars{font-size:12px;letter-spacing:1.5px}
  .print-card-v2-actions{
    gap:10px;
    flex-wrap:wrap;
  }
  .print-card-v2-btns{
    gap:8px;
    margin-left:auto;
  }
  .print-card-v2-link-secondary{
    padding:10px 4px;
    font-size:10px;
  }
  .print-card-v2-link-primary{
    padding:11px 14px;
    font-size:11px;
  }
}
@media(min-width:601px) and (max-width:900px){
  .print-card-v2-link-secondary{font-size:10px;letter-spacing:.12em}
  .print-card-v2-link-primary{font-size:11px;padding:10px 14px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
}
@media(forced-colors:active){
  .btn,.nav-shop,.cookie-btn-accept{border:2px solid ButtonText}
}

/* ── text-wrap Balance für Headlines (modern, fällt safe zurück) ──────────── */
.hd,
.hero-title,
.statement-headline,
.print-detail-title{
  text-wrap:balance;
}
