    html,
    body {
      margin: 0 !important;
      padding: 0 !important;
      min-height: 100%;
    }

    :root {
      --apo-blue: #0e2b57;
      --apo-blue-2: #153b78;
      --apo-light: #f4f7fc;
      --apo-line: #d5deeb;
      --apo-text: #1a1f2b;
      --apo-accent: #ffd66e;
      --ok: #2d8f58;
    }

    * { box-sizing: border-box; }

    body {
      font-family: "Roboto", sans-serif;
      color: var(--apo-text);
      background:
        radial-gradient(circle at 15% 0%, #edf3ff 0%, transparent 28%),
        radial-gradient(circle at 90% 100%, #e9f0ff 0%, transparent 26%),
        #ffffff;
    }

    #outer-wrap,
    #wrap {
      margin: 0 !important;
      padding: 0 !important;
      width: 100% !important;
      max-width: none !important;
      min-height: 100vh;
      display: flex;
      flex-direction: column;
    }

    body.content-max-width #outer-wrap,
    body.content-max-width #wrap {
      max-width: none !important;
      width: 100% !important;
    }

    #site-header,
    #footer {
      width: 100% !important;
      margin: 0 !important;
    }

    .page {
      flex: 1;
      margin: 0 auto;
      padding: 0 20px 56px;
      font-size: 17px;
      line-height: 1.48;
    }

    .hero {
      border-radius: 18px;
      background: linear-gradient(120deg, var(--apo-blue), var(--apo-blue-2));
      color: #fff;
      margin-top: 30px;
      padding: 22px 24px;
      display: flex;
      gap: 20px;
      align-items: center;
      box-shadow: 0 18px 45px rgba(14, 43, 87, 0.20);
    }

    .hero img {
      width: 95px;
      height: 95px;
      object-fit: contain;
      border-radius: 12px;
      background: #ffffff;
      padding: 8px;
    }

    .hero h1 {
      margin: 0;
      line-height: 1.12;
      font-size: clamp(1.5rem, 2.6vw, 2.1rem);
      font-weight: 800;
      color: #ffffff !important;
    }

    .hero p {
      margin: 6px 0 0;
      color: #dbe7ff;
      font-size: 1.06rem;
    }

    #footer,
    #footer p,
    #footer li,
    #footer a,
    #footer span,
    #footer strong,
    #footer mark,
    #footer-bottom,
    #footer-bottom-menu a,
    #copyright {
      color: #ffffff !important;
    }

    .card {
      margin-top: 18px;
      border: 1px solid var(--apo-line);
      border-radius: 18px;
      background: #fff;
      box-shadow: 0 8px 26px rgba(17, 33, 67, 0.08);
      overflow: hidden;
    }

    .topbar {
      padding: 16px 20px;
      border-bottom: 1px solid var(--apo-line);
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr auto;
      align-items: center;
      background: #fafcff;
    }

    .season {
      display: flex;
      align-items: center;
      gap: 10px;
      font-weight: 600;
    }

    .season select {
      min-width: 150px;
    }

    form {
      padding: 18px;
      display: grid;
      gap: 16px;
    }

    .registration-mode {
      padding: 18px 18px 0;
      display: grid;
      gap: 12px;
    }

    .mode-tabs {
      display: inline-flex;
      width: fit-content;
      max-width: 100%;
      gap: 4px;
      padding: 4px;
      border: 1px solid var(--apo-line);
      border-radius: 999px;
      background: #f7f9ff;
    }

    .mode-tab {
      border-radius: 999px;
      padding: 10px 16px;
      background: transparent;
      color: var(--apo-blue);
      box-shadow: none;
    }

    .mode-tab.active {
      background: linear-gradient(100deg, var(--apo-blue), var(--apo-blue-2));
      color: #fff;
    }

    .renewal-lookup {
      border: 1px solid var(--apo-line);
      border-radius: 14px;
      background: #fbfdff;
      padding: 14px;
      display: grid;
      gap: 10px;
    }

    .renewal-lookup[hidden],
    [data-hidden-when-renewal][hidden] {
      display: none !important;
    }

    .renewal-search-row {
      display: grid;
      grid-template-columns: minmax(0, 220px) auto;
      gap: 10px;
      align-items: center;
    }

    .renewal-search-row button {
      width: fit-content;
      white-space: nowrap;
    }

    .renewal-lookup-status {
      margin: 0;
      font-size: 1rem;
      color: #4e5b78;
    }

    .renewal-lookup-status.status-ok {
      color: var(--ok);
      font-weight: 600;
    }

    .renewal-lookup-status.status-ko {
      color: #b02a37;
      font-weight: 600;
    }

    @media (max-width: 640px) {
      .mode-tabs,
      .renewal-search-row {
        width: 100%;
      }

      .mode-tabs,
      .renewal-search-row {
        display: grid;
        grid-template-columns: 1fr;
      }

      .renewal-search-row button {
        width: 100%;
      }
    }

    fieldset {
      margin: 0;
      border: 1px solid var(--apo-line);
      border-radius: 14px;
      padding: 14px;
      background: #fff;
    }

    legend {
      padding: 0 10px;
      font-weight: 700;
      color: var(--apo-blue);
    }

    .grid {
      display: grid;
      grid-template-columns: repeat(12, minmax(0, 1fr));
      gap: 12px;
    }

    .field {
      display: grid;
      gap: 6px;
    }

    .field label {
      font-size: 1rem;
      font-weight: 600;
    }

    .required-asterisk {
      color: #d62839;
      margin-left: 3px;
      font-weight: 700;
    }

    .required-note {
      margin-bottom: 8px;
      padding: 10px 12px;
      border-radius: 10px;
      background: #f7f9ff;
      border: 1px solid var(--apo-line);
      font-size: 1rem;
      color: #3d4760;
    }

    .field small {
      color: #5f6a7d;
      font-size: 0.92rem;
    }

    input,
    select,
    textarea {
      width: 100%;
      border: 1px solid #b8c6dc;
      border-radius: 10px;
      padding: 10px 11px;
      font: inherit;
      color: inherit;
      background: #fff;
    }

    textarea {
      min-height: 74px;
      resize: vertical;
    }

    input:focus,
    select:focus,
    textarea:focus {
      outline: none;
      border-color: #5f87d8;
      box-shadow: 0 0 0 3px rgba(73, 120, 212, 0.15);
    }

    .inline-options {
      display: flex;
      flex-wrap: wrap;
      gap: 16px;
      padding: 2px 0;
    }

    .inline-options label {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-weight: 500;
      cursor: pointer;
    }

    .inline-options input {
      width: 19px;
      height: 19px;
      margin: 0;
      accent-color: var(--apo-blue);
    }

    .checkbox-options {
      display: grid;
      gap: 8px;
      padding: 2px 0;
    }

    .checkbox-options label {
      display: inline-flex;
      align-items: flex-start;
      gap: 8px;
      font-weight: 500;
      cursor: pointer;
    }

    .checkbox-options input {
      width: 19px;
      height: 19px;
      margin: 0;
      accent-color: var(--apo-blue);
    }

    .license-groups {
      display: grid;
      gap: 12px;
    }

    .license-group {
      border: 1px solid var(--apo-line);
      border-radius: 10px;
      background: #fbfdff;
      overflow: hidden;
    }

    .license-toggle {
      width: 100%;
      border: 0;
      border-radius: 0;
      margin: 0;
      padding: 12px 14px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: #eef3ff;
      color: var(--apo-blue);
      text-align: left;
      font: inherit;
      color: var(--apo-blue);
      font-weight: 700;
      cursor: pointer;
    }

    .license-toggle:hover {
      filter: none;
      background: #e4edff;
    }

    .license-toggle-title {
      font-size: 1.05rem;
      line-height: 1.2;
    }

    .license-arrow {
      display: inline-block;
      font-size: 1.02rem;
      transition: transform 0.18s ease;
    }

    .license-toggle[aria-expanded="true"] .license-arrow {
      transform: rotate(180deg);
    }

    .license-panel {
      display: none;
      padding: 12px 14px 14px;
    }

    .license-panel.open {
      display: block;
    }

    .license-fees {
      display: grid;
      gap: 10px;
    }

    .license-fees label {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      gap: 10px;
      cursor: pointer;
      font-weight: 500;
      width: 100%;
      text-align: left;
      margin: 0;
      line-height: 1.35;
    }

    .license-fees input[type="radio"] {
      margin: 0;
      flex: 0 0 auto;
      width: 19px !important;
      min-width: 19px;
      height: 19px !important;
      margin-top: 2px;
    }

    .license-fees span {
      display: inline-block;
      text-align: left;
    }

    .license-loading,
    .license-error {
      margin: 0;
      font-size: 1rem;
      color: #51607e;
    }

    .license-error {
      color: #b02a37;
    }

    .amount-field input {
      width: 100%;
      max-width: 260px;
      height: 34px;
      padding: 6px 10px;
    }

    #montant {
      min-width: 100px !important;
      max-width: 260px !important;
      width: 100% !important;
    }

    .reserved-apo-grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(230px, 320px);
      gap: 12px 16px;
      align-items: start;
    }

    .license-field {
      grid-column: 1;
      grid-row: 1;
    }

    .payment-column {
      grid-column: 2;
      grid-row: 1;
      display: grid;
      gap: 12px;
      align-content: start;
    }

    .payment-options-field .inline-options {
      display: grid;
      gap: 8px;
      padding: 0;
      margin: 0;
    }

    .payment-options-field .inline-options label {
      display: inline-flex;
      justify-content: flex-start;
      gap: 8px;
      font-weight: 500;
    }

    .note {
      margin-top: 10px;
      padding: 11px 12px;
      border-left: 4px solid var(--apo-blue);
      background: var(--apo-light);
      border-radius: 8px;
      font-size: 1rem;
      line-height: 1.4;
    }

    .legal-notice,
    .image-rights-notice {
      margin: 10px 0 0;
      padding: 12px 14px;
      border: 1px solid var(--apo-line);
      border-left: 4px solid var(--apo-blue);
      border-radius: 10px;
      background: #fbfdff;
      color: #24314a;
      font-size: 1rem;
      line-height: 1.55;
    }

    .legal-notice p {
      margin: 0;
    }

    .legal-notice p + p {
      margin-top: 10px;
    }

    .checkbox-description {
      margin: 2px 0 0 27px;
      color: #4e5b78;
      font-size: 0.98rem;
      line-height: 1.45;
    }

    .attestation {
      background: #fbfdff;
      border: 1px solid var(--apo-line);
      border-radius: 10px;
      padding: 12px;
      line-height: 1.5;
      font-size: 1.05rem;
    }

    .attestation a {
      text-decoration: underline;
      font-weight: 600;
    }

    .attestation-alert {
      margin-top: 12px;
      background: #fff2f2;
      border-color: #f3b5bb;
      border-left: 5px solid #d62839;
      color: #7a1420;
      font-weight: 500;
    }

    .attestation-choices {
      display: grid;
      gap: 8px;
      margin-top: 12px;
    }

    .attestation-choices label {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-weight: 500;
      cursor: pointer;
    }

.attestation-choices input {
  width: 19px;
  height: 19px;
  margin: 0;
  accent-color: var(--apo-blue);
}

#medical-certificate-warning[hidden] {
  display: none !important;
}

#medical-certificate-warning {
  display: block;
  min-height: 72px;
}

#medical-certificate-warning .attestation-alert {
  display: block;
  margin: 0;
}

#medical-certificate-warning.is-hidden .attestation-alert {
  display: none !important;
}

    .submit-row {
      display: flex;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
      border-top: 1px solid var(--apo-line);
      padding-top: 14px;
      flex-wrap: wrap;
    }

    .submit-row p {
      margin: 0;
      color: #5e6780;
      font-size: 0.98rem;
    }

    button {
      border: 0;
      border-radius: 999px;
      background: linear-gradient(100deg, var(--apo-blue), var(--apo-blue-2));
      color: #fff;
      font: inherit;
      font-weight: 700;
      padding: 12px 22px;
      cursor: pointer;
    }

    button:hover {
      filter: brightness(1.08);
    }

    .ok-msg {
      display: none;
      margin-top: 10px;
      color: var(--ok);
      font-weight: 600;
    }

    .col-12 { grid-column: span 12; }
    .col-9 { grid-column: span 9; }
    .col-8 { grid-column: span 8; }
    .col-7 { grid-column: span 7; }
    .col-6 { grid-column: span 6; }
    .col-5 { grid-column: span 5; }
    .col-4 { grid-column: span 4; }
    .col-3 { grid-column: span 3; }

    @media (max-width: 900px) {
      .hero {
        flex-direction: column;
        align-items: flex-start;
      }

      .topbar {
        grid-template-columns: 1fr;
      }

      .col-9,
      .col-8,
      .col-7,
      .col-6,
      .col-5,
      .col-4,
      .col-3 {
        grid-column: span 12;
      }

      .reserved-apo-grid {
        grid-template-columns: 1fr;
      }

      .license-field,
      .payment-column {
        grid-column: auto;
        grid-row: auto;
      }

    }
