/*
Theme Name: Uwe Nestlen Photography
Theme URI: https://uwenestlen-photography.de
Author: Uwe Nestlen Photography
Author URI: https://uwenestlen-photography.de
Description: Individuelles, dunkles und editoriales Theme für die Fotografie-Website von Uwe Nestlen. Konzert, Portrait, Sport und Fineart. Layout fest verbaut, Inhalte über den Customizer und einen eigenen Galerie-Bereich pflegbar – ganz ohne Zusatz-Plugin.
Version: 2.1
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: uwenestlen
*/


  /* ============ TOKENS ============ */
  :root{
    --black: #0a0a0a;
    --ink: #141312;
    --paper: #f5f3ee;
    --paper-dim: #cfccc3;
    --red: #8b1e1e;
    --red-bright: #b5311f;
    --slate: #3a3a38;
    --slate-light: #5a5854;
    --brass: #c9a961;

    --display: 'Oswald', sans-serif;
    --body: 'Newsreader', serif;

    --container: 1320px;
    --edge: clamp(20px, 5vw, 64px);
  }

  *{ margin:0; padding:0; box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  body{
    background: var(--black);
    color: var(--paper);
    font-family: var(--body);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }
  body.no-scroll{ overflow:hidden; }
  img{ display:block; width:100%; height:100%; object-fit:cover; }
  a{ color:inherit; text-decoration:none; }
  ::selection{ background: var(--red); color: var(--paper); }

  @media (prefers-reduced-motion: reduce){
    *{ animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  }

  /* ============ UTILITY TYPE ============ */
  .eyebrow{
    font-family: var(--display);
    font-size: 0.72rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--brass);
    font-weight: 500;
  }
  .display{
    font-family: var(--display);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.01em;
    line-height: 0.95;
  }
  .serif-italic{ font-style: italic; font-weight: 400; }

  /* ============ FILM GRAIN OVERLAY ============ */
  .grain{
    pointer-events:none;
    position:fixed; inset:0; z-index:90;
    opacity:0.045;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    mix-blend-mode: overlay;
  }

  /* ============ LIGHT BEAM SIGNATURE ============ */
  .beam{
    position:absolute;
    top:-10%;
    width:340px;
    height:170%;
    background: linear-gradient(180deg, rgba(245,243,238,0) 0%, rgba(245,243,238,0.06) 45%, rgba(201,169,97,0.10) 55%, rgba(245,243,238,0) 100%);
    transform: rotate(18deg);
    pointer-events:none;
    z-index:1;
  }

  /* ============ NAV ============ */
  header{
    position: fixed; top:0; left:0; right:0; z-index:200;
    display:flex; align-items:center; justify-content:space-between;
    padding: 18px var(--edge);
    transition: background 0.4s ease, padding 0.4s ease, border-color .4s ease;
    border-bottom: 1px solid transparent;
  }
  header.scrolled{
    background: rgba(10,10,10,0.88);
    backdrop-filter: blur(10px);
    padding: 10px var(--edge);
    border-bottom-color: rgba(245,243,238,0.08);
  }
  .logo-img{ height:78px; width:auto; transition: height .4s ease; }
  header.scrolled .logo-img{ height:58px; }
  nav ul{ list-style:none; display:flex; gap:36px; }
  nav a{
    font-family: var(--display);
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--paper-dim);
    position:relative;
    padding-bottom: 4px;
    transition: color .25s;
  }
  nav a::after{
    content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
    background: var(--red-bright); transition: width .3s ease;
  }
  nav a:hover{ color: var(--paper); }
  nav a:hover::after{ width:100%; }
  .nav-toggle{ display:none; }

  /* ============ HERO ============ */
  .hero{
    position:relative;
    min-height: 100vh;
    display:flex;
    align-items:flex-end;
    overflow:hidden;
    background: var(--ink);
  }
  .hero-grid{
    position:absolute; inset:0;
    display:grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap:0;
  }
  .hero-grid img{
    filter: grayscale(1) contrast(1.12) brightness(0.62);
    transform: scale(1.04);
    transition: filter .6s ease, transform .6s ease;
  }
  .hero-grid img:hover{
    filter: grayscale(0) contrast(1.05) brightness(0.92) saturate(1.05);
    transform: scale(1.07);
  }
  .hero::before{
    content:'';
    position:absolute; inset:0;
    background: linear-gradient(180deg, rgba(10,10,10,0.35) 0%, rgba(10,10,10,0.25) 40%, rgba(10,10,10,0.96) 92%);
    z-index:2;
    pointer-events:none;
  }
  .hero-content{
    position:relative; z-index:3;
    width:100%;
    padding: 0 var(--edge) 70px;
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap: 40px;
  }
  .hero-title{
    font-size: clamp(3.4rem, 9vw, 8.2rem);
    color: var(--paper);
  }
  .hero-title .line2{ color: var(--brass); }
  .hero-sub{
    max-width: 320px;
    font-family: var(--body);
    font-size: 1.05rem;
    line-height:1.5;
    color: var(--paper-dim);
    padding-bottom: 14px;
    border-left: 2px solid var(--red);
    padding-left: 20px;
  }
  .hero-meta{
    position:absolute; top:120px; left: var(--edge); z-index:3;
  }
  .scroll-cue{
    position:absolute; bottom:28px; right:var(--edge); z-index:3;
    display:flex; flex-direction:column; align-items:center; gap:10px;
  }
  .scroll-cue span{
    font-family:var(--display); font-size:0.68rem; letter-spacing:0.2em;
    color:var(--paper-dim); text-transform:uppercase; writing-mode: vertical-rl;
  }
  .scroll-cue .line{ width:1px; height:46px; background:linear-gradient(180deg, var(--brass), transparent); animation: scrollpulse 2s ease-in-out infinite; }
  @keyframes scrollpulse{ 0%,100%{opacity:0.3} 50%{opacity:1} }

  /* ============ SECTION SHELLS ============ */
  section{ position:relative; }
  .section-pad{ padding: 130px var(--edge); }
  .section-head{
    display:flex; justify-content:space-between; align-items:flex-end;
    margin-bottom: 56px; gap:30px; flex-wrap:wrap;
  }
  .section-head h2{ font-size: clamp(2.2rem, 4.2vw, 3.6rem); max-width: 640px; }
  .section-head .num{
    font-family:var(--display); font-size:0.8rem; color:var(--slate-light); letter-spacing:0.1em;
  }

  /* ============ INTRO / MANIFEST ============ */
  .intro{ background: var(--black); }
  .intro-row{ display:grid; grid-template-columns: 1fr 1.3fr; gap: 70px; align-items:start; }
  .intro-row p{ font-size: 1.5rem; line-height:1.5; color: var(--paper); font-weight:400; }
  .intro-row .accent{ color: var(--brass); font-style:italic; }
  .intro-stats{ display:flex; flex-direction:column; gap:30px; }
  .stat{ border-top:1px solid rgba(245,243,238,0.14); padding-top:14px; }
  .stat .n{ font-family:var(--display); font-size:2.1rem; color:var(--paper); display:block; }
  .stat .l{ font-size:0.85rem; color:var(--paper-dim); letter-spacing:.04em; }

  /* ============ CONTACT SHEET GALLERY ============ */
  .sheet{ background: var(--ink); }
  .sheet-grid{
    display:grid;
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: 130px;
    gap: 6px;
  }
  .cell{ position:relative; overflow:hidden; cursor:pointer; background: var(--slate); }
  .cell img{ transition: transform .7s cubic-bezier(.2,.7,.2,1), filter .5s; filter:grayscale(1) contrast(1.05); }
  .cell:hover img{ transform: scale(1.08); filter:grayscale(0.15) contrast(1.08); }
  .cell .frame-no{
    position:absolute; top:8px; left:10px; font-family:var(--display);
    font-size:0.62rem; color:rgba(245,243,238,0.55); letter-spacing:.1em; z-index:2;
  }
  .cell .tag{
    position:absolute; bottom:0; left:0; right:0; padding:10px 12px 8px;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.85));
    font-family:var(--display); font-size:0.68rem; letter-spacing:.08em; text-transform:uppercase;
    color:var(--paper); opacity:0; transform:translateY(6px);
    transition: opacity .3s, transform .3s; z-index:2;
  }
  .cell .zoom-hint{
    position:absolute; top:8px; right:10px; z-index:2; opacity:0; transition:opacity .3s;
  }
  .cell .zoom-hint svg{ width:18px; height:18px; stroke:var(--paper); filter:drop-shadow(0 1px 2px rgba(0,0,0,.6)); }
  .cell:hover .zoom-hint{ opacity:.85; }
  .cell:hover .tag{ opacity:1; transform:translateY(0); }
  .cell.r2c2{ grid-row: span 2; }
  .cell.c2{ grid-column: span 2; }
  .cell.r2{ grid-row: span 2; }
  .cell.is-hidden{ display:none; }

  .sheet-filter{ display:flex; gap:8px; margin-bottom:46px; flex-wrap:wrap; }
  .filter-pill{
    font-family:var(--display); font-size:0.74rem; letter-spacing:.12em; text-transform:uppercase;
    padding:9px 20px; border:1px solid rgba(245,243,238,0.2); border-radius:2px;
    color:var(--paper-dim); cursor:pointer; transition:.25s; background:none;
  }
  .filter-pill.active{ background:var(--red); border-color:var(--red); color:var(--paper); }
  .filter-pill:hover{ border-color: var(--brass); color:var(--paper); }
  .wm-note{ font-family:var(--body); font-size:0.9rem; color:var(--slate-light); margin-top:24px; font-style:italic; }

  /* ============ LIGHTBOX ============ */
  .lightbox{
    position:fixed; inset:0; z-index:1000;
    background: rgba(8,8,8,0.96);
    backdrop-filter: blur(6px);
    display:flex; align-items:center; justify-content:center;
    opacity:0; pointer-events:none; transition: opacity .35s ease;
  }
  .lightbox.open{ opacity:1; pointer-events:auto; }
  .lb-stage{
    position:relative; max-width:92vw; max-height:84vh;
    display:flex; align-items:center; justify-content:center;
  }
  .lb-stage img{
    max-width:92vw; max-height:84vh; width:auto; height:auto;
    object-fit:contain;
    box-shadow: 0 30px 80px rgba(0,0,0,0.7);
    border: 1px solid rgba(245,243,238,0.08);
  }
  .lb-caption{
    position:absolute; left:0; right:0; bottom:-46px;
    text-align:center; font-family:var(--display); font-size:0.78rem;
    letter-spacing:.12em; text-transform:uppercase; color:var(--paper-dim);
  }
  .lb-close{
    position:absolute; top:24px; right:28px; z-index:1002;
    width:48px; height:48px; border:1px solid rgba(245,243,238,0.25); background:none;
    color:var(--paper); cursor:pointer; border-radius:50%;
    display:flex; align-items:center; justify-content:center; transition:.25s;
  }
  .lb-close:hover{ background:var(--red); border-color:var(--red); }
  .lb-close svg{ width:20px; height:20px; }
  .lb-nav{
    position:absolute; top:50%; transform:translateY(-50%); z-index:1002;
    width:54px; height:54px; border:1px solid rgba(245,243,238,0.25); background:rgba(10,10,10,0.4);
    color:var(--paper); cursor:pointer; border-radius:50%;
    display:flex; align-items:center; justify-content:center; transition:.25s;
  }
  .lb-nav:hover{ background:var(--red); border-color:var(--red); }
  .lb-nav svg{ width:22px; height:22px; }
  .lb-prev{ left:24px; }
  .lb-next{ right:24px; }
  .lb-counter{
    position:absolute; top:30px; left:28px; z-index:1002;
    font-family:var(--display); font-size:0.8rem; letter-spacing:.1em; color:var(--paper-dim);
  }
  @media (max-width:720px){
    .lb-nav{ width:42px; height:42px; }
    .lb-prev{ left:8px; } .lb-next{ right:8px; }
    .lb-caption{ bottom:-40px; font-size:0.7rem; }
  }

  /* ============ SPLIT FEATURE ============ */
  .feature{ background: var(--black); }
  .feature-row{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap:0; align-items:stretch; }
  .feature-img{ position:relative; aspect-ratio: 4/5; overflow:hidden; }
  .feature-img img{ filter:grayscale(0.3) contrast(1.05); }

  /* ============ SCHWERPUNKT MIT 3 BILDERN ============ */
  .focus{ background:var(--black); padding: 80px var(--edge); }
  .focus-head{ max-width:760px; margin:0 auto 40px; text-align:center; }
  .focus-head .quote-mark{ font-size:3rem; color:var(--brass); line-height:0.5; display:block; margin-bottom:10px; }
  .focus-head h3{ font-family:var(--display); text-transform:uppercase; font-size:clamp(2rem,3.4vw,3rem); margin:8px 0 18px; }
  .focus-head p{ color:var(--paper-dim); font-size:1.08rem; line-height:1.6; }
  .focus-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; max-width:1280px; margin:0 auto 30px; }
  .focus-cell{ position:relative; background:var(--ink); border:1px solid rgba(245,243,238,0.08);
    aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; overflow:hidden; cursor:pointer; }
  .focus-cell img{ width:100%; height:100%; object-fit:contain; filter:grayscale(0.25) contrast(1.04); transition:transform .5s ease, filter .4s; }
  .focus-cell:hover img{ transform:scale(1.03); filter:grayscale(0) contrast(1.06); }
  .focus-cta{ text-align:center; }
  @media (max-width:760px){
    .focus-grid{ grid-template-columns:1fr; }
    .focus-cell{ aspect-ratio:3/2; }
  }
  .feature-text{
    background: var(--ink); padding: 70px 64px; display:flex; flex-direction:column;
    justify-content:center; gap:24px; position:relative;
  }
  .feature-text h3{ font-size: clamp(2rem, 3.4vw, 3rem); }
  .feature-text p{ font-size:1.15rem; line-height:1.65; color:var(--paper-dim); max-width:520px; }
  .feature-text .quote-mark{ font-family:var(--display); font-size:5rem; color:var(--red); line-height:0.6; }
  .post-readmore{ display:inline-flex; align-items:center; gap:8px; margin-top:6px; font-family:var(--display); font-size:0.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--paper); cursor:pointer; background:none; border:none; }
  .post-readmore svg{ width:14px; height:14px; transition:transform .25s; }
  .post-readmore:hover svg{ transform:translateX(4px); }

  /* ============ ABOUT / PHOTOGRAPHER ============ */
  .about{ background: var(--ink); }
  .about-row{ display:grid; grid-template-columns: 360px 1fr; gap:80px; align-items:center; }
  .about-portraits{ position:relative; }
  .about-portrait{
    position:relative; border-radius:50%; overflow:hidden; aspect-ratio:1;
    border: 1px solid rgba(201,169,97,0.4); padding:8px;
  }
  .about-portrait .inner{ border-radius:50%; overflow:hidden; width:100%; height:100%; }
  .about-portrait img{ filter:contrast(1.06) saturate(0.95); }
  .about-portrait.secondary{
    position:absolute; width:150px; height:150px; right:-20px; bottom:-20px;
    border-color: rgba(201,169,97,0.55);
    background: var(--ink);
    box-shadow: 0 12px 40px rgba(0,0,0,0.55);
  }
  .about-portrait.secondary .inner img{ filter:contrast(1.06) saturate(1); }
  .about-text .eyebrow{ margin-bottom:18px; display:block; }
  .about-text h2{ font-size:clamp(2.2rem,4vw,3.2rem); margin-bottom:24px; }
  .about-text p{ font-size:1.15rem; line-height:1.7; color:var(--paper-dim); margin-bottom:18px; max-width:600px; }
  .gear-line{ display:flex; gap:28px; margin-top:30px; flex-wrap:wrap; }
  .gear-line div{ font-family:var(--display); font-size:0.75rem; letter-spacing:.08em; color:var(--brass); text-transform:uppercase; }
  .gear-line span{ color:var(--paper-dim); display:block; font-family:var(--body); font-size:0.95rem; text-transform:none; letter-spacing:0; margin-top:4px; }
  .timeline{ display:flex; gap:0; margin-top:40px; flex-wrap:wrap; border-top:1px solid rgba(245,243,238,0.14); }
  .tl-item{ flex:1; min-width:120px; padding:18px 18px 0 0; }
  .tl-item .yr{ font-family:var(--display); font-size:1.5rem; color:var(--brass); display:block; }
  .tl-item .lbl{ font-size:0.92rem; color:var(--paper-dim); margin-top:4px; }

  /* ============ JOURNAL / BLOG ============ */
  .journal{ background: var(--black); }
  .journal-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:36px; }
  .post{ cursor:pointer; }
  .post-img{ position:relative; aspect-ratio: 3/2; overflow:hidden; margin-bottom:22px; }
  .post-img img{ filter:grayscale(0.85) contrast(1.08); transition:transform .6s ease, filter .4s; }
  .post:hover .post-img img{ transform:scale(1.05); filter:grayscale(0.3); }
  .post-img::after{ content:''; position:absolute; inset:0; border:1px solid rgba(245,243,238,0.12); }
  .post-cat{ font-family:var(--display); font-size:0.66rem; letter-spacing:.16em; color:var(--brass); text-transform:uppercase; background:rgba(139,30,30,0.18); border:1px solid rgba(201,169,97,0.3); padding:3px 9px; position:absolute; top:12px; left:12px; z-index:2; }
  .post-date{ font-family:var(--display); font-size:0.7rem; letter-spacing:.12em; color:var(--brass); text-transform:uppercase; margin-bottom:10px; display:block; }
  .post h4{ font-size:1.5rem; font-weight:500; line-height:1.3; margin-bottom:10px; }
  .post p{ color:var(--paper-dim); font-size:0.98rem; line-height:1.55; margin-bottom:14px; }
  .journal-all{ display:inline-flex; align-items:center; gap:10px; font-family:var(--display); font-size:0.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--brass); border:1px solid rgba(201,169,97,0.4); padding:13px 26px; transition:.25s; white-space:nowrap; }
  .journal-all:hover{ background:var(--brass); color:var(--black); }
  .journal-all svg{ width:15px; height:15px; transition:transform .25s; }
  .journal-all:hover svg{ transform:translateX(4px); }

  /* ============ CTA / CONTACT ============ */
  .cta{ background: linear-gradient(135deg, var(--red) 0%, #5e1414 100%); position:relative; overflow:hidden; }
  .cta::before{ content:''; position:absolute; inset:0; background-image: radial-gradient(circle at 80% 20%, rgba(255,255,255,0.08), transparent 50%); }
  .cta-inner{ position:relative; z-index:2; text-align:center; padding: 110px var(--edge); }
  .cta h2{ font-size: clamp(2.4rem, 6vw, 5rem); color: var(--paper); margin-bottom:24px; }
  .cta p{ font-size:1.2rem; color:rgba(245,243,238,0.85); max-width:560px; margin:0 auto 40px; }
  .btn{
    display:inline-flex; align-items:center; gap:12px;
    font-family:var(--display); font-size:0.82rem; letter-spacing:.14em; text-transform:uppercase;
    padding:18px 38px; background:var(--paper); color:var(--black); border:none;
    cursor:pointer; transition: background .25s, color .25s, transform .25s;
  }
  .btn:hover{ background:var(--black); color:var(--paper); transform:translateY(-2px); }

  /* ============ FOOTER ============ */
  footer{ background:var(--black); padding: 64px var(--edge) 30px; border-top:1px solid rgba(245,243,238,0.08); }
  .footer-row{ display:grid; grid-template-columns: 1.4fr 0.8fr 0.8fr 0.8fr; gap:50px; margin-bottom:60px; }
  .footer-brand img{ height:64px; width:auto; margin-bottom:18px; }
  .footer-brand p{ color:var(--paper-dim); font-size:0.95rem; max-width:280px; line-height:1.6; }
  .footer-col h5{ font-family:var(--display); font-size:0.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--brass); margin-bottom:18px; }
  .footer-col ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
  .footer-col a{ color:var(--paper-dim); font-size:0.95rem; transition:color .2s; }
  .footer-col a:hover{ color:var(--paper); }
  .footer-bottom{
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
    padding-top:28px; border-top:1px solid rgba(245,243,238,0.08);
    font-size:0.82rem; color:var(--slate-light);
  }
  .footer-bottom .legal a{ margin-left:22px; color:var(--slate-light); }
  .footer-bottom .legal a:hover{ color:var(--paper-dim); }

  /* ============ ANNOTATION BADGE (mockup only) ============ */
  .mock-flag{
    position:fixed; bottom:18px; left:18px; z-index:95;
    background:var(--brass); color:var(--black); font-family:var(--display);
    font-size:0.7rem; letter-spacing:.08em; padding:8px 14px; border-radius:3px;
    box-shadow:0 6px 20px rgba(0,0,0,0.4);
  }

  /* ============ REVEAL ============ */
  .reveal{ opacity:0; transform:translateY(28px); transition: opacity .8s ease, transform .8s ease; }
  .reveal.in{ opacity:1; transform:translateY(0); }

  /* ============ RESPONSIVE ============ */
  @media (max-width: 1080px){
    nav{ display:none; }
    .nav-toggle{ display:block; font-family:var(--display); font-size:0.8rem; letter-spacing:.1em; text-transform:uppercase; background:none; border:1px solid rgba(245,243,238,0.3); color:var(--paper); padding:8px 16px; cursor:pointer; }
    .hero-content{ flex-direction:column; align-items:flex-start; gap:24px; }
    .intro-row{ grid-template-columns:1fr; gap:40px; }
    .feature-row{ grid-template-columns:1fr; }
    .feature-img{ aspect-ratio:16/10; }
    .feature-text{ padding:50px var(--edge); }
    .about-row{ grid-template-columns:1fr; gap:60px; text-align:center; }
    .about-portraits{ width:260px; margin:0 auto; }
    .about-portrait.secondary{ width:110px; height:110px; }
    .gear-line, .timeline{ justify-content:center; }
    .journal-grid{ grid-template-columns:1fr 1fr; }
    .footer-row{ grid-template-columns:1fr 1fr; gap:36px; }
  }
  @media (max-width: 720px){
    .section-pad{ padding:90px var(--edge); }
    .sheet-grid{ grid-template-columns: repeat(3, 1fr); grid-auto-rows:100px; }
    .cell.c2{ grid-column: span 2; }
    .journal-grid{ grid-template-columns:1fr; }
    .footer-row{ grid-template-columns:1fr; gap:30px; }
    .hero-title{ font-size: clamp(2.2rem, 11vw, 3.4rem); line-height:1.0; }
    .hero-meta{ display:none; }
    .intro-stats{ grid-template-columns:1fr 1fr !important; }
    /* Hero-Inhalt kompakter, damit die Bilder sichtbar bleiben */
    .hero-content{ flex-direction:column; align-items:flex-start; gap:16px; padding-bottom:50px; }
    .hero-sub{ max-width:100%; font-size:0.98rem; }
    /* Bilder im Hero etwas heller zeigen, damit sie nicht „verschwinden" */
    .hero-grid img{ filter: grayscale(1) contrast(1.1) brightness(0.78); }
    .hero::before{ background: linear-gradient(180deg, rgba(10,10,10,0.25) 0%, rgba(10,10,10,0.2) 45%, rgba(10,10,10,0.92) 95%); }
  }

  /* Tablet: Hero-Schrift moderat verkleinern */
  @media (min-width: 721px) and (max-width: 1024px){
    .hero-title{ font-size: clamp(3rem, 7vw, 5.5rem); }
    .hero-sub{ max-width:280px; font-size:1rem; }
  }

  /* Handy im QUERFORMAT: niedrige Höhe — Schrift klein halten,
     damit die Hintergrundbilder nicht vom Text verdeckt werden */
  @media (max-height: 560px) and (orientation: landscape){
    .hero{ min-height: 460px; }
    .hero-title{ font-size: clamp(1.8rem, 7vw, 3rem); line-height:1.0; }
    .hero-content{ flex-direction:row; align-items:flex-end; padding-bottom:30px; gap:24px; }
    .hero-sub{ max-width:300px; font-size:0.9rem; padding-bottom:6px; }
    .scroll-cue{ display:none; }
  }

/* ============================================================
 * RECHTSSEITEN / STANDARD-SEITEN (page.php)
 * Eigener Scope .legal-page, damit nichts mit der Startseite kollidiert.
 * ============================================================ */
.legal-page{ max-width:820px; margin:0 auto; padding:90px var(--edge) 120px; }
.legal-page .eyebrow{ font-family:var(--display); font-size:0.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--brass); }
.legal-page h1{ font-family:var(--display); text-transform:uppercase; font-size:clamp(2.4rem,6vw,4rem); line-height:0.95; margin:14px 0 50px; }
.legal-page h2{ font-family:var(--display); text-transform:uppercase; font-size:1.4rem; color:var(--paper); margin:42px 0 14px; letter-spacing:.02em; }
.legal-page h3{ font-family:var(--display); font-size:1.05rem; color:var(--brass); margin:26px 0 10px; font-weight:500; }
.legal-page p{ color:var(--paper-dim); margin-bottom:16px; line-height:1.7; }
.legal-page a{ color:var(--brass); text-decoration:none; }
.legal-page a:hover{ text-decoration:underline; }
.legal-page strong{ color:var(--paper); font-weight:500; }
.legal-page ul, .legal-page ol{ color:var(--paper-dim); margin:0 0 16px 22px; line-height:1.7; }
.legal-page .lead{ font-size:1.1rem; color:var(--paper); }
.legal-page .note{ background:var(--ink); border-left:3px solid var(--brass); padding:20px 24px; margin:30px 0; border-radius:0 4px 4px 0; }
.legal-page .note p{ margin:0; color:var(--paper-dim); font-style:italic; font-size:0.98rem; }
.legal-page .divider{ height:1px; background:rgba(245,243,238,0.1); margin:40px 0; }


/* ============================================================
 * BLOG-ÜBERSICHT (archive.php) — aus journal.html
 * ============================================================ */


  .page-head{padding:90px var(--edge) 50px;max-width:1320px;margin:0 auto;}

  .eyebrow{font-family:var(--display);font-size:0.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);}

  .page-head h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.6rem,7vw,5rem);line-height:0.95;margin:14px 0 18px;}

  .page-head p{color:var(--paper-dim);font-size:1.15rem;max-width:560px;}

  .fpill{font-family:var(--display);font-size:0.74rem;letter-spacing:.12em;text-transform:uppercase;padding:9px 20px;
    border:1px solid rgba(245,243,238,0.2);border-radius:2px;color:var(--paper-dim);cursor:pointer;transition:.25s;background:none;}

  .fpill.active{background:var(--red);border-color:var(--red);color:var(--paper);}

  .fpill:hover{border-color:var(--brass);color:var(--paper);}

  .featured a{display:grid;grid-template-columns:1.3fr 1fr;gap:0;background:var(--ink);overflow:hidden;}

  .featured .f-img{position:relative;aspect-ratio:16/10;overflow:hidden;}

  .featured .f-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.4) contrast(1.08);transition:transform .7s ease,filter .4s;}

  .featured a:hover .f-img img{transform:scale(1.04);filter:grayscale(0);}

  .featured .f-text{padding:56px 50px;display:flex;flex-direction:column;justify-content:center;}

  .featured .f-cat{font-family:var(--display);font-size:0.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:16px;}

  .featured .f-text h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1;margin-bottom:16px;}

  .featured .f-date{font-family:var(--display);font-size:0.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:18px;}

  .featured .f-text p{color:var(--paper-dim);font-size:1.05rem;margin-bottom:24px;}

  .readmore{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-size:0.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--paper);}

  .readmore svg{width:15px;height:15px;transition:transform .25s;}

  @media(max-width:860px){.featured a{grid-template-columns:1fr;}.featured .f-text{padding:40px var(--edge);}}

  .bpost{cursor:pointer;display:flex;flex-direction:column;}

  .bpost.is-hidden{display:none;}

  .bpost .b-img{position:relative;aspect-ratio:3/2;overflow:hidden;margin-bottom:20px;}

  .bpost .b-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.7) contrast(1.08);transition:transform .6s ease,filter .4s;}

  .bpost:hover .b-img img{transform:scale(1.05);filter:grayscale(0.1);}

  .bpost .b-img::after{content:'';position:absolute;inset:0;border:1px solid rgba(245,243,238,0.12);}

  .b-cat{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--display);font-size:0.62rem;letter-spacing:.14em;
    text-transform:uppercase;color:var(--brass);background:rgba(10,10,10,0.6);border:1px solid rgba(201,169,97,0.3);padding:4px 10px;}

  .b-date{font-family:var(--display);font-size:0.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);margin-bottom:10px;}

  .bpost h3{font-family:var(--display);text-transform:uppercase;font-size:1.3rem;line-height:1.1;margin-bottom:14px;flex:1;}

  .bpost p{color:var(--paper-dim);font-size:0.96rem;margin-bottom:14px;flex:1;}

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

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

  .load-more{font-family:var(--display);font-size:0.82rem;letter-spacing:.14em;text-transform:uppercase;
    padding:16px 40px;border:1px solid var(--brass);color:var(--brass);background:none;cursor:pointer;transition:.25s;}

  .load-more:hover{background:var(--brass);color:var(--black);}

  .load-more-note{color:var(--slate-light);font-size:0.9rem;margin-top:18px;font-style:italic;}

/* ============================================================
 * BLOG-EINZELBEITRAG (single.php) — aus blog-preyrs.html
 * ============================================================ */

  .post-hero{position:relative;width:100%;height:72vh;min-height:480px;max-height:760px;overflow:hidden;margin-top:0;}

  .post-hero img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.4) contrast(1.08) brightness(0.7);}

  .post-hero::after{content:'';position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(10,10,10,0.4) 0%,rgba(10,10,10,0.2) 45%,rgba(10,10,10,0.95) 100%);}

  .post-hero-content{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:0 var(--edge) 56px;max-width:1000px;display:flex;flex-direction:column;align-items:flex-start;}

  .post-cat{display:inline-block;font-family:var(--display);font-size:0.7rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--brass);background:rgba(139,30,30,0.55);border:1px solid rgba(201,169,97,0.5);padding:8px 18px;margin:0 0 24px 0;}

  .post-hero h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.2rem,5.2vw,4.4rem);line-height:1.05;margin:0 0 18px 0;}

  .post-meta{font-family:var(--display);font-size:0.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-dim);}

  .post-meta span{color:var(--brass);}

  .lead{font-size:1.45rem;line-height:1.5;color:var(--paper);margin-bottom:34px;font-weight:400;}

  .lead .accent{color:var(--brass);font-style:italic;}

  .article{max-width:760px;margin:0 auto;padding:70px var(--edge) 40px;}

  .article p{font-size:1.12rem;color:var(--paper-dim);margin-bottom:24px;line-height:1.8;}

  .article p:first-of-type{font-size:1.28rem;color:var(--paper);line-height:1.7;}

  .article h2,.article h3{font-family:var(--display);color:var(--paper);margin:36px 0 14px;text-transform:uppercase;letter-spacing:.02em;}

  .article a{color:var(--brass);}

  .article strong{color:var(--paper);}

  .article .credits{margin-top:40px;padding-top:26px;border-top:1px solid rgba(245,243,238,0.12);
    font-size:0.98rem;color:var(--slate-light);line-height:1.9;}

  .article .credits strong{color:var(--paper-dim);font-weight:400;}

  .pg-head{font-family:var(--display);text-transform:uppercase;font-size:0.78rem;letter-spacing:.2em;color:var(--brass);
    margin-bottom:24px;text-align:center;}

  .post-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}

  .pg-cell{position:relative;overflow:hidden;cursor:pointer;background:var(--ink);border:1px solid rgba(245,243,238,0.08);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;}

  .pg-cell img{width:100%;height:100%;object-fit:contain;transition:transform .6s cubic-bezier(.2,.7,.2,1),filter .4s;filter:grayscale(0.4) contrast(1.04);}

  .pg-cell:hover img{transform:scale(1.04);filter:grayscale(0) contrast(1.06);}

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

  .post-nav a{font-family:var(--display);font-size:0.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-dim);
    display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(245,243,238,0.18);padding:14px 24px;transition:.25s;}

  .post-nav a:hover{border-color:var(--brass);color:var(--paper);}

  .post-nav svg{width:16px;height:16px;}
/* Blog-Filter-Container (Journal-Übersicht) */
.blog-filter{ display:flex; gap:8px; padding:0 var(--edge) 40px; max-width:1320px; margin:0 auto; flex-wrap:wrap; }

/* ============================================================
 * BEITRAGSTEXT: Bilder/Galerien im Fließtext ausblenden
 * (sie erscheinen separat unten in der schönen Galerie)
 * ============================================================ */
.article .wp-block-gallery,
.article .wp-block-image,
.article figure.wp-block-image,
.article > img,
.article p > img { display: none; }

/* ============================================================
 * ANGEBOT / LEISTUNGEN (Startseite)
 * ============================================================ */
.leistungen{background:var(--ink);}
.leistungen-intro{max-width:680px;color:var(--paper-dim);font-size:1.12rem;line-height:1.7;margin:0 0 50px;}
.leistungen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(245,243,238,0.1);border:1px solid rgba(245,243,238,0.1);}
.leistung-card{background:var(--black);padding:40px 38px;position:relative;transition:background .35s;}
.leistung-card:hover{background:#121110;}
.leistung-no{font-family:var(--display);font-size:0.78rem;letter-spacing:.2em;color:var(--brass);display:block;margin-bottom:18px;}
.leistung-card h3{font-family:var(--display);text-transform:uppercase;font-size:1.5rem;letter-spacing:.02em;margin-bottom:14px;color:var(--paper);}
.leistung-card h3::after{content:'';display:block;width:38px;height:2px;background:var(--red);margin-top:12px;}
.leistung-card p{color:var(--paper-dim);font-size:1.02rem;line-height:1.6;}
.leistungen-cta{margin-top:40px;}
@media(max-width:760px){
  .leistungen-grid{grid-template-columns:1fr;}
  .leistung-card{padding:32px 28px;}
}

/* ============================================================
 * LEISTUNGSSEITE (page-leistungen.php)
 * ============================================================ */
.leistung-detail-wrap{max-width:1100px;margin:0 auto;padding:20px var(--edge) 40px;}
.leistung-detail{display:grid;grid-template-columns:300px 1fr;gap:50px;padding:50px 0;border-top:1px solid rgba(245,243,238,0.12);}
.leistung-detail:last-child{border-bottom:1px solid rgba(245,243,238,0.12);}
.ld-left .ld-no{font-family:var(--display);font-size:0.8rem;letter-spacing:.2em;color:var(--brass);display:block;margin-bottom:14px;}
.ld-left h2{font-family:var(--display);text-transform:uppercase;font-size:2rem;line-height:1.05;color:var(--paper);}
.ld-right .ld-lead{font-size:1.15rem;color:var(--paper);margin-bottom:16px;line-height:1.5;}
.ld-right .ld-text{color:var(--paper-dim);font-size:1.05rem;line-height:1.7;}
.ablauf-wrap{max-width:1100px;margin:0 auto;padding:70px var(--edge) 90px;}
.ablauf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(245,243,238,0.1);border:1px solid rgba(245,243,238,0.1);margin-top:40px;}
.ablauf-step{background:var(--black);padding:34px 28px;}
.ablauf-step .as-no{font-family:var(--display);font-size:0.78rem;letter-spacing:.2em;color:var(--brass);display:block;margin-bottom:16px;}
.ablauf-step h3{font-family:var(--display);text-transform:uppercase;font-size:1.2rem;margin-bottom:10px;color:var(--paper);}
.ablauf-step p{color:var(--paper-dim);font-size:0.98rem;line-height:1.6;}
@media(max-width:860px){
  .leistung-detail{grid-template-columns:1fr;gap:18px;padding:38px 0;}
  .ablauf-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:520px){
  .ablauf-grid{grid-template-columns:1fr;}
}
