﻿:root{
  --bg:#0e1116;
  --panel:#121620;
  --panel-2:#0f1420;
  --border:rgba(255,255,255,.06);
  --muted:rgba(255,255,255,.55);
  --text:#e7eaf0;
  --text-dim:#b8c0cc;
  --ring:#6aa7ff;
  --brand:#e03870;
  --brand-2:#c02a5c;
  --success:#1db954;
  --warning:#ffb020;
  --danger:#ff5d5d;
  --radius:12px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:
    radial-gradient(1200px 800px at 20% -10%, #1b2233 0%, rgba(27,34,51,0) 60%),
    radial-gradient(1000px 700px at 110% 10%, #1a1f2d 0%, rgba(26,31,45,0) 55%),
    var(--bg);
  color:var(--text);
  background-size:120% 120%,120% 120%,auto;
  animation:bg-drift 18s ease-in-out infinite alternate;
}

.topbar{
  position:fixed;top:0;left:0;right:0;height:56px;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:saturate(140%) blur(8px);
  background:rgba(10,12,18,.5);border-bottom:1px solid var(--border);z-index:20
}
.brand{display:flex;gap:.5rem;align-items:center;font-weight:600;color:var(--text);animation:fade-down .6s ease-out both}
.rx{opacity:.9}
.divider{opacity:.25}
.cfx{opacity:.9}

#data-del {
  transition: background-color 0.3s ease-in-out;
}
#data-del:hover {
  background-color: #381b1b85;
}

#data-download {
  transition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;
}
#data-download:hover {
  background-color: #182b1498;
  color: #1db954;
}


.auth-actions{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}
.user-info{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}
.user-avatar{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);display:block;object-fit:cover}
.status-left{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}
.topnav{position:absolute;left:140px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:14px}
.topnav a{color:var(--muted);text-decoration:none}
.topnav a:hover{color:#fff;text-decoration:underline}
.status-line{display:flex;align-items:center;gap:6px}
.status-left, .status-left .status-line, .status-left .status-line span{font-size:13px;line-height:1}

.wrap{min-height:100dvh;display:grid;place-items:center;padding:96px 16px 80px}
.panel{
  width:100%;max-width:520px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
  opacity:0;transform:translateY(10px) scale(.98)
}
.panel.enter{animation:fade-up .6s cubic-bezier(.22,.8,.28,.99) .15s forwards}
.panel-head{padding:28px 28px 12px;border-bottom:1px solid var(--border)}
.panel{display:flex;flex-direction:column;height:100%}
#panel-session{position:relative}
.inline-hint{position:absolute;top:14px;right:16px;display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;opacity:0;transform:translateY(-4px);transition:opacity .2s ease, transform .2s ease}
.inline-hint.show{opacity:1;transform:none}
.hint-dot{width:12px;height:12px;border:2px solid rgba(255,255,255,.18);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}
.panel-body{flex:1;display:flex;flex-direction:column;gap:12px}
/* Ensure list stretches so pager stays pinned at bottom */
#myList{flex:1;overflow:auto;min-height:240px}
/* Pager layout consistent at bottom of panel */
.actions.pager{justify-content:space-between;margin-top:8px; margin-bottom: 1.8rem;border-top:1px solid var(--border);padding-top:10px}
.actions{display:flex;gap:10px;justify-content:flex-end}

.file-hidden{display:none}
.file-picker{display:flex;align-items:center;gap:10px}
.icon-btn{
  width:44px;height:44px;border-radius:12px;border:1px solid var(--border);
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  color:var(--text);display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:var(--shadow);transition:transform .08s ease, filter .2s ease, box-shadow .2s ease, background .2s ease
}
.icon-btn:hover{filter:brightness(1.06)}
.icon-btn:active{transform:translateY(1px)}
.icon-btn i{font-size:18px;color:#fff;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}

.dropzone{border:1px dashed var(--border);border-radius:12px;padding:12px;background:#0b0f17;transition:border-color .2s, box-shadow .2s, background .2s}
.dropzone:hover{border-color:#3d6cff33}
.dropzone.over{border-color:#3d6cff;box-shadow:0 0 0 3px rgba(61,108,255,.15);background:#0d1422}
.title{
  font-size:28px;line-height:1.1;font-weight:700;letter-spacing:-.02em;
  background:linear-gradient(90deg,#ffffff 0%,#b9c6d8 25%,#ffffff 50%,#b9c6d8 75%,#ffffff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;animation:shimmer 3.5s ease-in-out infinite
}
.subtitle{margin-top:6px;color:var(--text-dim);font-size:14px;opacity:0;transform:translateY(6px)}
.panel.enter .subtitle{animation:fade-up .5s ease .25s forwards}

.panel-body{padding:24px 28px 8px}
.label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;opacity:0;transform:translateY(6px)}
.panel.enter .label{animation:fade-up .5s ease .3s forwards}
.input{
  width:100%;height:44px;border-radius:10px;border:1px solid var(--border);
  font-family: 'Courier New', Courier, monospace;
  background:#0b0f17;color:var(--text);padding:0 14px;font-size:14px;transition:border .2s, box-shadow .2s, transform .12s
}
.input::placeholder{color:#71809a}
.input:focus{outline:none;border-color:#3d6cff;box-shadow:0 0 0 3px rgba(61,108,255,.15);transform:translateY(-1px)}
.btn{
  width:100%;height:44px;margin-top:12px;border:none;border-radius:10px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:transform .08s ease, filter .2s ease, box-shadow .2s ease, background .2s ease;
  position:relative;overflow:hidden
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);color:#fff;box-shadow:0 10px 24px rgba(224,56,112,.25);
  animation:btn-glow 3s ease-in-out infinite
}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary:after{
  content:"";position:absolute;inset:0;transform:translateX(-120%) skewX(-20deg);
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.22) 50%,transparent 100%);
  transition:transform .6s ease
}
.btn-primary:hover:after{transform:translateX(120%) skewX(-20deg)}
.ripple{
  position:absolute;border-radius:50%;pointer-events:none;transform:scale(0);
  background:rgba(255,255,255,.35);animation:ripple .6s ease-out forwards
}

.stack{margin-top:16px}

.alert{
  border:1px solid var(--border);
  background:#0c111a;border-radius:10px;padding:14px 14px;display:flex;gap:10px;align-items:center;font-size:14px;
  opacity:0;transform:translateY(6px)
}
.alert.show{animation:fade-up .45s ease forwards}
.alert.success{border-color:rgba(29,185,84,.35);background:rgba(29,185,84,.08);color:#8fe3ab}
.alert.warn{border-color:rgba(255,176,32,.35);background:rgba(255,176,32,.08);color:#ffd48a}
.alert.danger{border-color:rgba(255,93,93,.35);background:rgba(255,93,93,.08);color:#ff9c9c}

.download{margin-top:10px;display:flex;justify-content:center}
.dlbtn{
  display:inline-flex;gap:.5rem;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:10px;background:#1b2738;border:1px solid var(--border);color:#fff;text-decoration:none;transition:transform .12s, background .2s,border .2s, box-shadow .2s;
  transform:scale(.98);opacity:0
}
.dlbtn.pop{animation:pop .35s ease-out forwards}

/* --- Profile page components --- */
.panel.wide{max-width:1100px}
.profile-card{max-width:980px;display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center}
.p-avatar{width:96px;height:96px;border-radius:12px;object-fit:cover;border:1px solid var(--border);background:#0b0f17;box-shadow:var(--shadow)}
.p-meta h2{margin:0;font-size:24px;letter-spacing:-.01em}
.p-meta .muted{margin-top:4px}
.p-id{word-break:break-all}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);font-size:12px;color:var(--text-dim)}
.badge i{color:#8fe3ab}
.profile-hero{position:relative;border:1px solid var(--border);border-radius:12px;padding:18px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);box-shadow:var(--shadow);overflow:hidden}
.profile-hero::before{content:"";position:absolute;inset:-30%;background:radial-gradient(600px 240px at 0% 0%, rgba(106,167,255,.18), transparent 60%);pointer-events:none}
.hero-inner{display:flex;align-items:center;gap:16px}
.avatar-ring{width:108px;height:108px;border-radius:999px;padding:3px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);box-shadow:0 8px 24px rgba(224,56,112,.25)}
.avatar-ring .p-avatar{width:100%;height:100%;border-radius:inherit;border:1px solid rgba(255,255,255,.18);background:#0b0f17;display:block}
.pill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:14px}
.pill{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:14px;padding:12px 14px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);box-shadow:var(--shadow);transition:transform .15s ease, border-color .2s ease, box-shadow .2s ease}
.pill .icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);color:#fff;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 12px rgba(224,56,112,.25)}
.pill .meta .label{color:var(--muted);font-size:12px}
.pill .meta .value{font-size:20px;font-weight:700}
.pill:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.12);box-shadow:0 10px 28px rgba(0,0,0,.45)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:16px}
.stat-card{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease}
.stat-card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.12);box-shadow:0 10px 28px rgba(0,0,0,.45);background:linear-gradient(180deg,var(--panel) 0%,#0f1726 100%)}
.stat-card .head{display:flex;align-items:center;gap:10px}
.stat-card .icon{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);color:#fff;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 12px rgba(224,56,112,.25);transition:transform .2s ease, filter .2s ease}
.stat-card:hover .icon{transform:scale(1.06)}
.stat-card .label{color:var(--muted);font-size:12px}
.stat-card .value{font-size:22px;font-weight:700;margin-top:8px}
.stat-card .action-top{position:absolute;right:10px;top:10px}
.stat-card .action-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);display:inline-flex;align-items:center;justify-content:center;color:#fff}

.footer{
  position:fixed;left:0;right:0;bottom:0;height:44px;display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;border-top:1px solid var(--border);background:rgba(10,12,18,.6);backdrop-filter:blur(8px);color:var(--muted);font-size:12px
}

.foot-center {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.preloader{
  position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50;transition:opacity .5s ease-out
}
.preloader.fade-out{opacity:0;pointer-events:none}
.preloader-logo{width:84px;height:84px;border-radius:50%;margin-bottom:18px;animation:pulse 1.8s infinite}
.preloader-spinner{
  width:54px;height:54px;border-radius:50%;border:3px solid rgba(255,255,255,.08);border-top-color:#fff;animation:spin 1s linear infinite
}

@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.8}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fade-up{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes fade-down{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes btn-glow{0%,100%{box-shadow:0 10px 24px rgba(224,56,112,.25)}50%{box-shadow:0 14px 30px rgba(224,56,112,.38)}}
@keyframes ripple{to{transform:scale(10);opacity:0}}
@keyframes bg-drift{0%{background-position:0% 0%,100% 0%,0 0}100%{background-position:40% 20%,-20% 30%,0 0}}
@keyframes pop{0%{opacity:0;transform:scale(.95)}100%{opacity:1;transform:scale(1)}}

.grid{display:grid;gap:16px;width:100%;max-width:1100px;align-items:stretch}
@media(min-width:980px){.grid{grid-template-columns:1fr 1fr}}
.grid>.panel{margin:0 auto}

.toasts{position:fixed;right:16px;top:66px;display:flex;flex-direction:column;gap:10px;z-index:60;pointer-events:none}
.toast{min-width:260px;max-width:360px;border:1px solid var(--border);background:#0c111a;color:var(--text);border-radius:10px;box-shadow:var(--shadow);padding:12px 14px;opacity:0;transform:translateX(12px);animation:toast-in .28s ease forwards;pointer-events:auto}
.toast.success{border-color:rgba(29,185,84,.35);background:rgba(29,185,84,.08);color:#8fe3ab}
.toast.warn{border-color:rgba(255,176,32,.35);background:rgba(255,176,32,.08);color:#ffd48a}
.toast.danger{border-color:rgba(255,93,93,.35);background:rgba(255,93,93,.08);color:#ff9c9c}
.toast .close{margin-left:10px;color:inherit;opacity:.75;cursor:pointer;font-weight:600}
.toast .close{background:transparent;border:none;font-size:16px;line-height:1}
@keyframes toast-in{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
@keyframes toast-out{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(14px)}}
@media(max-width:640px){.toasts{left:16px;right:16px;top:70px}.toast{max-width:none;width:100%}.my-item{flex-direction:column;align-items:flex-start;gap:8px}.brand{display:none}
}



.muted{color:var(--muted);font-size:13px}

.bar-wrap{width:100%;max-width:1100px;margin:18px auto 0}
.ready-bar{border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);padding:18px;opacity:0;transform:translateY(14px) scale(.98)}
.ready-bar.enter{animation:fade-up .5s ease forwards}
.ready-title{font-size:18px;margin-bottom:12px;color:var(--text);text-align:center}
.btn-lg{height:56px;font-size:16px;border-radius:12px;width:100%}
.hidden{display:none !important}

.my-list{display:grid;gap:10px;align-content:start;align-items:start}
.my-item{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:#0b0f17}
.my-item .meta{display:flex;flex-direction:column;gap:2px}
.my-item .actions a{color:#fff;text-decoration:none;border:1px solid var(--border);padding:6px 10px;border-radius:8px;background:#1b2738}
.my-item .actions a:hover{filter:brightness(1.06)}
#myPrev, #myNext, #leaksPrev, #leaksNext {
  padding-left: .5rem;
  padding-right: .5rem;
}

.auth-gate{position:fixed;inset:0;z-index:70;display:flex;align-items:center;justify-content:center;background:rgba(8,10,14,.55);backdrop-filter:blur(10px)}
.gate-card{width:100%;max-width:380px;padding:22px;border-radius:12px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);box-shadow:var(--shadow);text-align:center}
.gate-logo{width:64px;height:64px;margin-bottom:10px}
.gate-title{font-size:22px;margin-bottom:6px}
.gate-sub{color:var(--text-dim);font-size:13px}

body.gate-open .wrap{filter:blur(6px);pointer-events:none}
body.gate-open .footer{filter:blur(6px);pointer-events:none}
body.gate-open .auth-actions{display:none}
body.gate-open .user-info{display:none !important}
body.gate-open .status-left{display:none !important}

.logout-link{color:var(--muted);text-decoration:none}
.logout-link:hover{color:#fff;text-decoration:underline}

#userText .bold {
  font-weight: 900;
  color: rgba(255, 255, 255, 0.63);
}
.drawer-toggle {
  position: fixed;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #111;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
  cursor: pointer;
  z-index: 1001;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.drawer-toggle i {
  font-size: 22px;
}

.drawer-toggle:focus {
  outline: 2px solid #4c9ffe;
  outline-offset: 2px;
}

.right-drawer {
  position: fixed;
  top: 0;
  right: -280px; 
  width: 260px;
  height: 100vh;
  background: #1e1e1e;
  color: #fff;
  box-shadow: -2px 0 14px rgba(0, 0, 0, 0.35);
  transition: right 0.3s ease;
  z-index: 1000;
  padding: 16px 12px;
  overflow-y: auto;
}

.right-drawer.open {
  right: 0;
}

.right-drawer header {
  font-weight: 600;
  margin-bottom: 8px;
}

.right-drawer ul {
  list-style: none;
  padding: 0;
  margin: 8px 0 0 0;
}

.right-drawer li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.right-drawer a,
.right-drawer button {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  color: inherit;
  text-decoration: none;
  padding: 12px 8px;
  border: 0;
  cursor: pointer;
}

.drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 999;
}

.drawer-backdrop.open {
  opacity: 1;
  pointer-events: auto;
}

.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.fab-wrapper {
  position: fixed;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  z-index: 1100;
}

.fab-main {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #111;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 8px 20px rgba(0,0,0,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background-color 0.2s ease;
  position: relative;
}

.fab-main i { font-size: 22px; }

.fab-wrapper.disabled { pointer-events: none; opacity: 0.6; }

.fab-actions {
  position: absolute;
  top: 50%;
  right: 50%; 
  transform: translate(50%, -50%);
  pointer-events: none; 
}

.fab-item {
  position: absolute;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #1e1e1e;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 8px 18px rgba(0,0,0,0.25);
  opacity: 0;
  transform: translateX(0) scale(0.85);
  transition: transform 0.28s ease, opacity 0.22s ease, box-shadow 0.22s ease, background-color 0.2s ease;
}

.fab-item i { font-size: 18px; }

.fab-wrapper.open .fab-actions { pointer-events: auto; }
.fab-wrapper.open .fab-item { opacity: 1; transform: scale(1); }
.fab-wrapper.open .fab-item:nth-child(1) { transform: translateX(-74px) scale(1); }
.fab-wrapper.open .fab-item:nth-child(2) { transform: translateX(-138px) scale(1); }
.fab-wrapper.open .fab-item:nth-child(3) { transform: translateX(-202px) scale(1); }
.fab-wrapper.open .fab-item:nth-child(4) { transform: translateX(-266px) scale(1); }

.fab-main:hover { transform: scale(1.06); background: #161616; box-shadow: 0 10px 24px rgba(0,0,0,0.38); }
.fab-main:active { transform: scale(0.98); }
.fab-wrapper.open .fab-item:hover { box-shadow: 0 10px 24px rgba(0,0,0,0.35); background: #242424; }
.fab-wrapper.open .fab-item:nth-child(1):hover { transform: translateX(-74px) scale(1.08); }
.fab-wrapper.open .fab-item:nth-child(2):hover { transform: translateX(-138px) scale(1.08); }
.fab-wrapper.open .fab-item:nth-child(3):hover { transform: translateX(-202px) scale(1.08); }
.fab-wrapper.open .fab-item:nth-child(4):hover { transform: translateX(-266px) scale(1.08); }
.fab-wrapper.open .fab-item:active { transform: scale(0.96); }

.fab-main i { transition: transform 0.3s ease; }
.fab-wrapper.open .fab-main i { transform: rotate(90deg); }

.fab-wrapper.open .fab-item:nth-child(1) { transition-delay: 40ms; }
.fab-wrapper.open .fab-item:nth-child(2) { transition-delay: 90ms; }
.fab-wrapper.open .fab-item:nth-child(3) { transition-delay: 130ms; }
.fab-wrapper.open .fab-item:nth-child(4) { transition-delay: 170ms; }

/* Desktop-only tooltips for FAB items */
@media (hover: hover) and (pointer: fine) {
  .fab-item[data-tip]::after {
    content: attr(data-tip);
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translate(-50%, 0) scale(0.96);
    background: rgba(15, 17, 24, 0.96);
    color: #fff;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 8px;
    font-size: 12px;
    white-space: nowrap;
    box-shadow: 0 8px 20px rgba(0,0,0,.35);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
    z-index: 1200;
  }
  .fab-wrapper.open .fab-item:hover::after { opacity: 1; transform: translate(-50%, 2px) scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  .fab-main, .fab-item {
    transition: none;
  }
}

body.is-loading { overflow: hidden; }
.preloader {
  position: fixed;
  inset: 0;
  background: #0d0d0f;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  z-index: 2000;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.6s ease;
}
.preloader.preloader-hide { opacity: 0; pointer-events: none; }
.preloader-logo {
  width: 72px;
  height: 72px;
  object-fit: contain;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,0.35));
}
.preloader-spinner {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 4px solid rgba(255,255,255,0.15);
  border-top-color: #4c9ffe;
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (min-width: 1024px) {
  #webAlert { display: none; }
  #startDecBtn {margin-bottom: 1.5rem;}
}

@media (max-width: 767px) {
  #toasts {
    display: none;
  }
}

/* --- Pager layout for My Decrypts --- */
#myList{flex:1;overflow:auto;min-height:240px}
.actions.pager{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  border-top:1px solid var(--border);
  padding-top:10px;
  margin-top:8px
}
.actions.pager #myPrev{justify-self:start}
.actions.pager #leaksPrev{justify-self:start}
.actions.pager #myPageInfo{justify-self:center;text-align:center}
.actions.pager #leaksPageInfo{justify-self:center;text-align:center}
.actions.pager #leaksNext{justify-self:end}
.actions.pager #myNext{justify-self:end}



.topbar svg {
  width: 35%;
}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;padding:12px}
.modal.hidden{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(2px)}
.modal-card{position:relative;width:100%;max-width:520px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
.modal-head{padding:16px 16px;border-bottom:1px solid var(--border)}
.modal-body{padding:16px 16px;max-height:80vh;overflow:auto}
.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px}

#imgPreview,#cmPrev,#imImage{display:block;width:100%;height:auto;max-height:45vh;object-fit:contain}
.dropzone{max-width:100%}

@media (max-width: 640px){
  .modal-card{max-width:100%}
  .modal-head{padding:12px 12px}
  .modal-body{padding:12px 12px}
  .two-cols{grid-template-columns:1fr}
}
