/* =============================================================================
   Tischlerei Haas — LMF003 (Küche) — Design nach echtem CI
   Quelle: Designguide + /CI/ (T_HASS_COLORS) + Live-Sampling info.tischlereihaas.at
   Palette: Navy #0A121E · Limettengrün #B9D347 · Weiß. Buttons eckig, DIN-Schrift.
   ============================================================================= */
/* ---- Hausschrift DIN (Dateien in /assets/fonts/, siehe Deploy-Hinweis) ---- */
@font-face { font-family:"DIN Web"; src:url("/assets/fonts/DIN-Regular.ttf") format("truetype"); font-weight:400; font-display:swap; }
@font-face { font-family:"DIN Web"; src:url("/assets/fonts/DIN-Medium.otf") format("opentype"); font-weight:600; font-display:swap; }
@font-face { font-family:"DIN Web"; src:url("/assets/fonts/DIN-Bold.otf") format("opentype"); font-weight:700; font-display:swap; }
@font-face { font-family:"DIN Web"; src:url("/assets/fonts/DIN-Black.ttf") format("truetype"); font-weight:800; font-display:swap; }

:root {
  --green:      #b9d347;   /* Marken-Akzent (rgb 185,211,71) */
  --green-2:    #cbe072;   /* helleres Grün */
  --green-deep: #a3bd30;   /* Hover */
  --navy:       #0a121e;   /* Basis-Hintergrund (rgb 10,18,30) */
  --navy-2:     #111c2b;   /* Sektion alternativ */
  --panel:      #16212f;   /* Karten / Panels */
  --panel-2:    #1c2937;   /* Inputs */
  --darkest:    #070d16;   /* dunkelste Sektion / Topbar / Footer */
  --text:       #e9edf2;   /* Fließtext auf dunkel */
  --muted:      #9fadbd;   /* gedämpft */
  --border:     #27333f;
  --white:      #ffffff;

  /* Legacy-Aliasse — von Inline-Styles referenziert, damit nichts bricht */
  --holz: var(--green); --holz-dark: var(--green-deep); --holz-soft: var(--green-2);
  --tinte: var(--text); --tinte-2: var(--muted);
  --creme: var(--navy); --creme-2: var(--navy-2); --sand: var(--panel);
  --weiss: var(--white); --linie: var(--border); --gruen: var(--green); --ok: var(--green);

  --radius: 0px;
  --maxw: 880px;
  --schatten: 0 2px 12px rgba(0,0,0,.35);
  --font: "DIN Web", "DIN Next", "DIN", -apple-system, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--font);
  color: var(--text); background: var(--navy);
  line-height: 1.6; font-size: 18px; -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--green); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }
.wrap-narrow { max-width: 680px; margin: 0 auto; padding: 0 22px; }

/* Überschriften wie Original: DIN Bold (700), Großbuchstaben aus Content-Optik, normaler Abstand */
h1, h2, h3 { line-height: 1.15; font-weight: 700; margin: 0 0 .5em; color: var(--white); }
h1 { font-size: clamp(30px, 5vw, 44px); text-transform: uppercase; letter-spacing: normal; }
h2 { font-size: clamp(23px, 3.6vw, 34px); text-transform: uppercase; letter-spacing: normal; }
h3 { font-size: clamp(18px, 2.3vw, 22px); }
h1 em, h2 em { color: var(--green); font-style: normal; }
p { margin: 0 0 1em; }
.lead { font-size: clamp(19px, 2.4vw, 23px); color: var(--muted); }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: 13px; font-weight: 700; color: var(--green); margin: 0 0 12px; }
.muted { color: var(--muted); }
.center { text-align: center; }

/* ---- Kopf / Logo ------------------------------------------------------ */
.topbar { background: var(--darkest); border-bottom: 1px solid var(--border); }
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; padding: 14px 22px; }
.brand {
  display: inline-block; width: 108px; height: 34px;
  background: url("/assets/img/logo-haas-green-220.png") left center / contain no-repeat;
  text-indent: -9999px; overflow: hidden; white-space: nowrap;
}
.brand small { display: none; }
.topbar .phone { color: var(--muted); text-decoration: none; font-size: 15px; }

/* ---- Sektionen -------------------------------------------------------- */
section { padding: clamp(46px, 7vw, 84px) 0; }
section.tight { padding: clamp(28px, 4vw, 46px) 0; }
.bg-creme2 { background: var(--navy-2); }
.bg-sand { background: var(--panel); }
.bg-tinte { background: var(--darkest); }
.bg-tinte h1, .bg-tinte h2, .bg-tinte h3 { color: var(--white); }
.bg-tinte .lead, .bg-tinte p { color: var(--muted); }

/* ---- Buttons (eckig, grün, dunkle Schrift, uppercase) ----------------- */
.btn {
  display: inline-block; background: var(--green); color: var(--darkest); text-decoration: none;
  font-weight: 800; font-size: 17px; text-transform: uppercase; letter-spacing: .04em;
  padding: 16px 30px; border-radius: 0; border: 0; cursor: pointer;
  transition: background .15s ease, transform .05s ease; text-align: center; font-family: inherit;
}
.btn:hover { background: var(--green-deep); }
.btn:active { transform: translateY(1px); }
.btn-lg { font-size: 19px; padding: 18px 40px; }
.btn::after { content: " →"; }
.btn-ghost { background: transparent; color: var(--green); border: 1.5px solid var(--green); }
.btn-ghost:hover { background: var(--green); color: var(--darkest); }
.btn-ghost::after { content: ""; }
.btn-block { display: block; width: 100%; }

/* ---- Karten ----------------------------------------------------------- */
.grid { display: grid; gap: 22px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: 0;
  padding: 26px; color: var(--text);
}
.card h3 { margin-top: 6px; color: var(--white); }
.card .num {
  display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px;
  background: var(--darkest); color: var(--green); font-weight: 800; border: 1px solid var(--border);
}

/* ---- Preisanker ------------------------------------------------------- */
.anchor {
  display: inline-block; background: transparent; border: 1.5px solid var(--green);
  border-radius: 0; padding: 7px 16px; font-weight: 800; color: var(--green); font-size: 15px;
  text-transform: uppercase; letter-spacing: .04em;
}

/* ---- Platzhalter für Bilder ------------------------------------------ */
.ph {
  display: flex; align-items: center; justify-content: center; text-align: center; flex-direction: column;
  background: repeating-linear-gradient(45deg, #101b28, #101b28 12px, #14202e 12px, #14202e 24px);
  color: var(--green); border: 1px dashed var(--green-deep); border-radius: 0;
  font-weight: 700; font-size: 14px; letter-spacing: .03em; padding: 20px; min-height: 220px;
}
.ph small { display: block; font-weight: 400; color: var(--muted); margin-top: 6px; letter-spacing: 0; }
.ph-16x9 { aspect-ratio: 16/9; min-height: 0; }
.ph-4x3 { aspect-ratio: 4/3; min-height: 0; }

/* ---- Liste ------------------------------------------------------------ */
ul.check { list-style: none; padding: 0; margin: 0 0 1em; }
ul.check li { position: relative; padding: 6px 0 6px 30px; }
ul.check li::before { content: "→"; position: absolute; left: 0; top: 6px; color: var(--green); font-weight: 800; }

/* ---- Formular / Quiz -------------------------------------------------- */
.form { max-width: 520px; margin: 0 auto; }
.field { margin: 0 0 16px; text-align: left; }
.field label { display: block; font-weight: 700; margin-bottom: 6px; font-size: 15px; color: var(--white); }
.field input {
  width: 100%; padding: 14px 15px; font-size: 17px; border: 1.5px solid var(--border);
  border-radius: 0; background: var(--panel-2); color: var(--text); font-family: inherit;
}
.field input::placeholder { color: #67788a; }
.field input:focus { outline: none; border-color: var(--green); }
.consent { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--muted); text-align: left; }
.consent a { color: var(--green); }
.consent input { margin-top: 4px; accent-color: var(--green); }

/* ---- Progress / Steps ------------------------------------------------- */
.progress { height: 6px; background: var(--panel); border-radius: 0; overflow: hidden; margin-bottom: 8px; }
.progress > span { display: block; height: 100%; background: var(--green); width: 0; transition: width .3s ease; }
.step-count { font-size: 13px; color: var(--muted); letter-spacing: .06em; text-transform: uppercase; font-weight: 700; }

.answers { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 6px; }
.answer {
  display: block; text-align: left; padding: 16px 20px; border: 0;
  border-radius: 0; background: var(--green); color: var(--darkest); font-size: 17px;
  font-weight: 700; cursor: pointer; font-family: inherit; transition: background .12s, transform .05s;
}
.answer:hover { background: var(--green-2); }
.answer:active { transform: translateY(1px); }
.answer.sel { background: var(--green-deep); box-shadow: inset 0 0 0 3px var(--darkest); }
@media (max-width: 640px) { .answers { grid-template-columns: 1fr; } }

/* Quiz-Kopfzeile wie Original */
.quiz-intro { text-align: center; color: var(--green); text-transform: uppercase; font-weight: 700;
  font-size: clamp(17px, 2.4vw, 22px); line-height: 1.35; letter-spacing: .01em; margin: 0 auto 30px; max-width: 640px; }
.quiz-intro strong { color: var(--green-2); }
.quiz-q { text-align: center; }

/* ---- Autor / Hans-Peter ---------------------------------------------- */
.author { display: grid; grid-template-columns: 150px 1fr; gap: 26px; align-items: center; }
.author .ph { min-height: 150px; }

/* ---- Footer ----------------------------------------------------------- */
footer.site { background: var(--darkest); color: var(--muted); padding: 34px 0; font-size: 14px; border-top: 1px solid var(--border); }
footer.site a { color: var(--green); }
footer.site .row { display: flex; gap: 18px; flex-wrap: wrap; justify-content: space-between; align-items: center; }
footer.site .links a { margin-left: 16px; }

/* ---- Utility ---------------------------------------------------------- */
.mt0 { margin-top: 0; } .mb0 { margin-bottom: 0; }
.stack > * + * { margin-top: 18px; }
.hr { height: 1px; background: var(--border); border: 0; margin: 40px 0; }
.small { font-size: 14px; }
.hide { display: none !important; }

/* ---- Mobile ----------------------------------------------------------- */
@media (max-width: 720px) {
  body { font-size: 17px; }
  .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .author { grid-template-columns: 1fr; text-align: center; }
  .author .ph { max-width: 200px; margin: 0 auto; }
  .topbar .phone { display: none; }
  section { padding: 44px 0; }
}
