/* =============================================================================
   QRZ11 — Estética "sala de control SDR / dial de radio nocturno"
   Paleta y tipografía deliberadas, no plantilla genérica.
   ========================================================================== */

:root{
  /* Superficies */
  --void:#070b12;
  --void-2:#090f18;
  --panel:#0d1420;
  --panel-2:#121b2b;
  --panel-3:#16223550;
  --line:#1e2c40;
  --line-soft:#16202f;

  /* Tinta */
  --ink:#e7eef7;
  --ink-dim:#aebccd;
  --muted:#7f93ab;
  --muted-2:#5a6c82;

  /* Acentos */
  --amber:#ffb24d;        /* dial retroiluminado — acento principal */
  --amber-deep:#e8951f;
  --cyan:#38e1d6;         /* señal enganchada — acento secundario */
  --cyan-deep:#1fb3aa;
  --alert:#ff5d6c;
  --ok:#4fd687;
  --warn:#ffc24b;

  /* Cascada de espectro (gradiente firma) */
  --wf:linear-gradient(90deg,#0a1830 0%,#13386b 18%,#1f6fb0 36%,#38e1d6 55%,#ffd27a 74%,#ffb24d 86%,#ff7a4d 100%);

  --r-sm:8px; --r:12px; --r-lg:18px; --r-xl:26px;
  --shadow:0 18px 50px -22px rgba(0,0,0,.8);
  --shadow-soft:0 8px 28px -16px rgba(0,0,0,.7);

  --maxw:1180px;
  --ff-display:"Space Grotesk",system-ui,sans-serif;
  --ff-body:"Inter",system-ui,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 78% -10%, #11203a55, transparent 60%),
    radial-gradient(900px 500px at -5% 8%, #1a2a1e33, transparent 55%),
    var(--void);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
img{max-width:100%;display:block}
a{color:var(--cyan);text-decoration:none}
a:hover{color:#7df0e8}
h1,h2,h3,h4{font-family:var(--ff-display);line-height:1.12;margin:0;letter-spacing:-.01em}
.wrap{width:min(var(--maxw),calc(100% - 40px));margin-inline:auto}

.skip{position:absolute;left:-999px;top:0;background:var(--amber);color:#000;padding:10px 16px;border-radius:0 0 10px 0;z-index:200}
.skip:focus{left:0}

::selection{background:var(--amber);color:#10131b}

/* Foco accesible ------------------------------------------------------------*/
:where(a,button,input,select,textarea,[tabindex]):focus-visible{
  outline:2px solid var(--cyan);outline-offset:2px;border-radius:4px;
}

/* =============================================================================
   Barra superior
   ========================================================================== */
.topbar{position:sticky;top:0;z-index:100;background:rgba(8,13,22,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.topbar__inner{display:flex;align-items:center;gap:18px;height:64px}
.topbar__scan{height:2px;background:var(--wf);opacity:.7}

.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-family:var(--ff-display);font-weight:700}
.brand__mark{color:var(--amber);display:grid;place-items:center;filter:drop-shadow(0 0 6px #ffb24d66)}
.brand__txt{font-size:1.32rem;letter-spacing:.02em}
.brand__11{color:var(--amber)}

.lookup{display:flex;align-items:center;flex:1;max-width:420px;background:var(--panel-2);
  border:1px solid var(--line);border-radius:999px;padding:4px 4px 4px 14px;transition:border-color .2s,box-shadow .2s}
.lookup:focus-within{border-color:var(--cyan);box-shadow:0 0 0 3px #38e1d622}
.lookup__pre{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.18em;color:var(--muted-2);padding-right:10px;border-right:1px solid var(--line)}
.lookup input{flex:1;border:0;background:transparent;color:var(--ink);font-family:var(--ff-mono);font-size:.9rem;padding:8px 12px;outline:none;text-transform:uppercase}
.lookup input::placeholder{color:var(--muted-2);text-transform:none;font-family:var(--ff-body)}
.lookup button{border:0;background:var(--amber);color:#10131b;width:36px;height:36px;border-radius:999px;display:grid;place-items:center;cursor:pointer;transition:transform .15s,background .2s}
.lookup button:hover{background:#ffc46e;transform:scale(1.05)}

.nav{display:flex;align-items:center;gap:14px}
.nav__link{color:var(--ink-dim);font-size:.92rem;font-weight:500}
.nav__link:hover{color:var(--ink)}
.nav__link--admin{color:var(--amber)}
.nav__call{font-family:var(--ff-mono);font-weight:700;font-size:.86rem;color:var(--cyan);
  border:1px solid var(--line);padding:5px 10px;border-radius:8px;background:var(--panel-2)}

.navtoggle{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.navtoggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}

/* Botones --------------------------------------------------------------------*/
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ff-display);
  font-weight:600;font-size:.95rem;padding:11px 20px;border-radius:10px;border:1px solid transparent;cursor:pointer;
  background:var(--amber);color:#10131b;transition:transform .12s,box-shadow .2s,background .2s;text-decoration:none}
.btn:hover{background:#ffc46e;color:#10131b;transform:translateY(-1px);box-shadow:0 10px 24px -12px #ffb24daa}
.btn:active{transform:translateY(0)}
.btn--sm{padding:8px 14px;font-size:.85rem;border-radius:8px}
.btn--lg{padding:14px 26px;font-size:1.02rem}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{background:var(--panel-2);border-color:var(--cyan);color:var(--ink)}
.btn--cyan{background:var(--cyan);color:#04201e}
.btn--cyan:hover{background:#5cf0e6;color:#04201e;box-shadow:0 10px 24px -12px #38e1d6aa}
.btn--danger{background:transparent;border-color:#ff5d6c55;color:#ff8a95}
.btn--danger:hover{background:#ff5d6c1a;border-color:var(--alert);color:#ffb3ba}
.btn--block{width:100%}

/* Flash ----------------------------------------------------------------------*/
.flashes{margin-top:18px;display:grid;gap:10px}
.flash{padding:12px 16px;border-radius:var(--r);border:1px solid var(--line);font-size:.93rem;
  background:var(--panel-2);border-left:3px solid var(--muted)}
.flash--ok{border-left-color:var(--ok)}
.flash--error{border-left-color:var(--alert)}
.flash--info{border-left-color:var(--cyan)}
.flash--success{border-left-color:var(--ok)}

/* =============================================================================
   Hero (portada) — la tesis es buscar un indicativo
   ========================================================================== */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero__wf{position:absolute;inset:0;width:100%;height:100%;opacity:.32;mix-blend-mode:screen}
.hero__inner{position:relative;padding:88px 0 76px;display:grid;gap:30px;max-width:760px}
.eyebrow{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--amber);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--amber)}
.hero h1{font-size:clamp(2.4rem,6vw,4.1rem);font-weight:700;letter-spacing:-.025em}
.hero h1 em{font-style:normal;color:var(--amber);position:relative}
.hero p.lead{font-size:1.12rem;color:var(--ink-dim);max-width:54ch;margin:0}

.hero-search{display:flex;gap:0;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:6px;max-width:560px;box-shadow:var(--shadow)}
.hero-search input{flex:1;border:0;background:transparent;color:var(--ink);font-family:var(--ff-mono);
  font-size:1.05rem;padding:14px 16px;outline:none;text-transform:uppercase;letter-spacing:.04em}
.hero-search input::placeholder{text-transform:none;font-family:var(--ff-body);color:var(--muted-2);letter-spacing:0}

.hero-stats{display:flex;gap:34px;flex-wrap:wrap;border-top:1px solid var(--line-soft);padding-top:22px}
.hero-stats div{display:grid;gap:2px}
.hero-stats b{font-family:var(--ff-mono);font-size:1.5rem;color:var(--ink)}
.hero-stats span{font-size:.78rem;color:var(--muted);letter-spacing:.04em}

/* =============================================================================
   Tira de espectro (motivo firma estático)
   ========================================================================== */
.spectrum-strip{height:6px;background:var(--wf);background-size:200% 100%;border-radius:999px}
.section{padding:64px 0}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:28px}
.section__head h2{font-size:clamp(1.5rem,3vw,2rem)}

/* Tarjetas de últimos indicativos -------------------------------------------*/
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px}
.opcard{display:flex;gap:14px;align-items:center;padding:16px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);transition:transform .16s,border-color .2s,background .2s}
.opcard:hover{transform:translateY(-3px);border-color:var(--cyan);background:var(--panel-2)}
.opcard__av{width:52px;height:52px;border-radius:10px;background:var(--panel-2);object-fit:cover;flex:none;
  display:grid;place-items:center;font-family:var(--ff-mono);color:var(--muted);border:1px solid var(--line)}
.opcard__call{font-family:var(--ff-mono);font-weight:700;color:var(--cyan);font-size:1.02rem}
.opcard__name{color:var(--ink-dim);font-size:.88rem}
.opcard__loc{color:var(--muted);font-size:.78rem;display:flex;align-items:center;gap:6px}

/* =============================================================================
   Formularios genéricos / paneles auth
   ========================================================================== */
.shell{padding:56px 0 80px}
.auth{max-width:460px;margin-inline:auto;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden}
.auth__head{padding:26px 30px 0}
.auth__head .eyebrow{margin-bottom:14px}
.auth__head h1{font-size:1.7rem}
.auth__head p{color:var(--muted);font-size:.92rem;margin:8px 0 0}
.auth__body{padding:24px 30px 30px;display:grid;gap:16px}
.auth__alt{padding:16px 30px;border-top:1px solid var(--line);background:var(--void-2);font-size:.9rem;color:var(--muted);text-align:center}

.field{display:grid;gap:7px}
.field label{font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600}
.field .req{color:var(--amber)}
.input,select.input,textarea.input{
  width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font-family:var(--ff-body);font-size:.96rem;padding:12px 14px;transition:border-color .18s,box-shadow .18s}
.input::placeholder{color:var(--muted-2)}
.input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px #38e1d61f}
.input--mono{font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.05em}
textarea.input{resize:vertical;min-height:120px}
.hint{font-size:.78rem;color:var(--muted-2)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Aviso de aprobación --------------------------------------------------------*/
.notice{display:flex;gap:14px;padding:18px;border-radius:var(--r);background:linear-gradient(180deg,#1a2435,#121b2b);
  border:1px solid var(--line);align-items:flex-start}
.notice__dot{width:10px;height:10px;border-radius:50%;background:var(--warn);margin-top:6px;flex:none;
  box-shadow:0 0 0 4px #ffc24b22;animation:pulse 1.8s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px #ffc24b00}}
.notice h3{font-size:1.05rem;margin-bottom:4px}
.notice p{color:var(--muted);font-size:.9rem;margin:0}

/* =============================================================================
   Página de perfil (estilo QRZ modernizado)
   ========================================================================== */
.profile{padding:28px 0 80px}
.profile__top{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}

/* Tarjeta de identidad lateral */
.idcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow);position:sticky;top:84px}
.idcard__photo{aspect-ratio:4/3;background:var(--panel-2) center/cover;position:relative}
.idcard__photo--ph{display:grid;place-items:center;color:var(--muted-2);font-family:var(--ff-mono);font-size:.8rem}
.idcard__av{position:absolute;left:18px;bottom:-26px;width:72px;height:72px;border-radius:14px;border:3px solid var(--panel);
  object-fit:cover;background:var(--panel-3);display:grid;place-items:center;color:var(--muted);font-family:var(--ff-mono)}
.idcard__body{padding:38px 22px 22px}
.idcard__call{font-family:var(--ff-mono);font-weight:700;font-size:1.9rem;color:var(--ink);letter-spacing:.01em;line-height:1}
.idcard__flag{font-size:1.2rem;vertical-align:middle;margin-left:6px}
.idcard__name{font-family:var(--ff-display);font-size:1.1rem;margin-top:6px}
.idcard__rows{margin-top:18px;display:grid;gap:0;border-top:1px solid var(--line-soft)}
.idrow{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:.9rem}
.idrow span{color:var(--muted);font-size:.76rem;letter-spacing:.05em;text-transform:uppercase;padding-top:2px}
.idrow b{font-weight:500;color:var(--ink-dim);text-align:right;font-family:var(--ff-mono)}
.idcard__foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft)}
.lookups{font-family:var(--ff-mono);font-size:.8rem;color:var(--muted)}
.lookups b{color:var(--amber)}

/* Insignia de estado / miembro */
.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.06em;
  padding:5px 11px;border-radius:999px;border:1px solid var(--line);background:var(--panel-2);text-transform:uppercase}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--muted)}
.pill--ok{color:var(--ok);border-color:#4fd68744}.pill--ok::before{background:var(--ok);box-shadow:0 0 8px var(--ok)}
.pill--warn{color:var(--warn);border-color:#ffc24b44}.pill--warn::before{background:var(--warn)}
.pill--bad{color:var(--alert);border-color:#ff5d6c44}.pill--bad::before{background:var(--alert)}

/* Zona principal: foto estación + pestañas */
.profile__main{display:grid;gap:20px;min-width:0}
.station{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);position:relative;background:var(--panel)}
.station img{width:100%;aspect-ratio:16/7;object-fit:cover}
.station__ph{aspect-ratio:16/7;background:
   repeating-linear-gradient(90deg,#0c1420 0 2px,transparent 2px 5px),var(--panel-2);
   display:grid;place-items:center;color:var(--muted-2);font-family:var(--ff-mono);font-size:.85rem;gap:8px}
.station__cap{position:absolute;left:0;right:0;bottom:0;padding:16px 20px;font-family:var(--ff-mono);
  background:linear-gradient(transparent,rgba(7,11,18,.92));color:var(--ink);font-size:.82rem;letter-spacing:.04em}

.tabs{display:flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:5px}
.tabs button{flex:1;border:0;background:transparent;color:var(--muted);font-family:var(--ff-display);font-weight:600;
  font-size:.92rem;padding:11px;border-radius:8px;cursor:pointer;transition:.18s}
.tabs button[aria-selected="true"]{background:var(--panel-2);color:var(--ink);box-shadow:inset 0 0 0 1px var(--line)}
.tabs button .n{font-family:var(--ff-mono);font-size:.72rem;color:var(--amber);margin-left:6px}

.tabpanel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 32px;min-height:200px}
.tabpanel[hidden]{display:none}

/* Render de la biografía */
.bio{font-size:1rem;color:var(--ink-dim);line-height:1.75;overflow-wrap:break-word}
.bio h2,.bio h3,.bio h4{color:var(--ink);font-family:var(--ff-display);margin:1.4em 0 .5em}
.bio p{margin:0 0 1em}
.bio a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.bio img{border-radius:10px;margin:1em 0;border:1px solid var(--line)}
.bio blockquote{border-left:3px solid var(--amber);margin:1em 0;padding:.4em 0 .4em 18px;color:var(--ink)}
.bio iframe{width:100%;aspect-ratio:16/9;height:auto;border:0;border-radius:12px;margin:1em 0}
.bio ul,.bio ol{padding-left:1.3em;margin:0 0 1em}
.bio pre{background:var(--void-2);border:1px solid var(--line);border-radius:10px;padding:14px;overflow:auto;font-family:var(--ff-mono);font-size:.85rem}

.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border-radius:12px;overflow:hidden}
.detail-grid > div{background:var(--panel);padding:16px 18px}
.detail-grid span{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.detail-grid b{font-family:var(--ff-mono);font-weight:500;color:var(--ink);font-size:.98rem}

.empty{color:var(--muted);font-size:.95rem;text-align:center;padding:30px 0}

.email-reveal{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--ff-mono);color:var(--cyan);font-size:.85rem;
  border:1px dashed var(--line);padding:4px 10px;border-radius:8px;background:transparent}
.email-reveal:hover{border-color:var(--cyan)}
.email-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-mono);color:#fff;font-size:.85rem;
  text-decoration:none;border:1px solid var(--line);padding:4px 10px;border-radius:8px;background:transparent;
  word-break:break-all;line-height:1.3}
.email-link:hover{border-color:var(--cyan);text-decoration:underline}
.email-mask{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--ff-mono);color:#fff;font-size:.85rem;
  border:1px dashed var(--line);padding:4px 10px;border-radius:8px;background:transparent;letter-spacing:.15em;word-break:break-all}
.email-mask:hover{border-color:var(--cyan);letter-spacing:normal}

/* Tarjeta de visitas en el panel del usuario */
.visits-card{display:flex;align-items:center;gap:16px;margin-bottom:22px;padding:18px 20px;
  border:1px solid var(--line);border-radius:14px;background:linear-gradient(135deg,#0d1420,#0d1420 60%,#11202b);
  position:relative;overflow:hidden}
.visits-card::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--wf, linear-gradient(180deg,var(--amber),var(--cyan)))}
.visits-card__icon{font-size:1.7rem;line-height:1;filter:saturate(.85)}
.visits-card__body{display:flex;flex-direction:column;line-height:1.1}
.visits-card__num{font-family:var(--ff-mono);font-size:2rem;font-weight:700;color:var(--amber)}
.visits-card__lbl{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);margin-top:4px}
.visits-card__hint{margin-left:auto;max-width:220px;font-size:.8rem;color:var(--muted);text-align:right}
@media(max-width:600px){.visits-card__hint{display:none}}


/* =============================================================================
   Dashboard del usuario
   ========================================================================== */
.dash{padding:36px 0 80px;display:grid;grid-template-columns:240px 1fr;gap:32px;align-items:start}
.dash__side{position:sticky;top:84px;display:grid;gap:6px}
.dash__side h1{font-size:1.4rem;margin-bottom:8px}
.sidelink{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:10px;color:var(--ink-dim);
  font-size:.92rem;border:1px solid transparent;cursor:pointer;background:none;font-family:var(--ff-body);text-align:left;width:100%}
.sidelink:hover{background:var(--panel)}
.sidelink.is-active{background:var(--panel);border-color:var(--line);color:var(--ink)}
.sidelink .dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2)}
.sidelink.is-active .dot{background:var(--amber)}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 30px;box-shadow:var(--shadow-soft)}
.card + .card{margin-top:22px}
.card__head{display:flex;align-items:center;gap:12px;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--line-soft)}
.card__head h2{font-size:1.2rem}
.card__head .tick{width:3px;height:22px;background:var(--amber);border-radius:2px}
.actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;flex-wrap:wrap}

.avatar-edit{display:flex;align-items:center;gap:16px}
.avatar-edit__prev{width:80px;height:80px;border-radius:14px;object-fit:cover;border:1px solid var(--line);background:var(--panel-2);
  display:grid;place-items:center;color:var(--muted);font-family:var(--ff-mono);font-size:.7rem}
.filebtn{position:relative;overflow:hidden}
.filebtn input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}

/* Editor de biografía (WYSIWYG ligero) --------------------------------------*/
.editor{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel-2)}
.editor__bar{display:flex;flex-wrap:wrap;gap:2px;padding:8px;background:var(--void-2);border-bottom:1px solid var(--line)}
.editor__bar button{width:34px;height:32px;border:0;background:transparent;color:var(--ink-dim);border-radius:7px;cursor:pointer;
  display:grid;place-items:center;font-family:var(--ff-mono);font-size:.9rem;transition:.15s}
.editor__bar button:hover{background:var(--panel-2);color:var(--ink)}
.editor__bar .sep{width:1px;background:var(--line);margin:4px 6px}
.editor__area{min-height:240px;max-height:520px;overflow:auto;padding:18px 20px;color:var(--ink-dim);line-height:1.7;outline:none}
.editor__area:empty::before{content:attr(data-ph);color:var(--muted-2)}
.editor__area:focus{box-shadow:inset 0 0 0 2px #38e1d61a}

/* =============================================================================
   Panel de administración
   ========================================================================== */
.admin{padding:32px 0 80px}
.admin__bar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.admin__bar h1{font-size:1.6rem}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:100%;background:var(--c,var(--muted));opacity:.7}
.kpi b{font-family:var(--ff-mono);font-size:2rem;display:block;color:var(--ink)}
.kpi span{font-size:.78rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.kpi--total{--c:var(--cyan)} .kpi--pending{--c:var(--warn)} .kpi--ok{--c:var(--ok)} .kpi--ban{--c:var(--alert)}

.filterbar{display:flex;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:5px;margin-bottom:18px;flex-wrap:wrap}
.filterbar a{padding:8px 14px;border-radius:7px;color:var(--muted);font-size:.88rem;font-weight:500}
.filterbar a.is-active{background:var(--panel-2);color:var(--ink);box-shadow:inset 0 0 0 1px var(--line)}

.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
table.admintbl{width:100%;border-collapse:collapse;font-size:.9rem}
.admintbl th{text-align:left;font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);padding:14px 16px;border-bottom:1px solid var(--line);background:var(--void-2)}
.admintbl td{padding:14px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.admintbl tr:last-child td{border-bottom:0}
.admintbl tr:hover td{background:#0f1827}
.tbl-call{font-family:var(--ff-mono);font-weight:700;color:var(--cyan)}
.tbl-sub{color:var(--muted);font-size:.8rem}
.tbl-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.iconbtn{border:1px solid var(--line);background:var(--panel-2);color:var(--ink-dim);border-radius:8px;padding:7px 11px;
  font-size:.8rem;font-weight:600;cursor:pointer;font-family:var(--ff-display);transition:.15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.iconbtn:hover{color:var(--ink);border-color:var(--muted)}
.iconbtn--ok{color:var(--ok);border-color:#4fd68744}.iconbtn--ok:hover{background:#4fd6871a}
.iconbtn--ban{color:var(--warn);border-color:#ffc24b44}.iconbtn--ban:hover{background:#ffc24b1a}
.iconbtn--del{color:var(--alert);border-color:#ff5d6c44}.iconbtn--del:hover{background:#ff5d6c1a}

/* =============================================================================
   Responsive
   ========================================================================== */
@media (max-width:980px){
  .profile__top{grid-template-columns:1fr}
  .idcard{position:static}
  .dash{grid-template-columns:1fr}
  .dash__side{position:static;display:flex;flex-wrap:wrap;gap:8px}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .lookup{display:none}
  .nav{display:none}
  .navtoggle{display:flex}
  .topbar.open .nav{display:flex;position:absolute;top:64px;right:0;left:0;flex-direction:column;align-items:stretch;
    gap:6px;padding:14px 20px;background:var(--void-2);border-bottom:1px solid var(--line)}
  .topbar.open .nav .btn{width:100%}
  .row-2{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .hero__inner{padding:56px 0 48px}
}

/* Movimiento reducido --------------------------------------------------------*/
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .hero__wf{display:none}
}

/* ============================================================================
   QSL — formulario y tarjeta
   ========================================================================== */
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
@media(max-width:640px){.row-3{grid-template-columns:1fr}}
.callsign-mini{font-family:var(--ff-mono);color:var(--cyan);font-weight:700}
.qslsubhead{margin:22px 0 14px;font-family:var(--ff-display);font-weight:600;font-size:.95rem;color:var(--amber);
  letter-spacing:.04em;padding-bottom:8px;border-bottom:1px solid var(--line-soft)}

/* Tarjeta QSL (recrea el ejemplo) */
.qslcard{position:relative;width:100%;max-width:560px;aspect-ratio:553/337;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);background:#0a0e16;box-shadow:0 18px 40px -22px #000}
.qslcard__photo{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#11202b}
.qslcard__top{position:absolute;left:0;right:0;top:0;display:flex;justify-content:space-between;align-items:flex-start;
  gap:12px;padding:14px 16px}
.qslcard__call{display:flex;flex-direction:column;gap:2px}
.qslcard__sign{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.4rem,5vw,2.2rem);color:var(--amber);
  text-shadow:0 2px 10px #000,0 1px 2px #000;line-height:1}
.qslcard__extra{font-family:var(--ff-mono);font-size:.72rem;color:#ffe9c2;text-shadow:0 1px 4px #000}
.qslcard__box{max-width:60%;background:rgba(245,248,252,.82);color:#10243a;border-radius:6px;padding:8px 12px;
  font-size:.74rem;line-height:1.45;backdrop-filter:blur(2px);box-shadow:0 6px 18px -10px #000;
  display:flex;align-items:center;gap:10px}
.qslcard__boxtext{flex:1 1 auto;min-width:0}
.qslcard__box b{display:block;font-size:.84rem;color:#0a1626}
.qslcard__box span{display:block}
.qslcard__box .qslcard__mail{color:#0d5a86;font-family:var(--ff-mono);font-size:.7rem;margin-top:2px}
.qslcard__box .qslcard__comment{margin-top:3px;font-size:.68rem;font-style:italic;color:#24405c;word-break:break-word}
.qslcard__log{position:absolute;left:0;right:0;bottom:0;display:grid;grid-template-columns:1.1fr 1.4fr 1.2fr .8fr .8fr;
  background:rgba(244,247,251,.85);border-top:1px solid rgba(255,255,255,.5);backdrop-filter:blur(3px)}
.qslcell{padding:4px 9px;border-left:1px solid rgba(16,36,58,.12)}
.qslcell:first-child{border-left:0}
.qslcell span{display:block;font-size:.52rem;letter-spacing:.05em;text-transform:uppercase;color:#5d6e80;margin-bottom:1px}
.qslcell b{font-family:var(--ff-mono);font-size:.76rem;color:#0e2236;font-weight:600;word-break:break-word;line-height:1.15}
@media(max-width:480px){
  .qslcell span{font-size:.46rem}.qslcell b{font-size:.62rem}
  .qslcard__box{font-size:.66rem;padding:6px 9px}
}
.qslcard__avatar{flex:0 0 auto;width:58px;height:58px;border-radius:50%;object-fit:cover}
@media(max-width:480px){.qslcard__avatar{width:44px;height:44px}}

/* Listado de QSL recibidas */
.qsl-received{display:flex;flex-direction:column;gap:22px}
.qsl-item{display:flex;flex-direction:column;gap:10px}
.qsl-item__meta{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.qsl-item__from{font-size:.85rem;color:var(--ink-dim)}
.qsl-empty{padding:30px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:12px}
.side-badge{display:inline-block;min-width:18px;text-align:center;background:var(--amber);color:#1a1206;
  font-family:var(--ff-mono);font-size:.7rem;font-weight:700;border-radius:9px;padding:1px 6px;margin-left:4px}

/* ============================================================================
   Modal (ventana emergente)
   ========================================================================== */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(4,7,12,.72);backdrop-filter:blur(4px);animation:fade .2s ease}
.modal__card{position:relative;width:100%;max-width:440px;text-align:center;padding:34px 30px 30px;
  background:linear-gradient(160deg,#101a28,#0c121d);border:1px solid var(--line);border-radius:18px;
  box-shadow:0 30px 70px -25px #000,0 0 0 1px rgba(56,225,214,.06);animation:pop .25s cubic-bezier(.2,.9,.3,1.2)}
.modal__card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;border-radius:18px 18px 0 0;background:var(--wf)}
.modal__emoji{font-size:2.6rem;line-height:1;margin-bottom:8px}
.modal__card h2{font-family:var(--ff-display);color:var(--amber);letter-spacing:.04em;margin:0 0 12px;font-size:1.5rem}
.modal__card p{color:var(--ink-dim);margin:0 0 10px;line-height:1.5}
.modal__sign{font-family:var(--ff-mono);color:var(--cyan);font-weight:600;letter-spacing:.03em}
.modal__card .btn{margin-top:18px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
.modal__card--alert::before{background:linear-gradient(90deg,var(--alert),#ff9d4d)}
.modal__card--alert h2{color:var(--alert)}

/* ============================================================================
   Enviar QSL: formulario + previsualización en vivo
   ========================================================================== */
.qsl-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,440px);gap:26px;align-items:start}
.qsl-preview-pane{position:sticky;top:90px}
.qsl-preview-head{font-family:var(--ff-display);color:var(--cyan);letter-spacing:.04em;text-transform:uppercase;
  font-size:.8rem;margin-bottom:10px}
.qsl-preview-pane .qslcard{max-width:none}
.qsl-preview-pane #pvPhoto{background:#0b1422 center/cover no-repeat}
@media(max-width:900px){
  .qsl-layout{grid-template-columns:1fr}
  .qsl-preview-pane{position:static;margin-top:8px}
}

/* Aviso "NEW" parpadeante en QSL recibidas */
.badge-new{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:10px;
  background:var(--alert);color:#1a0307;font-family:var(--ff-mono);font-size:.62rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;vertical-align:middle;animation:blinkNew 1s steps(2,start) infinite;
  box-shadow:0 0 10px -1px var(--alert)}
@keyframes blinkNew{50%{opacity:.25}}
@media(prefers-reduced-motion:reduce){.badge-new{animation:none}}

/* ============================================================================
   Chat público de la portada
   ========================================================================== */
.chatbox{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:0 18px 40px -26px #000}
.chat-head{font-family:var(--ff-display);color:var(--ink);letter-spacing:.02em;font-size:1.05rem;margin-bottom:12px}
.chat-head span{color:var(--cyan);font-size:.78rem;font-family:var(--ff-mono)}
.home-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr);gap:24px;align-items:start;
  max-width:1380px;margin:0 auto;padding:0 24px}
.home-row__left,.home-row__right{width:100%}
.home-row__left .grid-cards{margin-top:4px;grid-template-columns:1fr}
@media(max-width:1080px){
  .home-row{grid-template-columns:1fr;max-width:680px}
}

/* ===== Sección "Actividad del portal" ===== */
.portal .wrap{max-width:1380px}
.portal__head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.portal__eyebrow{color:var(--cyan);font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.22em;margin-bottom:4px}
.portal__title{font-family:var(--ff-display);font-size:clamp(1.6rem,3vw,2.3rem);letter-spacing:.04em;text-transform:uppercase;margin:0;color:var(--ink)}
.portal__period{display:flex;align-items:center;gap:12px}
.portal__pill{font-family:var(--ff-mono);font-size:.8rem;color:var(--cyan);border:1px solid #1d4a4f;background:#0c1a22;border-radius:999px;padding:5px 14px}
.portal__reset{color:var(--muted);font-size:.78rem}
.portal__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:18px}
.pcard{background:linear-gradient(180deg,#0e1726,#0b1018);border:1px solid var(--line);border-radius:14px;
  padding:15px 20px;position:relative;overflow:hidden;min-height:0}
.pcard::before{content:"";position:absolute;left:0;right:0;top:0;height:3px}
.pcard--qsl::before{background:var(--amber)}
.pcard--users::before{background:var(--cyan)}
.pcard--recv::before{background:linear-gradient(90deg,var(--cyan),var(--amber))}
.pcard__head{display:flex;align-items:center;gap:8px;color:var(--ink-dim);font-family:var(--ff-mono);
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}
.pcard__ico{font-size:1rem}
.pcard__big{font-family:var(--ff-display);font-size:2.3rem;line-height:1;color:var(--amber)}
.pcard__sub{color:var(--ink-dim);font-size:.85rem;margin-top:4px}
.pcard__label{color:var(--muted);font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;margin:12px 0 6px}
.daybars{display:flex;align-items:flex-end;gap:3px;height:30px}
.daybar{flex:1;min-width:2px;background:#1c2c40;border-radius:2px 2px 0 0;transition:background .2s}
.daybar.is-on{background:var(--amber)}
.daybar.is-today{outline:1px solid var(--cyan)}
.pcard__foot{display:flex;gap:18px;margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.pcard__foot span{color:var(--muted);font-size:.8rem}
.pcard__foot b{color:var(--ink);font-family:var(--ff-display)}
.pcard__empty{color:var(--muted);text-align:center;margin:18px 0;font-size:.9rem}
.rank{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.rank li{display:flex;align-items:center;gap:12px}
.rank__pos{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:7px;
  background:#13202f;color:var(--ink-dim);font-family:var(--ff-display);font-size:.85rem}
.rank li:nth-child(1) .rank__pos{background:var(--amber);color:#1a1206}
.rank li:nth-child(2) .rank__pos{background:#2a3a4d;color:var(--ink)}
.rank__call{font-family:var(--ff-mono);color:var(--cyan);font-size:.92rem;text-decoration:none}
.rank__call:hover{text-decoration:underline}
.rank__n{margin-left:auto;color:var(--ink-dim);font-size:.82rem}
@media(max-width:920px){
  .portal__grid{grid-template-columns:1fr}
}
.chatbox__log{height:200px;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:9px;
  background:linear-gradient(180deg,rgba(56,225,214,.03),transparent)}
.chat-empty{color:var(--muted);text-align:center;margin:auto;font-size:.9rem}
.chat-msg{max-width:60%;align-self:flex-start;background:#0f1a28;border:1px solid var(--line);
  border-radius:10px;padding:7px 11px}
.chat-msg--mine{align-self:flex-end;background:#10212b;border-color:#1d4a4f}
.chat-msg__meta{display:flex;gap:8px;align-items:baseline;margin-bottom:2px}
.chat-msg__meta b{color:var(--amber);font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.02em}
.chat-msg--mine .chat-msg__meta b{color:var(--cyan)}
.chat-msg__time{color:var(--muted);font-size:.64rem}
.chat-msg__text{color:var(--ink);font-size:.9rem;line-height:1.4;word-wrap:break-word;overflow-wrap:anywhere}
.chatbox__form{display:flex;gap:10px;padding:12px;border-top:1px solid var(--line);background:#0b1422}
.chatbox__name{max-width:180px}
.chatbox__text{flex:1}
.chatbox__hint{color:var(--muted);font-size:.78rem;margin:0;padding:0 12px 12px;background:#0b1422}
@media(max-width:620px){
  .chatbox__form{flex-wrap:wrap}
  .chatbox__name{max-width:none;flex:1 1 100%}
}

/* Selector de emoticonos del chat */
.chatbox__form{position:relative}
.emoji-btn{flex:0 0 auto;width:42px;border:1px solid var(--line);background:#0f1a28;border-radius:10px;
  font-size:1.2rem;line-height:1;cursor:pointer;color:var(--ink)}
.emoji-btn:hover{border-color:var(--cyan)}
.emoji-panel{position:absolute;bottom:calc(100% + 8px);left:12px;right:12px;z-index:20;
  background:#0c1420;border:1px solid var(--line);border-radius:12px;padding:8px;
  box-shadow:0 20px 40px -18px #000;display:flex;flex-wrap:wrap;gap:2px;max-height:180px;overflow-y:auto}
.emoji-panel[hidden]{display:none}
.emoji-item{border:0;background:transparent;font-size:1.25rem;line-height:1;padding:5px;border-radius:8px;cursor:pointer}
.emoji-item:hover{background:#16263a}

/* Banderas como imagen (se ven en Windows/Chrome, a diferencia del emoji) */
.flag{vertical-align:-2px;border-radius:2px;display:inline-block;box-shadow:0 0 0 1px rgba(255,255,255,.08)}

/* Selector de país personalizado (con bandera-imagen) */
.fsel{position:relative}
.fsel.is-enhanced > select.flagselect{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;left:-9999px}
.fsel__btn{display:flex;align-items:center;gap:9px;width:100%;cursor:pointer;text-align:left}
.fsel__btn .fsel__lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fsel__btn .fsel__chev{color:var(--muted);font-size:.8rem}
.fsel__sat{font-size:.95rem}
.fsel__panel{position:absolute;z-index:40;left:0;right:0;top:calc(100% + 6px);max-height:300px;overflow-y:auto;
  background:#0c1420;border:1px solid var(--line);border-radius:10px;padding:6px;box-shadow:0 22px 44px -20px #000}
.fsel__panel[hidden]{display:none}
.fsel__opt{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:0;background:transparent;
  color:var(--ink);cursor:pointer;border-radius:8px;text-align:left;font-size:.92rem}
.fsel__opt:hover{background:#16263a}

/* Botón Webchat en la barra + ventana emergente del chat */
.nav__chat{background:none;border:0;cursor:pointer;font:inherit;color:var(--ink-dim);padding:0}
.nav__chat:hover{color:var(--cyan)}
.chat-modal__card{position:relative;width:min(680px,94vw);max-width:none;text-align:left;padding:24px}
.chat-modal__close{position:absolute;top:12px;right:14px;background:none;border:0;color:var(--muted);
  font-size:1.15rem;line-height:1;cursor:pointer}
.chat-modal__close:hover{color:var(--alert)}
.chat-modal .chat-head{margin:0 0 12px}
.chat-modal .chatbox__log{height:46vh;max-height:440px}
@media(max-width:560px){
  .chat-modal__card{width:96vw;padding:18px}
  .chat-modal .chatbox__log{height:52vh}
}

/* Panel admin · Actividad (QSL) */
.searchbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.searchbar .input{flex:1;min-width:220px}
.qslthumb{display:inline-block;width:84px;height:54px;border-radius:7px;overflow:hidden;border:1px solid var(--line);background:#0b1018}
.qslthumb img{width:100%;height:100%;object-fit:cover;display:block}
.qsltbl td{vertical-align:top}

/* Selector de idioma (barra superior) */
.langsel{position:relative}
.langsel__btn{display:inline-flex;align-items:center;gap:6px;background:#0f1a28;border:1px solid var(--line);
  color:var(--ink-dim);border-radius:9px;padding:6px 9px;cursor:pointer;font:inherit;font-size:.82rem}
.langsel__btn:hover{border-color:var(--cyan);color:var(--ink)}
.langsel__panel{position:absolute;right:0;top:calc(100% + 6px);z-index:60;min-width:160px;background:#0c1420;
  border:1px solid var(--line);border-radius:10px;padding:6px;box-shadow:0 18px 38px -18px #000}
.langsel__panel[hidden]{display:none}
.langsel__opt{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;color:var(--ink);
  text-decoration:none;font-size:.88rem}
.langsel__opt:hover{background:#16263a}
.langsel__opt.is-active{color:var(--cyan)}

/* Bloqueo manual de IP (panel de cuentas) */
.ipbox{background:#0c1420;border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin:14px 0 4px;
  display:flex;flex-wrap:wrap;gap:18px 34px;align-items:flex-start}
.ipbox__form{display:flex;flex-direction:column;gap:6px}
.ipbox__form label{font-size:.82rem;color:var(--ink-dim);font-weight:600}
.ipbox__row{display:flex;gap:8px;align-items:center}
.ipbox__row .input{max-width:200px}
.ipbox__list{display:flex;flex-direction:column;gap:8px}
.ipchips{display:flex;flex-wrap:wrap;gap:8px}
.ipchip{display:inline-flex;align-items:center;gap:8px;background:#16263a;border:1px solid var(--line);
  border-radius:999px;padding:5px 6px 5px 12px;font-size:.82rem}
.ipchip button{background:var(--alert);color:#1a0008;border:0;border-radius:999px;width:20px;height:20px;
  cursor:pointer;font-size:.74rem;line-height:1;display:grid;place-items:center}
.ipchip button:hover{filter:brightness(1.15)}

/* Botón y modal del Grupo de WhatsApp */
.nav__wa:hover{color:#25d366}
.btn--wa{display:inline-flex;align-items:center;justify-content:center;background:transparent;
  border:1px solid #25d366;color:#25d366;font-weight:600}
.btn--wa:hover{background:#25d366;color:#06210f;border-color:#25d366}
