/* SuomiJobs Design System — v2.0
   Enhanced design tokens layered on top of existing styles.
   Import AFTER styles.css so existing components keep working. */

:root {
  /* ── Enhanced Palette (supplements existing --primary vars) ── */
  --sj-bg:          #F5F2EC;
  --sj-bg-2:        #ECEAE3;
  --sj-bg-3:        #E3E0D8;
  --sj-surface:     #FFFFFF;
  --sj-ink:         #1A1814;
  --sj-ink-2:       #4A4740;
  --sj-ink-3:       #8A877F;
  --sj-accent:      #1E6B4A;
  --sj-accent-2:    #2D8F63;
  --sj-accent-lt:   #E8F5EE;
  --sj-gold:        #C8A84B;
  --sj-gold-lt:     #FDF5E1;
  --sj-blue:        #2563EB;
  --sj-blue-lt:     #EEF4FF;
  --sj-danger:      #D94F4F;
  --sj-border:      rgba(26,24,20,0.10);
  --sj-border-2:    rgba(26,24,20,0.06);

  /* ── Typography ── */
  --sj-font-display: 'Syne', 'Inter', system-ui, sans-serif;
  --sj-font-body:    'DM Sans', 'Inter', system-ui, sans-serif;

  /* ── Elevation ── */
  --sj-shadow:    0 2px 16px rgba(26,24,20,0.08);
  --sj-shadow-lg: 0 8px 40px rgba(26,24,20,0.12);
  --sj-shadow-xl: 0 24px 64px rgba(26,24,20,0.16);

  /* ── Shape ── */
  --sj-r:    12px;
  --sj-r-lg: 20px;
  --sj-r-xl: 28px;

  /* ── Motion ── */
  --sj-ease:   cubic-bezier(0.16, 1, 0.3, 1);
  --sj-fast:   150ms;
  --sj-normal: 220ms;
  --sj-slow:   350ms;

  /* ── Layout ── */
  --sj-max:    1280px;
  --sj-gutter: 24px;
}

/* ── Utility classes ── */
.sj-container { max-width: var(--sj-max); margin: 0 auto; padding: 0 var(--sj-gutter); }
.sj-section   { padding: 80px var(--sj-gutter); max-width: var(--sj-max); margin: 0 auto; }
.sj-fade-in   { animation: sj-fade var(--sj-slow) var(--sj-ease) both; }
@keyframes sj-fade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* ── Badge ── */
.sj-badge { display:inline-flex; align-items:center; padding:4px 10px; border-radius:100px; font-size:12px; font-weight:600; white-space:nowrap; }
.sj-badge--default { background:var(--sj-bg-2); color:var(--sj-ink-2); }
.sj-badge--green   { background:var(--sj-accent-lt); color:var(--sj-accent); }
.sj-badge--gold    { background:var(--sj-gold-lt); color:#8B6914; }
.sj-badge--blue    { background:var(--sj-blue-lt); color:var(--sj-blue); }
.sj-badge--outline { border:1px solid var(--sj-border); color:var(--sj-ink-3); }

/* ── Announcement Banner ── */
.sj-banner {
  background: var(--sj-ink);
  padding: 10px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  position: relative;
}
.sj-banner-text  { font-size:13px; color:rgba(255,255,255,.65); text-align:center; margin:0; }
.sj-banner-link  { color:var(--sj-accent-2); font-weight:600; text-decoration:none; }
.sj-banner-link:hover { text-decoration:underline; }
.sj-banner-close {
  position:absolute; right:16px; top:50%; transform:translateY(-50%);
  background:none; border:none; color:rgba(255,255,255,.35);
  font-size:20px; cursor:pointer; line-height:1; padding:4px;
}
.sj-banner-close:hover { color:rgba(255,255,255,.7); }

/* ── Enhanced Search Bar ── */
.sj-hero-search { display:flex; flex-direction:column; gap:14px; max-width:860px; margin:0 auto 24px; }
.sj-search-bar {
  display:flex; align-items:stretch;
  background:rgba(255,255,255,0.06); border-radius:var(--sj-r-lg);
  border:1.5px solid rgba(255,255,255,0.12);
  box-shadow:0 8px 40px rgba(0,0,0,0.2); overflow:hidden;
}
.sj-search-field { flex:1; display:flex; flex-direction:column; padding:12px 18px; min-width:0; }
.sj-search-label { font-size:11px; font-weight:700; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:.08em; margin-bottom:4px; }
.sj-search-input { border:none; outline:none; background:transparent; font-family:inherit; font-size:15px; font-weight:500; color:#fff; width:100%; }
.sj-search-input::placeholder { color:rgba(255,255,255,0.3); font-weight:400; }
.sj-search-divider { width:1px; background:rgba(255,255,255,0.1); flex-shrink:0; margin:10px 0; }
.sj-search-btn {
  margin:6px; flex-shrink:0; border-radius:14px;
  background:var(--primary); color:#fff; border:none;
  padding:13px 28px; font-size:15px; font-weight:600;
  cursor:pointer; font-family:inherit; transition:all 0.2s;
}
.sj-search-btn:hover { background:var(--primary-dark); transform:translateY(-1px); box-shadow:0 4px 14px rgba(5,150,105,0.4); }
.sj-quick-searches { display:flex; align-items:center; gap:8px; flex-wrap:wrap; justify-content:center; }
.sj-quick-label { font-size:13px; color:rgba(255,255,255,0.35); font-weight:500; flex-shrink:0; }
.sj-quick-chip {
  padding:5px 14px; border-radius:100px;
  border:1px solid rgba(255,255,255,0.15); background:transparent;
  font-size:13px; font-weight:500; color:rgba(255,255,255,0.55);
  cursor:pointer; transition:all var(--sj-fast); font-family:inherit;
}
.sj-quick-chip:hover { border-color:var(--primary-light); color:#fff; background:rgba(5,150,105,0.15); }
@media(max-width:640px) {
  .sj-search-bar { flex-direction:column; }
  .sj-search-divider { width:auto; height:1px; margin:0 10px; }
  .sj-search-btn { margin:0 6px 6px; }
}

/* ── Enhanced Job Card ── */
.sj-job-card { position:relative; overflow:hidden; display:flex; flex-direction:column; gap:12px; }
.sj-job-card--featured { border-color:rgba(200,168,75,.35); }
.sj-job-featured-label {
  position:absolute; top:16px; right:16px;
  background:var(--sj-gold-lt); color:#8B6914;
  padding:3px 10px; border-radius:100px;
  font-size:11px; font-weight:700; letter-spacing:.04em;
}
.sj-job-header { display:flex; align-items:flex-start; gap:14px; }
.sj-job-logo {
  width:48px; height:48px; border-radius:12px;
  background:var(--bg-secondary); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--sj-font-display), 'Inter', sans-serif; font-size:14px; font-weight:800;
  color:var(--text); flex-shrink:0; overflow:hidden;
}
.sj-job-company-info { display:flex; flex-direction:column; gap:3px; flex:1; min-width:0; }
.sj-job-company { font-size:13px; font-weight:500; color:var(--text-secondary); }
.sj-job-location { font-size:12px; color:var(--text-muted); }
.sj-job-title { font-size:17px; font-weight:700; color:var(--text); line-height:1.2; }
.sj-job-tags { display:flex; gap:6px; flex-wrap:wrap; }
.sj-job-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:14px; border-top:1px solid var(--border-light); }
.sj-job-posted { font-size:12px; color:var(--text-muted); }

/* ── Job Alerts Form ── */
.sj-alerts-section { background:var(--bg-secondary); }
.sj-alerts-inner { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.sj-alerts-form {
  background:var(--bg-primary); border-radius:16px;
  padding:32px; display:flex; flex-direction:column; gap:16px;
  border:1px solid var(--border); box-shadow:var(--shadow-md);
}
.sj-alerts-form .form-group { margin-bottom:0; }
.sj-consent-label {
  display:flex; gap:10px; align-items:flex-start;
  font-size:13px; color:var(--text-muted); line-height:1.6; cursor:pointer;
}
.sj-consent-label input { margin-top:2px; accent-color:var(--primary); flex-shrink:0; width:16px; height:16px; }
.sj-consent-link { color:var(--primary); text-decoration:none; }
.sj-consent-link:hover { text-decoration:underline; }
@media(max-width:768px) {
  .sj-alerts-inner { grid-template-columns:1fr; gap:24px; }
}

/* ── Cookie Consent ── */
.sj-cookie-banner {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%);
  z-index:9998; width:calc(100% - 40px); max-width:680px;
  background:var(--bg-primary); border-radius:var(--sj-r-lg);
  box-shadow:var(--sj-shadow-xl); border:1px solid var(--border);
  animation:sj-cookie-in var(--sj-slow) var(--sj-ease);
}
@keyframes sj-cookie-in { from{transform:translateX(-50%) translateY(24px);opacity:0} to{transform:translateX(-50%) translateY(0);opacity:1} }
.sj-cookie-inner { padding:20px 24px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.sj-cookie-text { font-size:14px; color:var(--text-secondary); line-height:1.5; flex:1; min-width:200px; margin:0; }
.sj-cookie-link { color:var(--primary); text-decoration:none; }
.sj-cookie-link:hover { text-decoration:underline; }
.sj-cookie-actions { display:flex; gap:8px; flex-shrink:0; }

/* ── Enhanced Footer ── */
.sj-footer { background:var(--sj-ink); padding:64px 0 0; }
.sj-footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:48px;
}
.sj-footer-logo {
  font-family:var(--sj-font-display), 'Inter', sans-serif; font-size:22px; font-weight:800;
  color:#fff; text-decoration:none; display:block; margin-bottom:14px;
}
.sj-footer-logo span { color:var(--sj-accent-2); }
.sj-footer-desc   { font-size:14px; color:rgba(255,255,255,.4); line-height:1.65; max-width:260px; font-weight:300; margin-bottom:10px; }
.sj-footer-entity { font-size:12px; color:rgba(255,255,255,.25); }
.sj-footer-entity-link { color:rgba(255,255,255,.35); text-decoration:none; }
.sj-footer-entity-link:hover { color:rgba(255,255,255,.6); }
.sj-footer-col-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:rgba(255,255,255,.28); margin-bottom:14px; }
.sj-footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; padding:0; }
.sj-footer-link  { font-size:14px; color:rgba(255,255,255,.45); text-decoration:none; transition:color var(--sj-fast); }
.sj-footer-link:hover { color:#fff; }
.sj-footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding:24px 0 32px;
  display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap;
}
.sj-footer-copy  { font-size:13px; color:rgba(255,255,255,.28); margin:0; }
.sj-footer-legal-links { display:flex; gap:20px; flex-wrap:wrap; list-style:none; padding:0; margin:0; }
.sj-footer-legal-link { font-size:13px; color:rgba(255,255,255,.28); text-decoration:none; }
.sj-footer-legal-link:hover { color:rgba(255,255,255,.55); }
@media(max-width:900px) { .sj-footer-top { grid-template-columns:1fr 1fr; } }
@media(max-width:480px) { .sj-footer-top { grid-template-columns:1fr; gap:32px; } .sj-footer-bottom { flex-direction:column; align-items:flex-start; } }

/* ── Toast ── */
.sj-toast {
  position:fixed; bottom:24px; right:24px; z-index:9999;
  display:flex; align-items:center; gap:10px;
  padding:14px 20px; border-radius:var(--sj-r);
  font-family:inherit; font-size:14px; font-weight:500;
  box-shadow:var(--sj-shadow-xl);
  animation:sj-toast-in var(--sj-normal) var(--sj-ease);
}
@keyframes sj-toast-in { from{transform:translateY(12px);opacity:0} to{transform:translateY(0);opacity:1} }
.sj-toast--success { background:var(--sj-ink); color:#fff; }
.sj-toast--error   { background:var(--sj-danger); color:#fff; }
.sj-toast--info    { background:#1D4ED8; color:#fff; }
