/* ── SHARED PAGE STYLES ── */

/* Page header */
.page-h1  { font-family: var(--serif); font-size: var(--text-h1); font-weight: 400; color: var(--text-dark); line-height: 1.15; letter-spacing: 0.02em; margin-bottom: 24px; }
.page-lead { font-size: var(--text-body); color: var(--text-mid); line-height: 1.75; max-width: 560px; }

/* CTA blocks */
.cta-center    { text-align: center; }
.cta-border-top { border-top: 0.5px solid rgba(255,255,255,0.08); }
.cta-h2 { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--cream); line-height: 1.25; margin-bottom: 14px; }
.cta-p  { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.7; margin-bottom: 28px; }

/* ── ÜBER UNS ── */
.def-row { display: grid; grid-template-columns: 200px 1fr; gap: 24px; padding: 24px 0; border-top: 0.5px solid var(--cream-dark); align-items: start; }
.def-row-last { border-bottom: 0.5px solid var(--cream-dark); }
.def-title { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--text-dark); }
.def-text  { font-size: var(--text-body-sm); color: var(--text-mid); line-height: 1.7; }
.partner-row  { display: grid; grid-template-columns: 180px 1fr; gap: 24px; padding: 22px 0; border-top: 0.5px solid rgba(255,255,255,0.1); align-items: start; }
.partner-name { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--cream); }
.partner-text { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.65; }

/* ── ANLAGEPHILOSOPHIE ── */
.prose p { font-size: var(--text-body); color: var(--text-mid); line-height: 1.8; margin-bottom: 20px; max-width: 680px; }
.ap-row   { display: grid; grid-template-columns: 32px 200px 1fr; gap: 20px; padding: 26px 0; border-top: 0.5px solid rgba(255,255,255,0.1); align-items: start; }
.ap-num   { font-family: var(--serif); font-size: var(--text-small-title); font-weight: 400; color: var(--cream); padding-top: 2px; }
.ap-title { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--cream); }
.ap-text  { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.7; }
.btn-row  { display: flex; gap: 14px; margin-top: 36px; flex-wrap: wrap; }

/* ── LÖSUNGEN ── */
.sol-row { display: grid; grid-template-columns: 48px 180px 1fr; gap: 24px; padding: 36px 0; border-top: 0.5px solid var(--cream-dark); align-items: start; }
.sol-row-last { border-bottom: 0.5px solid var(--cream-dark); }
.sol-num      { font-family: var(--serif); font-size: var(--text-small-title); font-weight: 400; color: var(--text-mid); padding-top: 3px; }
.sol-title    { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--text-dark); line-height: 1.35; }
.sol-subtitle { font-size: var(--text-body-sm); font-weight: 500; color: var(--text-light); margin-bottom: 14px; }
.sol-bullets  { list-style: none; margin-bottom: 14px; }
.sol-bullets li { font-size: var(--text-body-sm); color: var(--text-mid); line-height: 1.65; padding-left: 14px; position: relative; margin-bottom: 5px; }
.sol-bullets li::before { content: '—'; position: absolute; left: 0; color: var(--text-light); }
.sol-fit { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-light); padding-top: 14px; border-top: 0.5px solid var(--cream-mid); }

/* ── INSIGHTS ── */
.insight-entry { display: grid; grid-template-columns: 110px 1fr 24px; gap: 28px; padding: 32px 0; border-top: 0.5px solid rgba(255,255,255,0.1); align-items: start; cursor: pointer; }
.insight-entry:last-of-type { border-bottom: 0.5px solid rgba(255,255,255,0.1); }
.ins-date     { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-pale); padding-top: 3px; }
.ins-title    { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--cream); margin-bottom: 12px; line-height: 1.3; }
.ins-body     { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.75; }
.ins-chevron  { color: var(--green-light); font-size: var(--text-item); padding-top: 3px; transition: transform 0.2s; }
.insight-entry.open .ins-chevron { transform: rotate(180deg); }
.insight-entry[aria-expanded="true"] .ins-chevron { transform: rotate(180deg); }
.ins-request  { margin-top: 40px; padding-top: 40px; border-top: 0.5px solid rgba(255,255,255,0.1); }
.ins-request p { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.7; margin-bottom: 18px; }

/* ── KONTAKT ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 80px; align-items: start; }
.info-label   { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-pale); margin-bottom: 7px; }
.info-val     { font-size: var(--text-body-sm); color: var(--cream); line-height: 1.7; }
.info-val a   { color: var(--cream); transition: color 0.15s; }
.info-val a:hover { color: var(--green-pale); }
.info-block   { margin-bottom: 28px; }
hr.info-div   { border: none; border-top: 0.5px solid rgba(255,255,255,0.1); margin: 0 0 24px; }

/* Honeypot — visually hidden, not display:none (screenreaders skip it via aria-hidden) */
.hp-wrap { position: absolute; left: -9999px; top: -9999px; opacity: 0; height: 0; overflow: hidden; }

.form-row     { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.form-group   { margin-bottom: 14px; }
label         { display: block; font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-pale); margin-bottom: 6px; }
.req          { color: var(--green-pale); }
input[type="text"],
input[type="email"],
select,
textarea {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 0.5px solid rgba(255,255,255,0.18);
  padding: 0 12px;
  height: 42px;
  font-family: var(--sans);
  font-size: var(--text-body-sm);
  color: var(--cream);
  outline: none;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.15s;
}
input:focus, select:focus, textarea:focus { border-color: rgba(255,255,255,0.45); }
input:invalid:not(:placeholder-shown),
textarea:invalid:not(:placeholder-shown) { border-color: rgba(220,100,100,0.6); }
input::placeholder, textarea::placeholder { color: rgba(164,197,183,0.4); }
select {
  color: rgba(164,197,183,0.75);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23A4C5B7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}
select option { background: #2C4A3E; color: var(--cream); }
textarea      { height: 128px; padding: 12px; resize: vertical; }
.form-note    { font-size: var(--text-micro); color: rgba(164,197,183,0.55); margin-top: 12px; }

/* ── LEGAL PAGES ── */
.legal-content { max-width: 720px; }
.legal-content h2 { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--text-dark); margin-bottom: 20px; line-height: 1.25; }
.legal-content h3 { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--text-dark); margin: 32px 0 12px; }
.legal-content p  { font-size: var(--text-body); color: var(--text-mid); line-height: 1.8; margin-bottom: 16px; }
.legal-badge { display: inline-block; font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); border: 0.5px solid var(--cream-dark); padding: 6px 14px; margin-bottom: 32px; }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .def-row, .partner-row, .ap-row, .sol-row { grid-template-columns: 1fr; gap: 8px; }
  .insight-entry { grid-template-columns: 1fr 24px; }
  .ins-date { grid-column: 1 / -1; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .form-row { grid-template-columns: 1fr; }
}
