/*
 * sgs-passwd — Design System SGS (dark-first).
 * Firma SGS: DM Sans + JetBrains Mono, acento verde #00d67e.
 * Layout "Aurora" split-screen homologado a sgs-transfer, recoloreado a la marca passwd.
 * Compartido por: index.html (público), redeem.html, admin.html.
 */

/* ══════════════════════════════════════════════════════════════
   TOKENS
   ══════════════════════════════════════════════════════════════ */
/* Tokens base de la firma (dark, fallback sin JS). theme.js (Regla #5) los
   sobreescribe en :root con el mapa light/dark — los derivados de abajo usan
   var(--token) para seguir el tema automáticamente. */
:root {
  --bg-deep:#0a0e13; --bg:#0f1419; --bg2:#151b23; --bg3:#1c2530; --bg4:#232d3b;
  --panel:#111820; --surface:#18202b; --surface2:#1e2836;
  --text:#e4e8ee; --text2:#c0c8d4; --dim:#7a8694; --muted:#525e6c;
  --accent:#00d67e; --accent2:#00f28e; --accent-dim:rgba(0,214,126,.08); --accent-border:rgba(0,214,126,.15);
  --blue:#38a3f8; --blue-dim:rgba(56,163,248,.08); --blue-border:rgba(56,163,248,.15);
  --orange:#f5a623; --orange-dim:rgba(245,166,35,.08);
  --red:#f04848; --red-dim:rgba(240,72,72,.08); --red-border:rgba(240,72,72,.15);
  --purple:#a78bfa; --purple-dim:rgba(167,139,250,.1); --gold:#ffd700;
  --border:rgba(255,255,255,.06); --border2:rgba(255,255,255,.1); --hover:rgba(255,255,255,.04);
  --shadow:0 4px 24px rgba(0,0,0,.3);
  /* Derivados (siguen al tema vía var) */
  --bg-card:var(--surface); --bg-card-hover:var(--surface2);
  --text-primary:var(--text); --text-secondary:var(--text2); --text-muted:var(--dim);
  --accent-muted:var(--accent-dim); --accent-glow:rgba(0,214,126,.28);
  --success:var(--accent); --success-muted:var(--accent-dim);
  --warning:var(--orange); --warning-muted:var(--orange-dim);
  --danger:var(--red); --danger-muted:var(--red-dim);
  --info:var(--blue); --info-muted:var(--blue-dim);
  --border-color:var(--border); --border-subtle:var(--hover);
  --grad:linear-gradient(135deg,#00d67e 0%,#00b368 55%,#0891b2 100%);
  --grad-btn:linear-gradient(135deg,var(--accent),#00b368);
  --shadow-sm:var(--shadow); --shadow-md:0 6px 22px rgba(0,0,0,.35); --shadow-lg:0 14px 48px rgba(0,0,0,.45);
  --radius-sm:8px; --radius-md:10px; --radius-lg:14px; --radius:12px;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --transition:all .2s cubic-bezier(.4,0,.2,1);
}
body { transition:background .2s,color .2s; }

/* ══════════════════════════════════════════════════════════════
   BASE
   ══════════════════════════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
body {
  font-family:'DM Sans',-apple-system,'Segoe UI',system-ui,sans-serif;
  background:var(--bg); color:var(--text); min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
input,select,textarea,button { font-family:inherit; }
input[type=text],input[type=email],input[type=password],input[type=number],select,textarea,.inp {
  width:100%; background:var(--bg-deep); border:1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--text); font-size:.86rem;
  padding:.55rem .7rem; outline:none; transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus,.inp:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
input::placeholder,textarea::placeholder { color:var(--muted); }
::selection { background:var(--accent-dim); color:var(--accent2); }
* { scrollbar-width:thin; scrollbar-color:var(--border) transparent; }
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }
.hidden { display:none !important; }
.grow { flex:1; }
.row { display:flex; align-items:center; gap:.75rem; flex-wrap:wrap; }
a { color:var(--accent); }
code,.mono { font-family:var(--mono); }

/* ══════════════════════════════════════════════════════════════
   BOTONES
   ══════════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.6rem 1.1rem; border:1px solid var(--border); border-radius:9px; cursor:pointer;
  font-family:inherit; font-weight:800; font-size:.86rem; color:var(--text);
  background:var(--surface2); transition:all .15s;
}
.btn:hover { filter:brightness(1.08); transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none; filter:none; }
.btn-accent { background:var(--grad-btn); color:#04130c; border:none; box-shadow:0 6px 18px var(--accent-glow); }
.btn-accent:hover:not(:disabled) { box-shadow:0 10px 26px var(--accent-glow); filter:none; transform:translateY(-1px); }
.btn-sec,.btn-ghost { background:var(--surface2); border:1px solid var(--border); color:var(--text); }
.btn-ghost { background:transparent; }
.btn-ghost:hover { border-color:var(--accent); color:var(--accent); }
.btn-danger { background:var(--danger); color:#fff; border:none; }
.btn-sm { padding:.35rem .65rem; font-size:.74rem; }
.full { width:100%; }
.iconbtn {
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  width:38px; height:38px; border-radius:8px; cursor:pointer; font-size:1.1rem;
  background:var(--surface2); border:1px solid var(--border); color:var(--text2); transition:all .15s;
}
.iconbtn:hover { color:var(--accent); border-color:var(--accent-border); }

label { font-size:.72rem; font-weight:700; color:var(--dim); text-transform:uppercase; letter-spacing:.03em; }

/* ══════════════════════════════════════════════════════════════
   STAGE — split-screen "Aurora"
   ══════════════════════════════════════════════════════════════ */
body.split { min-height:100vh; }
.stage { display:grid; grid-template-columns:1.02fr .98fr; min-height:100vh; width:100%; }

/* ── Panel de marca con aurora animada ── */
.brand-panel {
  position:relative; overflow:hidden; isolation:isolate;
  display:flex; flex-direction:column; justify-content:space-between; gap:2rem;
  padding:3.25rem 3.4rem; color:#fff; background:#06120c;
}
.brand-panel::before,.brand-panel::after { content:""; position:absolute; z-index:-2; border-radius:50%; filter:blur(74px); }
.brand-panel::before {
  width:62vmax; height:62vmax; top:-22%; left:-16%; opacity:.8;
  background:radial-gradient(circle at 32% 32%,#00d67e,transparent 60%),
             radial-gradient(circle at 70% 62%,#0891b2,transparent 60%);
  animation:drift1 22s ease-in-out infinite alternate;
}
.brand-panel::after {
  width:52vmax; height:52vmax; bottom:-24%; right:-12%; opacity:.7;
  background:radial-gradient(circle at 50% 50%,#047857,transparent 60%),
             radial-gradient(circle at 28% 72%,#38a3f8,transparent 55%);
  animation:drift2 27s ease-in-out infinite alternate;
}
.brand-panel .grain {
  position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@keyframes drift1 { from { transform:translate(0,0) scale(1); } to { transform:translate(7%,5%) scale(1.16); } }
@keyframes drift2 { from { transform:translate(0,0) scale(1); } to { transform:translate(-6%,-7%) scale(1.12); } }

.bp-mark { display:flex; align-items:center; gap:.6rem; font-size:1.15rem; font-weight:900; letter-spacing:-.02em; }
.bp-mark .chip {
  width:38px; height:38px; border-radius:11px; display:grid; place-items:center;
  background:rgba(0,214,126,.16); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  font-size:1.3rem; color:var(--accent2);
}
.bp-mark b { color:#fff; }
.bp-hero h1 { font-size:clamp(2rem,3.2vw,2.85rem); line-height:1.07; font-weight:900; letter-spacing:-.035em; margin:0 0 .9rem; }
.bp-hero p { font-size:1rem; line-height:1.55; color:rgba(255,255,255,.72); max-width:34ch; }
.bp-hero .accentword { background:linear-gradient(90deg,#6ee7b7,#99f6e4,#38a3f8);
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.bp-feats { display:flex; flex-wrap:wrap; gap:.5rem; }
.bp-feats span { font-size:.74rem; font-weight:700; color:rgba(255,255,255,.85);
  padding:.4rem .75rem; border-radius:99px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.13); display:inline-flex; align-items:center; gap:.35rem; }
.bp-feats i { font-size:.95rem; color:var(--accent2); }
.bp-foot { display:flex; align-items:center; gap:.4rem; font-size:.76rem; font-weight:700;
  color:rgba(255,255,255,.5); letter-spacing:.02em; }
.bp-foot i { font-size:.95rem; }

/* ── Ilustración (llave / escudo) ── */
.bp-art { position:absolute; right:6%; bottom:10%; width:min(46%,320px); z-index:-1; pointer-events:none; animation:floatY 7s ease-in-out infinite; }
.bp-art svg { width:100%; height:auto; filter:drop-shadow(0 26px 44px rgba(0,0,0,.5)); }
@keyframes floatY { 0%,100% { transform:translateY(0) rotate(0); } 50% { transform:translateY(-15px) rotate(-1.3deg); } }
.bp-art .ring { animation:spin 26s linear infinite; transform-origin:center; }
@keyframes spin { to { transform:rotate(360deg); } }
.bp-art .spark { animation:twinkle 3s ease-in-out infinite; }
.bp-art .s2 { animation-delay:.8s; } .bp-art .s3 { animation-delay:1.6s; }
@keyframes twinkle { 0%,100% { opacity:.25; transform:scale(.7); } 50% { opacity:1; transform:scale(1.25); } }

/* Entradas escalonadas */
.bp-mark { animation:fadeDown .6s ease both; }
.bp-hero h1 { animation:fadeUp .7s .08s ease both; }
.bp-hero p { animation:fadeUp .7s .2s ease both; }
.bp-feats span { animation:fadeUp .6s ease both; }
.bp-feats span:nth-child(1){ animation-delay:.30s; }
.bp-feats span:nth-child(2){ animation-delay:.40s; }
.bp-feats span:nth-child(3){ animation-delay:.50s; }
.bp-feats span:nth-child(4){ animation-delay:.60s; }
@keyframes fadeUp { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:none; } }
@keyframes fadeDown { from { opacity:0; transform:translateY(-12px); } to { opacity:1; transform:none; } }

/* ── Panel del formulario ── */
.form-panel { position:relative; display:flex; align-items:center; justify-content:center; padding:2.5rem 1.5rem; background:var(--bg); }
.app-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  width:100%; max-width:440px; padding:1.6rem; box-shadow:var(--shadow-lg);
  animation:cardIn .5s .1s ease both;
}
@keyframes cardIn { from { opacity:0; transform:translateY(20px) scale(.985); } to { opacity:1; transform:none; } }

/* Toggle de idioma ES | EN */
.lang-switch { position:absolute; top:1.1rem; left:1.1rem; z-index:20;
  display:inline-flex; gap:2px; padding:3px; background:var(--surface); border:1px solid var(--border);
  border-radius:999px; box-shadow:var(--shadow-sm); }
.lang-switch button { border:0; cursor:pointer; background:transparent; color:var(--dim);
  font:inherit; font-size:.7rem; font-weight:800; letter-spacing:.03em; padding:.28rem .6rem;
  border-radius:999px; line-height:1; transition:background .15s,color .15s; }
.lang-switch button:hover { color:var(--text); }
.lang-switch button.on { background:var(--accent); color:#04130c; }

/* Icono de login arriba a la derecha */
.login-fab {
  position:absolute; top:1.1rem; right:1.1rem; z-index:20;
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.45rem .7rem; border-radius:99px; cursor:pointer; text-decoration:none;
  background:var(--surface); border:1px solid var(--border); color:var(--text2);
  font-size:.74rem; font-weight:700; transition:all .15s;
}
.login-fab i { font-size:1rem; }
.login-fab:hover { color:var(--accent); border-color:var(--accent-border); background:var(--accent-dim); }

/* Toggle de tema (público / redeem) */
.theme-fab { position:absolute; top:1.1rem; right:11rem; z-index:20; width:34px; height:34px; border-radius:99px;
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; font-size:1rem;
  background:var(--surface); border:1px solid var(--border); color:var(--text2); transition:all .15s; }
.theme-fab:hover { color:var(--accent); border-color:var(--accent-border); background:var(--accent-dim); }
@media (max-width:560px){ .theme-fab { right:auto; left:3.4rem; top:1.15rem; } }

/* ══════════════════════════════════════════════════════════════
   GENERADOR + ENVÍO (público)
   ══════════════════════════════════════════════════════════════ */
.tabs { display:flex; gap:.4rem; background:var(--bg-deep); padding:.3rem; border-radius:10px; border:1px solid var(--border); margin-bottom:1.1rem; }
.tab { flex:1; padding:.55rem; border:none; background:none; color:var(--dim); font-weight:800; font-size:.82rem;
  border-radius:7px; cursor:pointer; font-family:inherit; display:flex; align-items:center; justify-content:center; gap:.4rem; transition:all .15s; }
.tab:hover { color:var(--text2); }
.tab.active { background:var(--accent-dim); color:var(--accent); }

.pwbox { display:flex; align-items:center; gap:.5rem; background:var(--bg-deep); border:1px solid var(--border2); border-radius:10px; padding:.7rem .9rem; margin-bottom:.7rem; }
.pwbox input { flex:1; background:none; border:none; color:var(--accent2); font-family:var(--mono); font-size:1.15rem; font-weight:600; outline:none; letter-spacing:.5px; min-width:0; padding:0; }
.pwbox input:focus { box-shadow:none; }
.strength { display:flex; align-items:center; gap:.6rem; margin-bottom:1rem; }
.bar { flex:1; height:6px; border-radius:99px; background:var(--bg-deep); overflow:hidden; }
.bar>div { height:100%; width:0; transition:.3s; }
.stag { font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; min-width:8.5rem; text-align:right; }
.rowlen { display:flex; align-items:center; gap:.8rem; margin:.7rem 0 1rem; }
.rowlen input[type=range] { flex:1; accent-color:var(--accent); }
.lenval { font-family:var(--mono); font-weight:700; font-size:1.1rem; width:2.2rem; text-align:center; color:var(--accent2); }
.opts { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-top:.4rem; }
.opt { display:flex; align-items:center; gap:.5rem; background:var(--bg-deep); border:1px solid var(--border); border-radius:8px; padding:.55rem .7rem; cursor:pointer; font-size:.82rem; font-weight:600; transition:border-color .15s,background .15s; }
.opt:hover { border-color:var(--accent-border); }
.opt:has(input:checked) { border-color:var(--accent-border); background:var(--accent-dim); }
.opt input { accent-color:var(--accent); width:16px; height:16px; }

.field { margin-bottom:.8rem; }
.field label { display:block; margin-bottom:.3rem; }
/* Llamada de venta (selling point) */
.upsell { display:flex; align-items:flex-start; gap:.6rem; padding:.7rem .8rem; margin-bottom:.9rem;
  background:var(--accent-dim); border:1px solid var(--accent-border); border-radius:var(--radius-md);
  font-size:.78rem; color:var(--text2); line-height:1.5; }
.upsell i { color:var(--accent); font-size:1.15rem; flex-shrink:0; margin-top:.05rem; }
.upsell a { font-weight:800; white-space:nowrap; }
textarea { font-family:var(--mono); resize:vertical; min-height:64px; }
.hint { font-size:.72rem; color:var(--muted); margin-top:.35rem; line-height:1.5; }
.linkout { background:var(--bg-deep); border:1px dashed var(--accent-border); border-radius:10px; padding:.7rem; margin-top:.8rem; word-break:break-all; font-family:var(--mono); font-size:.78rem; color:var(--accent2); }

.card-head { margin-bottom:1.1rem; }
.card-head h2 { font-size:1.25rem; font-weight:900; letter-spacing:-.02em; }
.card-head .sub { color:var(--dim); font-size:.82rem; margin-top:.25rem; }
.foot { text-align:center; color:var(--muted); font-size:.72rem; margin-top:1.2rem; line-height:1.6; }

/* ══════════════════════════════════════════════════════════════
   REDEEM (página de secreto)
   ══════════════════════════════════════════════════════════════ */
.redeem-card { text-align:center; }
.redeem-card .ico { font-size:2.6rem; color:var(--accent); margin-bottom:.6rem; }
.redeem-card h2 { font-size:1.15rem; font-weight:900; margin-bottom:.4rem; }
.redeem-card p { color:var(--dim); font-size:.85rem; line-height:1.6; margin-bottom:1.1rem; }
.secretbox { display:flex; align-items:center; gap:.5rem; background:var(--bg-deep); border:1px solid var(--border2); border-radius:10px; padding:.8rem; margin:1rem 0; text-align:left; }
.secretbox textarea { flex:1; background:none; border:none; color:var(--accent2); font-family:var(--mono); font-size:1rem; outline:none; resize:none; min-height:1.4rem; padding:0; }
.secretbox textarea:focus { box-shadow:none; }
.err { color:var(--red); font-weight:700; }
.warn { font-size:.74rem; color:var(--muted); margin-top:1rem; }

/* ══════════════════════════════════════════════════════════════
   ADMIN — login + dashboard
   ══════════════════════════════════════════════════════════════ */
.login-wrap { display:flex; align-items:center; justify-content:center; min-height:100vh; padding:1.5rem;
  background:radial-gradient(1100px 560px at 50% -10%,var(--bg2) 0%,var(--bg) 55%); }
.login-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2.4rem; width:100%; max-width:380px; box-shadow:var(--shadow-lg); animation:cardIn .5s ease both; }
.login-header { display:flex; align-items:center; justify-content:center; gap:10px; font-size:1.35rem; font-weight:900; margin-bottom:.4rem; }
.login-header i { font-size:1.7rem; color:var(--accent); }
.login-header b { color:var(--accent); }
.login-sub { text-align:center; color:var(--dim); font-size:.82rem; margin-bottom:1.4rem; }
.login-card label { display:block; margin:.85rem 0 .3rem; }
.login-card input { padding:.65rem .85rem; font-size:.9rem; }
.error-msg { color:var(--danger); font-size:.78rem; min-height:1.2em; margin:.5rem 0; }

/* ── Shell canónico SGS (topbar + leftnav + body + rightpanel + footer) ── */
#view-app { min-height:100vh; height:100vh; display:flex; flex-direction:column; }
body.mf-padded #view-app { height:calc(100vh - 22px); }
#view-main { flex:1; display:flex; flex-direction:column; min-height:0; }
.shell { flex:1; display:flex; min-height:0; overflow:hidden; }
.content { flex:1; overflow-y:auto; padding:1.4rem; }
.content .inner { max-width:1280px; margin:0 auto; }
/* Generador a todo el ancho: Generar | Enviar cifrado, mismo alto y ancho */
.gen-grid { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:1.1rem; align-items:stretch; }
.gen-grid .card { margin-bottom:0; display:flex; flex-direction:column; }
.gen-grid .card .g-fill { margin-top:auto; }  /* empuja la acción principal al fondo */
@media (max-width:860px) { .gen-grid { grid-template-columns:1fr; } }

.card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md);
  padding:1.25rem; margin-bottom:1rem; box-shadow:var(--shadow-sm); }
.section-head { display:flex; align-items:center; gap:.5rem; font-size:.95rem; font-weight:800; margin-bottom:.9rem; }
.section-head i { color:var(--accent); }
.form-field label { display:block; margin-bottom:.25rem; }

/* Campo de búsqueda canónico SGS (icono + foco acento + limpiar) */
.search-box { position:relative; display:flex; align-items:center; }
.search-box .s-ico { position:absolute; left:.7rem; font-size:1rem; color:var(--muted); pointer-events:none; transition:color .15s; }
.search-box input { padding-left:2.1rem; padding-right:2rem; }
.search-box input:focus ~ .s-ico, .search-box.has-val .s-ico { color:var(--accent); }
.search-box .s-clear { position:absolute; right:.45rem; display:none; align-items:center; justify-content:center;
  width:22px; height:22px; border:none; background:none; color:var(--muted); cursor:pointer; font-size:1rem; border-radius:6px; }
.search-box.has-val .s-clear { display:flex; }
.search-box .s-clear:hover { color:var(--text); background:var(--hover); }

.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:.8rem; }
table th { padding:.55rem .7rem; text-align:left; font-size:.68rem; text-transform:uppercase; letter-spacing:.04em;
  color:var(--muted); background:var(--bg-deep); border-bottom:2px solid var(--border); font-weight:800; white-space:nowrap; }
table td { padding:.55rem .7rem; border-bottom:1px solid var(--border-subtle); vertical-align:middle; }
table tr:hover td { background:var(--accent-dim); }
.right { text-align:right; }

.badge { display:inline-flex; align-items:center; gap:.3rem; padding:.14rem .55rem; border-radius:20px;
  font-size:.68rem; font-weight:800; background:var(--surface2); color:var(--dim); }
.badge-success { background:var(--success-muted); color:var(--accent); }
.badge-info { background:var(--info-muted); color:var(--info); }
.badge-warn { background:var(--warning-muted); color:var(--warning); }
.badge-danger { background:var(--danger-muted); color:var(--danger); }
.badge-muted { background:var(--surface2); color:var(--muted); }

/* ── Modal ── */
.modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,.62); z-index:200;
  display:flex; align-items:center; justify-content:center; padding:1rem; animation:fadeIn .15s ease; }
.modal { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  max-width:480px; width:100%; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-lg); animation:slideUp .2s ease; }
.modal-head { display:flex; align-items:center; justify-content:space-between; gap:.75rem;
  padding:1.1rem 1.4rem; border-bottom:1px solid var(--border); font-size:1rem; font-weight:800; }
.modal-head .close { cursor:pointer; color:var(--muted); font-size:1.3rem; line-height:1; }
.modal-head .close:hover { color:var(--text); }
.modal-body { padding:1.25rem 1.4rem; }
.modal-foot { display:flex; align-items:center; justify-content:flex-end; gap:.6rem; padding:1rem 1.4rem; border-top:1px solid var(--border); }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes slideUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }

.empty { text-align:center; padding:2.5rem 1rem; color:var(--muted); }
.empty i { font-size:2.5rem; margin-bottom:.4rem; display:block; opacity:.3; }

/* ── Lista de contacto (diálogo de límite) ─────────────────── */
.contact-list { display:flex; flex-direction:column; gap:.5rem; }
.contact-brand { display:flex; align-items:center; gap:.5rem; font-size:.82rem; font-weight:800; color:var(--text); margin-bottom:.15rem; }
.contact-brand i { color:var(--accent); }
.contact-row { display:flex; align-items:center; gap:.65rem; padding:.7rem .85rem; border:1px solid var(--border);
  border-radius:var(--radius-md); color:var(--text2); text-decoration:none; font-size:.85rem; font-weight:600;
  transition:border-color .15s, color .15s, background .15s; }
.contact-row:hover { border-color:var(--accent); color:var(--text); background:var(--accent-dim); }
.contact-row i { font-size:1.15rem; color:var(--accent); }

/* ══════════════════════════════════════════════════════════════
   TOAST
   ══════════════════════════════════════════════════════════════ */
/* Compat: toast simple centrado (app.js / redeem.js) */
.toast { position:fixed; bottom:1.2rem; left:50%; transform:translateX(-50%) translateY(10px);
  background:var(--accent); color:#04130c; font-weight:800; padding:.55rem 1.1rem; border-radius:99px;
  font-size:.82rem; opacity:0; transition:.25s; pointer-events:none; z-index:9999; box-shadow:var(--shadow-md); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.err { background:var(--red); color:#fff; }
.toast.warn { background:var(--orange); color:#1a1208; }
/* Stack de toasts (admin) */
#toasts { position:fixed; top:72px; right:1rem; z-index:9999; display:flex; flex-direction:column; gap:.5rem; pointer-events:none; }
.toast-item { display:flex; align-items:center; gap:.55rem; padding:.65rem 1rem; border-radius:10px; font-size:.8rem; font-weight:700;
  color:#04130c; background:var(--accent); box-shadow:var(--shadow-md); max-width:340px; pointer-events:auto;
  opacity:0; transform:translateX(40px); transition:opacity .22s,transform .22s; }
.toast-item.show { opacity:1; transform:none; }
.toast-item.err { background:var(--red); color:#fff; }
.toast-item.warn { background:var(--orange); color:#1a1208; }
.toast-item.nfo { background:var(--blue); color:#fff; }
.toast-item i { font-size:1.1rem; }

@media (prefers-reduced-motion:reduce) {
  .bp-art,.bp-art .ring,.bp-art .spark,.brand-panel::before,.brand-panel::after,
  .bp-mark,.bp-hero h1,.bp-hero p,.bp-feats span,.app-card,.login-card { animation:none !important; }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width:920px) {
  .stage { grid-template-columns:1fr; }
  .brand-panel { min-height:auto; padding:2.25rem 1.75rem; gap:1.4rem; }
  .bp-art { display:none; }
  .bp-hero h1 { font-size:clamp(1.7rem,7vw,2.2rem); }
  .form-panel { padding:1.75rem 1rem 2.5rem; }
}
@media (max-width:560px) {
  .bp-feats { display:none; }
  .brand-panel { padding:1.75rem 1.5rem; }
  .opts { grid-template-columns:1fr; }
}
