/* Dorfküche – calm, readable, card-based UI */
:root{
  --bg:#F6F4EF;
  --card:#FFFFFF;
  --text:#1F2A37;
  --muted:#5B6776;
  --blue:#2D4A68;
  --sage:#4E6E5D;
  --sand:#D8C7A7;
  --line:rgba(31,42,55,.12);
  --shadow:0 10px 30px rgba(31,42,55,.10);
  --shadow2:0 6px 18px rgba(31,42,55,.10);
  --r:22px;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 12% 0%, rgba(78,110,93,.12), transparent 60%),
    radial-gradient(1000px 500px at 88% 8%, rgba(45,74,104,.12), transparent 55%),
    var(--bg);
}
a{color:inherit}
img{max-width:100%; height:auto}
.wrap{max-width:var(--max); margin:0 auto; padding:0 18px;}

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(246,244,239,.86);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:12px;
}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none;}
.brand .wordmark{display:flex; flex-direction:column; line-height:1.05;}
.brand .wordmark strong{font-weight:900; letter-spacing:.2px}
.brand .wordmark span{font-size:12px; color:var(--muted)}
.brand img{width:42px; height:42px}

.navlinks{display:flex; align-items:center; gap:12px; flex-wrap:wrap; color:var(--muted); font-size:14px;}
.navlinks a{ text-decoration:none; padding:8px 10px; border-radius:999px; }
.navlinks a:hover{ background:rgba(45,74,104,.08); color:var(--text); }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius:999px; padding:12px 16px; font-weight:750; text-decoration:none;
  border:1px solid var(--line); box-shadow: var(--shadow2); background: var(--card);
}
.btn.primary{ background: linear-gradient(180deg, rgba(45,74,104,.98), rgba(45,74,104,.90)); color:#fff; border-color: rgba(45,74,104,.35);}
.btn.primary:hover{ filter: brightness(1.02); }
.btn.ghost{ background: transparent; box-shadow:none; }

main{padding-bottom:40px}
section{ padding:16px 0; }
.card{ background: var(--card); border:1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); padding:22px; }
.hero{ padding:34px 0 10px; }
.heroGrid{ display:grid; grid-template-columns: 1.1fr .9fr; gap:16px; align-items:stretch; }
@media (max-width: 920px){ .heroGrid{ grid-template-columns:1fr; } }

h1{ font-size:46px; line-height:1.08; margin:0 0 12px; letter-spacing:-.4px; text-shadow: 0 1px 0 rgba(255,255,255,.65);}
@media (max-width: 920px){ h1{ font-size:34px; } }
.lead{ font-size:20px; line-height:1.55; color:var(--muted); margin:0 0 16px;}
.sectionTitle{ font-size:28px; margin:0 0 12px; text-shadow: 0 1px 0 rgba(255,255,255,.65); }
.subTitle{ margin:0 0 10px; font-size:18px; }

.pillRow{ display:flex; gap:10px; flex-wrap:wrap; margin:14px 0 0; }
.pill{ display:inline-flex; align-items:center; gap:10px; padding:10px 12px; border-radius:999px; border:1px solid var(--line); background: rgba(216,199,167,.18); color: rgba(31,42,55,.85); font-weight:800; font-size:14px; }

.grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; }
@media (max-width: 920px){ .grid3{ grid-template-columns:1fr; } }
.split{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 920px){ .split{ grid-template-columns:1fr; } }

.feature{ display:flex; gap:14px; align-items:flex-start; }
.icon{ width:46px; height:46px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  background: rgba(45,74,104,.10); border:1px solid rgba(45,74,104,.18); flex:0 0 auto; }
.icon svg{width:24px; height:24px}
.feature h3{ margin:0 0 6px; font-size:18px; }
.feature p{ margin:0; color:var(--muted); line-height:1.6; }

.kpiGrid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:14px; }
@media (max-width: 520px){ .kpiGrid{ grid-template-columns:1fr; } }
.kpi{ border-radius: 18px; border:1px solid var(--line); padding:14px; background: rgba(78,110,93,.06); }
.kpi strong{ font-size:18px; display:block; }
.kpi span{ display:block; color:var(--muted); margin-top:4px; font-size:14px; line-height:1.5; }

.note{ font-size:13px; color:var(--muted); line-height:1.45; margin:10px 0 0; }
hr.sep{ border:0; border-top:1px solid var(--line); margin:16px 0; }

form{ display:grid; gap:10px; margin-top:8px; }
label{ font-weight:900; font-size:14px; }
input, select, textarea{
  width:100%; padding:12px 12px; border-radius: 14px; border:1px solid var(--line);
  background: rgba(246,244,239,.55); color:var(--text); font-size:16px; outline:none;
}
textarea{ min-height: 110px; resize: vertical; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media (max-width: 720px){ .row2{ grid-template-columns:1fr; } }

.alert{ border:1px solid rgba(78,110,93,.35); background: rgba(78,110,93,.10); padding:12px 14px; border-radius: 16px;
  color: rgba(31,42,55,.92); line-height:1.45; }

.faq details{ border:1px solid var(--line); border-radius: 16px; padding:14px; background: rgba(255,255,255,.82); }
.faq summary{ cursor:pointer; font-weight:900; }
.faq p{ color:var(--muted); line-height:1.6; margin:10px 0 0; }

.footer{ padding:30px 0 60px; color:rgba(31,42,55,.75); }
.footGrid{ display:grid; grid-template-columns: 1.2fr .8fr; gap:12px; }
@media (max-width: 920px){ .footGrid{ grid-template-columns:1fr; } }
.tiny{ font-size:12px; color:rgba(31,42,55,.62); line-height:1.45; }

.miniCalc{ display:grid; gap:10px; }
.miniCalc .out{ border:1px solid var(--line); border-radius: 16px; padding:14px; background: rgba(216,199,167,.12); }
.miniCalc .out b{ font-size:18px; }
.miniCalc .out div{ color:var(--muted); margin-top:6px; line-height:1.5; }

@media print{
  .topbar, .btn, .navlinks { display:none !important; }
  body{ background:#fff; }
  .card{ box-shadow:none; }
}
