/* ===================== /static/style.css ===================== */
:root{
  --bg: #0b0f19;
  --bg-2:#11162a;
  --card:#161b31;
  --text:#e6ecff;
  --muted:#a9b2d9;
  --brand:#7c5cff;
  --brand-2:#22d3ee;
  --accent:#ff7ab6;
  --success:#22c55e;
  --warn:#f59e0b;
  --error:#ef4444;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font:16px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial;
  color:var(--text); background:
    radial-gradient(1200px 600px at 10% -10%, rgba(124,92,255,.25), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(34,211,238,.18), transparent 60%), var(--bg);
}
.container{max-width:1040px; margin:0 auto; padding:24px}
.card{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
  border:1px solid rgba(255,255,255,.06); border-radius:var(--radius); box-shadow:var(--shadow)}
.btn{display:inline-flex; align-items:center; gap:.6rem; border:none; border-radius:999px; padding:.9rem 1.1rem; font-weight:700; cursor:pointer; background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#0b0f19; transition:transform .15s ease, filter .15s}
.btn:hover{transform:translateY(-1px); filter:saturate(1.2)}
.btn:focus-visible{outline:3px solid var(--brand-2); outline-offset:2px}
.btn.secondary{background:#1e243f; color:var(--text); border:1px solid rgba(255,255,255,.08)}
.icon{width:20px; height:20px}
.logo{display:flex; gap:.6rem; align-items:center; font-weight:800; letter-spacing:.3px; color:var(--text); text-decoration:none}
.logo .dot{width:10px; height:10px; border-radius:50%; background:linear-gradient(135deg, var(--accent), var(--brand-2))}
.nav{display:flex; justify-content:space-between; align-items:center; padding:18px 24px}
.footer{opacity:.7; font-size:.9rem; text-align:center; padding:24px}

/* Auth screen */
.auth-wrap{display:grid; min-height:100vh; grid-template-columns:1.2fr 1fr}
.auth-hero{position:relative; padding:64px}
.hero-blob{position:absolute; inset:auto -100px -120px auto; width:420px; height:420px; filter:blur(40px); background:radial-gradient(circle at 40% 40%, var(--brand), transparent 60%), radial-gradient(circle at 60% 60%, var(--accent), transparent 60%); opacity:.5}
.auth-panel{display:flex; align-items:center; justify-content:center; padding:40px}
.auth-card{width:min(520px, 96%); padding:32px}
.oauth-btn{background:#fff; color:#111;}
.oauth-btn .g{background:#fff; border-radius:3px; padding:2px}
.tip{color:var(--muted); font-size:.95rem}

/* Upload screen */
.header{position:sticky; top:0; backdrop-filter:saturate(140%) blur(8px); background:rgba(11,15,25,.6); border-bottom:1px solid rgba(255,255,255,.06); z-index:50}
.grid{display:grid; gap:20px}
.grid-2{grid-template-columns:2fr 1fr}
.upload-card{padding:24px}
.dropzone{position:relative; border:2px dashed rgba(255,255,255,.18); border-radius:var(--radius); padding:32px; text-align:center; transition:border-color .2s}
.dropzone.drag{border-color:var(--brand-2)}
.badge{display:inline-flex; align-items:center; padding:.35rem .6rem; border:1px solid rgba(255,255,255,.12); border-radius:999px; gap:.35rem; color:var(--muted); font-size:.85rem}
.progress{height:10px; background:#0f162f; border-radius:999px; overflow:hidden}
.progress > div{height:100%; width:0%; background:linear-gradient(90deg, var(--brand), var(--brand-2)); transition:width .3s ease}
.preview{display:flex; align-items:center; gap:12px; padding:10px 12px; background:#11162a; border-radius:12px; border:1px solid rgba(255,255,255,.06)}

/* Jobs list */
.filters{display:flex; flex-wrap:wrap; gap:10px}
.input{background:#101733; border:1px solid rgba(255,255,255,.10); color:var(--text); padding:.75rem 1rem; border-radius:12px}
.select{appearance:none; background:#101733; border:1px solid rgba(255,255,255,.10); color:var(--text); padding:.75rem 2.2rem .75rem 1rem; border-radius:12px; background-image:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"white\"><path d=\"M7 10l5 5 5-5z\"/></svg>'); background-repeat:no-repeat; background-position:right .6rem center}
.table{width:100%; border-collapse:separate; border-spacing:0 10px}
.table th{font-size:.9rem; color:var(--muted); text-align:left; padding:10px}
.table td{background:#0f1630; border:1px solid rgba(255,255,255,.06); padding:14px; vertical-align:middle}
.table tr td:first-child{border-top-left-radius:12px; border-bottom-left-radius:12px}
.table tr td:last-child{border-top-right-radius:12px; border-bottom-right-radius:12px}
.tags{display:flex; gap:6px; flex-wrap:wrap}
.tag{padding:.3rem .5rem; background:#152046; border:1px solid rgba(255,255,255,.08); border-radius:999px; font-size:.8rem; color:var(--muted)}
.pagination{display:flex; align-items:center; gap:8px}
.page-btn{background:#111a38; border:1px solid rgba(255,255,255,.12); color:var(--text); padding:.55rem .8rem; border-radius:10px; cursor:pointer}
.page-btn[disabled]{opacity:.4; pointer-events:none}
.active-page{background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#0b0f19; border:none}

/* Job management styles */
.job-item {
  padding: 16px !important;
}

.job-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8px;
}

.job-title {
  font-size: 16px;
  color: #333;
  margin: 0;
}

.job-date {
  font-size: 12px;
  color: #888;
  white-space: nowrap;
}

.job-description {
  line-height: 1.4;
  word-break: break-word;
}

.job-actions {
  border-top: 1px solid #eee;
  padding-top: 12px;
  margin-top: 12px;
}

.job-actions .btn {
  font-size: 13px;
  padding: 6px 12px;
  min-height: auto;
}

.cancel-edit {
  background: #6c757d !important;
  color: white !important;
}

.cancel-edit:hover {
  background: #5a6268 !important;
}

/* Form enhancements */
.card h3 {
  color: #333;
  font-weight: 600;
}

@media (max-width: 960px){
  .auth-wrap{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .nav{flex-wrap:wrap; gap:12px}
}

@media (prefers-reduced-motion: reduce){
  .btn{transition:none}
}

/* A11y helpers */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Responsive adjustments */
@media (max-width: 768px) {
  .job-header {
    flex-direction: column;
    gap: 4px;
  }
  
  .job-actions {
    flex-direction: column;
  }
  
  .job-actions .btn {
    margin-bottom: 4px;
  }
}

/* Candidates page styles */
.candidates-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 16px;
}

.candidates-table th,
.candidates-table td {
  padding: 12px;
  text-align: left;
  border-bottom: 1px solid #eee;
}

.candidates-table th {
  background: #101733;
  font-weight: 600;
  color: var(--muted);
  font-size: 14px;
}

.candidates-table td {
  font-size: 14px;
}

.candidates-table tbody tr {
  background: #101733;
  transition: background-color 0.2s ease;
}

.candidates-table tbody tr:nth-child(even) {
  background: #0f1630;
}

.candidates-table tbody tr:hover {
  background: #152046;
  cursor: pointer;
}

.table-container {
  overflow-x: auto;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.06);
}

.empty-state h3 {
  color: #666;
  margin-bottom: 8px;
}

.empty-state p {
  color: #888;
  line-height: 1.5;
}

.filters-container select {
  min-width: 140px;
}

/* Navigation improvements */
.nav-links {
  display: flex;
  gap: 16px;
  align-items: center;
}

.nav-link {
  color: #666;
  text-decoration: none;
  font-size: 14px;
  transition: color 0.2s;
}

.nav-link:hover {
  color: #333;
}

@media (max-width: 768px) {
  .candidates-table th,
  .candidates-table td {
    padding: 8px;
    font-size: 13px;
  }
  
  .filters-container {
    flex-direction: column;
    gap: 8px !important;
    align-items: stretch !important;
  }
  
  .filters-container select {
    width: 100%;
  }
}
