@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --bg: #0d0d1a;
  --bg-card: #13132b;
  --bg-card-hover: #1a1a3e;
  --gold: #D4AF37;
  --gold-dim: rgba(212,175,55,0.15);
  --gold-glow: rgba(212,175,55,0.3);
  --text: #e8e8f0;
  --text-dim: #8888aa;
  --border: rgba(212,175,55,0.12);
  --green: #34d399;
  --red: #f87171;
  --blue: #60a5fa;
  --orange: #fbbf24;
  --radius: 12px;
}

* { margin:0; padding:0; box-sizing:border-box; }

body {
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  line-height:1.6;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--gold-dim); border-radius:3px; }

/* ── LOGIN ── */
.login-wrapper {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(ellipse at 50% 30%, rgba(212,175,55,0.06) 0%, transparent 70%);
}

.login-box {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:20px;
  padding:48px 40px;
  width:100%;
  max-width:420px;
  text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}

.login-box .brand-icon {
  width:64px; height:64px;
  background:linear-gradient(135deg, var(--gold), #b8962e);
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 24px;
  font-size:28px; font-weight:800; color:var(--bg);
}

.login-box h1 {
  font-size:22px; font-weight:700; margin-bottom:4px;
  background:linear-gradient(135deg, var(--gold), #f0d060);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}

.login-box .subtitle { color:var(--text-dim); font-size:13px; margin-bottom:32px; }

.login-box input {
  width:100%; padding:14px 16px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text);
  font-size:14px; font-family:inherit;
  margin-bottom:12px;
  transition:border-color .2s;
  outline:none;
}

.login-box input:focus { border-color:var(--gold); }
.login-box input::placeholder { color:var(--text-dim); }

.login-box button {
  width:100%; padding:14px;
  background:linear-gradient(135deg, var(--gold), #b8962e);
  border:none; border-radius:10px;
  color:#0d0d1a; font-weight:700; font-size:15px;
  cursor:pointer; margin-top:8px;
  font-family:inherit;
  transition:transform .15s, box-shadow .15s;
}

.login-box button:hover {
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(212,175,55,0.3);
}

.login-error {
  color:var(--red); font-size:13px; margin-top:12px;
  display:none;
}

/* ── DASHBOARD LAYOUT ── */
.app { display:none; }
.app.active { display:block; }
.login-wrapper.hidden { display:none; }

header {
  padding:16px 32px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
  background:rgba(13,13,26,0.9);
  backdrop-filter:blur(20px);
  position:sticky; top:0; z-index:100;
}

.header-brand {
  display:flex; align-items:center; gap:12px;
  font-weight:700; font-size:16px;
}

.header-brand .icon {
  width:36px; height:36px;
  background:linear-gradient(135deg, var(--gold), #b8962e);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; font-weight:800; color:var(--bg);
}

.header-brand span {
  background:linear-gradient(135deg, var(--gold), #f0d060);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}

.header-right { display:flex; align-items:center; gap:16px; }

.header-right .client-name { font-size:13px; color:var(--text-dim); }

.btn-logout {
  padding:8px 16px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--text-dim);
  font-size:12px; font-family:inherit;
  cursor:pointer;
  transition:all .2s;
}

.btn-logout:hover { border-color:var(--gold); color:var(--gold); }

/* ── TABS ── */
.tabs {
  display:flex; gap:0; padding:0 32px;
  border-bottom:1px solid var(--border);
  background:rgba(13,13,26,0.5);
}

.tab {
  padding:14px 24px;
  font-size:13px; font-weight:500;
  color:var(--text-dim);
  cursor:pointer;
  border-bottom:2px solid transparent;
  transition:all .2s;
  font-family:inherit; background:none; border-top:none; border-left:none; border-right:none;
}

.tab:hover { color:var(--text); }
.tab.active { color:var(--gold); border-bottom-color:var(--gold); }

.tab-content { display:none; padding:32px; max-width:1200px; margin:0 auto; }
.tab-content.active { display:block; }

/* ── CARDS ── */
.card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px;
  margin-bottom:24px;
}

.card-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:20px;
}

.card-title { font-size:15px; font-weight:600; }
.card-badge {
  padding:4px 12px;
  background:var(--gold-dim);
  color:var(--gold);
  border-radius:20px;
  font-size:11px; font-weight:600;
}

/* ── STATS ROW ── */
.stats-row {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:16px;
  margin-bottom:24px;
}

.stat-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 24px;
  position:relative;
  overflow:hidden;
}

.stat-card::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--gold), transparent);
}

.stat-label { font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.stat-value { font-size:28px; font-weight:700; }
.stat-value.gold { color:var(--gold); }
.stat-sub { font-size:12px; color:var(--text-dim); margin-top:4px; }

/* ── SCORE CHART ── */
.score-chart {
  display:flex; gap:32px; align-items:flex-end;
  justify-content:center;
  padding:20px 0;
}

.score-group { text-align:center; }
.score-group .label { font-size:11px; color:var(--text-dim); margin-bottom:12px; text-transform:uppercase; letter-spacing:1px; }

.score-bars {
  display:flex; gap:8px; align-items:flex-end;
  justify-content:center; height:140px;
}

.score-bar {
  width:36px; border-radius:6px 6px 0 0;
  position:relative;
  transition:height .6s ease;
}

.score-bar .val {
  position:absolute; top:-22px; left:50%; transform:translateX(-50%);
  font-size:12px; font-weight:700; white-space:nowrap;
}

.score-bar.before { background:rgba(255,255,255,0.08); }
.score-bar.before .val { color:var(--text-dim); }
.score-bar.current { background:linear-gradient(to top, var(--gold), #f0d060); }
.score-bar.current .val { color:var(--gold); }
.score-bar.target { background:rgba(52,211,153,0.2); border:1px dashed var(--green); }
.score-bar.target .val { color:var(--green); }

.score-legend {
  display:flex; gap:24px; justify-content:center;
  margin-top:16px;
}

.score-legend span {
  display:flex; align-items:center; gap:6px;
  font-size:11px; color:var(--text-dim);
}

.score-legend .dot {
  width:10px; height:10px; border-radius:3px;
}

/* ── TABLE ── */
.dispute-table {
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}

.dispute-table thead th {
  text-align:left;
  padding:12px 16px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--text-dim);
  border-bottom:1px solid var(--border);
  font-weight:500;
}

.dispute-table tbody td {
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,0.03);
  vertical-align:middle;
}

.dispute-table tbody tr { transition:background .15s; }
.dispute-table tbody tr:hover { background:rgba(212,175,55,0.03); }

.status-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 10px;
  border-radius:6px;
  font-size:11px; font-weight:600;
}

.status-badge.sent { background:rgba(96,165,250,0.12); color:var(--blue); }
.status-badge.pending { background:rgba(251,191,36,0.12); color:var(--orange); }
.status-badge.removed { background:rgba(52,211,153,0.12); color:var(--green); }
.status-badge.verified { background:rgba(248,113,113,0.12); color:var(--red); }

.status-dot { width:6px; height:6px; border-radius:50%; }
.status-dot.sent { background:var(--blue); }
.status-dot.pending { background:var(--orange); }
.status-dot.removed { background:var(--green); }
.status-dot.verified { background:var(--red); }

.tracking-link {
  color:var(--text-dim);
  font-size:11px;
  font-family:'SF Mono','Fira Code',monospace;
  word-break:break-all;
}

/* ── COUNTDOWN ── */
.countdown-bar {
  display:flex; align-items:center; gap:12px;
  margin-top:4px;
}

.countdown-track {
  flex:1; height:4px;
  background:rgba(255,255,255,0.06);
  border-radius:2px;
  overflow:hidden;
}

.countdown-fill {
  height:100%; border-radius:2px;
  background:linear-gradient(90deg, var(--gold), #f0d060);
  transition:width .3s;
}

.countdown-text { font-size:11px; color:var(--text-dim); white-space:nowrap; }

/* ── PROGRESS ── */
.progress-section { margin-top:24px; }

.progress-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:10px;
}

.progress-header .label { font-size:13px; font-weight:500; }
.progress-header .value { font-size:13px; color:var(--gold); font-weight:700; }

.progress-track {
  height:10px;
  background:rgba(255,255,255,0.06);
  border-radius:5px;
  overflow:hidden;
}

.progress-fill {
  height:100%; border-radius:5px;
  background:linear-gradient(90deg, var(--gold), var(--green));
  transition:width .6s ease;
}

/* ── TIMELINE ── */
.timeline { position:relative; padding-left:32px; }

.timeline::before {
  content:'';
  position:absolute; left:11px; top:8px; bottom:8px;
  width:2px;
  background:var(--border);
}

.timeline-item {
  position:relative;
  padding:0 0 32px 24px;
}

.timeline-item:last-child { padding-bottom:0; }

.timeline-dot {
  position:absolute; left:-25px; top:4px;
  width:14px; height:14px;
  border-radius:50%;
  border:2px solid var(--border);
  background:var(--bg);
  z-index:1;
}

.timeline-item.complete .timeline-dot {
  background:var(--gold);
  border-color:var(--gold);
  box-shadow:0 0 12px var(--gold-glow);
}

.timeline-item.active .timeline-dot {
  background:var(--bg);
  border-color:var(--gold);
  box-shadow:0 0 12px var(--gold-glow);
  animation:pulse 2s infinite;
}

@keyframes pulse {
  0%,100% { box-shadow:0 0 8px var(--gold-glow); }
  50% { box-shadow:0 0 20px var(--gold-glow); }
}

.timeline-date { font-size:11px; color:var(--gold); font-weight:600; margin-bottom:4px; }
.timeline-title { font-size:14px; font-weight:600; margin-bottom:4px; }
.timeline-desc { font-size:13px; color:var(--text-dim); line-height:1.5; }

/* ── DOCUMENTS ── */
.doc-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:16px;
}

.doc-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  display:flex; align-items:center; gap:16px;
  transition:all .2s;
  cursor:pointer;
  text-decoration:none; color:inherit;
}

.doc-card:hover {
  border-color:var(--gold);
  background:var(--bg-card-hover);
  transform:translateY(-2px);
}

.doc-icon {
  width:44px; height:44px;
  background:var(--gold-dim);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex-shrink:0;
}

.doc-info .doc-name { font-size:14px; font-weight:500; }
.doc-info .doc-date { font-size:12px; color:var(--text-dim); margin-top:2px; }

/* ── FOOTER ── */
footer {
  padding:24px 32px;
  border-top:1px solid var(--border);
  text-align:center;
  font-size:11px;
  color:var(--text-dim);
  margin-top:48px;
}

footer .brand-name { color:var(--gold); font-weight:600; }

/* ── RESPONSIVE ── */
@media(max-width:768px) {
  .tabs { padding:0 16px; overflow-x:auto; }
  .tab { padding:12px 16px; white-space:nowrap; }
  .tab-content { padding:20px 16px; }
  header { padding:12px 16px; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .score-chart { flex-direction:column; align-items:center; gap:24px; }
  .dispute-table { font-size:12px; }
  .dispute-table thead th, .dispute-table tbody td { padding:10px 8px; }
  .login-box { margin:16px; padding:32px 24px; }
}

@media(max-width:480px) {
  .stats-row { grid-template-columns:1fr; }
}
