/* ============================================================
   Careers page + Job Manager (admin) — additive
   Loaded AFTER style.css + home.css.
   ============================================================ */

/* ---------- Hero visual: workplace image + floating perk chips ---------- */
.cr-visual{position:relative;width:100%;max-width:540px;height:460px;margin-left:auto}
.cr-glow{position:absolute;width:340px;height:340px;border-radius:50%;filter:blur(80px);opacity:.5;z-index:0}
.cr-glow.a{left:-6%;top:2%;background:radial-gradient(circle,#00e0c6,transparent 70%)}
.cr-glow.b{right:-4%;bottom:2%;background:radial-gradient(circle,#6a5cff,transparent 70%)}
.cr-photo{position:absolute;inset:6% 8%;border-radius:22px;overflow:hidden;z-index:1;
  border:1px solid rgba(255,255,255,.14);box-shadow:0 36px 80px -26px rgba(0,0,0,.7)}
.cr-photo img{width:100%;height:100%;object-fit:cover;display:block}
.cr-chip{position:absolute;z-index:3;background:rgba(255,255,255,.97);border-radius:14px;padding:12px 15px;
  display:flex;align-items:center;gap:11px;box-shadow:0 22px 50px -16px rgba(0,0,0,.5);animation:crFloat 6s ease-in-out infinite}
.cr-chip .ci{width:38px;height:38px;border-radius:11px;background:var(--grad);color:#fff;display:grid;place-items:center;flex:none}
.cr-chip .ci svg{width:19px;height:19px}
.cr-chip b{display:block;font-family:var(--display);font-size:15px;color:var(--ink);line-height:1.05}
.cr-chip small{font-size:11.5px;color:var(--slate);font-weight:600}
.cr-chip.c1{left:-5%;top:16%}
.cr-chip.c2{right:-4%;top:46%;animation-delay:1.3s}
.cr-chip.c3{left:4%;bottom:6%;animation-delay:2.3s}
@keyframes crFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Benefits & perks grid ---------- */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.benefit{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.benefit:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.benefit .bi{width:50px;height:50px;border-radius:14px;background:var(--grad-soft);color:var(--blue);display:grid;place-items:center;margin-bottom:16px}
.benefit .bi svg{width:25px;height:25px}
.benefit h3{font-size:17.5px;margin-bottom:6px}
.benefit p{color:var(--slate);font-size:14px;margin:0}

/* ---------- Open positions (dynamic) ---------- */
.jobs-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:26px}
.jobs-count{font-family:var(--display);font-weight:700;color:var(--ink)}
.jobs-count b{color:var(--blue)}
.job-filters{display:flex;flex-wrap:wrap;gap:9px}
.jf{padding:8px 16px;border-radius:50px;border:1px solid var(--line);background:#fff;font:600 13.5px var(--body);
  color:var(--slate);cursor:pointer;transition:all .25s}
.jf:hover{border-color:var(--blue);color:var(--blue)}
.jf.on{background:var(--navy);border-color:var(--navy);color:#fff}

.job-list{display:flex;flex-direction:column;gap:16px}
.job{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 26px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.job:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.job .j-dept{display:inline-block;font:700 11.5px var(--mono);letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue);background:var(--grad-soft);padding:5px 12px;border-radius:50px;margin-bottom:10px}
.job h3{font-size:21px;margin:0 0 12px}
.job .j-meta{display:flex;flex-wrap:wrap;gap:8px 16px;color:var(--slate);font-size:13.5px;font-weight:600}
.job .j-meta span{display:inline-flex;align-items:center;gap:6px}
.job .j-meta svg{width:15px;height:15px;color:var(--teal)}
.job .j-cta{white-space:nowrap}
@media(max-width:620px){.job{grid-template-columns:1fr}.job .j-cta{justify-self:start}}

.jobs-empty{text-align:center;padding:60px 20px;background:#fff;border:1px dashed var(--line);border-radius:20px}
.jobs-empty .ei{width:64px;height:64px;border-radius:18px;background:var(--grad-soft);color:var(--blue);display:grid;place-items:center;margin:0 auto 18px}
.jobs-empty h3{font-size:20px;margin-bottom:8px}
.jobs-empty p{color:var(--slate);max-width:440px;margin:0 auto}

/* ---------- Job detail modal ---------- */
.job-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.job-modal.open{display:flex}
.job-modal .jm-back{position:fixed;inset:0;background:rgba(3,14,23,.6);backdrop-filter:blur(4px)}
.jm-panel{position:relative;z-index:2;width:100%;max-width:680px;background:#fff;border-radius:24px;
  box-shadow:var(--shadow-lg);padding:38px 40px;animation:jmIn .4s var(--ease)}
@keyframes jmIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.jm-close{position:absolute;right:18px;top:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:#fff;font-size:20px;color:var(--slate);cursor:pointer;display:grid;place-items:center;transition:all .25s}
.jm-close:hover{background:var(--mist);color:var(--ink)}
.jm-dept{display:inline-block;font:700 11.5px var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--blue);background:var(--grad-soft);padding:5px 12px;border-radius:50px}
.jm-panel h2{font-family:var(--display);font-size:28px;margin:14px 0 14px;line-height:1.15}
.jm-meta{display:flex;flex-wrap:wrap;gap:8px 16px;color:var(--slate);font-size:13.5px;font-weight:600;padding-bottom:20px;border-bottom:1px solid var(--line)}
.jm-meta span{display:inline-flex;align-items:center;gap:6px}
.jm-meta svg{width:15px;height:15px;color:var(--teal)}
.jm-section{margin-top:22px}
.jm-section h4{font-family:var(--display);font-size:16px;margin-bottom:10px;color:var(--ink)}
.jm-section p{color:var(--slate);font-size:15px;line-height:1.6;margin:0}
.jm-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.jm-section li{position:relative;padding-left:28px;color:var(--ink);font-size:14.5px;line-height:1.5}
.jm-section li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:var(--grad-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230277d4' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 4 4 10-10'/%3E%3C/svg%3E");background-size:12px;background-repeat:no-repeat;background-position:center}
.jm-actions{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.jm-link{background:none;border:0;color:var(--blue);font:700 13.5px var(--body);cursor:pointer;padding:0;margin-bottom:14px}
.jm-link:hover{text-decoration:underline}
.ap-err{color:#e5484d;font-size:13.5px;font-weight:600;margin:4px 0 0}
.jm-tick{width:74px;height:74px;border-radius:50%;background:var(--grad-soft);color:var(--blue);display:grid;place-items:center;margin:0 auto 6px;animation:tickPop .5s var(--ease)}
.jm-tick svg{width:38px;height:38px;stroke-width:2.6}
@keyframes tickPop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.btn.is-loading{opacity:.7;pointer-events:none}
/* resume PDF upload */
.cv-up{position:relative;border:2px dashed var(--line);border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:border-color .25s,background .25s}
.cv-up:hover{border-color:var(--blue);background:rgba(2,119,212,.04)}
.cv-up.has{border-color:var(--teal);border-style:solid;background:rgba(0,189,195,.05)}
.cv-up input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.cv-up .cvi{width:42px;height:42px;border-radius:11px;background:var(--grad-soft);color:var(--blue);display:grid;place-items:center;flex:none}
.cv-up .cvi svg{width:21px;height:21px}
.cv-up .cvt b{display:block;font:700 14px var(--body);color:var(--ink)}
.cv-up .cvt small{font-size:12px;color:var(--slate)}
@media(max-width:560px){.jm-panel{padding:30px 22px}.jm-panel h2{font-size:23px}}

/* ---------- Life at DevHive strip ---------- */
.life-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.life-strip figure{margin:0;border-radius:16px;overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-sm)}
.life-strip figure:nth-child(even){margin-top:28px}
.life-strip img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.life-strip figure:hover img{transform:scale(1.06)}
@media(max-width:680px){.life-strip{grid-template-columns:1fr 1fr}}

/* ---------- Admin (Job Manager) ---------- */
.adm-wrap{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
@media(max-width:960px){.adm-wrap{grid-template-columns:1fr}}
.adm-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;box-shadow:var(--shadow-sm)}
.adm-card h2{font-family:var(--display);font-size:20px;margin-bottom:4px}
.adm-card .adm-sub{color:var(--slate);font-size:13.5px;margin-bottom:20px}
.fld{margin-bottom:16px}
.fld label{display:block;font:700 13px var(--body);color:var(--ink);margin-bottom:6px}
.fld input,.fld select,.fld textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:11px;
  font:500 14px var(--body);color:var(--ink);background:#fff;transition:border-color .25s,box-shadow .25s}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(2,119,212,.12)}
.fld textarea{min-height:92px;resize:vertical;font-family:var(--body)}
.fld .hint{font-size:12px;color:var(--slate);margin-top:5px}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.fld-row{grid-template-columns:1fr}}
.adm-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.adm-list{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.adm-job{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--line);border-radius:14px}
.adm-job b{font-family:var(--display);font-size:15px;color:var(--ink);display:block}
.adm-job small{color:var(--slate);font-size:12.5px}
.adm-job .aj-btns{display:flex;gap:8px;flex:none}
.btn-mini{padding:7px 13px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;font:700 12.5px var(--body);color:var(--ink);transition:all .25s}
.btn-mini:hover{border-color:var(--blue);color:var(--blue)}
.btn-mini.del:hover{border-color:#e5484d;color:#e5484d}
.adm-empty{color:var(--slate);font-size:14px;text-align:center;padding:24px;border:1px dashed var(--line);border-radius:14px}
.adm-note{background:var(--grad-soft);border:1px solid var(--line);border-radius:14px;padding:16px 18px;font-size:13.5px;color:var(--ink);line-height:1.55}
.adm-note code{background:#fff;border:1px solid var(--line);border-radius:6px;padding:1px 7px;font:600 12.5px var(--mono);color:var(--blue)}
.adm-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:22px}
.adm-pass{max-width:420px;margin:60px auto;text-align:center}
