/* =========================================================================
   kleine Hansen — Marken-CSS für die Website-Skelette
   Tokens & Komponenten aus firma/markenstyleguide.md (warm & handgemacht).
   EIN Ort für den Look — index/blog/post teilen sich diese Datei.
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Oregano:ital@0;1&family=Nunito:ital,wght@0,400;0,600;0,700;0,800;1,400;1,600&family=Jost:wght@400;500;600&display=swap');

:root{
  /* Kern-Palette */
  --altrosa:#E8C4B8; --sahne:#FBF7F2; --gold:#F0D080; --salbei:#A8C5A0;
  --braun:#4A3728; --lavendel:#C9C0D8;
  /* Ableitungen */
  --braun-soft:#6f5944; --linie:#E7DCD0; --paper:#FFFDFA;
  --salbei-dark:#8caa82; --altrosa-dark:#d8a596;
  --schatten:0 10px 34px rgba(74,55,40,.12);
  --radius:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--sahne); color:var(--braun);
  font-family:'Nunito',system-ui,sans-serif; font-size:17px; line-height:1.65;
}
.brush{font-family:'Oregano',cursive; font-weight:400}
.container{max-width:1080px; margin:0 auto; padding:0 24px}
.container.narrow{max-width:720px}
a{color:#a5694f}
img{max-width:100%; display:block}

/* ---- Buttons ---- */
.btn{
  display:inline-block; font-family:'Nunito'; font-weight:800; font-size:16px;
  padding:13px 24px; border-radius:999px; text-decoration:none; cursor:pointer;
  border:2px solid transparent; transition:transform .08s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--salbei); color:var(--braun)}
.btn-primary:hover{background:var(--salbei-dark)}
.btn-ghost{background:transparent; color:var(--braun); border-color:var(--braun)}
.btn-ghost:hover{background:var(--braun); color:var(--sahne)}

/* ---- Tags / Pills ---- */
.tag{
  display:inline-block; font-family:'Jost'; font-weight:600; font-size:12.5px;
  letter-spacing:.06em; text-transform:uppercase; color:var(--braun);
  background:var(--gold); padding:3px 11px; border-radius:999px;
}
.tag.s1{background:var(--lavendel)} .tag.s2{background:var(--altrosa)}
.tag.s3{background:var(--gold)} .tag.s4{background:var(--salbei)}

/* ---- Platzhalter-Bildboxen ---- */
.ph{
  background:
    repeating-linear-gradient(45deg,#f3e9df 0 14px,#efe3d6 14px 28px);
  border:1.5px dashed #d8c4b2; border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; text-align:center;
  color:var(--braun-soft); font-family:'Jost'; font-size:13px; letter-spacing:.04em;
  min-height:160px; padding:16px;
}
.ph::before{content:"🖼  "}
.ph.tall{aspect-ratio:4/5} .ph.square{aspect-ratio:1/1} .ph.wide{aspect-ratio:16/9}

/* ---- Navigation / Kopf ---- */
header.site{
  position:sticky; top:0; z-index:20; background:rgba(251,247,242,.92);
  backdrop-filter:blur(6px); border-bottom:1px solid var(--linie);
}
header.site .bar{display:flex; align-items:center; gap:18px; padding:14px 0}
header.site .logo{font-family:'Oregano',cursive; font-size:28px; color:var(--braun); text-decoration:none; line-height:1}
header.site nav{margin-left:auto; display:flex; flex-wrap:wrap; align-items:center; gap:6px 20px}
header.site nav a{font-family:'Jost'; font-weight:500; font-size:15px; color:var(--braun-soft); text-decoration:none}
header.site nav a:hover{color:var(--braun)}
header.site nav a.cta{
  font-family:'Nunito'; font-weight:800; color:var(--braun);
  background:var(--salbei); padding:8px 16px; border-radius:999px;
}

/* ---- Sektionen ---- */
section{padding:64px 0}
.eyebrow{font-family:'Jost'; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  font-size:13px; color:var(--altrosa-dark); margin:0 0 10px}
h1,h2,h3{color:var(--braun); line-height:1.15}
.display{font-family:'Oregano',cursive; font-weight:400; font-size:clamp(40px,7vw,72px); margin:0}
h2.title{font-size:clamp(28px,4vw,40px); font-weight:800; margin:0 0 14px}
.lead{color:var(--braun-soft); font-size:19px; max-width:640px}
.center{text-align:center} .center .lead{margin-left:auto;margin-right:auto}

/* ---- Karten-Raster ---- */
.grid{display:grid; gap:22px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper); border:1px solid var(--linie); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column}
.card .body{padding:20px 22px}
.card h3{margin:0 0 8px; font-size:20px}
.card p{margin:0; color:var(--braun-soft); font-size:15.5px}
.card .step-no{font-family:'Oregano',cursive; font-size:40px; color:var(--altrosa); line-height:1}

/* ---- Hero ---- */
.hero{background:linear-gradient(165deg,var(--altrosa) 0%,#efd7ce 60%,var(--lavendel) 130%);
  border-bottom:1px solid var(--linie)}
.hero .wrap{display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center; padding:72px 0}
.hero .lead{font-size:20px}
.hero .actions{margin-top:26px; display:flex; gap:12px; flex-wrap:wrap}

/* ---- CTA-Band ---- */
.band{background:var(--salbei); text-align:center}
.band h2{font-family:'Oregano',cursive; font-weight:400; font-size:clamp(30px,5vw,48px); margin:0 0 8px}
.band p{color:#3f5238; margin:0 0 22px}

/* ---- Blog-Artikel-Typografie ---- */
article.post{padding:8px 0 0}
.post .meta{font-family:'Jost'; font-size:14px; color:var(--braun-soft); display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.post-title{font-family:'Oregano',cursive; font-weight:400; font-size:clamp(34px,5.5vw,60px); margin:14px 0 6px}
.prose{font-size:18px; line-height:1.75}
.prose > p, .prose > ul, .prose > h2, .prose > h3, .prose > figure, .prose > .callout, .prose > blockquote{
  max-width:680px; margin-left:auto; margin-right:auto}
.prose h2{font-size:27px; font-weight:800; margin:38px auto 12px}
.prose h3{font-size:21px; font-weight:800; margin:28px auto 8px}
.prose ul{padding-left:22px} .prose li{margin:6px 0}
.prose blockquote{border:none; margin:30px auto; text-align:center}
.prose blockquote p{font-family:'Oregano',cursive; font-size:30px; color:var(--braun); line-height:1.3; margin:0}
.callout{background:#fbeee9; border:1px solid var(--altrosa); border-left:5px solid #c98b76;
  border-radius:12px; padding:16px 20px}
.callout strong{color:#a5694f}
figure.inline{margin:30px auto} figure.inline figcaption{font-size:13.5px; color:var(--braun-soft); margin-top:8px; text-align:center}

/* ---- Fußzeile ---- */
footer.site{background:var(--braun); color:#e9ddcf; margin-top:20px}
footer.site .wrap{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; padding:48px 0 34px}
footer.site .logo{font-family:'Oregano',cursive; font-size:30px; color:var(--sahne)}
footer.site h4{font-family:'Jost'; font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:13px; color:var(--altrosa); margin:0 0 12px}
footer.site a{color:#e9ddcf; text-decoration:none; display:block; padding:3px 0; font-size:15px}
footer.site a:hover{color:#fff}
footer.site .legal{border-top:1px solid #5e4a3a; padding:16px 0 40px; font-size:13px; color:#c4b3a2}
.ph-note{background:var(--gold); color:var(--braun); font-family:'Jost'; font-weight:600;
  font-size:12.5px; text-align:center; padding:6px; letter-spacing:.03em}

/* ---- Responsiv ---- */
@media(max-width:820px){
  .hero .wrap{grid-template-columns:1fr; padding:48px 0}
  .grid.cols-3{grid-template-columns:1fr 1fr}
  footer.site .wrap{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  header.site nav{display:none}
}
