:root{
  --bg:#0c0b10;
  --bg-2:#15131c;
  --panel:#191722;
  --panel-2:#211e2d;
  --line:#2e2a3d;
  --ink:#ece9f5;
  --ink-dim:#a39fb8;
  --ink-faint:#6f6a82;
  --accent:#ff4d2e;      /* hot vermilion */
  --accent-2:#ffd84d;    /* warm yellow */
  --ok:#39d98a;
  --err:#ff5d6c;
  --radius:14px;
  --mono:'Space Mono',ui-monospace,monospace;
  --sans:'Sora',system-ui,sans-serif;
  --display:'Archivo Black',var(--sans);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(255,77,46,.13), transparent 60%),
    radial-gradient(700px 500px at 0% 110%, rgba(255,216,77,.07), transparent 55%),
    var(--bg);
  color:var(--ink);
  min-height:100vh;
  display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

/* ── auth screen ── */
body.auth{align-items:center;justify-content:center}
.login-card{
  width:min(400px,92vw);
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:38px 34px;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8);
}
.login-head{text-align:center;margin-bottom:26px}
.logo-big{font-family:var(--display);font-size:42px;letter-spacing:-1px;line-height:.9}
.logo-big span{color:var(--accent)}
.tag{color:var(--ink-dim);font-size:13px;margin:10px 0 0}

/* ── topbar ── */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 26px;border-bottom:1px solid var(--line);
  background:rgba(12,11,16,.7);backdrop-filter:blur(10px);
  position:sticky;top:0;z-index:10;
}
.brand{display:flex;align-items:baseline;gap:10px}
.brand-mark{font-family:var(--display);font-size:22px;letter-spacing:-.5px}
.brand-sub{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:2px}
.nav{display:flex;align-items:center;gap:18px}
.nav a{color:var(--ink-dim);text-decoration:none;font-size:14px;font-weight:600;padding:6px 2px;border-bottom:2px solid transparent}
.nav a:hover{color:var(--ink)}
.nav a.on{color:var(--ink);border-color:var(--accent)}
.pill{background:var(--accent);color:#fff;border-radius:20px;font-size:11px;padding:1px 8px;margin-left:4px;font-family:var(--mono)}
.who{font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.inline{display:inline}
.link-btn{background:none;border:none;color:var(--ink-dim);cursor:pointer;font-size:13px;font-family:var(--sans)}
.link-btn:hover{color:var(--accent)}
.link-btn.danger:hover{color:var(--err)}

/* ── layout ── */
.wrap{flex:1;width:min(1080px,94vw);margin:0 auto;padding:34px 0}
.foot{text-align:center;color:var(--ink-faint);font-size:12px;padding:22px;border-top:1px solid var(--line);font-family:var(--mono)}

.panel{
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 32px;
}
.h1{font-family:var(--display);font-size:30px;letter-spacing:-.5px;margin:0 0 6px}
.lead{color:var(--ink-dim);font-size:15px;line-height:1.55;max-width:62ch;margin:0 0 22px}

/* ── forms ── */
.form{display:flex;flex-direction:column;gap:16px}
label{font-size:13px;font-weight:600;color:var(--ink-dim);display:flex;flex-direction:column;gap:6px}
input[type=text],input[type=password]{
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;color:var(--ink);font-size:15px;font-family:var(--sans);
}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,77,46,.15)}
.mono{font-family:var(--mono)}
small{font-weight:400;color:var(--ink-faint);font-size:12px}
.field small{margin-top:2px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:10px;padding:12px 22px;font-size:15px;font-weight:600;
  border:1px solid transparent;cursor:pointer;text-decoration:none;font-family:var(--sans);
  transition:transform .08s ease,filter .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink-dim)}
.btn-ghost:hover{color:var(--ink);border-color:var(--ink-faint)}
.btn-block{width:100%}
.btn-lg{padding:15px 28px;font-size:16px}

/* ── dropzone ── */
.dropzone{
  border:2px dashed var(--line);border-radius:var(--radius);
  padding:34px;display:flex;flex-direction:column;align-items:center;gap:10px;
  cursor:pointer;text-align:center;transition:border-color .15s,background .15s;
}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:rgba(255,77,46,.05)}
.dropzone.small{padding:20px;flex-direction:row;gap:14px}
.dz-icon{font-size:30px;color:var(--accent)}
.dropzone.small .dz-icon{font-size:22px}
.dz-text{color:var(--ink-dim);font-size:14px;font-weight:600}
.dz-file{font-family:var(--mono);font-size:13px;color:var(--accent-2)}
.upload-inline{flex-direction:row;align-items:center;gap:16px}
.upload-inline .dropzone{flex:1}

/* ── flash ── */
.flash{padding:13px 18px;border-radius:10px;margin-bottom:18px;font-size:14px;font-weight:600;border:1px solid}
.flash-ok{background:rgba(57,217,138,.12);border-color:rgba(57,217,138,.4);color:var(--ok)}
.flash-err{background:rgba(255,93,108,.12);border-color:rgba(255,93,108,.4);color:var(--err)}

/* ── mapping table ── */
.result-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.count-badge{font-family:var(--mono);font-size:12px;color:var(--accent-2);background:var(--panel-2);border:1px solid var(--line);border-radius:20px;padding:5px 12px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;margin-bottom:20px}
.map-table{width:100%;border-collapse:collapse;font-size:14px}
.map-table th{
  text-align:left;padding:12px 14px;background:var(--panel-2);
  color:var(--ink-faint);font-size:11px;text-transform:uppercase;letter-spacing:1px;
  position:sticky;top:0;
}
.map-table td{padding:11px 14px;border-top:1px solid var(--line);vertical-align:middle}
.map-table tr:hover td{background:rgba(255,255,255,.02)}
.row-warn td{background:rgba(255,216,77,.05)}
.dim{color:var(--ink-faint)}
.small{font-size:12px}
.ep{font-family:var(--display);color:var(--accent);font-size:16px}
.pkg-select{
  background:var(--bg);border:1px solid var(--line);border-radius:8px;
  padding:8px 10px;color:var(--ink);font-family:var(--mono);font-size:13px;min-width:120px;
}
.tag-warn{display:inline-block;margin-left:8px;font-size:11px;color:var(--accent-2);font-family:var(--mono)}
.actions{display:flex;gap:12px;justify-content:flex-end}

/* ── packages grid ── */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;margin-top:24px}
.pkg-card{
  background:var(--panel-2);border:1px solid var(--line);border-radius:12px;
  padding:18px 16px;text-align:center;position:relative;
}
.pkg-code{font-family:var(--display);font-size:28px;color:var(--accent)}
.pkg-name{font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin:4px 0 10px}
.empty{color:var(--ink-faint);text-align:center;padding:40px;font-style:italic}

/* ── result ── */
.result-panel{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.check{width:64px;height:64px;border-radius:50%;background:rgba(57,217,138,.15);border:2px solid var(--ok);color:var(--ok);font-size:32px;display:flex;align-items:center;justify-content:center}
.used-list{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:6px 0 10px}
.used-pill{font-family:var(--mono);font-size:12px;background:var(--panel-2);border:1px solid var(--line);border-radius:20px;padding:4px 12px;color:var(--accent-2)}

@media(max-width:640px){
  .h1{font-size:24px}
  .nav{gap:12px}
  .brand-sub{display:none}
  .upload-inline{flex-direction:column;align-items:stretch}
}

/* ── db-layer additions ── */
.note-input{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:11px 14px;color:var(--ink);font-size:14px;min-width:200px}
.pkg-meta{font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin-bottom:4px}
.pkg-note{font-size:12px;color:var(--ink-faint);margin-bottom:10px;line-height:1.3}
.user-form{margin-bottom:24px}
.user-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.user-row input[type=text],.user-row input[type=password]{flex:1;min-width:160px}
.chk{flex-direction:row;align-items:center;gap:6px;color:var(--ink-dim);font-size:13px}
.chk input{accent-color:var(--accent)}

/* ── multi-file sections ── */
.file-section{border:1px solid var(--line);border-radius:12px;margin-bottom:18px;overflow:hidden}
.file-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--panel-2);border-bottom:1px solid var(--line)}
.file-name{font-weight:600;font-size:14px}
.file-meta{font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.file-section .table-wrap{border:none;border-radius:0;margin:0}

/* ── result list ── */
.result-list{width:100%;display:flex;flex-direction:column;gap:10px;margin:10px 0 18px;text-align:left}
.result-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;background:var(--panel-2);border:1px solid var(--line);border-radius:12px}
.result-empty{opacity:.6}
.result-orig{font-weight:600;font-size:14px;margin-bottom:3px}
.result-sub{font-size:12px;color:var(--ink-dim);display:flex;gap:6px;align-items:center;flex-wrap:wrap}
