/* Refactored CSS — combined, deduplicated and scoped
   - Fonts kept as-is (local Rajdhani + Anonymous Pro)
   - Variables added in :root
   - Duplicates for p, .post-meta, .post figure img, .blog-post-container, media queries removed
   - Blog/single-post scoped where needed
*/

/* 1) Fonts */
@font-face {
  font-family: "Rajdhani";
  src: url("/assets/fonts/Rajdhani-Regular.woff2") format("woff2"),
       url("/assets/fonts/Rajdhani-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Rajdhani";
  src: url("/assets/fonts/Rajdhani-Bold.woff2") format("woff2"),
       url("/assets/fonts/Rajdhani-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Anonymous Pro";
  src: url("/assets/fonts/Anonymous-Pro-Regular.woff2") format("woff2"),
       url("/assets/fonts/Anonymous-Pro-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Variables */
:root{
  --bg: #fff;
  --text: #151515;
  --muted: #666;
  --accent: #111;
  --gap: 16px;
  --max-wide: 1200px;
  --overlap: clamp(80px, 16vh, 240px);
  --aspect-post: 1050/640;
}

/* Reset / Base */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Rajdhani', system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
  font-size:16px;
}

/* Scoped: use Anonymous Pro for blog content (if desired) */
.single-post,.blog { font-family: 'Anonymous Pro', system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; }

/* Utility: monospaced / code-like font helper */
.font-mono{ font-family: "Anonymous Pro", monospace; }

/* Intro (visually hidden H1 ok) */
.intro{left:40px;top:40px;z-index:11;color:#000}
.intro h1{font-size:1px;line-height:1;position:absolute;left:-9999px}

/* Layout: About Page main */
body:not(.single-post) main{
  max-width:var(--max-wide);margin:100px auto 120px;padding:0 20px;
}

/* Headings */
h1{font-size:32px;margin-bottom:32px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
h2{font-size:22px;margin:42px 0 16px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
h3, header.page-head h3{font-family:'Rajdhani', serif;font-weight:500;letter-spacing:.02em;line-height:1.15}

/* Paragraphs (single source of truth) */
p{
  font-size:17px;
  line-height:1.65;
  margin-bottom:16px;
  font-weight:400;
  letter-spacing:.02em;
  color:#222;
}

/* Headings inside single posts keep strong weight */
.single-post h1,.single-post h2,.single-post h3,.single-post h4,.single-post h5,.single-post h6{font-family:'Rajdhani',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:400}

.single-post h1 {
font-size: 80px;
}

/* Selected Projects */
.masonry{
  column-width:420px;
  column-gap:24px;
}
.project{
  position:relative;
  display:inline-block;
  width:100%;
  margin:0 0 24px;
  break-inside:avoid;
  overflow:hidden;
  border-radius:4px;
  transition:opacity .25s ease, transform .25s ease;
}
.project.is-hidden{ display:none; } /* beim Filtern aus dem Flow nehmen */

/* Einheitliche Thumbnail-Höhe über Seitenverhältnis + object-fit */
.project figure{
  position: relative;
  aspect-ratio: 3 / 2; /* Desktop */
  overflow: hidden;
  margin: 0;
}
.project img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition:transform .35s ease;
}
@media (max-width: 900px){
  .project figure{ aspect-ratio: 4 / 3; }
}
@media (max-width: 600px){
  .project figure{ aspect-ratio: 1 / 1; }
}

/* Hover Overlay */
.project::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(0,0,0,.0);
  transition:background .35s ease;
  pointer-events:none;
}
.caption-center{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  text-align:center; color:#fff; opacity:0;
  transition:opacity .35s ease;
  padding:0 12px; max-width:90%; z-index:1;
}
.caption-center h3{
  margin:0 0 6px; font-size:20px; font-weight:700; letter-spacing:.04em;
  line-height:1.2; text-transform:uppercase;
}
.caption-center span{ font-size:14px; opacity:.9; line-height:1.3; }
.project:hover::after{ background:rgba(0,0,0,.55); }
.project:hover img{ transform:scale(1.03); }
.project:hover .caption-center{ opacity:1; }
@media (hover:none){
  .project::after{background:rgba(0,0,0,.45);}
  .caption-center{opacity:1;}
  .project img{transform:none;}
}

/* FILTER rechts – textbasiert */
.category-filter{
  position: fixed;
  right:48px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 950;
  text-align: right;
  user-select: none;
}
.category-filter h2{
  font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:10px; margin-top: 0px !important;
}
.category-filter .filter-list{
  list-style:none;
}
.category-filter .filter-option{
  background: transparent;
  border: 0;
  display: block;
  width: 100%;
  padding: 6px 0;
  margin: 2px 0;
  cursor: pointer;
  font-weight:700;
  font-size:16px;
  letter-spacing:.03em;
  text-transform:uppercase;
  text-align: right;
  position: relative;
}
/* Aktiver Marker (dezente Linie rechts) */
.category-filter .filter-option.active::after{
  content:"";
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:24px; height:3px;
  background:#000;
}

/* Abstand zum Footer auf sehr kleinen Screens – unten rechts andocken */
@media (max-width: 768px){
  .category-filter{
    right: 12px;
    top: auto; bottom: 86px; /* über dem Footer */
    transform: none;
    background: rgba(255,255,255,1);
    padding: 6px 16px;
  }
  .category-filter .filter-option{ font-size:14px; }
  .category-filter .filter-option.active::after{ right:12px; }
}

/* Split section (About/Generic) */
.split{display:flex;gap:40px;align-items:flex-start;margin-bottom:60px}
#about-left, .about-intro{flex:1;min-width:0}
#about-left figure{margin:0;width:100%;overflow:hidden;border-radius:4px;height:100%}
#about-left img{width:100%;height:100%;object-fit:cover;display:block}
.about-intro{font-size:19px;line-height:1.7}

.about-content{width:100%}
ul.gear-list{list-style:none;margin:0 0 28px 0;padding:0;columns:2;column-gap:40px}
ul.gear-list li{margin-bottom:10px;font-size:16px;width:50%}

/* Split section Clients */
.clients-wrapper { column-gap: 40px; column-width: 240px;}
.clients-wrapper ul { list-style: none; margin: 0 0 24px 0; padding: 0; break-inside: avoid;}
.clients-wrapper li{ font-size:17px; margin-bottom:10px;}

/* Contact */
.intro-text{font-size:20px;line-height:1.6;margin-bottom:32px}
.split-left,.split-right{flex:1;display:flex;flex-direction:column}
figure{margin:0;flex:1;overflow:hidden;border-radius:4px}
figure img{width:100%;height:100%;object-fit:cover;display:block}

/* Form */
form{margin-top:0;display:flex;flex-direction:column;flex:1}
.form-row{margin-bottom:18px;display:flex;flex-direction:column}
label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
input[type="text"],input[type="email"],textarea{width:100%;padding:10px 12px;font-size:16px;border:1px solid #ccc;border-radius:3px;font-family:'Rajdhani',sans-serif;background:#fafafa;transition:border-color .2s}
input:focus,textarea:focus{outline:none;border-color:#000;background:#fff}
textarea{min-height:160px;resize:vertical}
.btn-submit{appearance:none;border:none;background:#000;color:#fff;padding:12px 24px;font-size:15px;font-family:'Rajdhani',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:opacity .3s;border-radius:3px;align-self:flex-start}
.btn-submit:hover{opacity:.85}
.hidden-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.success-msg,.error-msg{margin-top:20px;font-size:16px;font-weight:700}
.success-msg{color:#0a0}
.error-msg{color:#a00}

/* Projects */
/* CSS‑Masonry Gallery */

.gallery {
column-gap: 16px;
width: 100vw;
margin-left: calc(50% - 50vw);
padding: 16px;
column-count: 6;
}
@media (max-width: 2499px) { .gallery { column-count: 6; } }
@media (max-width: 1499px) { .gallery { column-count: 4; } }
@media (max-width: 1199px) { .gallery { column-count: 3; } }
@media (max-width: 1023px) { .gallery { column-count: 2; } }
@media (max-width: 767px)  { .gallery { column-count: 2; } }
@media (max-width: 599px)  { .gallery { column-count: 2; } }
@media (max-width: 399px)  { .gallery { column-count: 1; } }
.gallery a{
  display:inline-block;
  width:100%;
  margin-bottom:16px;
  overflow:hidden;
  border-radius:4px;
}
.gallery img{
  width:100%;display:block;
  transition:transform .4s,filter .4s;
}
.gallery a:hover img{
  transform:scale(1.05);filter:brightness(.85);
}
@media(max-width:900px){ .gallery{column-count:4;} }
@media(max-width:600px){ .gallery{column-count:2;} }
/* Text Block */
.text-block{
  max-width:700px;margin:40px auto 140px;padding:0 24px;
  text-align:center;line-height:1.6;
}
h2{
  font-size:22px;margin:32px 0 14px;
  text-transform:uppercase;letter-spacing:.05em;font-weight:700;
}
p{font-size:17px;margin-bottom:16px;}
/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.9);
  display:none;align-items:center;justify-content:center;z-index:2000;
}
.lightbox.open{display:flex;}
.lightbox img{
  max-width:90vw;max-height:90vh;
  box-shadow:0 0 20px rgba(0,0,0,.6);
}
.lightbox-close{
  position:fixed;top:24px;right:32px;color:#fff;
  font-size:34px;cursor:pointer;z-index:2100;font-family:Arial,sans-serif;
}
.lightbox-nav{
  position:fixed;top:50%;left:0;right:0;
  display:flex;justify-content:space-between;pointer-events:none;z-index:2100;
}
.lightbox-nav button{
  pointer-events:auto;background:none;border:none;
  color:#fff;font-size:46px;cursor:pointer;
  padding:20px 30px;opacity:.6;transition:opacity .25s;
}
.lightbox-nav button:hover{opacity:1;}

/* Global .post basics */
.post{margin-bottom:36px;position:relative}
.post[aria-hidden="true"]{display:none}
.post figure{margin:0;position:relative;z-index:1}
.post figure a{display:block}

/* Images single source */
.post figure img,
.post-content img,
.post figure img{display:block;width:100%;height:auto;background:#f5f5f5;object-fit:cover;aspect-ratio:var(--aspect-post);border:0}

/* Blog / Archive container consolidated */
.blog .blog-post-container, .blog-post-container{
  background:#fff;
  padding:28px 16px;
  position:relative;
  margin: 0 auto;
  margin-top: calc(-1 * var(--overlap));
  text-align:left;
  z-index:2;
  max-width: 100%;
}
@media(min-width:768px){
  .blog-post-container{padding:42px 36px;max-width:66.66667%;}
}
@media(max-width:768px){
  .blog-post-container{margin:-60px 4% 0;padding:18px}
}

/* Post meta (single) */
.post-meta{font-size:12px;text-transform:uppercase;color:var(--muted);line-height:1;margin-bottom:12px;letter-spacing:.03em}
.post-meta a{color:var(--text);text-decoration:none}
.post-meta a:hover{text-decoration:underline}
.post-meta .time{margin-left:12px;color:var(--muted)}

/* Category link marker */
a[data-cat-link]{text-decoration:none;color:inherit}
a[data-cat-link].active{font-weight:700;text-decoration:underline;color:var(--accent)}

/* Titles / excerpts */
.post-title h3{margin:0 0 20px;font-size:30px;line-height:1.35}
.post-title a{color:var(--text);text-decoration:none}
.post-content p{margin:0;font-size:16px;color:#333;line-height:1.7}

.excerpt-dot{display:inline-block;margin-top:20px;vertical-align:middle}
.excerpt-dot svg{width:30px;height:14px;fill:var(--text)}

/* Pagination */
.pagination{border-top:1px solid #e6e6e6;margin-top:28px;padding-top:24px;text-align:center;text-transform:uppercase}
.pagination a,.pagination span{padding:8px 12px;border:1px solid #ddd;border-radius:6px;text-decoration:none;color:var(--accent);font-size:12px}
.pagination .active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Utility hide */
.is-hidden{display:none !important}

/* Visually hidden */
.visually-hidden{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0 0 0 0) !important;clip-path:inset(50%) !important;white-space:nowrap !important;border:0 !important}

/* Hero */
.hero{position:relative;height:80svh;min-height:60vh;overflow:hidden;z-index:1}
.hero-media{position:absolute;inset:0;transform:translate3d(0,var(--p,0px),0);will-change:transform;pointer-events:none}
.hero-media picture,.hero-media img{display:block;width:100%;height:140svh;object-fit:cover;object-position:center}

/* Full-bleed */
.blog-post-container .full-bleed{width:100vw;margin-left:calc(50% - 50vw) !important;margin-right:calc(50% - 50vw) !important}

/* Media rows (images inside content) */
.post-content .media-row{display:grid;grid-template-columns:1fr;gap:16px;margin:22px 0}
.post-content .media-row.two-up{ /* will be activated with media query below */ }
@media(min-width:720px){ .post-content .media-row.two-up{grid-template-columns:1fr 1fr} }
.post-content .media{margin:0}
.post-content .media picture img{width:100%;height:auto;display:block}
.post-content .media figcaption{font-size:12px;color:#777;margin-top:8px}
.post-content .media-row.no-gap{gap:0}
.post-content .media-row.equal .media picture{display:block;aspect-ratio:3/2;overflow:hidden}
.post-content .media-row.equal .media picture img{width:100%;height:100%;object-fit:cover;object-position:center}

/* CTA */
.cta-work{display:inline-flex;align-items:center;justify-content:center;gap:10px;color:#000;text-decoration:none;font-weight:600}
.cta-work .cta-icon{width:18px;height:18px;display:inline-block;flex:0 0 auto}
.cta-work span{text-decoration:underline}

/* Author box */
.author-box{padding:18px 0;margin:32px 0 22px}
.author-box-inner{display:grid;grid-template-columns:110px 1fr;gap:16px;align-items:center}
@media(min-width:768px){.author-box-inner{grid-template-columns:180px 1fr;gap:20px}}
.author-box .media-figure img{width:100%;height:auto;max-width:180px;aspect-ratio:1/1;object-fit:cover;border-radius:2px;display:block}
.author-box h5{margin:0 0 6px;font-size:16px;text-transform:uppercase;letter-spacing:.06em;font-family:'Rajdhani',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.author-box p{margin:0;font-size:15px;line-height:1.6;color:#222}
.author-box p a{color:#333;font-weight:600;text-decoration:none}
.author-box p a:hover{text-decoration:underline}

.author-icons{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:12px}
.author-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:#fff;color:#111;text-decoration:none;font-weight:600;font-size:14px;transition:background .25s ease,color .25s ease,border-color .25s ease}
.author-btn:hover{background:#111;color:#fff}
.author-btn:hover svg{fill:#fff !important}
.author-btn svg, .author-btn svg *{fill:currentColor !important}

/* Mobile author adjustments */
@media(max-width:560px){
  .author-box-inner{grid-template-columns:1fr}
  .author-box .media-figure img{max-width:120px}
  .author-icons span{display:none}
  .author-icons::before{content:"Contact Me Via";display:block;width:100%;text-transform:uppercase;font-weight:bold;font-family:'Rajdhani',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;margin-top:12px}
}

/* Share / Tags / Post nav */
.share{display:flex;align-items:center;gap:10px;margin-top:18px;flex-wrap:wrap;border-top:1px solid #eee;padding-top:16px}
.share span{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}
.share a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid #ddd;border-radius:50%;color:#111}
.share a:hover{background:#111;border-color:#111}
.share a svg{width:16px;height:16px;fill:#111}
.share a:hover svg{fill:#fff}

.tags{margin-top:18px}
.tag{display:inline-block;padding:6px 10px;font-size:12px;text-transform:uppercase;line-height:1;color:var(--text);border:1px solid var(--text);border-radius:18px;margin:0 6px 6px 0;text-decoration:none}
.tag:hover{background:var(--text);color:#fff}

.post-nav{display:flex;justify-content:space-between;gap:12px;margin-top:28px;padding-top:18px;border-top:1px solid #eee}
.post-nav a{color:var(--accent);text-decoration:none;font-weight:600;text-transform:uppercase;font-size:12px}
.post-nav a:hover{text-decoration:underline}

/* Slider */
.slider{position:relative;display:flex;width:100%;height:100vh;gap:30px;padding:0 30px}
.slider img{width:100%;height:auto;display:block}
@supports(height:100svh){.slider{height:100svh}}
@supports not (height:100svh){.slider{height:calc(var(--vh,1vh)*100)}}
.slider-column{flex:1;overflow:hidden;position:relative}
.slider-track{position:relative;display:flex;flex-direction:column;transition:transform 1s ease-in-out;will-change:transform}
.slider-column.left .slider-track{transform:translateY(-12vh)}
.slider-column.right .slider-track{transform:translateY(calc(-200vh + 12vh))}
.slide{width:100%;height:100vh;flex-shrink:0;margin-bottom:30px}
.slide picture,.slide img{width:100%;height:100%;object-fit:cover;display:block}
.slider-nav{position:absolute;top:50%;right:40px;transform:translateY(-50%);display:flex;flex-direction:column;gap:15px;z-index:10;align-items:flex-end}
.slider-nav .nav-line{display:block;height:2px;width:40px;background:#000;opacity:.6;cursor:pointer;transition:all .4s ease;transform-origin:right center}
.slider-nav .nav-line.active{width:80px;opacity:1}

/* Hamburger / menu overlay */
.hamburger{position:fixed;top:40px;left:40px;width:30px;height:20px;z-index:20;display:flex;flex-direction:column;justify-content:space-between;padding:0;border:0;background:transparent;-webkit-appearance:none;appearance:none}
.hamburger span{width:100%;height:2px;background:#000;border-radius:2px;transition:all .5s cubic-bezier(.77,.2,.05,1)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.hamburger.active span:nth-child(2){opacity:0;transform:translateX(-20px)}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

.menu-overlay{position:fixed;inset:0;height:100vh;background:rgba(0,0,0,.6);display:none;z-index:15;justify-content:flex-start;align-items:flex-start}
.menu-overlay.open{display:flex}
.menu-content{width:300px;height:100%;background:#fff;transform:translateX(-100%);transition:transform .5s ease}
.menu-overlay.open .menu-content{transform:translateX(0)}

/* Menu content typography */
.menu-content ul{list-style:none;padding:100px 40px;margin:0}
.menu-content ul li{margin-bottom:20px}
.menu-content ul li a{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;text-transform:uppercase;text-decoration:none;color:#000;letter-spacing:.05em;transition:color .3s ease}
.menu-content ul li a:hover{color:#666}

/* Footer */
.footer{position:fixed;bottom:20px;left:40px;right:40px;display:flex;justify-content:space-between;align-items:center;font-family:'Rajdhani',sans-serif;font-size:14px;color:#000;z-index:12}
.footer a{text-decoration:none;color:#000;transition:opacity .3s ease}
.footer-left a{margin:0 10px}
.footer a:hover{opacity:.8}
.footer-right a svg{width:16px;height:16px;margin-left:14px;vertical-align:middle}

/* Focus styles (A11y) */
a:focus-visible,button:focus-visible{outline:2px solid #000;outline-offset:2px}

/* Lock scroll when menu open */
body.menu-open{overflow:hidden !important}

/* Safe-area support */
@supports(padding: env(safe-area-inset-top)){
  .hamburger{top:calc(16px + env(safe-area-inset-top));left:calc(16px + env(safe-area-inset-left))}
  .footer{padding-left:calc(40px + env(safe-area-inset-left));padding-right:calc(40px + env(safe-area-inset-right))}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .slider-track,.slider-nav .nav-line,.hamburger span,.menu-content{transition:none !important}
  .hero-media{transform:none !important}
}

/* Breadcrumbs */
.breadcrumbs{font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin:24px 0}
.breadcrumbs a{text-decoration:none;color:#000;opacity:.75}
.breadcrumbs a:hover{opacity:1}
.breadcrumbs span{margin:0 6px;opacity:.5}
.breadcrumbs .current{opacity:1;font-weight:700}

/* Mark small breakpoints together (avoid duplicates) */
@media(max-width:900px){
  .split{flex-direction:column}
  #about-left figure{height:auto}
  #about-left img{height:auto;object-fit:cover}
  ul.gear-list{columns:1}
  .intro-text{font-size:18px}
  figure img{height:auto}
}

@media(max-width:768px){
  body{overflow:auto}
  .blog-post-container{margin:-60px 4% 0;padding:18px}
  .slider{display:block;height:auto;padding:0 15px}
  .slider-column.left{display:none}
  .slider-column.right{width:100%}
  .slider-column.right .slider-track{transform:none!important}
  .slide{height:auto;margin-bottom:16px}
  .slide picture,.slide img{height:auto;object-fit:contain}
  .slider-nav{position:fixed;right:12px;top:50%;transform:translateY(-50%);z-index:999}
  .footer{font-size:12px;bottom:15px;left:20px;right:20px}
}

@media(max-width:600px){
  main{margin-top:60px !important;padding:0 16px 80px !important}
  h1{font-size:42px !important}
}

@media(max-width:560px){
  .author-box-inner{grid-template-columns:1fr}
}

@media(max-width:480px){
  .cta-work{display:block}
  .cta-work .cta-icon{margin-bottom:-5px}
  .author-box span.desktop{display:inline-block}
  .author-box span.mobile{display:none}
}

/* Print */
@media print{
  body{overflow:visible}
  .hamburger,.menu-overlay,.slider-nav{display:none !important}
  .slide{height:auto;margin:0 0 12mm 0;page-break-inside:avoid}
}
