@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,500;0,9..144,600;1,9..144,500&family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

.jhc-wrap{
  --ink:#0B2620;--green:#2E9E6E;--green2:#4FBE8E;--greend:#1B6B49;--navy:#1C357E;
  --paper:#F4F6F3;--paper2:#E7EDE8;--card:#fff;--text:#14241E;--muted:#56655C;--faint:#86918A;--line:rgba(20,36,30,.13);
  --serif:'Fraunces',Georgia,serif;--sans:'IBM Plex Sans',system-ui,sans-serif;--mono:'IBM Plex Mono',monospace;
  font-family:var(--sans);color:var(--text);max-width:1080px;margin:0 auto;
}
.jhc-wrap *{box-sizing:border-box;}

/* hero */
.jhc-hero{background:var(--ink);color:var(--paper);border-radius:18px;padding:48px 44px;position:relative;overflow:hidden;}
.jhc-guil{position:absolute;right:-60px;top:-50px;width:300px;opacity:.45;}
.jhc-logo{height:32px;filter:brightness(0) invert(1);position:relative;z-index:2;margin-bottom:22px;}
.jhc-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--green2);position:relative;z-index:2;}
.jhc-hero h2{font-family:var(--serif);font-size:34px;font-weight:500;margin:12px 0 12px;line-height:1.1;position:relative;z-index:2;color:#fff;}
.jhc-hero h2 em{font-style:italic;color:var(--green2);}
.jhc-hero p{color:rgba(244,246,243,.8);font-size:15px;max-width:560px;line-height:1.6;position:relative;z-index:2;margin:0;}

.jhc-body{padding:28px 2px;}
.jhc-filters{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:22px;}
.jhc-pill{font-family:var(--sans);font-size:13px;border:1px solid var(--line);background:#fff;border-radius:20px;padding:8px 16px;color:var(--muted);cursor:pointer;}
.jhc-pill.is-on{background:var(--green);color:#fff;border-color:var(--green);}

.jhc-job{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.jhc-job-main{min-width:0;}
.jhc-job h3{font-family:var(--serif);font-size:18px;font-weight:600;margin:0 0 8px;}
.jhc-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;}
.jhc-tag{font-family:var(--mono);font-size:10px;background:var(--paper2);color:var(--muted);padding:3px 9px;border-radius:6px;}
.jhc-meta{display:flex;gap:16px;font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-bottom:8px;}
.jhc-desc{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0;max-width:620px;}
.jhc-apply{background:rgba(46,158,110,.12);color:var(--greend);border:1px solid rgba(46,158,110,.3);border-radius:11px;padding:12px 22px;font-family:var(--sans);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;}
.jhc-apply:hover{background:var(--green);color:#fff;}
.jhc-empty{color:var(--muted);}

/* modal */
.jhc-modal{position:fixed;inset:0;background:rgba(11,38,32,.5);display:none;z-index:99999;align-items:center;justify-content:center;padding:20px;}
.jhc-modal.open{display:flex;}
.jhc-modal-box{background:var(--paper);border-radius:16px;width:560px;max-width:100%;max-height:92vh;overflow-y:auto;padding:30px;position:relative;}
.jhc-x{position:absolute;top:16px;right:18px;background:none;border:0;font-size:26px;color:var(--muted);cursor:pointer;line-height:1;}
.jhc-modal-head{margin-bottom:18px;}
.jhc-modal-head h3{font-family:var(--serif);font-size:22px;font-weight:600;margin:6px 0 0;}
.jhc-row{display:flex;gap:12px;}
.jhc-field{flex:1;margin-bottom:13px;min-width:0;}
.jhc-field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;}
.jhc-field input,.jhc-field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-family:var(--sans);font-size:14px;background:#fff;color:var(--text);}
.jhc-field textarea{resize:vertical;line-height:1.5;}
.jhc-submit{background:var(--green);color:#fff;border:0;border-radius:11px;padding:13px 22px;font-family:var(--sans);font-size:14.5px;font-weight:600;cursor:pointer;width:100%;margin-top:6px;}
.jhc-submit:hover{background:var(--greend);}
.jhc-note{font-size:12px;color:var(--faint);text-align:center;margin-top:10px;}
.jhc-success{text-align:center;padding:24px 10px;display:none;}
.jhc-success.show{display:block;}
.jhc-form.hide{display:none;}
.jhc-tick{width:60px;height:60px;border-radius:50%;background:var(--green);color:#fff;font-size:30px;display:grid;place-items:center;margin:0 auto 16px;}
.jhc-success h3{font-family:var(--serif);font-size:22px;margin:0 0 8px;}
.jhc-success p{color:var(--muted);font-size:14px;margin:0 0 18px;}

/* chatbot */
.jhc-bot-btn{position:fixed;bottom:26px;right:26px;width:56px;height:56px;border-radius:50%;background:var(--green);color:#fff;border:0;display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 30px -8px rgba(46,158,110,.6);z-index:99998;}
.jhc-bot{position:fixed;bottom:94px;right:26px;width:360px;max-width:calc(100vw - 40px);background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:none;flex-direction:column;box-shadow:0 24px 60px -20px rgba(11,38,32,.4);z-index:99998;}
.jhc-bot.open{display:flex;}
.jhc-bot-head{background:var(--ink);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:14px;}
.jhc-bot-head button{background:none;border:0;color:rgba(255,255,255,.7);font-size:22px;cursor:pointer;line-height:1;}
.jhc-bot-log{padding:16px;max-height:330px;min-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;background:var(--paper);}
.jhc-msg{max-width:85%;padding:10px 13px;border-radius:12px;font-size:13.5px;line-height:1.5;}
.jhc-msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;}
.jhc-msg.me{background:var(--green);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;}
.jhc-msg.typing{color:var(--faint);font-style:italic;}
.jhc-bot-in{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);}
.jhc-bot-in input{flex:1;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-family:var(--sans);font-size:13.5px;}
.jhc-bot-in button{background:var(--green);color:#fff;border:0;border-radius:9px;padding:0 16px;font-weight:600;cursor:pointer;font-size:13px;}

@media(max-width:680px){.jhc-job{flex-direction:column;align-items:flex-start;}.jhc-row{flex-direction:column;}.jhc-hero{padding:34px 26px;}.jhc-hero h2{font-size:27px;}}

.jhc-fileinput{display:block;width:100%;font-size:13px;color:var(--jhc-text,#14241E);padding:10px;border:1px dashed #BFD8C9;border-radius:10px;background:#F4F6F3;cursor:pointer;}
.jhc-fileinput::-webkit-file-upload-button{background:#2E9E6E;color:#fff;border:0;padding:7px 12px;border-radius:7px;margin-right:10px;cursor:pointer;font-family:inherit;}

.jhc-job-title{cursor:pointer;transition:color .15s;}
.jhc-job-title:hover{color:#2E9E6E;}
.jhc-details{background:none;border:0;color:#2E9E6E;font-weight:600;font-size:13px;cursor:pointer;padding:6px 0 0;font-family:inherit;}
.jhc-details:hover{text-decoration:underline;}
.jhc-jd-box{max-width:640px;}
.jhc-jd-body{font-size:14.5px;line-height:1.7;color:#33433B;margin:14px 0 20px;max-height:46vh;overflow-y:auto;}
.jhc-jd-body h1,.jhc-jd-body h2,.jhc-jd-body h3{font-family:"Fraunces",Georgia,serif;color:#14241E;margin:16px 0 8px;}
.jhc-jd-body ul,.jhc-jd-body ol{margin:8px 0 8px 20px;}
.jhc-jd-body p{margin:0 0 10px;}
