/* ============================================================
   FIARE — Website Stylesheet
   finances are easy · Schwerpunkt Versicherung & Investment
   Mobile-first. Robust. WordPress-tauglich als Vorlage.
   ============================================================ */

:root{
  /* Markenfarben (final, Richtung B "Fresh") */
  --grass:#1FA968;      /* Primär */
  --grass-d:#178A53;    /* Hover/dunkler */
  --pine:#0E5C3C;       /* Support */
  --forest:#06342A;     /* dezent / dunkle Flächen */
  --mint:#8FEFBE;       /* Akzent */
  --foam:#E7F8EF;       /* helles Grün-Feld */

  --ink:#0B1A14;
  --ink-soft:#46584F;
  --ink-faint:#85948C;

  --paper:#F4FBF8;
  --paper-2:#FFFFFF;
  --line:rgba(11,26,20,0.12);
  --line-2:rgba(11,26,20,0.07);

  /* Themen-Akzente (nur als Würze: Tag/Kante/Icon) */
  --t-invest:#0E5C3C;
  --t-versich:#DD6E8A;
  --t-sparen:#E6A52E;
  --t-kredit:#D2603F;
  --t-vorsorge:#3E8FD0;
  --t-steuern:#7E6BD6;

  --grotesk:"Schibsted Grotesk", system-ui, -apple-system, sans-serif;
  --mono:"IBM Plex Mono", ui-monospace, monospace;

  --wrap:1120px;
  --pad:20px;
  --radius:18px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--grotesk);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 var(--pad); }
.meta{ font-family:var(--mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); }
.mono-label{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; }

/* ---- Doppel-Chevron ---- */
.chev{ display:inline-block; vertical-align:-0.12em; }

/* ============================================================
   HEADER / NAV  (mobile-first, robust)
   ============================================================ */
.site-head{
  position:sticky; top:0; z-index:50;
  background:rgba(244,251,248,0.86);
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line-2);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:66px;
}
.nav .logo{ display:flex; align-items:center; gap:9px; }
.nav .logo img{ height:30px; width:auto; }
.nav-toggle{
  appearance:none; border:1px solid var(--line); background:var(--paper-2);
  width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; flex:none;
}
.nav-toggle span{ position:relative; width:18px; height:2px; background:var(--ink); display:block; border-radius:2px; transition:.2s; }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink); border-radius:2px; transition:.2s; }
.nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
.site-head.open .nav-toggle span{ background:transparent; }
.site-head.open .nav-toggle span::before{ top:0; transform:rotate(45deg); }
.site-head.open .nav-toggle span::after{ top:0; transform:rotate(-45deg); }

.nav-links{
  position:absolute; left:0; right:0; top:66px;
  background:var(--paper-2); border-bottom:1px solid var(--line);
  display:none; flex-direction:column; padding:8px var(--pad) 16px;
  box-shadow:0 18px 36px -22px rgba(11,26,20,0.4);
}
.site-head.open .nav-links{ display:flex; }
.nav-links a{
  padding:14px 4px; font-size:17px; font-weight:600; letter-spacing:-0.01em;
  border-bottom:1px solid var(--line-2); display:flex; align-items:center; gap:10px;
}
.nav-links a:last-of-type{ border-bottom:0; }
.nav-links a.active{ color:var(--grass); }
.nav-links .nav-cta{
  margin-top:12px; border:0; background:var(--grass); color:#fff; border-radius:100px;
  justify-content:center; padding:14px; font-weight:700;
}

/* Desktop nav */
@media (min-width:880px){
  .nav{ height:74px; }
  .nav .logo img{ height:34px; }
  .nav-toggle{ display:none; }
  .nav-links{
    position:static; display:flex; flex-direction:row; align-items:center; gap:6px;
    background:none; border:0; box-shadow:none; padding:0; width:auto;
  }
  .nav-links a{ border:0; padding:9px 14px; font-size:15px; border-radius:100px; }
  .nav-links a:not(.nav-cta):hover{ background:var(--foam); color:var(--pine); }
  .nav-links .nav-cta{ margin-top:0; padding:11px 20px; font-size:15px; }
  .nav-links .nav-cta:hover{ background:var(--grass-d); }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--grotesk); font-weight:700; font-size:16px; letter-spacing:-0.01em;
  padding:15px 26px; border-radius:100px; border:1.5px solid transparent; cursor:pointer;
  transition:transform .12s ease, background .15s ease, border-color .15s ease;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--grass); color:#fff; }
.btn-primary:hover{ background:var(--grass-d); }
.btn-ghost{ background:transparent; color:var(--pine); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--grass); color:var(--grass); }
.btn-light{ background:#fff; color:var(--pine); }
.btn-light:hover{ background:var(--foam); }
.btn-block{ width:100%; }

/* ============================================================
   SECTIONS / HEADINGS
   ============================================================ */
section{ padding:56px 0; }
.sec-tight{ padding:40px 0; }
.eyebrow{ font-family:var(--mono); font-size:11.5px; letter-spacing:0.2em; text-transform:uppercase; color:var(--grass); }
.sec-head{ margin-bottom:30px; }
.sec-head h2{ font-size:clamp(26px,6vw,40px); font-weight:800; letter-spacing:-0.03em; line-height:1.02; margin-top:12px; }
.sec-head p{ margin-top:14px; color:var(--ink-soft); font-size:16px; max-width:620px; }

/* Page hero (interior pages) */
.page-hero{ padding:42px 0 18px; }
.page-hero h1{ font-size:clamp(32px,8vw,56px); font-weight:800; letter-spacing:-0.04em; line-height:1; margin-top:14px; }
.page-hero p{ margin-top:16px; color:var(--ink-soft); font-size:17px; max-width:620px; }

/* ============================================================
   CARDS / GRID
   ============================================================ */
.grid{ display:grid; gap:16px; }
.card{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot{ background:var(--forest); color:#D9EFE3; margin-top:24px; }
.site-foot .wrap{ padding-top:48px; padding-bottom:40px; }
.foot-top{ display:grid; gap:30px; }
.foot-brand img{ height:30px; }
.foot-brand p{ margin-top:16px; font-size:14.5px; color:rgba(217,239,227,0.75); max-width:340px; }
.foot-claim{ font-family:var(--mono); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--mint); margin-top:18px; }
.foot-col h4{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--mint); margin-bottom:14px; }
.foot-col a{ display:block; padding:7px 0; font-size:14.5px; color:rgba(217,239,227,0.82); }
.foot-col a:hover{ color:#fff; }
.foot-bot{ margin-top:34px; padding-top:22px; border-top:1px solid rgba(255,255,255,0.12);
  display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center; }
.foot-bot span{ font-family:var(--mono); font-size:11px; letter-spacing:0.1em; color:rgba(217,239,227,0.6); }
@media (min-width:760px){
  .foot-top{ grid-template-columns:1.6fr 1fr 1fr; }
}

/* ============================================================
   FORM
   ============================================================ */
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.field label{ font-family:var(--mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-soft); }
.field input,.field select,.field textarea{
  font-family:var(--grotesk); font-size:16px; color:var(--ink);
  background:var(--paper-2); border:1.5px solid var(--line); border-radius:12px; padding:14px 15px;
  width:100%; transition:border-color .15s ease;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--grass); }
.field .hint{ font-size:12.5px; color:var(--ink-faint); }

/* Utilities */
.center{ text-align:center; }
.tag{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; padding:6px 12px; border-radius:100px; border:1px solid var(--line); color:var(--ink-soft); }
.tag i{ width:9px; height:9px; border-radius:3px; flex:none; }
.placeholder-note{ font-family:var(--mono); font-size:11px; letter-spacing:0.06em; color:var(--ink-faint); border:1px dashed var(--line); border-radius:10px; padding:8px 12px; display:inline-block; }
