/* =========================================================
   Da Rugna Hundefotografie — an Brand-System angeglichen
   Farben/Schriften gemäss "Design System.html" der Architektur-Marke.
   ========================================================= */
:root{
  /* Brand-Farben */
  --sumi:#1A1A1A;       /* Text, dunkle Flächen (kein #000) */
  --washi:#FAFAF7;      /* Seitenhintergrund, warmes Weiss */
  --papier:#E8E6E1;     /* Flächen, Karten, Platzhalter */
  --tinte-d:#4A4A4A;    /* sekundärer Text, H3 */
  --tinte-m:#8A8A8A;    /* Meta, Captions, Trennlinien */
  --vermillion:#E34234; /* Akzent — NUR Logo-Punkt, Hover, kritische CTAs */

  /* Schrift */
  --ff-display:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ff-body:"Manrope", -apple-system, system-ui, "Segoe UI", sans-serif;
  --ff-mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
  --ls-label:0.22em;

  /* Layout */
  --maxw:1280px;
  --pad:clamp(1.2rem, 5vw, 4rem);
  --gap:clamp(1.5rem, 4vw, 3.5rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-body);font-weight:400;
  color:var(--sumi);background:var(--washi);
  line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
h1,h2{font-family:var(--ff-display);font-weight:400;line-height:1.12}
h1{font-weight:300;letter-spacing:-0.01em}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-family:var(--ff-body);font-weight:500;font-size:1.05rem;color:var(--tinte-d);letter-spacing:0}
a{color:inherit}

.eyebrow{
  font-family:var(--ff-mono);font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:var(--ls-label);
  color:var(--tinte-m);margin-bottom:1rem;
}
.skip{position:absolute;left:-999px}
.skip:focus{left:1rem;top:1rem;background:var(--sumi);color:#fff;padding:.6rem 1rem;z-index:100}
a:focus-visible,button:focus-visible{outline:2px solid var(--vermillion);outline-offset:3px}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--pad);transition:background .42s,box-shadow .42s;
}
.site-header.scrolled{background:color-mix(in srgb,var(--washi) 90%,transparent);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(138,138,138,.35)}
.brand{text-decoration:none;display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--ff-display);font-size:1.35rem;letter-spacing:.3em;font-weight:500}
.brand__name .dot{color:var(--vermillion)}
.brand__sub{font-family:var(--ff-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.28em;color:var(--tinte-m);margin-top:.4rem}

.nav__toggle{display:none;background:none;border:1px solid var(--tinte-m);padding:.5rem .8rem;font-family:var(--ff-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer}
.nav__list{list-style:none;display:flex;gap:1.7rem;align-items:center}
.nav__list a{text-decoration:none;font-size:.8rem;letter-spacing:.04em;color:var(--sumi);opacity:.82;transition:opacity .24s,color .24s}
.nav__list a:hover{opacity:1;color:var(--vermillion)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;text-decoration:none;font-family:var(--ff-body);
  font-size:.78rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  padding:.9rem 1.7rem;border:1px solid transparent;cursor:pointer;transition:.24s;
}
.btn--primary{background:var(--sumi);color:var(--washi)}
.btn--primary:hover{background:var(--vermillion)}
.btn--ghost{border-color:currentColor}
.btn--ghost:hover{color:var(--vermillion)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:var(--hero-h,100svh);display:flex;align-items:flex-end;color:#fff}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.84)}
.hero__inner{position:relative;padding:var(--pad);padding-bottom:clamp(3rem,9vh,7rem);max-width:780px}
.hero .eyebrow{color:rgba(255,255,255,.92)}
.hero__title{font-family:var(--ff-display);font-weight:300;font-size:clamp(2.7rem,7vw,5.2rem);line-height:1.04;letter-spacing:-0.01em;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero__lead{font-weight:300;font-size:clamp(1rem,2vw,1.2rem);margin:1.3rem 0 2rem;max-width:48ch;text-shadow:0 1px 18px rgba(0,0,0,.4)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero .btn--ghost{color:#fff}
.hero .btn--ghost:hover{color:#fff;background:rgba(255,255,255,.12)}

/* ---------- Sections ---------- */
section{padding:clamp(3.5rem,9vw,7rem) var(--pad)}
.section-head{max-width:var(--maxw);margin:0 auto clamp(2rem,5vw,3.5rem)}
.section-head p:last-child{color:var(--tinte-d);max-width:55ch;margin-top:.9rem;font-weight:300}

/* Intro */
.intro{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:var(--gap);align-items:center}
.intro p{max-width:50ch;font-weight:300;color:var(--tinte-d)}
.intro h2{margin-bottom:1rem}
.ticks{list-style:none;margin-top:1.5rem;display:grid;gap:.7rem}
.ticks li{padding-left:1.6rem;position:relative;color:var(--tinte-d);font-weight:300}
.ticks li::before{content:"";position:absolute;left:0;top:.65em;width:6px;height:6px;background:var(--vermillion)}
.intro__fig img{width:100%}

/* Kategorien */
.cats{background:var(--papier)}
.cat-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:var(--gap)}
.cat__img{aspect-ratio:4/5;overflow:hidden;background:#dcd6cc}
.cat__img img{width:100%;height:100%;object-fit:cover;transition:transform .64s cubic-bezier(.2,.6,.2,1)}
.cat:hover .cat__img img{transform:scale(1.04)}
.cat__img--placeholder{display:grid;place-items:center;background:repeating-linear-gradient(45deg,#e2dcd2,#e2dcd2 12px,#dcd5c9 12px,#dcd5c9 24px)}
.cat__img--placeholder span{font-family:var(--ff-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--tinte-m)}
.cat h3{margin:1.1rem 0 .35rem;color:var(--sumi)}
.cat p{color:var(--tinte-d);font-size:.92rem;font-weight:300}

/* Looks */
.looks__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap)}
.look{padding:2rem 1.7rem;border:1px solid var(--tinte-m);background:var(--washi)}
.look h3{margin-bottom:.6rem;color:var(--sumi)}
.look p{color:var(--tinte-d);font-size:.92rem;font-weight:300}

/* Galerie CTA */
.gallery-cta{background:var(--sumi);color:var(--washi);text-align:center}
.gallery-cta__inner{max-width:680px;margin:0 auto}
.gallery-cta h2{color:var(--washi)}
.gallery-cta p{color:#cfc8bf;margin:1.1rem auto 2rem;max-width:48ch;font-weight:300}
.gallery-cta .btn--primary{background:var(--washi);color:var(--sumi)}
.gallery-cta .btn--primary:hover{background:var(--vermillion);color:var(--washi)}

/* About */
.about{max-width:var(--maxw);margin:0 auto}
.about__text{max-width:62ch}
.about h2{margin-bottom:1rem}
.about p{color:var(--tinte-d);margin-top:1rem;font-weight:300}

/* Kontakt */
.contact{text-align:center}
.contact .section-head{margin-inline:auto}
.contact__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Footer */
.site-footer{padding:2.6rem var(--pad);border-top:1px solid var(--tinte-m);display:flex;flex-direction:column;gap:.6rem;align-items:center;text-align:center}
.site-footer .brand__name{font-family:var(--ff-display);font-size:1.2rem;letter-spacing:.3em}
.site-footer .dot{color:var(--vermillion)}
.site-footer p{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tinte-m)}

/* Responsive */
@media (max-width:900px){
  .intro{grid-template-columns:1fr}
  .nav__toggle{display:block}
  .nav__list{
    position:absolute;top:100%;right:var(--pad);left:var(--pad);
    flex-direction:column;align-items:flex-start;gap:1.2rem;
    background:var(--washi);border:1px solid var(--tinte-m);
    padding:1.4rem;box-shadow:0 12px 40px rgba(0,0,0,.12);display:none;
  }
  .nav__list.open{display:flex}
}
/* Footer-Rechtslinks */
.site-footer .footer-legal{display:flex;gap:1.4rem;margin-top:.3rem}
.site-footer .footer-legal a{font-family:var(--ff-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--tinte-m);text-decoration:none}
.site-footer .footer-legal a:hover{color:var(--vermillion)}

/* Legal-Seiten (Impressum, Datenschutz) */
.legal{max-width:780px;margin:0 auto;padding-top:clamp(6.5rem,13vh,9.5rem)}
.legal h1{font-family:var(--ff-display);font-weight:300;font-size:clamp(2rem,5vw,3rem);letter-spacing:-0.01em;margin:.8rem 0 1.2rem}
.legal h2{font-size:1.35rem;margin:2.2rem 0 .6rem;color:var(--sumi)}
.legal p,.legal li{color:var(--tinte-d);font-weight:300;margin-bottom:.6rem}
.legal ul{padding-left:1.2rem;margin-bottom:.6rem}
.legal a{color:var(--sumi);text-decoration:underline;text-underline-offset:3px}
.legal a:hover{color:var(--vermillion)}
.legal .updated{font-family:var(--ff-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--tinte-m);margin-top:2.6rem}
.back-link{display:inline-block;font-family:var(--ff-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--tinte-m);text-decoration:none}
.back-link:hover{color:var(--vermillion)}

/* =========================================================
   Homepage v2 – Split-Hero, Portfolio-Reihe, About, Services, Artworks, Testimonials
   ========================================================= */
.site-header.solid{background:color-mix(in srgb,var(--washi) 92%,transparent);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(138,138,138,.3)}
.nav{flex:1;display:flex;justify-content:center;align-items:center;position:static}
.header-cta{padding:.72rem 1.25rem;font-size:.7rem;white-space:nowrap}

/* Hero Split */
.hero-split{display:grid;grid-template-columns:1.05fr 1fr;min-height:100svh}
.hero-split__text{display:flex;flex-direction:column;justify-content:center;padding:6.5rem var(--pad) 3.5rem;position:relative}
.hero-split__text h1{font-family:var(--ff-display);font-weight:300;font-size:clamp(2.6rem,5.5vw,4.6rem);line-height:1.04;letter-spacing:-0.01em;margin:.5rem 0 1.1rem}
.hero-split .lead{font-family:var(--ff-display);font-style:italic;font-weight:400;font-size:clamp(1.1rem,1.8vw,1.45rem);line-height:1.4;color:var(--tinte-d);max-width:32ch}
.hero-split__cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.7rem}
.hero-split__media{position:relative;background:var(--papier);overflow:hidden}
.hero-split__media img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}
.badge{position:absolute;right:1.4rem;bottom:1.4rem;width:94px;height:94px;border-radius:50%;border:1px solid rgba(255,255,255,.85);color:#fff;display:grid;place-items:center;text-align:center;font-family:var(--ff-mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;line-height:1.5;background:rgba(26,26,26,.42);backdrop-filter:blur(2px)}
.social-rail{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;list-style:none;display:flex;gap:1.3rem;align-items:center;font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase}
.social-rail span{color:var(--tinte-m)}
.social-rail a{color:var(--tinte-m);text-decoration:none}
.social-rail a:hover{color:var(--vermillion)}

/* Placeholder-Flächen */
.ph{display:grid;place-items:center;background:repeating-linear-gradient(45deg,#e6e0d6,#e6e0d6 14px,#e0dacf 14px,#e0dacf 28px)}
.ph span{font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--tinte-m)}
.ph--portrait{aspect-ratio:4/5;border-radius:2px}
.ph--wide{aspect-ratio:16/10;min-height:260px;border-radius:2px}

/* Portfolio-Reihe */
.rowfolio{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:var(--gap);align-items:center;max-width:1500px;margin:0 auto;padding:clamp(3rem,7vw,5.5rem) var(--pad)}
.rowfolio__intro h2{margin:.5rem 0 .8rem}
.rowfolio__tags{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tinte-m);margin-bottom:1.1rem}
.rowfolio__track{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.6rem;scroll-snap-type:x mandatory}
.rowfolio__track img{height:clamp(280px,38vh,420px);aspect-ratio:4/5;width:auto;object-fit:cover;flex:0 0 auto;scroll-snap-align:start;border-radius:2px}

/* About Split */
.about-split{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--gap);align-items:center;max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,8vw,6rem) var(--pad)}
.about-split__text h2{margin-bottom:1rem}
.about-split__text p{color:var(--tinte-d);font-weight:300;margin-bottom:.9rem;max-width:52ch}
blockquote.pull{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.3;color:var(--sumi);border-left:2px solid var(--vermillion);padding-left:1.1rem;margin-top:1.5rem}

/* Services Band */
.services{background:var(--papier);padding-block:clamp(3.5rem,8vw,6rem);padding-inline:max(var(--pad),calc((100% - var(--maxw))/2))}
.services__head{margin-bottom:2.4rem}
.services__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--gap);align-items:stretch}
.services__list{list-style:none}
.service{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 0;border-top:1px solid var(--tinte-m);font-family:var(--ff-display);font-size:clamp(1.2rem,2vw,1.5rem);color:var(--sumi)}
.service:last-child{border-bottom:1px solid var(--tinte-m)}
.service__arrow{color:var(--vermillion);font-family:var(--ff-body);font-size:1rem;transition:transform .24s}
.service:hover .service__arrow{transform:translateX(5px)}
.cta-card{background:var(--sumi);color:var(--washi);padding:2.2rem;display:flex;flex-direction:column;gap:1rem;justify-content:center}
.cta-card .eyebrow{color:var(--vermillion)}
.cta-card p{color:#cfc8bf;font-weight:300}
.cta-card .btn{background:var(--washi);color:var(--sumi);align-self:flex-start}
.cta-card .btn:hover{background:var(--vermillion);color:var(--washi)}

/* Creative Artworks */
.artworks{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--gap);align-items:center;max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,8vw,6rem) var(--pad)}
.artworks__text p{color:var(--tinte-d);font-weight:300;margin-top:1rem;max-width:46ch}

/* Testimonials */
.testimonials{max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,8vw,6rem) var(--pad);border-top:1px solid var(--tinte-m)}
.eyebrow--center{text-align:center;margin-bottom:2.4rem}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.testi{margin:0}
.testi p{font-family:var(--ff-display);font-style:italic;font-size:1.22rem;line-height:1.4;color:var(--sumi);margin-bottom:1rem}
.testi cite{font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:var(--tinte-m);font-style:normal}

/* Überlauf-Sicherung (Grid/Flex-Kinder dürfen schrumpfen, Text bricht um) */
.hero-split__text,.about-split__text,.artworks__text,.rowfolio__intro,.testi,.services__grid>*{min-width:0}
.hero-split .lead,.about-split__text p,.artworks__text p,.testi p,.service{overflow-wrap:break-word}

/* Responsive v2 */
@media (max-width:900px){
  .hero-split{grid-template-columns:1fr;min-height:auto}
  .hero-split__text{padding-top:7rem;order:2}
  .hero-split__media{order:1;height:clamp(340px,52svh,520px)}
  .social-rail{display:none}
  .header-cta{display:none}
  .nav{flex:0;justify-content:flex-end}
  .rowfolio,.about-split,.services__grid,.artworks,.testi-grid{grid-template-columns:1fr}
  .rowfolio__track{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;overflow:visible}
  .rowfolio__track img{width:100%;height:auto;aspect-ratio:4/5}
  .testi-grid{gap:2rem}
}

@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}
