/* ============================================================
   THEME 02 — BRUTALIST / RAW
   ------------------------------------------------------------
   Holz trifft Beton. Sichtbare 3px-Ränder, harte Schlagschatten,
   Mono-Schrift, Safety-Orange, Laufband, gestempelte Labels,
   leicht verdrehte Blöcke. Nichts ist weichgespült.
   ============================================================ */

body[data-theme="brutalist"] {
  /* --- Tokens --- */
  --c-bg:         #eceae3;
  --c-surface:    #dcd9cf;
  --c-ink:        #0c0c0c;
  --c-ink-soft:   #55534d;
  --c-accent:     #ff4d00;
  --c-accent-ink: #0c0c0c;
  --c-line:       #0c0c0c;

  --font-display: "Archivo Black", sans-serif;
  --font-body:    "IBM Plex Mono", monospace;

  --radius-img:   0;
  --btn-radius:   0;
  --container:    1400px;
  --ease:         cubic-bezier(.6, 0, .2, 1);
  --dur:          .45s;

  --bru-border:   3px solid var(--c-ink);
  --bru-shadow:   8px 8px 0 var(--c-ink);

  cursor: crosshair;
  font-size: 15px;
}
/* Beton-Körnung über allem (SVG-Noise, sehr dezent) */
body[data-theme="brutalist"]::after {
  content: ""; position: fixed; inset: 0; z-index: 950;
  pointer-events: none; opacity: .06;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}
body[data-theme="brutalist"] a,
body[data-theme="brutalist"] button { cursor: crosshair; }

/* Reveals: hart und schnell, kein sanftes Gleiten */
body[data-theme="brutalist"] [data-reveal] { transform: translate(8px, 14px); }
body[data-theme="brutalist"] [data-reveal].is-revealed { transform: none; }

/* ---------- Header ---------- */
body[data-theme="brutalist"] .site-header {
  background: var(--c-bg);
  border-bottom: var(--bru-border);
}
body[data-theme="brutalist"] .brand__name {
  font-family: var(--font-display);
  text-transform: uppercase;
}
body[data-theme="brutalist"] .brand__sub { letter-spacing: .1em; }
body[data-theme="brutalist"] .main-nav__link {
  border: 2px solid var(--c-ink);
  padding: .45em .8em;
  font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
  transition: background-color .15s steps(2), color .15s steps(2),
              box-shadow .15s, transform .15s;
}
body[data-theme="brutalist"] .main-nav__link:hover {
  background: var(--c-ink); color: var(--c-bg);
  box-shadow: 4px 4px 0 var(--c-accent);
  transform: translate(-2px, -2px);
}
body[data-theme="brutalist"] .theme-btn { border: 2px solid var(--c-ink); color: var(--c-ink); }
body[data-theme="brutalist"] .theme-btn[aria-pressed="true"] {
  background: var(--c-accent); color: var(--c-accent-ink);
  box-shadow: 3px 3px 0 var(--c-ink);
}
body[data-theme="brutalist"] .theme-switcher__label { color: var(--c-ink); font-weight: 700; }

/* ---------- Hero: gestapelte Brocken ---------- */
body[data-theme="brutalist"] .hero {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap: clamp(1.5rem, 3vw, 3rem);
  align-content: center; align-items: center;
}
body[data-theme="brutalist"] .hero__kicker {
  display: inline-block; justify-self: start;
  border: var(--bru-border);
  background: var(--c-bg);
  padding: .5em .9em;
  font-size: .72rem; text-transform: uppercase; letter-spacing: .1em;
  box-shadow: var(--bru-shadow);
  margin-bottom: 2.2rem;
}
body[data-theme="brutalist"] .hero__title {
  font-size: clamp(3.6rem, 11vw, 10rem);
  text-transform: uppercase;
  line-height: .92; letter-spacing: -.01em;
}
/* Zeile 1: massiv schwarz / Zeile 2: nur Kontur / Zeile 3: Orange-Block */
body[data-theme="brutalist"] .hero__line:nth-child(2) .hero__word {
  color: transparent;
  -webkit-text-stroke: 3px var(--c-ink);
  margin-left: .6em;
}
body[data-theme="brutalist"] .hero__line:nth-child(3) .hero__word {
  background: var(--c-accent); color: var(--c-ink);
  padding: 0 .12em;
  box-shadow: var(--bru-shadow);
}
body[data-theme="brutalist"] .hero__claim {
  margin-top: 2.4rem;
  max-width: 42ch; font-size: .92rem;
  border-left: var(--bru-border);
  padding-left: 1.2rem;
}
body[data-theme="brutalist"] .hero__actions { margin-top: 1.6rem; }

body[data-theme="brutalist"] .hero__media {
  position: relative;
  aspect-ratio: 1;
  border: var(--bru-border);
  box-shadow: var(--bru-shadow);
  transform: rotate(2deg);
  transition: transform .25s var(--ease);
}
body[data-theme="brutalist"] .hero__media:hover { transform: rotate(0deg) scale(1.01); }
body[data-theme="brutalist"] .hero__media img { filter: contrast(1.12) saturate(.92); }
body[data-theme="brutalist"] .hero__media-caption {
  position: absolute; left: -3px; bottom: -3px;
  background: var(--c-ink); color: var(--c-bg);
  padding: .5em .8em;
  font-size: .66rem; text-transform: uppercase; letter-spacing: .12em;
}
/* "EST. 1987"-Stempel */
body[data-theme="brutalist"] .hero__deco {
  position: absolute; top: 16vh; right: clamp(1rem, 4vw, 4rem);
  width: 110px; height: 110px;
  border: var(--bru-border); border-radius: 50%;
  display: grid; place-items: center;
  transform: rotate(-12deg);
  font-family: var(--font-body); font-weight: 700;
  font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
  background: var(--c-bg); z-index: 3;
  animation: bru-spin 14s linear infinite;
}
body[data-theme="brutalist"] .hero__deco::before { content: "EST.\A 1987"; white-space: pre; text-align: center; }
@keyframes bru-spin {
  0%, 46%  { transform: rotate(-12deg); }
  50%, 96% { transform: rotate(8deg); }
  100%     { transform: rotate(-12deg); }
}
body[data-theme="brutalist"] .hero__scroll-hint {
  left: clamp(1.25rem, 5vw, 4rem);
  border: 2px solid var(--c-ink);
  padding: .4em .7em; color: var(--c-ink);
}

/* ---------- Laufband ---------- */
body[data-theme="brutalist"] .ticker {
  display: block;
  border-top: var(--bru-border); border-bottom: var(--bru-border);
  background: var(--c-accent); color: var(--c-ink);
}
body[data-theme="brutalist"] .ticker__track {
  font-family: var(--font-display);
  text-transform: uppercase; font-size: 1.1rem;
}

/* ---------- Buttons ---------- */
body[data-theme="brutalist"] .btn {
  border: var(--bru-border);
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  font-size: .76rem;
  box-shadow: 5px 5px 0 var(--c-ink);
}
body[data-theme="brutalist"] .btn--primary { background: var(--c-accent); color: var(--c-ink); }
body[data-theme="brutalist"] .btn--ghost   { background: var(--c-bg); }
body[data-theme="brutalist"] .btn:hover {
  transform: translate(5px, 5px);
  box-shadow: 0 0 0 var(--c-ink);
}

/* ---------- Sektionsköpfe: Stempel + Brocken ---------- */
body[data-theme="brutalist"] .section-head { position: relative; }
body[data-theme="brutalist"] .section-head__index {
  font-family: var(--font-display);
  font-size: clamp(4rem, 9vw, 8rem);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px var(--c-ink);
  position: absolute; right: 0; top: -0.2em;
  opacity: .55; pointer-events: none;
}
body[data-theme="brutalist"] .section-head__label {
  background: var(--c-ink); color: var(--c-bg);
  padding: .5em .9em;
  font-size: .72rem; text-transform: uppercase; letter-spacing: .14em;
  transform: rotate(-1.5deg);
  box-shadow: 4px 4px 0 var(--c-accent);
}
body[data-theme="brutalist"] .section-head__title {
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  text-transform: uppercase; margin-top: .5em;
}
body[data-theme="brutalist"] .section-head__title em {
  font-style: normal;
  background: var(--c-accent); padding: 0 .1em;
}
body[data-theme="brutalist"] .section-head__desc { font-size: .9rem; margin-top: 1em; }

/* ---------- Leistungen: 2×2-Zellenblock ---------- */
body[data-theme="brutalist"] .services__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border: var(--bru-border);
  box-shadow: var(--bru-shadow);
  background: var(--c-bg);
}
body[data-theme="brutalist"] .service-card {
  padding: 2rem 1.8rem 2.2rem;
  display: flex; flex-direction: column; gap: 1rem;
  position: relative;
  transition: background-color .15s steps(2), color .15s steps(2);
}
body[data-theme="brutalist"] .service-card:nth-child(1) { border-right: var(--bru-border); border-bottom: var(--bru-border); }
body[data-theme="brutalist"] .service-card:nth-child(2) { border-bottom: var(--bru-border); }
body[data-theme="brutalist"] .service-card:nth-child(3) { border-right: var(--bru-border); }
body[data-theme="brutalist"] .service-card:hover { background: var(--c-ink); color: var(--c-bg); }
body[data-theme="brutalist"] .service-card:hover .service-card__text { color: var(--c-bg); }
body[data-theme="brutalist"] .service-card__index {
  position: absolute; top: 1.2rem; right: 1.4rem;
  font-size: .72rem; font-weight: 700;
}
body[data-theme="brutalist"] .service-card__index::before { content: "Nr. "; }
body[data-theme="brutalist"] .service-card__icon { width: 52px; color: var(--c-accent); }
body[data-theme="brutalist"] .service-card__icon svg { stroke-width: 2.6; }
body[data-theme="brutalist"] .service-card__title {
  font-size: 1.25rem; text-transform: uppercase;
}
body[data-theme="brutalist"] .service-card__text { font-size: .84rem; color: var(--c-ink-soft); flex: 1; }
body[data-theme="brutalist"] .service-card__link {
  font-size: .74rem; font-weight: 700; text-transform: uppercase;
  text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px;
  display: inline-flex; gap: .5em;
}
body[data-theme="brutalist"] .service-card__link:hover { color: var(--c-accent); }

/* ---------- Projekte: rohe Kacheln, leicht verdreht ---------- */
body[data-theme="brutalist"] .projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem) clamp(1.5rem, 3vw, 2.5rem);
}
body[data-theme="brutalist"] .project {
  border: var(--bru-border);
  background: var(--c-bg);
  box-shadow: var(--bru-shadow);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
body[data-theme="brutalist"] .project:nth-child(odd)  { transform: rotate(-1deg); }
body[data-theme="brutalist"] .project:nth-child(even) { transform: rotate(1deg) translateY(1.2rem); }
body[data-theme="brutalist"] .project:hover {
  transform: rotate(0) translateY(0) !important;
  box-shadow: 12px 12px 0 var(--c-accent);
  z-index: 2; position: relative;
}
body[data-theme="brutalist"] .project__media { aspect-ratio: 1; border-bottom: var(--bru-border); }
body[data-theme="brutalist"] .project__media img { filter: contrast(1.1) saturate(.92); }
body[data-theme="brutalist"] .project__meta {
  padding: .9rem 1rem 1rem;
  grid-template-columns: 1fr auto;
  align-items: start;
}
body[data-theme="brutalist"] .project__title {
  font-size: .95rem; text-transform: uppercase; grid-column: 1;
}
body[data-theme="brutalist"] .project__cat { font-size: .7rem; grid-column: 1; }
body[data-theme="brutalist"] .project__year {
  grid-column: 2; grid-row: 1 / 3; align-self: start;
  background: var(--c-ink); color: var(--c-bg);
  font-size: .7rem; padding: .35em .55em; font-weight: 700;
}

/* ---------- Werkstatt ---------- */
body[data-theme="brutalist"] .about__layout {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: start;
}
body[data-theme="brutalist"] .about__fig--1 {
  aspect-ratio: 3 / 4;
  border: var(--bru-border); box-shadow: var(--bru-shadow);
  transform: rotate(-1.5deg);
}
body[data-theme="brutalist"] .about__fig--2 {
  aspect-ratio: 1; width: 58%;
  border: var(--bru-border); box-shadow: 8px 8px 0 var(--c-accent);
  margin: -18% 0 0 auto;
  transform: rotate(2deg);
  position: relative; z-index: 2;
}
body[data-theme="brutalist"] .about__lead {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.2vw, 1.7rem);
  text-transform: uppercase; line-height: 1.25;
  margin-bottom: 1.2em;
}
body[data-theme="brutalist"] .about__body > p:not(.about__lead) { font-size: .9rem; }
body[data-theme="brutalist"] .about__quote {
  background: var(--c-accent);
  border: var(--bru-border);
  box-shadow: var(--bru-shadow);
  padding: 1.4rem 1.6rem;
  margin: 2rem 0;
  transform: rotate(-1deg);
}
body[data-theme="brutalist"] .about__quote p { font-weight: 700; font-size: 1rem; margin-bottom: .4em; }
body[data-theme="brutalist"] .about__quote cite { color: var(--c-ink); }
body[data-theme="brutalist"] .about__stats {
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border: var(--bru-border);
  margin-top: 2.4rem;
  background: var(--c-bg);
}
body[data-theme="brutalist"] .stat { padding: 1.1rem 1.2rem; }
body[data-theme="brutalist"] .stat:nth-child(1) { border-right: var(--bru-border); border-bottom: var(--bru-border); }
body[data-theme="brutalist"] .stat:nth-child(2) { border-bottom: var(--bru-border); }
body[data-theme="brutalist"] .stat:nth-child(3) { border-right: var(--bru-border); }
body[data-theme="brutalist"] .stat__value { color: var(--c-accent); -webkit-text-stroke: 1px var(--c-ink); }

/* ---------- Kontakt ---------- */
body[data-theme="brutalist"] .contact {
  border-top: var(--bru-border);
}
body[data-theme="brutalist"] .contact__title {
  font-size: clamp(2.6rem, 8vw, 7rem);
  text-transform: uppercase; line-height: .95;
  max-width: 13ch;
}
body[data-theme="brutalist"] .contact__title em {
  font-style: normal; background: var(--c-accent); padding: 0 .08em;
}
body[data-theme="brutalist"] .contact__desc { margin-top: 1.6rem; max-width: 46ch; font-size: .92rem; }
body[data-theme="brutalist"] .contact__actions { margin-top: 2rem; }
body[data-theme="brutalist"] .contact__details {
  margin-top: 3.5rem;
  grid-template-columns: repeat(4, 1fr); gap: 0;
  border: var(--bru-border);
  box-shadow: var(--bru-shadow);
  background: var(--c-bg);
  font-size: .82rem;
}
body[data-theme="brutalist"] .contact__detail { padding: 1.1rem 1.2rem; }
body[data-theme="brutalist"] .contact__detail:not(:last-child) { border-right: var(--bru-border); }
body[data-theme="brutalist"] .contact__detail-label { color: var(--c-accent); font-weight: 700; }

/* ---------- Footer ---------- */
body[data-theme="brutalist"] .site-footer {
  background: var(--c-ink); color: var(--c-bg);
  border-top: 6px solid var(--c-accent);
}
body[data-theme="brutalist"] .footer__nav a,
body[data-theme="brutalist"] .footer__legal a {
  font-size: .74rem; text-transform: uppercase;
  text-decoration: underline; text-underline-offset: 4px;
}
body[data-theme="brutalist"] .footer__nav a:hover { color: var(--c-accent); }
body[data-theme="brutalist"] .footer__meta { color: #8c8a84; }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  body[data-theme="brutalist"] .projects__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  body[data-theme="brutalist"] .hero { grid-template-columns: 1fr; }
  body[data-theme="brutalist"] .hero__media { max-width: 480px; margin-top: 2.5rem; }
  body[data-theme="brutalist"] .hero__deco { display: none; }
  body[data-theme="brutalist"] .about__layout { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  body[data-theme="brutalist"] .services__grid { grid-template-columns: 1fr; }
  body[data-theme="brutalist"] .service-card { border-right: 0 !important; border-bottom: var(--bru-border); }
  body[data-theme="brutalist"] .service-card:last-child { border-bottom: 0; }
  body[data-theme="brutalist"] .projects__grid { grid-template-columns: 1fr; }
  body[data-theme="brutalist"] .project:nth-child(even) { transform: rotate(1deg); }
  body[data-theme="brutalist"] .contact__details { grid-template-columns: 1fr; }
  body[data-theme="brutalist"] .contact__detail { border-right: 0 !important; }
  body[data-theme="brutalist"] .contact__detail:not(:last-child) { border-bottom: var(--bru-border); }
}
