/* ============================================================
   I & R DEVELOPMENT — Dokument-Vorlagen · „Aurora Glass" für Papier
   Gemeinsames Stylesheet für Rechnung, Angebot, Verträge, AVV,
   Datenschutz-Merkblatt. A4, druckoptimiert (-> PDF via Strg+P).
   ============================================================ */

/* ---------- Schriften (selbst gehostet, identisch zur Webseite) ---------- */
@font-face{font-family:"Schibsted Grotesk";src:url("fonts/schibsted-grotesk-latin-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Instrument Sans";src:url("fonts/instrument-sans-latin-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Instrument Sans";src:url("fonts/instrument-sans-latin-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Instrument Sans";src:url("fonts/instrument-sans-latin-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Geist Mono";src:url("fonts/geist-mono-latin-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}

/* ---------- Design-Tokens (aus dem Webseiten-Designsystem) ---------- */
:root{
  --bg:#EFF2FA;
  --ink:#0B1026;
  --muted:#485672;
  --faint:#7E8AA6;
  --line:rgba(11,16,38,.12);
  --line-strong:rgba(11,16,38,.20);
  --a-violet:#8B5CF6;
  --a-blue:#4F8DF9;
  --a-cyan:#22D3EE;
  --grad:linear-gradient(115deg,#8B5CF6,#4F8DF9 50%,#22D3EE);
  --acc-text:#4F46E5;
  --soft:#F4F6FC;          /* zarte Füllfläche für Boxen/Zeilen */
  --font-display:"Schibsted Grotesk","Instrument Sans",system-ui,sans-serif;
  --font-sans:"Instrument Sans",system-ui,-apple-system,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,"Cascadia Mono",monospace;
  --radius-sm:10px;
  --radius-md:16px;
}

/* Farben/Verläufe IMMER mitdrucken (sonst druckt der Browser sie weg) */
*,*::before,*::after{
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}
*{margin:0;padding:0;box-sizing:border-box}

html{background:var(--bg)}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  line-height:1.6;
  font-size:10.5pt;
  -webkit-font-smoothing:antialiased;
  background:#E7ECF6;
  padding:22px 0 60px;
}
a{color:var(--acc-text);text-decoration:none}

/* ---------- Bildschirm-Werkzeugleiste (wird nie gedruckt) ---------- */
.toolbar{
  max-width:210mm;margin:0 auto 16px;padding:0 6px;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.toolbar button{
  font:inherit;font-weight:600;cursor:pointer;color:#fff;
  background:var(--grad);border:none;border-radius:999px;
  padding:.62em 1.4em;font-size:10.5pt;
  box-shadow:0 10px 24px -10px rgba(124,58,237,.6);
}
.toolbar .hint{color:var(--muted);font-size:9.5pt}
.toolbar .hint b{color:var(--ink)}

/* ---------- Die „Seite" (A4) ---------- */
.sheet{
  width:210mm;min-height:297mm;
  margin:0 auto;padding:20mm 18mm 16mm;
  background:#fff;
  box-shadow:0 12px 40px -16px rgba(23,23,80,.28);
  display:flex;flex-direction:column;
}
.sheet + .sheet{margin-top:22px}

/* ---------- Briefkopf / Marke ---------- */
.doc-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;flex:none}
.wordmark{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.02em;line-height:1}
.wordmark .amp{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0 .04em;
}
.wordmark .suffix{
  font-family:var(--font-mono);font-weight:400;font-size:11px;color:var(--muted);
  letter-spacing:.04em;margin-left:.5em;text-transform:none;
}
.brand-contact{
  text-align:right;font-size:8.6pt;line-height:1.5;color:var(--muted);
}
.brand-contact b{color:var(--ink);font-weight:600}

/* dünner Aurora-Strich als Trenner */
.accent-rule{height:3px;border-radius:2px;background:var(--grad);margin:14px 0 0}

/* ---------- Geschäftsbrief-Kopf (Rechnung/Angebot) ---------- */
.letter{display:flex;justify-content:space-between;gap:28px;margin-top:30px}
.addr .from{
  font-size:7.6pt;color:var(--faint);border-bottom:1px solid var(--line);
  padding-bottom:3px;margin-bottom:9px;letter-spacing:.02em;
}
.addr .to{font-size:11pt;line-height:1.55}
.addr .to b{font-weight:600}
.docmeta{flex:none;min-width:62mm;font-size:9.5pt}
.docmeta table{border-collapse:collapse;width:100%}
.docmeta td{padding:2.5px 0;vertical-align:top}
.docmeta td:first-child{color:var(--muted);padding-right:14px;white-space:nowrap}
.docmeta td:last-child{text-align:right;font-weight:600;font-family:var(--font-mono);font-size:9pt}

/* ---------- Dokument-Titel ---------- */
.doc-title{
  font-family:var(--font-display);font-weight:700;font-size:25pt;letter-spacing:-.02em;
  margin:26px 0 4px;line-height:1.05;
}
.doc-sub{color:var(--muted);font-size:10pt;margin-bottom:6px}
.intro{margin:16px 0;color:var(--ink)}

/* ---------- Positions-Tabelle (Rechnung/Angebot) ---------- */
table.pos{width:100%;border-collapse:collapse;margin:14px 0;font-size:9.8pt}
table.pos thead th{
  background:var(--ink);color:#fff;font-weight:600;text-align:left;
  padding:8px 10px;font-size:8.4pt;letter-spacing:.03em;text-transform:uppercase;
}
table.pos thead th.num{text-align:right}
table.pos tbody td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
table.pos tbody td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.pos tbody tr:nth-child(even) td{background:var(--soft)}
table.pos .desc b{font-weight:600}
table.pos .desc small{display:block;color:var(--muted);font-size:8.6pt;margin-top:2px}

/* Summen */
.totals{margin-top:6px;margin-left:auto;width:74mm;font-size:9.8pt}
.totals .row{display:flex;justify-content:space-between;padding:5px 10px}
.totals .row.sub{border-bottom:1px solid var(--line);color:var(--muted)}
.totals .row.grand{
  margin-top:6px;border-radius:var(--radius-sm);color:#fff;background:var(--ink);
  padding:11px 12px;font-size:12pt;font-weight:700;
}
.totals .row.grand .lbl{font-family:var(--font-display)}
.totals .num{font-variant-numeric:tabular-nums}

/* §19-Hinweis & allgemeine Hinweisboxen */
.note{
  margin:18px 0;padding:12px 14px;border-radius:var(--radius-sm);
  background:var(--soft);border:1px solid var(--line);font-size:9.4pt;color:var(--muted);
}
.note.accent{
  border:1px solid transparent;position:relative;background:#F3F1FD;color:var(--ink);
}
.note.accent::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;background:var(--grad);
}
.note b{color:var(--ink)}

/* Zahlung / Bankblock */
.pay{display:flex;gap:24px;flex-wrap:wrap;margin-top:14px;font-size:9.6pt}
.pay .box{flex:1;min-width:62mm;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 13px}
.pay h4{font-size:8pt;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);margin-bottom:6px;font-weight:600}
.pay .box p{line-height:1.55}

/* ---------- Verträge: Parteien, Paragraphen ---------- */
.parties{display:flex;gap:16px;margin:22px 0 6px;flex-wrap:wrap}
.party{
  flex:1;min-width:66mm;background:var(--soft);border:1px solid var(--line);
  border-radius:var(--radius-md);padding:14px 16px;font-size:9.6pt;line-height:1.5;
}
.party .role{font-size:8pt;text-transform:uppercase;letter-spacing:.05em;color:var(--acc-text);font-weight:600;margin-bottom:6px}
.party b{font-weight:600}
.between{text-align:center;color:var(--muted);font-size:9pt;margin:2px 0}

.preamble{margin:16px 0;color:var(--muted);font-size:9.8pt}

section.par{margin:15px 0;break-inside:avoid}
section.par > h2{
  font-family:var(--font-display);font-weight:700;font-size:11.5pt;letter-spacing:-.01em;
  margin-bottom:6px;padding-bottom:5px;border-bottom:1px solid var(--line);
}
section.par > h2 .nr{color:var(--acc-text);margin-right:.5em}
section.par p{margin:6px 0}
section.par ol,section.par ul{margin:6px 0 6px 22px}
section.par li{margin:4px 0;padding-left:3px}
section.par ol.alpha{list-style:lower-alpha}
section.par .sub{color:var(--muted)}

/* Anlagen */
.annex{margin-top:18px;padding-top:14px;border-top:2px solid var(--line-strong);break-inside:avoid}
.annex h3{font-family:var(--font-display);font-size:11pt;margin-bottom:8px}
table.grid{width:100%;border-collapse:collapse;font-size:9.2pt;margin:8px 0}
table.grid th,table.grid td{border:1px solid var(--line);padding:7px 9px;text-align:left;vertical-align:top}
table.grid th{background:var(--soft);font-weight:600}

/* ---------- Unterschriften ---------- */
.sign{display:flex;gap:34px;margin-top:30px;break-inside:avoid}
.sign .col{flex:1}
.sign .line{border-top:1.4px solid var(--ink);margin-top:34px;padding-top:6px;font-size:8.8pt;color:var(--muted)}
.sign .place{font-size:9pt;color:var(--muted);margin-bottom:0}

/* ---------- Datenschutz-Merkblatt / lange Fließtexte ---------- */
.flow h2{font-family:var(--font-display);font-size:12pt;margin:18px 0 6px;break-after:avoid}
.flow h3{font-size:10.5pt;font-weight:600;margin:12px 0 4px}
.flow p{margin:6px 0}
.flow ul{margin:6px 0 6px 20px}
.flow li{margin:3px 0}

/* ---------- Platzhalter (am Bildschirm markiert, im Druck dezent) ---------- */
.fill{
  background:#FFF4C2;border-bottom:1px dashed #C9A100;
  padding:0 3px;border-radius:3px;font-style:normal;color:#5b4b00;
  font-family:var(--font-mono);font-size:.92em;
}
@media print{
  .fill{background:transparent;border-bottom:1px solid var(--line-strong);color:var(--ink);border-radius:0}
}

/* ---------- Fuß der Dokumente ---------- */
.doc-footer{
  margin-top:auto;padding-top:14px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:7.6pt;color:var(--faint);line-height:1.5;
}
.doc-footer .col b{color:var(--muted);font-weight:600;display:block;margin-bottom:2px}
.legal-hint{
  margin-top:14px;font-size:8.2pt;color:var(--muted);font-style:italic;
  padding:9px 12px;background:var(--soft);border-radius:var(--radius-sm);
}

/* Kleine Helfer */
.mono{font-family:var(--font-mono)}
.muted{color:var(--muted)}
.right{text-align:right}
.mt0{margin-top:0}
.spacer{flex:1 1 auto}

/* ============================================================
   DRUCK: weißer Grund, keine Schatten, echte A4-Ränder
   ============================================================ */
@media print{
  @page{size:A4;margin:16mm 15mm}
  html,body{background:#fff}
  body{padding:0;font-size:10pt}
  .no-print,.toolbar{display:none !important}
  .sheet{
    width:auto;min-height:0;margin:0;padding:0;box-shadow:none;
  }
  .sheet + .sheet{margin-top:0;page-break-before:always}
  a{color:var(--ink)}
  section.par,.sign,.annex,.party,table.pos tr{break-inside:avoid}
}
