.app{--r:#c41212;--b:#101010;--g:#f4f5f7;--line:#d9d9d9;--ok:#1b7f36;--mid:#d68100;--bad:#b00020}
.app,.app *,.sticky-banner,.sticky-banner *,.mobile-fixed-actions,.mobile-fixed-actions *{box-sizing:border-box}
.app{font-family:Arial,Helvetica,sans-serif;color:#111}
.app{width:min(1440px,100vw);max-width:1440px;margin-left:calc(50% - min(720px,50vw));margin-right:calc(50% - min(720px,50vw));background:#fff;min-height:100vh}
.app > header{display:grid;grid-template-columns:320px 1fr 360px;gap:22px;align-items:center;padding:24px 30px;border-bottom:6px solid var(--r)}
.app .logo{font-weight:900;font-size:42px;line-height:.9}.app .logo span{display:block;color:var(--r);font-size:26px;text-align:center}
.app h1{margin:0;font-size:30px}.app .red{color:var(--r)}
.app .topbox{border:1px solid #e7b0b0;border-radius:10px;padding:12px;background:#fff8f8}
.app .topbox label,.app .field label{
font-size:12px;
font-weight:700;
color:#333
}

/* Astérisque champs obligatoires */
.app label.required::after{
content:" *";
color:#c41212;
font-weight:900;
}
.app input,.app select,.app textarea{width:100%;border:1px solid #bcc3cf;border-radius:6px;padding:8px;background:#f8fbff}
.app > main{padding:22px 30px 115px}
.app .toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.app button{border:0;border-radius:8px;padding:11px 14px;font-weight:800;cursor:pointer}
.app .primary{background:var(--r);color:white}.app .dark{background:#111;color:#fff}.app .light{background:#eee}
.app .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.app .card{border:1px solid var(--line);border-radius:12px;padding:16px;background:white;box-shadow:0 1px 3px #0001}
.app .card.full{grid-column:1/-1}.app .card.two{grid-column:span 2}
.app h2{font-size:16px;margin:0 0 12px;color:var(--r);text-transform:uppercase}
.app .fields{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.app .field{display:flex;flex-direction:column;gap:1cm}
.app .audit{width:100%;border-collapse:collapse;font-size:13px}
.app .audit th{background:#111;color:#fff;text-align:left;padding:8px}
.app .audit td{border-bottom:1px solid #eee;padding:7px;vertical-align:middle}
.app .audit td:nth-child(2),.app .audit td:nth-child(3),.app .audit td:nth-child(4),.app .audit td:nth-child(5){text-align:center;width:80px}
.app .audit input[type=radio]{transform:scale(1.1)}
.app .badge{border-radius:10px;padding:16px;text-align:center;font-weight:900;font-size:22px}
.app .ok{background:#e8f7ec;color:var(--ok)}.app .mid{background:#fff3dd;color:var(--mid)}.app .bad{background:#fde8ec;color:var(--bad)}
.app .scoregrid{display:grid;grid-template-columns:1fr 1fr 1fr 2fr;gap:12px;align-items:stretch}
.app #conclusion{font-size:18px;line-height:1.35}
.app > footer{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid #ddd;padding:10px 30px;font-size:12px;display:grid;grid-template-columns:1.3fr 1fr 1fr 1.5fr;gap:18px}
.app .report{display:none}
.app .small{font-size:12px;color:#555}
@media(max-width:900px){.app > header{grid-template-columns:1fr}.app .grid{grid-template-columns:1fr}.app .card.two{grid-column:1}.app .fields{grid-template-columns:1fr 1fr}.app .scoregrid{grid-template-columns:1fr}}
@media print{
.app{background:white}.app .toolbar{display:none}.app{max-width:none}.app .card{box-shadow:none;break-inside:avoid}
.app > main{padding-bottom:115px} .app input,.app select,.app textarea{border:0;border-bottom:1px solid #aaa;border-radius:0;background:white}
.app .audit th{background:#111!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.app .badge,.app .ok,.app .mid,.app .bad{ -webkit-print-color-adjust:exact; print-color-adjust:exact}
}


/* Ultra-compact client info block (-70% spacing) */
.app .topbox{padding:4px !important}
.app .topbox .field{margin-bottom:2px !important; gap:2px}
.app .topbox label{margin-bottom:0}
.app .topbox input{padding:3px 6px; height:28px}
.app .topbox{line-height:1.1}


/* Réduction 40% blocks 1 et 2 */
.app .card.full .fields{
  gap:6px !important;
}
.app .card.full .field{
  gap:2px !important;
}
.app .card.full input{
  padding:4px 6px !important;
  height:28px;
}


/* Bandeau sticky fiable */
.sticky-banner{
  position: sticky;
  top: 0;
  z-index: 2;
  width:min(1440px,100vw);
  max-width:1440px;
  margin-left:calc(50% - min(720px,50vw));
  margin-right:calc(50% - min(720px,50vw));
  background: #ffffff;
  padding: 8px 0;
  text-align: center;
}
.sticky-banner span{
  display: inline-block;
  background: #c41212;
  color: #ffffff;
  padding: 8px 18px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
}


/* Align radio buttons perfectly in audit table */
.app .audit td{
  vertical-align: middle;
}
.app .audit input[type=radio]{
  display: block;
  margin: 0 auto;
}


/* Validation champs obligatoires */
.app .field-error{
  border:2px solid #c41212 !important;
  background:#fff1f1 !important;
}
.app .error-message{
  color:#c41212;
  font-size:12px;
  font-weight:700;
  margin-top:4px;
}


/* Correctif mobile fonctionnel - conserve le design Valrhone */
@media(max-width:900px){
  .app{width:100%;overflow-x:hidden}
  .app{width:100%;max-width:100%;min-height:100vh}
  .sticky-banner{position:sticky;top:0;z-index:2}
  .app > header{grid-template-columns:1fr !important;gap:12px !important;padding:14px 12px !important}
  .app > header .logo{text-align:center}
  .app > header .logo img{max-width:220px;width:80%;height:auto !important;object-fit:contain}
  .app h1{font-size:22px !important;line-height:1.15}
  .app > main{padding:14px 12px 170px !important}
  .app .toolbar{display:grid !important;grid-template-columns:1fr !important;gap:10px !important;margin-bottom:14px}
  .app .toolbar button, .app .card.full button, .app a button{width:100%;min-height:48px;font-size:15px}
  .app .topbox{padding:10px !important;border-radius:12px}
  .app .topbox input{height:42px !important;padding:10px !important;font-size:16px}
  .app .fields{grid-template-columns:1fr !important;gap:10px !important}
  .app .field{gap:4px !important}
  .app .card.full input,.app .card.full select{height:42px !important;padding:10px !important;font-size:16px}
  .app textarea{font-size:16px;min-height:140px}
  .app .grid{grid-template-columns:1fr !important;gap:12px}
  .app .card,.app .card.two,.app .card.full{grid-column:1/-1 !important;border-radius:12px;padding:14px}
  .app .scoregrid{grid-template-columns:1fr !important;gap:10px}
  .app .badge{font-size:18px;padding:12px}
  .app .audit{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:normal}
  .app .audit tbody,.app .audit tr{width:100%}
  .app .audit th,.app .audit td{min-width:78px;padding:8px 6px}
  .app .audit th:first-child,.app .audit td:first-child{min-width:230px}
  .app .audit th:last-child,.app .audit td:last-child{min-width:210px}
  .app .audit input[type=radio]{width:22px;height:22px;transform:none}
  .app .audit td input[id^='o']{min-width:180px;height:40px;font-size:14px}
  .app > footer{position:static !important;display:block !important;padding:12px !important;font-size:11px;line-height:1.45}
  .mobile-fixed-actions{display:grid !important;grid-template-columns:1fr 1fr;gap:8px;position:fixed;left:0;right:0;bottom:0;z-index:10;background:#fff;border-top:1px solid #ddd;padding:10px 12px calc(10px + env(safe-area-inset-bottom));box-shadow:0 -4px 14px rgba(0,0,0,.12)}
  .mobile-fixed-actions button{min-height:48px;border-radius:10px;font-size:15px}
}
.mobile-fixed-actions{display:none}
.mobile-fixed-actions .primary{background:#c41212;color:#fff}
.mobile-fixed-actions .dark{background:#111;color:#fff}
@media print{.mobile-fixed-actions{display:none!important} .app > footer{position:fixed!important}}
