/* JobFinder - Jobspot-inspired visual layer.
   Routes and form names stay in app.py; this file only changes presentation. */

:root {
  --jf-ink: #120357;
  --jf-ink-2: #1f116f;
  --jf-muted: #706a90;
  --jf-soft-2: #eee9ff;
  --jf-line: #e8e2ff;
  --jf-orange: #ff9f3f;
  --jf-blue: #9be8f4;
  --jf-purple: #a991ff;
  --jf-shadow: 0 24px 70px rgba(31, 17, 111, 0.18);
  --jf-shadow-soft: 0 14px 34px rgba(31, 17, 111, 0.11);
  color-scheme: light;
  font-family: "Inter", "Noto Sans Hebrew", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { background: #cfc7ff; }

body {
  min-height: 100vh;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.38) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.28) 1px, transparent 1px),
    linear-gradient(135deg, #d8d0ff 0%, #c6c2ef 48%, #eef0ff 100%) !important;
  background-size: 56px 56px, 56px 56px, auto !important;
  color: var(--jf-ink) !important;
}

.shell {
  position: relative;
  overflow: hidden;
}

.shell::before {
  content: "FREE";
  position: fixed;
  inset-block-start: 0;
  left: 0;
  z-index: 0;
  display: grid;
  place-items: center;
  width: min(225px, 44vw);
  height: 98px;
  background: var(--jf-ink);
  color: #fff;
  font-size: clamp(42px, 7vw, 68px);
  font-weight: 900;
  letter-spacing: 0;
  pointer-events: none;
}

header, main, footer {
  position: relative;
  z-index: 1;
}

header {
  width: min(1180px, calc(100% - 32px)) !important;
  margin: 0 auto !important;
  padding: 24px 0 !important;
  background: transparent !important;
  border: 0 !important;
}

.brand {
  gap: 12px !important;
  color: var(--jf-ink) !important;
  font-size: 22px !important;
  font-weight: 900 !important;
}

.brand span { color: var(--jf-ink); }

.brand img {
  width: 46px !important;
  height: 46px !important;
  border-radius: 16px;
  background: var(--jf-ink);
  box-shadow: var(--jf-shadow-soft);
}

nav {
  gap: 8px !important;
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: 999px;
  background: rgba(255,255,255,0.48);
  box-shadow: var(--jf-shadow-soft);
  backdrop-filter: blur(16px);
}

nav a {
  border-radius: 999px !important;
  color: var(--jf-muted) !important;
  font-size: 14px;
  font-weight: 800 !important;
  padding: 9px 15px !important;
}

nav a:hover,
nav a.active {
  background: var(--jf-ink) !important;
  color: #fff !important;
}

main { padding-top: 18px; }

.shell:has(.app-layout)::before {
  display: none;
}

.shell:has(.app-layout) header nav {
  display: none !important;
}

.app-layout h1,
.onboarding h1,
.panel h1 {
  font-size: clamp(34px, 5vw, 58px) !important;
  line-height: 1.05 !important;
}

.hero {
  direction: ltr;
  min-height: calc(100vh - 178px);
  padding: clamp(72px, 10vw, 132px) 0 42px !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 410px) !important;
  gap: clamp(28px, 6vw, 76px) !important;
  align-items: center !important;
}

.hero > div:first-child {
  position: relative;
  direction: rtl;
  text-align: right;
  max-width: 690px;
}

.hero > div:first-child::before {
  content: "";
  display: block;
  width: 130px;
  height: 130px;
  margin-bottom: 54px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 38% 45%, #fff 0 7px, transparent 8px),
    radial-gradient(circle at 62% 45%, #fff 0 7px, transparent 8px),
    radial-gradient(ellipse at 50% 65%, #fff 0 9px, transparent 10px),
    var(--jf-ink);
  border: 22px solid #fff;
  box-shadow: var(--jf-shadow);
}

.eyebrow {
  display: inline-flex !important;
  width: fit-content;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px !important;
  padding: 7px 13px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.68) !important;
  color: var(--jf-orange) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--jf-orange);
}

h1 {
  color: #05010e !important;
  font-size: clamp(42px, 8vw, 96px) !important;
  line-height: 0.92 !important;
  letter-spacing: 0 !important;
  font-weight: 900 !important;
  margin: 0 0 22px !important;
}

h2 {
  color: var(--jf-ink) !important;
  letter-spacing: 0 !important;
}

p {
  color: var(--jf-muted) !important;
  font-size: 16px !important;
  line-height: 1.72 !important;
}

.gradient {
  display: inline-block;
  background: linear-gradient(90deg, var(--jf-ink), var(--jf-orange)) !important;
  -webkit-background-clip: text !important;
  color: transparent !important;
}

.actions { gap: 12px !important; }

.button, button {
  min-height: 44px;
  border-radius: 8px !important;
  padding: 12px 18px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease !important;
}

.button:hover, button:hover { transform: translateY(-2px); }

.primary {
  background: var(--jf-ink) !important;
  color: #fff !important;
  box-shadow: 0 16px 30px rgba(18, 3, 87, 0.24) !important;
}

.secondary, .ghost {
  background: rgba(255,255,255,0.76) !important;
  border: 1px solid rgba(255,255,255,0.9) !important;
  color: var(--jf-ink) !important;
  box-shadow: var(--jf-shadow-soft);
}

.ghost:hover, .secondary:hover {
  border-color: var(--jf-orange) !important;
  color: var(--jf-ink) !important;
}

.logo-panel {
  position: relative;
  min-height: 520px;
  place-items: center !important;
}

.logo-panel::before,
.logo-panel::after {
  content: "";
  position: absolute;
  border-radius: 28px;
  background: #fff;
  box-shadow: var(--jf-shadow);
}

.logo-panel::before {
  width: 245px;
  height: 440px;
  transform: rotate(-1deg);
}

.logo-panel::after {
  width: 175px;
  height: 118px;
  inset-block-end: 58px;
  inset-inline-start: 12px;
  background:
    linear-gradient(var(--jf-ink), var(--jf-ink)) 28px 78px / 118px 10px no-repeat,
    linear-gradient(var(--jf-orange), var(--jf-orange)) 28px 96px / 86px 10px no-repeat,
    #fff;
}

.logo-panel img {
  position: relative;
  z-index: 1;
  width: min(66%, 260px) !important;
  max-height: 260px;
  object-fit: contain;
  padding: 24px;
  border-radius: 28px;
  background: #fff;
  box-shadow: var(--jf-shadow-soft);
}

.trust, .metrics, .status, .grid, .two, .onboarding {
  gap: 18px !important;
}

.panel, .metric, .tile, .job-card, .empty-state, .trust div, .side, .loading-card {
  border: 1px solid rgba(255,255,255,0.76) !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,0.82) !important;
  box-shadow: var(--jf-shadow-soft) !important;
  color: var(--jf-ink) !important;
  backdrop-filter: blur(16px);
}

.panel, .metric, .tile, .job-card, .empty-state {
  padding: 22px !important;
}

.panel:hover, .job-card:hover, .metric:hover {
  transform: translateY(-3px);
  box-shadow: var(--jf-shadow) !important;
}

.metric span, .tile span {
  color: var(--jf-muted) !important;
  font-size: 13px !important;
  font-weight: 800;
}

.metric strong, .tile strong, .score strong {
  color: var(--jf-ink) !important;
}

.app-layout {
  grid-template-columns: 218px minmax(0, 1fr) !important;
  gap: 22px !important;
}

.side {
  top: 24px !important;
  padding: 12px !important;
}

.side a {
  border-radius: 14px !important;
  color: var(--jf-muted) !important;
  font-weight: 900 !important;
}

.side a.active,
.side a:hover {
  background: var(--jf-ink) !important;
  color: #fff !important;
}

.toolbar {
  display: grid !important;
  grid-template-columns: 1fr;
  margin-bottom: 22px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,0.76);
  border-radius: 24px;
  background: rgba(255,255,255,0.62);
  box-shadow: var(--jf-shadow-soft);
  backdrop-filter: blur(16px);
}

.toolbar .actions {
  width: 100%;
  align-items: stretch !important;
}

.toolbar .actions > form {
  min-width: 0;
}

.toolbar .actions > .search-inline {
  flex: 1 1 520px;
}

.search-inline {
  gap: 10px !important;
}

.search-inline input {
  min-width: min(420px, 100%) !important;
}

input, select {
  width: 100%;
  border: 1px solid var(--jf-line) !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: var(--jf-ink) !important;
  font-size: 15px !important;
  outline: none;
}

input:focus, select:focus {
  border-color: var(--jf-purple) !important;
  box-shadow: 0 0 0 4px rgba(169, 145, 255, 0.24) !important;
}

label {
  color: var(--jf-muted) !important;
  font-weight: 900 !important;
}

.dropzone {
  border: 2px dashed #b8a8ff !important;
  border-radius: 24px !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.94), rgba(238,233,255,0.78)) !important;
  padding: 28px !important;
  text-align: center;
}

.dropzone strong {
  color: var(--jf-ink);
  font-size: 19px;
}

input[type="file"] {
  padding: 14px !important;
  background: #fbf9ff !important;
}

.chips span, .badge {
  border: 1px solid rgba(18,3,87,0.08) !important;
  border-radius: 999px !important;
  background: var(--jf-soft-2) !important;
  color: var(--jf-ink) !important;
}

.timeline b {
  background: var(--jf-orange) !important;
  color: #fff !important;
  box-shadow: 0 10px 24px rgba(255,159,63,0.3);
}

.progress {
  height: 12px !important;
  background: #eee9ff !important;
}

.progress span,
.loading-progress span {
  background: linear-gradient(90deg, var(--jf-orange), var(--jf-ink)) !important;
}

.job-card {
  grid-template-columns: minmax(0, 1fr) 92px auto !important;
}

.job-card h2 { font-size: 20px !important; }

.score {
  border-radius: 18px;
  padding: 12px 8px;
  background: var(--jf-blue);
}

table {
  overflow: hidden;
  border-radius: 18px;
}

th, td {
  border-bottom: 1px solid var(--jf-line) !important;
  color: var(--jf-ink) !important;
}

th { color: var(--jf-muted) !important; }

.loading-overlay {
  background: rgba(18, 3, 87, 0.38) !important;
  backdrop-filter: blur(16px);
}

.spinner {
  border-color: #eee9ff !important;
  border-top-color: var(--jf-orange) !important;
}

footer {
  width: min(1180px, calc(100% - 32px)) !important;
  border-top: 1px solid rgba(255,255,255,0.55) !important;
  color: var(--jf-muted) !important;
}

@media (max-width: 900px) {
  .shell::before {
    width: 148px;
    height: 68px;
    font-size: 40px;
  }

  .hero, .two, .onboarding, .app-layout {
    grid-template-columns: 1fr !important;
  }

  .hero {
    min-height: auto;
    padding-top: 86px !important;
  }

  .hero > div:first-child::before {
    width: 96px;
    height: 96px;
    margin-bottom: 28px;
    border-width: 16px;
    border-radius: 28px;
  }

  .logo-panel { min-height: 360px; }

  .logo-panel::before {
    width: 205px;
    height: 330px;
  }

  .logo-panel::after { display: none; }

  .metrics, .status, .trust {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .side {
    position: static !important;
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (max-width: 560px) {
  header { align-items: stretch !important; }

  nav, .side, .metrics, .status, .trust {
    grid-template-columns: 1fr !important;
  }

  nav { border-radius: 18px; }
  .job-card { grid-template-columns: 1fr !important; }
  h1 { font-size: 44px !important; }

  .toolbar, .panel, .metric, .job-card, .empty-state {
    padding: 18px !important;
  }
}
