/* ==========================================================================
   Passwordn — Agency Credential Management
   Mobile-first · Light & Dark · Navy primary · AES-256 encrypted
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Archivo+Narrow:ital,wght@0,400..700;1,400..700&family=Archivo:ital,wdth,wght@0,62..125,100..900;1,62..125,100..900&family=Google+Sans:ital,opsz,wght@0,17..18,100..900;1,17..18,100..900&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── Design tokens ──────────────────────────────────────────────────── */
:root {
  --navy-50:  #EFF3FC; --navy-100: #D8E2F7; --navy-200: #A9BEE8;
  --navy-300: #6E8DD4; --navy-400: #3E63BF; --navy-500: #1E3A8A;
  --navy-600: #17306F; --navy-700: #112657; --navy-800: #0B1B40; --navy-900: #071128;
  --red: #EF4444;   --red-dk: #DC2626;   --red-bg: rgba(239,68,68,.12);
  --grn: #22C55E;   --grn-dk: #16A34A;   --grn-bg: rgba(34,197,94,.12);
  --yel: #F59E0B;   --yel-dk: #D97706;   --yel-bg: rgba(245,158,11,.15);
  --pur: #A855F7;   --pur-dk: #9333EA;
  --r-xs: 6px; --r-sm: 8px; --r: 12px; --r-lg: 16px; --r-xl: 22px; --r-2xl: 28px;
  --ease: cubic-bezier(.22,.68,.2,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t: 180ms; --t-fast: 100ms; --t-slow: 380ms;
  --font: "Google Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --font-heading: "Archivo", sans-serif;
  --font-ui: "Archivo", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --safe-top:    env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left, 0px);
  --safe-right:  env(safe-area-inset-right, 0px);
  --tab-h: 64px;
}

/* ── Light theme ─────────────────────────────────────────────────────── */
:root, [data-theme="light"] {
  --bg:        #F4F6FB; --bg-2: #ECF0F7; --bg-3: #E4EAF5;
  --surface:   #FFFFFF; --surface-2: #F8FAFD; --surface-3: #F1F4FB;
  --border:    rgba(30,58,138,.10); --border-2: rgba(30,58,138,.18);
  --text:      #0A1628; --text-2: #3A4A6B; --text-3: #6C7A98; --muted: #9AA5BC;
  --primary:   #1E3A8A; --primary-h: #17306F; --primary-l: #3E63BF;
  --on-primary: #FFFFFF;
  --shadow-xs: 0 1px 2px rgba(10,22,40,.06);
  --shadow-sm: 0 1px 3px rgba(10,22,40,.07), 0 4px 12px rgba(10,22,40,.05);
  --shadow:    0 1px 3px rgba(10,22,40,.08), 0 8px 24px rgba(10,22,40,.08);
  --shadow-lg: 0 4px 6px rgba(10,22,40,.05), 0 20px 50px rgba(10,22,40,.15);
  --shadow-xl: 0 8px 10px rgba(10,22,40,.05), 0 40px 80px rgba(10,22,40,.22);
  --glow:   radial-gradient(ellipse 100% 60% at 50% -10%, rgba(30,58,138,.14), transparent 65%);
  --grid-line: rgba(30,58,138,.05);
  --input-bg: #FFFFFF;
  --sidebar-bg: #FFFFFF;
  --sidebar-border: rgba(30,58,138,.10);
  --card-glass: rgba(255,255,255,.92);
  --overlay: rgba(5,12,30,.6);
  color-scheme: light;
  --accent-gradient: linear-gradient(135deg, #1E3A8A 0%, #059669 100%);
  --accent-glow: rgba(30,58,138,.18);
}

/* ── Dark theme ──────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:        #08080E;
  --bg-2:      #0B0B17;
  --bg-3:      #10102A;
  --surface:   #0F0F1E;
  --surface-2: #141428;
  --surface-3: #1A1A35;
  --border:    rgba(110,100,220,.13);
  --border-2:  rgba(130,120,255,.24);
  --text:      #F0F0FF;
  --text-2:    #9090B8;
  --text-3:    #55557A;
  --muted:     #3A3A60;
  --primary:   #3B7DFF;
  --primary-h: #5B96FF;
  --primary-l: #2260EB;
  --on-primary: #FFFFFF;
  --shadow-xs: 0 1px 2px rgba(0,0,0,.5);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.4);
  --shadow:    0 1px 3px rgba(0,0,0,.65), 0 8px 24px rgba(0,0,0,.55);
  --shadow-lg: 0 4px 6px rgba(0,0,0,.55), 0 20px 50px rgba(0,0,0,.75);
  --shadow-xl: 0 8px 10px rgba(0,0,0,.6), 0 40px 80px rgba(0,0,0,.88);
  --glow:      radial-gradient(ellipse 100% 60% at 50% -10%, rgba(59,125,255,.20), transparent 65%);
  --grid-line: rgba(59,125,255,.06);
  --input-bg:  #0F0F1E;
  --sidebar-bg: #0B0B17;
  --sidebar-border: rgba(110,100,220,.13);
  --card-glass: rgba(15,15,30,.96);
  --overlay:   rgba(0,0,0,.82);
  color-scheme: dark;
  --red: #F87171; --red-dk: #EF4444; --red-bg: rgba(248,113,113,.14);
  --grn: #34D399; --grn-dk: #10B981; --grn-bg: rgba(52,211,153,.12);
  --yel: #FBBF24; --yel-dk: #F59E0B; --yel-bg: rgba(251,191,36,.14);
  --accent-gradient: linear-gradient(135deg, #3B7DFF 0%, #10B981 100%);
  --accent-glow: rgba(59,125,255,.22);
}

/* ── Reset & base ────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; padding: 0;
  font-family: var(--font);
  font-optical-sizing: auto;
  font-variation-settings: "GRAD" 0;
  background: var(--bg); color: var(--text);
  -webkit-font-smoothing: antialiased;
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
  min-height: 100dvh;
  overscroll-behavior: none;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; -webkit-tap-highlight-color: transparent; }
input, textarea, select { font: inherit; color: var(--text); }
img, svg { display: block; max-width: 100%; }
ul, ol { list-style: none; margin: 0; padding: 0; }
:focus-visible { outline: 2px solid color-mix(in oklab, var(--primary) 70%, white); outline-offset: 2px; border-radius: 6px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* ── Type ───────────────────────────────────────────────────────────── */
.h1 { font-family: var(--font-heading); font-size: clamp(52px,7vw,96px); font-weight: 700; letter-spacing: -0.025em; line-height: 1.04; margin: 0; font-optical-sizing: auto; }
.h2 { font-family: var(--font-heading); font-size: clamp(36px,4.5vw,60px); font-weight: 700; letter-spacing: -0.022em; line-height: 1.07; margin: 0; font-optical-sizing: auto; }
.h3 { font-family: var(--font-heading); font-size: clamp(22px,2.4vw,28px); font-weight: 600; letter-spacing: -0.015em; line-height: 1.2; margin: 0; font-optical-sizing: auto; }
.h4 { font-family: var(--font-heading); font-size: clamp(16px,1.6vw,19px); font-weight: 600; letter-spacing: -0.008em; margin: 0; font-optical-sizing: auto; }
.lead { font-size: clamp(16px,1.4vw,19px); line-height: 1.65; color: var(--text-2); margin: 0; max-width: 62ch; }
.muted  { color: var(--text-2); }
.muted2 { color: var(--text-3); }
.mono   { font-family: var(--mono); }
.grad-text {
  background: linear-gradient(120deg, var(--primary-l) 0%, var(--pur) 60%, #C084FC 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  background-size: 200% auto;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  width: fit-content; align-self: flex-start; justify-self: start;
  font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--primary);
  background: color-mix(in oklab, var(--primary) 10%, transparent);
  padding: 5px 10px; border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--primary) 22%, transparent);
}
/* Space above headings when preceded by any element */
* + .h1 { margin-top: clamp(20px, 3vw, 36px); }
* + .h2 { margin-top: clamp(16px, 2.5vw, 28px); }
* + .h3 { margin-top: clamp(14px, 2vw, 22px); }
* + .h4 { margin-top: clamp(10px, 1.5vw, 16px); }

/* ── Layout ─────────────────────────────────────────────────────────── */
.container { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px; }
.section { padding: clamp(64px, 9vw, 128px) 0; position: relative; }
.row   { display: flex; align-items: center; gap: 10px; }
.col   { display: flex; flex-direction: column; gap: 8px; }
.between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.center  { display: flex; align-items: center; justify-content: center; }
.grid    { display: grid; }

/* ── Navigation ─────────────────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 40;
  padding-top: var(--safe-top);
  backdrop-filter: saturate(1.8) blur(16px);
  -webkit-backdrop-filter: saturate(1.8) blur(16px);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  border-bottom: 1px solid var(--border);
}
.nav .container { height: 64px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-heading); font-weight: 700; font-size: 17px; letter-spacing: -.01em; font-optical-sizing: auto; }
.brand .mark { width: 28px; height: 28px; flex-shrink: 0; }
.nav-links { display: flex; gap: 2px; align-items: center; }
.nav-link { padding: 7px 11px; border-radius: 9px; color: var(--text-2); font-family: var(--font-ui); font-variation-settings: "wdth" 100; font-weight: 500; font-size: 13.5px; transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease); }
.nav-link:hover { color: var(--text); background: color-mix(in oklab, var(--text) 6%, transparent); }
.nav-link.active { color: var(--text); font-weight: 600; }
@media (max-width: 768px) { .nav-links { display: none; } }

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  min-height: 44px; padding: 0 18px; border-radius: 11px;
  font-family: var(--font-ui); font-variation-settings: "wdth" 100;
  font-weight: 600; font-size: 14px; letter-spacing: -.01em;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  border: 1px solid transparent; white-space: nowrap; user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.btn:active { transform: scale(.97); }
.btn-primary {
  background: var(--primary); color: var(--on-primary);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset,
              0 6px 20px -8px color-mix(in oklab, var(--primary) 65%, transparent);
}
.btn-primary:hover { background: var(--primary-h); box-shadow: none; }
.btn-ghost { background: transparent; color: var(--text); border-color: var(--border-2); }
.btn-ghost:hover { background: color-mix(in oklab, var(--text) 5%, transparent); }
.btn-soft  { background: color-mix(in oklab, var(--primary) 11%, transparent); color: var(--primary); border-color: color-mix(in oklab, var(--primary) 18%, transparent); }
.btn-soft:hover  { background: color-mix(in oklab, var(--primary) 18%, transparent); }
.btn-danger { background: var(--red-bg); color: var(--red); border-color: color-mix(in oklab, var(--red) 22%, transparent); }
.btn-danger:hover { background: color-mix(in oklab, var(--red) 18%, transparent); }
.btn-sm { min-height: 34px; padding: 0 12px; font-size: 12.5px; border-radius: 9px; gap: 5px; }
.btn-lg { min-height: 50px; padding: 0 22px; font-size: 15px; border-radius: 13px; }
.btn-xs { min-height: 28px; padding: 0 9px; font-size: 11.5px; border-radius: 7px; gap: 4px; }
.btn-icon { width: 36px; min-height: 36px; padding: 0; border-radius: 9px; }
.btn-icon-sm { width: 28px; min-height: 28px; padding: 0; border-radius: 7px; }
.btn[disabled], .btn:disabled { opacity: .45; pointer-events: none; }

/* Theme toggle */
.theme-toggle {
  position: relative; width: 38px; height: 38px; border-radius: 10px;
  background: color-mix(in oklab, var(--text) 6%, transparent); color: var(--text);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease);
}
.theme-toggle:hover { background: color-mix(in oklab, var(--text) 10%, transparent); }
.theme-toggle .sun, .theme-toggle .moon { position: absolute; transition: transform var(--t) var(--ease), opacity var(--t) var(--ease); }
[data-theme="light"] .moon { opacity:0; transform: rotate(-90deg) scale(.4); }
[data-theme="light"] .sun  { opacity:1; transform: none; }
[data-theme="dark"]  .moon { opacity:1; transform: none; }
[data-theme="dark"]  .sun  { opacity:0; transform: rotate(90deg) scale(.4); }

/* ── Cards / Surfaces ────────────────────────────────────────────────── */
.card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
}
.card-hover:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--border-2); }
.card-pad { padding: 20px; }
.card-pad-lg { padding: 28px; }

/* ── Forms ───────────────────────────────────────────────────────────── */
.label { display: block; font-size: 12px; font-weight: 600; color: var(--text-3); margin: 0 0 5px; letter-spacing: .03em; text-transform: uppercase; }
.input, .select {
  width: 100%; height: 44px; padding: 0 13px;
  background: var(--input-bg); color: var(--text);
  border: 1.5px solid var(--border); border-radius: 10px; outline: none;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.input:focus, .select:focus {
  border-color: color-mix(in oklab, var(--primary) 55%, var(--border));
  box-shadow: 0 0 0 3.5px color-mix(in oklab, var(--primary) 15%, transparent);
}
.input::placeholder { color: var(--muted); }
.textarea {
  width: 100%; height: auto; padding: 11px 13px; min-height: 88px; resize: vertical;
  background: var(--input-bg); color: var(--text);
  border: 1.5px solid var(--border); border-radius: 10px; outline: none;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.textarea:focus {
  border-color: color-mix(in oklab, var(--primary) 55%, var(--border));
  box-shadow: 0 0 0 3.5px color-mix(in oklab, var(--primary) 15%, transparent);
}
.textarea::placeholder { color: var(--muted); }

/* ── Pill badges ─────────────────────────────────────────────────────── */
.pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; font-size: 11.5px; font-weight: 600; border-radius: 999px;
  background: color-mix(in oklab, var(--text) 6%, transparent); color: var(--text-2);
  border: 1px solid transparent; white-space: nowrap;
}
.pill.green  { color: var(--grn-dk); background: var(--grn-bg); border-color: color-mix(in oklab, var(--grn) 22%, transparent); }
.pill.red    { color: var(--red-dk); background: var(--red-bg); border-color: color-mix(in oklab, var(--red) 22%, transparent); }
.pill.yellow { color: var(--yel-dk); background: var(--yel-bg); border-color: color-mix(in oklab, var(--yel) 22%, transparent); }
.pill.navy   { color: var(--primary); background: color-mix(in oklab, var(--primary) 12%, transparent); border-color: color-mix(in oklab, var(--primary) 22%, transparent); }
.pill.purple { color: var(--pur-dk);  background: rgba(168,85,247,.12); border-color: rgba(168,85,247,.22); }
.dot { width: 7px; height: 7px; border-radius: 999px; background: currentColor; display: inline-block; flex-shrink: 0; }

/* ── Strength meter ──────────────────────────────────────────────────── */
.meter { height: 5px; border-radius: 999px; background: color-mix(in oklab, var(--text) 8%, transparent); overflow: hidden; }
.meter > span { display: block; height: 100%; border-radius: 999px; transition: width var(--t) var(--ease), background var(--t) var(--ease); }

/* ── Icon buttons ────────────────────────────────────────────────────── */
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 8px; color: var(--text-3);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.icon-btn:hover { background: color-mix(in oklab, var(--text) 8%, transparent); color: var(--text); }

/* ── Toast ───────────────────────────────────────────────────────────── */
.toast-wrap { position: fixed; bottom: calc(24px + var(--safe-bottom)); right: 16px; z-index: 80; display: grid; gap: 8px; pointer-events: none; }
.toast {
  pointer-events: auto; display: flex; align-items: center; gap: 10px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
  padding: 11px 14px; box-shadow: var(--shadow-lg); font-size: 13.5px;
  animation: slide-in .22s var(--spring);
}
@keyframes slide-in { from { transform: translateX(12px) scale(.95); opacity: 0; } }
.toast .t-ico { width: 20px; height: 20px; border-radius: 999px; display: grid; place-items: center; flex-shrink: 0; font-size: 11px; }
.toast.ok   .t-ico { background: var(--grn-bg); color: var(--grn-dk); }
.toast.warn .t-ico { background: var(--yel-bg); color: var(--yel-dk); }
.toast.err  .t-ico { background: var(--red-bg); color: var(--red-dk); }

/* ── Modal ───────────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed; inset: 0; background: var(--overlay);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  display: none; align-items: flex-end; justify-content: center; z-index: 60;
  padding: 0 0 var(--safe-bottom);
}
@media (min-width: 640px) { .modal-backdrop { align-items: center; padding: 24px; } }
.modal-backdrop.open { display: flex; animation: fade-bg .2s var(--ease); }
@keyframes fade-bg { from { opacity: 0; } }
.modal {
  width: 100%; max-width: 540px; background: var(--surface); border-radius: var(--r-xl) var(--r-xl) 0 0;
  border: 1px solid var(--border); box-shadow: var(--shadow-xl);
  animation: sheet-up .28s var(--spring);
  overflow: hidden;
}
@media (min-width: 640px) { .modal { border-radius: var(--r-xl); animation: pop-in .22s var(--spring); } }
@keyframes sheet-up { from { transform: translateY(100%); } }
@keyframes pop-in   { from { transform: scale(.93) translateY(12px); opacity: 0; } }
.modal .mh { padding: 16px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.modal .mh h3 { font-size: 16px; font-weight: 650; letter-spacing: -.01em; margin: 0; }
.modal .mb { padding: 18px; display: grid; gap: 12px; max-height: 70dvh; overflow-y: auto; }
.modal .mf { padding: 14px 18px; border-top: 1px solid var(--border); display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; }

/* ── Landing: hero ───────────────────────────────────────────────────── */
.hero {
  position: relative; overflow: hidden;
  padding: clamp(48px,7vw,100px) 0 0;
}
.hero::before {
  content:""; position:absolute; inset:0;
  background:
    var(--glow),
    linear-gradient(180deg, transparent 40%, color-mix(in oklab, var(--primary) 6%, transparent) 100%);
  pointer-events:none;
}
/* grid removed — conflicted with dot canvas */
.hero-inner { position:relative; z-index:1; display:grid; gap:24px; }
.hero-meta { display:flex; flex-wrap:wrap; gap:16px; font-size:13px; color:var(--text-2); }
.hero-meta .chk { color:var(--grn-dk); font-weight:600; }
.beam { position:absolute; border-radius:100%; filter:blur(80px); pointer-events:none; will-change:transform; }
.beam-a { width:600px; height:600px; top:-140px; left:-140px; background:color-mix(in oklab, var(--primary) 28%, transparent); }
.beam-b { width:520px; height:520px; bottom:-180px; right:-80px; background:color-mix(in oklab, var(--pur) 22%, transparent); }

/* hero mock window */
.hero-card {
  position:relative; border-radius:var(--r-xl); background:var(--card-glass);
  border:1px solid var(--border-2); box-shadow:var(--shadow-xl); overflow:hidden;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
}
.hc-topbar { display:flex; gap:7px; align-items:center; padding:10px 14px; border-bottom:1px solid var(--border); background:color-mix(in oklab,var(--surface-2) 70%,transparent); }
.tl { width:10px; height:10px; border-radius:999px; }
.tl:nth-child(1){ background:var(--red); } .tl:nth-child(2){ background:var(--yel); } .tl:nth-child(3){ background:var(--grn); }
.addr { flex:1; height:24px; border-radius:6px; background:var(--surface); border:1px solid var(--border); margin-left:6px; display:flex; align-items:center; gap:6px; padding:0 8px; color:var(--text-3); font-size:11px; }
.hc-body { display:grid; grid-template-columns:170px 1fr; min-height:300px; }
.hc-side { border-right:1px solid var(--border); padding:12px 8px; display:flex; flex-direction:column; gap:3px; background:color-mix(in oklab,var(--surface-2) 50%,transparent); }
.hc-side .item { padding:7px 10px; font-size:12.5px; border-radius:8px; color:var(--text-2); display:flex; align-items:center; gap:7px; }
.hc-side .item.active { background:color-mix(in oklab,var(--primary) 12%,transparent); color:var(--primary); font-weight:600; }
.hc-main { padding:14px; display:grid; gap:7px; align-content:start; }
.hc-row { display:grid; grid-template-columns:28px 1fr auto; gap:10px; align-items:center; padding:9px; border:1px solid var(--border); border-radius:10px; background:var(--surface); animation:row-in .5s var(--ease) both; }
.hc-row:nth-child(1){animation-delay:.15s} .hc-row:nth-child(2){animation-delay:.28s} .hc-row:nth-child(3){animation-delay:.41s} .hc-row:nth-child(4){animation-delay:.54s}
@keyframes row-in { from { opacity:0; transform:translateY(7px); } }
.hc-row .favi { width:26px; height:26px; border-radius:7px; display:grid; place-items:center; font-weight:700; font-size:11px; color:#fff; }
.hc-row .tt   { font-weight:600; font-size:12.5px; }
.hc-row .sub  { color:var(--text-3); font-size:11px; }
.hc-row .mask { color:var(--muted); font-family:var(--mono); font-size:11px; letter-spacing:.08em; }
/* floating chips */
.chip { position:absolute; display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:var(--card-glass); border:1px solid var(--border-2); box-shadow:var(--shadow); font-size:12px; font-weight:600; white-space:nowrap; backdrop-filter:blur(12px); animation:float 6s var(--ease) infinite alternate; }
.chip .chip-ico { width:22px; height:22px; border-radius:6px; display:grid; place-items:center; color:#fff; font-size:10px; font-weight:700; }
.chip-a{top:10%;left:3%;animation-delay:-1s} .chip-b{top:18%;right:0%;animation-delay:-3s}
.chip-c{bottom:24%;left:0%;animation-delay:-2s} .chip-d{bottom:14%;right:6%;animation-delay:-4s}
@keyframes float { 0%{transform:translateY(0)} 100%{transform:translateY(-12px)} }
/* rings */
.ring { position:absolute; border:1px dashed color-mix(in oklab,var(--primary) 35%,transparent); border-radius:50%; opacity:.5; }
.ring-1 { width:65%; aspect-ratio:1; animation:spin 40s linear infinite; }
.ring-2 { width:85%; aspect-ratio:1; animation:spin 65s linear infinite reverse; opacity:.3; }
@keyframes spin { to { transform:rotate(360deg); } }
.hero-stage { position:absolute; inset:0; display:grid; place-items:center; transform-style:preserve-3d; animation:tilt 16s var(--ease) infinite alternate; }
@keyframes tilt { 0%{transform:rotateX(11deg) rotateY(-7deg)} 100%{transform:rotateX(9deg) rotateY(7deg)} }

/* ── Features grid ───────────────────────────────────────────────────── */
.features { display:grid; grid-template-columns:repeat(12,1fr); gap:16px; }
.feature { grid-column:span 4; padding:20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-xs); transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease); }
.feature:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.feature .ico { width:36px; height:36px; border-radius:9px; display:grid; place-items:center; background:color-mix(in oklab,var(--primary) 13%,transparent); color:var(--primary); margin-bottom:11px; }
.feature h3 { font-size:15px; font-weight:650; letter-spacing:-.01em; margin:0 0 5px; }
.feature p  { font-size:13.5px; color:var(--text-2); margin:0; line-height:1.55; }
@media(max-width:900px){ .feature{grid-column:span 6} }
@media(max-width:600px){ .feature{grid-column:span 12} }

/* ── Showcase ────────────────────────────────────────────────────────── */
.showcase { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.showcase.reverse { direction:rtl; } .showcase.reverse > * { direction:ltr; }
.showcase .copy h2 { margin-bottom:10px; }
.showcase .shot { border-radius:12px; background:var(--surface-2); border:1px solid var(--border); box-shadow:var(--shadow-lg); padding:18px; min-height:320px; position:relative; overflow:hidden; }
@media(max-width:900px){ .showcase { grid-template-columns:1fr; } .showcase.reverse { direction:ltr; } }

/* ── Autofill browser wrapper ────────────────────────────────────────── */
.mock-browser { border-radius:14px; overflow:hidden; border:1px solid var(--border); background:var(--surface-3); }
.mock-browser-bar { display:flex; align-items:center; gap:6px; padding:8px 12px; border-bottom:1px solid var(--border); background:var(--surface-2); }
.mock-browser-bar .mbtn { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.mock-browser-bar .mbtn:nth-child(1){background:var(--red)} .mock-browser-bar .mbtn:nth-child(2){background:var(--yel)} .mock-browser-bar .mbtn:nth-child(3){background:var(--grn)}
.mock-browser-bar .murl { flex:1; height:20px; border-radius:5px; background:var(--surface); border:1px solid var(--border); display:flex; align-items:center; gap:5px; padding:0 8px; color:var(--text-3); font-size:10.5px; margin:0 4px; overflow:hidden; white-space:nowrap; }
.mock-browser-bar .mpwdn { display:flex; align-items:center; gap:4px; font-size:10px; font-weight:700; color:var(--primary); white-space:nowrap; margin-left:auto; }
.mock-browser .autofill-mock { border:none; border-radius:0; padding:14px; }

/* ── Autofill demo (landing) ─────────────────────────────────────────── */
.autofill-mock { display:grid; gap:10px; padding:18px; background:var(--surface-3); border:1px solid var(--border); border-radius:14px; }
.autofill-mock .field { position:relative; background:var(--surface); border:1px solid var(--border); border-radius:9px; padding:11px 13px; display:flex; align-items:center; gap:8px; }
.autofill-mock .field .flabel { font-size:10px; color:var(--muted); position:absolute; top:-7px; left:9px; background:var(--surface-3); padding:0 5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; }
.autofill-mock .field .val { flex:1; font-family:var(--mono); font-size:13px; color:var(--text-2); }
.autofill-mock .field .caret { width:2px; height:16px; background:var(--primary); animation:blink 1s steps(2) infinite; }
@keyframes blink { to { opacity:0; } }
.autofill-suggest { position:absolute; right:8px; top:50%; transform:translateY(-50%) scale(.95); background:var(--primary); color:var(--on-primary); padding:5px 9px; border-radius:7px; font-size:11.5px; font-weight:700; box-shadow:0 4px 16px -4px color-mix(in oklab,var(--primary) 65%,transparent); animation:suggest 4.5s var(--ease) infinite; }
@keyframes suggest { 0%,18%{opacity:0;transform:translateY(-50%) scale(.9) translateX(4px)} 28%,70%{opacity:1;transform:translateY(-50%) scale(1)} 85%,100%{opacity:0;transform:translateY(-50%) scale(.9) translateX(4px)} }

/* ── Marquee ─────────────────────────────────────────────────────────── */
.marquee { display:flex; gap:24px; overflow:hidden; mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent); }
.marquee .track { display:flex; gap:24px; align-items:center; animation:marq 28s linear infinite; white-space:nowrap; flex-shrink:0; }
.marquee .track span { font-size:18px; font-weight:700; letter-spacing:-.02em; color:var(--muted); }
@keyframes marq { to { transform:translateX(-50%); } }

/* ── Capture popup (landing) ─────────────────────────────────────────── */
.capture-popup { background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow-lg); overflow:hidden; max-width:300px; }
.capture-popup .cp-head { background:var(--primary); color:var(--on-primary); padding:11px 14px; display:flex; align-items:center; gap:8px; font-weight:700; font-size:14px; }
.capture-popup .cp-body { padding:12px 14px; display:grid; gap:7px; font-size:13px; }
.capture-popup .kv { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.capture-popup .k { color:var(--text-3); }

/* ── Download browser mock ───────────────────────────────────────────── */
.dl-browser { border-radius:8px; background:var(--surface); border:1px solid var(--border-2); box-shadow:var(--shadow-lg); overflow:hidden; }
.dl-browser .bar { display:flex; gap:6px; align-items:center; padding:10px 14px; border-bottom:1px solid var(--border); background:var(--surface-2); }
.dl-browser .bar .d { width:11px; height:11px; border-radius:999px; }
.dl-browser .bar .d:nth-child(1){background:var(--red)} .dl-browser .bar .d:nth-child(2){background:var(--yel)} .dl-browser .bar .d:nth-child(3){background:var(--grn)}
.dl-browser .bar .url-bar { flex:1; height:26px; margin:0 10px; background:var(--surface); border:1px solid var(--border); border-radius:5px; display:flex; align-items:center; gap:5px; padding:0 9px; font-size:12px; color:var(--text-3); overflow:hidden; }
.dl-browser .bar .url-bar svg { flex-shrink:0; opacity:.5; }
.dl-browser .content { padding:20px; display:grid; gap:10px; }
.autofill-mock .field { border-radius:5px !important; }

/* ── APP SHELL ───────────────────────────────────────────────────────── */
.app-shell {
  display:grid; min-height:100dvh;
}
@media(min-width:769px) {
  .app-shell { grid-template-columns:256px 1fr; }
}
@media(max-width:768px) {
  .app-shell { grid-template-rows:1fr auto; }
}

/* ── Sidebar (desktop) ───────────────────────────────────────────────── */
.sidebar {
  background:var(--sidebar-bg);
  border-right:1px solid var(--sidebar-border);
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100dvh;
  overflow-y:auto; overflow-x:hidden;
}
.sidebar .sb-brand { padding:18px 14px 10px; }
.sidebar .sb-nav { flex:1; padding:4px 8px; display:flex; flex-direction:column; gap:1px; overflow-y:auto; }
.sidebar .sb-section { padding:10px 8px 4px; font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); }
.sb-item {
  display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:10px;
  font-size:13.5px; font-weight:500; color:var(--text-2); cursor:pointer;
  transition:background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.sb-item:hover { background:color-mix(in oklab,var(--text) 5%,transparent); color:var(--text); }
.sb-item.active { background:color-mix(in oklab,var(--primary) 12%,transparent); color:var(--primary); font-weight:650; }
.sb-item .sb-icon { width:20px; flex-shrink:0; display:grid; place-items:center; }
.sb-item .badge { margin-left:auto; font-size:11px; padding:2px 7px; border-radius:999px; background:var(--bg-3); color:var(--text-3); font-weight:600; }
.sb-item.active .badge { background:color-mix(in oklab,var(--primary) 18%,transparent); color:var(--primary); }
.sb-item.alert .badge { background:var(--red-bg); color:var(--red-dk); }
.sb-foot { padding:10px; border-top:1px solid var(--border); }

/* ── Client pill in sidebar ──────────────────────────────────────────── */
.client-pill {
  display:flex; align-items:center; gap:9px; padding:7px 10px; border-radius:10px;
  font-size:13px; font-weight:500; cursor:pointer;
  transition:background var(--t-fast) var(--ease);
}
.client-pill:hover { background:color-mix(in oklab,var(--text) 5%,transparent); }
.client-pill.active { background:color-mix(in oklab,var(--primary) 10%,transparent); }
.client-avatar {
  width:26px; height:26px; border-radius:7px; flex-shrink:0;
  display:grid; place-items:center; font-size:11px; font-weight:700; color:#fff;
}

/* ── Bottom tab bar (mobile) ─────────────────────────────────────────── */
@media(max-width:768px) {
  .sidebar { display:none; }
  .app-sidebar { display:none; }
  .bottom-nav {
    position:fixed; bottom:0; left:0; right:0; z-index:30;
    height:calc(var(--tab-h) + var(--safe-bottom));
    padding-bottom:var(--safe-bottom);
    background:color-mix(in oklab,var(--sidebar-bg) 90%,transparent);
    backdrop-filter:saturate(1.8) blur(20px);
    -webkit-backdrop-filter:saturate(1.8) blur(20px);
    border-top:1px solid var(--border);
    display:flex; align-items:center;
  }
  .bottom-nav-inner { display:flex; width:100%; }
  .tab-btn {
    flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:3px; padding:8px 4px; font-size:10px; font-weight:600; color:var(--text-3);
    border-radius:0; min-height:var(--tab-h); cursor:pointer;
    transition:color var(--t-fast) var(--ease);
  }
  .tab-btn.active { color:var(--primary); }
  .tab-btn.active .tab-icon { background:color-mix(in oklab,var(--primary) 14%,transparent); border-radius:10px; }
  .tab-icon { width:28px; height:28px; display:grid; place-items:center; transition:background var(--t-fast) var(--ease); }
  .main-content { padding-bottom:calc(var(--tab-h) + var(--safe-bottom) + 12px); }
}
@media(min-width:769px) {
  .bottom-nav { display:none; }
}

/* ── Main content area ───────────────────────────────────────────────── */
.main-content {
  padding:20px 20px 24px;
  display:grid; gap:20px; align-content:start; min-height:100dvh;
}
@media(min-width:1200px) { .main-content { padding:24px 32px 32px; } }

/* ── Topbar ──────────────────────────────────────────────────────────── */
.topbar { display:flex; gap:10px; align-items:center; }
.topbar h1, .topbar-title { font-family:var(--font-heading); font-size:22px; font-weight:700; letter-spacing:-.02em; margin:0; white-space:nowrap; font-optical-sizing:auto; }
.search-wrap { position:relative; flex:1; max-width:400px; }
.search-wrap .ico { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--text-3); }
.search-wrap .input { padding-left:36px; height:40px; }

/* ── KPI row ─────────────────────────────────────────────────────────── */
.kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
@media(max-width:900px){ .kpis{grid-template-columns:repeat(2,1fr)} }
@media(max-width:480px){ .kpis{grid-template-columns:repeat(2,1fr)} }
.kpi { padding:14px; border-radius:13px; background:var(--surface); border:1px solid var(--border); }
.kpi .k-ico { width:32px; height:32px; border-radius:8px; display:grid; place-items:center; margin-bottom:8px; }
.kpi .k-num { font-family:var(--font-heading); font-size:28px; font-weight:700; letter-spacing:-.03em; font-optical-sizing:auto; }
.kpi .k-lbl { font-size:11.5px; color:var(--text-3); margin-top:2px; font-family:var(--font-ui); }

/* ── Panel ───────────────────────────────────────────────────────────── */
.panel { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.panel .ph { padding:13px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.panel .ph h3 { font-family:var(--font-heading); font-size:16px; font-weight:700; letter-spacing:-.015em; margin:0; font-optical-sizing:auto; }
.panel .body { padding:8px; }

/* ── Vault list rows ─────────────────────────────────────────────────── */
.vault-list { display:flex; flex-direction:column; }
.vault-row {
  display:grid; align-items:center; padding:10px; border-radius:10px; cursor:pointer;
  transition:background var(--t-fast) var(--ease);
  grid-template-columns:34px 1fr 1fr 130px auto;
  gap:12px;
}
.vault-row:hover { background:color-mix(in oklab,var(--text) 4%,transparent); }
.vault-row .favi { width:32px; height:32px; border-radius:9px; display:grid; place-items:center; font-weight:700; font-size:12px; color:#fff; flex-shrink:0; }
.vault-row .vr-t  { font-weight:600; font-size:13.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.vault-row .vr-u  { font-size:12px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.vault-row .vr-pw { font-family:var(--mono); font-size:12px; color:var(--muted); letter-spacing:.1em; }
.vault-row .vr-actions { display:flex; gap:3px; opacity:0; transition:opacity var(--t-fast) var(--ease); }
.vault-row:hover .vr-actions { opacity:1; }
@media(max-width:768px) {
  .vault-row { grid-template-columns:34px 1fr auto; gap:10px; }
  .vault-row .vr-u { display:none; }
  .vault-row .vr-pw { display:none; }
  .vault-row .vr-actions { opacity:1; }
}

/* ── Client cards grid ───────────────────────────────────────────────── */
.clients-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px; }
.client-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:16px; cursor:pointer; box-shadow:var(--shadow-xs);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease);
}
.client-card:hover { transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--border-2); }
.client-card .cc-header { display:flex; align-items:center; gap:11px; margin-bottom:12px; }
.client-card .cc-avatar { width:40px; height:40px; border-radius:10px; display:grid; place-items:center; font-weight:700; font-size:15px; color:#fff; flex-shrink:0; }
.client-card .cc-name { font-family:var(--font-heading); font-weight:700; font-size:15px; letter-spacing:-.012em; font-optical-sizing:auto; }
.client-card .cc-url  { font-size:12px; color:var(--text-3); margin-top:1px; }
.client-card .cc-stats { display:flex; gap:10px; flex-wrap:wrap; }
.client-card .cc-stat { font-size:12px; color:var(--text-2); background:var(--bg-2); padding:3px 9px; border-radius:6px; }
.client-card .cc-foot { margin-top:12px; padding-top:11px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.client-card .cc-status { font-size:11.5px; }

/* add-client card */
.client-card.add { border:2px dashed var(--border-2); background:transparent; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; min-height:140px; color:var(--text-3); }
.client-card.add:hover { background:color-mix(in oklab,var(--primary) 5%,transparent); border-color:var(--primary-l); color:var(--primary); }

/* ── Payment cards ───────────────────────────────────────────────────── */
.cards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:24px; padding:4px 0 20px; }

.paycard {
  position:relative; aspect-ratio:1.586/1; border-radius:20px;
  padding:24px 26px; color:#fff; overflow:hidden; isolation:isolate;
  transition:transform 400ms cubic-bezier(.22,.68,.2,1.2), box-shadow 400ms ease;
  cursor:pointer; user-select:none; perspective:1000px;
}
.paycard:hover { transform:translateY(-8px) scale(1.02) rotateX(2deg); }

/* card gradients per network */
.paycard.visa {
  background: linear-gradient(145deg, #0A1172 0%, #1a237e 20%, #1565c0 55%, #0277bd 80%, #01579b 100%);
  box-shadow: 0 20px 60px -10px rgba(10,17,114,.7), 0 4px 8px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.15);
}
.paycard.mc {
  background: linear-gradient(145deg, #1a0000 0%, #7f0000 25%, #c62828 55%, #e65100 80%, #bf360c 100%);
  box-shadow: 0 20px 60px -10px rgba(127,0,0,.7), 0 4px 8px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.15);
}
.paycard.amex {
  background: linear-gradient(145deg, #003300 0%, #1b5e20 25%, #2e7d32 55%, #00695c 80%, #004d40 100%);
  box-shadow: 0 20px 60px -10px rgba(27,94,32,.7), 0 4px 8px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.15);
}
.paycard.discover {
  background: linear-gradient(145deg, #1a0033 0%, #4a148c 25%, #6a1b9a 55%, #ad1457 80%, #880e4f 100%);
  box-shadow: 0 20px 60px -10px rgba(74,20,140,.7), 0 4px 8px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.15);
}
.paycard.default {
  background: linear-gradient(145deg, #0a0a1a 0%, #111128 25%, #1c1c3e 55%, #252550 80%, #2d2d6e 100%);
  box-shadow: 0 20px 60px -10px rgba(0,0,0,.6), 0 4px 8px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.15);
}

/* multi-layer gloss: top highlight + bottom soft glow + edge vignette */
.paycard::before {
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background:
    radial-gradient(ellipse 120% 50% at 20% -20%, rgba(255,255,255,.28), transparent 55%),
    radial-gradient(ellipse 60% 40% at 80% 110%, rgba(255,255,255,.06), transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, transparent 30%);
}

/* animated holographic shimmer */
.paycard::after {
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background: linear-gradient(
    105deg,
    transparent 30%, rgba(255,230,100,.15) 35%,
    rgba(255,255,255,.22) 40%, rgba(255,230,100,.15) 45%,
    transparent 55%
  );
  background-size: 250% 100%;
  animation: card-shimmer 4s ease-in-out infinite;
}
@keyframes card-shimmer {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}

/* EMV chip */
.paycard .pc-chip {
  position:absolute; top:24px; right:26px;
  width:44px; height:34px; border-radius:8px;
  background: linear-gradient(145deg, #d4af37, #ffd700, #b8860b, #ffd700, #d4af37);
  box-shadow: 0 2px 6px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.4);
  display:grid; place-items:center; overflow:hidden;
}
.paycard .pc-chip::before {
  content:""; position:absolute; top:0; left:0; right:0; height:50%;
  background: linear-gradient(180deg, rgba(255,255,255,.25), transparent);
}
.paycard .pc-chip::after {
  content:"";
  width:28px; height:20px; border-radius:4px;
  border: 1px solid rgba(0,0,0,.35);
  background: linear-gradient(135deg, #c8a500, #e8c600, #a07800);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.15);
}

/* contactless symbol */
.paycard .pc-contactless {
  position:absolute; top:66px; right:26px; opacity:.85;
  display:flex; flex-direction:column; gap:3px; align-items:center;
}
.pc-contactless span {
  display:block; border:2px solid rgba(255,255,255,.9); border-radius:50%;
  box-shadow: 0 0 4px rgba(255,255,255,.3);
}
.pc-contactless span:nth-child(1){ width:8px;  height:8px; }
.pc-contactless span:nth-child(2){ width:14px; height:14px; }
.pc-contactless span:nth-child(3){ width:20px; height:20px; }

/* card brand label */
.paycard .pc-brand {
  font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  opacity:.7; font-family: var(--font-ui);
}

/* card number */
.paycard .pc-number {
  font-family:var(--mono); font-size:20px; letter-spacing:.20em;
  margin-top:auto; display:flex; gap:18px; align-items:center;
  padding-top:32px; text-shadow:0 1px 3px rgba(0,0,0,.4);
}

/* cardholder / expiry row */
.paycard .pc-meta { display:flex; justify-content:space-between; align-items:flex-end; margin-top:12px; }
.pc-meta .pc-holder .l,
.pc-meta .pc-exp .l  { font-size:8px; opacity:.6; letter-spacing:.12em; text-transform:uppercase; font-family:var(--font-ui); }
.pc-meta .pc-holder .v { font-size:13px; font-weight:600; text-shadow:0 1px 2px rgba(0,0,0,.3); }
.pc-meta .pc-exp .v  { font-size:13px; font-weight:600; font-family:var(--mono); }
.pc-meta .pc-exp { text-align:center; }

/* network logo */
.paycard .pc-logo {
  position:absolute; bottom:22px; right:24px;
  font-family:var(--font-heading); font-weight:700; font-size:20px;
  letter-spacing:-.02em; opacity:.95; text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.paycard.mc .pc-logo { display:flex; }
.paycard.mc .mc-l { width:28px; height:28px; border-radius:50%; background:#eb001b; box-shadow:0 2px 6px rgba(0,0,0,.4); }
.paycard.mc .mc-r { width:28px; height:28px; border-radius:50%; background:#f79e1b; box-shadow:0 2px 6px rgba(0,0,0,.4); margin-left:-12px; }

/* last 4 shortcut badge */
.paycard .pc-balance {
  position:absolute; bottom:22px; left:26px;
  font-size:11px; opacity:.75; font-weight:600; font-family:var(--font-ui);
  letter-spacing:.04em;
}

/* ── Subscriptions ───────────────────────────────────────────────────── */
.sub-summary { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
@media(max-width:600px){ .sub-summary { grid-template-columns:1fr 1fr; } }
.sub-total-card { padding:18px; border-radius:14px; border:1px solid var(--border); }
.sub-total-card .t { font-size:12px; color:var(--text-3); letter-spacing:.06em; text-transform:uppercase; }
.sub-total-card .a { font-size:28px; font-weight:700; letter-spacing:-.03em; margin-top:2px; }
.sub-total-card .s { font-size:12px; color:var(--text-2); margin-top:2px; }

.sub-row {
  display:grid; grid-template-columns:32px 1fr auto; gap:12px; align-items:center;
  padding:11px 10px; border-radius:10px; cursor:pointer;
  transition:background var(--t-fast) var(--ease);
}
.sub-row:hover { background:color-mix(in oklab,var(--text) 4%,transparent); }
.sub-row .sr-ico { width:30px; height:30px; border-radius:8px; display:grid; place-items:center; font-size:12px; font-weight:700; color:#fff; }
.sub-row .sr-name { font-weight:600; font-size:13.5px; }
.sub-row .sr-next { font-size:12px; color:var(--text-3); }
.sub-row .sr-amt  { font-weight:700; font-size:15px; font-family:var(--mono); }
.sub-row .sr-amt.exp { color:var(--red-dk); }
.sub-row .sr-actions { display:flex; gap:4px; opacity:0; }
.sub-row:hover .sr-actions { opacity:1; }
@media(max-width:600px){ .sub-row .sr-actions { opacity:1; } }

/* category breakdown */
.cat-bar { height:8px; border-radius:999px; overflow:hidden; display:flex; gap:2px; background:var(--bg-3); }
.cat-bar span { height:100%; border-radius:999px; transition:flex var(--t-slow) var(--ease); }

/* ── Security dashboard ──────────────────────────────────────────────── */
.sec-alert {
  display:grid; gap:10px; padding:14px; border-radius:12px;
  border:1px solid var(--border); background:var(--surface);
}
.sec-alert.danger { border-color:color-mix(in oklab,var(--red) 25%,transparent); background:var(--red-bg); }
.sec-alert.warn   { border-color:color-mix(in oklab,var(--yel) 25%,transparent); background:var(--yel-bg); }
.sec-alert.ok     { border-color:color-mix(in oklab,var(--grn) 25%,transparent); background:var(--grn-bg); }

/* ── Generator ───────────────────────────────────────────────────────── */
.gen-out {
  font-family:var(--mono); font-size:clamp(14px,2.5vw,20px); word-break:break-all;
  padding:18px; background:var(--surface-3); border:1px solid var(--border); border-radius:12px;
  text-align:center; min-height:64px; display:flex; align-items:center; justify-content:center;
  letter-spacing:.04em; color:var(--text);
}

/* ── Service catalog ─────────────────────────────────────────────────── */
.catalog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:8px; padding:10px; }
.catalog-item {
  padding:14px 10px 12px; border-radius:12px; cursor:pointer; text-align:center;
  border:1px solid var(--border); transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),transform var(--t-fast) var(--spring);
}
.catalog-item:hover { transform:translateY(-2px); border-color:var(--border-2); background:color-mix(in oklab,var(--primary) 5%,transparent); }
.catalog-item .ci-ico { width:52px; height:52px; border-radius:14px; display:grid; place-items:center; font-size:18px; font-weight:700; color:#fff; margin:0 auto 9px; }
.catalog-item .ci-name { font-size:12px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.catalog-item .ci-cat  { font-size:10.5px; color:var(--text-3); margin-top:2px; }

/* ── Pricing page ────────────────────────────────────────────────────── */
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.plan-card {
  position:relative; padding:28px; border-radius:var(--r-xl);
  background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; gap:0;
}
.plan-card.featured {
  background:var(--primary); color:var(--on-primary);
  border-color:transparent;
  box-shadow:0 12px 40px -10px color-mix(in oklab,var(--primary) 60%,transparent),var(--shadow);
  transform:scale(1.03);
}
@media(max-width:768px){ .plan-card.featured{transform:none} }
.plan-card .pn   { font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; opacity:.7; margin-bottom:8px; }
.plan-card .pr   { font-size:42px; font-weight:700; letter-spacing:-.04em; margin-bottom:2px; }
.plan-card .pr sub { font-size:16px; font-weight:500; vertical-align:baseline; opacity:.7; }
.plan-card .ps   { font-size:13px; opacity:.65; margin-bottom:18px; }
.plan-card .pd   { font-size:14px; opacity:.85; line-height:1.6; margin-bottom:20px; flex:1; }
.plan-card .pf   { margin-top:auto; }
.plan-card .plan-features { list-style:none; padding:0; margin:0 0 20px; display:grid; gap:9px; }
.plan-card .plan-features li { display:flex; align-items:baseline; gap:8px; font-size:13.5px; }
.plan-card .plan-features .check { color:var(--grn-dk); font-size:12px; flex-shrink:0; }
.plan-card.featured .plan-features .check { color:#a7f3d0; }
.plan-card .badge-popular { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:#F59E0B; color:#fff; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:4px 12px; border-radius:999px; }

/* ── Docs page ───────────────────────────────────────────────────────── */
.docs-layout { display:grid; grid-template-columns:240px 1fr; gap:40px; align-items:start; }
@media(max-width:900px){ .docs-layout { grid-template-columns:1fr; } }
.docs-nav { position:sticky; top:80px; display:flex; flex-direction:column; gap:2px; }
.docs-nav a { padding:7px 12px; border-radius:8px; font-size:13.5px; color:var(--text-2); transition:color var(--t-fast) var(--ease),background var(--t-fast) var(--ease); }
.docs-nav a:hover { color:var(--text); background:color-mix(in oklab,var(--text) 5%,transparent); }
.docs-nav a.active { color:var(--primary); background:color-mix(in oklab,var(--primary) 10%,transparent); font-weight:600; }
.docs-nav .dn-section { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); padding:10px 12px 4px; }
.docs-content { display:grid; gap:36px; }
.docs-content h2 { font-size:24px; font-weight:700; letter-spacing:-.02em; margin:0 0 10px; border-bottom:1px solid var(--border); padding-bottom:10px; }
.docs-content h3 { font-size:18px; font-weight:650; margin:24px 0 8px; letter-spacing:-.015em; }
.docs-content p  { font-size:14.5px; line-height:1.7; color:var(--text-2); margin:0 0 12px; }
.docs-content ul { padding:0 0 0 20px; margin:0 0 12px; }
.docs-content li { font-size:14.5px; line-height:1.7; color:var(--text-2); margin-bottom:5px; list-style:disc; }
.code-block { background:var(--bg-2); border:1px solid var(--border); border-radius:10px; padding:16px 18px; overflow-x:auto; }
.code-block pre { margin:0; font-family:var(--mono); font-size:13px; color:var(--text); white-space:pre; }
.code-block .kw { color:var(--primary-l); } .code-block .str { color:var(--grn-dk); } .code-block .cm { color:var(--muted); } .code-block .num { color:var(--yel-dk); }
.api-endpoint { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:10px; background:var(--surface-2); border:1px solid var(--border); margin-bottom:6px; }
.api-method { font-size:11px; font-weight:700; letter-spacing:.08em; padding:3px 8px; border-radius:5px; }
.api-method.get  { background:var(--grn-bg);  color:var(--grn-dk); }
.api-method.post { background:var(--yel-bg);  color:var(--yel-dk); }
.api-method.del  { background:var(--red-bg);  color:var(--red-dk); }
.api-endpoint .path { font-family:var(--mono); font-size:13px; color:var(--text); }
.api-endpoint .ep-desc { font-size:12.5px; color:var(--text-3); margin-left:auto; }

/* ── Lock / auth screen ──────────────────────────────────────────────── */
.lock-screen {
  min-height:100dvh; display:grid; place-items:center; padding:20px;
  position:relative; overflow:hidden;
}
.lock-screen::before { content:""; position:absolute; inset:0; background:var(--glow); pointer-events:none; }
.lock-screen::after { content:""; position:absolute; inset:0; background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px); background-size:36px 36px; mask-image:radial-gradient(ellipse at center,black 10%,transparent 65%); -webkit-mask-image:radial-gradient(ellipse at center,black 10%,transparent 65%); pointer-events:none; }
.lock-card { width:min(420px,100%); position:relative; z-index:1; }

/* ── Footer ──────────────────────────────────────────────────────────── */
footer { border-top:1px solid var(--border); padding:40px 0; color:var(--text-2); font-size:13.5px; }
footer .container { display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.footer-links { display:flex; gap:20px; flex-wrap:wrap; }
.footer-links a { color:var(--text-2); transition:color var(--t-fast) var(--ease); }
.footer-links a:hover { color:var(--text); }

/* ── Reveal on scroll ────────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(14px); transition:opacity var(--t-slow) var(--ease),transform var(--t-slow) var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal.delay-1 { transition-delay:.08s; }
.reveal.delay-2 { transition-delay:.16s; }
.reveal.delay-3 { transition-delay:.24s; }

/* ── Utility ─────────────────────────────────────────────────────────── */
.mt-8{margin-top:8px} .mt-12{margin-top:12px} .mt-16{margin-top:16px} .mt-24{margin-top:24px} .mt-32{margin-top:32px}
.gap-6{gap:6px} .gap-8{gap:8px} .gap-12{gap:12px} .gap-16{gap:16px}
.w-full{width:100%} .text-center{text-align:center} .hidden{display:none!important}
.divider { height:1px; background:var(--border); margin:4px 0; }
.no-scroll { overflow:hidden; }
.text-green  { color:var(--grn-dk); } .text-red { color:var(--red-dk); } .text-yellow { color:var(--yel-dk); }
.surface-2 { background:var(--surface-2); }
.truncate { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.flex-1 { flex:1; min-width:0; }

/* ── Empty state ─────────────────────────────────────────────────────── */
.empty-state { padding:48px 24px; text-align:center; display:grid; gap:10px; justify-items:center; }
.empty-state .e-ico { width:52px; height:52px; border-radius:14px; display:grid; place-items:center; background:color-mix(in oklab,var(--primary) 10%,transparent); color:var(--primary); margin-bottom:4px; }
.empty-state h3 { font-family:var(--font-heading); font-size:17px; font-weight:700; margin:0; font-optical-sizing:auto; }
.empty-state p { font-size:13.5px; color:var(--text-2); max-width:38ch; margin:0; }

/* ── CTA row ─────────────────────────────────────────────────────────── */
.cta-row { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }

/* ── CTA section inner grid ──────────────────────────────────────────── */
.cta-inner-grid { grid-template-columns: 1.4fr 1fr; }
@media(max-width:768px) {
  .cta-inner-grid { grid-template-columns: 1fr; }
  .cta-inner-grid > div:last-child { justify-content: flex-start; }
}

/* ── Company logo images (Clearbit) ──────────────────────────────────── */
.logo-img {
  width:100%; height:100%; display:block;
  object-fit:contain; padding:3px;
  border-radius:inherit;
}
.ci-ico .logo-img { padding:6px; }
.cc-avatar .logo-img { padding:5px; }

/* ── Hero visual ─────────────────────────────────────────────────────── */
.hero-visual { position:relative; height:420px; margin-top:32px; }
@media(min-width:900px){ .hero-visual { margin-top:0; } }
.hero-meta .check { color:var(--grn-dk); font-weight:600; }

/* Extra chips */
.chip-e { top:55%;  left:1%;  animation-delay:-5s; }
.chip-f { top:68%;  right:2%; animation-delay:-2.5s; }
.ring-3 { width:105%; aspect-ratio:1; animation:spin 90s linear infinite; opacity:.18; }

/* Bottom brightness glow on hero rings */
.hero-visual::after {
  content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:85%; height:48%; pointer-events:none; z-index:0;
  background: radial-gradient(ellipse at 50% 100%,
    color-mix(in oklab,var(--primary) 24%,transparent) 0%,
    color-mix(in oklab,var(--grn) 12%,transparent) 38%,
    transparent 70%);
}

/* ── Download page hero ──────────────────────────────────────────────── */
.dl-hero { display:grid; gap:32px; grid-template-columns:1fr 1fr; align-items:center; }
@media(max-width:768px){ .dl-hero { grid-template-columns:1fr; } }

/* ── Save popup (landing + extension demo) ───────────────────────────── */
.dl-popup { background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow-lg); overflow:hidden; max-width:280px; }
.dl-popup .hp { background:linear-gradient(135deg,var(--navy-700),var(--navy-500)); color:#fff; padding:11px 14px; display:flex; align-items:center; gap:8px; font-weight:700; font-size:14px; }
.dl-popup .bd { padding:12px 14px; display:grid; gap:7px; font-size:13px; }
.dl-popup .kv { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.dl-popup .k  { color:var(--text-3); }

/* ── Footer links (alias) ────────────────────────────────────────────── */
footer .links { display:flex; gap:20px; flex-wrap:wrap; }
footer .links a { color:var(--text-2); transition:color var(--t-fast) var(--ease); }
footer .links a:hover { color:var(--text); }

/* ── Security animated section ───────────────────────────────────────── */
.sec-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; }
.sec-card {
  padding:28px; border-radius:20px; border:1px solid var(--border);
  background:var(--surface); transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.sec-card:hover { border-color:var(--border-2); box-shadow:var(--shadow); }
.sec-card h3 { margin-top:20px; }
.sec-card p  { margin-top:10px; color:var(--text-2); font-size:15px; line-height:1.65; }

.sec-graphic {
  aspect-ratio:4/3; border-radius:14px; background:var(--bg-2);
  border:1px solid var(--border); overflow:hidden; position:relative;
  display:flex; align-items:center; justify-content:center;
}

/* AES card: vertical layout — lock on top, cipher text below */
#sg-aes { flex-direction:column; justify-content:space-between; padding:20px 16px 16px; gap:0; }
.aes-center { flex:1; display:flex; align-items:center; justify-content:center; position:relative; width:100%; }

/* cipher stream */
.cipher-stream {
  display:flex; flex-direction:column; gap:5px; align-items:flex-start;
  font-family:var(--mono); font-size:11px;
  padding:0 4px; width:100%;
}
.cs-plain  { color:var(--text-2); font-size:10.5px; opacity:.8; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.cs-arrow  { color:var(--primary); font-size:10px; letter-spacing:.05em; font-weight:700; }
.cs-cipher { color:var(--grn); font-size:10.5px; letter-spacing:.04em; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }

.lock-ring { position:relative; width:80px; height:80px; flex-shrink:0; }
.lock-ring svg { width:100%; height:100%; }
.ring-spin     { animation: ring-cw  8s linear infinite; transform-origin:50% 50%; }
.ring-spin-rev { animation: ring-ccw 6s linear infinite; transform-origin:50% 50%; }
@keyframes ring-cw  { to { stroke-dashoffset:-200; } }
@keyframes ring-ccw { to { stroke-dashoffset: 200; } }

/* Pulse rings — emanate outward from lock center */
.pulse-ring {
  position:absolute; border-radius:50%; pointer-events:none;
  border:1px solid color-mix(in oklab,var(--primary) 50%,transparent);
  width:80px; height:80px;
  animation:pulse-out 2.4s ease-out infinite;
}
.pr-2 { animation-delay:.8s; }
.pr-3 { animation-delay:1.6s; }
@keyframes pulse-out {
  0%   { transform:scale(.85); opacity:.7; }
  100% { transform:scale(2.6); opacity:0; }
}

/* zero-knowledge vis — solid icon version */
.zk-vis { display:flex; align-items:center; justify-content:center; gap:8px; padding:0 14px; width:100%; box-sizing:border-box; }
.zk-device, .zk-server { display:flex; flex-direction:column; align-items:center; gap:6px; font-size:10px; color:var(--text-3); flex:0 0 auto; }
.zk-icon-wrap { position:relative; width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; }
.zk-has-key { background:linear-gradient(135deg,color-mix(in oklab,var(--primary) 20%,transparent),color-mix(in oklab,var(--grn) 12%,transparent)); color:var(--primary-l); }
.zk-no-key  { background:color-mix(in oklab,var(--text-3) 10%,transparent); color:var(--text-3); }
.zk-badge { position:absolute; bottom:-5px; right:-5px; width:18px; height:18px; border-radius:6px; display:flex; align-items:center; justify-content:center; border:2px solid var(--bg-2); }
.zk-badge-key  { background:var(--grn); color:#fff; }
.zk-badge-lock { background:color-mix(in oklab,var(--text-3) 70%,transparent); color:#fff; }
@keyframes key-pulse { 0%,100%{transform:scale(1);opacity:.9;} 50%{transform:scale(1.15);opacity:1;} }
.zk-icon-wrap.zk-has-key svg { animation:key-pulse 2s ease-in-out infinite; }
.zk-flow { flex:0 1 100px; min-width:60px; max-width:110px; display:flex; flex-direction:column; align-items:center; gap:4px; position:relative; min-height:32px; }
.zk-arrow { width:100%; height:12px; }
.zk-label { font-size:9px; color:var(--text-3); letter-spacing:.06em; text-transform:uppercase; margin-top:2px; }
.zk-data-packet {
  position:absolute; top:0; width:8px; height:8px; border-radius:50%;
  background:linear-gradient(135deg,#3B7DFF,#10B981);
  box-shadow:0 0 6px rgba(59,125,255,.7);
  animation:pkt-fly 1.8s ease-in-out infinite;
}
@keyframes pkt-fly {
  0%   { left:0%;   opacity:0; transform:scale(.6); }
  15%  { opacity:1; transform:scale(1); }
  85%  { opacity:1; transform:scale(1); }
  100% { left:calc(100% - 8px); opacity:0; transform:scale(.6); }
}

/* KDF vis */
.kdf-vis { display:flex; flex-direction:column; gap:12px; padding:16px 20px; width:100%; }
.kdf-input, .kdf-output { display:flex; flex-direction:column; gap:3px; }
.kdf-label { font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); font-family:var(--font-ui); }
.kdf-val   { font-family:var(--mono); font-size:13px; color:var(--text); }
.kdf-val.mono { color:var(--grn); font-size:11px; }
.kdf-rounds { display:flex; flex-direction:column; gap:5px; }
.kdf-bar-wrap { height:6px; border-radius:99px; background:var(--bg-3); overflow:hidden; }
.kdf-bar { height:100%; width:0%; border-radius:99px; background:var(--accent-gradient); transition:width .04s linear; }
.kdf-count { font-size:10px; color:var(--primary); font-family:var(--mono); font-weight:600; }

/* privacy section graphic */
.prv-graphic { border-radius:16px; overflow:hidden; border:1px solid var(--border); }
