/* =========================================================================
   Líderes Aumentados · capa de diseño compartida
   Origen único de verdad: tokens + base + componentes + movimiento.
   Linkeado desde admin.html, hub.html, casa.html, login.html.
   Cada página conserva solo su CSS específico.
   ========================================================================= */

:root{
  /* --- Paleta --- */
  --bg:#14110D;            /* fondo base, oscuro cálido */
  --bg2:#181410;           /* fondo escalonado para profundidad */
  --surface:#1C1813;       /* tarjetas */
  --surface2:#221D16;      /* inputs, items anidados */
  --surface3:#272118;      /* hover de superficies */
  --text:#ECE4D4;          /* texto principal, crema */
  --muted:#A79E8C;         /* texto secundario (subido de #9C9484 por contraste) */
  --muted-dim:#7E7565;     /* texto terciario muy tenue */
  --gold:#C9A962;          /* dorado de marca */
  --gold-soft:#D8BE83;     /* dorado claro para hover/realces */
  --gold-dim:#7E6C3E;      /* dorado apagado */
  --gold-ink:#1A1407;      /* texto sobre fondo dorado */
  --green:#84A98C;
  --amber:#D8B66A;
  --danger:#E0796B;
  --line:rgba(201,169,98,.16);        /* borde tenue dorado */
  --line-strong:rgba(201,169,98,.34); /* borde dorado en hover/foco */
  --track:rgba(236,228,212,.10);      /* riel de barras */

  /* --- Tipografía --- */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat',system-ui,-apple-system,sans-serif;

  /* --- Escala de espaciado --- */
  --s1:6px; --s2:10px; --s3:14px; --s4:20px; --s5:28px; --s6:40px;

  /* --- Radios --- */
  --r1:10px; --r2:14px; --r3:18px; --r-pill:99px;

  /* --- Sombras + glow --- */
  --shadow-1:0 1px 2px rgba(0,0,0,.20);
  --shadow-2:0 8px 24px -8px rgba(0,0,0,.45);
  --shadow-3:0 18px 50px -12px rgba(0,0,0,.60);
  --glow-gold:0 0 0 3px rgba(201,169,98,.18);  /* anillo de foco */
  --glow-soft:0 0 40px -8px rgba(201,169,98,.22);

  /* --- Movimiento --- */
  --ease:cubic-bezier(.2,.7,.2,1);            /* ease-out premium */
  --ease-spring:cubic-bezier(.34,1.56,.64,1); /* rebote suave (momentos) */
  --dur-1:120ms;  /* taps / micro */
  --dur-2:240ms;  /* entradas / transiciones */
  --dur-3:440ms;  /* momentos grandes */
}

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

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* Profundidad: glow radial dorado muy sutil arriba + grano fino encima. */
  background-image:
    radial-gradient(120% 60% at 50% -10%, rgba(201,169,98,.07), rgba(201,169,98,0) 60%),
    linear-gradient(180deg, var(--bg2), var(--bg) 240px);
  background-attachment:fixed;
}

/* Grano fino sobre todo el fondo (sin requests: SVG noise en data-URI). */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body > *{position:relative;z-index:1}

::selection{background:rgba(201,169,98,.30);color:var(--text)}

/* Foco visible y consistente en todo (accesibilidad + feel premium). */
:focus-visible{outline:none;box-shadow:var(--glow-gold);border-radius:var(--r1)}

/* =========================================================================
   Marca (wordmark + glyph)
   ========================================================================= */
.brand{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:.28em;color:var(--gold);
  text-transform:uppercase;font-weight:500;
}
.brand .glyph{width:17px;height:17px;flex-shrink:0;display:block;color:var(--gold)}
.brand .glyph path{fill:currentColor}

/* =========================================================================
   Botones
   ========================================================================= */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--gold);color:var(--gold-ink);border:0;
  border-radius:var(--r-pill);
  font-family:var(--sans);font-weight:600;font-size:13px;
  padding:11px 20px;cursor:pointer;
  transition:transform var(--dur-1) var(--ease), filter var(--dur-1) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.btn:hover{filter:brightness(1.06)}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.55;cursor:default;transform:none;filter:none}
.btn--ghost{background:none;border:1px solid var(--line);color:var(--muted)}
.btn--ghost:hover{border-color:var(--line-strong);color:var(--text);filter:none}

/* Estado loading: oculta el texto y muestra un spinner. */
.btn.is-loading{color:transparent !important;pointer-events:none}
.btn.is-loading::after{
  content:"";position:absolute;width:15px;height:15px;border-radius:50%;
  border:2px solid rgba(26,20,7,.35);border-top-color:var(--gold-ink);
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================================
   Inputs / textarea / select
   ========================================================================= */
.field,
input[type=text],input[type=email],input[type=tel],input[type=number],
input[type=date],input[type=time],input:not([type]),textarea,select{
  background:var(--surface2);border:1px solid var(--line);border-radius:var(--r1);
  color:var(--text);font-family:var(--sans);font-size:14px;padding:11px 13px;width:100%;
  transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-2) var(--ease), background var(--dur-1) var(--ease);
}
input::placeholder,textarea::placeholder{color:var(--muted-dim)}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--gold-dim);box-shadow:var(--glow-gold);background:var(--surface3);
}
select{
  appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:34px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A962' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
}

/* Checkbox custom (caja dorada con check animado). Markup:
   <label class="check"><input type="checkbox"><span class="box"></span> Texto</label> */
.check{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.check input{position:absolute;opacity:0;width:0;height:0}
.check .box{
  width:20px;height:20px;flex-shrink:0;border:1.5px solid var(--gold-dim);
  border-radius:6px;position:relative;transition:all var(--dur-1) var(--ease);
}
.check .box::after{
  content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;
  border:solid var(--gold-ink);border-width:0 2px 2px 0;
  transform:rotate(45deg) scale(0);transform-origin:center;
  transition:transform var(--dur-2) var(--ease-spring);
}
.check input:checked + .box{background:var(--gold);border-color:var(--gold)}
.check input:checked + .box::after{transform:rotate(45deg) scale(1)}
.check input:focus-visible + .box{box-shadow:var(--glow-gold)}

/* =========================================================================
   Tarjetas, pills, labels
   ========================================================================= */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r3);
  padding:var(--s4);box-shadow:var(--shadow-1);
}
.pill{
  font-size:11px;padding:3px 9px;border-radius:var(--r-pill);
  border:1px solid var(--line);color:var(--muted);
}
.label{
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:10px;
}

/* =========================================================================
   Skeletons (placeholders con shimmer mientras carga)
   ========================================================================= */
.skeleton{
  position:relative;overflow:hidden;background:var(--surface2);
  border-radius:var(--r1);
}
.skeleton::after{
  content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg, transparent, rgba(236,228,212,.06), transparent);
  animation:shimmer 1.4s infinite;
}
@keyframes shimmer{100%{transform:translateX(100%)}}
.sk-line{height:13px;margin:9px 0;border-radius:6px}
.sk-line.sk-sm{width:40%} .sk-line.sk-md{width:65%} .sk-line.sk-lg{width:88%}
.sk-card{height:96px;border-radius:var(--r3);margin-bottom:16px}
.sk-block{height:140px;border-radius:var(--r3);margin-bottom:16px}

/* =========================================================================
   Movimiento (entradas, stagger, momentos)
   ========================================================================= */
@keyframes fade-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes pop-in{0%{opacity:0;transform:scale(.92)}100%{opacity:1;transform:none}}
@keyframes pulse-gold{0%{box-shadow:0 0 0 0 rgba(201,169,98,.45)}100%{box-shadow:0 0 0 14px rgba(201,169,98,0)}}
@keyframes draw-check{from{stroke-dashoffset:var(--len,48)}to{stroke-dashoffset:0}}

.fade-in{animation:fade-in var(--dur-2) var(--ease) both}
.fade-up{animation:fade-up var(--dur-2) var(--ease) both}

/* Entrada escalonada: cada hijo directo entra un poco después que el anterior. */
.stagger > *{animation:fade-up var(--dur-2) var(--ease) both}
.stagger > *:nth-child(1){animation-delay:.02s}
.stagger > *:nth-child(2){animation-delay:.07s}
.stagger > *:nth-child(3){animation-delay:.12s}
.stagger > *:nth-child(4){animation-delay:.17s}
.stagger > *:nth-child(5){animation-delay:.22s}
.stagger > *:nth-child(6){animation-delay:.27s}
.stagger > *:nth-child(7){animation-delay:.32s}
.stagger > *:nth-child(n+8){animation-delay:.36s}

/* Barras que se llenan al cargar: poné --to en el width final y .bar-fill en el span. */
@keyframes bar-fill{from{width:0}to{width:var(--to,0%)}}
.bar-fill{animation:bar-fill var(--dur-3) var(--ease) both;animation-delay:.15s}

/* =========================================================================
   Reduce motion: apaga todo lo no esencial.
   ========================================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .skeleton::after{display:none}
}
