/* ============================================================
   womokosten.de — Sevenhills Baseline
   Gemeinsames Stylesheet für alle Seiten
   ============================================================ */

:root{
  --forest:      #22310A;
  --forest-deep: #172305;
  --panel:       #2C3E11;
  --cream:       #F6F4EA;
  --body:        #DFE3CE;
  --gold:        #F0B84E;
  --gold-deep:   #C9912F;
  --line:        rgba(246,244,234,.16);
  --line-dark:   rgba(23,35,5,.14);

  --maxw: 1140px;
  --pad: clamp(20px, 5vw, 56px);

  --f-display: "Fraunces", Georgia, serif;
  --f-body: "Inter", system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--f-body);
  background:var(--forest);
  color:var(--body);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; height:auto; display:block; } /* nie zuschneiden */

a{ color:var(--gold); text-decoration:none; }
a:hover{ color:var(--cream); }

h1,h2,h3{
  font-family:var(--f-display);
  font-weight:500;
  line-height:1.1;
  color:var(--cream);
  margin:0 0 .5em;
  letter-spacing:-.01em;
}
h1{ font-size:clamp(2.4rem, 6vw, 4.3rem); font-weight:400; }
h2{ font-size:clamp(1.8rem, 4vw, 2.8rem); }
h3{ font-size:1.3rem; }

p{ margin:0 0 1.1em; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }

.eyebrow{
  font-family:var(--f-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 1rem;
  display:flex; align-items:center; gap:.7rem;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold); opacity:.7; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-weight:600;
  font-size:.98rem;
  padding:.85em 1.5em;
  border-radius:2px;
  border:1px solid transparent;
  transition:transform .15s ease, background .2s ease, color .2s ease;
  cursor:pointer;
}
.btn:hover{ transform:translateY(-2px); }
.btn--gold{ background:var(--gold); color:var(--forest-deep); }
.btn--gold:hover{ background:var(--cream); color:var(--forest-deep); }
.btn--ghost{ border-color:var(--line); color:var(--cream); }
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold); }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(23,35,5,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
  max-width:var(--maxw); margin:0 auto;
  padding-left:var(--pad); padding-right:var(--pad);
}
.brand{
  font-family:var(--f-display);
  font-size:1.25rem; font-weight:500; color:var(--cream);
  letter-spacing:-.01em;
}
.brand b{ color:var(--gold); font-weight:500; }
.nav-links{ display:flex; gap:30px; list-style:none; margin:0; padding:0; }
.nav-links a{
  color:var(--body); font-size:.95rem; font-weight:500;
  padding:6px 0; position:relative;
}
.nav-links a:hover{ color:var(--cream); }
.nav-links a.is-active{ color:var(--gold); }
.nav-toggle{ display:none; background:none; border:0; color:var(--cream); font-size:1.6rem; cursor:pointer; }

/* ---------- Sections ---------- */
.section{ padding:clamp(60px,9vw,120px) 0; }
.section--panel{ background:var(--panel); }
.section--deep{ background:var(--forest-deep); }
.section--light{ background:var(--cream); color:#33401f; }
.section--light h1,.section--light h2,.section--light h3{ color:var(--forest-deep); }
.section--light a{ color:var(--gold-deep); }
.section--light a:hover{ color:var(--forest); }
.section--light .eyebrow{ color:var(--gold-deep); }
.section--light .eyebrow::before{ background:var(--gold-deep); }

.lead{ font-size:1.18rem; max-width:62ch; }

/* ---------- Hero ---------- */
.hero{
  background:
    linear-gradient(rgba(23,35,5,.55), rgba(23,35,5,.78)),
    var(--forest-deep);
  padding:clamp(90px,15vh,170px) 0 clamp(60px,9vw,110px);
}
.hero .route{
  font-family:var(--f-body); font-size:.8rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:var(--body);
  display:flex; gap:.55rem; flex-wrap:wrap; align-items:center; margin-top:1.6rem; opacity:.85;
}
.hero .route span{ display:flex; align-items:center; gap:.55rem; }
.hero .route span::after{ content:"·"; color:var(--gold); }
.hero .route span:last-child::after{ content:""; }
.hero h1{ max-width:16ch; }
.hero .lead{ color:var(--body); }

/* ---------- Grids & Cards ---------- */
.grid{ display:grid; gap:26px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,72px); align-items:center; }

.card{
  background:rgba(246,244,234,.04);
  border:1px solid var(--line);
  border-radius:4px;
  padding:30px;
}
.section--light .card{ background:#fff; border-color:var(--line-dark); }
.card h3{ margin-top:0; }
.card .num{
  font-family:var(--f-display); font-size:1.1rem; color:var(--gold);
  display:block; margin-bottom:.6rem;
}

/* ---------- Spec list ---------- */
.specs{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:0; }
.specs li{ display:flex; justify-content:space-between; gap:16px; padding:13px 0; border-bottom:1px solid var(--line); }
.section--light .specs li{ border-color:var(--line-dark); }
.specs li span:first-child{ color:var(--body); }
.section--light .specs li span:first-child{ color:#5a6647; }
.specs li span:last-child{ color:var(--cream); font-weight:600; text-align:right; }
.section--light .specs li span:last-child{ color:var(--forest-deep); }

/* ---------- Image frame (nie cropped) ---------- */
.frame{ border-radius:4px; overflow:hidden; border:1px solid var(--line); }
.placeholder-img{
  aspect-ratio:4/3; width:100%;
  background:
    repeating-linear-gradient(45deg,rgba(240,184,78,.07) 0 14px,transparent 14px 28px),
    var(--panel);
  display:flex; align-items:center; justify-content:center;
  color:var(--body); font-size:.85rem; letter-spacing:.08em; text-transform:uppercase;
  border:1px dashed var(--line);
  border-radius:4px;
}

/* ---------- Notes / Platzhalter ---------- */
.todo{
  background:rgba(240,184,78,.1);
  border-left:3px solid var(--gold);
  padding:14px 18px; border-radius:0 4px 4px 0;
  font-size:.92rem; color:var(--cream);
}
.section--light .todo{ color:var(--forest-deep); background:rgba(201,145,47,.12); border-color:var(--gold-deep); }

/* ---------- Calculator ---------- */
.calc{ display:grid; gap:18px; max-width:480px; }
.calc label{ font-size:.9rem; color:var(--body); font-weight:600; display:block; margin-bottom:6px; }
.calc input{
  width:100%; padding:12px 14px; font-size:1rem; font-family:var(--f-body);
  background:#fff; border:1px solid var(--line-dark); border-radius:3px; color:#33401f;
}
.calc .result{
  margin-top:8px; padding:20px 24px; background:var(--forest-deep); border-radius:4px;
  display:flex; justify-content:space-between; align-items:baseline;
}
.calc .result .label{ color:var(--body); font-size:.95rem; }
.calc .result .sum{ font-family:var(--f-display); font-size:2rem; color:var(--gold); }

/* ---------- Posts list ---------- */
.post{ display:grid; grid-template-columns:140px 1fr; gap:24px; padding:26px 0; border-bottom:1px solid var(--line); align-items:center; }
.post .placeholder-img{ aspect-ratio:1/1; }
.post h3{ margin:0 0 .3rem; }
.post .meta{ font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; color:var(--gold); margin-bottom:.5rem; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--forest-deep); border-top:1px solid var(--line); padding:60px 0 34px; }
.foot-grid{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; }
.foot-grid h4{ font-family:var(--f-body); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin:0 0 1rem; }
.foot-grid ul{ list-style:none; margin:0; padding:0; }
.foot-grid li{ margin-bottom:.55rem; }
.foot-grid a{ color:var(--body); font-size:.94rem; }
.foot-grid a:hover{ color:var(--cream); }
.foot-bottom{ margin-top:44px; padding-top:22px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.84rem; color:var(--body); }
.foot-affiliate{ font-size:.82rem; color:var(--body); opacity:.75; max-width:60ch; margin-top:10px; }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid-3{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{
    display:none; position:absolute; top:68px; left:0; right:0;
    flex-direction:column; gap:0; background:var(--forest-deep);
    border-bottom:1px solid var(--line); padding:8px var(--pad) 20px;
  }
  .nav-links.open{ display:flex; }
  .nav-links a{ padding:14px 0; border-bottom:1px solid var(--line); }
  .nav-toggle{ display:block; }
}
@media (max-width:600px){
  body{ font-size:16px; }
  .grid-2,.grid-3{ grid-template-columns:1fr; }
  .specs{ grid-template-columns:1fr; }
  .post{ grid-template-columns:90px 1fr; gap:16px; }
  .foot-grid{ grid-template-columns:1fr; }
}

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