/* ── SHARED SUBPAGE STYLES — VARIANT B ── */

.page-h1  { font-family: var(--f); font-size: var(--text-h1); font-weight: 300; color: var(--ink); line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 24px; }
.page-lead { font-size: var(--text-body); font-weight: 400; color: var(--mid); line-height: 1.75; max-width: 540px; }
.sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 32px; }
.sec-h2   { font-family: var(--f); font-size: var(--text-h2); font-weight: 300; color: var(--ink); letter-spacing: -0.015em; }
.sec-link { font-family: var(--f); font-size: var(--text-label); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--g500); }
.cta-center { text-align: center; }
.cta-border-top { border-top: 0.5px solid rgba(255,255,255,0.08); }
.cta-h2 { font-family: var(--f); font-size: var(--text-h2); font-weight: 300; color: var(--bg); letter-spacing: -0.015em; margin-bottom: 12px; }
.cta-p  { font-size: var(--text-body-sm); color: var(--g200); 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(--border); align-items: start; }
.def-row-last { border-bottom: 0.5px solid var(--border); }
.def-title { font-family: var(--f); font-size: var(--text-item); font-weight: 500; color: var(--ink); letter-spacing: -0.01em; }
.def-text  { font-size: var(--text-body-sm); color: var(--mid); line-height: 1.75; }
.partner-row  { display: grid; grid-template-columns: 180px 1fr; gap: 24px; padding: 20px 0; border-top: 0.5px solid rgba(255,255,255,0.1); align-items: start; }
.partner-name { font-family: var(--f); font-size: var(--text-item); font-weight: 500; color: var(--bg); letter-spacing: -0.01em; }
.partner-text { font-size: var(--text-body-sm); color: var(--g200); line-height: 1.65; }

/* ── ANLAGEPHILOSOPHIE ── */
.prose p { font-size: var(--text-body); color: var(--mid); line-height: 1.8; margin-bottom: 20px; max-width: 680px; }
.ap-row   { display: grid; grid-template-columns: 28px 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(--f); font-size: var(--text-label); font-weight: 600; color: var(--g300); letter-spacing: 0.06em; padding-top: 3px; }
.ap-title { font-family: var(--f); font-size: var(--text-item); font-weight: 500; color: var(--bg); letter-spacing: -0.01em; }
.ap-text  { font-size: var(--text-body-sm); color: var(--g200); 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: 44px 180px 1fr; gap: 24px; padding: 36px 0; border-top: 0.5px solid var(--border); align-items: start; }
.sol-row-last { border-bottom: 0.5px solid var(--border); }
.sol-num      { font-family: var(--f); font-size: var(--text-label); font-weight: 600; color: var(--g400); letter-spacing: 0.08em; padding-top: 3px; }
.sol-title    { font-family: var(--f); font-size: var(--text-item); font-weight: 500; color: var(--ink); line-height: 1.3; letter-spacing: -0.01em; }
.sol-subtitle { font-size: var(--text-body-sm); font-weight: 500; color: var(--g500); margin-bottom: 14px; }
.sol-bullets  { list-style: none; margin-bottom: 14px; }
.sol-bullets li { font-size: var(--text-body-sm); color: var(--mid); line-height: 1.65; padding-left: 14px; position: relative; margin-bottom: 5px; }
.sol-bullets li::before { content: '—'; position: absolute; left: 0; color: var(--g300); }
.sol-fit { font-family: var(--f); font-size: var(--text-micro); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); padding-top: 14px; border-top: 0.5px solid var(--border); }

/* ── INSIGHTS ── */
.insight-entry { display: grid; grid-template-columns: 90px 1fr 24px; gap: 24px; padding: 28px 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(--f); font-size: var(--text-micro); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--g300); padding-top: 3px; }
.ins-title    { font-family: var(--f); font-size: var(--text-h3); font-weight: 500; color: var(--bg); margin-bottom: 10px; line-height: 1.3; letter-spacing: -0.01em; }
.ins-body     { font-size: var(--text-body-sm); color: var(--g200); line-height: 1.75; }
.ins-chevron  { color: var(--g400); font-size: 18px; padding-top: 3px; transition: transform 0.2s; }
.insight-entry.open .ins-chevron,
.insight-entry[aria-expanded="true"] .ins-chevron { transform: rotate(180deg); }
.ins-request  { margin-top: 40px; padding-top: 36px; border-top: 0.5px solid rgba(255,255,255,0.1); }
.ins-request p { font-size: var(--text-body-sm); color: var(--g200); 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(--f); font-size: var(--text-micro); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--g300); margin-bottom: 7px; }
.info-val     { font-size: var(--text-body-sm); color: var(--bg); line-height: 1.75; }
.info-val a   { color: var(--bg); transition: color 0.15s; }
.info-val a:hover { color: var(--g200); }
.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; }
.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(--f); font-size: var(--text-micro); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--g300); margin-bottom: 6px; }
.req          { color: var(--g300); }
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(--f); font-size: var(--text-body-sm);
  color: var(--bg); outline: none; border-radius: 0; -webkit-appearance: none; appearance: none;
  transition: border-color 0.15s; font-weight: 400;
}
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.55); }
input::placeholder, textarea::placeholder { color: rgba(164,197,183,0.4); }
select { color: rgba(164,197,183,0.7); 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='%237AA898'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; cursor: pointer; }
select option { background: #2C4A3E; color: #fff; }
textarea { height: 128px; padding: 12px; resize: vertical; }
.form-note { font-size: var(--text-micro); color: rgba(164,197,183,0.5); margin-top: 12px; }

/* ── LEGAL ── */
.legal-content { max-width: 720px; }
.legal-content h2 { font-family: var(--f); font-size: var(--text-h2); font-weight: 300; color: var(--ink); margin-bottom: 20px; line-height: 1.2; letter-spacing: -0.015em; }
.legal-content h3 { font-family: var(--f); font-size: var(--text-h3); font-weight: 500; color: var(--ink); margin: 32px 0 12px; }
.legal-content p  { font-size: var(--text-body); color: var(--mid); line-height: 1.8; margin-bottom: 16px; }
.legal-badge { display: inline-block; font-family: var(--f); font-size: var(--text-label); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); border: 0.5px solid var(--border); padding: 6px 14px; margin-bottom: 28px; }

/* ── 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; }
  .sec-head { flex-direction: column; gap: 8px; }
}
