/* ══════════════════════════════════════════════
   Job Detail Modal – Shared Styles (.jd-*)
   Used by: web/views/jobs.php, web/views/applications.php
   ══════════════════════════════════════════════ */

/* ── Modal Shell ── */
.jd-modal .modal-content { border-radius:22px;border:none;overflow:hidden;box-shadow:0 25px 70px rgba(0,0,0,.22),0 8px 24px rgba(109,40,217,.08); }
.jd-modal .modal-dialog { max-width:720px; }

/* ── Header ── */
.jd-header { position:relative;overflow:visible; }
.jd-header-bg { position:absolute;inset:0;overflow:hidden;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 35%,#4c1d95 70%,#3b1f8e 100%); }
.jd-header-bg::before { content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:18px 18px; }
.jd-header-bg::after { content:'';position:absolute;bottom:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(167,139,250,.3),transparent 70%);animation:jd-pulse 4s ease-in-out infinite alternate; }
@keyframes jd-pulse { 0%{opacity:.6;transform:scale(1)} 100%{opacity:1;transform:scale(1.15)} }
.jd-header-inner { position:relative;z-index:1;padding:24px 28px 22px;display:flex;align-items:flex-start;gap:16px; }
.jd-logo { width:56px;height:56px;border-radius:16px;background:rgba(255,255,255,.1);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s;box-shadow:0 4px 16px rgba(0,0,0,.12); }
.jd-logo:hover { transform:scale(1.05); }
.jd-logo img { width:42px;height:42px;object-fit:contain;border-radius:10px; }
.jd-header-info { flex:1;min-width:0; }
.jd-company { color:rgba(255,255,255,.6);font-size:.78rem;font-weight:600;margin-bottom:3px;letter-spacing:.03em; }
.jd-title { color:#fff;font-size:1.3rem;font-weight:800;line-height:1.25;letter-spacing:-.02em;text-shadow:0 2px 8px rgba(0,0,0,.15); }
.jd-salary-badge { display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.25);color:#6ee7b7;font-size:.78rem;font-weight:700;backdrop-filter:blur(6px); }
.jd-close { background:rgba(255,255,255,.08);border:none;border-radius:10px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin-top:2px; }
.jd-close:hover { background:rgba(255,255,255,.18);transform:rotate(90deg); }
.jd-close i { color:rgba(255,255,255,.6);font-size:.85rem; }

/* ── Tag Strip ── */
.jd-tags { display:flex;flex-wrap:wrap;gap:7px;padding:14px 28px;border-bottom:1px solid #f0eef8;background:linear-gradient(180deg,#faf9ff,#fff); }
.jd-tag { display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:20px;font-size:.72rem;font-weight:600;border:1px solid;transition:transform .15s,box-shadow .15s; }
.jd-tag:hover { transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.06); }

/* ── Body ── */
.jd-body { padding:22px 28px 28px; }
.jd-info-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px;margin-bottom:22px; }
.jd-info-card { padding:14px 16px;border-radius:12px;border:1px solid #ede9fe;background:linear-gradient(135deg,#faf9ff 0%,#f5f3ff 100%);position:relative;overflow:hidden;transition:all .2s; }
.jd-info-card::before { content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#a78bfa,#7c3aed);opacity:0;transition:opacity .2s; }
.jd-info-card:hover { border-color:#ddd6fe;box-shadow:0 4px 14px rgba(124,58,237,.06); }
.jd-info-card:hover::before { opacity:1; }
.jd-info-label { font-size:.64rem;font-weight:700;color:#a78bfa;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;display:flex;align-items:center;gap:4px; }
.jd-info-label i { font-size:.7rem; }
.jd-info-val { font-size:.85rem;font-weight:700;color:#1e1b4b; }

/* ── Map ── */
.jd-map-wrap { border-radius:14px;overflow:hidden;border:1px solid #ede9fe;margin-bottom:22px;box-shadow:0 2px 10px rgba(0,0,0,.04); }
.jd-map-wrap iframe { width:100%;height:170px;border:0;display:block; }
.jd-map-bar { padding:10px 16px;background:linear-gradient(135deg,#faf9ff,#f5f3ff);display:flex;align-items:center;justify-content:space-between;border-top:1px solid #ede9fe; }

/* ── Sections ── */
.jd-section { margin-bottom:22px; }
.jd-section-title { font-size:.82rem;font-weight:700;color:#1e1b4b;margin-bottom:10px;display:flex;align-items:center;gap:9px; }
.jd-section-icon { width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.1); }
.jd-section-icon i { font-size:.7rem;color:#fff; }
.jd-section-text { color:#4b5563;font-size:.84rem;line-height:1.75;white-space:pre-line;padding-left:35px; }

/* ── Company Card ── */
.jd-company-card { border-radius:14px;padding:18px 20px;background:linear-gradient(135deg,#faf9ff 0%,#f5f3ff 50%,#ede9fe 100%);border:1px solid #e9e5f5;position:relative;overflow:hidden; }
.jd-company-card::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#7c3aed,#a78bfa,#c4b5fd);border-radius:3px 3px 0 0; }

/* ── Footer ── */
.jd-footer { border-top:1px solid #f0eef8;padding:16px 28px;display:flex;align-items:center;gap:10px;background:linear-gradient(180deg,#fdfcff,#faf8ff); }
.jd-btn-close { background:#f3f4f6;color:#6b7280;border:none;border-radius:10px;padding:10px 22px;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s; }
.jd-btn-close:hover { background:#e5e7eb;color:#374151; }
.jd-btn-save { background:#fff;color:#6d28d9;border:1.5px solid #ddd6fe;border-radius:10px;padding:10px 22px;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s; }
.jd-btn-save:hover { background:#f5f3ff;border-color:#b794f4;box-shadow:0 2px 10px rgba(109,40,217,.1); }
.jd-btn-apply { background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border:none;border-radius:10px;padding:10px 26px;font-weight:700;font-size:.82rem;cursor:pointer;box-shadow:0 4px 14px rgba(109,40,217,.3);transition:all .2s;letter-spacing:.01em; }
.jd-btn-apply:hover { box-shadow:0 6px 20px rgba(109,40,217,.4);transform:translateY(-2px); }
.jd-btn-apply:active { transform:translateY(0);box-shadow:0 2px 8px rgba(109,40,217,.25); }

/* ── Posted time badge ── */
.jd-posted-badge { display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;background:rgba(255,255,255,.92);color:#4c1d95;font-size:.72rem;font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.1); }

/* ── Smooth open ── */
.jd-modal.show .modal-content { animation:jd-slideUp .35s cubic-bezier(.21,1.02,.73,1); }
@keyframes jd-slideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ── Loading ── */
.jd-loading { display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px; }
.jd-loading-spinner { width:36px;height:36px;border:3px solid #ede9fe;border-top-color:#7c3aed;border-radius:50%;animation:jd-spin .7s linear infinite; }
@keyframes jd-spin { to{transform:rotate(360deg)} }
.jd-loading-text { color:#9ca3af;font-size:.82rem;font-weight:500; }

/* ── Divider ── */
.jd-divider { height:1px;background:linear-gradient(90deg,transparent,#ede9fe,transparent);margin:4px 0 22px; }
