/* ════════════════════════════════════════════════════════════
   ZODEX MAIL — DESIGN SYSTEM v3.0 "NEXUS"
   Premium · Futuristic · Enterprise-grade
════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700;800&display=swap');

/* ── TOKENS ── */
:root {
  /* Colors */
  --c-bg:          #03050b;
  --c-surface:     #070c18;
  --c-surface2:    #0b1120;
  --c-border:      rgba(99,114,153,0.15);
  --c-border-glow: rgba(82,138,255,0.25);
  --c-accent:      #3b7bff;
  --c-accent-dim:  rgba(59,123,255,0.12);
  --c-accent-glow: rgba(59,123,255,0.22);
  --c-green:       #00c77a;
  --c-red:         #ff4757;
  --c-amber:       #ffc531;
  --c-purple:      #8b5cf6;

  /* Text */
  --t-primary:   #e8edf8;
  --t-secondary: #8896b3;
  --t-muted:     #3d4f70;
  --t-accent:    #5c9fff;

  /* Fonts */
  --f-sans:    'Inter', system-ui, sans-serif;
  --f-display: 'Space Grotesk', sans-serif;

  /* Radii */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-full: 9999px;

  /* Shadows */
  --shadow-sm:    0 2px 12px rgba(0,0,0,0.4);
  --shadow-md:    0 8px 32px rgba(0,0,0,0.5);
  --shadow-glow:  0 0 40px rgba(59,123,255,0.1);
  --shadow-card:  0 4px 24px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.03);

  /* Transitions */
  --tr-fast:   0.15s cubic-bezier(0.4,0,0.2,1);
  --tr-base:   0.25s cubic-bezier(0.4,0,0.2,1);
  --tr-spring: 0.4s cubic-bezier(0.34,1.56,0.64,1);
}

/* ── RESET ── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { height:100%; background:var(--c-bg); -webkit-font-smoothing:antialiased; }
body {
  height:100vh; width:100vw; overflow:hidden;
  background:var(--c-bg); color:var(--t-primary);
  font-family:var(--f-sans); display:flex;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(59,123,255,0.06), transparent),
    radial-gradient(ellipse 60% 60% at 80% 80%, rgba(139,92,246,0.04), transparent);
}
a { text-decoration:none; color:inherit; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input,select { font-family:inherit; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--c-accent); }

/* ═══════════════════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════════════════ */
#sb {
  width:240px; min-width:240px; height:100vh;
  background:var(--c-surface);
  border-right:1px solid var(--c-border);
  display:flex; flex-direction:column;
  padding:1.5rem 0.875rem;
  position:relative; z-index:10;
  transition:width var(--tr-base);
}

#sb::before {
  content:'';
  position:absolute; top:0; right:0; width:1px; height:100%;
  background:linear-gradient(to bottom, transparent, var(--c-border-glow) 40%, var(--c-border-glow) 60%, transparent);
  pointer-events:none;
}

/* Brand */
.sb-brand {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.5rem 0.625rem; margin-bottom:2rem;
  border-radius:var(--r-md);
  transition:background var(--tr-fast);
  position:relative;
}
.sb-brand:hover { background:rgba(255,255,255,0.03); }
.sb-logo-wrap {
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(135deg, #1a3a8f, var(--c-accent));
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:#fff;
  box-shadow:0 0 0 1px rgba(59,123,255,0.3), var(--shadow-glow);
  flex-shrink:0;
}
.sb-wordmark {
  font-family:var(--f-display); font-weight:800; font-size:1.1rem;
  background:linear-gradient(135deg, #fff 30%, #6b8fca 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  letter-spacing:-0.4px;
}
.sb-wordmark span { color:var(--t-accent); }

/* Nav */
.sb-nav { display:flex; flex-direction:column; gap:2px; flex:1; }
.sb-lnk {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.65rem 0.875rem; border-radius:var(--r-sm);
  font-size:0.82rem; font-weight:600; color:var(--t-secondary);
  transition:all var(--tr-base);
  border:1px solid transparent;
  position:relative; overflow:hidden;
}
.sb-lnk::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(90deg, var(--c-accent-dim), transparent);
  opacity:0; transition:opacity var(--tr-base);
}
.sb-lnk:hover { color:var(--t-primary); background:rgba(255,255,255,0.04); }
.sb-lnk.on {
  color:var(--t-accent); background:var(--c-accent-dim);
  border-color:var(--c-border-glow);
}
.sb-lnk.on::before { opacity:1; }
.sb-lnk i { width:16px; text-align:center; font-size:0.85rem; }
.sb-badge {
  margin-left:auto; background:var(--c-accent);
  color:#fff; font-size:0.6rem; font-weight:800;
  padding:1px 6px; border-radius:var(--r-full); letter-spacing:0.3px;
  animation:pulse-badge 2s ease-in-out infinite;
}
@keyframes pulse-badge {
  0%,100% { box-shadow:0 0 0 0 rgba(59,123,255,0.4); }
  50% { box-shadow:0 0 0 4px transparent; }
}

/* Footer user card */
.sb-footer { margin-top:auto; padding-top:1rem; border-top:1px solid var(--c-border); }
.sb-user {
  display:flex; align-items:center; gap:0.65rem;
  padding:0.7rem 0.75rem; border-radius:var(--r-md);
  background:rgba(255,255,255,0.025);
  border:1px solid var(--c-border);
  transition:all var(--tr-fast);
}
.sb-user:hover { border-color:var(--c-border-glow); background:rgba(59,123,255,0.05); }
.sb-av {
  width:32px; height:32px; border-radius:9px;
  background:linear-gradient(135deg, var(--c-accent), var(--c-purple));
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:0.85rem; color:#fff; flex-shrink:0;
  box-shadow:0 0 12px rgba(59,123,255,0.3);
}
.sb-uname { font-size:0.78rem; font-weight:700; color:var(--t-primary); }
.sb-role {
  font-size:0.55rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1.2px; color:var(--c-accent);
}
.sb-login-cta {
  display:flex; align-items:center; gap:0.6rem;
  padding:0.65rem 0.875rem; border-radius:var(--r-sm);
  font-size:0.8rem; font-weight:600; color:var(--t-secondary);
  transition:all var(--tr-fast);
  background:transparent; border:1px solid var(--c-border);
}
.sb-login-cta:hover { border-color:var(--c-border-glow); color:var(--t-accent); }

/* ═══════════════════════════════════════════════════════════
   MAIN CONTAINER
═══════════════════════════════════════════════════════════ */
#main {
  flex:1; height:100vh; overflow-y:auto;
  background:var(--c-bg);
  display:flex; flex-direction:column;
  position:relative;
}

/* Background grid */
#main::before {
  content:'';
  position:fixed; inset:0; left:240px;
  background-image:
    linear-gradient(rgba(99,114,153,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,114,153,0.03) 1px, transparent 1px);
  background-size:44px 44px;
  pointer-events:none; z-index:0;
}

/* ── TOPBAR ── */
#tb {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 2rem;
  height:60px; min-height:60px;
  border-bottom:1px solid var(--c-border);
  background:rgba(7,12,24,0.85);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px);
  position:sticky; top:0; z-index:9;
}

.tb-left h1 {
  font-family:var(--f-display); font-size:0.95rem; font-weight:700;
  color:var(--t-primary); letter-spacing:-0.2px;
}
.tb-left p {
  font-size:0.65rem; color:var(--t-muted); margin-top:1px;
}

.tb-right { display:flex; align-items:center; gap:0.5rem; }

/* Icon buttons */
.icon-btn {
  width:34px; height:34px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--c-border);
  border-radius:var(--r-sm); color:var(--t-secondary);
  display:flex; align-items:center; justify-content:center;
  font-size:0.8rem; cursor:pointer;
  transition:all var(--tr-base);
}
.icon-btn:hover {
  border-color:var(--c-border-glow);
  background:var(--c-accent-dim); color:var(--t-accent);
  box-shadow:0 0 12px rgba(59,123,255,0.15);
}
.icon-btn.danger:hover { border-color:rgba(255,71,87,0.3); color:var(--c-red); background:rgba(255,71,87,0.08); }
.icon-btn.text-btn { width:auto; padding:0 0.75rem; font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; gap:5px; }

/* ── PAGE WRAPPER ── */
#pg {
  flex:1; padding:1.75rem 2rem 4rem;
  position:relative; z-index:1;
}

/* ═══════════════════════════════════════════════════════════
   INBOX
═══════════════════════════════════════════════════════════ */
.inbox-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1.5rem;
}
.inbox-title {
  font-family:var(--f-display); font-size:1.5rem; font-weight:800;
  color:var(--t-primary); letter-spacing:-0.5px;
}
.inbox-count {
  display:inline-flex; align-items:center;
  padding:3px 10px; border-radius:var(--r-full);
  background:var(--c-accent-dim); color:var(--t-accent);
  font-size:0.65rem; font-weight:800; text-transform:uppercase; letter-spacing:1px;
  border:1px solid var(--c-border-glow); margin-left:10px;
}

/* Email card */
.email-card {
  display:flex; align-items:center; gap:1rem;
  padding:1rem 1.25rem;
  background:var(--c-surface);
  border:1px solid var(--c-border);
  border-radius:var(--r-md);
  margin-bottom:0.5rem; cursor:pointer;
  transition:all var(--tr-base);
  position:relative; overflow:hidden;
}
.email-card::before {
  content:''; position:absolute; left:0; top:0;
  width:3px; height:100%;
  background:var(--c-accent); opacity:0;
  transition:opacity var(--tr-base);
}
.email-card:hover {
  border-color:var(--c-border-glow);
  background:linear-gradient(90deg, rgba(59,123,255,0.05) 0%, var(--c-surface) 60%);
  transform:translateX(4px);
  box-shadow:var(--shadow-card);
}
.email-card:hover::before { opacity:1; }

.e-av {
  width:42px; height:42px; border-radius:12px; flex-shrink:0;
  background:linear-gradient(135deg, var(--c-accent), var(--c-purple));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-weight:800; font-size:1rem; color:#fff;
  box-shadow:0 4px 16px rgba(59,123,255,0.2);
}
.e-info { flex:1; min-width:0; }
.e-from {
  font-weight:700; font-size:0.85rem; color:var(--t-primary);
  margin-bottom:3px; display:flex; align-items:center; gap:6px;
}
.e-from .verified { color:var(--c-accent); font-size:0.7rem; }
.e-sub { font-size:0.78rem; color:var(--t-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.e-time { font-size:0.64rem; font-weight:600; color:var(--t-muted); white-space:nowrap; }

/* Empty state */
.empty-state {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:6rem 2rem; text-align:center;
}
.empty-ico {
  width:80px; height:80px; border-radius:var(--r-lg);
  background:var(--c-accent-dim); border:1px solid var(--c-border-glow);
  display:flex; align-items:center; justify-content:center;
  font-size:2rem; color:var(--c-accent); margin-bottom:1.5rem;
  animation:float 3s ease-in-out infinite;
}
@keyframes float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-8px); } }
.empty-state h3 { font-family:var(--f-display); font-weight:800; font-size:1.1rem; color:var(--t-primary); margin-bottom:0.5rem; }
.empty-state p { font-size:0.8rem; color:var(--t-secondary); max-width:260px; line-height:1.6; }

/* ═══════════════════════════════════════════════════════════
   EMAIL VIEWER
═══════════════════════════════════════════════════════════ */
.msg-meta {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:var(--r-md); padding:1.25rem 1.5rem;
  margin-bottom:1.25rem; display:flex; gap:1.25rem; align-items:flex-start;
}
.msg-meta-av {
  width:48px; height:48px; border-radius:14px; flex-shrink:0;
  background:linear-gradient(135deg, var(--c-accent), var(--c-purple));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-weight:800; font-size:1.2rem; color:#fff;
  box-shadow:0 4px 20px rgba(59,123,255,0.25);
}
.msg-subject { font-family:var(--f-display); font-weight:800; font-size:1.1rem; color:var(--t-primary); margin-bottom:4px; }
.msg-from { font-size:0.78rem; color:var(--t-secondary); }
.msg-from strong { color:var(--t-primary); }

.msg-iframe-wrap {
  background:#fff; border-radius:var(--r-md); overflow:hidden;
  border:1px solid var(--c-border); box-shadow:var(--shadow-md);
}
.msg-iframe { width:100%; border:none; min-height:500px; display:block; }

.msg-meta-row {
  display:flex; gap:0.5rem; flex-wrap:wrap; margin-top:0.75rem;
}
.meta-chip {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:var(--r-full);
  background:var(--c-accent-dim); border:1px solid var(--c-border-glow);
  font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.8px;
  color:var(--t-accent);
}

/* ═══════════════════════════════════════════════════════════
   EMPIRE MANAGER (GESTION)
═══════════════════════════════════════════════════════════ */

/* Wizard card */
.wiz {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:var(--r-xl); overflow:hidden;
  margin-bottom:1.75rem;
  box-shadow:var(--shadow-card);
}
.wiz-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 1.5rem; border-bottom:1px solid var(--c-border);
  background:linear-gradient(90deg, rgba(59,123,255,0.04), transparent 70%);
}
.wiz-header h2 {
  font-family:var(--f-display); font-weight:800; font-size:0.95rem; color:var(--t-primary);
}
.wiz-header p { font-size:0.65rem; color:var(--t-muted); margin-top:2px; }

/* Step pills */
.steps { display:flex; align-items:center; gap:4px; }
.step-pill {
  display:flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:var(--r-full);
  font-size:0.62rem; font-weight:800; text-transform:uppercase;
  letter-spacing:0.6px; color:var(--t-muted);
  transition:all var(--tr-base);
}
.step-pill.act {
  background:var(--c-accent-dim); color:var(--t-accent);
  border:1px solid var(--c-border-glow);
  box-shadow:0 0 12px rgba(59,123,255,0.1);
}
.step-pill.done { color:var(--c-green); }
.step-num {
  width:18px; height:18px; border-radius:50%;
  background:rgba(255,255,255,0.06); font-size:0.6rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--tr-base); flex-shrink:0;
  position:relative;
}
.step-pill.act .step-num { background:var(--c-accent); color:#fff; box-shadow:0 0 8px rgba(59,123,255,0.4); }
.step-pill.done .step-num {
  background:var(--c-green); color:transparent; font-size:0;
}
.step-pill.done .step-num::after {
  content:'\f00c';
  font-family:'Font Awesome 6 Free'; font-weight:900;
  font-size:9px; color:#fff; position:absolute;
}
.step-divider { width:18px; height:1px; background:var(--c-border); }

.wiz-body { padding:1.5rem; }
.wiz-step { display:none; }
.wiz-step.act { display:block; animation:slideIn 0.3s var(--tr-spring); }
@keyframes slideIn { from { opacity:0; transform:translateX(16px); } to { opacity:1; transform:translateX(0); } }

/* Service tag */
.svc-tag {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 12px; border-radius:var(--r-full);
  font-size:0.62rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1px; margin-bottom:1rem;
}
.step-title {
  font-family:var(--f-display); font-size:1.5rem; font-weight:800;
  color:var(--t-primary); line-height:1.2; margin-bottom:4px; letter-spacing:-0.5px;
}
.step-sub { font-size:0.75rem; color:var(--t-muted); margin-bottom:1.5rem; }

/* Credential bubbles grid */
.bubs { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr)); gap:0.875rem; margin-bottom:1.5rem; }
.bub {
  background:var(--c-surface2); border:1px solid var(--c-border);
  border-radius:var(--r-md); padding:1.1rem;
  position:relative; cursor:pointer; overflow:hidden;
  transition:all var(--tr-base); user-select:none;
}
.bub::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at top right, rgba(59,123,255,0.08), transparent 60%);
  opacity:0; transition:opacity var(--tr-base);
}
.bub:hover { border-color:var(--c-border-glow); transform:translateY(-3px); box-shadow:var(--shadow-card); }
.bub:hover::before { opacity:1; }
.bub:active { transform:translateY(0) scale(0.98); }
.b-label { font-size:0.52rem; font-weight:800; text-transform:uppercase; letter-spacing:2px; color:var(--t-muted); margin-bottom:0.5rem; }
.b-value { font-family:var(--f-display); font-size:0.95rem; font-weight:700; color:var(--t-primary); word-break:break-all; }
.b-actions { position:absolute; top:0.6rem; right:0.6rem; display:flex; gap:3px; opacity:0; transition:opacity var(--tr-fast); }
.bub:hover .b-actions { opacity:1; }
.micro-btn {
  width:24px; height:24px; border-radius:7px;
  background:rgba(0,0,0,0.5); backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,0.08);
  display:flex; align-items:center; justify-content:center;
  color:var(--t-secondary); font-size:0.6rem;
  cursor:pointer; transition:all var(--tr-fast);
}
.micro-btn:hover { background:var(--c-accent); border-color:var(--c-accent); color:#fff; transform:scale(1.1); }
.b-hint {
  position:absolute; bottom:0.6rem; right:0.75rem;
  font-size:0.52rem; color:var(--t-muted);
  display:flex; align-items:center; gap:3px;
  opacity:0; transition:opacity var(--tr-fast);
}
.bub:hover .b-hint { opacity:1; }

/* Rockstar action bubble */
.bub-action {
  border-style:dashed; border-color:rgba(255,197,49,0.25)!important;
  background:rgba(255,197,49,0.03)!important;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; min-height:80px;
}
.bub-action:hover { background:rgba(255,197,49,0.07)!important; border-color:rgba(255,197,49,0.45)!important; }
.bub-action .ba-label { font-size:0.55rem; font-weight:800; text-transform:uppercase; letter-spacing:1.5px; color:var(--t-muted); }
.bub-action .ba-value { font-family:var(--f-display); font-weight:900; font-size:0.9rem; color:var(--c-amber); }

/* Wizard nav */
.wiz-nav { display:flex; gap:0.75rem; margin-top:1.5rem; }
.wiz-nav .btn { flex:1; }

/* ═══════════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:0.75rem 1.25rem; border-radius:var(--r-sm); border:none;
  font-family:var(--f-sans); font-size:0.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.5px; cursor:pointer;
  transition:all var(--tr-base); position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(rgba(255,255,255,0.08), transparent);
  opacity:0; transition:opacity var(--tr-fast);
}
.btn:hover::after { opacity:1; }
.btn-primary { background:var(--c-accent); color:#fff; box-shadow:0 4px 16px rgba(59,123,255,0.3); }
.btn-primary:hover { background:#2a6bef; box-shadow:0 6px 24px rgba(59,123,255,0.45); transform:translateY(-1px); }
.btn-ghost { background:rgba(255,255,255,0.04); color:var(--t-secondary); border:1px solid var(--c-border); }
.btn-ghost:hover { background:rgba(255,255,255,0.07); color:var(--t-primary); border-color:rgba(255,255,255,0.12); }
.btn-success { background:var(--c-green); color:#fff; box-shadow:0 4px 16px rgba(0,199,122,0.3); }
.btn-success:hover { background:#00b06d; box-shadow:0 6px 24px rgba(0,199,122,0.4); transform:translateY(-1px); }
.btn-danger { background:var(--c-red); color:#fff; box-shadow:0 4px 16px rgba(255,71,87,0.3); }
.btn-danger:hover { background:#e6394a; }
.btn:disabled { opacity:0.5; cursor:not-allowed; transform:none!important; }

/* Small btn */
.btn-xs {
  display:inline-flex; align-items:center; gap:5px;
  padding:0.35rem 0.875rem; border-radius:var(--r-sm);
  background:rgba(255,255,255,0.04); border:1px solid var(--c-border);
  color:var(--t-secondary); font-size:0.65rem; font-weight:700;
  cursor:pointer; transition:all var(--tr-fast);
  text-transform:uppercase; letter-spacing:0.4px;
}
.btn-xs:hover { color:var(--t-primary); border-color:rgba(255,255,255,0.12); }

/* ═══════════════════════════════════════════════════════════
   VAULT / ACCOUNTS
═══════════════════════════════════════════════════════════ */
.section-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1.25rem; padding-bottom:0.875rem;
  border-bottom:1px solid var(--c-border);
}
.section-title {
  font-family:var(--f-display); font-size:1.1rem; font-weight:800;
  color:var(--t-primary); display:flex; align-items:center; gap:10px;
}
.section-title i { color:var(--c-accent); font-size:0.9rem; }
.section-count { font-size:0.65rem; font-weight:700; color:var(--t-muted); font-family:var(--f-sans); margin-left:4px; }

.acc {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:var(--r-md); overflow:hidden;
  transition:all var(--tr-base); margin-bottom:0.625rem;
  position:relative;
}
.acc::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--c-accent); opacity:0;
  transition:opacity var(--tr-base);
}
.acc:hover { border-color:var(--c-border-glow); box-shadow:var(--shadow-card); }
.acc:hover::before { opacity:1; }

.acc-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:0.875rem 1.25rem; cursor:pointer;
}
.acc-email {
  display:flex; align-items:center; gap:8px;
  font-size:0.85rem; font-weight:700; color:var(--t-primary);
}
.acc-email i { color:var(--c-accent); font-size:0.75rem; }
.acc-meta { display:flex; align-items:center; gap:8px; }
.acc-date { font-size:0.62rem; color:var(--t-muted); }
.acc-actions { display:flex; gap:4px; }
.acc-btn {
  width:28px; height:28px; border-radius:var(--r-xs);
  background:transparent; border:1px solid var(--c-border);
  display:flex; align-items:center; justify-content:center;
  color:var(--t-muted); font-size:0.65rem; cursor:pointer;
  transition:all var(--tr-fast);
}
.acc-btn.view:hover { background:var(--c-accent-dim); border-color:var(--c-border-glow); color:var(--t-accent); }
.acc-btn.del:hover { background:rgba(255,71,87,0.1); border-color:rgba(255,71,87,0.3); color:var(--c-red); }

.acc-body {
  display:grid; grid-template-columns:repeat(3,1fr);
  max-height:0; overflow:hidden;
  transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1);
  border-top:1px solid transparent;
}
.acc-body.open { max-height:200px; border-top-color:var(--c-border); }
.acc-section { padding:1rem 1.25rem; border-right:1px solid var(--c-border); }
.acc-section:last-child { border-right:none; }
.acc-svc-name {
  display:flex; align-items:center; gap:6px;
  font-size:0.58rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1.5px; margin-bottom:0.75rem;
}
.field { margin-bottom:0.5rem; }
.field-label {
  font-size:0.5rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1.5px; color:var(--t-muted); margin-bottom:2px;
}
.field-value {
  font-size:0.75rem; font-weight:600; color:var(--t-secondary);
  word-break:break-all; cursor:pointer; display:flex; align-items:center; gap:5px;
  transition:color var(--tr-fast); padding:2px 0;
}
.field-value i { font-size:0.55rem; opacity:0; transition:opacity var(--tr-fast); }
.field-value:hover { color:var(--c-accent); }
.field-value:hover i { opacity:1; }

/* Vault empty state */
.vault-empty {
  text-align:center; padding:4rem 2rem;
  border:2px dashed rgba(99,114,153,0.1);
  border-radius:var(--r-xl);
  background:rgba(255,255,255,0.005);
  display:flex; flex-direction:column; align-items:center;
}
.vault-empty i { font-size:3rem; color:var(--c-accent); opacity:0.15; margin-bottom:1.25rem; }
.vault-empty h3 { font-family:var(--f-display); font-weight:800; color:var(--t-muted); font-size:0.95rem; margin-bottom:0.5rem; }
.vault-empty p { font-size:0.78rem; color:var(--t-muted); max-width:240px; line-height:1.6; }

/* ═══════════════════════════════════════════════════════════
   AUTH PAGES
═══════════════════════════════════════════════════════════ */
.auth-page {
  display:flex; align-items:center; justify-content:center;
  height:100vh; width:100vw;
  background:var(--c-bg);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(59,123,255,0.06), transparent),
    radial-gradient(ellipse 60% 60% at 80% 80%, rgba(139,92,246,0.04), transparent);
  position: relative;
}
.auth-page::before {
  content: '';
  position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(99,114,153,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,114,153,0.03) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none; z-index: 0;
}

.auth-card {
  width:100%; max-width:400px;
  background:var(--c-surface);
  border:1px solid var(--c-border);
  border-radius:var(--r-xl);
  padding:2.5rem;
  box-shadow:var(--shadow-md), 0 0 80px rgba(59,123,255,0.05);
  animation:cardIn 0.5s var(--tr-spring);
}
@keyframes cardIn { from { opacity:0; transform:translateY(24px) scale(0.98); } to { opacity:1; transform:none; } }

.auth-logo {
  width:60px; height:60px; border-radius:18px;
  background:linear-gradient(135deg, #1a3a8f, var(--c-accent));
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:#fff; margin:0 auto 1.5rem;
  box-shadow:0 0 0 1px rgba(59,123,255,0.3), 0 0 40px rgba(59,123,255,0.2);
}
.auth-title {
  font-family:var(--f-display); font-size:1.5rem; font-weight:800;
  color:var(--t-primary); text-align:center; margin-bottom:4px;
}
.auth-sub {
  font-size:0.78rem; color:var(--t-secondary); text-align:center; margin-bottom:2rem; line-height:1.5;
}

/* Form fields */
.form-group { margin-bottom:1.1rem; }
.form-label {
  display:block; font-size:0.62rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1.5px; color:var(--t-muted); margin-bottom:0.5rem;
}
.form-input {
  width:100%; padding:0.8rem 1rem;
  background:var(--c-surface2); border:1px solid var(--c-border);
  border-radius:var(--r-sm); color:var(--t-primary);
  font-size:0.88rem; font-family:var(--f-sans);
  outline:none; transition:all var(--tr-base);
}
.form-input:focus {
  border-color:var(--c-border-glow);
  background:rgba(59,123,255,0.04);
  box-shadow:0 0 0 3px rgba(59,123,255,0.12);
}
.form-input::placeholder { color:var(--t-muted); }

/* PIN specific */
.pin-input {
  text-align:center; font-size:2.5rem; font-family:var(--f-display); font-weight:800;
  letter-spacing:1rem; padding:1rem 1.25rem;
}

/* ═══════════════════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════════════════ */
#toast {
  position:fixed; bottom:1.5rem; right:1.5rem;
  padding:0.75rem 1.25rem; border-radius:var(--r-md);
  font-size:0.78rem; font-weight:700; z-index:9999;
  display:flex; align-items:center; gap:8px;
  transform:translateY(80px) scale(0.95); opacity:0;
  transition:transform 0.4s var(--tr-spring), opacity 0.35s ease;
  white-space:nowrap; pointer-events:none;
  backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,0.1);
}
#toast.show { transform:translateY(0) scale(1); opacity:1; }
.toast-info  { background:linear-gradient(135deg, rgba(59,123,255,0.9), rgba(30,80,200,0.9)); color:#fff; }
.toast-ok    { background:linear-gradient(135deg, rgba(0,199,122,0.9), rgba(0,150,90,0.9)); color:#fff; }
.toast-error { background:linear-gradient(135deg, rgba(255,71,87,0.9), rgba(200,40,50,0.9)); color:#fff; }

/* ═══════════════════════════════════════════════════════════
   SPIN ANIMATION
═══════════════════════════════════════════════════════════ */
.spin { animation:spin 0.9s linear infinite; display:inline-block; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Staggered card animation ── */
.fade-in { animation:fadeUp 0.4s ease-out both; }
@keyframes fadeUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media(max-width:768px) {
  body { flex-direction:column; height:auto; overflow:auto; }
  #main::before { left:0; }
  #sb { width:100%; min-width:unset; height:auto; padding:1rem; }
  #main { height:auto; overflow:visible; }
  #pg { padding:1.25rem; }
  .bubs { grid-template-columns:1fr 1fr; }
  .acc-body { grid-template-columns:1fr; }
  .acc-section { border-right:none; border-bottom:1px solid var(--c-border); }
  .auth-card { margin:1rem; padding:2rem 1.5rem; border-radius:var(--r-lg); }
  #tb { padding:0 1.25rem; }
}
/* ═══════════════════════════════════════════════════════════
   MODAL DIALOGS (Z-Dialog)
   ═══════════════════════════════════════════════════════════ */
.zx-modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.7);
  backdrop-filter:blur(10px) saturate(180%);
  display:none; align-items:center; justify-content:center;
  z-index:10000; opacity:0; pointer-events:none;
  transition:all 0.2s ease;
}
.zx-modal-overlay.show { display:flex; opacity:1; pointer-events:auto; }

.zx-modal {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:var(--r-xl); width:calc(100% - 2rem); max-width:420px;
  padding:2.5rem; box-shadow:0 20px 80px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.05);
  transform:scale(0.9) translateY(20px); transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  text-align:center;
}
.zx-modal-overlay.show .zx-modal { transform:scale(1) translateY(0); }

.zx-modal-icon {
  width:64px; height:64px; border-radius:20px;
  background:var(--c-accent-dim); color:var(--c-accent);
  display:flex; align-items:center; justify-content:center;
  font-size:1.75rem; margin:0 auto 1.5rem;
  box-shadow:0 0 30px rgba(59,123,255,0.1);
}
.zx-modal-title { font-family:var(--f-display); font-size:1.4rem; font-weight:800; margin-bottom:0.75rem; color:var(--t-primary); }
.zx-modal-text { font-size:0.9rem; color:var(--t-secondary); line-height:1.6; margin-bottom:2.25rem; }
.zx-modal-actions { display:flex; gap:0.75rem; }
.zx-modal-actions .btn { flex:1; }
/* ═══════════════════════════════════════════════════════════
   PIN KEYPAD SYSTEM
   ═══════════════════════════════════════════════════════════ */
.pin-dots { display: flex; justify-content: center; gap: 1rem; margin: 2rem 0; }
.pin-dot {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid var(--c-border); transition: all 0.2s cubic-bezier(0.18,0.89,0.32,1.28);
}
.pin-dot.filled { background: var(--c-accent); border-color: var(--c-accent); box-shadow: 0 0 15px var(--shadow-glow); transform: scale(1.2); }

.pin-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem;
  max-width: 280px; margin: 0 auto; justify-items: center;
}
.pin-btn {
  width: 68px; height: 68px; border-radius: 50%;
  background: rgba(255,255,255,0.03); border: 1px solid var(--c-border);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-size: 1.6rem; font-family: var(--f-display); font-weight: 700; cursor: pointer;
  transition: all 0.15s ease; user-select: none; color: var(--t-primary);
  line-height: 1;
}
.pin-btn span { font-size: 0.6rem; font-weight: 800; color: var(--t-muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 1px; }

.pin-btn:hover { background: rgba(255,255,255,0.07); transform: translateY(-2px); border-color: rgba(255,255,255,0.2); }
.pin-btn:active { background: var(--c-accent-dim); color: var(--c-accent); transform: scale(0.92); }
.pin-btn.backspace { font-size: 1.25rem; color: var(--t-muted); border-color: transparent; background: transparent; }
.pin-btn.backspace:hover { color: var(--c-red); background: rgba(255,71,87,0.1); transform: none; }

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-10px); }
  40%, 80% { transform: translateX(10px); }
}
.shake { animation: shake 0.4s ease-in-out; }
