/* ═══════════════════════════════════════════════
   JUDE.WORKS — SHARED DESIGN SYSTEM v3
   Single external CSS file loaded by all 6 pages
   ═══════════════════════════════════════════════ */

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,svg{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ── TOKENS ── */
:root{
  --forest:#1A3C2E;
  --moss:#2D6A4F;
  --mint:#52B788;
  --cream:#F5F2EA;
  --cream-dk:#EAE6DB;
  --charcoal:#111A14;
  --text:#1A2417;
  --muted:#6B7A6A;
  --amber:#D97706;
  --red:#DC2626;
  --purple:#7C3AED;
  --sky:#0EA5E9;
  --white:#FFFFFF;

  --nav-h:72px;
  --container:1280px;

  --r-sm:8px;
  --r-md:12px;
  --r-lg:16px;
  --r-xl:20px;
  --r-2xl:28px;

  --shadow-sm:0 1px 4px rgba(0,0,0,.05),0 2px 8px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.05);
  --shadow-lg:0 8px 32px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.06);

  --font-display:'DM Serif Display',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;

  --fs-hero:clamp(2.4rem,5vw,4.2rem);
  --fs-h1:clamp(1.8rem,3.5vw,3rem);
  --fs-h2:clamp(1.4rem,2.5vw,2rem);
  --fs-h3:clamp(1.1rem,1.8vw,1.4rem);
  --fs-body:clamp(0.9rem,1.2vw,1rem);
  --fs-sm:clamp(0.8rem,1vw,0.875rem);
}

/* ── BODY ── */
body{
  font-family:var(--font-body);
  font-size:var(--fs-body);
  color:var(--text);
  background:var(--cream);
  padding-top:var(--nav-h);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

/* ── LAYOUT ── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem)}
.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section-sm{padding:clamp(2rem,4vw,3.5rem) 0}

/* ── TYPOGRAPHY ── */
h1,h2,h3,.display{font-family:var(--font-display);line-height:1.15;color:var(--forest)}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{line-height:1.7}
.text-muted{color:var(--muted)}
.text-mint{color:var(--mint)}
.text-forest{color:var(--forest)}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:clamp(9px,1.3vw,12px) clamp(16px,2.2vw,24px);
  border-radius:var(--r-md);
  font-family:var(--font-body);font-size:var(--fs-sm);font-weight:600;
  cursor:pointer;border:2px solid transparent;
  transition:all .18s;white-space:nowrap;
}
.btn-mint{background:var(--mint);color:white}
.btn-mint:hover{background:#3DA574;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-forest{background:var(--forest);color:white}
.btn-forest:hover{background:var(--moss);transform:translateY(-1px)}
.btn-outline{background:transparent;border-color:rgba(255,255,255,.35);color:white}
.btn-outline:hover{background:rgba(255,255,255,.08);border-color:white}
.btn-outline-dark{background:transparent;border-color:rgba(26,60,46,.2);color:var(--forest)}
.btn-outline-dark:hover{background:rgba(26,60,46,.05);border-color:var(--moss)}
.btn-ghost{background:transparent;color:rgba(255,255,255,.6);padding:13px 20px;border:none}
.btn-ghost:hover{color:white;background:rgba(255,255,255,.06)}
.btn-sm{padding:6px 14px;font-size:12.5px}
.btn-lg{padding:clamp(12px,1.8vw,15px) clamp(20px,3vw,32px);font-size:clamp(0.9rem,1.3vw,1.05rem)}

/* ── CARD ── */
.card{background:var(--white);border-radius:var(--r-xl);border:1px solid rgba(26,60,46,.07);box-shadow:var(--shadow-sm)}
.card-pad{padding:clamp(16px,2.5vw,28px)}

/* ── FORM ── */
.input{
  width:100%;padding:11px 14px;
  background:white;border:1.5px solid rgba(26,60,46,.14);
  border-radius:var(--r-md);
  font-family:var(--font-body);font-size:15px;color:var(--text);
  outline:none;transition:border-color .2s,box-shadow .2s;
}
.input:focus{border-color:var(--mint);box-shadow:0 0 0 3px rgba(82,183,136,.1)}
.input::placeholder{color:var(--muted)}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7A6A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.input-lbl{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px}
.input-grp{margin-bottom:16px}

/* ── TOGGLE ── */
.toggle{
  width:38px;height:21px;border-radius:11px;
  background:rgba(26,60,46,.12);cursor:pointer;
  position:relative;transition:background .2s;border:none;flex-shrink:0;
}
.toggle.on{background:var(--mint)}
.toggle::after{
  content:'';position:absolute;
  width:15px;height:15px;border-radius:50%;
  background:white;top:3px;left:3px;
  transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle.on::after{transform:translateX(17px)}

/* ── CHIPS ── */
.chip{
  padding:6px 14px;border-radius:20px;
  font-size:12.5px;font-weight:600;cursor:pointer;
  border:1.5px solid rgba(26,60,46,.14);
  color:var(--muted);background:white;transition:all .15s;
}
.chip:hover,.chip.on{background:var(--forest);color:white;border-color:var(--forest)}

/* ── TAGS ── */
.tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}
.tag-default{background:var(--cream-dk);color:var(--muted)}
.tag-green{background:rgba(82,183,136,.1);color:var(--moss);border:1px solid rgba(82,183,136,.22)}
.tag-amber{background:rgba(217,119,6,.08);color:var(--amber)}
.tag-sky{background:rgba(14,165,233,.08);color:#0284C7}
.tag-purple{background:rgba(124,58,237,.08);color:var(--purple)}
.tag-red{background:rgba(220,38,38,.08);color:var(--red)}
.badge-perm{background:rgba(82,183,136,.1);color:var(--moss);font-weight:600}
.badge-contract{background:rgba(217,119,6,.08);color:var(--amber);font-weight:600}
.badge-parttime{background:rgba(14,165,233,.08);color:#0284C7;font-weight:600}
.badge-ir35-outside{background:rgba(82,183,136,.1);color:var(--moss);font-weight:600}
.badge-ir35-inside{background:rgba(217,119,6,.08);color:var(--amber);font-weight:600}

/* ── BADGE ── */
.badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}
.badge-mint{background:var(--mint);color:var(--forest)}
.badge-amber{background:var(--amber);color:white}
.badge-employer{font-size:9px;font-weight:700;background:rgba(82,183,136,.15);color:var(--mint);padding:3px 8px;border-radius:6px;margin-left:8px;text-transform:uppercase;letter-spacing:.6px;vertical-align:middle;border:1px solid rgba(82,183,136,.25)}
.badge-seeker{font-size:9px;font-weight:700;background:rgba(14,165,233,.12);color:var(--sky);padding:3px 8px;border-radius:6px;margin-left:8px;text-transform:uppercase;letter-spacing:.6px;vertical-align:middle;border:1px solid rgba(14,165,233,.2)}

/* ── NAVIGATION ── */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);background:var(--forest);
  border-bottom:1px solid rgba(82,183,136,.15);
}
.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:clamp(1.5rem,2.5vw,1.9rem);font-weight:400;color:white;letter-spacing:-.02em;line-height:1}
.logo-dot{color:var(--mint)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  color:rgba(255,255,255,.6);font-size:14px;font-weight:500;
  padding:7px 13px;border-radius:20px;transition:all .2s;white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{background:rgba(82,183,136,.15);color:var(--mint)}
.nav-badge{font-size:10px;font-weight:700;background:var(--mint);color:var(--forest);padding:2px 7px;border-radius:10px;margin-left:4px;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}
.nav-cta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:all .3s}
.mobile-menu{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;
  background:var(--forest);border-bottom:1px solid rgba(82,183,136,.15);
  padding:1rem;z-index:999;flex-direction:column;gap:4px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  color:rgba(255,255,255,.7);padding:11px 16px;border-radius:10px;
  font-size:15px;font-weight:500;transition:all .2s;
}
.mobile-menu a:hover,.mobile-menu a.active{background:rgba(82,183,136,.12);color:var(--mint)}
.mobile-cta{display:flex;gap:8px;padding:10px 0 4px}
.mobile-cta a{flex:1;justify-content:center}

/* ── APP LAYOUT (sidebar pages) ── */
.app-layout{display:flex;min-height:calc(100vh - var(--nav-h))}
.sidebar{
  width:clamp(200px,18vw,252px);background:var(--forest);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;
  overflow-y:auto;flex-shrink:0;
  z-index:100;
}
.sb-logo{padding:clamp(14px,2vw,20px);border-bottom:1px solid rgba(82,183,136,.12)}
.sb-profile{
  margin:clamp(10px,1.5vw,14px);padding:clamp(10px,1.5vw,14px);
  background:rgba(255,255,255,.06);border-radius:14px;border:1px solid rgba(82,183,136,.1);
}
.sb-avatar{
  width:40px;height:40px;border-radius:50%;background:var(--moss);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:var(--mint);margin-bottom:7px;
}
.sb-name{font-size:14px;font-weight:700;color:white}
.sb-role{font-size:11.5px;color:var(--muted)}
.sb-section{
  padding:clamp(10px,1.5vw,14px) clamp(14px,2vw,20px) 4px;
  font-size:9.5px;font-weight:700;letter-spacing:1.2px;
  color:rgba(82,183,136,.45);text-transform:uppercase;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px clamp(14px,2vw,20px);
  color:rgba(255,255,255,.55);font-size:13.5px;
  transition:all .18s;border-left:3px solid transparent;
}
.nav-item:hover{color:white;background:rgba(255,255,255,.04)}
.nav-item.active{color:white;background:rgba(82,183,136,.1);border-left-color:var(--mint);font-weight:600}
.nb{margin-left:auto}
.sb-foot{padding:clamp(10px,1.5vw,14px) clamp(14px,2vw,20px);border-top:1px solid rgba(82,183,136,.08);margin-top:auto}
.pbar-lbl{display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.35);margin-bottom:5px}
.pbar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.pbar-fill{height:100%;background:linear-gradient(90deg,var(--moss),var(--mint));border-radius:2px}
.main-content{flex:1;padding:clamp(24px,3.5vw,40px) clamp(20px,3vw,36px);min-width:0;overflow-x:hidden;margin-left:clamp(200px,18vw,252px)}
.page-hdr{margin-bottom:clamp(24px,3vw,36px)}
.page-hdr h1{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--forest);margin-bottom:6px;line-height:1.15}
.page-hdr p{font-size:var(--fs-body);color:var(--muted);max-width:60ch;line-height:1.7}
.sec-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(14px,2vw,20px);flex-wrap:wrap;gap:8px}
.sec-hdr h2{font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.4rem);color:var(--forest)}

/* ── FOOTER ── */
.site-footer{
  background:var(--charcoal);color:rgba(255,255,255,.55);
  padding:clamp(3rem,6vw,5rem) 0 clamp(1.5rem,3vw,2.5rem);
}
.app-layout ~ .site-footer{margin-left:clamp(200px,18vw,252px)}
.footer-grid{
  display:grid;grid-template-columns:2fr repeat(3,1fr);
  gap:clamp(2rem,4vw,4rem);margin-bottom:clamp(2rem,4vw,3rem);
}
.footer-brand .logo-text{font-size:clamp(1.3rem,2vw,1.6rem)}
.footer-brand p{font-size:13px;line-height:1.7;max-width:28ch;color:rgba(255,255,255,.4);margin-top:.75rem}
.footer-social{display:flex;gap:10px;margin-top:1.25rem}
.social-btn{
  width:34px;height:34px;border-radius:8px;
  background:rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:13px;font-weight:700;
  transition:all .2s;
}
.social-btn:hover{background:rgba(82,183,136,.15);color:var(--mint)}
.footer-col h4{color:white;font-size:13px;font-weight:700;margin-bottom:.75rem}
.footer-col ul{display:flex;flex-direction:column;gap:.4rem}
.footer-col li a{font-size:13px;color:rgba(255,255,255,.4);transition:color .2s}
.footer-col li a:hover{color:var(--mint)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding-top:clamp(1rem,2vw,1.5rem);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem;
  font-size:12px;color:rgba(255,255,255,.3);
}
.footer-bottom a{color:rgba(255,255,255,.38);transition:color .2s}
.footer-bottom a:hover{color:var(--mint)}
.footer-legal{display:flex;gap:1.25rem;flex-wrap:wrap}

/* ── SKILL BAR ── */
.sbar-wrap{margin-bottom:14px}
.sbar-hdr{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:5px;font-weight:500;color:var(--text)}
.sbar-pct{font-weight:700}
.sbar-track{height:7px;background:var(--cream-dk);border-radius:4px;overflow:hidden}
.sbar-fill{height:100%;border-radius:4px}

/* ── MATCH RING ── */
.match-ring-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;width:56px}
.match-ring-inner{position:relative;width:48px;height:48px}
.match-ring-inner svg{position:absolute;inset:0;transform:rotate(-90deg)}
.match-ring-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:var(--forest)}
.match-ring-label{font-size:9px;font-weight:700;color:var(--muted);text-align:center;line-height:1.2;max-width:56px;word-break:break-word}

/* ── JOB CARD ── */
.job-card{
  background:white;border-radius:var(--r-xl);border:1px solid rgba(26,60,46,.08);
  padding:clamp(16px,2vw,22px);display:flex;gap:14px;align-items:flex-start;
  box-shadow:var(--shadow-sm);transition:all .2s;
}
.job-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:rgba(82,183,136,.2)}
.job-logo{
  width:46px;height:46px;border-radius:12px;
  background:var(--cream-dk);display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;font-weight:700;color:var(--forest);
}
.job-body{flex:1;min-width:0}
.job-title{font-size:clamp(14px,1.3vw,15.5px);font-weight:700;color:var(--forest);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-company{font-size:13px;color:var(--muted);margin-bottom:8px}
.job-tags{display:flex;flex-wrap:wrap;gap:5px}
.job-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--cream-dk)}
.job-salary{font-size:13.5px;font-weight:700;color:var(--forest)}
.job-posted{font-size:11.5px;color:var(--muted)}

/* ── TIMELINE ── */
.timeline{position:relative;padding-left:0}
.timeline::before{content:'';position:absolute;left:15px;top:24px;bottom:24px;width:2px;background:var(--cream-dk)}
.titem{display:flex;gap:clamp(12px,2vw,18px);align-items:flex-start;padding-bottom:clamp(16px,2vw,22px);position:relative}
.tdot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;z-index:1}
.tdot-done{background:var(--mint);color:white}
.tdot-active{background:var(--forest);color:white;box-shadow:0 0 0 4px rgba(82,183,136,.2)}
.tdot-todo{background:white;border:2px solid var(--cream-dk);color:var(--muted)}
.tbody h4{font-size:clamp(13px,1.2vw,14.5px);font-weight:600;color:var(--forest);margin-bottom:2px}
.tbody p{font-size:12px;color:var(--muted)}

/* ── AI INSIGHT BOX ── */
.ai-box{
  background:rgba(82,183,136,.05);border:1px solid rgba(82,183,136,.18);
  border-radius:12px;padding:clamp(12px,2vw,16px);margin-top:clamp(14px,2vw,18px);
}
.ai-box-lbl{font-size:11.5px;font-weight:700;color:var(--moss);margin-bottom:6px}
.ai-box p{font-size:13px;color:var(--text);line-height:1.65}

/* ── STAT CARD ── */
.stat-c{background:white;border-radius:var(--r-lg);border:1px solid rgba(26,60,46,.07);padding:clamp(16px,2vw,22px);box-shadow:var(--shadow-sm)}
.stat-lbl{font-size:12.5px;color:var(--muted);margin-bottom:6px;font-weight:500}
.stat-num{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.4rem);color:var(--forest);line-height:1}
.stat-sub{font-size:12px;color:var(--mint);margin-top:4px;font-weight:500}

/* ── CHAT ── */
.chat-layout{display:flex;height:calc(100vh - var(--nav-h));overflow:hidden}
.chat-threads{width:clamp(200px,18vw,240px);background:var(--forest);border-right:1px solid rgba(82,183,136,.12);display:flex;flex-direction:column;flex-shrink:0}
.chat-threads-hdr{padding:clamp(14px,2vw,20px);border-bottom:1px solid rgba(82,183,136,.12)}
.chat-threads-hdr h2{font-size:14px;font-weight:700;color:white}
.thread-item{padding:12px clamp(14px,2vw,18px);border-left:3px solid transparent;cursor:pointer;transition:all .18s}
.thread-item:hover{background:rgba(255,255,255,.04)}
.thread-item.active{background:rgba(82,183,136,.1);border-left-color:var(--mint)}
.thread-title{font-size:13px;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.thread-meta{font-size:11px;color:rgba(255,255,255,.35)}
.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--cream)}
.chat-topbar{padding:clamp(12px,1.8vw,16px) clamp(16px,2vw,24px);background:white;border-bottom:1px solid rgba(26,60,46,.07);display:flex;align-items:center;gap:12px}
.chat-messages{flex:1;overflow-y:auto;padding:clamp(16px,2.5vw,28px);display:flex;flex-direction:column;gap:clamp(14px,2vw,18px)}
.msg-wrap{display:flex;gap:10px;align-items:flex-start;max-width:80%}
.msg-wrap.user{align-self:flex-end;flex-direction:row-reverse}
.msg-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.msg-bubble{padding:clamp(10px,1.5vw,13px) clamp(12px,1.8vw,16px);border-radius:16px;font-size:14px;line-height:1.65}
.msg-jude .msg-bubble{background:white;border:1px solid rgba(26,60,46,.07);border-radius:4px 16px 16px 16px;box-shadow:var(--shadow-sm)}
.msg-user .msg-bubble{background:var(--forest);color:white;border-radius:16px 16px 4px 16px}
.msg-time{font-size:10.5px;color:var(--muted);margin-top:4px;text-align:right}
.chat-input-bar{padding:clamp(12px,1.8vw,16px) clamp(16px,2vw,24px);background:white;border-top:1px solid rgba(26,60,46,.07)}
.chat-input-wrap{display:flex;gap:10px;align-items:flex-end;background:var(--cream);border:1.5px solid rgba(26,60,46,.14);border-radius:var(--r-xl);padding:8px 8px 8px 16px;transition:border-color .2s}
.chat-input-wrap:focus-within{border-color:var(--mint)}
.chat-input{flex:1;background:none;border:none;outline:none;resize:none;font-family:var(--font-body);font-size:14.5px;color:var(--text);max-height:120px;padding:4px 0}
.chat-send{width:36px;height:36px;border-radius:50%;background:var(--forest);border:none;color:white;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.chat-send:hover{background:var(--moss)}
.chat-ctx{width:clamp(200px,18vw,232px);background:white;border-left:1px solid rgba(26,60,46,.07);overflow-y:auto;flex-shrink:0}
.chat-ctx-hdr{padding:clamp(14px,2vw,18px);border-bottom:1px solid rgba(26,60,46,.07);font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.chat-ctx-body{padding:clamp(12px,1.8vw,16px)}
.ctx-row{margin-bottom:14px}
.ctx-lbl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}
.ctx-val{font-size:13px;color:var(--text);font-weight:500}

/* ── SUGGESTED QUESTIONS ── */
.suggested-q{
  background:white;border:1px solid rgba(82,183,136,.2);border-radius:10px;
  padding:10px 14px;font-size:13px;color:var(--moss);cursor:pointer;
  transition:all .18s;text-align:left;width:100%;margin-bottom:8px;font-family:var(--font-body);
}
.suggested-q:hover{background:rgba(82,183,136,.05);border-color:var(--mint)}

/* ── DROP ZONE ── */
.drop-zone{
  border:2px dashed rgba(26,60,46,.2);border-radius:16px;
  padding:clamp(24px,4vw,40px) 20px;text-align:center;
  cursor:pointer;transition:all .2s;background:white;
}
.drop-zone:hover{border-color:var(--mint);background:rgba(82,183,136,.02)}

/* ── COURSE CARD ── */
.course-card{background:white;border-radius:var(--r-lg);border:1px solid rgba(26,60,46,.08);padding:clamp(14px,2vw,20px);margin-bottom:10px;display:flex;align-items:flex-start;gap:12px;box-shadow:var(--shadow-sm)}
.course-card:last-child{margin-bottom:0}
.course-accent{width:3px;align-self:stretch;border-radius:2px;flex-shrink:0}
.course-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.course-title{font-size:clamp(13px,1.2vw,15px);font-weight:700;color:var(--forest);margin-bottom:3px}
.course-meta{font-size:12px;color:var(--muted)}

/* ── MOBILE BREAKPOINTS ── */
@media(max-width:1024px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
}
@media(max-width:860px){
  .sidebar{display:none}
  .main-content{padding:clamp(16px,3vw,24px);margin-left:0}
  .app-layout ~ .site-footer{margin-left:0}
  .chat-threads{display:none}
  .chat-ctx{display:none}
}
@media(max-width:640px){
  :root{--nav-h:56px}
  body{overflow-x:hidden}
  .logo-text{font-size:1.4rem}
  .container{padding:0 20px}
  .job-card{flex-wrap:wrap}
  .match-ring-wrap{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{justify-content:center}
}

/* ── DROPDOWN ── */
.dropdown-menu{display:none;position:absolute;top:100%;right:0;background:white;border:1.5px solid rgba(26,60,46,.1);border-radius:var(--r-lg);box-shadow:var(--shadow-md);min-width:180px;z-index:100;margin-top:6px;padding:6px 0}
.dropdown-menu.show{display:block}
.dropdown-menu a{display:block;padding:10px 16px;font-size:13px;color:var(--forest);text-decoration:none;transition:background .15s}
.dropdown-menu a:hover{background:rgba(82,183,136,.06)}

/* ── ACCESSIBILITY ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── LANDING / HOMEPAGE ── */
.landing-dark{background:linear-gradient(135deg,#1A3C2E 0%,#2D5A3D 60%,#1A3C2E 100%);color:white;position:relative;overflow:hidden}
.landing-dark>*{position:relative;z-index:1}
.hero-section{padding:clamp(3rem,8vw,5rem) 0 clamp(2rem,5vw,3.5rem);position:relative;overflow:hidden}
.hero-section::before{content:'';position:absolute;top:-200px;right:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(134,239,172,.12) 0%,transparent 70%);pointer-events:none;z-index:0}
.hero-section>*{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,380px),1fr));gap:clamp(2rem,5vw,3.5rem);align-items:center}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(82,183,136,.14);border:1px solid rgba(82,183,136,.28);border-radius:20px;padding:6px 14px;font-size:11.5px;font-weight:600;color:var(--mint);margin-bottom:18px}
.hero-pulse{width:6px;height:6px;border-radius:50%;background:var(--mint);animation:pulse 2s infinite;flex-shrink:0}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);line-height:1.1;color:white;margin-bottom:18px}
.hero-title em{color:var(--mint);font-style:italic}
.hero-desc{font-size:clamp(14px,1.5vw,16px);color:rgba(255,255,255,.65);line-height:1.65;margin-bottom:28px;max-width:440px}
.hero-desc em{font-style:italic}
.hero-ctas{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:36px}
.hero-stats{display:flex;gap:clamp(16px,3vw,28px);padding-top:24px;border-top:1px solid rgba(82,183,136,.14);flex-wrap:wrap}
.hero-stat-num{font-family:var(--font-display);font-size:clamp(20px,2.5vw,26px);color:white;line-height:1}
.hero-stat-lbl{font-size:11.5px;color:rgba(255,255,255,.7);margin-top:2px}
.hero-card{background:rgba(255,255,255,.07);backdrop-filter:blur(12px);border:1px solid rgba(82,183,136,.2);border-radius:22px;padding:clamp(18px,2.5vw,26px)}
.hero-card-hdr{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--mint);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.hero-card-hdr::after{content:'';flex:1;height:1px;background:rgba(82,183,136,.2)}
.hero-job-row{background:rgba(255,255,255,.06);border:1px solid rgba(82,183,136,.14);border-radius:14px;padding:clamp(10px,1.5vw,14px);margin-bottom:8px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s}
.hero-job-row:hover{background:rgba(255,255,255,.1)}
.hero-job-logo{width:38px;height:38px;border-radius:10px;background:rgba(82,183,136,.14);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--mint);flex-shrink:0}
.hero-job-title{font-size:clamp(12px,1.3vw,13.5px);font-weight:600;color:white}
.hero-job-info{flex:1;min-width:0}
.hero-job-sub{font-size:11.5px;color:rgba(255,255,255,.45)}
.hero-job-match{font-size:clamp(16px,2vw,20px);font-weight:700;color:var(--mint);text-align:right}
.hero-job-match-lbl{font-size:9px;color:rgba(255,255,255,.35);text-align:right}
.hero-gap-bar{padding-top:14px;border-top:1px solid rgba(82,183,136,.14);margin-top:6px}
.hero-gap-row{display:flex;justify-content:space-between;margin-bottom:7px;font-size:11.5px}
.hero-gap-lbl{color:rgba(255,255,255,.45)}
.hero-gap-val{color:var(--mint);font-weight:600}
.hero-progress-track{height:5px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}
.hero-progress-fill{height:100%;background:linear-gradient(90deg,var(--moss),var(--mint));border-radius:3px}

.ticker-strip{background:#0D1F16;border-top:none;border-bottom:none;padding:13px 0;overflow-x:auto}
.ticker-inner{display:flex;gap:clamp(18px,3vw,36px);padding:0 clamp(1rem,4vw,2.5rem);white-space:nowrap}
.ticker-item{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.8);white-space:nowrap;flex-shrink:0}
.ticker-item strong{color:var(--mint)}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:clamp(12px,1.5vw,18px)}
.feature-card{background:rgba(255,255,255,.06);border:1px solid rgba(82,183,136,.18);border-radius:20px;padding:clamp(18px,2.5vw,26px);transition:background .2s,border-color .2s}
.feature-card:hover{background:rgba(255,255,255,.09);border-color:rgba(82,183,136,.32)}
.feature-icon{width:46px;height:46px;border-radius:50%;background:rgba(82,183,136,.14);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px;border:1px solid rgba(82,183,136,.28)}
.feature-card h3{font-size:clamp(14px,1.3vw,15.5px);font-weight:700;color:white;margin-bottom:7px;font-family:var(--font-body)}
.feature-card p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6}

.who-posts-title{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,1.9rem);color:white;margin-bottom:5px}
.who-posts-desc{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:24px}
.who-posts-grid{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.poster-card{min-width:160px;padding:clamp(14px,2vw,18px);border-radius:16px;flex-shrink:0;transition:transform .2s,background .2s;background:rgba(255,255,255,.06)}
.poster-card:hover{transform:translateY(-2px);background:rgba(255,255,255,.1)}
.poster-card .poster-emoji{font-size:28px;margin-bottom:9px;display:block}
.poster-card h4{font-size:13px;font-weight:700;margin-bottom:3px}
.poster-card p{font-size:11.5px;color:rgba(255,255,255,.45)}
.poster-company{border:1.5px solid rgba(82,183,136,.4)}
.poster-company h4{color:var(--mint)}
.poster-recruiter{border:1.5px solid rgba(14,165,233,.4)}
.poster-recruiter h4{color:#7DD3FC}
.poster-gov{border:1.5px solid rgba(167,139,250,.4)}
.poster-gov h4{color:#C4B5FD}
.poster-edu{border:1.5px solid rgba(251,191,36,.4)}
.poster-edu h4{color:#FDE68A}
.poster-nhs{border:1.5px solid rgba(248,113,113,.4)}
.poster-nhs h4{color:#FCA5A5}

/* ── HOMEPAGE MOBILE BREAKPOINTS ── */
@media(max-width:1024px){
  .hero-card{max-width:480px}
  .hero-stats{gap:1.5rem}
}
@media(max-width:640px){
  .landing-dark{overflow-x:hidden}
  .hero-section{padding:1.5rem 20px 1rem}
  .hero-pill{font-size:10px;padding:5px 10px;margin-bottom:12px}
  .hero-title{font-size:1.6rem;margin-bottom:12px}
  .hero-desc{font-size:13px;margin-bottom:16px;line-height:1.5}
  .hero-ctas{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:16px}
  .hero-ctas .btn{justify-content:center;text-align:center;padding:12px 16px;font-size:14px}
  .hero-stats{flex-direction:row;gap:1rem;flex-wrap:wrap;padding-top:16px}
  .hero-stat-num{font-size:18px}
  .hero-stat-lbl{font-size:10px}
  .hero-grid{gap:1.5rem}
  .hero-card{padding:14px;margin-left:0;margin-right:0}
  .hero-card-hdr{font-size:9px;margin-bottom:10px}
  .hero-job-row{padding:8px;gap:8px;margin-bottom:6px}
  .hero-job-logo{width:30px;height:30px;font-size:7px;border-radius:8px}
  .hero-job-title{font-size:12px}
  .hero-job-sub{font-size:10px}
  .hero-job-match{font-size:15px}
  .hero-job-match-lbl{font-size:8px}
  .hero-gap-bar{padding-top:10px}
  .hero-gap-row{font-size:10px;margin-bottom:5px}
  .hero-progress-track{height:4px}
  .ticker-strip{overflow:hidden;padding:10px 20px}
  .ticker-item{font-size:11px}
  .features-grid{grid-template-columns:1fr;gap:12px}
  .feature-card{padding:16px}
  .feature-icon{width:38px;height:38px;font-size:18px;margin-bottom:10px}
  .feature-card h3{font-size:14px}
  .feature-card p{font-size:12px}
  .who-posts-title{font-size:1.3rem}
  .who-posts-desc{font-size:13px;margin-bottom:16px}
  .who-posts-grid{gap:8px}
  .poster-card{min-width:130px;padding:12px}
  .poster-card .poster-emoji{font-size:22px;margin-bottom:6px}
  .poster-card h4{font-size:12px}
  .poster-card p{font-size:10px}
}

/* ── BLOG ── */
.blog-page{background:var(--cream);min-height:60vh}
.blog-header{text-align:center;margin-bottom:clamp(2rem,4vw,3.5rem)}
.blog-page-title{font-family:var(--font-display);font-size:var(--fs-h1);color:var(--forest);margin-bottom:8px}
.blog-page-desc{font-size:var(--fs-body);color:var(--muted);max-width:50ch;margin:0 auto;line-height:1.7}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));gap:clamp(16px,2.5vw,24px)}
.blog-card{display:flex;flex-direction:column;padding:clamp(20px,2.5vw,28px);border-radius:var(--r-xl);transition:all .2s;text-decoration:none;color:inherit}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:rgba(82,183,136,.2)}
.blog-category{align-self:flex-start;margin-bottom:12px}
.blog-card-title{font-family:var(--font-display);font-size:var(--fs-h3);color:var(--forest);margin-bottom:10px;line-height:1.25}
.blog-card-excerpt{font-size:var(--fs-sm);color:var(--muted);line-height:1.65;margin-bottom:16px;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-meta{font-size:12px;color:var(--muted);display:flex;gap:8px;align-items:center;margin-bottom:12px}
.blog-card-link{font-size:var(--fs-sm);font-weight:600;color:var(--mint);margin-top:auto}
.blog-card:hover .blog-card-link{color:var(--moss)}
.blog-empty{text-align:center;padding:clamp(3rem,6vw,5rem) 1rem}
.blog-empty-icon{font-size:3rem;margin-bottom:16px;opacity:.5}
.blog-empty h2{font-family:var(--font-display);font-size:var(--fs-h2);color:var(--forest);margin-bottom:8px}
.blog-empty p{font-size:var(--fs-body);color:var(--muted);max-width:44ch;margin:0 auto;line-height:1.7}
.blog-error{background:rgba(220,38,38,.08);color:var(--red);padding:12px 16px;border-radius:var(--r-md);margin-bottom:20px;font-size:14px;border:1px solid rgba(220,38,38,.15)}
.blog-back{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:600;color:var(--moss);margin-bottom:24px;transition:color .2s}
.blog-back:hover{color:var(--forest)}
.blog-article-header{margin-bottom:clamp(24px,4vw,40px);max-width:720px}
.blog-article-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--forest);line-height:1.15;margin-bottom:12px}
.blog-article-meta{font-size:var(--fs-sm);color:var(--muted);display:flex;gap:8px;align-items:center}
.blog-article-body{max-width:720px;font-size:clamp(15px,1.3vw,17px);line-height:1.8;color:var(--text)}
.blog-article-body h2{font-family:var(--font-display);font-size:var(--fs-h2);color:var(--forest);margin:2em 0 .75em}
.blog-article-body h3{font-family:var(--font-display);font-size:var(--fs-h3);color:var(--forest);margin:1.5em 0 .5em}
.blog-article-body p{margin-bottom:1.25em}
.blog-article-body ul,.blog-article-body ol{margin-bottom:1.25em;padding-left:1.5em}
.blog-article-body li{margin-bottom:.5em}
.blog-article-body ul{list-style:disc}
.blog-article-body ol{list-style:decimal}
.blog-article-body blockquote{border-left:3px solid var(--mint);padding:12px 20px;margin:1.5em 0;background:rgba(82,183,136,.04);border-radius:0 var(--r-md) var(--r-md) 0;color:var(--muted);font-style:italic}
.blog-article-body code{background:rgba(26,60,46,.06);padding:2px 6px;border-radius:4px;font-size:.9em}
.blog-article-body pre{background:var(--forest);color:rgba(255,255,255,.9);padding:clamp(16px,2vw,24px);border-radius:var(--r-md);overflow-x:auto;margin:1.5em 0;font-size:.88em;line-height:1.6}
.blog-article-body pre code{background:none;padding:0;color:inherit}
.blog-article-body a{color:var(--mint);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.blog-article-body a:hover{color:var(--moss)}
.blog-article-body strong{font-weight:700;color:var(--forest)}
.blog-article-footer{margin-top:clamp(2rem,4vw,3.5rem);padding-top:clamp(1.5rem,3vw,2rem);border-top:1px solid var(--cream-dk)}
.blog-form .input-grp{margin-bottom:20px}
.blog-body-input{min-height:360px;resize:vertical;font-family:var(--font-body);font-size:15px;line-height:1.65}
.blog-form-error{background:rgba(220,38,38,.08);color:var(--red);padding:12px 16px;border-radius:var(--r-md);margin-bottom:20px;font-size:14px;border:1px solid rgba(220,38,38,.15)}
.blog-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}

/* ── MOBILE / TOUCH IMPROVEMENTS ── */
@media(hover:none) and (pointer:coarse){
  .btn,.job-card,.feature-card,.poster-card,.hero-job-row{-webkit-tap-highlight-color:rgba(82,183,136,.12)}
  .btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .hamburger{min-width:44px;min-height:44px}
  .nav a,.dropdown-menu a,.mobile-menu a,.footer-links a{min-height:44px;display:flex;align-items:center}
  .job-card:hover,.feature-card:hover,.poster-card:hover,.blog-card:hover{transform:none}
}
@media(max-width:768px){
  .hero-section{padding-left:20px;padding-right:20px}
  .ticker-strip{padding-left:20px;padding-right:20px}
  .filter-chips{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;padding-bottom:4px}
  .filter-chips::-webkit-scrollbar{display:none}
  .filter-chip{flex-shrink:0}
}
.sticky-apply{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:white;border-top:1px solid rgba(26,60,46,.1);box-shadow:0 -4px 16px rgba(0,0,0,.08);z-index:100;display:none}
.sticky-apply .btn{width:100%;justify-content:center}
@media(max-width:640px){
  .sticky-apply{display:block}
  .job-detail-apply-desktop{display:none}
}
@media(min-width:641px) and (max-width:1024px){
  .container{max-width:960px}
  .hero-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .features-grid{grid-template-columns:repeat(2,1fr)}
}
/* ── ANIMATIONS ── */
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(82,183,136,.5)}50%{box-shadow:0 0 0 6px rgba(82,183,136,0)}}
@keyframes fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.fadein{animation:fadein .5s ease both}
.fadein-2{animation:fadein .5s .12s ease both}
.fadein-3{animation:fadein .5s .24s ease both}
