/* ================================================================
   /jobs/assets/css/portal.css  — Job Portal Styles
   Requires parent app's main.css to be loaded first
   ================================================================ */
.jp-wrap        { max-width:1280px;margin:0 auto;padding:0 20px }
.jp-two-col     { display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start }
.jp-three-col   { display:grid;grid-template-columns:260px 1fr 280px;gap:22px;align-items:start }
@media(max-width:1100px){ .jp-three-col{ grid-template-columns:1fr } }
@media(max-width:768px) { .jp-two-col  { grid-template-columns:1fr } }

/* ── Hero ── */
.jp-hero{ background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(244,197,66,.1) 0%,transparent 60%),var(--dark);padding:72px 0 52px;text-align:center }
.jp-hero h1{ font-size:clamp(1.8rem,4vw,3rem);margin-bottom:10px }
.jp-hero p { color:var(--muted);font-size:1rem;margin-bottom:32px }
.jp-search-box{ display:flex;max-width:800px;margin:0 auto;background:var(--dark-2);border:1px solid var(--border);border-radius:12px;overflow:hidden;flex-wrap:wrap }
.jp-search-box input,.jp-search-box select{ flex:1;min-width:130px;padding:15px 16px;background:transparent;border:none;color:var(--text);font-size:.9rem;outline:none;border-right:1px solid var(--border) }
.jp-search-box select option{ background:var(--dark-2) }
.jp-search-box button{ padding:15px 26px;background:var(--primary);color:var(--dark);font-weight:700;border:none;cursor:pointer;font-size:.9rem;white-space:nowrap;transition:opacity .2s }
.jp-search-box button:hover{ opacity:.88 }

/* ── Job Card ── */
.jp-job-card{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:20px 22px;transition:border-color .2s,transform .15s;position:relative }
.jp-job-card:hover{ border-color:var(--primary);transform:translateY(-2px) }
.jp-job-card.featured{ border-color:rgba(244,197,66,.35) }
.jp-featured-tag{ position:absolute;top:-1px;right:18px;background:var(--primary);color:var(--dark);font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:0 0 8px 8px;letter-spacing:.4px }
.jp-urgent-tag{ position:absolute;top:-1px;left:18px;background:#ef4444;color:#fff;font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:0 0 8px 8px }
.jp-card-top{ display:flex;gap:14px;align-items:flex-start;margin-bottom:12px }
.jp-card-logo{ width:52px;height:52px;border-radius:10px;background:var(--dark);border:1px solid var(--border);object-fit:contain;flex-shrink:0;padding:6px }
.jp-card-logo-ph{ width:52px;height:52px;border-radius:10px;background:var(--dark);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:800;font-size:1.1rem;flex-shrink:0 }
.jp-card-company{ font-size:.8rem;color:var(--muted);margin-bottom:2px }
.jp-card-title a{ font-size:1rem;font-weight:700;color:var(--text);text-decoration:none }
.jp-card-title a:hover{ color:var(--primary) }
.jp-card-meta{ display:flex;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--muted) }
.jp-card-meta span{ display:flex;align-items:center;gap:5px }
.jp-card-foot{ display:flex;align-items:center;justify-content:space-between;margin-top:12px;flex-wrap:wrap;gap:8px }

/* ── Tags ── */
.jp-tag{ background:rgba(244,197,66,.1);color:var(--primary);font-size:.72rem;font-weight:600;padding:3px 9px;border-radius:20px }
.jp-tag-blue{ background:rgba(59,130,246,.1);color:#60a5fa }
.jp-tag-red { background:rgba(239,68,68,.1); color:#f87171 }
.jp-tag-green{background:rgba(34,197,94,.1); color:#4ade80 }

/* ── Filter sidebar ── */
.jp-filter{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:18px 20px }
.jp-filter h4{ font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:10px }
.jp-filter-group{ margin-bottom:20px }
.jp-filter label{ display:flex;align-items:center;gap:8px;font-size:.85rem;cursor:pointer;padding:3px 0 }
.jp-filter input[type=checkbox],.jp-filter input[type=radio]{ accent-color:var(--primary) }

/* ── Detail page ── */
.jp-detail-box{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:26px }
.jp-detail-meta{ display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px;margin:18px 0 }
.jp-detail-meta label{ font-size:.7rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);display:block;margin-bottom:3px }
.jp-detail-meta span{ font-weight:600;font-size:.875rem }
.jp-section-title{ font-size:.95rem;font-weight:700;border-bottom:1px solid var(--border);padding-bottom:8px;margin:22px 0 12px }
.jp-bullet-list{ list-style:none;padding:0 }
.jp-bullet-list li{ padding:4px 0 4px 18px;position:relative;font-size:.875rem;line-height:1.7 }
.jp-bullet-list li::before{ content:'▹';position:absolute;left:0;color:var(--primary) }

/* ── Apply box ── */
.jp-apply-box{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:22px;position:sticky;top:80px }
.jp-apply-box .deadline{ color:var(--muted);font-size:.78rem;text-align:center;margin-top:10px }

/* ── Profile page ── */
.jp-profile-header{ background:var(--dark-2);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:20px;display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap }
.jp-profile-photo{ width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);flex-shrink:0 }
.jp-profile-photo-ph{ width:96px;height:96px;border-radius:50%;background:var(--dark);border:3px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--primary);flex-shrink:0 }
.jp-progress{ height:6px;background:var(--dark);border-radius:3px;overflow:hidden;margin:6px 0 }
.jp-progress-bar{ height:100%;background:var(--primary);border-radius:3px;transition:width .4s }

/* ── Section card ── */
.jp-section-card{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:18px }
.jp-section-card__header{ display:flex;align-items:center;justify-content:space-between;margin-bottom:16px }
.jp-section-card h3{ font-size:.95rem;font-weight:700 }
.jp-entry{ border-bottom:1px solid var(--border);padding-bottom:14px;margin-bottom:14px }
.jp-entry:last-child{ border-bottom:none;margin-bottom:0;padding-bottom:0 }
.jp-entry__title{ font-weight:700;font-size:.9rem;margin-bottom:2px }
.jp-entry__sub{ font-size:.8rem;color:var(--muted) }
.jp-entry__date{ font-size:.76rem;color:var(--primary);margin-top:2px }
.jp-skill-pill{ display:inline-flex;align-items:center;gap:6px;background:rgba(244,197,66,.08);border:1px solid rgba(244,197,66,.18);color:var(--text);padding:4px 11px;border-radius:20px;font-size:.8rem;margin:3px }
.jp-skill-pill span{ color:var(--primary);font-size:.7rem }

/* ── Dash nav ── */
.jp-dash-nav{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;overflow:hidden }
.jp-dash-nav a{ display:flex;align-items:center;gap:11px;padding:12px 16px;color:var(--muted);text-decoration:none;font-size:.85rem;border-bottom:1px solid var(--border);transition:background .15s,color .15s }
.jp-dash-nav a:last-child{ border-bottom:none }
.jp-dash-nav a:hover,.jp-dash-nav a.active{ background:rgba(244,197,66,.07);color:var(--primary) }
.jp-dash-nav a i{ width:16px;text-align:center }

/* ── Stats ── */
.jp-stat-row{ display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-bottom:26px }
.jp-stat-card{ background:var(--dark-2);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center }
.jp-stat-card__num{ font-size:1.8rem;font-weight:800;color:var(--primary);font-family:var(--font-display) }
.jp-stat-card__label{ font-size:.76rem;color:var(--muted);margin-top:3px }

/* ── Table ── */
.jp-table-wrap{ overflow-x:auto;border-radius:12px;border:1px solid var(--border) }
.jp-table-wrap table{ width:100%;border-collapse:collapse }
.jp-table-wrap th,.jp-table-wrap td{ padding:11px 14px;text-align:left;border-bottom:1px solid var(--border) }
.jp-table-wrap th{ background:var(--dark);font-size:.75rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted) }
.jp-table-wrap tr:last-child td{ border-bottom:none }
.jp-table-wrap tr:hover td{ background:rgba(255,255,255,.02) }

/* ── Modal ── */
.jp-modal-bg{ position:fixed;inset:0;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px }
.jp-modal{ background:var(--dark-2);border:1px solid var(--border);border-radius:16px;padding:26px;max-width:540px;width:100%;max-height:90vh;overflow-y:auto }
.jp-modal h3{ margin-bottom:18px }

/* ── Misc ── */
.jp-verified{ color:#22c55e;font-size:.8rem }
.jp-notif-dot{ position:absolute;top:-4px;right:-4px;width:17px;height:17px;border-radius:50%;background:#ef4444;color:#fff;font-size:.62rem;display:flex;align-items:center;justify-content:center;font-weight:700 }
.jp-pagination{ display:flex;gap:5px;justify-content:center;margin-top:28px;flex-wrap:wrap }
.jp-pagination a,.jp-pagination span{ padding:7px 13px;border-radius:8px;border:1px solid var(--border);font-size:.82rem;color:var(--muted);text-decoration:none;transition:all .15s }
.jp-pagination a:hover{ border-color:var(--primary);color:var(--primary) }
.jp-pagination .active{ background:var(--primary);color:var(--dark);border-color:var(--primary);font-weight:700 }
.jp-empty{ text-align:center;padding:56px 20px;color:var(--muted) }
.jp-empty i{ font-size:2.8rem;margin-bottom:14px;opacity:.35;display:block }
.jp-empty h3{ margin-bottom:7px;color:var(--text) }
.jp-company-card{ background:var(--dark-2);border:1px solid var(--border);border-radius:14px;padding:22px;text-align:center;transition:border-color .2s;text-decoration:none;display:block;color:var(--text) }
.jp-company-card:hover{ border-color:var(--primary) }

/* ── Responsive ── */
@media(max-width:640px){
  .jp-hero{ padding:44px 0 32px }
  .jp-search-box{ flex-direction:column }
  .jp-search-box input,.jp-search-box select,.jp-search-box button{ border-right:none;border-bottom:1px solid var(--border);width:100% }
  .jp-profile-header{ flex-direction:column;align-items:center;text-align:center }
  .jp-detail-meta{ grid-template-columns:1fr 1fr }
}
