/* ============================================================
   Immobilienpartner Sachsen — CI-Druck-Stylesheet
   Für die 10 Download-Dokumente · DIN A4 · druckoptimiert
   ============================================================ */

:root{
  --brand:#1B3A5C; --brand-dark:#002444; --brand-light:#2B486B;
  --accent:#C17B4A; --accent-dark:#A8693D;
  --surface:#F3F4F5; --surface-2:#E8E9EB; --tint:#FDF8F4;
  --serif:Georgia,"Times New Roman",serif;
  --sans:system-ui,-apple-system,"Segoe UI",sans-serif;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background:#d9d7d2;
  font-family:var(--sans);
  color:var(--brand);
  font-size:14px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

/* ---- A4 sheet ---- */
.doc{
  width:210mm;
  min-height:297mm;
  margin:24px auto;
  background:#fff;
  position:relative;
  box-shadow:0 4px 22px rgba(27,58,92,0.16);
}

/* ---- Running header (each page in print) ---- */
.rh{
  background:var(--brand);
  border-bottom:3px solid var(--accent);
  height:24mm;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 20mm;
}
.rh img{ height:36px; width:auto; display:block; }
.rh .cat{
  font-size:10px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accent);
}

/* ---- Running footer line (each page in print) ---- */
.rf{
  display:flex; align-items:center; justify-content:space-between;
  padding:6px 20mm; height:14mm;
  border-top:1px solid var(--accent);
  font-size:10px; color:rgba(27,58,92,0.7);
}
.rf b{ color:var(--brand); font-weight:600; }

/* ---- Content area ---- */
.content{ padding:14mm 20mm 8mm; }

/* ---- Typography ---- */
h1{ font-family:var(--serif); font-style:italic; font-weight:700; font-size:28px; line-height:1.15; color:var(--brand); margin:0 0 6px; }
h2{ font-family:var(--serif); font-style:italic; font-weight:700; font-size:20px; line-height:1.2; color:var(--brand); margin:26px 0 10px; }
h3{ font-family:var(--sans); font-weight:700; font-size:14px; letter-spacing:0.02em; color:var(--brand); margin:16px 0 6px; }
p{ margin:0 0 10px; color:rgba(27,58,92,0.86); }
.lead{ font-size:15px; color:rgba(27,58,92,0.78); }
.sub{ font-family:var(--serif); font-style:italic; font-size:16px; color:var(--accent-dark); margin:0 0 4px; }
strong,b{ color:var(--brand); }
small{ font-size:11px; color:rgba(27,58,92,0.6); }

/* ---- Category label ---- */
.cat-label{
  display:inline-block; background:rgba(193,123,74,0.15); color:var(--accent-dark);
  font-size:10px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
  padding:5px 11px; border-radius:999px; margin-bottom:12px;
}

/* ---- Info / hint box ---- */
.infobox{
  border-left:3px solid var(--accent); background:var(--tint);
  padding:12px 16px; margin:14px 0; border-radius:0 6px 6px 0;
  font-size:13px; color:rgba(27,58,92,0.85);
}
.infobox b{ color:var(--brand); }

/* ---- Numbered steps ---- */
.step{ display:flex; gap:16px; align-items:flex-start; margin:0 0 16px; page-break-inside:avoid; break-inside:avoid; }
.step .no{
  flex:0 0 auto; width:34px; height:34px; border-radius:50%;
  background:var(--brand); color:#fff; font-family:var(--serif); font-weight:700;
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.step .bd{ flex:1; }
.step .bd h3{ margin:4px 0 4px; }
.step .meta{ font-size:11px; color:var(--accent-dark); font-weight:600; text-transform:uppercase; letter-spacing:0.06em; }
.step ul{ margin:6px 0 0; padding-left:18px; }
.step li{ margin:2px 0; font-size:13px; color:rgba(27,58,92,0.82); }

/* ---- Tables ---- */
table{ width:100%; border-collapse:collapse; margin:12px 0; font-size:12.5px; }
th{ background:var(--brand); color:#fff; text-align:left; padding:9px 10px; font-weight:600; font-size:11px; letter-spacing:0.04em; }
td{ border:1px solid var(--surface-2); padding:8px 10px; vertical-align:top; color:rgba(27,58,92,0.88); }
tr:nth-child(even) td{ background:#fbfbfc; }
td.fill{ background:var(--surface); }
td.num{ text-align:right; font-variant-numeric:tabular-nums; }
.tbl-note{ font-size:10px; color:rgba(27,58,92,0.55); margin-top:4px; }

/* ---- Form fields ---- */
.field{ margin:0 0 12px; }
.field label, label.fl{ display:block; font-size:11px; font-weight:600; letter-spacing:0.04em; text-transform:uppercase; color:rgba(27,58,92,0.6); margin-bottom:4px; }
input[type="text"], input[type="date"], input[type="number"]{
  font-family:var(--sans); font-size:13px; color:var(--brand);
  border:none; border-bottom:1.5px solid var(--brand); background:transparent;
  width:100%; padding:5px 2px; outline:none;
}
input.line{ border-bottom:1.5px dotted rgba(27,58,92,0.5); }
textarea{
  font-family:var(--sans); font-size:13px; color:var(--brand);
  border:1px solid rgba(27,58,92,0.3); border-radius:6px; background:var(--surface);
  width:100%; resize:vertical; min-height:60px; padding:8px 10px; outline:none;
}
.fieldgrid{ display:grid; gap:14px 22px; }
.fg-2{ grid-template-columns:1fr 1fr; }
.fg-3{ grid-template-columns:1fr 1fr 1fr; }

/* ---- Checkboxes ---- */
.chk{ display:flex; align-items:flex-start; gap:9px; margin:7px 0; font-size:13px; color:rgba(27,58,92,0.88); page-break-inside:avoid; }
.chk input[type="checkbox"]{ width:16px; height:16px; accent-color:var(--accent); margin:1px 0 0; flex:0 0 auto; }
.chk-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2px 28px; }
.chk-inline{ display:flex; flex-wrap:wrap; gap:6px 20px; align-items:center; }
.chk-inline .chk{ margin:4px 0; }

/* ---- CTA box (last page) ---- */
.cta{
  margin:20px 0 8px; background:var(--surface); border:1px solid var(--brand);
  border-radius:10px; padding:16px 20px; page-break-inside:avoid;
}
.cta .k{ font-size:10px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent-dark); }
.cta .t{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--brand); margin:4px 0 6px; }
.cta .u{ font-weight:700; color:var(--accent); font-size:14px; }

/* ---- Signature grid ---- */
.sign{ display:grid; grid-template-columns:1fr 1fr; gap:36px; margin-top:18px; }
.sign .col .who{ font-weight:700; color:var(--brand); margin-bottom:24px; }
.sign .line{ border-top:1.5px dashed rgba(27,58,92,0.6); padding-top:5px; font-size:11px; color:rgba(27,58,92,0.6); }
.sign .sub-line{ margin-top:22px; }

/* ---- Cover (dark) for Leitfaden ---- */
.cover{ background:var(--brand-dark); color:#fff; min-height:297mm; padding:40mm 24mm; display:flex; flex-direction:column; }
.cover img{ height:46px; width:auto; }
.cover h1{ color:#fff; font-size:40px; margin-top:auto; }
.cover .c-sub{ font-family:var(--serif); font-style:italic; font-size:22px; color:var(--accent); margin:14px 0 0; }
.cover .c-lead{ font-size:15px; color:rgba(255,255,255,0.82); max-width:120mm; margin-top:20px; line-height:1.6; }
.cover .c-year{ font-family:var(--serif); font-weight:700; font-size:64px; color:rgba(255,255,255,0.16); margin-top:30px; }

/* ---- Misc helpers ---- */
.muted{ color:rgba(27,58,92,0.6); }
.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.divider{ height:1px; background:var(--surface-2); margin:18px 0; border:none; }
.room{ border:1px solid var(--surface-2); border-radius:8px; padding:12px 14px; margin:0 0 10px; page-break-inside:avoid; break-inside:avoid; }
.room .rname{ font-weight:700; color:var(--brand); font-size:13px; margin-bottom:8px; }
.rating{ display:flex; gap:6px; }
.star{ font-size:20px; color:var(--surface-2); }
.timeline{ display:flex; gap:0; margin:14px 0; }
.timeline .ph{ flex:1; text-align:center; position:relative; padding:0 6px; }
.timeline .ph .dot{ width:14px; height:14px; border-radius:50%; background:var(--accent); margin:0 auto 8px; }
.timeline .ph .bar{ position:absolute; top:6px; left:50%; right:-50%; height:2px; background:var(--surface-2); z-index:0; }
.timeline .ph:last-child .bar{ display:none; }
.timeline .ph .t{ font-weight:700; font-size:12px; color:var(--brand); }
.timeline .ph .d{ font-size:10px; color:var(--accent-dark); }

/* ============================================================
   PRINT
   ============================================================ */
@media print{
  body{ background:#fff; }
  .doc{ margin:0; box-shadow:none; width:auto; min-height:auto; }
  .no-print{ display:none !important; }
  @page{ size:A4; margin:24mm 0 14mm; }
  .rh{ position:fixed; top:-24mm; left:0; right:0; }
  .rf{ position:fixed; bottom:-14mm; left:0; right:0; background:#fff; }
  .content{ padding:6mm 20mm 4mm; }
  .cover{ min-height:auto; height:auto; }
  /* Farben im Druck erzwingen */
  *,*::before,*::after{ -webkit-print-color-adjust:exact !important; print-color-adjust:exact !important; }
  h1,h2,h3,.step,.room,.cta,.infobox,tr,.chk,.sign{ page-break-inside:avoid; break-inside:avoid; }
  thead{ display:table-header-group; }
  .pagebreak{ page-break-before:always; break-before:page; }
}
