/* ============================================================
   ZINEAS · Sistema de Diseño · zineas.css · v2 "Marco"
   Fuente única de verdad para la plataforma (app + módulos).
   Alineado a la estética de la landing (jul 2026): diamante,
   barrido en botones, tokens de superficie/radio, Casas reales.
   ============================================================ */
:root{
    --bg:#0A0A0B; --bg2:#0E0E10; --surface:#161619; --surface2:#1D1D21;
    --negro:#0A0A0B; --light:#F3F3F1;
    --hi:rgba(255,255,255,.05);
    --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.13);
    --text:#F4F3F1; --dim:rgba(244,243,241,.56); --faint:rgba(244,243,241,.42);
    --rojo:#E74242; --rojo-hi:#F45A5A; --glow:rgba(231,66,66,.42);
    --verde:#3DDC84; --ambar:#F1C40F;
    --leon:#AB3AFD; --pegaso:#4B65FF; --fenix:#FBA900; --dragon:#F60048; --grifo:#008966;
    --ease:cubic-bezier(.22,1,.36,1);
    --spring:cubic-bezier(.32,1.4,.42,1);
    --mono:'JetBrains Mono','SF Mono',ui-monospace,Menlo,monospace;
    /* espaciado · grilla 8pt */
    --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px; --sp-6:24px; --sp-7:32px; --sp-8:48px; --sp-9:64px;
    /* radios */
    --r-sm:10px; --r-md:14px; --r-lg:18px; --r-pill:999px;
    /* elevación */
    --sh-1:0 1px 2px rgba(0,0,0,.25); --sh-2:0 10px 30px -14px rgba(0,0,0,.55); --sh-pop:0 24px 60px -24px rgba(0,0,0,.85);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  *{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.16) transparent}
  html{-webkit-text-size-adjust:100%}
  body{
    background:var(--bg); color:var(--text);
    font-family:"Space Grotesk",system-ui,sans-serif; font-weight:400; line-height:1.5;
    letter-spacing:-.011em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
    min-height:100vh; position:relative; overflow-x:hidden;
  }
  /* ambient cinematic light + vignette */
  body::before{
    content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
    background:
      radial-gradient(60% 45% at 50% 0%, rgba(231,66,66,.10), transparent 60%),
      radial-gradient(120% 90% at 50% 12%, rgba(255,255,255,.02), transparent 55%),
      radial-gradient(100% 100% at 50% 100%, rgba(0,0,0,.5), transparent 60%);
    animation:zineasAmbient 9s ease-in-out infinite;
  }
  @keyframes zineasAmbient{0%,100%{opacity:.82}50%{opacity:1}}
  body::after{
    content:""; position:fixed; inset:0; z-index:0; pointer-events:none; 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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  #app,.topbar{position:relative;z-index:2}
  ::selection{background:var(--rojo);color:#fff}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1060px;margin:0 auto;padding:0 24px}

  /* ---------------- topbar ---------------- */
  .topbar{position:sticky;top:0;z-index:60;
    background:rgba(10,10,11,.72);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);
    border-bottom:1px solid var(--line)}
  .topbar .row{display:flex;align-items:center;justify-content:space-between;height:62px}
  .brand{display:flex;align-items:center;gap:11px}
  .brand svg:not(.brand-logo){width:19px;height:19px}
  .brand .brand-logo{height:30px;width:auto;display:block}
  .brand .w{font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:13.5px}
  .who{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--dim)}
  .who .em{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* ---------------- buttons ---------------- */
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
    font-family:inherit;font-size:14.5px;font-weight:500;letter-spacing:-.01em;
    border:none;border-radius:13px;height:48px;padding:0 20px;white-space:nowrap;
    transition:transform .22s var(--ease),background .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease),color .22s var(--ease)}
  .btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
  .btn:focus-visible{outline:2px solid var(--rojo);outline-offset:2px}
  .btn--primary{background:var(--light);color:var(--negro);position:relative;overflow:hidden}
  .btn--primary::after{content:"";position:absolute;top:0;bottom:0;left:-40%;width:34%;
    background:linear-gradient(100deg,transparent,rgba(255,255,255,.85),transparent);
    transform:skewX(-18deg) translateX(-120%);transition:transform .7s var(--ease);pointer-events:none}
  .btn--primary:hover{transform:translateY(-1px);box-shadow:0 12px 30px -12px rgba(243,243,241,.4)}
  .btn--primary:hover::after{transform:skewX(-18deg) translateX(460%)}
  .btn--primary:active{transform:translateY(0) scale(.99)}
  .btn--ghost{background:transparent;color:var(--text);border:1px solid var(--line2)}
  .btn--ghost:hover{border-color:var(--text);transform:translateY(-1px)}
  .btn--google{background:var(--surface2);color:var(--text);border:1px solid var(--line2);height:52px;width:100%}
  .btn--google:hover{background:#232327;border-color:rgba(255,255,255,.22);transform:translateY(-1px);box-shadow:0 10px 28px -14px rgba(0,0,0,.8)}
  .btn--google:active{transform:translateY(0)}
  .btn--google svg{width:18px;height:18px;flex:none}
  .btn--sm{height:38px;font-size:13.5px;padding:0 15px;border-radius:10px}
  .btn--block{width:100%}
  .btn .ar{display:inline-block;transition:transform .3s var(--ease)}
  .btn:hover .ar{transform:translateX(3px)}

  /* ---------------- inputs ---------------- */
  .input{width:100%;background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r-md);
    color:var(--text);font-family:inherit;font-size:15px;height:50px;padding:0 16px;outline:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
    transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
  textarea.input{height:auto;padding:13px 16px;resize:vertical;min-height:46px}
  .input::placeholder{color:var(--faint)}
  .input:focus{border-color:var(--rojo);box-shadow:0 0 0 4px rgba(231,66,66,.12)}
  .input:focus-visible{border-color:var(--rojo);box-shadow:0 0 0 3px var(--glow)}
  .input:disabled{opacity:.5}
  select.input{appearance:none;cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23888' stroke-width='1.5'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
  select.input option{background:var(--surface2);color:var(--text)}
  .label{display:block;font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-bottom:9px;font-weight:500}
  .field{margin-bottom:16px}

  /* ---------------- card ---------------- */
  .card{position:relative;border:1px solid var(--line);border-radius:20px;padding:30px;
    background:linear-gradient(180deg,rgba(255,255,255,.018),transparent 42%),var(--surface);
    box-shadow:0 24px 64px -34px rgba(0,0,0,.85),inset 0 1px 0 var(--hi)}

  .eyebrow{display:flex;align-items:center;gap:11px;font-size:11.5px;letter-spacing:.16em;
    text-transform:uppercase;color:var(--rojo);font-weight:500}
  .eyebrow::before{content:"";width:7px;height:7px;background:var(--rojo);transform:rotate(45deg);
    box-shadow:0 0 13px var(--glow);display:inline-block;flex:none}

  .title{font-weight:600;letter-spacing:-.03em;line-height:1.08;font-size:clamp(24px,3.4vw,34px)}
  .sub{color:var(--dim);font-weight:300;font-size:15.5px;line-height:1.55}
  .msg{font-size:13.5px;margin-top:14px;min-height:18px;line-height:1.5}
  .msg.ok{color:var(--verde)} .msg.err{color:var(--rojo)} .msg.info{color:var(--dim)}
  .msg a{color:var(--rojo);font-weight:500}
  .section{padding:38px 0}

  /* ---------------- auth ---------------- */
  .auth-wrap{min-height:calc(100vh - 62px);display:grid;place-items:center;padding:48px 24px}
  .auth-card{max-width:436px;width:100%;padding:40px 36px;
    animation:cardIn .75s var(--ease) both}
  @keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.985)}to{opacity:1;transform:none}}
  .auth-card>*{animation:rise .6s var(--ease) both}
  .auth-card>*:nth-child(1){animation-delay:.06s}
  .auth-card>*:nth-child(2){animation-delay:.12s}
  .auth-card>*:nth-child(3){animation-delay:.17s}
  .auth-card>*:nth-child(4){animation-delay:.22s}
  .auth-card>*:nth-child(5){animation-delay:.27s}
  .auth-card>*:nth-child(6){animation-delay:.31s}
  .auth-card>*:nth-child(7){animation-delay:.35s}
  @keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
  .mark{position:relative;width:48px;height:48px;margin-bottom:26px}
  .mark svg{width:48px;height:48px;position:relative;z-index:1}
  .mark::after{content:"";position:absolute;inset:-18px;z-index:0;
    background:radial-gradient(circle,var(--glow),transparent 68%);filter:blur(6px);
    animation:focusPulse 3.4s ease-in-out infinite}
  @keyframes focusPulse{0%,100%{opacity:.5}50%{opacity:.95}}
  .auth-card h1{font-weight:600;letter-spacing:-.03em;font-size:30px;line-height:1.05;margin-top:18px}
  .auth-sub{margin-top:12px;color:var(--dim);font-weight:300;font-size:15.5px;line-height:1.5;max-width:34ch}
  .auth-card .btn--google{margin-top:28px}
  .divider{display:flex;align-items:center;gap:14px;margin:20px 0;color:var(--faint);font-size:12px}
  .divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
  .email-field{position:relative}
  .email-field .input{padding-right:54px}
  .email-send{position:absolute;right:6px;top:50%;transform:translateY(-50%);
    width:38px;height:38px;border-radius:9px;background:var(--surface2);border:1px solid var(--line2);
    color:var(--dim);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;
    transition:all .2s var(--ease)}
  .email-send:hover{background:var(--rojo);border-color:var(--rojo);color:#fff}
  .email-send:focus-visible{outline:2px solid var(--rojo);outline-offset:2px}
  .fine{margin-top:13px;font-size:12.5px;color:var(--faint)}

  /* ---------------- stepper (tracker) ---------------- */
  .stepper{display:flex;flex-direction:column}
  .step{display:flex;align-items:center;gap:16px;padding:13px 0}
  .step__ring{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line2);
    display:flex;align-items:center;justify-content:center;flex:none;font-size:12px;color:var(--faint);
    font-variant-numeric:tabular-nums;transition:all .3s var(--ease)}
  .step--done .step__ring{background:var(--rojo);border-color:var(--rojo);color:#fff}
  .step--now .step__ring{border-color:var(--rojo);color:var(--rojo);box-shadow:0 0 0 4px rgba(231,66,66,.14)}
  .step__label{font-size:16px;font-weight:500}
  .step--pending .step__label{color:var(--faint);font-weight:400}
  .step__date{margin-left:auto;font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}
  .step__conn{width:1.5px;height:14px;margin-left:15.25px;background:var(--line)}
  .step__conn--done{background:var(--rojo)}

  .pill{display:inline-flex;align-items:center;gap:8px;font-size:12px;padding:6px 13px;border-radius:999px;
    border:1px solid var(--line2);color:var(--dim)}
  .pill .dot{width:6px;height:6px;border-radius:50%}

  /* ---------------- admin ---------------- */
  .stat{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 26px}
  .stat__item{border:1px solid var(--line);border-radius:13px;padding:13px 17px;min-width:88px;
    background:linear-gradient(180deg,rgba(255,255,255,.015),transparent),var(--surface)}
  .stat__n{font-size:23px;font-weight:600;letter-spacing:-.02em;line-height:1}
  .stat__l{font-size:10.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.07em;margin-top:6px}
  .plist{display:flex;flex-direction:column;gap:11px;margin-top:18px}
  .prow{border:1px solid var(--line);border-radius:15px;padding:18px 20px;
    background:linear-gradient(180deg,rgba(255,255,255,.012),transparent),var(--surface);
    transition:border-color .2s var(--ease)}
  .prow:hover{border-color:var(--line2)}
  .prow__head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
  .prow__nm{font-size:16px;font-weight:600}
  .prow__meta{font-size:13px;color:var(--dim);margin-top:3px}
  .prow__code{font-size:11.5px;color:var(--faint);font-variant-numeric:tabular-nums;margin-top:2px}
  .prow__ctrls{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;margin-top:16px;align-items:end}
  .badge{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;
    border:1px solid var(--line2);color:var(--dim);white-space:nowrap}
  .badge--rech{color:var(--rojo);border-color:rgba(231,66,66,.4)}
  .badge--miembro{color:var(--verde);border-color:rgba(61,220,132,.4)}

  .muted{color:var(--dim)}
  .spin{width:18px;height:18px;border:2px solid var(--line2);border-top-color:var(--rojo);border-radius:50%;
    animation:sp .7s linear infinite;display:inline-block}
  @keyframes sp{to{transform:rotate(360deg)}}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

  /* ---------------- estética v2 · firmas compartidas con la landing ---------------- */
  :focus-visible{outline:2px solid var(--rojo);outline-offset:2px;border-radius:6px}
  .input:focus-visible{outline:none}
  .title,.auth-card h1{text-wrap:balance}
  /* marcador de sección del wizard de postulación: mismo diamante del sistema */
  .form-wrap .step-eyebrow::before{width:7px;height:7px;background:var(--rojo);
    transform:rotate(45deg);box-shadow:0 0 12px var(--glow)}
  /* tarjetas de acceso del inicio de miembro: acento rojo que se dibuja */
  .home-card{position:relative;overflow:hidden}
  .home-card::before{content:"";position:absolute;top:0;left:22px;right:22px;height:2px;border-radius:2px;
    background:var(--rojo);opacity:0;transform:scaleX(.35);transform-origin:left;
    transition:opacity .3s var(--ease),transform .5s var(--ease)}
  .home-card:hover::before{opacity:.9;transform:scaleX(1)}

  @media(max-width:640px){
    .grid2{grid-template-columns:1fr}
    .prow__ctrls{grid-template-columns:1fr}
    .auth-card{padding:34px 26px}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
  }

  /* ============================================================
     v3 · LA CABINA — capa de plataforma
     La sala es el Marco; esto es la cabina del operador.
     Datos en mono como timecode · luz REC · hojas, no alertas.
     ============================================================ */
  .mono,.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0}
  .btn{transition:transform .18s var(--spring),background .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease),color .22s var(--ease)}
  .btn:active{transform:scale(.97)}
  .btn--danger{background:var(--rojo);color:#fff}
  .btn--danger:hover{transform:translateY(-1px);box-shadow:0 12px 30px -12px var(--glow)}

  .rec{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;
    letter-spacing:.16em;text-transform:uppercase;color:var(--rojo);font-weight:500}
  .rec i{width:8px;height:8px;border-radius:50%;background:var(--rojo);box-shadow:0 0 10px var(--glow);
    animation:recPulse 1.7s ease-in-out infinite}
  .rec.off{color:var(--faint)} .rec.off i{background:var(--faint);box-shadow:none;animation:none}
  @keyframes recPulse{0%,100%{opacity:1}50%{opacity:.3}}

  /* Hoja de confirmación — la plataforma no usa alertas del navegador */
  .zx-back{position:fixed;inset:0;z-index:140;background:rgba(6,6,8,.62);
    backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
    opacity:0;pointer-events:none;transition:opacity .22s var(--ease)}
  .zx-back.on{opacity:1;pointer-events:auto}
  .zx-sheet{position:fixed;z-index:141;left:0;right:0;bottom:0;background:var(--surface2);
    border:1px solid var(--line2);border-bottom:none;border-radius:20px 20px 0 0;
    padding:12px 22px calc(24px + env(safe-area-inset-bottom));
    transform:translateY(106%);transition:transform .34s var(--spring)}
  .zx-sheet.on{transform:none}
  .zx-handle{width:38px;height:4px;border-radius:99px;background:rgba(255,255,255,.16);margin:2px auto 16px}
  .zx-t{font-size:19px;font-weight:600;letter-spacing:-.02em}
  .zx-s{font-size:13.5px;color:var(--dim);line-height:1.55;margin-top:7px}
  .zx-s b{color:var(--text);font-weight:600}
  .zx-btns{display:flex;gap:10px;margin-top:22px}
  .zx-btns .btn{flex:1}
  @media(min-width:760px){
    .zx-sheet{left:50%;right:auto;bottom:auto;top:50%;width:430px;border-radius:18px;
      border-bottom:1px solid var(--line2);padding:24px 26px 26px;
      transform:translate(-50%,-46%) scale(.97);opacity:0;
      transition:transform .26s var(--spring),opacity .2s var(--ease)}
    .zx-sheet.on{transform:translate(-50%,-50%);opacity:1}
    .zx-handle{display:none}
  }
  .zx-toast{position:fixed;z-index:150;left:50%;bottom:26px;transform:translateX(-50%) translateY(10px);
    background:var(--light);color:var(--negro);font-size:13.5px;font-weight:500;border-radius:12px;
    padding:12px 18px;box-shadow:var(--sh-pop);opacity:0;pointer-events:none;
    transition:opacity .22s var(--ease),transform .26s var(--spring);max-width:calc(100vw - 32px)}
  .zx-toast.on{opacity:1;transform:translateX(-50%)}

