/* ==============================================
   Calculateur Allure Natation — v1.0.0
   ============================================== */
.can-wrap {
  --can-blue:    #0577A8;
  --can-blue-dk: #045D82;
  --can-cyan:    #16A6C9;
  --can-bg:      rgba(5,119,168,0.07);
  --can-light:   #EAF6FB;
  --can-light-dk:#d4ecf6;
  --can-white:   #FFFFFF;
  --can-black:   #0c2330;
  --can-muted:   rgba(12,35,48,0.45);
  --can-error:   #dc2626;
  --can-r:       14px;
  --can-font:    'DM Sans', sans-serif;
  --can-disp:    'Bebas Neue', sans-serif;
}
.can-wrap, .can-wrap *, .can-wrap *::before, .can-wrap *::after { box-sizing: border-box; }
.can-wrap { font-family: var(--can-font); max-width: 580px; width: 100%; }

.can-card {
  background: var(--can-white); border-radius: var(--can-r);
  border: 2px solid var(--can-blue);
  box-shadow: 0 12px 40px rgba(5,119,168,0.13); overflow: hidden;
}

.can-header { background: var(--can-blue); padding: 24px 28px 18px; position: relative; overflow: hidden; }
.can-header::after {
  content: '~'; position: absolute; right: 10px; top: -30px;
  font-family: var(--can-disp); font-size: 130px; color: rgba(255,255,255,0.07);
  line-height: 1; pointer-events: none; user-select: none;
}
.can-title {
  font-family: var(--can-disp) !important; font-size: 32px !important;
  color: var(--can-white) !important; letter-spacing: 1.5px !important;
  line-height: 1 !important; margin: 0 !important; padding: 0 !important;
  border: none !important; background: none !important; text-transform: none !important;
}
.can-subtitle {
  color: rgba(234,246,251,0.7) !important; font-size: 12px !important;
  margin: 5px 0 0 !important; font-weight: 400 !important; font-style: normal !important;
}

.can-body { padding: 24px 28px; background: var(--can-white); }
.can-body-results { padding-top: 20px; }

.can-group { margin-bottom: 16px; }
.can-group label {
  display: block !important; font-size: 11px !important; font-weight: 700 !important;
  color: var(--can-blue) !important; text-transform: uppercase !important;
  letter-spacing: .9px !important; margin-bottom: 7px !important;
}
.can-group input[type="number"] {
  width: 100% !important; background: var(--can-light) !important;
  border: 2px solid transparent !important; border-radius: 9px !important;
  padding: 11px 15px !important; color: var(--can-black) !important;
  font-family: var(--can-font) !important; font-size: 16px !important;
  outline: none !important; transition: border-color .2s, background .2s !important;
  box-shadow: none !important; -moz-appearance: textfield !important;
}
.can-group input[type="number"]:focus {
  border-color: var(--can-blue) !important; background: var(--can-white) !important;
  box-shadow: 0 0 0 3px rgba(5,119,168,0.12) !important;
}
.can-time { display: flex; align-items: center; gap: 8px; }
.can-time input { text-align: center; }
.can-time-sep { font-family: var(--can-disp); font-size: 22px; color: var(--can-muted); }

.can-hint { font-size: 12px !important; color: var(--can-muted) !important; margin: 0 0 14px !important; line-height: 1.5 !important; font-style: italic !important; }
.can-error { color: var(--can-error) !important; font-size: 13px !important; font-weight: 500 !important; margin: 6px 0 !important; display: none; }
.can-error.show { display: block !important; }

.can-btn {
  display: block !important; width: 100% !important; padding: 13px 20px !important;
  margin-top: 6px !important; background: var(--can-blue) !important; color: var(--can-white) !important;
  border: none !important; border-radius: 9px !important; font-family: var(--can-disp) !important;
  font-size: 19px !important; font-weight: 400 !important; letter-spacing: 1.5px !important;
  text-align: center !important; cursor: pointer !important;
  transition: background .2s, transform .15s, box-shadow .15s !important;
  box-shadow: none !important; text-decoration: none !important; line-height: 1 !important;
  text-transform: none !important; appearance: none !important; -webkit-appearance: none !important;
}
.can-btn:hover { background: var(--can-blue-dk) !important; transform: translateY(-2px) !important; box-shadow: 0 6px 18px rgba(5,119,168,0.28) !important; color: var(--can-white) !important; }
.can-btn:active { transform: translateY(0) !important; }
.can-btn:focus { outline: 3px solid rgba(5,119,168,0.3) !important; outline-offset: 2px !important; }

.can-btn-ghost {
  display: inline-flex !important; align-items: center !important; gap: 6px !important;
  padding: 8px 16px !important; background: rgba(255,255,255,0.13) !important;
  color: var(--can-light) !important; border: 1px solid rgba(255,255,255,0.28) !important;
  border-radius: 8px !important; font-family: var(--can-font) !important; font-size: 13px !important;
  font-weight: 600 !important; cursor: pointer !important; transition: background .2s !important;
  white-space: nowrap !important; text-decoration: none !important; box-shadow: none !important;
  line-height: 1.2 !important; appearance: none !important; -webkit-appearance: none !important;
}
.can-btn-ghost:hover { background: rgba(255,255,255,0.22) !important; color: var(--can-white) !important; }

.can-banner { background: var(--can-blue); padding: 20px 28px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.can-banner-vals { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.can-banner-allure { font-family: var(--can-disp); font-size: 48px; color: var(--can-light); line-height: 1; }
.can-banner-kmh { font-family: var(--can-disp); font-size: 32px; color: rgba(234,246,251,0.85); line-height: 1; }
.can-banner-unit { font-size: 13px; color: rgba(234,246,251,0.6); }
.can-banner-sep { color: rgba(234,246,251,0.4); font-size: 24px; }

.can-table-heading { font-family: var(--can-disp); font-size: 20px; color: var(--can-blue); letter-spacing: .8px; }
.can-table-desc { font-size: 12px; color: var(--can-muted); margin: 4px 0 12px; line-height: 1.5; }
.can-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 9px; border: 2px solid var(--can-light-dk); }
table.can-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 300px; }
.can-table thead tr { background: var(--can-blue); }
.can-table thead th { padding: 9px 11px; text-align: center; font-family: var(--can-disp); font-size: 13px; letter-spacing: .7px; color: var(--can-white); white-space: nowrap; font-weight: 400; }
.can-table thead th:first-child { text-align: left; padding-left: 14px; }
.can-table tbody tr:nth-child(even) { background: var(--can-light); }
.can-table tbody tr:hover { background: var(--can-bg); }
.can-table tbody td { padding: 9px 11px; text-align: center; color: var(--can-black); white-space: nowrap; border-bottom: 1px solid var(--can-light-dk); }
.can-table tbody tr:last-child td { border-bottom: none; }
.can-table tbody td:first-child { text-align: left; padding-left: 14px; font-weight: 700; color: var(--can-blue); text-transform: uppercase; letter-spacing: .5px; font-size: 12px; }
.can-table tr.col-ref td { background: rgba(5,119,168,0.10); font-weight: 700; color: var(--can-blue); }

@media (max-width: 500px) {
  .can-header, .can-body, .can-banner { padding-left: 16px !important; padding-right: 16px !important; }
  .can-title { font-size: 26px !important; }
  .can-banner-allure { font-size: 38px; }
  .can-banner-kmh { font-size: 26px; }
}
