:root {
  --bg: #050409;
  --bg2: #0a0813;
  --charcoal: #14121c;
  --panel: rgba(9, 7, 17, 0.62);
  --panel-2: rgba(30, 24, 48, 0.5);
  --panel-solid: #14101f;
  --border: rgba(160, 130, 255, 0.12);
  --border-bright: rgba(168, 110, 255, 0.42);
  --text: #f3f0ff;
  --muted: #9a93b6;
  --faint: #6f6890;
  --purple: #a855f7;
  --violet: #7c3aed;
  --magenta: #d946ef;
  --blue: #3b82f6;
  --blue-l: #60a5fa;
  --cyan: #22d3ee;
  --grad: linear-gradient(135deg, #6d4bff 0%, #a855f7 50%, #d946ef 100%);
  --grad-blue: linear-gradient(135deg, #3b82f6 0%, #7c3aed 55%, #d946ef 100%);
  --grad-soft: linear-gradient(135deg, rgba(124,58,237,0.16), rgba(217,70,239,0.10));
  --glass: rgba(255,255,255,0.04);
  --glass-line: rgba(255,255,255,0.08);
  --good: #34d399;
  --warn: #fbbf24;
  --bad: #fb5f7a;
  --shadow: 0 24px 60px -18px rgba(0,0,0,0.7);
  --glow-p: 0 0 40px rgba(168,85,247,0.35);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
::selection { background: rgba(168,85,247,0.35); color: #fff; }
html { scroll-behavior: smooth; }
body {
  font-family: "Inter", system-ui, sans-serif;
  background: #010103;
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.01em;
  overflow-x: hidden;
}
.hidden { display: none !important; }
.muted { color: var(--muted); font-size: 12px; font-weight: 500; }

/* custom scrollbar */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: linear-gradient(var(--violet), var(--magenta)); border-radius: 20px; border: 3px solid var(--bg); }

/* mouse-reactive ambient glow — faint & cool */
.cursor-glow { position: fixed; top: 0; left: 0; width: 460px; height: 460px; margin: -230px 0 0 -230px; z-index: 0;
  border-radius: 50%; pointer-events: none; mix-blend-mode: screen; opacity: 0.28; transition: opacity 0.4s;
  background: radial-gradient(circle, rgba(120,180,255,0.12), rgba(120,180,255,0.04) 42%, transparent 70%); will-change: transform; }
.bg-orbs { display: none; }

/* drifting glow orbs */
.bg-orbs { position: fixed; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.bg-orbs span { position: absolute; border-radius: 50%; filter: blur(120px); opacity: 0.4; will-change: transform; }
.bg-orbs span:nth-child(1) { width: 480px; height: 480px; background: #6d4bff; top: -150px; left: -110px; animation: drift1 22s ease-in-out infinite; }
.bg-orbs span:nth-child(2) { width: 440px; height: 440px; background: #d946ef; bottom: -170px; right: -120px; opacity: 0.28; animation: drift2 26s ease-in-out infinite; }
.bg-orbs span:nth-child(3) { width: 360px; height: 360px; background: #3b82f6; top: 45%; left: 58%; opacity: 0.2; animation: drift3 30s ease-in-out infinite; }
@keyframes drift1 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(80px,60px) scale(1.12); } }
@keyframes drift2 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-70px,-50px) scale(1.15); } }
@keyframes drift3 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-60px,40px) scale(1.2); } }

/* ============ LOGIN — CYBER SHOWCASE ============ */
.login-screen { position: relative; z-index: 1; min-height: 100vh; display: flex; flex-direction: column; justify-content: flex-end; align-items: center; padding: 24px; padding-bottom: 7vh; overflow: hidden; }

/* ===== premium holographic login (no card, no cheap gradients) ===== */
.login-hud { position: relative; z-index: 3; width: min(380px, 86vw); display: flex; flex-direction: column; align-items: center; gap: 22px;
  animation: hudIn 1.8s var(--ease-out) 2.4s both; }
.sys-label { font-family: "Sora"; font-size: 11px; letter-spacing: 5px; color: rgba(200,225,255,0.5); text-transform: uppercase; }
.hud-fields { width: 100%; display: flex; flex-direction: column; gap: 26px;
  padding: 30px 26px 26px; position: relative; }
/* thin holographic frame projected from the void */
.hud-fields::before, .hud-fields::after { content: ""; position: absolute; left: 8%; right: 8%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(150,200,255,0.45), transparent); }
.hud-fields::before { top: 0; } .hud-fields::after { bottom: 0; }

.field-line { display: flex; flex-direction: column; gap: 9px; cursor: text; }
.field-k { font-family: "Sora"; font-size: 11px; letter-spacing: 4px; color: rgba(180,210,255,0.55); }
.hl-input { width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(160,200,255,0.22);
  color: #fff; font-family: "Sora", system-ui; font-weight: 500; font-size: 22px; letter-spacing: 1px; padding: 6px 2px 10px;
  caret-color: #8fd0ff; transition: border-color 0.3s, box-shadow 0.3s; }
.hl-input:focus { outline: none; border-bottom-color: rgba(180,220,255,0.9); box-shadow: 0 1px 0 rgba(140,200,255,0.5); }

.enter-btn { position: relative; width: 100%; margin-top: 6px; cursor: pointer; overflow: hidden;
  padding: 17px; border-radius: 14px; color: #fff; font-family: "Sora"; font-weight: 600; font-size: 14px; letter-spacing: 5px;
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.22); backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.4), inset 0 -1px 0 rgba(0,0,0,0.4), 0 14px 36px -16px rgba(0,0,0,0.9);
  transition: border-color 0.3s, transform 0.2s var(--ease), box-shadow 0.3s; }
.enter-btn::before { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: radial-gradient(120% 60% at 50% -20%, rgba(180,220,255,0.18), transparent 60%); }
.enter-btn:hover { border-color: rgba(180,220,255,0.6); transform: translateY(-1px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 20px 50px -18px rgba(120,180,255,0.55); }
.enter-btn:active { transform: translateY(0) scale(0.99); }

.login-hud .login-err { color: #ff9bb0; font-size: 13px; letter-spacing: 1px; min-height: 16px; text-align: center; }
.login-hud .powered { font-size: 10px; letter-spacing: 2.5px; color: rgba(160,180,210,0.4); }
.login-hud .powered b { color: rgba(200,225,255,0.7); font-weight: 600; }

/* animated synthwave grid floor */
.cyber-grid { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.cyber-grid::before {
  content: ""; position: absolute; left: -50%; right: -50%; bottom: -10%; height: 75%;
  background-image: linear-gradient(rgba(168,85,247,0.35) 1px, transparent 1px), linear-gradient(90deg, rgba(168,85,247,0.35) 1px, transparent 1px);
  background-size: 48px 48px; transform: perspective(380px) rotateX(68deg);
  transform-origin: bottom center; animation: gridMove 5s linear infinite;
  -webkit-mask-image: linear-gradient(to top, #000 10%, transparent 80%); mask-image: linear-gradient(to top, #000 10%, transparent 80%);
}
@keyframes gridMove { from { background-position: 0 0; } to { background-position: 0 48px; } }

/* scanline sweep */
.scanlines { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0.5;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 3px); }
.scanlines::after { content: ""; position: absolute; left: 0; right: 0; height: 180px;
  background: linear-gradient(180deg, transparent, rgba(217,70,239,0.10), transparent); animation: scan 6s linear infinite; }
@keyframes scan { 0% { top: -180px; } 100% { top: 100%; } }

/* rising particles */
.particles { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.particles span { position: absolute; bottom: -10px; width: 4px; height: 4px; border-radius: 50%;
  background: var(--magenta); box-shadow: 0 0 10px var(--magenta); opacity: 0; animation: rise 7s linear infinite; }
.particles span:nth-child(7n) { background: var(--cyan); box-shadow: 0 0 10px var(--cyan); }
.particles span:nth-child(2n) { width: 3px; height: 3px; }
.particles span:nth-child(1){left:6%;animation-delay:0s}.particles span:nth-child(2){left:14%;animation-delay:1.4s}
.particles span:nth-child(3){left:23%;animation-delay:3.1s}.particles span:nth-child(4){left:31%;animation-delay:.6s}
.particles span:nth-child(5){left:40%;animation-delay:2.2s}.particles span:nth-child(6){left:48%;animation-delay:4.5s}
.particles span:nth-child(7){left:57%;animation-delay:1.1s}.particles span:nth-child(8){left:64%;animation-delay:3.7s}
.particles span:nth-child(9){left:72%;animation-delay:.3s}.particles span:nth-child(10){left:79%;animation-delay:2.8s}
.particles span:nth-child(11){left:86%;animation-delay:5.2s}.particles span:nth-child(12){left:92%;animation-delay:1.9s}
.particles span:nth-child(13){left:35%;animation-delay:5.8s}.particles span:nth-child(14){left:67%;animation-delay:4.1s}
@keyframes rise { 0% { transform: translateY(0); opacity: 0; } 10% { opacity: 1; } 90% { opacity: 1; } 100% { transform: translateY(-100vh); opacity: 0; } }

/* the stack */
.login-stack { position: relative; z-index: 2; width: 100%; max-width: 440px; display: flex; flex-direction: column; align-items: center; gap: 22px; }

/* 3D logo hero */
.logo-hero { transform-style: preserve-3d; transition: transform 0.2s ease-out; }
.logo-frame { position: relative; width: min(380px, 78vw); aspect-ratio: 1; border-radius: 22px; overflow: hidden;
  transform-style: preserve-3d; animation: float3d 6s ease-in-out infinite;
  box-shadow: 0 0 0 1px rgba(168,85,247,0.4), 0 30px 90px rgba(124,58,237,0.45); }
.logo-frame::before { content: ""; position: absolute; inset: -40%; z-index: 0;
  background: conic-gradient(from 0deg, transparent, var(--purple), var(--magenta), var(--cyan), transparent 60%);
  animation: spin 5s linear infinite; filter: blur(22px); opacity: 0.85; }
.logo-img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: cover; border-radius: 22px;
  display: block; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08); }
@keyframes float3d { 0%,100% { transform: translateY(0) rotateX(0) rotateY(0); } 50% { transform: translateY(-14px) rotateX(4deg) rotateY(-3deg); } }
@keyframes spin { to { transform: rotate(360deg); } }

/* neon corner brackets */
.corner { position: absolute; z-index: 2; width: 26px; height: 26px; border: 2px solid var(--cyan); box-shadow: 0 0 12px var(--cyan); }
.corner.tl { top: 10px; left: 10px; border-right: none; border-bottom: none; }
.corner.tr { top: 10px; right: 10px; border-left: none; border-bottom: none; }
.corner.bl { bottom: 10px; left: 10px; border-right: none; border-top: none; }
.corner.br { bottom: 10px; right: 10px; border-left: none; border-top: none; }

/* tagline */
.tagline { font-family: "Sora"; font-weight: 800; letter-spacing: 6px; font-size: clamp(14px, 3.4vw, 20px);
  background: linear-gradient(90deg, #c4b5fd, #fff, #f0abfc, #fff, #c4b5fd); background-size: 200% auto;
  -webkit-background-clip: text; background-clip: text; color: transparent; animation: shimmer 4s linear infinite; }
.tagline i { color: var(--magenta); font-style: normal; -webkit-text-fill-color: var(--magenta); text-shadow: 0 0 10px var(--magenta); }
@keyframes shimmer { to { background-position: 200% center; } }

/* login card */
.login-card { width: 100%; max-width: 380px; background: rgba(13,8,24,0.7); border: 1px solid var(--border-bright);
  border-radius: 18px; padding: 26px 26px 22px; text-align: center; backdrop-filter: blur(16px);
  box-shadow: 0 0 30px rgba(168,85,247,0.18), inset 0 1px 0 rgba(255,255,255,0.06); }
.login-inp { margin-bottom: 14px; text-align: left; }
.login-btn { width: 100%; margin-top: 6px; letter-spacing: 2px; font-weight: 800; position: relative; overflow: hidden; }
.login-btn::after { content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.45), transparent); animation: sweep 3s ease-in-out infinite; }
@keyframes sweep { 0% { left: -120%; } 55%,100% { left: 160%; } }
.login-err { color: var(--bad); font-size: 13px; margin-top: 14px; min-height: 18px; }

/* powered by */
.powered { font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.powered b { color: #d8b4fe; font-weight: 700; }
.pw-bolt { color: var(--cyan); text-shadow: 0 0 8px var(--cyan); animation: flick 2.5s steps(1) infinite; }
@keyframes flick { 0%,97%,100% { opacity: 1; } 98% { opacity: 0.3; } }

@media (max-width: 480px) { .tagline { letter-spacing: 3px; } }

/* faint cyber grid across the whole app + glowing sidebar logo */
.bg-orbs::after { content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(168,85,247,0.045) 1px, transparent 1px), linear-gradient(90deg, rgba(168,85,247,0.045) 1px, transparent 1px);
  background-size: 46px 46px; -webkit-mask-image: radial-gradient(circle at 50% 0%, #000, transparent 75%); mask-image: radial-gradient(circle at 50% 0%, #000, transparent 75%); }
.logo-side { animation: logoGlow 3.5s ease-in-out infinite; }
@keyframes logoGlow { 0%,100% { filter: drop-shadow(0 0 2px rgba(168,85,247,0.25)); } 50% { filter: drop-shadow(0 0 10px rgba(217,70,239,0.6)); } }

/* ============ APP SHELL ============ */
.app-shell { position: relative; z-index: 1; display: flex; min-height: 100vh; }
.sidebar {
  width: 252px; flex-shrink: 0; background: linear-gradient(180deg, rgba(18,14,30,0.72), rgba(10,8,18,0.66));
  border-right: 1px solid var(--glass-line); backdrop-filter: blur(26px) saturate(140%);
  display: flex; flex-direction: column; padding: 26px 16px; position: sticky; top: 0; height: 100vh;
}
.logo-side { font-family: "Sora"; font-weight: 800; font-size: 25px; letter-spacing: 1px; padding: 0 10px 26px; }
.logo-side span { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.nav-tabs { display: flex; flex-direction: column; gap: 5px; flex: 1; }
.nav-item {
  position: relative; display: flex; align-items: center; gap: 13px; padding: 12px 14px; border-radius: 13px;
  color: var(--muted); font-weight: 600; font-size: 14px; cursor: pointer; border: 1px solid transparent; background: transparent;
  text-align: left; transition: all 0.25s var(--ease); width: 100%; overflow: hidden;
}
.nav-item::before { content: ""; position: absolute; left: 0; top: 50%; height: 0; width: 3px; border-radius: 3px;
  background: var(--grad); transform: translateY(-50%); transition: height 0.3s var(--ease); box-shadow: 0 0 12px var(--purple); }
.nav-item:hover { background: var(--glass); color: var(--text); transform: translateX(3px); }
.nav-item.active { background: linear-gradient(100deg, rgba(124,58,237,0.22), rgba(217,70,239,0.08)); color: #fff; border-color: var(--border-bright); box-shadow: inset 0 1px 0 rgba(255,255,255,0.06); }
.nav-item.active::before { height: 56%; }
.nav-item .ico { font-size: 16px; width: 20px; text-align: center; transition: transform 0.25s var(--ease); }
.nav-item:hover .ico, .nav-item.active .ico { transform: scale(1.18); }
.nav-badge { margin-left: auto; font-size: 11px; background: rgba(168,85,247,0.2); color: #d8b4fe; padding: 1px 8px; border-radius: 20px; font-weight: 700; }

.sidebar-foot { border-top: 1px solid var(--border); padding-top: 16px; margin-top: 12px; }
.user-chip { display: flex; align-items: center; gap: 10px; padding: 0 4px 12px; }
.user-avatar { width: 38px; height: 38px; border-radius: 11px; background: var(--grad); display: grid; place-items: center; font-weight: 800; color: #fff; }
.user-name { font-weight: 700; font-size: 14px; }
.user-role { color: var(--muted); font-size: 11px; }
.logout-btn { width: 100%; background: rgba(251,95,122,0.1); color: #ff90a4; border: 1px solid rgba(251,95,122,0.2); padding: 9px; border-radius: 10px; cursor: pointer; font-weight: 600; font-size: 13px; }
.logout-btn:hover { background: rgba(251,95,122,0.18); }

/* content */
.content { flex: 1; padding: 40px 44px 90px; max-width: 1160px; }
.page-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 30px; flex-wrap: wrap; gap: 12px; }
.page-title { font-family: "Sora"; font-size: 34px; font-weight: 800; letter-spacing: -1px;
  background: linear-gradient(180deg, #fff, #c9bfee); -webkit-background-clip: text; background-clip: text; color: transparent; }
.page-sub { color: var(--muted); font-size: 13.5px; margin-top: 4px; }

@media (max-width: 800px) {
  .app-shell { flex-direction: column; }
  .sidebar { width: 100%; height: auto; position: relative; flex-direction: row; flex-wrap: wrap; align-items: center; padding: 12px; }
  .nav-tabs { flex-direction: row; flex-wrap: wrap; }
  .sidebar-foot { border-top: none; border-left: 1px solid var(--border); padding: 0 0 0 12px; margin: 0; display: flex; gap: 10px; align-items: center; }
  .content { padding: 20px; }
}

/* ============ CARDS / GRID ============ */
.card { position: relative; background: var(--panel); border: 1px solid var(--glass-line); border-radius: 22px; padding: 24px;
  backdrop-filter: blur(22px) saturate(140%); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,0.05);
  margin-bottom: 20px; transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s var(--ease); overflow: hidden; }
.card::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; pointer-events: none;
  background: linear-gradient(140deg, rgba(168,85,247,0.4), transparent 40%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0.6; }
.card:hover { transform: translateY(-4px); border-color: var(--border-bright); box-shadow: var(--shadow), var(--glow-p), inset 0 1px 0 rgba(255,255,255,0.08); }
.card-title { font-family: "Sora"; font-weight: 700; font-size: 15.5px; margin-bottom: 18px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.grid { display: grid; gap: 18px; }
.grid.cols-2 { grid-template-columns: 1fr 1fr; }
.grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) { .grid.cols-2, .grid.cols-3, .grid.cols-4 { grid-template-columns: 1fr; } }

/* stat cards */
.stat { position: relative; background: linear-gradient(150deg, rgba(124,58,237,0.16), rgba(59,130,246,0.06)); border: 1px solid var(--glass-line);
  border-radius: 18px; padding: 20px; overflow: hidden; transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease); }
.stat::after { content: ""; position: absolute; top: -50%; right: -30%; width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle, rgba(168,85,247,0.3), transparent 70%); filter: blur(20px); }
.stat:hover { transform: translateY(-3px); box-shadow: 0 14px 36px -10px rgba(124,58,237,0.5); }
.stat-label { color: var(--muted); font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; position: relative; }
.stat-value { font-family: "Sora"; font-size: 34px; font-weight: 800; margin-top: 8px; letter-spacing: -1.5px; position: relative;
  background: linear-gradient(180deg, #fff, #d6c9ff); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat-value.sm { font-size: 24px; }

/* ============ BUTTONS / INPUTS ============ */
.btn-primary { position: relative; background: var(--grad); background-size: 180% 180%; color: #fff; border: none; cursor: pointer;
  font-weight: 700; font-size: 14px; padding: 12px 22px; border-radius: 13px; overflow: hidden;
  transition: transform 0.18s var(--ease), box-shadow 0.3s var(--ease); box-shadow: 0 10px 28px -8px rgba(124,58,237,0.6), inset 0 1px 0 rgba(255,255,255,0.25);
  animation: btnFlow 6s ease infinite; }
@keyframes btnFlow { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -8px rgba(168,85,247,0.75), inset 0 1px 0 rgba(255,255,255,0.3); }
.btn-primary:active { transform: translateY(0) scale(0.98); }
.btn-ghost { background: var(--glass); color: #d8b4fe; border: 1px solid var(--glass-line); cursor: pointer; font-weight: 600; font-size: 13px;
  padding: 9px 15px; border-radius: 11px; transition: all 0.22s var(--ease); }
.btn-ghost:hover { border-color: var(--border-bright); color: #fff; background: rgba(168,85,247,0.12); transform: translateY(-1px); }
.btn-sm { padding: 7px 13px; font-size: 12px; border-radius: 10px; }
.btn-danger { background: rgba(251,95,122,0.12); color: #ff90a4; border: 1px solid rgba(251,95,122,0.25); cursor: pointer; padding: 8px 13px; border-radius: 10px; font-weight: 600; font-size: 12px; transition: all 0.2s var(--ease); }
.btn-danger:hover { background: rgba(251,95,122,0.2); transform: translateY(-1px); }
.inp { background: rgba(255,255,255,0.035); border: 1px solid var(--glass-line); color: var(--text); border-radius: 12px; padding: 12px 15px; font-size: 14px; font-family: inherit; width: 100%; transition: border-color 0.25s, box-shadow 0.25s, background 0.25s; }
.inp:focus { outline: none; border-color: var(--purple); background: rgba(168,85,247,0.06); box-shadow: 0 0 0 3px rgba(168,85,247,0.18), 0 0 24px rgba(168,85,247,0.25); }
.inp::placeholder { color: var(--faint); }
select.inp { cursor: pointer; }
.area { resize: vertical; line-height: 1.6; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 12px; color: var(--muted); font-weight: 600; margin-bottom: 7px; }
.row { display: flex; gap: 10px; align-items: center; }
.row.wrap { flex-wrap: wrap; }

/* pills / badges */
.pill { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; padding: 5px 12px; border-radius: 20px; background: var(--glass); color: var(--muted); border: 1px solid var(--glass-line); }
.pill.on { background: rgba(52,211,153,0.14); color: var(--good); border-color: rgba(52,211,153,0.3); box-shadow: 0 0 16px rgba(52,211,153,0.2); animation: livePulse 2s ease-in-out infinite; }
.pill.off { background: rgba(155,147,184,0.1); color: var(--muted); }
@keyframes livePulse { 0%,100% { box-shadow: 0 0 16px rgba(52,211,153,0.18); } 50% { box-shadow: 0 0 22px rgba(52,211,153,0.4); } }
.tag { font-size: 10px; text-transform: uppercase; font-weight: 800; letter-spacing: 0.5px; padding: 3px 8px; border-radius: 6px; }
.tag.major { background: rgba(217,70,239,0.16); color: #f0abfc; }
.tag.minor { background: rgba(124,58,237,0.16); color: #c4b5fd; }
.tag.high { background: rgba(251,95,122,0.16); color: #ff90a4; }
.tag.good { background: rgba(52,211,153,0.16); color: var(--good); }
.tag.warn { background: rgba(251,191,36,0.16); color: var(--warn); }

/* clock card */
.clock-wrap { text-align: center; }
.timer { font-family: "Sora"; font-size: 50px; font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: -1.5px; margin: 8px 0;
  background: linear-gradient(180deg, #fff, #c4b5fd); -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 40px rgba(168,85,247,0.3); }
.clock-btn { width: 100%; margin-top: 14px; padding: 15px; font-size: 15px; letter-spacing: 0.5px; }
.clock-btn.out { background: linear-gradient(135deg, #fb5f7a, #d946ef); }

/* progress bar */
.bar { height: 9px; background: rgba(255,255,255,0.06); border-radius: 8px; overflow: hidden; box-shadow: inset 0 1px 3px rgba(0,0,0,0.4); }
.bar > i { display: block; height: 100%; background: var(--grad); background-size: 200% 100%; border-radius: 8px;
  transition: width 1.1s var(--ease-out); box-shadow: 0 0 14px rgba(168,85,247,0.6); animation: barFlow 3s linear infinite; }
@keyframes barFlow { to { background-position: 200% 0; } }

/* lists / rows */
.list { display: flex; flex-direction: column; gap: 11px; }
.lrow { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 15px 17px; background: var(--glass);
  border: 1px solid var(--glass-line); border-radius: 15px; transition: all 0.25s var(--ease); }
.lrow:hover { background: rgba(168,85,247,0.07); border-color: var(--border-bright); transform: translateX(4px); }
.lrow .l-main { min-width: 0; }
.lrow .l-title { font-weight: 600; font-size: 14px; }
.lrow .l-sub { color: var(--muted); font-size: 12px; margin-top: 3px; }

/* checkable */
.check-item { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: 12px; cursor: pointer; }
.check-item:hover { background: rgba(168,85,247,0.06); }
.check-box { width: 22px; height: 22px; border-radius: 7px; border: 2px solid rgba(168,85,247,0.35); display: grid; place-items: center; flex-shrink: 0; color: transparent; transition: 0.15s; }
.check-item.done .check-box { background: var(--good); border-color: var(--good); color: #042; }
.check-item.done .c-label { color: var(--muted); text-decoration: line-through; }

/* table */
.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl th { text-align: left; color: var(--muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.tbl td { padding: 12px; border-bottom: 1px solid rgba(255,255,255,0.04); }
.tbl tr:hover td { background: rgba(168,85,247,0.04); }
.mono { font-variant-numeric: tabular-nums; }

/* schedule grid */
.sched { display: grid; grid-template-columns: repeat(7, 1fr); gap: 10px; }
@media (max-width: 640px) { .sched { grid-template-columns: 1fr 1fr; } }
.sched-day { position: relative; background: var(--glass); border: 1px solid var(--glass-line); border-radius: 14px; padding: 14px 10px; text-align: center; transition: all 0.3s var(--ease); overflow: hidden; }
.sched-day:hover { transform: translateY(-3px); border-color: var(--border-bright); box-shadow: 0 10px 26px -10px rgba(124,58,237,0.55); }
.sched-day.today { border-color: var(--border-bright); background: linear-gradient(160deg, rgba(124,58,237,0.25), rgba(217,70,239,0.08)); box-shadow: var(--glow-p); }
.sched-day.today::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--grad); box-shadow: 0 0 12px var(--magenta); }
.sched-day.off { opacity: 0.45; }
.sched-day .d { font-weight: 700; font-size: 13px; margin-bottom: 7px; }
.sched-day .t { font-size: 12px; color: var(--muted); line-height: 1.5; }

/* creators */
.creator-card { background: var(--glass); border: 1px solid var(--glass-line); border-radius: 16px; padding: 18px; transition: all 0.3s var(--ease); }
.creator-card:hover { transform: translateY(-3px); border-color: var(--border-bright); box-shadow: 0 12px 30px -12px rgba(124,58,237,0.5); }
.creator-card.star { background: linear-gradient(155deg, rgba(124,58,237,0.14), rgba(217,70,239,0.06)); }
.creator-card.under { border-color: rgba(251,191,36,0.4); }
.creator-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.dots { display: flex; gap: 6px; margin: 12px 0; align-items: center; }
.dot { width: 15px; height: 15px; border-radius: 50%; background: rgba(255,255,255,0.08); border: 1px solid var(--glass-line); transition: all 0.3s var(--ease); }
.dot.fill { background: var(--grad); border-color: transparent; box-shadow: 0 0 12px rgba(168,85,247,0.6); }

/* message ideas */
.cat-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.cat-btn { background: rgba(168,85,247,0.08); border: 1px solid var(--border); color: var(--muted); padding: 8px 14px; border-radius: 20px; cursor: pointer; font-weight: 600; font-size: 13px; }
.cat-btn.active { background: var(--grad); color: #fff; border-color: transparent; }
.msg-box { background: var(--grad-soft); border: 1px solid var(--border-bright); border-radius: 16px; padding: 24px; font-size: 16px; line-height: 1.6; min-height: 90px; }

/* modal */
.modal-wrap { position: fixed; inset: 0; z-index: 50; background: rgba(4,2,10,0.6); backdrop-filter: blur(10px); display: grid; place-items: center; padding: 20px; animation: modalFade 0.3s var(--ease); }
@keyframes modalFade { from { opacity: 0; } to { opacity: 1; } }
.modal { width: 100%; max-width: 470px; background: linear-gradient(165deg, rgba(28,22,44,0.95), rgba(16,12,26,0.95));
  border: 1px solid var(--border-bright); border-radius: 22px; box-shadow: 0 50px 120px rgba(0,0,0,0.7), var(--glow-p), inset 0 1px 0 rgba(255,255,255,0.07);
  backdrop-filter: blur(30px); animation: modalPop 0.4s var(--ease); }
@keyframes modalPop { from { opacity: 0; transform: translateY(24px) scale(0.94); } to { opacity: 1; transform: translateY(0) scale(1); } }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid var(--glass-line); }
.modal-title { font-family: "Sora"; font-weight: 700; font-size: 18px; }
.modal-close { background: transparent; border: none; color: var(--muted); font-size: 26px; cursor: pointer; line-height: 1; transition: color 0.2s, transform 0.2s; }
.modal-close:hover { color: #fff; transform: rotate(90deg); }
.modal-body { padding: 22px; max-height: 70vh; overflow-y: auto; }

.empty { text-align: center; color: var(--muted); padding: 30px; font-size: 14px; }
.flash-ok { color: var(--good) !important; }

/* ============ SCHEDULE CALENDAR ============ */
.sched-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.week-nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.week-label { font-weight: 700; font-size: 14px; margin-left: 6px; }

.cal-wrap { overflow-x: auto; margin: 0 -6px; padding: 0 6px; }
.cal { width: 100%; border-collapse: separate; border-spacing: 7px; min-width: 760px; }
.cal th { padding: 6px 4px; text-align: center; }
.cal th.cal-name-h { text-align: left; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; width: 150px; }
.cal th .cal-day { font-weight: 700; font-size: 13px; }
.cal th .cal-date { font-size: 11px; color: var(--muted); margin-top: 2px; }
.cal th.today-col .cal-day { color: var(--magenta); }
.cal td { padding: 0; vertical-align: top; }
.cal-name { width: 150px; }
.cal-name .cn-name { font-weight: 700; font-size: 14px; }
.cal-name .cn-role { color: var(--muted); font-size: 11px; margin-top: 2px; }

.cell {
  width: 100%; min-height: 64px; border-radius: 12px; cursor: pointer;
  background: rgba(255,255,255,0.03); border: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px;
  color: var(--text); font-family: inherit; transition: 0.15s; padding: 8px 4px;
}
.cell:hover { border-color: var(--border-bright); background: rgba(168,85,247,0.08); }
.cell.has { background: var(--grad-soft); border-color: var(--border-bright); }
.cell.has .cell-time { font-weight: 700; font-size: 13px; }
.cell.has .cell-sep { color: var(--muted); font-size: 11px; }
.cell.empty .cell-add { color: #6b6483; font-size: 20px; font-weight: 600; }
.cell.empty:hover .cell-add { color: var(--purple); }
.cell.today-col { box-shadow: inset 0 0 0 1px rgba(217,70,239,0.3); }

/* current-time banner */
.now-banner { background: var(--grad-soft); border: 1px solid var(--border-bright); border-radius: 18px; padding: 20px 24px; margin-bottom: 18px; text-align: center; }
.now-label { color: var(--muted); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.now-clock { font-family: "Sora"; font-size: 40px; font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: -1px; margin: 4px 0; }
.now-zone { color: var(--muted); font-size: 13px; }

/* countdown blocks (worker clock card) */
.cd-block { margin-top: 16px; padding: 16px; border-radius: 14px; background: rgba(168,85,247,0.08); border: 1px solid var(--border); }
.cd-block.big { background: var(--grad-soft); border-color: var(--border-bright); }
.cd-label { color: var(--muted); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.cd-count { font-family: "Sora"; font-weight: 800; font-size: 22px; font-variant-numeric: tabular-nums; margin-top: 4px; }
.cd-count.huge { font-size: 34px; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.cd-time { font-size: 19px; font-weight: 700; margin-top: 8px; }
.cd-tz { font-size: 12px; color: var(--muted); font-weight: 500; }
.cd-sub { color: var(--muted); font-size: 13px; margin-top: 4px; }

/* ============ CREATORS ============ */
.star-section { border-color: var(--border-bright); }
.creator-card { background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 14px; padding: 16px; }
.creator-card.star { background: var(--grad-soft); }
.creator-card.under { border-color: rgba(251,191,36,0.4); }
.creator-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.c-name { font-weight: 700; font-size: 14px; }
.c-uid { color: var(--muted); font-size: 12px; margin-top: 2px; }
.dots { display: flex; gap: 6px; margin-top: 12px; align-items: center; }
.dot { width: 16px; height: 16px; border-radius: 50%; background: rgba(255,255,255,0.08); border: 1px solid var(--border); }
.dot.fill { background: var(--grad); border-color: transparent; box-shadow: 0 0 10px rgba(168,85,247,0.5); }
.btn-ghost.starred { color: #fde047; border-color: rgba(253,224,71,0.4); background: rgba(253,224,71,0.08); }
[data-unstar] { color: #fde047 !important; }

/* ============ ANALYTICS ============ */
.metric { background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 14px; padding: 16px; text-align: center; }
.metric-label { color: var(--muted); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.metric-value { font-family: "Sora"; font-size: 30px; font-weight: 800; letter-spacing: -1px; margin: 6px 0; }
.chg { font-size: 13px; font-weight: 700; }
.chg.up { color: var(--good); }
.chg.down { color: var(--bad); }
.chg.neutral { color: #ffffff; }

.waiting { text-align: center; padding: 50px 24px; }
.waiting-ico { font-size: 46px; margin-bottom: 10px; }
.waiting-title { font-family: "Sora"; font-size: 20px; font-weight: 700; margin-bottom: 8px; }

.analytics-tbl { min-width: 640px; }
.analytics-tbl th { font-size: 12px; }
.analytics-tbl .cname { font-weight: 700; font-size: 14px; min-width: 150px; }
.analytics-tbl input.num { width: 120px; padding: 9px 11px; }
.lastwk { color: var(--muted); font-size: 11px; margin-top: 4px; height: 14px; }

/* ============ MONTHLY GOALS ============ */
.goal-card { }
.goal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.goal-name { font-family: "Sora"; font-weight: 700; font-size: 18px; }
.goal-pct { font-family: "Sora"; font-weight: 800; font-size: 30px; letter-spacing: -1px; color: var(--text); }
.goal-pct.up { color: var(--good); }
.goal-meta { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 12px; font-size: 13px; color: var(--muted); flex-wrap: wrap; }
.goal-meta b { color: var(--text); }
.exp-btn { background: rgba(168,85,247,0.1); border: 1px solid var(--border); color: #d8b4fe; cursor: pointer; padding: 6px 12px; border-radius: 9px; font-weight: 600; font-size: 12px; }
.exp-btn:hover { border-color: var(--border-bright); }
.movers { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border); }
.mov-h { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; }
.mov-h.up { color: var(--good); }
.mov-h.down { color: var(--bad); }
.mov-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 8px 10px; border-radius: 9px; background: rgba(255,255,255,0.03); margin-bottom: 6px; font-size: 13px; }
.mov-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* timezone conversion preview in shift modal */
.tz-preview { font-size: 14px; padding: 12px 14px; border-radius: 12px; background: rgba(52,211,153,0.08); border: 1px solid rgba(52,211,153,0.25); min-height: 20px; }
.tz-preview:empty { display: none; }
.tz-pico { color: var(--muted); font-size: 12px; }

/* ============================================================
   MOTION LAYER — page transitions, staggered reveals, lift
   ============================================================ */
@keyframes pageIn { from { opacity: 0; transform: translateY(10px); filter: blur(4px); } to { opacity: 1; transform: translateY(0); filter: blur(0); } }
@keyframes cardIn { from { opacity: 0; transform: translateY(26px) scale(0.985); } to { opacity: 1; transform: translateY(0) scale(1); } }

.content.stagger { animation: pageIn 0.5s var(--ease-out); }
.content.stagger > * { opacity: 0; animation: cardIn 0.62s var(--ease-out) forwards; }
/* delays assigned inline by JS, with a CSS fallback cascade */
.content.stagger > *:nth-child(1) { animation-delay: 0.02s; }
.content.stagger > *:nth-child(2) { animation-delay: 0.09s; }
.content.stagger > *:nth-child(3) { animation-delay: 0.16s; }
.content.stagger > *:nth-child(4) { animation-delay: 0.23s; }
.content.stagger > *:nth-child(5) { animation-delay: 0.30s; }
.content.stagger > *:nth-child(6) { animation-delay: 0.37s; }
.content.stagger > *:nth-child(n+7) { animation-delay: 0.44s; }

/* tasteful focus ring for keyboard users */
button:focus-visible, .inp:focus-visible, .nav-item:focus-visible { outline: 2px solid rgba(168,85,247,0.6); outline-offset: 2px; }

/* ============ COMMAND DASHBOARD ============ */
.qa-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.qa { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; padding: 18px; border-radius: 16px; cursor: pointer;
  background: var(--glass); border: 1px solid var(--glass-line); color: var(--text); font-family: inherit; font-weight: 700; font-size: 14px;
  text-align: left; transition: all 0.3s var(--ease); }
.qa:hover { transform: translateY(-3px); border-color: var(--border-bright); background: linear-gradient(150deg, rgba(124,58,237,0.18), rgba(217,70,239,0.05)); box-shadow: 0 12px 30px -12px rgba(124,58,237,0.6); }
.qa-ico { width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; font-size: 18px; background: var(--grad); color: #fff; box-shadow: 0 6px 16px -4px rgba(168,85,247,0.6); }
.dash-mini { margin-top: 20px; padding: 18px; border-radius: 16px; background: linear-gradient(150deg, rgba(59,130,246,0.12), rgba(124,58,237,0.06)); border: 1px solid var(--glass-line); }
.dash-mini-num { font-family: "Sora"; font-size: 32px; font-weight: 800; letter-spacing: -1px; background: linear-gradient(180deg,#fff,#c4b5fd); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ============================================================
   LIVING AI ENGINE — full-viewport WebGL stage
   ============================================================ */
#ai-stage { position: fixed; inset: 0; width: 100%; height: 100%; z-index: 0; display: block; pointer-events: none; transition: opacity 1.6s var(--ease); }
.bg-orbs { opacity: 0.22; }
body.app-active #ai-stage { opacity: 0.55; }

/* arrival veil — covers the very first frames, then dissolves */
#arrivalVeil { position: fixed; inset: 0; z-index: 40; background: #02010a; pointer-events: none; animation: veilOut 1.8s ease forwards; }
@keyframes veilOut { 0% { opacity: 1; } 100% { opacity: 0; } }
#arrivalVeil.gone { opacity: 0; }

/* DOCKING — the HUD powers down as the camera jumps to hyperspace */
body.docking .login-hud { opacity: 0; transform: scale(0.88) translateY(-18px); filter: blur(18px);
  transition: opacity 0.7s var(--ease), transform 1s var(--ease), filter 0.7s var(--ease); pointer-events: none; }
body.docking .boot-line { opacity: 0; transition: opacity 0.5s; }

/* ===== LOGIN HUD — the AI is the screen ===== */
.login-screen { background: transparent; }
.boot-line { position: absolute; top: 22px; left: 26px; z-index: 3; font-family: "Sora"; font-size: 12px; letter-spacing: 3px;
  color: #c3b1ff; text-transform: uppercase; opacity: 0.85; text-shadow: 0 0 12px rgba(168,85,247,0.7); animation: bootflick 5s steps(1) infinite; }
@keyframes bootflick { 0%,95%,100% { opacity: 0.85; } 96% { opacity: 0.15; } 98% { opacity: 0.6; } }
.login-hud { position: relative; z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 20px; width: min(420px, 88vw); text-align: center;
  animation: hudIn 1.8s var(--ease-out) 2.4s both; }
@keyframes hudIn { 0% { opacity: 0; transform: translateY(34px) scale(0.95); filter: blur(12px); } 100% { opacity: 1; transform: none; filter: blur(0); } }
.boot-line { animation-delay: 0s; }
.hud-mark { font-family: "Sora"; font-weight: 800; font-size: clamp(56px, 13vw, 92px); letter-spacing: -3px; line-height: 0.88;
  background: linear-gradient(180deg, #fff 0%, #d8c9ff 45%, #a855f7 100%); -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 0 34px rgba(168,85,247,0.6)); }
.hud-mark span { background: linear-gradient(180deg, #fff, #7cc7ff 55%, #3b82f6); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hud-tag { font-family: "Sora"; font-weight: 700; letter-spacing: 6px; font-size: clamp(12px, 3vw, 15px);
  background: linear-gradient(90deg, #c4b5fd, #fff, #f0abfc, #fff, #c4b5fd); background-size: 200% auto; -webkit-background-clip: text; background-clip: text; color: transparent; animation: shimmer 4s linear infinite; }
.hud-tag i { -webkit-text-fill-color: var(--magenta); color: var(--magenta); font-style: normal; text-shadow: 0 0 10px var(--magenta); }
.hud-field { width: 100%; display: flex; flex-direction: column; gap: 13px; padding: 24px; border-radius: 20px;
  background: rgba(6,5,12,0.55); border: 1px solid rgba(168,110,255,0.22); backdrop-filter: blur(26px) saturate(150%);
  box-shadow: 0 40px 100px -28px rgba(124,58,237,0.6), inset 0 1px 0 rgba(255,255,255,0.06); }
.hud-field .login-inp { text-align: left; background: rgba(255,255,255,0.03); border-color: rgba(168,110,255,0.28); padding: 14px 16px; }
.hud-field .login-inp:focus { box-shadow: 0 0 0 3px rgba(168,85,247,0.22), 0 0 30px rgba(168,85,247,0.4); border-color: var(--purple); }
.login-btn { width: 100%; margin-top: 6px; letter-spacing: 2px; padding: 15px;
  animation: btnFlow 6s ease infinite, heroPulse 3.6s ease-in-out infinite; }
@keyframes heroPulse {
  0%,100% { box-shadow: 0 0 0 1px rgba(168,85,247,0.4), 0 14px 40px -10px rgba(168,85,247,0.55); }
  50% { box-shadow: 0 0 0 1px rgba(217,70,239,0.7), 0 20px 64px -8px rgba(217,70,239,0.9); }
}

/* ===== first-contact greeting ===== */
.greeting { position: absolute; top: 11%; left: 0; right: 0; z-index: 3; text-align: center; pointer-events: none; display: flex; flex-direction: column; gap: 9px; }
.g-line { font-family: "Sora"; font-weight: 600; letter-spacing: 4px; font-size: clamp(11px, 2.3vw, 14px); text-transform: uppercase;
  color: #bfe0ff; text-shadow: 0 0 18px rgba(90,160,255,0.7); opacity: 0; animation: gLine 1.3s var(--ease-out) forwards; }
.g-line:nth-child(2) { color: #fff; font-size: clamp(13px, 2.7vw, 17px); text-shadow: 0 0 24px rgba(140,190,255,0.9); }
@keyframes gLine { 0% { opacity: 0; transform: translateY(12px); filter: blur(9px); letter-spacing: 14px; } 100% { opacity: 0.92; transform: none; filter: blur(0); letter-spacing: 4px; } }
body.app-active .greeting { opacity: 0; transition: opacity 0.6s; }

/* ===== cursor energy beacon ===== */
#beacon { position: fixed; top: 0; left: 0; z-index: 60; width: 11px; height: 11px; margin: -5.5px 0 0 -5.5px; border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, #ffffff 0%, #9fd0ff 38%, rgba(124,58,237,0) 72%);
  box-shadow: 0 0 16px #7cc7ff, 0 0 34px rgba(124,58,237,0.65); mix-blend-mode: screen; transition: width 0.2s, height 0.2s; }
.login-screen, .login-screen * { cursor: none; }

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}
