:root{
  --bg:#f7f5f1;
  --text:#111;
  --muted:rgba(17,17,17,.66);
  --line:rgba(17,17,17,.12);
  --dark:#111827;
  --accent:#9f2f2f;
  --accent-soft:#d66b5f;
  --radius:28px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.site-header{z-index:50;border-bottom:1px solid var(--line);background:rgba(247,245,241,.88);backdrop-filter:blur(18px)}
.site-header.fixed{position:fixed;inset:0 0 auto 0}
.site-header.sticky{position:sticky;top:0}
.header-inner{max-width:var(--max);margin:0 auto;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;gap:24px;position:relative}
.brand{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.22em}
.nav{display:flex;gap:30px;font-size:14px;color:var(--muted)}
.nav a:hover{color:var(--text)}
.mobile-nav{display:none;position:relative}
.mobile-nav summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.4);font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}
.mobile-nav summary::-webkit-details-marker{display:none}
.mobile-nav summary::after{content:"☰";font-size:18px;line-height:1;letter-spacing:0}
.mobile-nav[open] summary::after{content:"×";font-size:22px}
.mobile-nav-panel{position:absolute;right:0;top:calc(100% + 14px);min-width:220px;padding:12px;border:1px solid var(--line);border-radius:22px;background:rgba(247,245,241,.98);box-shadow:0 18px 50px rgba(0,0,0,.12);display:grid;gap:4px}
.mobile-nav-panel a{padding:13px 14px;border-radius:14px;color:var(--muted);font-size:15px;font-weight:700}
.mobile-nav-panel a:hover{background:rgba(17,17,17,.06);color:var(--text)}
.section{padding:112px 24px}
.container{max-width:var(--max);margin:0 auto}
.container.narrow{max-width:900px}
.eyebrow{margin:0 0 20px;color:var(--accent);font-size:13px;font-weight:800;letter-spacing:.25em;text-transform:uppercase}
h1,h2,h3,p{margin-top:0}
h1{max-width:1040px;margin-bottom:30px;font-size:clamp(52px,8vw,104px);line-height:.94;letter-spacing:-.07em;hyphens:auto;overflow-wrap:break-word}
h2{max-width:820px;margin-bottom:0;font-size:clamp(38px,5.2vw,68px);line-height:.98;letter-spacing:-.055em;hyphens:auto;overflow-wrap:break-word}
h3{margin-bottom:14px;font-size:30px;line-height:1.05;letter-spacing:-.035em}
.lead{max-width:760px;margin-bottom:36px;color:var(--muted);font-size:22px;line-height:1.6}
.button{display:inline-flex;align-items:center;padding:15px 22px;border-radius:999px;border:0;background:var(--text);color:#fff;font-size:14px;font-weight:800;cursor:pointer;transition:background 180ms ease,transform 180ms ease}
.button:hover{background:var(--accent);transform:translateY(-1px)}
.hero{padding-top:96px;padding-bottom:34px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:32px;align-items:center}
.hero-copy{padding:42px 0}
.hero-photo-wrap{position:relative;margin:0;min-height:clamp(430px,54vh,620px);overflow:hidden;border-radius:var(--radius);background:#111827}
.hero-photo{width:100%;height:clamp(430px,54vh,620px);object-fit:cover;object-position:50% 50%;filter:saturate(.95) contrast(1.02)}
.hero-photo-wrap::after{content:"Echte Arbeit. Echte Umgebung.";position:absolute;left:22px;bottom:22px;padding:9px 14px;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:rgba(0,0,0,.24);color:rgba(255,255,255,.82);font-size:11px;letter-spacing:.22em;text-transform:uppercase;backdrop-filter:blur(8px)}
.intro-box{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:78px 0;display:grid;grid-template-columns:.65fr 1fr;gap:48px}
.intro-text{max-width:900px;margin:0;font-size:clamp(30px,3.8vw,50px);line-height:1.06;letter-spacing:-.045em;font-weight:700}
.section-heading{margin-bottom:64px;display:flex;justify-content:space-between;align-items:end;gap:48px}
.section-heading p:not(.eyebrow){max-width:460px;margin:0;color:var(--muted);font-size:18px;line-height:1.65}
.projects{display:grid;gap:96px}
.project{display:grid;grid-template-columns:.42fr 1fr;gap:44px;align-items:start}
.project-meta{position:sticky;top:112px}
.project-number{margin-bottom:16px;color:rgba(17,17,17,.42);font-size:14px}
.project p{max-width:430px;color:var(--muted);font-size:18px;line-height:1.65}
.project-link{margin-top:22px}
.project-images{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:stretch}
.project-images .project-thumb,.project-images .project-thumb.wide{grid-column:auto;min-height:260px;aspect-ratio:4 / 3}
.project-thumb,.placeholder,.thumb,.portrait-placeholder{position:relative;overflow:hidden;border-radius:var(--radius);background:radial-gradient(circle at 28% 20%,rgba(255,255,255,.18),transparent 30%),linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.02)),#111827}
.project-thumb,.placeholder{min-height:320px}
.project-thumb.wide,.placeholder.wide{grid-column:span 2}
.project-thumb img,.placeholder img,.thumb img,.portrait-placeholder img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.project-thumb::before,.placeholder::before,.thumb::before,.portrait-placeholder::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.34),rgba(0,0,0,0) 48%);z-index:1;pointer-events:none}
.project-thumb::after,.placeholder::after,.thumb::after,.portrait-placeholder::after{position:absolute;left:22px;bottom:22px;padding:9px 14px;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:rgba(0,0,0,.22);color:rgba(255,255,255,.78);font-size:11px;letter-spacing:.2em;text-transform:uppercase;backdrop-filter:blur(8px);z-index:2}
.project-thumb::after,.placeholder::after,.thumb::after{content:attr(data-label)}
.portrait-placeholder{min-height:420px}
.portrait-placeholder::after{content:"Fotografenportrait"}
.all-projects{margin-top:72px;text-align:center}
.dark-section{background:var(--dark);color:#fff}
.dark-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.dark-section .eyebrow{color:var(--accent-soft)}
.service-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.service-card{min-height:126px;padding:26px;border:1px solid rgba(255,255,255,.11);border-radius:22px;background:rgba(255,255,255,.035);font-size:22px;font-weight:700;line-height:1.2;letter-spacing:-.025em}
.service-card span{display:block;margin-bottom:18px;color:var(--accent-soft)}
.process-grid{overflow:hidden;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border:1px solid var(--line);border-radius:32px;background:var(--line)}
.process-card{padding:32px;background:var(--bg)}
.process-card .number{margin-bottom:46px;color:var(--accent);font-weight:800}
.process-card p{margin-bottom:0;color:var(--muted);line-height:1.65}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center;border-top:1px solid var(--line);padding-top:80px}
.about-text{margin-top:32px;color:var(--muted);font-size:18px;line-height:1.7}
.about-text strong{color:var(--text)}
.contact-box{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;padding:56px;border-radius:36px;background:#111;color:#fff}
.contact-box .eyebrow{color:var(--accent-soft)}
.contact-box .lead{color:rgba(255,255,255,.66)}
.form{display:grid;gap:18px}
label span{display:block;margin-bottom:8px;color:rgba(255,255,255,.62);font-size:14px}
input,textarea{width:100%;padding:16px 18px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.06);color:#fff;font:inherit;outline:none}
input:focus,textarea:focus{border-color:var(--accent-soft)}
textarea{resize:vertical}
.contact-hint{margin-top:18px;color:rgba(255,255,255,.55);font-size:14px;line-height:1.6}
.contact-hint a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.button.light{width:fit-content;background:#fff;color:#111}
.button.light:hover{background:var(--accent-soft);color:#fff}
.overview-main,.page-main{padding:96px 24px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card{border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.36);overflow:hidden}
.thumb{min-height:300px}
.card-body{padding:30px}
.number{color:rgba(17,17,17,.4);font-size:14px;margin:0 0 12px}
.card h2{font-size:30px;line-height:1.05;letter-spacing:-.035em;margin:0 0 14px}
.card p,.note{color:var(--muted);font-size:17px;line-height:1.65}
.note{margin-top:60px;max-width:760px;font-size:15px}
.back{display:inline-block;margin-bottom:54px;color:var(--muted);font-size:14px}
.meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:24px;overflow:hidden;margin-bottom:80px}
.meta div{background:var(--bg);padding:24px}
.meta strong{display:block;margin-bottom:8px;font-size:13px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent)}
.project-intro{display:grid;grid-template-columns:.65fr 1fr;gap:48px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:60px 0;margin-bottom:80px}
.project-intro h2,.legal h2{font-size:32px;line-height:1.05;letter-spacing:-.035em;margin:0 0 12px}
.project-intro p,.legal p,.legal li{color:var(--muted);font-size:17px;line-height:1.75;margin:0 0 18px}
.shotlist{margin-bottom:80px}
.shotlist h2{font-size:42px;letter-spacing:-.045em;margin:0 0 32px}
.shotgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.shotcard{border:1px solid var(--line);border-radius:24px;padding:28px;background:rgba(255,255,255,.36)}
.shotcard h3{margin:0 0 14px;font-size:24px;letter-spacing:-.03em}
.shotcard ul{margin:0;padding-left:18px;color:var(--muted);line-height:1.75}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.legal-box{border:1px solid var(--line);border-radius:24px;padding:28px;background:rgba(255,255,255,.36);margin:32px 0}
.site-footer,.footer{border-top:1px solid var(--line);padding:40px 24px;color:rgba(17,17,17,.56);font-size:14px}
.footer-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;gap:24px}
.footer-links{display:flex;gap:24px}
.footer-links a:hover{color:var(--text)}
.page-main .gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:64px 0 80px}
.page-main .gallery:not(:first-of-type) .placeholder.wide{grid-column:auto}
.page-main .gallery:not(:first-of-type) .placeholder{min-height:360px}
.page-main .gallery:first-of-type{margin-top:48px}
.page-main .gallery:first-of-type .placeholder.wide{grid-column:1 / -1;min-height:min(58vw,560px)}
.page-main .gallery:first-of-type .placeholder:not(.wide){min-height:360px}
.page-main .gallery:first-of-type + .project-intro{margin-top:0}
@media(max-width:900px){
  .nav{display:none}
  .mobile-nav{display:block}
  .hero-grid,.intro-box,.project,.dark-grid,.about-grid,.contact-box,.meta,.project-intro,.shotgrid,.gallery{grid-template-columns:1fr}
  .hero-copy{padding:48px 0 24px}
  .hero-photo,.hero-photo-wrap{min-height:520px;height:auto}
  .section-heading{display:block}
  .section-heading p:not(.eyebrow){margin-top:24px}
  .project-meta{position:static}
  .project-images,.service-grid,.process-grid,.grid{grid-template-columns:1fr}
  .project-images .project-thumb,.project-images .project-thumb.wide{aspect-ratio:16 / 10;min-height:300px}
  .project-thumb.wide,.placeholder.wide{grid-column:auto}
  .page-main .gallery{grid-template-columns:1fr;margin:40px 0 64px}
  .page-main .gallery:first-of-type .placeholder.wide,.page-main .gallery:first-of-type .placeholder:not(.wide){grid-column:auto;min-height:360px}
  .contact-box{padding:32px}
  .footer-inner{flex-direction:column}
}
@media(max-width:560px){
  h1{font-size:clamp(40px,12.5vw,52px);line-height:.98;letter-spacing:-.055em;max-width:100%}
  h2{font-size:clamp(34px,10vw,44px);line-height:1;letter-spacing:-.045em;max-width:100%}
  .lead{font-size:21px;line-height:1.55}
  .section{padding:82px 18px}
  .hero{padding:92px 18px 34px}
  .header-inner{padding:18px}
  .brand{letter-spacing:.14em}
  .hero-photo,.hero-photo-wrap{min-height:420px}
  .intro-box{padding:56px 0}
  .overview-main,.page-main{padding:72px 18px}
}
