:root{
  --ink:#25221f;
  --muted:#6e6860;
  --paper:#fbfaf7;
  --line:#ddd6ca;
  --very-good:rgba(146,180,150,.30);
  --good:rgba(150,175,198,.25);
  --neutral:rgba(255,255,255,.92);
  --bad:rgba(201,164,116,.30);
  --very-bad:rgba(170,105,92,.25);
}
*{box-sizing:border-box}
html{-webkit-print-color-adjust:exact;print-color-adjust:exact}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family: Georgia, "Times New Roman", serif;
}
.app{max-width:1180px;margin:0 auto;padding:32px}
.hero{
  min-height:90vh;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  align-items:center;
  gap:42px;
}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted)}
h1{font-size:clamp(2.3rem,6vw,5rem);line-height:.95;margin:.2em 0;font-weight:400}
h2{font-size:1.25rem;font-weight:400;margin:.4em 0 1.2em;color:#3a3631}
p{line-height:1.55;color:#3d3833}
.hero-illustration{width:100%;max-width:560px;justify-self:center}
.form-card{
  margin-top:28px;border:1px solid var(--line);border-radius:18px;padding:22px;
  background:rgba(255,255,255,.55);display:grid;gap:10px;max-width:430px
}
label{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
input,select,button{font:inherit;border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:white}
.checkline{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-size:.88rem;color:var(--ink)}
.checkline input{width:auto;accent-color:#292520}
.help{font-size:.78rem;color:var(--muted);margin:-2px 0 8px}
.technical-hidden{display:none!important}
button{cursor:pointer;background:#292520;color:#fff;margin-top:8px}
button.secondary{background:transparent;color:var(--ink)}
.hidden{display:none}
.toolbar{position:sticky;top:0;z-index:10;padding:14px 0;background:var(--paper);display:flex;gap:12px;justify-content:flex-end;align-items:flex-start}
.print-help{display:flex;flex-direction:column;gap:5px;max-width:420px}
.print-help small{color:var(--muted);font-size:.74rem;line-height:1.3}
.page{
  background:#fffdf9;border:1px solid var(--line);border-radius:24px;padding:36px;margin:24px 0;
  box-shadow:0 18px 60px rgba(0,0,0,.04)
}
.cover{min-height:680px;display:flex;align-items:center;justify-content:center;text-align:center}
.cover h1{font-size:4.6rem}
.cover-illustration{width:520px;max-width:80%;margin:18px auto}
.identity{display:inline-block;text-align:left;border-top:1px solid var(--line);margin-top:14px;padding-top:14px}
.copyright{
  margin-top:24px;padding-top:12px;border-top:1px solid var(--line);
  color:var(--muted);font-size:.76rem;line-height:1.4
}
.cover-copyright{max-width:760px;margin-left:auto;margin-right:auto}
.legend-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:28px}
.legend{border:1px solid var(--line);border-radius:16px;padding:14px;min-height:150px}
.legend span{display:block;font-size:1.6rem;margin-bottom:8px}
.legend p{font-size:.88rem;margin:.6em 0 0}
.very-good{background:var(--very-good)!important}
.good{background:var(--good)!important}
.neutral{background:var(--neutral)!important}
.bad{background:var(--bad)!important}
.very-bad{background:var(--very-bad)!important}
.very-good,.good,.neutral,.bad,.very-bad{
  -webkit-print-color-adjust:exact!important;
  print-color-adjust:exact!important;
}
.months-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.month-card{border:1px solid var(--line);border-radius:18px;padding:13px;background:rgba(255,255,255,.72);break-inside:avoid;page-break-inside:avoid}
.month-card h3{margin:0 0 10px;font-weight:400;letter-spacing:.05em;text-transform:uppercase;font-size:.95rem}
.month-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.weekday{text-align:center;color:var(--muted);font-size:.66rem;padding-bottom:3px}
.day{
  min-height:28px;border:1px solid rgba(221,214,202,.8);border-radius:7px;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  font-size:.68rem;background:#fff
}
.day.empty{border-color:transparent;background:transparent!important}
.day .symbol{font-size:1.08rem;line-height:1}
.day.bad-symbol .symbol{font-size:1.08rem}
.day.very-good .symbol,
.day.good .symbol,
.day.bad .symbol{font-size:1.08rem}
.periods{margin-top:10px;display:grid;grid-template-columns:1fr;gap:5px}
.period{
  border:1px solid var(--line);border-radius:10px;padding:6px 10px;
  display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center;font-size:.72rem
}
.period .picto{
  font-size:1.2rem;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
}
.period.very-good .picto,
.period.good .picto,
.period.bad .picto{font-size:1.2rem}
.period strong{display:block;font-weight:600}
.period small{color:var(--muted)}
.footer{margin-top:14px;padding-top:9px;border-top:1px solid var(--line);color:var(--muted);font-size:.7rem;line-height:1.35}
@media(max-width:900px){
  .app{padding:20px}.hero{grid-template-columns:1fr}.legend-grid,.months-grid{grid-template-columns:1fr}
}
@page{size:A4 landscape;margin:8mm}
@media print{
  html,body{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:white}
  .app{max-width:none;padding:0}
  .no-print{display:none!important}
  .page{
    border:0;box-shadow:none;border-radius:0;margin:0;padding:7mm;
    page-break-after:always;break-after:page;page-break-inside:avoid;break-inside:avoid;
    width:281mm;min-height:194mm;overflow:hidden
  }
  .cover{min-height:194mm}
  .cover h1{font-size:38pt}
  .cover h2{font-size:15pt}
  .cover-illustration{width:420px}
  .intro h2{font-size:17pt;margin-top:0}
  .intro p{font-size:9.4pt;line-height:1.38;margin:.45em 0}
  .legend-grid{grid-template-columns:repeat(5,1fr);gap:6px}
  .legend{min-height:86px;padding:7px;border-radius:10px}
  .legend span{font-size:15pt;margin-bottom:2px}
  .legend p{font-size:7.4pt;line-height:1.25}
  .months-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .month-card{padding:6px;border-radius:12px}
  .month-card h3{font-size:8.4pt;margin-bottom:4px}
  .month-calendar{gap:2px}
  .weekday{font-size:6.2pt}
  .day{min-height:15px;border-radius:4px;font-size:6pt}
  .day .symbol{font-size:8.5pt}
  .day.bad-symbol .symbol{font-size:8.5pt}
  .day.very-good .symbol,
  .day.good .symbol,
  .day.bad .symbol{font-size:8.5pt}
  .periods{gap:2px;margin-top:5px}
  .period{font-size:6.1pt;line-height:1.1;padding:2px 5px;border-radius:5px;grid-template-columns:19px 1fr;gap:5px}
  .period .picto{font-size:8.8pt;display:flex;align-items:center;justify-content:center;min-width:19px}
  .footer,.copyright{font-size:6.4pt;margin-top:8px;padding-top:6px}
}
