/* =====================================================
   Areté · estilos base
   Identidad editorial. Light mode forzado. Sin imágenes
   de fondo. Componentes con prefijo `arete-` para no
   colisionar con el flyer existente.
===================================================== */

:root {
  color-scheme: light only;

  /* Paleta */
  --paper: #FFFFFF;
  --paper-soft: #FAFAFA;
  --paper-warm: #F7F6F2;
  --ink: #0B0B0B;
  --ink-soft: #1A1A1E;
  --ink-mid: #4A4D55;
  --ink-mute: #7A7E88;
  --ink-faint: #B8BBC2;
  --accent: #BC002D;
  --accent-deep: #8E001F;
  --accent-go: #A7E853;        /* verde de marca — SOLO acciones positivas / de pago */
  --accent-go-deep: #8FD13B;   /* tono más oscuro derivado, para extrusión / hover */
  --rule: rgba(11, 11, 11, 0.10);
  --rule-soft: rgba(11, 11, 11, 0.05);
  --gold: #C9A961;

  /* Tipografía */
  --font: 'Helvetica Neue', 'Helvetica', 'Inter', 'Arial', sans-serif;
  --serif: 'Iowan Old Style', 'Palatino', 'Georgia', serif;
}

html {
  forced-color-adjust: none;
  -webkit-forced-color-adjust: none;
  scroll-behavior: smooth;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font);
  font-weight: 400;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-soft);
  background: var(--paper-soft);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.005em;
}

::selection { background: var(--accent); color: #fff; }

a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
/* El hover rojo es SOLO para links de texto — nunca para botones (que se
   renderizan como <a> y, si no, heredaban texto rojo en hover). */
a:hover:not(.arete-btn):not(.arete-menubar-cta):not(.arete-landing-cta-btn) { color: var(--accent); }

img, svg { display: block; max-width: 100%; }

/* =====================================================
   LAYOUT MASTER
===================================================== */
.arete-page {
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  background: var(--paper-soft);
}

.arete-container {
  max-width: 760px;
  margin: 0 auto;
  width: 100%;
  background: var(--paper);
  box-shadow: 0 0 0 1px var(--rule), 0 40px 80px -20px rgba(0,0,0,0.06);
  padding: 32px 26px 48px;
  flex: 1;
}

@media (min-width: 720px) {
  .arete-container { margin: 32px auto; padding: 56px 56px 64px; }
}

/* Header simple */
.arete-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 28px;
  margin-bottom: 36px;
  border-bottom: 1px solid var(--rule);
}
.arete-header-mark {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}
.arete-header-mark:hover { color: var(--accent); }
.arete-header-meta {
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* Footer */
.arete-footer {
  padding: 32px 26px 40px;
  text-align: center;
  border-top: 1px solid var(--rule);
  background: var(--paper);
}
.arete-footer-text {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  line-height: 1.7;
}
.arete-footer-text .accent { color: var(--accent); }
.arete-footer-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: opacity 0.15s ease;
}
.arete-footer-link:hover { opacity: 0.6; }

/* =====================================================
   TIPOGRAFÍA EDITORIAL
===================================================== */
.arete-headline {
  font-size: clamp(28px, 7vw, 40px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.028em;
  color: var(--ink);
  margin-bottom: 16px;
}
.arete-headline em { font-style: normal; color: var(--accent); }

.arete-lead {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-mid);
  max-width: 580px;
  margin-bottom: 32px;
}

.arete-section-num {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.arete-section-num-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}
.arete-section-num-line {
  height: 1px;
  flex: 1;
  background: var(--rule);
}

/* =====================================================
   FORM
===================================================== */
.arete-form {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.arete-form-group {
  margin-top: 28px;
}
.arete-form-group:first-of-type { margin-top: 0; }

.arete-form-group-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
}

.arete-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 22px;
}

.arete-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 520px) {
  .arete-form-row { grid-template-columns: 1fr; gap: 0; }
}

.arete-form-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-form-label .req { color: var(--accent); margin-left: 3px; }

.arete-form-help {
  font-size: 12px;
  color: var(--ink-mute);
  font-weight: 400;
  letter-spacing: 0;
  margin-top: 2px;
}

/* Inputs estilo editorial: sin caja, solo border-bottom.
   Padding lateral 14px para que el texto nunca quede pegado al borde,
   incluso cuando el browser aplica fondo default (ej: input[type=number]). */
.arete-input,
.arete-textarea,
.arete-select {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--rule);
  border-radius: 0;
  padding: 12px 14px;
  font-family: var(--font);
  font-size: 15px;
  color: var(--ink);
  width: 100%;
  transition: border-color 0.15s ease;
  box-sizing: border-box;
}
.arete-input:focus,
.arete-textarea:focus,
.arete-select:focus {
  outline: 0;
  border-bottom-color: var(--ink);
}
.arete-input::placeholder,
.arete-textarea::placeholder { color: var(--ink-faint); }

/* Textarea: caja completa con borde fino. Distinto al input lineal porque
   un border-bottom en un campo de varias líneas queda visualmente colgado. */
.arete-textarea {
  border: 1px solid var(--rule);
  border-radius: 0;
  padding: 12px 14px;
  resize: vertical;
  min-height: 88px;
  line-height: 1.5;
}
.arete-textarea:focus {
  border: 1px solid var(--ink);
}

.arete-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='none' stroke='%230B0B0B' stroke-width='1.5' d='M1 1l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 4px center;
  padding-right: 24px;
  cursor: pointer;
}

/* Estado de error */
.arete-form-field.has-error .arete-input,
.arete-form-field.has-error .arete-textarea,
.arete-form-field.has-error .arete-select {
  border-bottom-color: var(--accent);
}

.arete-error {
  font-size: 12px;
  color: var(--accent);
  font-weight: 500;
  letter-spacing: 0.01em;
  margin-top: 4px;
  display: block;
}

/* Radio group inline */
.arete-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 6px 0;
}
.arete-radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}
.arete-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.arete-radio-label {
  display: inline-block;
  padding: 9px 16px;
  border: 1px solid var(--rule);
  border-radius: var(--m3-shape-sm);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mid);
  background: var(--paper);
  transition: all 0.15s ease;
  user-select: none;
}
.arete-radio:hover .arete-radio-label {
  border-color: var(--ink-mid);
  color: var(--ink);
}
.arete-radio input[type="radio"]:focus-visible + .arete-radio-label {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.arete-radio input[type="radio"]:checked + .arete-radio-label {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

/* Checkbox */
.arete-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  padding: 10px 0;
}
.arete-checkbox input[type="checkbox"] {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--accent);
  cursor: pointer;
}
.arete-checkbox-label {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-soft);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
}
.arete-checkbox-label a { color: var(--accent); }

/* =====================================================
   BOTONES
===================================================== */
/* UN SOLO SISTEMA DE BOTÓN — extrusión 3D push.
   Lo único que cambia por variante: background, color de texto y --btn-deep
   (el tono de la sombra dura). Misma forma, misma animación, mismo tamaño. */
.arete-btn {
  display: inline-block;
  position: relative;            /* anchor para el m3-loader absolute durante is-loading */
  padding: 14px 28px;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  border: none;
  background: var(--ink);
  color: var(--paper);
  cursor: pointer;
  transition: filter 0.16s ease, transform 0.12s ease, box-shadow 0.12s ease;
  user-select: none;
  line-height: 1.2;
  --btn-deep: var(--ink-soft);
  box-shadow: 0 4px 0 var(--btn-deep), 0 8px 14px rgba(0, 0, 0, 0.16);
}
.arete-btn:hover:not(:disabled) {
  filter: brightness(1.05);
}
.arete-btn:active:not(:disabled) {
  transform: translateY(4px);
  box-shadow: 0 0 0 var(--btn-deep);
}
.arete-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}
.arete-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Variantes — SOLO color. Nada de formas distintas. */
.arete-btn-primary {
  background: var(--accent);
  color: var(--paper);
  --btn-deep: var(--accent-deep);
}
.arete-btn-go {
  background: var(--accent-go);
  color: var(--ink);
  --btn-deep: #D4D4D4;          /* misma sombra gris claro que el secondary — los verdes "flotan" parejo */
}
.arete-btn-secondary {
  background: var(--paper);
  color: var(--ink);
  --btn-deep: #D4D4D4;          /* gris claro — la sombra hard-drop queda suave, no compite con el texto */
}
.arete-btn-ghost {
  background: var(--paper);
  color: var(--ink-mid);
  --btn-deep: var(--rule);
}

/* Estado "ya estás inscripto" — verde de marca, lee como confirmación viva
   (call-to-action), no como botón apagado. Misma forma 3D que el resto. */
.arete-btn-inscripto {
  background: var(--accent-go);
  color: var(--ink);
  --btn-deep: #D4D4D4;          /* misma sombra gris claro que el resto de verdes */
}

.arete-btn-block { display: block; width: 100%; }

.arete-btn-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
}
@media (min-width: 520px) {
  .arete-btn-stack.row { flex-direction: row; }
  .arete-btn-stack.row > * { flex: 1; }
}

/* =====================================================
   MODAL (overlay + dialog)
===================================================== */
.arete-modal {
  position: fixed;
  inset: 0;
  background: rgba(11, 11, 11, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 1000;
  animation: arete-fade 0.2s ease;
}
.arete-modal.is-open { display: flex; }

.arete-modal-dialog {
  background: var(--paper);
  max-width: 460px;
  width: 100%;
  padding: 36px 32px 32px;
  position: relative;
  box-shadow: 0 30px 60px -15px rgba(0,0,0,0.3);
  animation: arete-rise 0.25s cubic-bezier(0.2,0.8,0.2,1);
}
.arete-modal-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.arete-modal-title {
  font-size: clamp(20px, 4.6vw, 24px);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin-bottom: 14px;
  line-height: 1.2;
}
.arete-modal-body {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-mid);
  margin-bottom: 24px;
}
.arete-modal-body strong { color: var(--ink); font-weight: 700; }
.arete-modal-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (min-width: 480px) {
  .arete-modal-actions { flex-direction: row-reverse; }
  .arete-modal-actions > * { flex: 1; }
}

@keyframes arete-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes arete-rise {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* =====================================================
   TOAST (feedback bottom-right)
===================================================== */
.arete-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  background: var(--ink);
  color: var(--paper);
  padding: 14px 22px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 1100;
  max-width: calc(100vw - 48px);
}
.arete-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.arete-toast--success { border-left: 3px solid var(--gold); }
.arete-toast--error { border-left: 3px solid var(--accent); }

/* =====================================================
   BADGES (estados de inscripto)
===================================================== */
.arete-badge {
  display: inline-block;
  padding: 4px 10px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-mid);
  line-height: 1.3;
  font-variant-numeric: tabular-nums;
}
.arete-badge--wishlist {
  border-color: var(--ink-faint);
  background: var(--paper-warm);
  color: var(--ink-mid);
}
.arete-badge--pendiente_pago {
  border-color: var(--gold);
  background: rgba(201, 169, 97, 0.12);
  color: #7A6630;
}
.arete-badge--preinscripto {
  border-color: var(--ink);
  background: var(--paper);
  color: var(--ink);
}
/* Confirmado: verde de marca — lee como confirmación viva, no etiqueta apagada */
.arete-badge--confirmado {
  border-color: var(--accent-go-deep);
  background: var(--accent-go);
  color: var(--ink);
}
.arete-badge--cancelado {
  border-color: var(--ink-faint);
  background: var(--paper);
  color: var(--ink-mute);
  text-decoration: line-through;
}

/* =====================================================
   UTILIDADES
===================================================== */
.arete-divider {
  height: 1px;
  background: var(--rule);
  margin: 32px 0;
  border: 0;
}
.arete-divider-accent {
  width: 28px;
  height: 2px;
  background: var(--accent);
  margin: 0 0 20px;
  border: 0;
}
.arete-text-center { text-align: center; }
.arete-text-mute { color: var(--ink-mute); }
.arete-text-accent { color: var(--accent); }
.arete-mt-0 { margin-top: 0; }
.arete-mt-2 { margin-top: 16px; }
.arete-mt-4 { margin-top: 32px; }
.arete-mb-0 { margin-bottom: 0; }
.arete-mb-2 { margin-bottom: 16px; }
.arete-mb-4 { margin-bottom: 32px; }

.arete-hidden { display: none !important; }

.arete-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
  display: inline-block;
}

/* Hero check (registro_ok) */
.arete-confirm-hero {
  text-align: center;
  padding: 24px 0 36px;
}
.arete-confirm-check {
  width: 48px;
  height: 48px;
  margin: 0 auto 24px;
  color: var(--ink);
}
.arete-confirm-summary {
  margin-top: 36px;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  text-align: left;
}
.arete-confirm-summary-cell {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.arete-confirm-summary-key {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-confirm-summary-value {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
}

/* Accesibilidad: respeta reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* =====================================================
   ADMIN · panel interno
   Prefijo `arete-admin-` para no chocar con el público.
   Layout: sidebar fija a la izquierda + main scrolleable.
===================================================== */
.arete-admin-body {
  background: var(--paper-warm);
  font-family: var(--font);
  color: var(--ink-soft);
  min-height: 100vh;
  min-height: 100svh;
}

.arete-admin-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
  min-height: 100svh;
}
@media (max-width: 760px) {
  .arete-admin-shell { grid-template-columns: 1fr; }
}

/* Sidebar */
.arete-admin-sidebar {
  background: var(--ink);
  color: var(--paper);
  padding: 32px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  position: sticky;
  top: 0;
  height: 100vh;
  height: 100svh;
}
@media (max-width: 760px) {
  .arete-admin-sidebar {
    position: static;
    height: auto;
    padding: 22px 22px 18px;
  }
}

.arete-admin-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  text-decoration: none;
  color: var(--paper);
  letter-spacing: 0.2em;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.arete-admin-brand:hover { color: var(--paper); }
.arete-admin-brand-mark { color: var(--paper); }
.arete-admin-brand-sep { color: var(--accent); font-weight: 700; }
.arete-admin-brand-name { color: var(--paper); }

.arete-admin-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.arete-admin-nav-link {
  display: block;
  padding: 11px 14px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}
.arete-admin-nav-link:hover {
  color: var(--paper);
  background: rgba(255,255,255,0.04);
}
.arete-admin-nav-link.is-active {
  color: var(--paper);
  background: rgba(188, 0, 45, 0.18);
  border-left-color: var(--accent);
}

.arete-admin-sidebar-foot {
  border-top: 1px solid rgba(255,255,255,0.10);
  padding-top: 16px;
  margin-top: auto;
}

.arete-admin-nav-logout {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-decoration: none;
  padding: 8px 0;
}
.arete-admin-nav-logout:hover { color: var(--accent); }

/* Main */
.arete-admin-main {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100svh;
}
@media (max-width: 760px) {
  .arete-admin-main { min-height: auto; }
}

.arete-admin-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 32px;
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  gap: 16px;
}
@media (max-width: 520px) {
  .arete-admin-header { padding: 16px 20px; }
}
.arete-admin-header-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.32em;
  color: var(--ink);
  text-transform: uppercase;
}
.arete-admin-header-title .sep { color: var(--accent); margin: 0 4px; }

/* Badge alert (preinscriptos por validar) */
.arete-admin-badge-alert {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px 7px 10px;
  background: var(--accent);
  color: var(--paper);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--accent);
  transition: background 0.15s ease, transform 0.15s ease;
}
.arete-admin-badge-alert:hover {
  background: var(--accent-deep);
  color: var(--paper);
}
.arete-admin-badge-alert-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--paper);
  display: inline-block;
  animation: arete-admin-pulse 1.6s ease-in-out infinite;
}
.arete-admin-badge-alert-num {
  font-variant-numeric: tabular-nums;
  font-size: 12px;
  letter-spacing: 0.04em;
}
.arete-admin-badge-alert-label { letter-spacing: 0.18em; }

@keyframes arete-admin-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.85); }
}

/* Contenido */
.arete-admin-content {
  padding: 36px 32px 48px;
  flex: 1;
}
@media (max-width: 520px) {
  .arete-admin-content { padding: 24px 20px 36px; }
}

.arete-admin-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}

.arete-admin-h2 {
  font-size: clamp(22px, 4vw, 28px);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin-bottom: 28px;
  line-height: 1.2;
}

/* Cards */
.arete-admin-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  margin-bottom: 28px;
}

.arete-admin-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 22px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}
.arete-admin-card:hover {
  box-shadow: 0 12px 32px -16px rgba(0,0,0,0.18);
}

.arete-admin-card--featured {
  grid-column: 1 / -1;
  border-color: var(--ink);
}

.arete-admin-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.arete-admin-card-key {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-admin-card-cupo {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.arete-admin-card-flag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 3px 8px;
  background: rgba(188, 0, 45, 0.06);
}

.arete-admin-card-num {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-top: 4px;
}
.arete-admin-card-num--mute { color: var(--ink-mute); }

.arete-admin-card-foot {
  font-size: 12px;
  color: var(--ink-mute);
  line-height: 1.5;
  margin-top: 4px;
}

/* Progress bar */
.arete-admin-progress {
  height: 8px;
  background: var(--paper-warm);
  border: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
}
.arete-admin-progress-bar {
  height: 100%;
  background: var(--ink);
  transition: width 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  min-width: 0;
}
.arete-admin-progress-bar.is-full {
  background: var(--accent);
}

/* Aux line (pendientes de pago, total) */
.arete-admin-aux {
  border-top: 1px solid var(--rule);
  padding-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}
.arete-admin-aux-line {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.arete-admin-aux-key {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-admin-aux-num {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

/* Footer */
.arete-admin-foot {
  padding: 18px 32px;
  border-top: 1px solid var(--rule);
  background: var(--paper);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
@media (max-width: 520px) {
  .arete-admin-foot { padding: 14px 20px; }
}

/* =====================================================
   ADMIN — TABLA INSCRIPTOS (slice #7)
===================================================== */

.arete-admin-h2-mute {
  color: var(--ink-mute);
  font-weight: 500;
  font-size: 0.7em;
  letter-spacing: 0;
  margin-left: 8px;
}

/* Botones admin */
.arete-admin-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 16px;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.arete-admin-btn:hover { background: var(--accent); border-color: var(--accent); color: var(--paper); }
.arete-admin-btn--ghost {
  background: transparent;
  color: var(--ink);
}
.arete-admin-btn--ghost:hover {
  background: var(--ink);
  color: var(--paper);
}
.arete-admin-btn--danger {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--paper);
}
.arete-admin-btn--danger:hover {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
}
.arete-admin-btn--success {
  background: #0F6F3F;
  border-color: #0F6F3F;
  color: var(--paper);
}
.arete-admin-btn--success:hover {
  background: #0B5530;
  border-color: #0B5530;
  color: var(--paper);
}
.arete-admin-btn--sm {
  padding: 6px 12px;
  font-size: 10px;
  letter-spacing: 0.16em;
}
.arete-admin-btn:disabled,
.arete-admin-btn[disabled] {
  background: var(--ink-faint);
  border-color: var(--ink-faint);
  color: var(--paper);
  cursor: not-allowed;
  opacity: 0.6;
}

.arete-admin-btn-tiny {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--rule);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.arete-admin-btn-tiny:hover {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

/* Filtros */
.arete-admin-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: flex-end;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 18px 18px 16px;
  margin-bottom: 22px;
}
.arete-admin-filter {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 130px;
}
.arete-admin-filter--grow { flex: 1 1 200px; min-width: 180px; }
.arete-admin-filter--actions {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  align-self: flex-end;
}
.arete-admin-filter label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-admin-filter input,
.arete-admin-filter select,
.arete-admin-input {
  font-family: var(--font);
  font-size: 14px;
  padding: 8px 10px;
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--rule);
  outline: none;
  transition: border-color 0.15s ease;
  width: 100%;
}
.arete-admin-filter input:focus,
.arete-admin-filter select:focus,
.arete-admin-input:focus {
  border-color: var(--ink);
}

/* Tabla */
.arete-admin-table-wrap {
  background: var(--paper);
  border: 1px solid var(--rule);
  overflow-x: auto;
  margin-bottom: 22px;
}
.arete-admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.arete-admin-table thead th {
  background: var(--paper-warm);
  text-align: left;
  padding: 11px 14px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border-bottom: 1px solid var(--rule);
  white-space: nowrap;
}
.arete-admin-table tbody td {
  padding: 10px 14px;
  border-top: 1px solid var(--rule-soft);
  color: var(--ink-soft);
  vertical-align: middle;
}
.arete-admin-table tbody tr:hover {
  background: var(--paper-warm);
}
.arete-admin-table--compact thead th { padding: 8px 10px; }
.arete-admin-table--compact tbody td { padding: 7px 10px; font-size: 12.5px; }
.arete-admin-th-num,
.arete-admin-td-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.arete-admin-td-email { color: var(--ink-mid); }
.arete-admin-td-date {
  white-space: nowrap;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}
.arete-admin-th-actions,
.arete-admin-td-actions {
  text-align: right;
  white-space: nowrap;
}

/* Badges de estado */
.arete-admin-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  color: var(--ink-mid);
  white-space: nowrap;
}
.arete-admin-badge--lg {
  padding: 5px 11px;
  font-size: 10.5px;
  margin-left: 12px;
  vertical-align: middle;
}
.arete-admin-badge--wishlist {
  background: rgba(11,11,11,0.04);
  color: var(--ink-mid);
}
.arete-admin-badge--pendiente_pago {
  background: #FFF6DC;
  border-color: #E8C46B;
  color: #6E4F00;
}
.arete-admin-badge--preinscripto {
  background: #FFEAEF;
  border-color: var(--accent);
  color: var(--accent-deep);
}
.arete-admin-badge--confirmado {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.arete-admin-badge--cancelado {
  background: transparent;
  border-color: var(--rule);
  color: var(--ink-faint);
  text-decoration: line-through;
}

/* Paginación */
.arete-admin-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 0;
  flex-wrap: wrap;
}
.arete-admin-pagebtn {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  color: var(--ink);
  text-decoration: none;
  background: var(--paper);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.arete-admin-pagebtn:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.arete-admin-pagebtn.is-disabled {
  color: var(--ink-faint);
  border-color: var(--rule);
  background: var(--paper);
  cursor: not-allowed;
  pointer-events: none;
}
.arete-admin-pageinfo {
  font-size: 11.5px;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
}
.arete-admin-pageinfo strong {
  color: var(--ink);
  font-weight: 700;
}
.arete-admin-pageinfo-sub {
  color: var(--ink-faint);
  font-size: 11px;
  margin-left: 6px;
}

/* Empty state */
.arete-admin-empty {
  padding: 36px 24px;
  text-align: center;
  background: var(--paper);
  border: 1px dashed var(--rule);
  color: var(--ink-mute);
  font-size: 14px;
}
.arete-admin-empty-line {
  color: var(--ink-mute);
  font-size: 13px;
  padding: 8px 0;
}

/* =====================================================
   ADMIN — DETALLE INSCRIPTO
===================================================== */

.arete-admin-detail-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.arete-admin-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-bottom: 28px;
}

.arete-admin-detail-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 22px 22px 18px;
}

.arete-admin-detail-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
}

.arete-admin-dl {
  display: grid;
  grid-template-columns: minmax(100px, max-content) 1fr;
  gap: 8px 14px;
  font-size: 13.5px;
}
.arete-admin-dl dt {
  color: var(--ink-mute);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  align-self: center;
}
.arete-admin-dl dd {
  color: var(--ink);
  margin: 0;
  word-break: break-word;
}

.arete-admin-mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--ink-mid);
}
.arete-admin-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 280px;
  display: inline-block;
}

.arete-admin-section-block {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 22px 22px 18px;
  margin-bottom: 18px;
}

/* Audit log list */
.arete-admin-audit {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.arete-admin-audit-item {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: baseline;
  padding: 10px 0;
  border-top: 1px solid var(--rule-soft);
  font-size: 12.5px;
}
.arete-admin-audit-item:first-child { border-top: 0; }
.arete-admin-audit-when {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px;
  color: var(--ink-mute);
}
.arete-admin-audit-actor {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.arete-admin-audit-accion {
  font-weight: 700;
  color: var(--accent);
}
.arete-admin-audit-target {
  color: var(--ink-mute);
  font-size: 12px;
}
.arete-admin-audit-detalle {
  flex: 1 0 100%;
  margin: 4px 0 0;
  padding: 8px 12px;
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  font-size: 11.5px;
  color: var(--ink-mid);
  overflow-x: auto;
  white-space: pre-wrap;
}

/* Modal admin (variant) */
.arete-admin-modal-dialog {
  max-width: 520px;
}
.arete-admin-modal-dialog .arete-admin-input {
  margin: 8px 0 18px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 14px;
  letter-spacing: 0.06em;
}

/* ===== Pago — datos bancarios + form ===== */
.arete-pago-banco {
  margin-top: 32px;
  padding: 24px;
  background: var(--paper-warm);
  border: 1px solid var(--rule);
}
.arete-pago-datos {
  margin: 12px 0 0;
  display: grid;
  gap: 14px;
}
.arete-pago-datos > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.arete-pago-datos dt {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-pago-datos dd {
  margin: 0;
  font-size: 15px;
  color: var(--ink-soft);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.arete-pago-codigo {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 14px;
  letter-spacing: 0.05em;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 6px 10px;
  white-space: nowrap;
  overflow-x: auto;
  max-width: 100%;
}
.arete-pago-monto {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--accent);
}
.arete-btn-copy {
  font-size: 11px;
  padding: 6px 10px;
}
.arete-form-help {
  font-size: 12px;
  color: var(--ink-mute);
  margin: 0 0 12px;
}
.arete-form-help--destacado {
  display: inline-block;
  margin-top: 6px;
  padding: 8px 12px;
  background: #d8f3df;
  color: #1d5b34;
  border-left: 3px solid #2c8a4e;
  font-weight: 500;
}

/* =====================================================
   PERFIL (slice #5) — /perfil/:token
===================================================== */
.arete-perfil {
  padding: 8px 0 12px;
}

.arete-perfil-card {
  margin-top: 24px;
  padding: 22px 22px 24px;
  border: 1px solid var(--rule);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}
.arete-perfil-card--wishlist {
  background: var(--paper-warm);
  border-color: var(--rule);
}
/* Pendiente / preinscripto: tinte rojo sutil (sin border-left para no recargar) */
.arete-perfil-card--pendiente,
.arete-perfil-card--preinscripto {
  background: rgba(188, 0, 45, 0.04);
  border-color: var(--rule);
}
/* Confirmado: tinte verde de marca + acento lateral, lee como estado positivo vivo */
.arete-perfil-card--confirmado {
  background: rgba(167, 232, 83, 0.12);
  border-color: var(--accent-go-deep);
  border-left: 3px solid var(--accent-go-deep);
}
.arete-perfil-card--cancelado {
  background: var(--paper-soft);
  border-color: var(--ink-faint);
}
.arete-perfil-card .arete-btn-stack { width: 100%; }

.arete-perfil-mensaje {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--ink-mid);
  margin: 0;
}
.arete-perfil-mensaje strong { color: var(--ink); font-weight: 700; }

/* Lista de próximos encuentros (timeline minimal) */
.arete-perfil-encuentros {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
}
.arete-perfil-encuentros .arete-eyebrow {
  display: block;
  margin-bottom: 18px;
}
.arete-perfil-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.arete-perfil-timeline-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.arete-perfil-timeline-item:last-child {
  border-bottom: 0;
}
.arete-perfil-timeline-num {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--accent);
}
.arete-perfil-timeline-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.arete-perfil-timeline-fecha {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-perfil-timeline-tema {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.3;
}
.arete-perfil-timeline-meta {
  font-size: 12.5px;
  color: var(--ink-mid);
}

/* Bloque soporte (siempre visible) */
.arete-perfil-soporte {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.arete-perfil-soporte-text {
  font-size: 13.5px;
  color: var(--ink-mute);
  margin: 0;
}
.arete-perfil-soporte-btn {
  align-self: stretch;
}
@media (min-width: 480px) {
  .arete-perfil-soporte {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
  .arete-perfil-soporte-btn { align-self: auto; }
}

/* 404 perfil */
.arete-perfil-404 .arete-lead {
  margin-top: 8px;
}

/* Popup verde post-upload (3s no-dismissible) */
.arete-perfil-popup {
  position: fixed;
  inset: 0;
  background: rgba(11, 11, 11, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 1200;
  animation: arete-fade 0.2s ease;
}
.arete-perfil-popup.is-visible { display: flex; }
.arete-perfil-popup-dialog {
  background: var(--paper);
  max-width: 420px;
  width: 100%;
  padding: 36px 32px 32px;
  border-top: 4px solid #2E7D32;
  text-align: center;
  box-shadow: 0 30px 60px -15px rgba(0,0,0,0.3);
  animation: arete-rise 0.25s cubic-bezier(0.2,0.8,0.2,1);
}
.arete-perfil-popup-check {
  width: 44px;
  height: 44px;
  margin: 0 auto 16px;
  color: #2E7D32;
  display: block;
}
.arete-perfil-popup-title {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 8px;
}
.arete-perfil-popup-text {
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-mid);
  margin: 0;
}

/* =====================================================
   ADMIN — COLA DE PAGOS (slice #7)
===================================================== */

/* Botones de acción inline en la fila */
.arete-admin-action-inline {
  display: inline-block;
  margin: 0 4px 0 0;
}

/* Link sobre nombre del inscripto en la cola */
.arete-admin-link-row {
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s ease, color 0.15s ease;
}
.arete-admin-link-row:hover {
  border-bottom-color: var(--accent);
  color: var(--accent);
}

/* Ícono de ojo para abrir captura en pestaña nueva */
.arete-admin-link-eye {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-mid);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.arete-admin-link-eye:hover {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

/* Textarea + label dentro de modal */
.arete-admin-textarea {
  resize: vertical;
  min-height: 92px;
  font-family: var(--font);
  letter-spacing: 0;
  margin: 6px 0 14px;
}
.arete-admin-label-block {
  display: block;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 8px;
}

/* Badges de estado de pago (por si los reusamos en otras vistas) */
.arete-admin-badge--en_revision {
  background: #FFF6DC;
  border-color: #E8C46B;
  color: #6E4F00;
}
.arete-admin-badge--aprobado {
  background: #E5F2EB;
  border-color: #0F6F3F;
  color: #0B5530;
}
.arete-admin-badge--rechazado {
  background: transparent;
  border-color: var(--rule);
  color: var(--ink-faint);
  text-decoration: line-through;
}

/* ===== Perfil — footer discreto + mensaje de pool prioritario ===== */
.arete-perfil-footer {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--rule-soft);
  text-align: center;
}
.arete-perfil-footer-text {
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: 0.01em;
  margin: 0;
}
.arete-perfil-footer-link {
  color: var(--ink-mid);
  text-decoration: underline;
  text-decoration-color: var(--rule);
  text-underline-offset: 3px;
}
.arete-perfil-footer-link:hover {
  color: var(--ink);
  text-decoration-color: var(--ink);
}

/* Mensaje destacado para wishlist en pool prioritario (#1-#5) */
.arete-perfil-mensaje--alta,
.arete-pool-alta {
  border-left: 2px solid var(--accent-go);
  padding: 12px 16px;
  background: rgba(10, 125, 62, 0.04);
  margin-top: 16px;
}

/* ===== Animación del check de "inscripción recibida" =====
   El círculo se traza primero, después se dibuja el check.
   El verde se aplica al final con un fade del color. */
.arete-confirm-check {
  width: 56px;
  height: 56px;
  color: var(--ink);
  margin: 0 auto 24px;
  display: block;
}
.arete-confirm-check.is-animated {
  animation: arete-check-pop 480ms cubic-bezier(0.34, 1.56, 0.64, 1) 80ms backwards,
             arete-check-color 600ms ease 700ms both;
}
.arete-confirm-check-circle {
  stroke-dasharray: 138.23;
  stroke-dashoffset: 138.23;
}
.arete-confirm-check.is-animated .arete-confirm-check-circle {
  animation: arete-check-draw 600ms ease-out 100ms forwards;
}
.arete-confirm-check-path {
  stroke-dasharray: 32;
  stroke-dashoffset: 32;
}
.arete-confirm-check.is-animated .arete-confirm-check-path {
  animation: arete-check-draw-tick 280ms ease-out 600ms forwards;
}

@keyframes arete-check-pop {
  from { transform: scale(0.6); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}
@keyframes arete-check-draw {
  to { stroke-dashoffset: 0; }
}
@keyframes arete-check-draw-tick {
  to { stroke-dashoffset: 0; }
}
@keyframes arete-check-color {
  from { color: var(--ink); }
  to   { color: var(--accent-go); }
}

@media (prefers-reduced-motion: reduce) {
  .arete-confirm-check.is-animated,
  .arete-confirm-check.is-animated .arete-confirm-check-circle,
  .arete-confirm-check.is-animated .arete-confirm-check-path {
    animation: none;
  }
  .arete-confirm-check-circle,
  .arete-confirm-check-path { stroke-dashoffset: 0; }
  .arete-confirm-check { color: var(--accent-go); }
}

/* ===== Inputs: matar el azul de autofill del browser =====
   Chrome/Edge/Opera pinta el background de azul claro cuando el input
   tiene valor o el browser autocompleta. Lo neutralizamos con un inset
   shadow del color paper. */
.arete-input:-webkit-autofill,
.arete-textarea:-webkit-autofill,
.arete-select:-webkit-autofill,
.arete-input:-webkit-autofill:hover,
.arete-textarea:-webkit-autofill:hover,
.arete-input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--ink);
  -webkit-box-shadow: 0 0 0 100px var(--paper-soft) inset;
  box-shadow: 0 0 0 100px var(--paper-soft) inset;
  transition: background-color 5000s ease-in-out 0s;
  caret-color: var(--ink);
}

/* Cajas (textareas) — gris sutil + border-bottom dotted más visible
   para que se entienda que es zona de carga (no campo flotante).
   Pedido del operador: "se ve volando, agregale línea de puntos abajo
   o un poco más de contraste". */
.arete-textarea {
  background: #F5F5F5;
  border: 1px solid rgba(11, 11, 11, 0.08);
  border-bottom: 2px dashed rgba(11, 11, 11, 0.32);
  min-height: 72px;
  padding: 10px 14px;
}
.arete-textarea:focus {
  background: var(--paper);
}

/* ===== LANDING ===== */
.arete-landing { display: flex; flex-direction: column; gap: 36px; }
.arete-landing-hero { padding: 12px 0 24px; }
.arete-landing-title { font-size: clamp(32px, 8vw, 52px); margin-bottom: 18px; }
.arete-landing-lead { max-width: 620px; }

.arete-landing-countdown {
  margin-top: 24px;
  padding: 18px 20px;
  background: var(--paper-warm);
  border-left: 2px solid var(--ink);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.arete-landing-countdown-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-landing-countdown-numbers {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.arete-landing-countdown-numbers > div {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-variant-numeric: tabular-nums;
}
.arete-landing-countdown-numbers .n {
  font-size: clamp(28px, 6vw, 40px);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1;
}
.arete-landing-countdown-numbers .u {
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 4px;
}
.arete-landing-countdown-fecha {
  font-size: 13px;
  color: var(--ink-mid);
  letter-spacing: 0.02em;
}
.arete-landing-countdown-fecha em { font-style: italic; color: var(--ink); }

.arete-landing-counters {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 24px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 520px) {
  .arete-landing-counters { grid-template-columns: 1fr; }
}
.arete-landing-counter { text-align: center; padding: 8px; }
.arete-landing-counter-num {
  font-size: clamp(28px, 6vw, 38px);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.arete-landing-counter-num .den {
  font-size: 0.5em;
  font-weight: 500;
  color: var(--ink-mute);
}
.arete-landing-counter-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 6px;
}

.arete-text-accent-go { color: var(--accent-go); }
.arete-text-accent { color: var(--accent); }

.arete-landing-cta { padding: 16px 0 4px; }
.arete-landing-cta-main { font-size: 16px; padding: 18px 24px; }
.arete-landing-cta-help {
  text-align: center;
  font-size: 12.5px;
  margin-top: 12px;
}

.arete-landing-sesion {
  margin-top: 24px;
  padding: 24px;
  background: var(--paper-warm);
  text-align: center;
}
.arete-landing-sesion-text {
  margin-bottom: 16px;
  font-size: 14px;
  color: var(--ink-mid);
}

.arete-landing-login {
  padding-top: 32px;
  border-top: 1px solid var(--rule);
  max-width: 480px;
  margin: 0 auto;
  width: 100%;
}
.arete-landing-login-help { margin-bottom: 16px; font-size: 13px; }
.arete-landing-login-form { gap: 18px; max-width: none; }

/* ===== LOGIN dedicado ===== */
.arete-login {
  max-width: 480px;
  margin: 0 auto;
  padding: 24px 0;
}


/* ===== Login DNI tooltip (LEGACY — el tooltip flotante se removió porque
   se solapaba con el botón ENTRAR. Ahora va help text estático debajo
   del input + validación inline en rojo). Estas reglas quedan inertes
   porque el HTML ya no las usa. ===== */
.arete-login-dni-wrap {
  position: relative;
}
.arete-login-dni-tip {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 8px;
  padding: 12px 14px;
  background: rgba(11,11,11,0.05);
  border: 1px solid var(--rule);
  color: var(--ink-mid);
  font-size: 12.5px;
  line-height: 1.5;
  letter-spacing: 0.005em;
  box-shadow: 0 12px 28px -12px rgba(0,0,0,0.35);
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 5;
}
.arete-login-dni-tip::before {
  content: "";
  position: absolute;
  top: -6px;
  left: 18px;
  width: 12px;
  height: 12px;
  background: rgba(11,11,11,0.05);
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
  transform: rotate(45deg);
}
.arete-login-dni-tip strong {
  color: var(--ink);
  font-weight: 700;
  display: block;
  margin-bottom: 4px;
  letter-spacing: 0.01em;
}
.arete-login-dni-wrap:focus-within .arete-login-dni-tip {
  opacity: 1;
  transform: translateY(0);
}

/* =====================================================
   FLYER PORT — clases sin prefijo, scopeadas bajo
   `.arete-flyer` para evitar colisiones con `.arete-*`.
   El markup vive en views/partials/flyer-hero.ejs y
   views/partials/flyer-info.ejs.
===================================================== */
.arete-flyer { color: var(--ink-soft); }

/* ----- HERO ----- */
.arete-flyer .hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  background: var(--paper);
  overflow: hidden;
  padding: 32px 26px 28px;
}
.arete-flyer .hero::before,
.arete-flyer .hero::after {
  content: "";
  position: absolute;
  width: 18px; height: 18px;
  border: 1px solid var(--rule);
}
.arete-flyer .hero::before { top: 14px; left: 14px; border-right: 0; border-bottom: 0; }
.arete-flyer .hero::after  { top: 14px; right: 14px; border-left: 0; border-bottom: 0; }

.arete-flyer .hero-corner-bl,
.arete-flyer .hero-corner-br {
  position: absolute;
  width: 18px; height: 18px;
  border: 1px solid var(--rule);
}
.arete-flyer .hero-corner-bl { bottom: 14px; left: 14px; border-right: 0; border-top: 0; }
.arete-flyer .hero-corner-br { bottom: 14px; right: 14px; border-left: 0; border-top: 0; }

.arete-flyer .hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-flyer .hero-top .pulse {
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--accent);
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
  animation: arete-flyer-pulse 2.4s ease-in-out infinite;
}
@keyframes arete-flyer-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.6); }
}

/* Hero: solo la medalla dorada, estatica. */
.arete-flyer .hero-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto 8px;
  text-align: center;
}
.arete-flyer .hero-iso {
  width: min(48vw, 180px);
  height: auto;
  display: block;
}
@media (min-width: 720px) {
  .arete-flyer .hero-iso { width: 200px; }
}
@keyframes arete-flyer-fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.arete-flyer .hero-headline {
  text-align: center;
  margin: 36px auto 0;
  max-width: 540px;
  animation: arete-flyer-fadeUp 1s cubic-bezier(0.2,0.8,0.2,1) 0.4s both;
}
.arete-flyer .hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 22px;
}
.arete-flyer .hero-eyebrow::before,
.arete-flyer .hero-eyebrow::after {
  content: "";
  width: 18px;
  height: 1px;
  background: var(--accent);
}
.arete-flyer .hero-title {
  font-size: clamp(34px, 9.5vw, 56px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.038em;
  color: var(--ink);
  margin-bottom: 20px;
}
.arete-flyer .hero-title .accent { color: var(--accent); }
.arete-flyer .hero-sub {
  font-size: clamp(14px, 3.6vw, 16px);
  font-weight: 500;
  line-height: 1.55;
  color: var(--ink-mid);
  max-width: 420px;
  margin: 0 auto;
}
.arete-flyer .hero-divider {
  width: 28px;
  height: 2px;
  background: var(--accent);
  margin: 28px auto 0;
}

.arete-flyer .hero-coach {
  text-align: center;
  margin: 32px auto 0;
  max-width: 520px;
  animation: arete-flyer-fadeUp 1s cubic-bezier(0.2,0.8,0.2,1) 0.7s both;
}
.arete-flyer .coach-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.arete-flyer .coach-name {
  font-size: clamp(22px, 5.6vw, 30px);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin-bottom: 6px;
}
.arete-flyer .coach-role {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 24px;
}
.arete-flyer .coach-medals {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 22px;
  flex-wrap: nowrap;
}
.arete-flyer .medal {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
}
.arete-flyer .medal-img {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--paper-warm);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule);
  overflow: hidden;
  padding: 0;
}
.arete-flyer .medal-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.arete-flyer .medal-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-align: center;
  line-height: 1.3;
}
.arete-flyer .medal-label span {
  display: block;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: 0.16em;
  font-size: 8.5px;
  margin-top: 2px;
}

.arete-flyer .hero-foot {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 10px;
  animation: arete-flyer-fadeUp 1s cubic-bezier(0.2,0.8,0.2,1) 1s both;
}
.arete-flyer .hero-foot .line-1 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
}
.arete-flyer .hero-foot .line-2 {
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--ink-mid);
  font-weight: 600;
  text-transform: uppercase;
}
.arete-flyer .hero-foot .dot {
  color: var(--accent);
  font-size: 14px;
  line-height: 1;
}

/* ----- SECCIONES GENERICAS ----- */
.arete-flyer section.block {
  padding: 72px 26px 64px;
  border-top: 1px solid var(--rule);
}
.arete-flyer section.block.alt { background: var(--paper-warm); }

.arete-flyer .section-num {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}
.arete-flyer .section-num-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}
.arete-flyer .section-num-line {
  height: 1px;
  flex: 1;
  background: var(--rule);
}
.arete-flyer .section-title {
  font-size: clamp(28px, 7vw, 40px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.028em;
  color: var(--ink);
  margin-bottom: 16px;
}
.arete-flyer .section-title em {
  font-style: normal;
  color: var(--accent);
}
.arete-flyer .section-lead {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink-mid);
  max-width: 580px;
  margin-bottom: 36px;
}

/* ----- Sobre el entrenamiento ----- */
.arete-flyer .theory {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.arete-flyer .theory-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
}
.arete-flyer .theory-key {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding-top: 4px;
}
.arete-flyer .theory-value {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--ink-soft);
}
.arete-flyer .theory-value strong {
  color: var(--ink);
  font-weight: 700;
}

/* ----- Estructura ----- */
.arete-flyer .rounds {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.arete-flyer .round {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.arete-flyer .round-num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}
.arete-flyer .round-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.arete-flyer .round-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.arete-flyer .round-desc {
  font-size: 13px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--ink-mid);
}
.arete-flyer .round-time {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ----- Cronograma ----- */
.arete-flyer .calendar {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.arete-flyer .cal-row {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 14px;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.arete-flyer .cal-month {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
}
.arete-flyer .cal-topic {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink-soft);
  line-height: 1.4;
}
.arete-flyer .cal-topic strong {
  font-weight: 700;
  color: var(--ink);
}
.arete-flyer .cal-dates {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ----- Sandro Lopez ----- */
.arete-flyer .sandro {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: 12px;
}
.arete-flyer .sandro-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.arete-flyer .stat {
  padding: 22px 16px;
  text-align: center;
  border-right: 1px solid var(--rule);
}
.arete-flyer .stat:last-child { border-right: 0; }
.arete-flyer .stat-num {
  font-size: clamp(28px, 7vw, 38px);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 8px;
}
.arete-flyer .stat-num .accent { color: var(--accent); }
.arete-flyer .stat-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  line-height: 1.4;
}

/* fotos olimpicas dentro de la seccion Sandro (no estaba en el flyer original,
   se agrega aca segun el brief: "bio breve + 3 fotos olimpicas") */
.arete-flyer .sandro-photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.arete-flyer .sandro-photo {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.arete-flyer .sandro-photo img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
  border: 1px solid var(--rule);
  background: var(--paper);
}
.arete-flyer .sandro-photo figcaption {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  text-align: center;
  line-height: 1.3;
}
.arete-flyer .sandro-photo figcaption span {
  color: var(--ink-mute);
  font-weight: 500;
  letter-spacing: 0.16em;
  margin-left: 4px;
}

.arete-flyer .quote {
  position: relative;
  padding: 36px 28px 28px 56px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
}
.arete-flyer .quote-mark {
  position: absolute;
  top: 16px;
  left: 18px;
  font-family: var(--serif);
  font-size: 36px;
  line-height: 1;
  color: var(--accent);
  font-weight: 400;
  background: transparent;
  padding: 0;
  pointer-events: none;
}
.arete-flyer .quote-text {
  font-family: var(--serif);
  font-size: clamp(15px, 3.8vw, 17.5px);
  font-style: italic;
  line-height: 1.5;
  color: var(--ink-soft);
  margin-bottom: 14px;
}
.arete-flyer .quote-attr {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-flyer .quote-attr::before {
  content: "— ";
  color: var(--accent);
}

/* ----- Practico ----- */
.arete-flyer .glance {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
}
.arete-flyer .gcell {
  padding: 22px 18px;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
}
.arete-flyer .gcell-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.arete-flyer .gcell-value {
  font-size: clamp(22px, 5.6vw, 28px);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  line-height: 1.05;
}
.arete-flyer .gcell-value .unit {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: 0;
  margin-left: 4px;
}
.arete-flyer .gcell-value .accent { color: var(--accent); }
.arete-flyer .gcell-sub {
  font-size: 11px;
  font-weight: 500;
  color: var(--ink-mute);
  margin-top: 6px;
  letter-spacing: 0.02em;
}

.arete-flyer .cta {
  margin-top: 40px;
  padding: 32px 24px;
  background: var(--ink);
  color: var(--paper);
  text-align: center;
}
.arete-flyer .cta-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.arete-flyer .cta-title {
  font-size: clamp(22px, 5.4vw, 28px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.022em;
  margin-bottom: 14px;
  color: var(--paper);
}
.arete-flyer .cta-sub {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.72);
  max-width: 420px;
  margin: 0 auto 24px;
}
.arete-flyer .cta-link {
  display: inline-block;
  padding: 13px 26px;
  background: var(--accent);
  color: var(--paper);
  text-decoration: none;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  transition: background 0.2s;
}
.arete-flyer .cta-link:hover { background: var(--accent-deep); }

/* ----- DESKTOP ----- */
@media (min-width: 720px) {
  .arete-flyer .hero { padding: 56px 56px 48px; }
  .arete-flyer .hero-headline { margin-top: 48px; }
  .arete-flyer .hero-coach { margin-top: 44px; }
  .arete-flyer .medal-img { width: 64px; height: 64px; }
  .arete-flyer .hero-foot { margin-top: 48px; }

  .arete-flyer section.block { padding: 88px 56px 72px; }
  .arete-flyer .theory-row { grid-template-columns: 130px 1fr; gap: 28px; padding: 26px 0; }
  .arete-flyer .theory-value { font-size: 16px; }
  .arete-flyer .round { grid-template-columns: 50px 1fr auto; gap: 24px; padding: 24px 0; }
  .arete-flyer .round-name { font-size: 16px; }
  .arete-flyer .round-desc { font-size: 14px; }
  .arete-flyer .cal-row { grid-template-columns: 110px 1fr auto; gap: 24px; padding: 22px 0; }
  .arete-flyer .cal-topic { font-size: 16px; }
  .arete-flyer .glance { grid-template-columns: repeat(3, 1fr); }
  .arete-flyer .gcell { padding: 28px 22px; }
  .arete-flyer .quote { padding: 40px 36px 36px 72px; }
  .arete-flyer .quote-mark { font-size: 44px; left: 28px; top: 24px; }
}

/* ===== LANDING PRO — bloques que conviven con el flyer dentro de .sheet ===== */
.arete-landing-block {
  padding: 36px 26px 12px;
  background: var(--paper);
  border-top: 1px solid var(--rule);
}
.arete-landing-inner { max-width: 620px; margin: 0 auto; }

/* Countdown — formato HH:MM:SS:MS estilo digital */
.arete-landing-cd-wrap { text-align: center; margin-bottom: 32px; }
.arete-landing-cd-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.32em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 12px;
}
.arete-landing-cd {
  display: inline-flex; align-items: baseline; gap: 8px;
  font-variant-numeric: tabular-nums;
}
.arete-landing-cd-cell { display: inline-flex; flex-direction: column; align-items: center; }
.arete-landing-cd-n {
  font-size: clamp(36px, 8vw, 56px); font-weight: 700;
  letter-spacing: -0.04em; color: var(--ink); line-height: 1;
}
.arete-landing-cd-u {
  font-size: 9px; font-weight: 700; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute); margin-top: 6px;
}
.arete-landing-cd-sep {
  font-size: clamp(28px, 6vw, 40px); font-weight: 300; color: var(--ink-faint); align-self: center; margin-bottom: 14px;
}

/* Counters PRO */
.arete-landing-counters-pro {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  margin: 0 0 32px;
}
.arete-landing-counter-pro {
  text-align: center; padding: 22px 8px;
  border-right: 1px solid var(--rule);
}
.arete-landing-counter-pro:last-child { border-right: 0; }
.arete-landing-counter-pro-n {
  font-size: clamp(28px, 5vw, 36px); font-weight: 700; letter-spacing: -0.03em;
  color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums;
}
.arete-landing-counter-pro-n .den { font-size: 0.5em; font-weight: 500; color: var(--ink-mute); }
.arete-landing-counter-pro-l {
  font-size: 9.5px; font-weight: 700; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute); margin-top: 6px;
}
@media (max-width: 480px) {
  /* Mantenemos 3 columnas también en mobile (pedido del operador):
     cupos / disponibles / wishlist lado a lado, sin apilar. */
  .arete-landing-counters-pro { grid-template-columns: repeat(3, 1fr); }
  .arete-landing-counter-pro { padding: 16px 4px; }
  .arete-landing-counter-pro-l { letter-spacing: 0.16em; font-size: 8.5px; }
}

/* CTA PRO — botón grande, ocupa el ancho */
.arete-landing-cta-pro { text-align: center; margin-bottom: 12px; }
/* Modificador de TAMAÑO del CTA grande de la landing.
   El patrón visual (forma 3D, color, hover, active) lo da .arete-btn + su variante. */
.arete-landing-cta-btn {
  display: block;
  width: 100%;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
  padding: 18px 32px;
  font-size: 11px;
  letter-spacing: 0.28em;
}
.arete-landing-cta-help-pro {
  font-size: 12.5px; color: var(--ink-mute); margin: 14px auto 0; max-width: 480px; line-height: 1.55;
}

/* Login inline al final */
.arete-landing-login-block {
  padding: 40px 26px 56px;
  background: var(--paper-warm);
  border-top: 1px solid var(--rule);
}
.arete-landing-login-pro { text-align: center; max-width: 460px; margin: 0 auto; }
.arete-landing-login-title {
  font-size: 18px; font-weight: 700; letter-spacing: -0.012em; color: var(--ink); margin-bottom: 6px;
}
.arete-landing-login-help-pro {
  font-size: 13px; color: var(--ink-mid); margin-bottom: 18px; line-height: 1.55;
}
.arete-landing-login-error {
  font-size: 12.5px; color: var(--accent); padding: 10px 14px;
  background: rgba(188, 0, 45, 0.06); border-left: 2px solid var(--accent);
  margin-bottom: 14px; text-align: left;
}
.arete-landing-login-form-pro { display: flex; flex-direction: column; gap: 10px; }
.arete-landing-login-input {
  appearance: none; -webkit-appearance: none;
  background: var(--paper); border: 1px solid var(--rule);
  padding: 14px 16px; font-family: var(--font); font-size: 14px; color: var(--ink);
  letter-spacing: 0.005em; width: 100%; border-radius: var(--m3-shape-xs);
}
.arete-landing-login-input:focus { outline: 0; border-color: var(--ink); }
.arete-landing-login-input::placeholder { color: var(--ink-faint); }
.arete-landing-login-btn { margin-top: 6px; }

.arete-landing-sesion-pro {
  text-align: center; max-width: 460px; margin: 0 auto;
}
.arete-landing-sesion-text {
  font-size: 14px; color: var(--ink-mid); margin-bottom: 16px;
}
.arete-landing-sesion-text strong { color: var(--ink); }
.arete-landing-sesion-actions {
  display: flex; flex-direction: column; gap: 10px;
}

/* Compatibilidad: .sheet del flyer aplicado al wrapper de la landing */
.arete-flyer.sheet,
.sheet.arete-flyer {
  max-width: 760px;
  margin: 0 auto;
  background: var(--paper);
  min-height: 100vh;
  box-shadow: 0 0 0 1px var(--rule), 0 40px 80px -20px rgba(0,0,0,0.06);
}

/* ===== ACORDEÓN del flyer ===== */
.arete-flyer .arete-acc {
  border-top: 1px solid var(--rule);
  padding: 0;
  margin: 0;
}
.arete-flyer .arete-acc:last-of-type {
  border-bottom: 1px solid var(--rule);
}
.arete-flyer .arete-acc-summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: center;
  background: var(--paper);
  transition: background 0.15s ease;
  position: relative;
}
.arete-flyer .arete-acc-summary::-webkit-details-marker { display: none; }
.arete-flyer .arete-acc-summary:hover {
  background: var(--paper-soft);
}
/* Eyebrow decorativo oculto: el operador no quiere el simbolo decorativo */
.arete-flyer .arete-acc-eyebrow { display: none; }
.arete-flyer .arete-acc-title {
  font-size: clamp(20px, 4vw, 26px);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  line-height: 1.15;
  flex: 0 1 auto;
  max-width: 100%;
}
.arete-flyer .arete-acc-title em {
  font-style: normal;
  color: var(--accent);
}
/* Toggle: chevron pequeño y proporcionado a un costado del título.
   Posicionado en flujo flex (no absolute) para que NUNCA se desalinee. */
.arete-flyer .arete-acc-toggle {
  display: inline-block;
  width: 10px;
  height: 10px;
  position: relative;
  flex-shrink: 0;
  align-self: center;
  transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.arete-flyer .arete-acc-toggle::before {
  content: "";
  position: absolute;
  top: 1px;
  left: 1px;
  width: 7px;
  height: 7px;
  border-right: 1.5px solid var(--ink-mid);
  border-bottom: 1.5px solid var(--ink-mid);
  transform: rotate(45deg);
  transform-origin: 60% 60%;
}
.arete-flyer .arete-acc[open] .arete-acc-toggle {
  transform: rotate(180deg);
}
.arete-flyer .arete-acc-body {
  padding: 0 26px 36px;
  border-top: 1px solid var(--rule-soft);
  background: var(--paper-soft);
  animation: arete-acc-open 0.25s ease;
  overflow-x: hidden;
  word-wrap: break-word;
}
.arete-flyer .arete-acc-body .section-lead {
  padding-top: 22px;
}
/* El padre que se "pinea" — al abrirse, el summary queda sticky arriba durante el scroll */
.arete-flyer .arete-acc[open] .arete-acc-summary {
  position: sticky;
  top: 0;
  z-index: 4;
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
}
@keyframes arete-acc-open {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Cuando hay acordeones, el .arete-landing-block se hace más compacto */
.arete-flyer + .arete-landing-block,
.arete-flyer .arete-landing-block {
  padding: 28px 26px 24px;
}

/* Hero del flyer compacto cuando es landing (no flyer standalone) */
.arete-flyer.sheet .hero {
  min-height: auto;
  padding: 28px 26px 24px;
}
.arete-flyer.sheet .hero-coach {
  padding-bottom: 8px;
}
.arete-flyer.sheet .coach-medals {
  gap: 14px;
}
.arete-flyer.sheet .medal-img {
  width: 56px;
  height: 56px;
}
.arete-flyer.sheet .hero-title {
  font-size: clamp(28px, 6vw, 40px);
}

/* =====================================================
   TÉRMINOS Y CONDICIONES — página estática editorial
===================================================== */
.arete-terminos {
  max-width: 720px;
  margin: 0 auto;
  padding-bottom: 32px;
}
.arete-terminos-meta {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 24px;
}
.arete-terminos-doc {
  display: block;
}
.arete-terminos-item {
  border-top: 1px solid var(--rule);
  padding: 28px 0 4px;
}
.arete-terminos-item:first-child {
  border-top: 0;
  padding-top: 8px;
}
.arete-terminos-h2 {
  font-family: Helvetica, "Helvetica Neue", Arial, sans-serif;
  font-size: clamp(18px, 3.4vw, 22px);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0 0 14px;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.arete-terminos-num {
  display: inline-block;
  min-width: 28px;
  font-variant-numeric: tabular-nums;
  color: var(--accent);
  font-weight: 700;
}
.arete-terminos-item p {
  font-size: 15.5px;
  line-height: 1.75;
  color: var(--ink-mid);
  margin: 0 0 14px;
}
.arete-terminos-item p:last-child {
  margin-bottom: 0;
}
.arete-terminos-item strong {
  color: var(--ink);
  font-weight: 700;
}
.arete-terminos-item a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.arete-terminos-list {
  margin: 0 0 14px;
  padding-left: 20px;
  list-style: disc;
}
.arete-terminos-list li {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-mid);
  margin-bottom: 6px;
}
.arete-terminos-actions {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
}

/* Modal admin preview de captura — más ancho que el modal default */
.arete-modal-dialog--wide {
  max-width: 720px !important;
  width: 90vw;
}

/* Acordeón: animación más suave (era inmediata) */
.arete-flyer .arete-acc-body {
  animation: arete-acc-open 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
@keyframes arete-acc-open {
  from { opacity: 0; max-height: 0; transform: translateY(-6px); }
  to   { opacity: 1; max-height: 4000px; transform: translateY(0); }
}
/* Toggle más suave también */
.arete-flyer .arete-acc-toggle {
  transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ===== MENUBAR mobile-first =====
   Mobile (default): marca + "Mi perfil" + CTA "Inscribirme" verde.
   Tablet+ (≥720px): se suma "Inicio" entre la marca y "Mi perfil". */
.arete-menubar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--rule);
}
.arete-menubar-mark {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.arete-menubar-mark:hover,
.arete-menubar-mark:focus-visible { color: var(--accent); }
.arete-menubar-links {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-left: auto;
}
.arete-menubar-link {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mid);
  text-decoration: none;
  white-space: nowrap;
  padding: 8px 4px;
  transition: color 0.15s ease;
}
.arete-menubar-link:hover,
.arete-menubar-link:focus-visible { color: var(--ink); }
.arete-menubar-link--desktop { display: none; } /* Solo aparece en tablet+ */
.arete-menubar-link--mute {
  color: var(--ink-faint);
  opacity: 0.7;
}
.arete-menubar-link--mute:hover { opacity: 1; }

/* Modificador de TAMAÑO del CTA del menubar. El patrón visual lo da .arete-btn. */
.arete-menubar-cta {
  padding: 9px 14px;
  font-size: 10.5px;
  letter-spacing: 0.16em;
  white-space: nowrap;
  flex-shrink: 0;
}

@media (min-width: 720px) {
  .arete-menubar { padding: 14px 32px; gap: 24px; }
  .arete-menubar-mark { font-size: 14px; letter-spacing: 0.32em; }
  .arete-menubar-links { gap: 24px; }
  .arete-menubar-link { font-size: 11.5px; letter-spacing: 0.18em; }
  .arete-menubar-link--desktop { display: inline-block; }
  .arete-menubar-cta { padding: 11px 22px; font-size: 11.5px; letter-spacing: 0.2em; }
}

/* Mobile chico extra: bajar tamaño un poco si la pantalla < 360px */
@media (max-width: 359px) {
  .arete-menubar { padding: 10px 10px; }
  .arete-menubar-mark { font-size: 12px; letter-spacing: 0.22em; }
  .arete-menubar-link { font-size: 10px; letter-spacing: 0.12em; padding: 8px 2px; }
  .arete-menubar-cta { padding: 8px 11px; font-size: 9.5px; letter-spacing: 0.12em; }
  .arete-menubar-links { gap: 8px; }
}

/* ===== Admin flash post-aprobar/rechazar (toast con check verde animado) ===== */
.arete-admin-flash {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 999;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px 14px 14px;
  background: var(--paper);
  box-shadow: 0 12px 40px -8px rgba(0, 0, 0, 0.25);
  border-left: 4px solid var(--accent-go);
  min-width: 320px;
  max-width: 460px;
  animation: arete-admin-flash-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.arete-admin-flash.is-bad { border-left-color: var(--accent); }
.arete-admin-flash.is-leaving { animation: arete-admin-flash-out 0.35s ease forwards; }
.arete-admin-flash-check {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  color: var(--accent-go);
}
.arete-admin-flash.is-bad .arete-admin-flash-check { color: var(--accent); }
.arete-admin-flash-check .c {
  stroke-dasharray: 138; stroke-dashoffset: 138;
}
.arete-admin-flash-check.is-animated .c {
  animation: arete-admin-flash-circle 500ms ease-out 80ms forwards;
}
.arete-admin-flash-check .p {
  stroke-dasharray: 32; stroke-dashoffset: 32;
}
.arete-admin-flash-check.is-animated .p {
  animation: arete-admin-flash-tick 280ms ease-out 580ms forwards;
}
@keyframes arete-admin-flash-circle { to { stroke-dashoffset: 0; } }
@keyframes arete-admin-flash-tick   { to { stroke-dashoffset: 0; } }
.arete-admin-flash-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 2px;
  letter-spacing: -0.005em;
}
.arete-admin-flash-text {
  font-size: 12.5px;
  color: var(--ink-mid);
  margin: 0;
  line-height: 1.45;
}
.arete-admin-flash-text strong { color: var(--ink); font-weight: 700; }
.arete-admin-flash-close {
  background: transparent;
  border: 0;
  color: var(--ink-mute);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
  margin-left: auto;
  align-self: flex-start;
}
.arete-admin-flash-close:hover { color: var(--ink); }
@keyframes arete-admin-flash-in {
  from { opacity: 0; transform: translateX(20px) scale(0.96); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes arete-admin-flash-out {
  to { opacity: 0; transform: translateX(20px) scale(0.96); }
}

@media (prefers-reduced-motion: reduce) {
  .arete-admin-flash,
  .arete-admin-flash.is-leaving { animation: none; }
  .arete-admin-flash-check.is-animated .c,
  .arete-admin-flash-check.is-animated .p { animation: none; stroke-dashoffset: 0; }
}

/* Centra el botón "Asegurar mi lugar (pagar)" del card wishlist del perfil */
.arete-perfil-cta-form {
  margin: 12px 0 0;
  display: flex;
  justify-content: center;
}
.arete-perfil-cta-form .arete-btn {
  width: 100%;
  max-width: 360px;
}

/* Badges del filtro competidor en admin/inscripto_detalle */
.arete-admin-badge--competidor {
  background: #E7F5EC;
  border-color: #5BA77A;
  color: #1F5733;
}
.arete-admin-badge--no-competidor {
  background: rgba(11,11,11,0.04);
  border-color: var(--rule);
  color: var(--ink-mid);
}

/* ===== Selector cinto: grilla de radios visuales con swatch + nombre =====
   Reemplaza al <select> nativo (Chrome ignora estilos custom en <option>). */
.arete-cinto-group {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 6px;
}
@media (max-width: 560px) {
  .arete-cinto-group { grid-template-columns: repeat(3, 1fr); }
}
.arete-cinto {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 10px 6px;
  border: 1px solid var(--rule);
  background: var(--paper);
  cursor: pointer;
  text-align: center;
  user-select: none;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.arete-cinto input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}
.arete-cinto-swatch {
  display: block;
  width: 28px;
  height: 28px;
  border-radius: 4px;
  border: 1px solid rgba(0,0,0,0.12);
}
.arete-cinto-name {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-mute);
  transition: color 0.15s ease;
}
.arete-cinto--blanco  .arete-cinto-swatch { background: #FFFFFF; }
.arete-cinto--azul    .arete-cinto-swatch { background: #1E40AF; }
.arete-cinto--violeta .arete-cinto-swatch { background: #6B21A8; }
.arete-cinto--marron  .arete-cinto-swatch { background: #6B3410; }
.arete-cinto--negro   .arete-cinto-swatch { background: #0B0B0B; }

.arete-cinto:has(input:checked) {
  border-color: var(--ink);
  background: var(--ink);
}
.arete-cinto:has(input:checked) .arete-cinto-name {
  color: var(--paper);
}
.arete-cinto:has(input:checked) .arete-cinto-swatch {
  border-color: rgba(255,255,255,0.3);
}
.arete-cinto:focus-within {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ===== Card IBJJF: muestra categoria por peso + edad en vivo ===== */
.arete-ibjjf-card {
  border: 1px solid var(--rule);
  padding: 14px 16px;
  margin: 16px 0 4px;
  background: rgba(11,11,11,0.025);
}
.arete-ibjjf-card-title {
  margin: 0 0 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.arete-ibjjf-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 4px 0;
}
.arete-ibjjf-row + .arete-ibjjf-row {
  border-top: 1px dashed rgba(11,11,11,0.08);
  margin-top: 4px;
  padding-top: 8px;
}
.arete-ibjjf-row-label {
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
}
.arete-ibjjf-row-value {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  text-align: right;
}
.arete-ibjjf-row-rango {
  font-size: 11px;
  font-weight: 400;
  color: var(--ink-mute);
}
.arete-ibjjf-empty {
  font-size: 12px;
  font-style: italic;
  font-weight: 400;
  color: var(--ink-faint);
}

/* === normalización UI pre-evento === */

/* --- registro_ok: ritmo vertical y alineación coherentes --- */

/* Lead del hero: centrado y con ancho de lectura, sin estilos inline */
.arete-confirm-lead {
  max-width: 46ch;
  margin-left: auto;
  margin-right: auto;
}

/* Badge de estado debajo del lead: separado parejo, centrado en el hero */
.arete-confirm-hero .arete-badge {
  margin-top: 14px;
}

/* Email del summary: más chico y con corte de palabra, antes era inline */
.arete-confirm-summary-value--email {
  font-size: 13px;
  word-break: break-all;
}

/* Bloque de ayuda forzado a ancho completo (reemplaza display:block inline) */
.arete-form-help--block {
  display: block;
}

/* Error de código a ancho completo con respiro vertical (reemplaza inline) */
.arete-error--block {
  display: block;
  padding: 8px 0;
}

/* Nota final "Listo, todo OK": integrada al ritmo, alineación coherente */
.arete-confirm-nota {
  margin-top: 28px;
  text-align: left;
}

/* Form dentro del stack de acciones: ocupa su celda como el resto */
.arete-confirm-action-form {
  margin: 0;
  display: flex;
}
.arete-confirm-action-form > .arete-btn {
  flex: 1;
}

/* Ritmo vertical parejo del hero: hero -> summary -> solapas -> acciones -> nota.
   El gap base lo dan los .arete-mt-* del markup; acá emparejamos el summary. */
.arete-confirm-summary {
  margin-top: 28px;
}

/* --- Solapas (tabs) pago / código: solapas de verdad, no botoncitos grises --- */
.arete-tabs-nav {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--rule);
}
.arete-tab {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  padding: 12px 18px;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  cursor: pointer;
  line-height: 1.2;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}
.arete-tab:hover:not(.is-active) {
  color: var(--ink-mid);
  background: var(--paper-warm);
}
.arete-tab.is-active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}
.arete-tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

/* Paneles de las solapas: solo el activo visible, con respiro arriba */
.arete-tab-panel {
  display: none;
  padding-top: 22px;
}
.arete-tab-panel.is-active {
  display: block;
}

/* Acordeón explicativo dentro del panel de transferencia */
.arete-accordion {
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  padding: 0 16px;
}
.arete-accordion-summary {
  cursor: pointer;
  padding: 14px 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  list-style: none;
}
.arete-accordion-summary::-webkit-details-marker {
  display: none;
}
.arete-accordion-summary::after {
  content: "+";
  float: right;
  font-weight: 700;
  color: var(--ink-mute);
}
.arete-accordion[open] .arete-accordion-summary::after {
  content: "–";
}
.arete-accordion-body {
  padding: 0 0 16px;
  border-top: 1px solid var(--rule);
  padding-top: 14px;
}

/* --- registro: "dos caminos" (#18) — el markup venía sin CSS, todo pegado --- */
.arete-dos-caminos {
  display: grid;
  gap: 16px;
  margin-top: 16px;
}
@media (min-width: 600px) {
  .arete-dos-caminos { grid-template-columns: 1fr 1fr; }
}
.arete-camino {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px;
  margin-top: 16px;
  border: 1px solid var(--rule);
  background: var(--paper);
}
.arete-dos-caminos .arete-camino { margin-top: 0; }
.arete-camino-titulo {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.arete-camino-texto {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-mid);
  flex: 1;
}
.arete-camino .arete-btn { margin-top: 8px; }

/* --- flyer · estructura de clase: hora arriba, duración abajo (#8) --- */
.round-time-clock {
  display: block;
  font-weight: 700;
  white-space: nowrap;
}
.round-time-dur {
  display: block;
  margin-top: 2px;
  font-size: 0.82em;
  font-weight: 400;
  color: var(--ink-mute);
}
.round--pausa { opacity: 0.7; }

/* --- registro_ok: 3 cards distintas — perfil / pago+código / acciones (#25) --- */
.arete-card {
  border: 1px solid var(--rule);
  background: var(--paper);
  padding: 24px;
  margin-top: 16px;
  text-align: left;
}
.arete-card:first-of-type { margin-top: 28px; }
.arete-card .arete-confirm-summary { margin-top: 0; }
.arete-card .arete-confirm-nota { margin-top: 18px; }
.arete-card > .arete-btn-stack { margin-top: 0; }

/* === Material Design 3 — Shape tokens por componente ===
   Spec: https://m3.material.io/styles/shape/overview
   Reemplaza el radius global de 16 por niveles según jerarquía visual.
   Compat: --radius (16px) se mantiene para overrides legacy que aún lo usan.
*/
:root {
  --radius: 16px;             /* legacy, no romper */
  --m3-shape-xs: 4px;         /* inputs, text fields (declarada en bloque Outlined) */
  --m3-shape-sm: 8px;         /* chips, snackbars, badges, toasts, tags */
  --m3-shape-md: 12px;        /* cards, botones */
  --m3-shape-lg: 16px;        /* containers extendidos, sections grandes */
  --m3-shape-xl: 28px;        /* modales, bottom sheets */
}

/* MD — cards y contenedores (la mayoría de los rectángulos del sitio) */
.arete-card,
.arete-perfil-card,
.arete-pago-banco,
.arete-ibjjf-card,
.arete-accordion,
.arete-confirm-summary,
.arete-tab-panel,
.arete-acc,
.round {
  border-radius: var(--m3-shape-md);
}

/* SM — controles y chips: botones, radios, cintos, badges, toasts,
   etiquetas inline, mensajes inline. Mismo radius para todo lo que
   "se ve como botón o tag" (feedback del operador: bajar contraste de
   forma + unificar familia de controles al mínimo M3). */
.arete-btn,
.arete-cinto,
.arete-toast,
.arete-badge,
.arete-section-num-tag,
.arete-pago-codigo,
.arete-error,
.arete-error--block {
  border-radius: var(--m3-shape-sm);
}

/* LG — containers de hoja, popups grandes */
.arete-flyer.sheet,
.arete-perfil-popup-dialog {
  border-radius: var(--m3-shape-lg);
}

/* XL — modales (la jerarquía visual M3 los pone arriba de cards) */
.arete-modal-dialog {
  border-radius: var(--m3-shape-xl);
}

/* =====================================================================
   MATERIAL DESIGN 3 — OUTLINED TEXT FIELD
   Spec: https://m3.material.io/components/text-fields/overview
   Variante usada: Outlined (caja con border 1px, no Filled).
   Decisión: mantenemos label arriba estática (no flotante notched) para
   no romper el HTML existente — el form es largo y la label fija + help
   text leen mejor en mobile que la label flotante con notch.
   ===================================================================== */
:root {
  /* M3 tokens — armonizados con la paleta de marca. El "primary" usa el rojo
     de Areté en vez del default morado de M3 (esto NO es Material genérico,
     es M3 + tokens de marca). */
  --m3-outline: #79747E;
  --m3-outline-variant: #C4C7C5;
  --m3-primary: var(--accent);          /* #BC002D rojo de marca */
  --m3-error: #B3261E;
  --m3-on-surface: var(--ink);
  --m3-on-surface-variant: var(--ink-mute);
  --m3-shape-xs: 4px;   /* extra-small — inputs */
}

/* Inputs Outlined: caja con border 1px en TODOS los lados (no más
   border-bottom editorial). Padding M3 vertical 16px / horizontal 14px. */
.arete-input,
.arete-textarea,
.arete-select {
  border: 1px solid var(--m3-outline);
  border-bottom: 1px solid var(--m3-outline);   /* anula el border-bottom legacy */
  border-radius: var(--m3-shape-xs);
  padding: 16px 14px;
  background: transparent;
}

/* Focus: border 2px primary, sin shadow (M3 lo prefiere limpio). El border
   crece de 1 a 2 — compensamos el padding restando 1px para que el contenido
   no se desplace. */
.arete-input:focus,
.arete-textarea:focus,
.arete-select:focus {
  outline: 0;
  border: 2px solid var(--m3-primary);
  border-bottom: 2px solid var(--m3-primary);
  padding: 15px 13px;
}

/* Hover: oscurece levemente el outline (M3 state layer). */
.arete-input:hover:not(:focus):not(:disabled),
.arete-textarea:hover:not(:focus):not(:disabled),
.arete-select:hover:not(:focus):not(:disabled) {
  border-color: var(--m3-on-surface);
  border-bottom-color: var(--m3-on-surface);
}

/* Disabled: opacity 0.38 (M3 spec), border outline-variant. */
.arete-input:disabled,
.arete-textarea:disabled,
.arete-select:disabled {
  opacity: 0.38;
  cursor: not-allowed;
  border-color: var(--m3-outline-variant);
  border-bottom-color: var(--m3-outline-variant);
}

/* Estado de error: border 2px error en todos los lados. */
.arete-form-field.has-error .arete-input,
.arete-form-field.has-error .arete-textarea,
.arete-form-field.has-error .arete-select {
  border: 2px solid var(--m3-error);
  border-bottom: 2px solid var(--m3-error);
  padding: 15px 13px;
}

/* Override select arrow (mantiene el patrón del data URI, alineado al nuevo padding) */
.arete-select {
  padding-right: 32px;
  background-position: right 12px center;
}

/* =====================================================================
   MATERIAL DESIGN 3 EXPRESSIVE — LOADING INDICATOR (morfeante)
   Spec: https://m3.material.io/components/loading-indicator/overview
   Para cargas cortas (<5s). Reemplaza el spinner circular indeterminate.
   ===================================================================== */
.m3-loader {
  display: inline-block;
  vertical-align: middle;
  position: relative;
}
.m3-loader-svg {
  width: 100%;
  height: 100%;
  /* Rotación constante: el "movimiento" del indicador. */
  animation: m3-loader-rotate 2s linear infinite;
}
.m3-loader-shape {
  fill: var(--m3-primary);
  transform-origin: center;
  /* Morfeo: cross-fade entre círculo (shape A) y trébol de 4 lóbulos (shape B). */
}
.m3-loader-shape--a {
  animation: m3-loader-fade-circle 1.6s ease-in-out infinite;
}
.m3-loader-shape--b {
  animation: m3-loader-fade-clover 1.6s ease-in-out infinite;
}

/* Modificador inline: para usar el loader dentro de un botón al lado del label.
   Tamaño chico, color sobre fondo del botón. */
.m3-loader--inline {
  width: 18px;
  height: 18px;
  margin-right: 8px;
}
.m3-loader--on-primary .m3-loader-shape {
  fill: #ffffff;
}

/* Overlay full-screen: para transiciones entre pantallas o cargas pesadas. */
.m3-loader-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.m3-loader-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

/* Estado de form en submit: el loader queda absolute centered sobre el botón
   y el texto pasa a transparent. El botón conserva su ancho y el texto no
   se desplaza al inyectar el SVG (feedback del operador: "al click se
   descentra el texto"). M3 spec recomienda esconder el label durante loading. */
.arete-btn .m3-loader { display: none; }
.arete-btn.is-loading {
  cursor: progress;
  pointer-events: none;
  opacity: 0.85;
  color: transparent;
}
.arete-btn.is-loading .m3-loader {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;                     /* anula el margin-right del modifier --inline */
}

@keyframes m3-loader-rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes m3-loader-fade-circle {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0; transform: scale(0.85); }
}
@keyframes m3-loader-fade-clover {
  0%, 100% { opacity: 0; transform: scale(0.85); }
  50%      { opacity: 1; transform: scale(1); }
}

/* Reduced motion: respetar prefers-reduced-motion (a11y). */
@media (prefers-reduced-motion: reduce) {
  .m3-loader-svg { animation-duration: 4s; }
  .m3-loader-shape--a,
  .m3-loader-shape--b { animation: none; opacity: 1; }
  .m3-loader-shape--b { opacity: 0; }
}

/* =====================================================================
   MATERIAL DESIGN 3 — CARDS (3 variantes por jerarquía visual)
   Spec: https://m3.material.io/components/cards/overview
   - Outlined: border 1px, sin sombra. Para bloques de info plana.
   - Elevated: sombra suave, sin border. Para info que "flota" sobre el fondo.
   - Filled:   bg tinted, sin border ni sombra. Para info secundaria/agrupada.
   Clases utility nuevas. Las cards existentes (.arete-card, .arete-perfil-card,
   etc.) tambien adoptan el border M3 outline-variant abajo para coherencia visual.
   ===================================================================== */
.m3-card {
  padding: 16px;
  border-radius: var(--m3-shape-md);
  background: var(--paper);
}
.m3-card--outlined {
  border: 1px solid var(--m3-outline-variant);
  box-shadow: none;
}
.m3-card--elevated {
  border: 0;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.10);
}
.m3-card--filled {
  border: 0;
  background: var(--paper-warm);
  box-shadow: none;
}

/* Coherencia: las cards de info existentes adoptan el outline M3.
   No tocamos las cards con tinte semántico (perfil-card--confirmado/wishlist/etc.)
   — sus border-colors ya están definidos abajo en su bloque y los respetan via
   especificidad de selector con modificador. */
.arete-card,
.arete-perfil-card,
.arete-pago-banco,
.arete-ibjjf-card,
.arete-admin-detail-card,
.arete-admin-section-block,
.arete-tab-panel {
  border-color: var(--m3-outline-variant);
}
