/* /frontend/wads-list.css
   Clean full stylesheet for wads-list.html
*/

/* =========================================================
   Base palette
========================================================= */
:root{
  --bg:#0b0e14;
  --panel:#111827;
  --panel-2:#0f172a;
  --border:rgba(148,163,184,.35);
  --border-soft:rgba(148,163,184,.18);
  --text:#e5e7eb;
  --muted:#9ca3af;
  --accent:#f97316;
  --accent-soft:rgba(249,115,22,.14);

  --ok:#22c55e;
  --ok-soft:rgba(34,197,94,.18);

  --danger:#ef4444;
  --danger-soft:rgba(239,68,68,.18);

  --warn:#f59e0b;
  --warn-soft:rgba(245,158,11,.16);

  --info:#60a5fa;
  --info-soft:rgba(96,165,250,.16);
}

/* =========================================================
   Page layout
========================================================= */
body.pd-dark.wads-page{
  margin:0;
  min-height:100vh;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:15px;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 0% 0%, rgba(249,115,22,.18), transparent 60%),
    radial-gradient(1000px 500px at 100% 0%, rgba(96,165,250,.20), transparent 55%),
    var(--bg);
}

.wads-page .container{
  width:min(2200px, calc(100vw - 28px));
  max-width:none;
  margin:80px auto 40px;
  padding:0 0 32px;
}

/* =========================================================
   Header card
========================================================= */
.wads-page .card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px 18px 20px;
  box-shadow:0 18px 45px rgba(15,23,42,.65);
}

.wads-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.wads-title-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.wads-upload-btn{
  white-space:nowrap;
}

.wads-page .wads-container h1{
  margin:0 0 4px;
  font-size:22px;
  display:flex;
  align-items:center;
  gap:8px;
}

.wads-page .wads-container p,
.wads-subtitle{
  margin:6px 0 12px;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}

/* =========================================================
   Inputs / buttons
========================================================= */
.wads-page .filters{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  align-items:center;
}

.wads-page .filters .pd-input{
  min-width:180px;
}

.wads-page .pd-input{
  height:40px;
  padding:0 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#020617;
  color:var(--text);
  outline:none;
  font-size:14px;
}

.wads-page .pd-input::placeholder{
  color:var(--muted);
}

.wads-page .pd-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 2px var(--accent-soft);
}

.wads-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid transparent;
  background:#111827;
  color:var(--text);
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:background .15s, border-color .15s, transform .08s, box-shadow .15s;
}

.wads-page .btn:hover{
  background:#1f2937;
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(0,0,0,.35);
}

.wads-page .btn-secondary{
  background:#020617;
  border-color:var(--border);
}

.wads-page .btn-danger{
  background:rgba(239,68,68,.14);
  border:1px solid rgba(239,68,68,.35);
}

.wads-page .btn-danger:hover{
  background:rgba(239,68,68,.22);
  border-color:rgba(239,68,68,.55);
}

/* =========================================================
   Legend
========================================================= */
.legend{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(148,163,184,.18);
  color:var(--muted);
  font-size:12px;
}

.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.legend-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(148,163,184,.25);
  box-shadow:0 0 0 1px rgba(255,255,255,.10) inset;
}

.legend-dot.ban{
  background:rgba(239,68,68,.55);
  box-shadow:0 0 0 1px rgba(239,68,68,.35) inset, 0 0 14px rgba(239,68,68,.25);
}

.legend-dot.live{
  background:rgba(34,197,94,.60);
  box-shadow:0 0 0 1px rgba(34,197,94,.35) inset, 0 0 14px rgba(34,197,94,.18);
}

.legend-dot.lock{
  background:rgba(249,115,22,.60);
  box-shadow:0 0 0 1px rgba(249,115,22,.35) inset, 0 0 14px rgba(249,115,22,.20);
}

.legend-dot.host{
  background:rgba(245,158,11,.60);
  box-shadow:0 0 0 1px rgba(245,158,11,.35) inset, 0 0 14px rgba(245,158,11,.18);
}

.legend-dot.st{
  background:rgba(96,165,250,.60);
  box-shadow:0 0 0 1px rgba(96,165,250,.35) inset, 0 0 14px rgba(96,165,250,.18);
}

/* =========================================================
   Table wrapper
========================================================= */
.wads-page .table-wrapper{
  margin-top:1rem;
  width:100%;
  border-radius:10px;
  border:1px solid var(--border);
  background:#020617;
  overflow:auto;
}

/* =========================================================
   Table
========================================================= */
.wads-page .pd-table{
  width:100%;
  table-layout:fixed;
  border-collapse:collapse;
  font-size:13px;
}

.wads-page .pd-table thead{
  background:#020617;
}

.wads-page .pd-table th,
.wads-page .pd-table td{
  padding:8px 10px;
  border-bottom:1px solid rgba(30,64,175,.55);
  text-align:left;
  vertical-align:top;
}

.wads-page .pd-table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.03em;
  color:var(--muted);
}

.wads-page .pd-table td{
  white-space:nowrap;
}

.wads-page .pd-table tbody tr:nth-child(even){
  background:rgba(15,23,42,.65);
}

.wads-page .pd-table tbody tr:hover{
  background:rgba(30,64,175,.45);
}

/* Column sizing */
#wadsTable th.col-actions,
#wadsTable td.col-actions{
  width:156px;
  text-align:center;
}

#wadsTable th.col-flags,
#wadsTable td.col-flags{
  width:180px;
  text-align:center;
}

#wadsTable th.col-md5,
#wadsTable td.col-md5{
  width:300px;
}

#wadsTable th.col-size,
#wadsTable td.col-size{
  width:110px;
}

#wadsTable th.col-uploader,
#wadsTable td.col-uploader{
  width:150px;
}

#wadsTable th.col-date,
#wadsTable td.col-date{
  width:180px;
}

#wadsTable th.col-status,
#wadsTable td.col-status{
  width:92px;
  text-align:center;
}

#wadsTable th.col-reason,
#wadsTable td.col-reason{
  width:520px;
}

#wadsTable td.col-name{
  min-width:280px;
  max-width:280px;
  white-space:normal;
  word-break:break-word;
}

#wadsTable td.col-reason{
  white-space:pre-wrap;
  word-break:break-word;
  overflow:visible;
  text-overflow:clip;
}

/* =========================================================
   Text helpers
========================================================= */
.wads-page .mono{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:12px;
  color:#cbd5e1;
}

.wads-page a.file-link{
  color:#93c5fd;
  text-decoration:none;
}

.wads-page a.file-link:hover{
  text-decoration:underline;
}

.wads-page .file-link.is-disabled{
  color:rgba(226,232,240,.55);
  cursor:not-allowed;
  text-decoration:none;
}

.wads-page .uploader-link{
  color:#7dd3fc;
  font-weight:700;
  text-decoration:none;
}

.wads-page .uploader-link:hover{
  color:#bae6fd;
  text-decoration:underline;
}

/* =========================================================
   Status badges
========================================================= */
.wads-page .badge-ban{
  display:inline-block;
  padding:3px 7px;
  border-radius:999px;
  background:var(--danger-soft);
  color:#fecaca;
  font-size:11px;
  border:1px solid rgba(248,113,113,.6);
}

.wads-page .badge-ok{
  display:inline-block;
  padding:3px 7px;
  border-radius:999px;
  background:var(--ok-soft);
  color:#bbf7d0;
  font-size:11px;
  border:1px solid rgba(34,197,94,.55);
}

/* =========================================================
   Row highlights
========================================================= */
.wads-page tr.row-private td.col-name{
  opacity:.95;
}

.wads-page tr.row-banned{
  background:rgba(127,29,29,.20) !important;
}

/* =========================================================
   Action buttons
   Same style as upload.html
========================================================= */
.wads-page .wad-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
  flex-wrap:nowrap;
}

.wads-page .icon-btn{
  width:34px;
  height:34px;
  border-radius:11px;
  border:1px solid rgba(148,163,184,.22);
  background:rgba(15,23,42,.45);
  color:#e5e7eb;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  flex:0 0 auto;
  transition:
    transform .12s ease,
    border-color .12s ease,
    box-shadow .12s ease,
    background .12s ease,
    opacity .12s ease;
}

.wads-page .icon-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(0,0,0,.35);
  border-color:rgba(148,163,184,.55);
  background:rgba(2,6,23,.48);
}

.wads-page .icon-btn:active{
  transform:translateY(0);
}

.wads-page .icon-btn.is-disabled,
.wads-page .icon-btn:disabled{
  opacity:.35;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}

.wads-page .icon-btn i{
  font-size:28px;
  line-height:1;
}

.wads-page .icon-btn-info{
  border-color:rgba(96,165,250,.60);
  background:rgba(59,130,246,.12);
  color:#bfdbfe;
  box-shadow:0 0 0 1px rgba(59,130,246,.14) inset;
}

.wads-page .icon-btn-download{
  border-color:rgba(34,197,94,.60);
  background:rgba(34,197,94,.12);
  color:#bbf7d0;
  box-shadow:0 0 0 1px rgba(34,197,94,.14) inset;
}

.wads-page .icon-btn-delete{
  border-color:rgba(244,63,94,.65);
  background:rgba(244,63,94,.12);
  color:#fecdd3;
  box-shadow:0 0 0 1px rgba(244,63,94,.14) inset;
}

.wads-page .icon-btn-info:hover{
  border-color:rgba(96,165,250,.82);
  background:rgba(59,130,246,.18);
  box-shadow:
    0 10px 22px rgba(0,0,0,.35),
    0 0 0 1px rgba(59,130,246,.16) inset;
}

.wads-page .icon-btn-download:hover{
  border-color:rgba(34,197,94,.82);
  background:rgba(34,197,94,.18);
  box-shadow:
    0 10px 22px rgba(0,0,0,.35),
    0 0 0 1px rgba(34,197,94,.16) inset;
}

.wads-page .icon-btn-delete:hover{
  border-color:rgba(244,63,94,.82);
  background:rgba(244,63,94,.18);
  box-shadow:
    0 10px 22px rgba(0,0,0,.35),
    0 0 0 1px rgba(244,63,94,.16) inset;
}

/* =========================================================
   Round flags
========================================================= */
.wads-page .wad-flags{
  display:flex;
  justify-content:center;
  gap:6px;
}

.wads-page .wad-flag{
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.18);
  background:rgba(2,6,23,.55);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(148,163,184,.55);
  transition:
    transform .12s ease,
    filter .12s ease,
    box-shadow .12s ease,
    opacity .12s ease,
    border-color .12s ease,
    color .12s ease;
}

.wads-page .wad-flag i{
  font-size:18px;
  line-height:1;
}

.wads-page .wad-flag.is-off{
  opacity:.25;
}

.wads-page .wad-flag.is-on{
  opacity:1;
  color:#fff;
  border-color:rgba(255,255,255,.10);
}

.wads-page .wad-flag:hover{
  transform:translateY(-1px);
  filter:brightness(1.05);
}

.wads-page .wad-flag.flag-ban.is-on{
  background:rgba(239,68,68,.16);
  box-shadow:0 0 0 1px rgba(239,68,68,.20) inset, 0 0 18px rgba(239,68,68,.22);
  color:#fecaca;
}

.wads-page .wad-flag.flag-lock.is-on{
  background:rgba(249,115,22,.16);
  box-shadow:0 0 0 1px rgba(249,115,22,.20) inset, 0 0 18px rgba(249,115,22,.18);
  color:#fed7aa;
}

.wads-page .wad-flag.flag-host.is-on{
  background:rgba(245,158,11,.16);
  box-shadow:0 0 0 1px rgba(245,158,11,.20) inset, 0 0 18px rgba(245,158,11,.16);
  color:#fde68a;
}

.wads-page .wad-flag.flag-st.is-on{
  background:rgba(96,165,250,.16);
  box-shadow:0 0 0 1px rgba(96,165,250,.20) inset, 0 0 18px rgba(96,165,250,.16);
  color:#bfdbfe;
}

.wads-page .wad-flag.flag-live.is-on{
  background:rgba(34,197,94,.18);
  border-color:rgba(34,197,94,.35);
  box-shadow:0 0 0 1px rgba(34,197,94,.25) inset, 0 0 18px rgba(34,197,94,.20);
  color:#bbf7d0;
}

/* =========================================================
   Modal
========================================================= */
.wad-modal{
  position:fixed;
  inset:0;
  z-index:3000;
}

.wad-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,.72);
  backdrop-filter:blur(4px);
}

.wad-modal-card{
  position:relative;
  width:min(94vw, 720px);
  margin:7vh auto 0;
  background:#111827;
  border:1px solid rgba(148,163,184,.25);
  border-radius:16px;
  box-shadow:0 24px 70px rgba(0,0,0,.45);
  color:#e5e7eb;
  overflow:hidden;
}

.wad-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding:16px 18px;
  border-bottom:1px solid rgba(148,163,184,.18);
}

.wad-modal-head-left h3{
  margin:0;
  font-size:18px;
}

.wad-modal-filename{
  margin-top:6px;
  font-weight:800;
  color:#f8fafc;
  word-break:break-all;
}

.wad-modal-close{
  background:none;
  border:0;
  color:#cbd5e1;
  font-size:20px;
  cursor:pointer;
}

.wad-modal-body{
  padding:18px;
  display:grid;
  gap:14px;
}

.wad-info-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}

.wad-info-item{
  padding:12px 14px;
  border:1px solid rgba(148,163,184,.18);
  border-radius:12px;
  background:rgba(15,23,42,.65);
}

.wad-info-item .k{
  font-size:12px;
  color:#9ca3af;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.wad-info-item .v{
  margin-top:6px;
  font-size:14px;
  color:#e5e7eb;
  word-break:break-word;
}

.wad-modal-section{
  padding:12px 14px;
  border:1px solid rgba(148,163,184,.18);
  border-radius:12px;
  background:rgba(15,23,42,.45);
}

.wad-modal-section-title{
  font-size:13px;
  font-weight:800;
  color:#f8fafc;
  margin-bottom:8px;
}

.wad-flags-hint{
  font-size:12px;
  color:#94a3b8;
  margin-bottom:10px;
}

.wad-toggle{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  padding:12px;
  border:1px solid rgba(148,163,184,.16);
  border-radius:12px;
  background:rgba(2,6,23,.35);
  margin-top:10px;
}

.wad-toggle .txt{
  flex:1 1 auto;
  min-width:0;
  text-align:left;
}

.wad-toggle .txt .title{
  display:block;
  margin:0;
  font-weight:800;
  color:#e5e7eb;
}

.wad-toggle .txt .sub{
  display:block;
  margin-top:3px;
  font-size:12px;
  color:#94a3b8;
}

.wad-toggle .switch{
  position:relative;
  width:46px;
  height:26px;
  flex:0 0 auto;
}

.wad-toggle .switch input{
  opacity:0;
  width:0;
  height:0;
  position:absolute;
}

.wad-toggle .switch .slider{
  position:absolute;
  inset:0;
  border-radius:999px;
  background:rgba(148,163,184,.22);
  border:1px solid rgba(148,163,184,.22);
  transition:all .15s ease;
}

.wad-toggle .switch .slider::before{
  content:"";
  position:absolute;
  width:20px;
  height:20px;
  left:3px;
  top:50%;
  transform:translateY(-50%);
  border-radius:999px;
  background:#e5e7eb;
  transition:all .15s ease;
  box-shadow:0 8px 16px rgba(0,0,0,.35);
}

.wad-toggle .switch input:checked + .slider{
  background:rgba(249,115,22,.35);
  border-color:rgba(249,115,22,.35);
}

.wad-toggle .switch input:checked + .slider::before{
  transform:translate(20px, -50%);
}

.wad-toggle .switch input:disabled + .slider{
  opacity:.55;
  cursor:not-allowed;
}

.wad-modal-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  padding:16px 18px;
  border-top:1px solid rgba(148,163,184,.18);
  flex-wrap:wrap;
}

/* =========================================================
   Pagination
========================================================= */
.pager{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.pager-info{
  font-size:12px;
  color:var(--muted);
}

.pager-controls{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}

.pager-btn{
  height:30px;
  min-width:30px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid var(--border);
  background:rgba(249,115,22,.12);
  color:var(--text);
  cursor:pointer;
  user-select:none;
}

.pager-btn:hover{
  background:rgba(249,115,22,.22);
}

.pager-btn.active{
  background:var(--accent);
  color:#0b0e14;
  font-weight:700;
}

.pager-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}

.pager-ellipsis{
  padding:0 6px;
  color:var(--muted);
}

/* =========================================================
   Responsive
========================================================= */
@media (max-width:1200px){
  .wads-page .container{
    width:min(100vw - 20px, 1600px);
    margin-top:70px;
  }

  .wads-page .filters{
    flex-direction:column;
    align-items:stretch;
  }

  .wads-page .filters .pd-input,
  .wads-page .filters .btn{
    width:100%;
  }
}

@media (max-width:1100px){
  #wadsTable th.col-md5,
  #wadsTable td.col-md5{
    display:none;
  }
}

@media (max-width:900px){
  #wadsTable th.col-reason,
  #wadsTable td.col-reason{
    display:none;
  }

  #wadsTable td.col-name{
    min-width:220px;
    max-width:220px;
  }
}

@media (max-width:780px){
  #wadsTable th.col-uploader,
  #wadsTable td.col-uploader{
    width:120px;
  }

  #wadsTable th.col-date,
  #wadsTable td.col-date{
    width:150px;
  }

  #wadsTable th.col-reason,
  #wadsTable td.col-reason{
    width:240px;
  }
}

@media (max-width:640px){
  .wad-info-grid{
    grid-template-columns:1fr;
  }

  .wads-title-row{
    align-items:stretch;
  }

  .wads-title-actions{
    width:100%;
  }

  .wads-title-actions .btn{
    flex:1 1 auto;
  }
}