/* Informe HTML — estil institucional inspirat en diba.cat (sense copiar literal) */
:root{
  --brand:#9D2235;
  --brand-2:#891536;
  --brand-hover:#5D0E25;
  --ink:#1f2328;
  --text:#333333;
  --muted:#707173;
  --bg:#ffffff;
  --bg-soft:#F3F5F5;
  --bg-wash:#F7F7F7;
  --line:#DADADA;
  --accent-line:#707173; /* línia d'accent neutra (no vermell) */
  --shadow: 0 12px 30px rgba(0,0,0,.08);
  --radius:0px; /* legacy */
  --radius-sm:0px; /* legacy */
  --radiusR: 14px;
  --max: 1040px;
}

/* Tipografia: parell editorial + institucional */
@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,500;8..60,600;8..60,700&display=swap');

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Source Sans 3", system-ui, -apple-system, Segoe UI, sans-serif;
  color:var(--text);
  background: #ffffff;
}

a{color:var(--text);text-decoration:none}
a:hover{color:var(--brand)}

.container{max-width:var(--max); margin:0 auto; padding:32px 20px 64px}

/* Capçalera */
.header{
  display:flex; align-items:flex-start; justify-content:space-between; gap:24px;
  padding:18px 18px 14px;
  border:1px solid var(--line);
  border-left: 6px solid var(--accent-line);
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
  background: #ffffff;
}

/* Portada */
.cover{
  min-height: 420px;
}

.brand{
  display:flex; flex-direction:column; gap:10px;
}

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--muted);
  font-size: 13px;
  letter-spacing:.10em;
  text-transform: uppercase;
}
.kicker .dot{width:8px;height:8px;border-radius:999px;background:var(--brand)}

h1{
  margin:0;
  font-family: "Source Serif 4", serif;
  font-weight: 700;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height:1.08;
  color:var(--brand);
}

.subtitle{
  margin:6px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.45;
  max-width: 62ch;
}

.logo{
  width:min(220px, 40vw);
  height:auto;
  padding:8px 10px;
  border-left: 0;
  background: var(--bg-soft);
  border-radius: 0;
}

.meta{
  margin-top:12px;
  display:flex; flex-wrap:wrap; gap:8px;
}

.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius: 0;
  background:#fff;
  color: var(--muted);
  font-size: 13px;
}
.chip strong{color:var(--text); font-weight:600}

/* Seccions */
.section{margin-top:22px}

.card{
  border:1px solid var(--line);
  border-left: 6px solid var(--accent-line);
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
  background: #ffffff;
  box-shadow: none;
  overflow:hidden;
}

.card__hd{
  padding:16px 18px;
  border-bottom:1px solid var(--line);
  background: var(--bg-soft);
  display:flex; align-items:baseline; justify-content:space-between; gap:12px;
}

.card__hd h2{
  margin:0;
  font-size: 18px;
  font-weight:700;
  color: var(--brand);
  letter-spacing:.01em;
}

.card__bd{padding:18px}

.grid2{display:grid; grid-template-columns: 1.15fr .85fr; gap:16px}
@media (max-width: 900px){.grid2{grid-template-columns:1fr}}

.p{margin:0 0 12px; line-height:1.6}

.list{margin:0; padding-left:18px; line-height:1.6}
.list li{margin:6px 0}

.callout{
  border-left: 6px solid var(--accent-line);
  background: var(--bg-soft);
  padding:14px 14px;
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
}
.callout p{margin:0; color:var(--text)}

/* Flow diagram */
.flow{
  border:1px dashed rgba(112,113,115,.55);
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
  background: #fff;
  padding:14px;
}

.flow svg{width:100%; height:auto; display:block}

/* Taules */
.table{
  width:100%;
  border-collapse: collapse;
  overflow:hidden;
  border:1px solid var(--line);
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
}
.table th, .table td{
  padding:12px 12px;
  border-bottom:1px solid var(--line);
  vertical-align: top;
}
.table th{
  text-align:left;
  color: var(--brand);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing:.08em;
  background: var(--bg-soft);
}
.table tr:last-child td{border-bottom:none}

.badge{
  display:inline-flex; align-items:center;
  padding:4px 9px;
  border-radius:0;
  border:1px solid var(--line);
  background: var(--bg-soft);
  color: var(--muted);
  font-weight:600;
  font-size: 12px;
}

.money{
  font-family: "Source Serif 4", serif;
  font-weight: 700;
  color: var(--brand);
}

hr.sep{border:none;border-top:1px solid var(--line); margin:16px 0}

.footer{
  margin-top:24px;
  padding:16px 18px;
  border:1px solid var(--line);
  border-left: 6px solid var(--accent-line);
  border-bottom:4px solid var(--brand);
  /* esquerra quadrada, dreta amb radi */
  border-radius: 0 var(--radiusR) var(--radiusR) 0;
  color: var(--muted);
  background:#fff;
  font-size: 13px;
  display:flex; gap:12px; justify-content:space-between; flex-wrap:wrap;
}

@media print{
  body{background:#fff}
  .container{padding:0}
  .card{box-shadow:none}
  a{color:inherit}

  /* Prioritat: que el PDF quedi net.
     Evitem orfes (títols sols) i talls lletjos de taules, però NO forcem
     cada secció sencera a 1 pàgina (això crea blancs i empitjora el layout). */

  /* Mantén el títol amb el primer bloc de contingut */
  .card__hd{ page-break-after: avoid; break-after: avoid; }
  .card__bd{ page-break-before: avoid; break-before: avoid; }

  /* Taules: evita tallar files */
  table{ page-break-inside: auto; break-inside: auto; }
  tr{ page-break-inside: avoid; break-inside: avoid; }

  /* Control de salts de pàgina (wkhtmltopdf)
     Objectiu:
       - Portada a la pàgina 1
       - Secció 1 + 2 juntes (pàgina 2)
       - Secció 3 en nova pàgina
       - Secció 5 en nova pàgina
  */
  #cover{ page-break-after: always; break-after: page; }

  /* Manté 1 i 2 juntes */
  #sec1{ page-break-after: avoid; break-after: avoid; }
  #sec2{ page-break-before: avoid; break-before: avoid; }

  #sec3{ page-break-before: always; break-before: page; }
  #sec5{ page-break-before: always; break-before: page; }

  /* El diagrama (sec2) és el que més trenca el PDF: compactem només en print */
  #sec2 .flow{ padding: 8px; }
  #sec2 .flow svg{ max-height: 120mm; }

  /* Compactació per print */
  .card__bd{ padding: 12px; }
  .card__hd{ padding: 11px 12px; }
  .table th, .table td{ padding: 8px 10px; }
  .p, p, li{ font-size: 12.3px; }
  h1{ font-size: 28px; }
  .subtitle{ font-size: 13px; }
  .chip{ padding: 6px 8px; }

  /* Portada: una mica més d'aire */
  #cover .meta{ margin-top: 10px; }
}

