@font-face{font-family:'Montserrat';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/montserrat-500.woff2') format('woff2');}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/montserrat-600.woff2') format('woff2');}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/montserrat-700.woff2') format('woff2');}
@font-face{font-family:'Open Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/opensans-400.woff2') format('woff2');}
@font-face{font-family:'Open Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/opensans-600.woff2') format('woff2');}

/* =========================================================
   Allmed Consult – Design System (Endfassung 2026)
   Farbwelt: Petrol / Salbeigrün / warmes Weiß / Sandgrau
   Typografie: Montserrat (Headings) + Open Sans (Text)
   ========================================================= */

:root{
  --petrol:#2B6777;
  --petrol-dark:#1F4E5F;
  --white-warm:#F7F7F5;
  --sage:#A8C3B0;
  --sand:#D9D4CC;
  --ink:#243640;
  --muted:#5c6a70;
  --maxw:1140px;
  --radius:14px;
  --shadow:0 14px 40px rgba(31,78,95,.10);
  --font-head:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-body:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white-warm);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--petrol-dark);line-height:1.2;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,4.5vw,3.3rem)}
h2{font-size:clamp(1.6rem,3vw,2.25rem)}
h3{font-size:1.3rem;font-weight:600}
p{margin:0 0 1.1em}
a{color:var(--petrol);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section--tight{padding:60px 0}
.lead{font-size:1.2rem;color:var(--muted);max-width:62ch}
.eyebrow{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:600;color:var(--petrol)}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:var(--font-head);font-weight:600;font-size:1rem;
  background:var(--petrol);color:#fff;padding:15px 34px;border-radius:50px;
  border:2px solid var(--petrol);cursor:pointer;transition:.2s;text-decoration:none;
}
.btn:hover{background:var(--petrol-dark);border-color:var(--petrol-dark);color:#fff;text-decoration:none;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover{background:#fff;color:var(--petrol-dark);border-color:#fff}
.btn--outline{background:transparent;color:var(--petrol)}
.btn--outline:hover{background:var(--petrol);color:#fff}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,247,245,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--sand)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700;color:var(--petrol-dark);font-size:1.15rem}
.brand img{width:46px;height:46px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--font-head);font-weight:500;color:var(--ink);font-size:1rem}
.nav-links a:hover,.nav-links a.active{color:var(--petrol);text-decoration:none}
.nav-links a.active{border-bottom:2px solid var(--sage);padding-bottom:4px}
.nav-cta{background:var(--petrol);color:#fff !important;padding:9px 22px;border-radius:50px}
.nav-cta:hover{background:var(--petrol-dark);text-decoration:none}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--petrol-dark);margin:5px 0;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--petrol-dark)}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03)}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(31,78,95,.92),rgba(43,103,119,.72))}
.hero__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:120px 24px;}
.hero--lg .hero__inner{padding:160px 24px}
.hero h1{color:#fff;max-width:18ch}
.hero p{font-size:1.25rem;max-width:54ch;color:rgba(255,255,255,.94)}
.hero .eyebrow{color:var(--sage)}
.hero__actions{margin-top:30px;display:flex;gap:16px;flex-wrap:wrap}

/* ---------- Area cards (Home) ---------- */
.areas{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.area-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.area-card:hover{transform:translateY(-6px)}
.area-card__media{height:200px;background-size:cover;background-position:center}
.area-card__body{padding:34px;display:flex;flex-direction:column;flex:1}
.area-card h3{font-size:1.5rem;color:var(--petrol-dark)}
.area-card p{color:var(--muted)}
.area-card .btn{margin-top:auto;align-self:flex-start}

/* ---------- Generic two-col content ---------- */
.split{display:grid;grid-template-columns:1.6fr 1fr;gap:56px;align-items:start}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px}
.card--sage{background:var(--sage);color:var(--petrol-dark)}
.card--sand{background:var(--sand)}
.contact-box h3{margin-top:0}
.contact-box p{color:var(--ink)}
.contact-box .row{display:flex;gap:10px;margin-bottom:6px}

/* ---------- Checklist ---------- */
.checklist{list-style:none;margin:14px 0 0;padding:0}
.checklist li{position:relative;padding:10px 0 10px 40px;border-bottom:1px solid var(--sand)}
.checklist li:last-child{border-bottom:0}
.checklist li::before{
  content:"";position:absolute;left:0;top:14px;width:24px;height:24px;border-radius:50%;
  background:var(--sage);
}
.checklist li::after{
  content:"";position:absolute;left:8px;top:19px;width:8px;height:4px;
  border-left:2px solid var(--petrol-dark);border-bottom:2px solid var(--petrol-dark);
  transform:rotate(-45deg);
}
.checklist--cols{columns:2;column-gap:46px}
.checklist--cols li{break-inside:avoid}

/* ---------- Blockquote / approach ---------- */
.pull{border-left:5px solid var(--sage);padding:6px 0 6px 26px;font-family:var(--font-head);
  font-size:1.4rem;font-weight:500;color:var(--petrol-dark);font-style:italic;margin:0 0 1em}

/* ---------- CTA band ---------- */
.cta-band{background:var(--petrol);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.92);max-width:60ch;margin-left:auto;margin-right:auto}

/* ---------- Alt background ---------- */
.bg-white{background:#fff}
.bg-sand-soft{background:linear-gradient(180deg,var(--white-warm),#efece5)}

/* ---------- Contact form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field.full{grid-column:1 / -1}
.form-field label{font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--petrol-dark)}
.form-field .req{color:#c0392b}
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--font-body);font-size:1rem;padding:13px 15px;border:1px solid var(--sand);
  border-radius:10px;background:#fff;color:var(--ink);width:100%;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--petrol);box-shadow:0 0 0 3px rgba(43,103,119,.12)}
.form-consent{display:flex;gap:12px;align-items:flex-start;margin:6px 0 18px;font-size:.95rem;color:var(--muted)}
.form-consent input{margin-top:5px;width:18px;height:18px;flex:none}
.hp{position:absolute;left:-9999px}
.banner{display:none;margin-bottom:22px;padding:16px 20px;border-radius:10px;font-size:1rem}
.banner.ok{display:block;background:#e7f3ec;color:#1e7e44;border:1px solid #1e7e44}
.banner.err{display:block;background:#fdecea;color:#b3261e;border:1px solid #b3261e}

/* ---------- Legal pages ---------- */
.legal{max-width:860px}
.legal h1{margin-bottom:.6em}
.legal h2,.legal h3{margin-top:1.4em}
.legal p,.legal li{color:var(--ink);font-size:.97rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--petrol-dark);color:#dfe8ea;padding:60px 0 28px;font-size:.95rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:.8em}
.site-footer a{color:#cfe0e3}
.site-footer a:hover{color:#fff}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer-brand img{width:44px;height:44px;background:#fff;border-radius:8px;padding:3px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#a9c0c5;font-size:.85rem}
.footer-bottom a{color:#a9c0c5}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:34px}
  .areas{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .checklist--cols{columns:1}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;background:var(--white-warm);
    flex-direction:column;align-items:flex-start;gap:0;padding:8px 24px 18px;
    border-bottom:1px solid var(--sand);box-shadow:var(--shadow);display:none;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:12px 0;width:100%}
  .nav-links a.active{border-bottom:0;color:var(--petrol)}
  .hero__inner,.hero--lg .hero__inner{padding:90px 24px}
}
