/* ============================================================
   Shortcuts — visual neon / glass
   ============================================================ */
:root{
  --bg:#070711;
  --bg-2:#0c0c1d;
  --card:rgba(22,22,42,.55);
  --card-brd:rgba(130,140,255,.14);
  --txt:#eaeaf7;
  --txt-dim:#9aa0c4;
  --txt-faint:#646a93;
  --cyan:#19e6ff;
  --violet:#9b5cff;
  --pink:#ff3da6;
  --glow:0 0 22px rgba(25,230,255,.45);
  --radius:18px;
  --ring:rgba(25,230,255,.55);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  color:var(--txt);
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(155,92,255,.18), transparent 60%),
    radial-gradient(900px 600px at -5% 10%, rgba(25,230,255,.14), transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg-2));
  min-height:100vh;
  padding:32px clamp(16px,5vw,56px) 80px;
  overflow-x:hidden;
}

/* orbs flutuantes de fundo */
.bg-orbs{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;animation:float 18s ease-in-out infinite}
.orb-1{width:340px;height:340px;background:var(--violet);top:-80px;right:8%}
.orb-2{width:280px;height:280px;background:var(--cyan);bottom:-60px;left:-40px;animation-delay:-6s}
.orb-3{width:220px;height:220px;background:var(--pink);top:40%;left:55%;opacity:.32;animation-delay:-11s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-26px,32px) scale(1.08)}}

/* ---------- topo ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;max-width:1180px;margin:0 auto 26px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  font-size:30px;line-height:1;display:grid;place-items:center;
  width:54px;height:54px;border-radius:15px;
  background:linear-gradient(145deg,rgba(25,230,255,.18),rgba(155,92,255,.18));
  border:1px solid var(--card-brd);
  box-shadow:var(--glow),inset 0 0 18px rgba(155,92,255,.15);
  animation:pulse 3.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 18px rgba(25,230,255,.35),inset 0 0 18px rgba(155,92,255,.15)}50%{box-shadow:0 0 30px rgba(25,230,255,.6),inset 0 0 22px rgba(155,92,255,.28)}}
.brand-text h1{
  font-size:30px;font-weight:700;letter-spacing:.5px;
  background:linear-gradient(92deg,#fff,var(--cyan) 55%,var(--violet));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.brand-text p{color:var(--txt-dim);font-size:13.5px;margin-top:2px}

/* ---------- botões ---------- */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  font-family:inherit;font-size:15px;font-weight:600;color:#06121a;
  padding:12px 20px;border:none;border-radius:13px;
  background:linear-gradient(120deg,var(--cyan),var(--violet));
  box-shadow:0 6px 22px rgba(25,230,255,.32);
  transition:transform .15s, box-shadow .2s, filter .2s;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(155,92,255,.5);filter:brightness(1.08)}
.btn-primary:active{transform:translateY(0)}
.btn-primary .plus{font-size:20px;line-height:0;margin-top:-2px}
.btn-ghost{
  cursor:pointer;font-family:inherit;font-size:15px;font-weight:500;color:var(--txt-dim);
  padding:12px 18px;border-radius:13px;border:1px solid var(--card-brd);background:transparent;
  transition:.18s;
}
.btn-ghost:hover{color:var(--txt);border-color:var(--ring);background:rgba(255,255,255,.03)}

/* ---------- toolbar ---------- */
.toolbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;max-width:1180px;margin:0 auto 18px}
.search-wrap{position:relative;flex:1;min-width:260px;display:flex;align-items:center}
.search-ico{position:absolute;left:16px;width:19px;height:19px;color:var(--txt-faint);pointer-events:none}
#search{
  width:100%;font-family:inherit;font-size:15px;color:var(--txt);
  padding:14px 44px 14px 46px;border-radius:14px;
  background:var(--card);border:1px solid var(--card-brd);
  backdrop-filter:blur(12px);transition:.2s;
}
#search::placeholder{color:var(--txt-faint)}
#search:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 4px rgba(25,230,255,.1)}
.kbd-hint{
  position:absolute;right:14px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--txt-faint);
  width:22px;height:22px;display:grid;place-items:center;border-radius:6px;border:1px solid var(--card-brd);
}
.sort-wrap{display:flex;align-items:center;gap:9px}
.sort-wrap label{font-size:13px;color:var(--txt-dim)}
#sort{
  font-family:inherit;font-size:14px;color:var(--txt);cursor:pointer;
  padding:13px 14px;border-radius:13px;background:var(--card);border:1px solid var(--card-brd);
  backdrop-filter:blur(12px);transition:.2s;
}
#sort:focus{outline:none;border-color:var(--ring)}
#sort option{background:#12122a;color:var(--txt)}

/* ---------- topo: ações + sair ---------- */
.topbar-actions{display:flex;align-items:center;gap:10px}
.logout{
  display:grid;place-items:center;width:46px;height:46px;border-radius:12px;flex-shrink:0;
  color:var(--txt-dim);border:1px solid var(--card-brd);background:var(--card);
  text-decoration:none;font-size:19px;backdrop-filter:blur(10px);transition:.16s;
}
.logout:hover{color:var(--pink);border-color:var(--pink);box-shadow:0 0 16px rgba(255,61,166,.3)}

/* ---------- tela de login ---------- */
.login-wrap{min-height:78vh;display:grid;place-items:center;padding:20px}
.login-card{
  width:100%;max-width:380px;padding:40px 32px;border-radius:26px;text-align:center;
  background:linear-gradient(180deg,rgba(20,20,40,.92),rgba(12,12,28,.92));
  border:1px solid var(--card-brd);box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 50px rgba(155,92,255,.14);
  backdrop-filter:blur(16px);animation:pop .35s cubic-bezier(.2,.9,.3,1.3);
}
.login-card .brand-mark{margin:0 auto 18px}
.login-card h1{
  font-size:28px;font-weight:700;letter-spacing:.5px;
  background:linear-gradient(92deg,#fff,var(--cyan) 55%,var(--violet));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.login-card p{color:var(--txt-dim);font-size:14px;margin:8px 0 24px}
.login-card input{
  width:100%;text-align:center;font-size:20px;letter-spacing:6px;color:var(--txt);
  padding:15px;border-radius:14px;background:rgba(8,8,22,.6);border:1px solid var(--card-brd);
  transition:.18s;margin-bottom:16px;
}
.login-card input::placeholder{letter-spacing:6px;color:var(--txt-faint)}
.login-card input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 4px rgba(25,230,255,.12)}
.login-card .btn-primary{width:100%;justify-content:center;font-size:16px;padding:14px}
.login-err{color:var(--pink);font-size:13px;margin:-6px 0 16px}

/* ---------- grid de cards ---------- */
.grid{
  display:grid;gap:16px;max-width:1180px;margin:0 auto;
  grid-template-columns:repeat(auto-fill,minmax(248px,1fr));
}
.card{
  position:relative;display:flex;flex-direction:column;gap:12px;
  padding:18px;border-radius:var(--radius);cursor:pointer;
  background:var(--card);border:1px solid var(--card-brd);
  backdrop-filter:blur(14px);
  transition:transform .18s, border-color .2s, box-shadow .25s;
  animation:cardIn .4s both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.card::before{
  content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(130deg,transparent,rgba(25,230,255,.5),transparent 60%);
  -webkit-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;pointer-events:none;
}
.card:hover{transform:translateY(-4px);border-color:transparent;box-shadow:0 14px 40px rgba(8,8,25,.7),0 0 30px rgba(25,230,255,.12)}
.card:hover::before{opacity:1}
.card.dragging{opacity:.45;transform:scale(.97)}
.card.drag-over{border-color:var(--ring);box-shadow:0 0 0 2px var(--ring)}

.card-top{display:flex;align-items:center;gap:12px}
.fav{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(145deg,rgba(155,92,255,.22),rgba(25,230,255,.12));
  border:1px solid var(--card-brd);font-size:19px;font-weight:700;color:#fff;
}
.fav img{width:100%;height:100%;object-fit:cover}
.card-head{min-width:0;flex:1}
.card-title{font-size:16px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-host{font-size:12.5px;color:var(--txt-faint);font-family:'JetBrains Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-note{font-size:13px;color:var(--txt-dim);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.card-meta{display:flex;align-items:center;gap:8px;margin-top:auto;flex-wrap:wrap}
.pass-copy{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-family:inherit;
  color:var(--violet);background:rgba(155,92,255,.12);padding:4px 11px;border-radius:99px;
  border:1px solid rgba(155,92,255,.3);transition:.15s;
}
.pass-copy:hover{color:#fff;border-color:var(--violet);box-shadow:0 0 14px rgba(155,92,255,.4)}
.pass-dots{letter-spacing:2px;font-size:14px;line-height:1}
.pass-ico{font-size:12px}
.uses{font-size:11px;color:var(--txt-faint);display:flex;align-items:center;gap:4px;margin-left:auto}

/* ações no hover */
.card-actions{position:absolute;top:12px;right:12px;display:flex;gap:6px;opacity:0;transform:translateY(-4px);transition:.18s}
.card:hover .card-actions{opacity:1;transform:translateY(0)}
.icon-btn{
  width:30px;height:30px;display:grid;place-items:center;cursor:pointer;border-radius:9px;
  background:rgba(8,8,22,.7);border:1px solid var(--card-brd);color:var(--txt-dim);
  font-size:14px;transition:.15s;backdrop-filter:blur(6px);
}
.icon-btn:hover{color:#fff;border-color:var(--ring);transform:scale(1.08)}
.icon-btn.danger:hover{color:var(--pink);border-color:var(--pink)}
.icon-btn.pinned{color:var(--cyan);border-color:rgba(25,230,255,.4)}
.card.is-pinned{border-color:rgba(25,230,255,.3)}
.pin-flag{position:absolute;top:0;left:18px;font-size:11px;color:var(--cyan);background:var(--bg-2);padding:2px 8px;border-radius:0 0 8px 8px;transform:translateY(-1px)}

.drag-handle{cursor:grab;color:var(--txt-faint);font-size:15px;padding:2px 4px;user-select:none}
.drag-handle:active{cursor:grabbing}

/* ---------- empty ---------- */
.empty{text-align:center;max-width:420px;margin:60px auto;color:var(--txt-dim)}
.empty-art{font-size:64px;margin-bottom:12px;filter:drop-shadow(0 0 22px rgba(25,230,255,.4))}
.empty h2{color:var(--txt);font-size:22px;margin-bottom:6px}
.empty p{margin-bottom:22px}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:20px;
  background:rgba(4,4,12,.66);backdrop-filter:blur(6px);animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-card{
  position:relative;width:100%;max-width:480px;padding:30px;border-radius:24px;
  background:linear-gradient(180deg,rgba(20,20,40,.96),rgba(12,12,28,.96));
  border:1px solid var(--card-brd);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 50px rgba(155,92,255,.12);
  animation:pop .25s cubic-bezier(.2,.9,.3,1.3);
}
@keyframes pop{from{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-card h2{font-size:21px;margin-bottom:22px}
.modal-close{position:absolute;top:16px;right:18px;width:32px;height:32px;border-radius:10px;cursor:pointer;
  background:transparent;border:1px solid var(--card-brd);color:var(--txt-dim);font-size:20px;line-height:1;transition:.15s}
.modal-close:hover{color:#fff;border-color:var(--pink)}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field span{font-size:13px;color:var(--txt-dim);font-weight:500}
.field span em{color:var(--txt-faint);font-style:normal;font-weight:400}
.field input{
  font-family:inherit;font-size:15px;color:var(--txt);
  padding:13px 15px;border-radius:12px;background:rgba(8,8,22,.6);border:1px solid var(--card-brd);transition:.18s;
}
.field input::placeholder{color:var(--txt-faint)}
.field input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 4px rgba(25,230,255,.1)}
.pass-input{position:relative;display:flex;align-items:center}
.pass-input input{flex:1;width:100%;padding-right:46px}
.pass-eye{
  position:absolute;right:7px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;
  background:transparent;border:none;border-radius:8px;font-size:15px;opacity:.55;transition:.15s;
}
.pass-eye:hover{opacity:1;background:rgba(255,255,255,.06)}
.field-row{display:flex;gap:14px}
.field-row .field{flex:1}
.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:60;
  padding:13px 22px;border-radius:13px;font-size:14px;font-weight:500;color:var(--txt);
  background:linear-gradient(120deg,rgba(25,230,255,.16),rgba(155,92,255,.16));
  border:1px solid var(--ring);box-shadow:0 10px 30px rgba(0,0,0,.5),var(--glow);
  opacity:0;transition:.3s;pointer-events:none;backdrop-filter:blur(12px)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.hidden{display:none !important}

/* ---------- responsivo ---------- */
@media(max-width:560px){
  body{padding:22px 16px 60px}
  .field-row{flex-direction:column;gap:0}
  .brand-text h1{font-size:25px}
  .topbar{margin-bottom:20px}
}
@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}
