:root {
  --color-rouge: #DA0000;
  --color-navy: #02304C;
  --color-blanc: #FFFFFF;
  --color-text-primary: #02304C;
  --color-text-secondary: #5A6B7A;
  --color-bg-page: #F5F5F5;
  --color-border-soft: rgba(2, 48, 76, 0.12);
  --color-border-input: rgba(2, 48, 76, 0.20);
  --color-bg-pauline: rgba(218, 0, 0, 0.03);
  --color-bg-footer: rgba(2, 48, 76, 0.04);
  --radius-md: 8px;
  --radius-lg: 12px;
  --font-stack: 'Montserrat', system-ui, -apple-system, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--font-stack);
  background: var(--color-bg-page);
  color: var(--color-text-primary);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

.app {
  max-width: 600px;
  margin: 0 auto;
  padding: 32px 16px;
}

.card {
  background: var(--color-blanc);
  border-radius: var(--radius-lg);
  border: 0.5px solid var(--color-border-soft);
  overflow: hidden;
}

/* Header */
.card-header {
  background: var(--color-navy);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.logo-icon {
  /* déjà 20x14 via attributs SVG, on ne touche pas */
  display: block;
}

.brand-name {
  color: var(--color-blanc);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.5px;
}

/* Footer */
.card-footer {
  background: var(--color-bg-footer);
  padding: 14px 20px;
  text-align: center;
  font-size: 11px;
  color: var(--color-text-secondary);
  border-top: 0.5px solid var(--color-border-soft);
}

.card-footer a {
  color: var(--color-navy);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(2, 48, 76, 0.3);
}

/* États : un seul visible à la fois */
.state {
  padding: 28px 24px;
  display: none;
}

.state[data-state="upload"] {
  /* visible par défaut pour cette étape */
  display: block;
}

/* Hero */
.hero-title {
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 600;
  color: var(--color-navy);
  line-height: 1.3;
}

.hero-sub {
  margin: 0 0 24px;
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.5;
}

/* Dropzone */
.dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  border: 1.5px dashed var(--color-border-input);
  border-radius: var(--radius-md);
  padding: 24px 20px;
  background: rgba(2, 48, 76, 0.02);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  margin-bottom: 16px;
}

.dropzone:hover {
  border-color: var(--color-rouge);
  background: rgba(218, 0, 0, 0.02);
}

.dropzone-icon {
  margin-bottom: 4px;
}

.dropzone-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-navy);
}

.dropzone-hint {
  font-size: 12px;
  color: var(--color-text-secondary);
}

.dropzone-input {
  display: none;
}

/* Form fields */
.form-field {
  margin-bottom: 14px;
}

.field-label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-secondary);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.text-input {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--color-border-input);
  border-radius: var(--radius-md);
  font-family: var(--font-stack);
  font-size: 14px;
  color: var(--color-navy);
  background: var(--color-blanc);
}

.text-input:focus {
  outline: none;
  border-color: var(--color-rouge);
}

/* Buttons */
.btn {
  font-family: var(--font-stack);
  font-weight: 500;
  font-size: 14px;
  padding: 14px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.1s;
}

.btn:active { transform: translateY(1px); }

.btn-primary {
  background: var(--color-rouge);
  color: var(--color-blanc);
  border-color: var(--color-rouge);
}

.btn-primary:hover { opacity: 0.92; }

.btn-block {
  width: 100%;
}

/* Trust line */
.trust-line {
  text-align: center;
  font-size: 11px;
  color: var(--color-text-secondary);
  margin: 14px 0 0;
}

/* Responsive */
@media (max-width: 480px) {
  .app { padding: 16px 12px; }
  .state { padding: 20px 16px; }
}

/* ─── Loading ─── */
.loading-wrap {
  text-align: center;
  padding: 24px 0;
}

.spinner {
  width: 36px;
  height: 36px;
  margin: 0 auto 20px;
  border: 3px solid rgba(218, 0, 0, 0.15);
  border-top-color: var(--color-rouge);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

.loading-title {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-navy);
  margin: 0 0 6px;
}

.loading-sub {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0;
}

.loading-countdown {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin: 20px 0 0;
}

/* ─── Verdict pill ─── */
.verdict-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--color-rouge);
  color: var(--color-blanc);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin-bottom: 24px;
}

.verdict-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-blanc);
}

.verdict-pill[data-verdict="rdv_ok"] {
  background: #1D9E75;
}

.verdict-pill[data-verdict="neutre_utile"],
.verdict-pill.verdict-grey {
  background: var(--color-text-secondary);
}

/* ─── Section labels ─── */
.section-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-secondary);
  margin: 0 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ─── Pauline quote ─── */
.pauline-quote {
  margin: 0 0 28px;
  padding: 6px 18px;
  border-left: 3px solid var(--color-rouge);
  background: var(--color-bg-pauline);
  font-size: 16px;
  line-height: 1.65;
  color: var(--color-navy);
  font-style: normal;
}

/* ─── Actions list ─── */
.actions-list {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
}

.actions-list li {
  display: flex;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 0.5px solid rgba(2, 48, 76, 0.08);
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-navy);
}

.actions-list li:last-child {
  border-bottom: none;
}

.action-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--color-rouge);
  color: var(--color-blanc);
  font-size: 12px;
  font-weight: 500;
  flex-shrink: 0;
}

/* ─── Share grid ─── */
.share-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 28px;
}

.share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px;
  background: var(--color-blanc);
  border: 1px solid var(--color-border-input);
  border-radius: var(--radius-md);
  font-family: var(--font-stack);
  font-size: 13px;
  color: var(--color-navy);
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.2s, transform 0.1s;
}

.share-btn:hover {
  border-color: var(--color-rouge);
}

.share-btn:active { transform: translateY(1px); }

/* ─── CTA row ─── */
.cta-row {
  display: flex;
  gap: 8px;
  padding-top: 20px;
  border-top: 0.5px solid rgba(2, 48, 76, 0.1);
}

.btn-outline {
  flex: 1;
  background: var(--color-blanc);
  border: 1px solid var(--color-border-input);
  color: var(--color-navy);
}

.btn-outline:hover {
  border-color: var(--color-navy);
}

.btn-navy {
  flex: 1;
  background: var(--color-navy);
  border: 1px solid var(--color-navy);
  color: var(--color-blanc);
  text-decoration: none;
}

.btn-navy:hover { opacity: 0.92; }

/* ─── Alert box (état 3-bis) ─── */
.alert-box {
  background: rgba(218, 0, 0, 0.06);
  border-left: 3px solid var(--color-rouge);
  padding: 14px 18px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-navy);
  margin-bottom: 24px;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

/* ─── Link secondary ─── */
.link-secondary {
  display: block;
  text-align: center;
  font-size: 12px;
  color: var(--color-text-secondary);
  text-decoration: underline;
  margin-top: 16px;
}

/* ─── Audit (état 3-ter) ─── */
.audit-wrap {
  text-align: center;
  padding: 8px 0;
}

.audit-icon {
  margin: 24px auto 16px;
  display: block;
}

.audit-title {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-navy);
  margin: 0 0 12px;
}

.audit-text {
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.5;
  margin: 0 0 24px;
}

.audit-microcopy {
  font-size: 11px;
  color: var(--color-text-secondary);
  margin: 8px 0 0;
}

/* ─── Confirm (état 4) ─── */
.confirm-wrap {
  text-align: center;
  padding: 16px 0;
}

.confirm-icon {
  margin: 0 auto 20px;
  display: block;
}

.confirm-title {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-navy);
  margin: 0 0 12px;
}

.confirm-text {
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.5;
  margin: 0 0 24px;
}

/* ─── Responsive (états résultat/audit) ─── */
@media (max-width: 480px) {
  .share-grid { gap: 6px; }
  .share-btn { font-size: 12px; padding: 8px; }
  .share-btn span { display: none; } /* icônes seules sur très petit */
  .cta-row { flex-direction: column; }
}

/* ─── Pauline feedback en bullets (remplace .pauline-quote) ─── */
.pauline-list {
  list-style: none;
  margin: 0 0 28px;
  padding: 8px 0 8px 18px;
  border-left: 3px solid var(--color-rouge);
  background: var(--color-bg-pauline);
}

.pauline-list li {
  position: relative;
  padding: 4px 0 4px 18px;
  font-size: 16px;
  line-height: 1.5;
  color: var(--color-navy);
}

.pauline-list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--color-rouge);
  font-weight: 600;
}

.pauline-list li.tone-positive::before { color: #1D9E75; }
.pauline-list li.tone-negative::before { color: var(--color-rouge); }
.pauline-list li.tone-neutral::before  { color: var(--color-text-secondary); }

/* ─── Drag & drop active state ─── */
.dropzone-active {
  border-color: var(--color-rouge) !important;
  border-style: solid;
  background: rgba(218, 0, 0, 0.06);
}

/* ─── Counter banner ─── */
.counter-banner {
  text-align: center;
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-bottom: 20px;
  padding: 8px;
  background: rgba(218, 0, 0, 0.04);
  border-radius: 4px;
}
.counter-number {
  font-weight: 600;
  color: var(--color-rouge);
  margin-right: 4px;
}

/* ─── Newsletter checkbox ─── */
.newsletter-field {
  margin-top: 8px;
  margin-bottom: 16px;
}
.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: var(--color-text-secondary);
  cursor: pointer;
  line-height: 1.4;
}
.checkbox-label input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
}

/* ─── Bullets colorés (override .pauline-list li) ─── */
.pauline-list li.bullet-positive,
.pauline-list li.tone-positive {
  color: #1D9E75;
}
.pauline-list li.bullet-negative,
.pauline-list li.tone-negative {
  color: var(--color-rouge);
}
.pauline-list li.bullet-neutral,
.pauline-list li.tone-neutral {
  color: #E89B2C;
}
