/* ===========================
   Jobs Lite – Frontend Styles
   modern, clean, accessible
   =========================== */

:root{
  --jl-bg: #ffffff;
  --jl-card-bg: #ffffff;
  --jl-text: #111318;
  --jl-muted: #5b616e;
  --jl-border: #e6e8ec;
  --jl-accent: #0ea5e9;     /* Akzent (Links/Buttons) */
  --jl-accent-ink: #0b6ea1; /* Hover/Active */
  --jl-badge-bg: #f4f6f8;
  --jl-shadow: 0 1px 2px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.06);
  --jl-radius: 14px;
  --jl-radius-sm: 10px;
  --jl-gap: 16px;
  --jl-gap-lg: 22px;
  --jl-font: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, "Helvetica Neue", Arial, "Apple Color Emoji","Segoe UI Emoji";
}

@media (prefers-color-scheme: dark){
  :root{
    --jl-bg: #0f1115;
    --jl-card-bg: #141820;
    --jl-text: #eef2f7;
    --jl-muted: #a7afbd;
    --jl-border: #202636;
    --jl-accent: #38bdf8;
    --jl-accent-ink: #7dd3fc;
    --jl-badge-bg: #1b2130;
    --jl-shadow: 0 1px 2px rgba(0,0,0,.35), 0 10px 28px rgba(0,0,0,.35);
  }
}

/* Scope auf unsere Komponenten */
.jl-job-list,
.jl-single-job{
  font-family: var(--jl-font);
  color: var(--jl-text);
}

/* ---------- Grid Liste ---------- */
.jl-job-list{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--jl-gap);
  margin: 0 0 32px 0;
}
.jl-thumb {display: block; padding-bottom: 20px;}
/* ---------- Card ---------- */
.jl-card{
  background: var(--jl-card-bg);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius);
  padding: 18px 18px 16px;
  box-shadow: var(--jl-shadow);
  display:flex;
  flex-direction:column;
  gap: 10px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}
.jl-card .mtg-btn::before { top: 1px !important;}
.jl-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 2px 10px rgba(16,24,40,.10), 0 16px 34px rgba(16,24,40,.10);
}
@media (prefers-reduced-motion: reduce){
  .jl-card, .jl-card:hover{ transform:none; transition:none; }
}
.jl-card header {padding-top: 0px; margin-top: 0px;}
.jl-card header h3{
  font-size: clamp(1.05rem, 0.96rem + 0.4vw, 1.25rem);
  line-height: 1.25;
  margin: 0 0 20px 0;
    font-weight: 700;
}
.jl-card header a{
  color: var(--jl-text);
  text-decoration:none;
}
.jl-card header a:hover{ text-decoration: underline; }

.jl-card .jl-meta{
  display:flex; flex-wrap:wrap; gap:6px;
}

.jl-card .badge{
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1;
  border-radius: 999px;
  background: var(--jl-badge-bg);
  border: 1px solid var(--jl-border);
  color: var(--jl-muted);
  white-space: nowrap;
}

.jl-card .excerpt{
  color: var(--jl-muted);
  font-size: 0.96rem;
  margin-top: 2px;
}

.jl-card footer{
  display:flex; align-items:center; justify-content:space-between;
  margin-top: auto;
  font-size: 13px;
  color: var(--jl-muted);
  gap: 10px;
}

/* ---------- Single ---------- */
.jl-single-job .jl-single-header{
  display:flex; flex-direction:column; gap: 12px;
  margin: 10px 0 18px;
}
.jl-single-job h1{
  margin:0;
  font-size: clamp(1.35rem, 1.06rem + 1.6vw, 2rem);
  line-height:1.15;
}
.jl-single-job .jl-tags{
  color: var(--jl-muted);
  display:flex; flex-wrap:wrap; gap:8px;
}

.jl-single-job .jl-meta-box{
  background: var(--jl-card-bg);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius);
  box-shadow: var(--jl-shadow);
}
.jl-single-job .jl-meta-box ul{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 10px 16px;
}
.jl-single-job .jl-meta-box li{
  color: var(--jl-text);
}
.jl-single-job .jl-meta-box strong{
  color: var(--jl-muted);
  font-weight:600;
  margin-right:6px;
}

/* ---------- Apply Button ---------- */
.jl-apply.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding: 11px 16px;
  border-radius: 10px;
  border: 1px solid var(--jl-accent);
  background: var(--jl-accent);
  color: #fff !important;
  text-decoration:none;
  font-weight: 600;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease;
  box-shadow: 0 1px 2px rgba(16,24,40,.08);
}
.jl-apply.btn:hover{
  background: var(--jl-accent-ink);
  border-color: var(--jl-accent-ink);
  box-shadow: 0 2px 8px rgba(14,165,233,.25);
  transform: translateY(-1px);
}
.jl-apply.btn:focus-visible{
  outline: 2px solid #0000;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--jl-accent) 35%, transparent);
}

/* ---------- Helpers ---------- */
.jl-muted{ color: var(--jl-muted); }

.jl-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px;
  background: var(--jl-badge-bg);
  border: 1px solid var(--jl-border);
  border-radius: 999px;
  color: var(--jl-muted);
  font-size:12px;
}

/* ---------- Links im Content ---------- */
.jl-single-job .entry-content a{
  color: var(--jl-accent);
  text-underline-offset: 3px;
}
.jl-single-job .entry-content a:hover{ color: var(--jl-accent-ink); }

/* ---------- Tables im Content (falls genutzt) ---------- */
.jl-single-job .entry-content table{
  width:100%; border-collapse: collapse; font-size: .98rem;
}
.jl-single-job .entry-content th,
.jl-single-job .entry-content td{
  border:1px solid var(--jl-border);
  padding:10px 12px;
}
.jl-single-job .entry-content th{
  text-align:left; background: var(--jl-badge-bg); color: var(--jl-text);
}

/* ---------- Media ---------- */
.jl-single-job img{ max-width:100%; height:auto; border-radius: 8px; }

/* ---------- Print (kompakt & sauber) ---------- */
@media print {
  .site-header, .site-footer, nav, .sidebar, .widget, .comments-area { display:none !important; }
  .jl-apply.btn{ display:none !important; }
  .jl-card{ box-shadow:none; border-color:#bbb; }
}

/* ---------- Accessibility Extras ---------- */
.jl-card a:focus-visible,
.jl-single-job a:focus-visible{
  outline: 2px solid var(--jl-accent);
  outline-offset: 2px;
  border-radius: 6px;
}
