/* ────────────────────────────────────────────────────────────────
   Glassy dark UI with animated mesh-gradient background, juicy
   accent gradients, and snappy motion. SF / system stack.
   ──────────────────────────────────────────────────────────────── */
:root{
  --bg-0:        #07070a;
  --fg:          #f5f5f7;
  --fg-dim:      #a8a8b3;
  --fg-faint:    #6e6e7a;
  --line:        rgba(255,255,255,.08);
  --line-2:      rgba(255,255,255,.14);

  --c-blue:      #0a84ff;
  --c-violet:    #7c5cff;
  --c-pink:      #ff2d8a;
  --c-green:     #30d158;
  --c-red:       #ff453a;

  --grad-accent: linear-gradient(135deg, #5e8bff 0%, #a85cff 50%, #ff5cd0 100%);

  --card-bg:     rgba(22,22,28,.55);
  --card-border: rgba(255,255,255,.07);
  --radius:      24px;
  --shadow:      0 30px 80px -20px rgba(0,0,0,.75),
                 0 8px 24px -10px rgba(0,0,0,.45);
  --ease:        cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;}
body{
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display",
               "SF Pro Text", "Inter", "Segoe UI", system-ui, sans-serif;
  font-weight:400;
  color:var(--fg);
  background:var(--bg-0);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.012em;
  min-height:100vh;
  overflow-x:hidden;
}
pre, code{font-family:"SF Mono","JetBrains Mono",Consolas,Menlo,monospace;}

/* ── static mesh background (no animation, lightweight) ─────────── */
.bg-static{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60vmax 60vmax at 10% -10%,  rgba(94,139,255,.45),  transparent 60%),
    radial-gradient(55vmax 55vmax at 105% 10%,  rgba(168,92,255,.40),  transparent 60%),
    radial-gradient(60vmax 60vmax at 40% 115%,  rgba(255,92,208,.32),  transparent 60%),
    linear-gradient(180deg, #07070a 0%, #0a0a10 100%);
}
.bg-noise{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ── layout ──────────────────────────────────────────────────────── */
.shell{
  max-width:700px; margin:0 auto; padding:52px 28px 28px;
  display:flex; flex-direction:column; gap:20px;
}
.hero{ text-align:center; }
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 13px; font-size:12px; font-weight:600;
  color:#d4d4dc; letter-spacing:.04em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:99px;
  background:rgba(255,255,255,.04); backdrop-filter:blur(8px);
}
.badge .dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--c-green); box-shadow:0 0 0 4px rgba(48,209,88,.18);
}
.hero h1{
  font-size:44px; line-height:1.05; font-weight:800;
  margin:12px 0 10px; letter-spacing:-.035em;
  background: var(--grad-accent);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter: drop-shadow(0 6px 30px rgba(124,92,255,.25));
}
.hero .sub{
  font-size:15px; color:var(--fg-dim); line-height:1.5; margin:0;
  max-width:520px; margin-inline:auto;
}

/* ── telegram settings card ─────────────────────────────────────── */
.card-tg{ padding:20px 24px; }
.tg-head{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:16px; margin-bottom:14px;
}
.tg-title{
  margin:0 0 4px; font-size:17px; font-weight:700; letter-spacing:-.02em;
}
.tg-sub{
  margin:0; font-size:13px; color:var(--fg-dim); line-height:1.45;
  max-width:420px;
}
.tg-status{
  flex-shrink:0; font-size:11px; font-weight:600; letter-spacing:.04em;
  text-transform:uppercase; padding:5px 10px; border-radius:99px;
  border:1px solid var(--line);
}
.tg-status.off{ color:var(--fg-faint); background:rgba(255,255,255,.03); }
.tg-status.on{
  color:#9dffbb; border-color:rgba(48,209,88,.35);
  background:rgba(48,209,88,.1);
}
.tg-fields{ margin-bottom:12px; }
.tg-actions{
  display:flex; align-items:center; flex-wrap:wrap; gap:8px;
}
.tg-msg{
  font-size:12.5px; color:var(--fg-faint); margin-left:4px;
}
.tg-msg.ok{ color:#9dffbb; }
.tg-msg.err{ color:#ff8a82; }

/* ── glass card ─────────────────────────────────────────────────── */
.card{
  position:relative;
  background: rgba(18,18,24,.78);
  border:1px solid var(--card-border);
  border-radius:var(--radius);
  padding:22px 26px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card::before{   /* subtle top highlight, glass edge */
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.08) 0%, transparent 30%);
  mix-blend-mode:screen;
}
.card.hidden{display:none}
@keyframes rise{
  from{opacity:0; transform:translateY(14px) scale(.985);}
  to  {opacity:1; transform:translateY(0)    scale(1);}
}

/* ── form fields (name + icon) ──────────────────────────────────── */
.fields{
  display:flex; flex-direction:column; gap:14px; margin-bottom:16px;
}
.field{ display:flex; flex-direction:column; gap:8px; }
.label{
  font-size:13px; color:var(--fg-dim); font-weight:500;
  display:flex; align-items:center; gap:8px;
}
.label .hint{ color:var(--fg-faint); font-weight:400; font-size:12px; }
.field input[type=text]{
  width:100%; padding:13px 16px; border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  color:var(--fg); font: inherit; font-size:15px;
  outline:none; transition: border-color .2s var(--ease), background .2s var(--ease);
}
.field input[type=text]::placeholder{ color:var(--fg-faint); }
.field input[type=text],
.field input[type=password]{
  width:100%; padding:13px 16px; border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  color:var(--fg); font: inherit; font-size:15px;
  outline:none; transition: border-color .2s var(--ease), background .2s var(--ease);
  -webkit-text-fill-color:var(--fg);
  caret-color:#fff;
}
.field input[type=password]::placeholder{ color:var(--fg-faint); }
.field input[type=text]:focus,
.field input[type=password]:focus{
  border-color:rgba(124,92,255,.6);
  background:rgba(124,92,255,.06);
}
/* kill Chrome/Edge yellow autofill background */
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--fg) !important;
  -webkit-box-shadow: 0 0 0 1000px rgba(255,255,255,.04) inset !important;
  box-shadow:         0 0 0 1000px rgba(255,255,255,.04) inset !important;
  caret-color:#fff;
  transition: background-color 9999s ease-in-out 0s;
}

.icon-row{ display:flex; align-items:center; gap:14px; }
.icon-preview{
  width:64px; height:64px; flex-shrink:0;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  display:flex; align-items:center; justify-content:center;
  color:var(--fg-faint); overflow:hidden;
}
.icon-preview svg{ width:24px; height:24px; }
.icon-preview img{ width:100%; height:100%; object-fit:cover; display:block; }
.icon-actions{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.icon-meta{ font-size:12.5px; color:var(--fg-faint); }

.btn-mini{
  align-self:flex-start;
  font:inherit; font-size:13px; font-weight:500;
  padding:7px 13px; border-radius:9px; cursor:pointer;
  background:rgba(255,255,255,.07); color:var(--fg);
  border:1px solid var(--line-2);
  transition: background .2s var(--ease);
}
.btn-mini:hover{ background:rgba(255,255,255,.12); }
.btn-mini.ghost{ background:transparent; color:var(--fg-dim); }
.btn-mini.hidden{ display:none; }

/* ── drop zone ──────────────────────────────────────────────────── */
.drop{
  position:relative; cursor:pointer;
  border-radius:18px;
  padding:28px 24px; text-align:center;
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  border:1.5px dashed var(--line-2);
  transition: border-color .25s var(--ease), transform .15s var(--ease),
              background .25s var(--ease);
  overflow:hidden; isolation:isolate;
}
.drop::after{   /* gradient border on hover */
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1.5px;
  background: var(--grad-accent);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:0; transition:opacity .25s var(--ease); pointer-events:none; z-index:1;
}
.drop:hover::after{ opacity:.55; }
.drop.drag::after{  opacity:1; }
.drop.drag{ transform:scale(1.01); }

.drop-glow{
  position:absolute; left:50%; top:0; width:240px; height:240px;
  transform:translate(-50%,-50%); border-radius:50%;
  background: radial-gradient(closest-side, rgba(124,92,255,.55), transparent 70%);
  filter:blur(20px); opacity:.7; pointer-events:none; z-index:0;
  transition:opacity .35s var(--ease);
}
.drop:hover .drop-glow{ opacity:1; }

.drop-icon{
  position:relative; z-index:2;
  width:52px; height:52px; margin:0 auto 10px;
  display:flex; align-items:center; justify-content:center;
  border-radius:50%;
  background: linear-gradient(135deg, rgba(94,139,255,.22), rgba(255,92,208,.22));
  color:#fff;
  box-shadow: 0 8px 24px -8px rgba(124,92,255,.5),
              inset 0 1px 0 rgba(255,255,255,.18);
  transition: transform .25s var(--ease);
}
.drop:hover .drop-icon{ transform:translateY(-2px); }
.drop-icon svg{width:24px;height:24px;}
.drop-title{position:relative; z-index:2; font-size:17px; font-weight:600; margin-bottom:4px; letter-spacing:-.015em;}
.drop-sub{  position:relative; z-index:2; font-size:13px; color:var(--fg-dim);}

/* ── progress card ──────────────────────────────────────────────── */
.row{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  margin-bottom:20px;
}
.file-info{min-width:0;}
.file-name{
  font-size:17px; font-weight:600; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; max-width:380px;
}
.file-meta{font-size:13px; color:var(--fg-dim); margin-top:3px;}
.state-pill{
  font-size:12px; font-weight:600; padding:6px 12px; border-radius:99px;
  background:rgba(124,92,255,.18); color:#c0acff;
  text-transform:lowercase; letter-spacing:.02em;
}
.state-pill.error{background:rgba(255,69,58,.18); color:#ff8a82;}
.state-pill.done{ background:rgba(48,209,88,.18); color:#7eecae;}

.bar{
  width:100%; height:8px; border-radius:99px;
  background:rgba(255,255,255,.07); overflow:hidden;
  position:relative;
}
.bar-fill{
  height:100%; width:0%;
  background: var(--grad-accent);
  border-radius:99px;
  transition:width .55s var(--ease);
  box-shadow:0 0 24px rgba(168,92,255,.55);
  position:relative;
}
.bar-meta{
  display:flex; justify-content:space-between;
  font-size:12.5px; color:var(--fg-dim); margin-top:12px;
}

.logbox{
  margin-top:24px; border-top:1px solid var(--line); padding-top:18px;
}
.logbox summary{
  cursor:pointer; font-size:13px; color:var(--fg-dim);
  list-style:none; user-select:none;
}
.logbox summary::-webkit-details-marker{display:none}
.logbox summary::before{
  content:"›"; display:inline-block; margin-right:8px;
  transition:transform .2s var(--ease); font-size:16px;
}
.logbox[open] summary::before{transform:rotate(90deg);}
.logbox pre{
  max-height:240px; overflow:auto; margin:12px 0 0;
  background:rgba(0,0,0,.35); padding:14px 16px; border-radius:12px;
  font-size:12px; line-height:1.5; color:#c9c9d1;
  border:1px solid var(--line);
}

/* ── done card ──────────────────────────────────────────────────── */
#card-done{ text-align:center; padding:40px 32px; }
.done-ring{
  width:84px; height:84px; margin:0 auto 22px;
  border-radius:50%;
  background:
    radial-gradient(closest-side, rgba(48,209,88,.18), transparent 70%),
    linear-gradient(135deg, rgba(48,209,88,.18), rgba(94,209,156,.10));
  display:flex; align-items:center; justify-content:center;
  color:#7eecae;
  box-shadow: 0 0 0 6px rgba(48,209,88,.06),
              0 12px 40px -10px rgba(48,209,88,.5);
  animation: pop .5s var(--ease) both;
}
@keyframes pop{
  0%  {transform:scale(.6); opacity:0;}
  60% {transform:scale(1.08);}
  100%{transform:scale(1); opacity:1;}
}
.done-ring svg{width:38px; height:38px;}
#card-done h2{
  font-size:34px; font-weight:700; letter-spacing:-.03em; margin:0 0 8px;
}
#card-done .sub{color:var(--fg-dim); margin:0 0 26px; font-size:15px;}

.btn-row{display:flex; gap:10px; justify-content:center; flex-wrap:wrap;}

.btn-primary, .btn-ghost{
  font: inherit; font-weight:600; font-size:15px;
  padding:14px 28px; border-radius:14px; cursor:pointer;
  border:1px solid transparent;
  transition: transform .12s var(--ease), box-shadow .22s var(--ease),
              filter .22s var(--ease);
  text-decoration:none; display:inline-block;
}
.btn-primary{
  background: var(--grad-accent);
  color:#fff;
  box-shadow: 0 10px 30px -8px rgba(124,92,255,.55),
              inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover{ transform:translateY(-1px); filter:brightness(1.06);
  box-shadow:0 14px 36px -10px rgba(124,92,255,.7), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-primary:active{ transform:translateY(0); }

.btn-ghost{
  background:rgba(255,255,255,.04); color:#d4d4dc;
  border:1px solid var(--line-2);
}
.btn-ghost:hover{ color:#fff; background:rgba(255,255,255,.08); }

/* ── footer ─────────────────────────────────────────────────────── */
.foot{
  text-align:center; color:var(--fg-faint); font-size:12px;
  padding:16px 16px 18px; letter-spacing:.02em;
}

/* ── brand ──────────────────────────────────────────────────────── */
.brand{
  position:fixed; top:18px; left:22px; z-index:10;
  display:flex; align-items:center; gap:10px;
  font-weight:800; letter-spacing:.06em; font-size:14px;
  color:#fff; text-decoration:none;
  padding:8px 14px; border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  backdrop-filter: blur(8px);
}
.brand .brand-mark{
  width:18px; height:18px; border-radius:5px;
  background: var(--grad-accent);
  box-shadow:0 4px 14px -3px rgba(168,92,255,.6);
}
.brand .brand-text{
  background: var(--grad-accent);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ── deadpool mascot ────────────────────────────────────────────── */
.mascot{
  display:block; margin:0 auto -6px;
  width:120px; height:auto;
  filter: drop-shadow(0 14px 30px rgba(255,69,58,.35))
          drop-shadow(0 2px 6px rgba(0,0,0,.4));
  pointer-events:none; user-select:none;
}

/* ── auth ───────────────────────────────────────────────────────── */
.shell-narrow{ max-width:440px; }
.auth-card{ padding:22px 26px; }
.auth-form{ display:flex; flex-direction:column; gap:12px; }
.auth-form .field input{ padding:12px 14px; font-size:15px; }
.auth-submit{ margin-top:6px; padding:13px 28px; width:100%; }
.auth-err{
  font-size:13.5px; color:#ff8a82;
  background:rgba(255,69,58,.10);
  border:1px solid rgba(255,69,58,.25);
  padding:10px 14px; border-radius:10px;
  text-align:center;
}

.top-right{
  position:fixed; top:18px; right:20px; z-index:10;
  display:flex; align-items:center; gap:10px;
}
.logout-btn{
  font:inherit; font-size:13px; font-weight:500;
  padding:8px 14px; border-radius:10px;
  background:rgba(255,255,255,.06); color:var(--fg-dim);
  border:1px solid var(--line-2); cursor:pointer; text-decoration:none;
  transition: background .2s var(--ease), color .2s var(--ease);
}
.logout-btn:hover{ background:rgba(255,255,255,.12); color:#fff; }

.quota-pill{
  display:flex; align-items:center; gap:8px;
  padding:8px 13px; border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line-2);
  font-size:13px; color:var(--fg-dim);
}
.quota-pill .quota-icon{ display:flex; color:#c0acff; }
.quota-pill .quota-icon svg{ width:15px; height:15px; }
.quota-pill b{ color:#fff; font-weight:600; }
.quota-pill.low b{   color:#ffb86b; }
.quota-pill.empty b{ color:#ff8a82; }

@media (max-width: 520px){
  .hero h1{font-size:44px}
  .shell{padding:48px 18px 40px}
  .card{padding:24px}
}


/* -- method picker (DexShield / Casper) ------------------------- */
.method-field{ border:0; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.method-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.method-opt{ cursor:pointer; }
.method-opt input{ position:absolute; opacity:0; pointer-events:none; }
.method-card{
  display:flex; flex-direction:column; gap:3px;
  padding:12px 14px; border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  transition:border-color .15s, background .15s;
}
.method-opt:hover .method-card{ border-color:rgba(124,92,255,.4); }
.method-opt input:checked + .method-card{
  border-color:rgba(124,92,255,.7);
  background:rgba(124,92,255,.10);
}
.method-title{ font-size:14px; font-weight:600; color:var(--fg); }
.method-sub{ font-size:12px; color:var(--fg-faint); }
