/* ============================================================
   ELMS TALENT GROUP — SHARED DESIGN SYSTEM
   Tokens, layout primitives, and site-wide components.
   Loaded by every page; page-specific styling lives inline.
   ============================================================ */

:root{
  --green:#3c6b4f;--green-light:#6fae87;--green-pale:#eef4f1;--green-mid:#4a7d5e;
  --green-glow:rgba(60,107,79,0.16);--green-bright:#2c4f3a;
  --bg:#f9f7f2;--bg-secondary:#f1ece2;--bg-card:#ffffff;
  --border:#e1dccd;--text-primary:#201c16;--text-secondary:#5a5346;--text-muted:#8a8270;
  --nav-bg:rgba(249,247,242,0.94);--shadow:rgba(32,28,22,0.07);--shadow-deep:rgba(32,28,22,0.15);
  --amber:#d98e3f;--amber-bright:#c87a2a;--amber-glow:rgba(217,142,63,0.2);--mist:#eaf0ec;
  --font-display:'Space Grotesk',system-ui,sans-serif;--font-body:'DM Sans',system-ui,sans-serif;--font-mono:'JetBrains Mono',monospace;
  --tr:0.2s cubic-bezier(0.4,0,0.2,1);--radius:14px;--radius-sm:8px;--radius-lg:22px;
  --logo-light:url("../images/logo-light.png");--logo-dark:url("../images/logo-dark.png");
  --nav-main-h:88px;--nav-h:var(--nav-main-h);
  --ink-deep:#0f1d16;--ink-darker:#0a1a0e;
}
[data-theme="dark"]{
  --green:#7ec99a;--green-light:#a8dab8;--green-pale:#17241a;--green-mid:#6baa88;
  --green-glow:rgba(126,201,154,0.14);--green-bright:#9fdcb6;
  --bg:#13160f;--bg-secondary:#181c13;--bg-card:#1c2017;--border:#2b3024;
  --text-primary:#eceee6;--text-secondary:#a5ac9b;--text-muted:#666e5c;
  --nav-bg:rgba(19,22,15,0.95);--shadow:rgba(0,0,0,0.4);--shadow-deep:rgba(0,0,0,0.6);
  --amber:#e0a25a;--amber-bright:#eeb678;--amber-glow:rgba(224,162,90,0.18);--mist:#1b241c;
  --ink-deep:#060e08;--ink-darker:#050d07;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.65;transition:background var(--tr),color var(--tr);overflow-x:hidden}
body.menu-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
::selection{background:var(--green-glow);color:var(--text-primary)}
:focus-visible{outline:2px solid var(--green);outline-offset:2px}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ===== TYPOGRAPHY ===== */
.display{font-family:var(--font-display);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.display-xl{font-size:clamp(2.75rem,5.2vw,4.6rem)}
.display-lg{font-size:clamp(2.2rem,3.6vw,3.3rem)}
.display-md{font-size:clamp(1.6rem,2.6vw,2.3rem)}
.label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green)}
.body-lg{font-size:1.02rem;line-height:1.75;color:var(--text-secondary)}

/* ===== LAYOUT ===== */
.container{max-width:1200px;margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
.section{padding:clamp(4.5rem,8vw,7.5rem) 0}
.section-sm{padding:clamp(3rem,5vw,4.5rem) 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-center{display:flex;align-items:center;justify-content:center}
.text-center{text-align:center}
.divider{width:2.25rem;height:2px;background:var(--green);margin:1.5rem 0;border-radius:2px}
.divider-center{margin-left:auto;margin-right:auto}

/* ===== LOGO ===== */
.logo-auto,img.logo-auto{content:var(--logo-light);height:clamp(72px,7.5vw,96px);width:auto;max-width:300px;object-fit:contain;display:block}
[data-theme="dark"] .logo-auto{content:var(--logo-dark)}
.logo-sm{content:var(--logo-light);height:clamp(52px,5.5vw,68px);width:auto;max-width:240px;object-fit:contain;display:block}
[data-theme="dark"] .logo-sm{content:var(--logo-dark)}
.footer-logo-img{content:var(--logo-dark);height:clamp(100px,10vw,130px);width:auto;max-width:360px;object-fit:contain;object-position:left center;display:block}
.nav-logo{display:flex;align-items:center;min-width:0;flex:0 1 auto}
@media(max-width:620px){
  .logo-auto,img.logo-auto{height:62px;max-width:240px}
  .footer-logo-img{height:80px;max-width:280px}
}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.875rem 1.9rem;font-family:var(--font-body);font-size:.86rem;font-weight:500;letter-spacing:.02em;transition:all var(--tr);position:relative;white-space:nowrap;border-radius:var(--radius)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 2px 14px var(--shadow)}
.btn-primary:hover{background:var(--green-bright);box-shadow:0 6px 22px var(--shadow-deep);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{border:1.5px solid var(--border);color:var(--text-primary);background:transparent}
.btn-outline:hover{border-color:var(--green);color:var(--green);background:var(--green-pale)}
.btn-ghost{color:var(--green);font-weight:500;padding:0;font-size:.86rem;background:none;border:none}
.btn-ghost:hover{opacity:.7}
.btn-white{background:#fff;color:var(--text-primary);box-shadow:0 2px 16px rgba(0,0,0,.12)}
.btn-white:hover{opacity:.95;transform:translateY(-1px)}
.btn-ghost-inv{border:1.5px solid rgba(255,255,255,.3);color:#fff;padding:.875rem 1.9rem}
.btn-ghost-inv:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08)}
.arr{display:inline-block;transition:transform var(--tr)}
.btn:hover .arr,.btn-ghost:hover .arr{transform:translateX(4px)}

/* ===== CARDS ===== */
.card{background:var(--bg-card);border:1px solid var(--border);padding:2.5rem;transition:all var(--tr);border-radius:var(--radius)}
.card:hover{border-color:var(--green);box-shadow:0 12px 36px var(--shadow)}

/* ===== TAGS ===== */
.tag{display:inline-flex;align-items:center;padding:.4rem .95rem;background:var(--green-pale);color:var(--green);font-size:.78rem;font-weight:500;border:1px solid transparent;transition:all var(--tr);cursor:pointer;user-select:none;border-radius:50px}
.tag.active,.tag:hover{background:var(--green);color:#fff}
.tag-group{display:flex;flex-wrap:wrap;gap:.5rem}

/* ===== FORMS ===== */
.form-group{margin-bottom:1.5rem}
.form-label{display:block;font-size:.72rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}
.form-input,.form-select,.form-textarea{width:100%;padding:.875rem 1rem;background:var(--bg);border:1.5px solid var(--border);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;transition:border-color var(--tr),box-shadow var(--tr);outline:none;-webkit-appearance:none;appearance:none;border-radius:var(--radius)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow)}
.form-textarea{min-height:120px;resize:vertical}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}

/* ===== STATS ===== */
.stat-num{font-family:var(--font-display);font-size:clamp(2rem,3.6vw,3.2rem);font-weight:600;color:var(--green);line-height:1}
.stat-label{font-size:.83rem;color:var(--text-muted);margin-top:.3rem;letter-spacing:.02em}

/* ===== NAV ===== */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--nav-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background var(--tr)}
.nav-inner{display:flex;align-items:center;height:var(--nav-main-h);padding:0 clamp(1.25rem,3vw,2.5rem);max-width:1400px;margin:0 auto}
.nav-links{display:flex;align-items:center;gap:1.85rem;margin-left:auto;margin-right:2.25rem}
.nav-link{font-size:.83rem;color:var(--text-secondary);transition:color var(--tr);position:relative;padding-bottom:2px;letter-spacing:.01em;cursor:pointer}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--green);transition:width var(--tr);border-radius:1px}
.nav-link:hover,.nav-link.active{color:var(--text-primary)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:.875rem}
.theme-toggle{width:38px;height:38px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--tr);background:transparent;color:var(--text-secondary);border-radius:50%}
.theme-toggle:hover{border-color:var(--green);color:var(--green)}
[data-theme="light"] .icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:none}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.ham span{width:22px;height:1.5px;background:var(--text-primary);display:block;transition:all var(--tr)}
/* Mobile-only theme toggle — hidden on desktop, sits left of logo on mobile */
.theme-toggle-mob{display:none;width:38px;height:38px;border:1.5px solid var(--border);align-items:center;justify-content:center;cursor:pointer;transition:all var(--tr);background:transparent;color:var(--text-secondary);border-radius:50%;flex-shrink:0}
.theme-toggle-mob:hover{border-color:var(--green);color:var(--green)}

/* ===== PAGE SHELL ===== */
.page{padding-top:var(--nav-h);min-height:100vh}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;padding:calc(var(--nav-h) + clamp(2.5rem,6vw,4.5rem)) 0 clamp(3rem,6vw,5rem)}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-glow{position:absolute;top:8%;right:-8%;width:50%;height:70%;background:radial-gradient(ellipse,rgba(60,107,79,.1) 0%,transparent 70%);border-radius:50%}
.hero>.container{position:relative;z-index:1}
/* Faint dot-grid overlay for the main hero — add class hero-dots to the hero element */
.hero-dots::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(60,107,79,.1) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0;mask-image:radial-gradient(ellipse 70% 100% at 50% 0%,#000 30%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 70% 100% at 50% 0%,#000 30%,transparent 100%)}
[data-theme="dark"] .hero-dots::before{background-image:radial-gradient(rgba(126,201,154,.07) 1px,transparent 1px)}
.hero-status{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;color:var(--text-muted);margin-bottom:1.25rem}
.hero-status-dot{width:6px;height:6px;background:var(--amber);box-shadow:0 0 0 3px var(--amber-glow);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-heading em{font-style:normal;color:var(--green)}
.hero-actions{margin-top:2.25rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:clamp(1.5rem,4vw,3rem);margin-top:clamp(2.5rem,4vh,3.5rem);padding-top:2.25rem;border-top:1px solid var(--border);flex-wrap:wrap}
.hero-stat{position:relative}
.hero-stat+.hero-stat::before{content:'';position:absolute;left:clamp(-.75rem,-2vw,-1.5rem);top:50%;transform:translateY(-50%);height:40%;width:1px;background:var(--border)}
@media(max-width:640px){.hero-stat+.hero-stat::before{display:none}}

/* ===== TICKER ===== */
.ticker-wrap{background:var(--green);overflow:hidden;padding:.75rem 0}
.ticker{display:flex;animation:tick var(--ticker-dur,20s) linear infinite;white-space:nowrap;will-change:transform}
.ticker:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:.6rem;padding:.1rem 1.4rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;color:rgba(255,255,255,.85);transition:color var(--tr)}
.ticker-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.5);flex-shrink:0}
.ticker-wrap-dark .ticker-dot{background:var(--green-light)}
.ticker-wrap-dark .ticker-item:hover{color:#fff}
.t-up{color:#d6ffe6;font-weight:500}
.t-dn{color:#ffd6d6;font-weight:500}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-wrap-dark{background:var(--ink-deep);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.ticker-label{flex-shrink:0;padding:0 1.25rem;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-light);border-right:1px solid rgba(255,255,255,.1);display:flex;align-items:center}

/* ===== TYPEWRITER ===== */
.tw-cursor{display:inline-block;width:3px;height:.82em;margin-left:3px;vertical-align:text-bottom;background:var(--green);animation:tw-blink 1s steps(1) infinite;border-radius:1px}
@keyframes tw-blink{0%,50%{opacity:1}51%,100%{opacity:0}}

/* ===== PROOF / BENTO ===== */
.bento{padding:clamp(3.5rem,6vw,5rem) 0}
.bento-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:auto auto;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:3rem}
.bento-cell{background:var(--bg);padding:clamp(2rem,3.4vw,2.75rem);position:relative;transition:background var(--tr)}
.bento-cell:hover{background:var(--bg-card)}
.bento-cell--main{grid-row:1/3;display:flex;flex-direction:column;justify-content:space-between;gap:2.5rem;border-right:1px solid var(--border)}
.bento-cell--accent{background:var(--green-pale)}
.bento-big-num{font-family:var(--font-display);font-size:clamp(3rem,5.6vw,4.6rem);font-weight:600;line-height:1;color:var(--text-primary);letter-spacing:-.02em}
.bento-big-num em{color:var(--green);font-style:normal}
.bento-cell-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}
.bento-cell-copy{font-size:.88rem;color:var(--text-secondary);line-height:1.7;max-width:360px}
.bento-quote{font-family:var(--font-display);font-size:clamp(1.4rem,2.2vw,1.85rem);font-weight:500;line-height:1.3;color:var(--text-primary)}
.bento-quote em{color:var(--green);font-style:normal}
.bento-disc-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}
.bento-disc{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.04em;padding:.3rem .75rem;border:1px solid var(--border);border-radius:50px;color:var(--text-secondary);transition:all var(--tr)}
.bento-disc:hover{border-color:var(--green);color:var(--green)}
.bento-cell--dark{background:var(--bg-secondary)}
.bento-cell--dark:hover{background:var(--bg-card)}
@media(max-width:860px){.bento-grid{grid-template-columns:1fr 1fr}.bento-cell--main{grid-row:auto;grid-column:1/3}}
@media(max-width:540px){.bento-grid{grid-template-columns:1fr}.bento-cell--main{grid-column:auto}}

/* ===== SPLIT CTA (centered) ===== */
.split-cta{display:flex;justify-content:center;border-bottom:1px solid var(--border)}
.split-cta-inner{display:flex;justify-content:center;align-items:center;gap:3rem;max-width:1100px;width:100%;margin:0 auto;text-align:center;flex-wrap:wrap;padding:clamp(2.5rem,5vw,4.5rem) 0}
.split-cta .split-content{margin:0 auto;max-width:480px;text-align:center}

/* ===== QUOTE BAND ===== */
.quote-band{background:#0f1d16;padding:clamp(3.5rem,6vw,5.5rem) 0;text-align:center}
[data-theme="dark"] .quote-band{background:#060e08}
.quote-band-text{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.4rem);font-weight:500;line-height:1.3;color:#fff;max-width:760px;margin:0 auto}
.quote-band-text em{color:var(--green-light);font-style:normal}
.quote-band-attr{margin-top:1.5rem;font-size:.8rem;color:rgba(255,255,255,.45)}
.quote-band-cta{display:inline-block;margin-top:1.5rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green-light)}
.quote-band-cta:hover{opacity:.75}

/* ===== WHY SECTION ===== */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.why-l{padding:clamp(3rem,5vw,5rem) clamp(2rem,4vw,5rem) clamp(3rem,5vw,5rem) 0;border-right:1px solid var(--border)}
.why-r{padding:clamp(3rem,5vw,5rem) 0 clamp(3rem,5vw,5rem) clamp(2rem,4vw,5rem)}
.why-features{display:flex;flex-direction:column;gap:0}
.wf{display:flex;gap:1.5rem;align-items:flex-start;padding:1.5rem;border-bottom:1px solid var(--border);transition:background var(--tr);cursor:default}
.wf:last-child{border-bottom:none}
.wf:hover{background:var(--green-pale)}
.wf-icon{width:40px;height:40px;border:1.5px solid var(--green);display:flex;align-items:center;justify-content:center;color:var(--green);flex-shrink:0;font-family:var(--font-mono);font-size:.75rem;border-radius:50%;transition:all var(--tr)}
.wf:hover .wf-icon{background:var(--green);color:#fff}
.wf h4{font-size:.95rem;font-weight:500;margin-bottom:.35rem}
.wf p{font-size:.875rem;color:var(--text-secondary);line-height:1.7}

/* ===== PATHFINDER ===== */
.pf-card{background:var(--bg-card);border:1px solid var(--border);padding:clamp(2rem,4vw,3.5rem);max-width:840px;margin:3rem auto 0;border-radius:var(--radius)}
.pf-step{display:none}
.pf-step.active{display:block}
.pf-q{font-family:var(--font-display);font-size:clamp(1.4rem,2.2vw,1.75rem);font-weight:500;margin:1rem 0 2rem}
.pf-opts{display:flex;flex-wrap:wrap;gap:.75rem}
.pf-opt{padding:.75rem 1.5rem;border:1.5px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:.88rem;cursor:pointer;transition:all var(--tr);font-family:var(--font-body);border-radius:50px}
.pf-opt:hover{border-color:var(--green);color:var(--green);background:var(--green-pale)}
.pf-opt.sel{background:var(--green);color:#fff;border-color:var(--green)}
.pf-prog{display:flex;gap:.5rem;margin-bottom:2rem}
.pf-dot{height:3px;flex:1;background:var(--border);transition:background var(--tr);border-radius:2px}
.pf-dot.done{background:var(--green)}
.pf-res{display:none}
.pf-res.show{display:block}
.pf-rg{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.pf-rc{border:1px solid var(--border);padding:1.5rem;background:var(--bg-secondary);transition:all var(--tr);border-radius:var(--radius)}
.pf-rc:hover{border-color:var(--green);transform:translateY(-2px)}
.pf-rt{font-weight:500;font-size:.93rem;margin-bottom:.25rem}
.pf-rm{font-size:.75rem;color:var(--green);font-family:var(--font-mono);margin-top:.25rem}
.pf-rd{font-size:.78rem;color:var(--text-muted);margin-top:.4rem;line-height:1.55}

/* ===== PROCESS ===== */
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:3.5rem;position:relative}
.proc-steps::before{content:'';position:absolute;top:20px;left:calc(1.25rem + 21px);right:calc(25% - 1.25rem - 21px);height:1px;background:var(--border);pointer-events:none}
.proc-step{padding:0 1.25rem;text-align:left}
.proc-num{width:42px;height:42px;border:1.5px solid var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;color:var(--green);background:var(--bg);margin-bottom:1.5rem;position:relative;z-index:1;border-radius:50%;transition:all var(--tr)}
.proc-step:hover .proc-num{background:var(--green);color:#fff}
.proc-step h4{font-size:.95rem;font-weight:500;margin-bottom:.4rem}
.proc-step p{font-size:.83rem;color:var(--text-secondary);line-height:1.65}

/* ===== TESTIMONIALS ===== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.testi-card{background:var(--bg-card);border:1px solid var(--border);padding:2.25rem;transition:all var(--tr);border-radius:var(--radius)}
.testi-card:hover{border-color:var(--green);box-shadow:0 10px 32px var(--shadow)}
.stars{color:var(--amber);font-size:.95rem;margin-bottom:1rem}
.testi-text{font-size:.92rem;color:var(--text-secondary);line-height:1.8;font-style:italic}
.testi-author{margin-top:1.5rem;font-size:.88rem;font-weight:500}
.testi-role{font-size:.76rem;color:var(--text-muted)}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.blog-card{border-top:2px solid var(--border);padding-top:1.5rem;cursor:pointer;transition:all var(--tr)}
.blog-card:hover{border-top-color:var(--green)}
.blog-card:hover .blog-title{color:var(--green)}
.blog-date{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}
.blog-pill{display:inline-block;font-size:.67rem;padding:.2rem .7rem;background:var(--green-pale);color:var(--green);font-weight:500;margin:.5rem 0 .6rem;letter-spacing:.04em;border-radius:50px}
.blog-title{font-size:1rem;font-weight:500;line-height:1.4;transition:color var(--tr)}
.blog-exc{font-size:.83rem;color:var(--text-secondary);margin-top:.4rem;line-height:1.65}
.blog-read{font-size:.78rem;color:var(--green);margin-top:.875rem;font-weight:500}
.blog-full-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:3rem}
.blog-full-card{border:1px solid var(--border);cursor:pointer;transition:all var(--tr);border-radius:var(--radius);overflow:hidden}
.blog-full-card:hover{border-color:var(--green);box-shadow:0 10px 36px var(--shadow)}
.blog-img{height:180px;background:var(--green-pale);display:flex;align-items:center;justify-content:center;color:var(--green);font-family:var(--font-display);font-size:1.25rem;font-weight:500;padding:2rem;text-align:center}
.blog-body{padding:2rem}
.blog-post-layout{display:grid;grid-template-columns:minmax(0,720px) 1fr;gap:4rem;align-items:start;max-width:1100px}
.blog-post-sidebar{position:sticky;top:calc(var(--nav-h) + 2rem)}

/* ===== CTA STRIP ===== */
.cta-strip{position:relative;padding:clamp(3.5rem,6vw,5.5rem) 0;background:#0f1d16;color:#fff}
[data-theme="dark"] .cta-strip{background:#060e08}
.cta-strip h2{font-family:var(--font-display);font-size:clamp(1.7rem,3.2vw,2.7rem);font-weight:500;color:#fff}
.cta-strip p{color:rgba(255,255,255,.65);font-size:.93rem;margin-top:.5rem}
.cta-btns{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.cta-strip .btn-white{background:#fff;color:#0f1d16;border:1px solid rgba(255,255,255,.85)}
.cta-strip .btn-white:hover{background:rgba(255,255,255,.92);color:#0f1d16}
.cta-feature{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:rgba(255,255,255,.7)}
.cta-feature-dot{width:6px;height:6px;border-radius:50%;background:var(--green-light)}

/* ===== FOOTER ===== */
footer{background:#0a1a0e;border-top:1px solid rgba(255,255,255,.06);padding:clamp(3rem,5vw,4rem) 0 2rem}
[data-theme="dark"] footer{background:#050d07}
.footer-top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;padding-bottom:clamp(2rem,4vw,2.75rem);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:clamp(2rem,4vw,2.75rem)}
.footer-brand{max-width:440px}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:clamp(1.75rem,3vw,2.5rem)}
.footer-desc{font-size:.83rem;color:rgba(255,255,255,.4);margin-top:1.25rem;line-height:1.8;max-width:340px}
.footer-col h5{font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1rem}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
.footer-link{font-size:.83rem;color:rgba(255,255,255,.5);transition:color var(--tr);cursor:pointer}
.footer-link:hover{color:var(--green-light)}
.footer-bottom{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-legal{font-size:.74rem;color:rgba(255,255,255,.3)}
.socials{display:flex;gap:.75rem}
.soc{width:36px;height:36px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--tr);color:var(--text-muted);font-size:.78rem;font-weight:600;border-radius:50%}
.soc-li{width:auto;height:40px;padding:0 1.1rem;gap:.4rem;border-color:var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);letter-spacing:.02em;background:var(--bg-card)}
.soc-li:hover{background:#0a66c2!important;border-color:#0a66c2!important;color:#fff!important}
.soc-label{font-size:.78rem;font-weight:500;letter-spacing:.03em}
.soc:hover{border-color:var(--green);color:var(--green)}
footer .soc,footer .soc-li{border-color:rgba(255,255,255,.14);color:rgba(255,255,255,.5);background:transparent}
footer .soc-li{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.8)}
footer .soc:hover{border-color:var(--green-light);color:var(--green-light)}

/* ===== POLICY / LEGAL PAGES ===== */
.policy-meta{margin-top:1.5rem}
.policy-pill{display:inline-block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:.35rem .85rem;border-radius:50px}
.policy-wrap{max-width:760px;margin:0 auto}
.policy-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(2rem,4vw,3rem)}
.policy-card h2{font-family:var(--font-display);font-size:1.3rem;font-weight:500;margin:2rem 0 .75rem}
.policy-card h2:first-child{margin-top:0}
.policy-card p{font-size:.92rem;color:var(--text-secondary);line-height:1.8}
.policy-card ul{margin:.5rem 0 0 1.25rem;list-style:disc}
.policy-card li{font-size:.92rem;color:var(--text-secondary);line-height:1.8;margin-bottom:.4rem}

/* ===== PAGE HERO (sub-pages) ===== */
.page-hero{padding:calc(var(--nav-h) + clamp(2rem,4vw,3rem)) 0 clamp(2.5rem,4vw,3.5rem);background:var(--bg-secondary);border-bottom:1px solid var(--border)}

/* ===== VALUES ===== */
.val-list{display:flex;flex-direction:column;gap:1.75rem;margin-top:2rem}
.val-item{border-left:2px solid var(--green);padding-left:1.5rem;transition:padding-left var(--tr)}
.val-item:hover{padding-left:2rem}
.val-item h4{font-size:.95rem;font-weight:500;margin-bottom:.3rem}
.val-item p{font-size:.875rem;color:var(--text-secondary);line-height:1.7}

/* ===== TEAM ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.team-grid-two{grid-template-columns:repeat(2,minmax(260px,360px));justify-content:center}
.team-card{background:var(--bg-card);border:1px solid var(--border);padding:2.5rem;text-align:center;transition:all var(--tr);border-radius:var(--radius)}
.team-card:hover{border-color:var(--green);box-shadow:0 12px 36px var(--shadow)}
.team-avatar{width:80px;height:80px;background:var(--green-pale);border:2px solid var(--green);border-radius:50%;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2rem;color:var(--green);font-weight:600;transition:all var(--tr)}
.team-card:hover .team-avatar{background:var(--green);color:#fff}
.team-name{font-weight:500;font-size:1rem;margin-bottom:.25rem}
.team-role{font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.05em}

/* ===== CERTS ===== */
.certs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.cert-box{border:1px dashed var(--border);padding:2rem;text-align:center;opacity:.55;transition:all var(--tr)}
.cert-box:hover{opacity:.85;border-color:var(--green)}
.cert-ph{font-size:.75rem;color:var(--text-muted);margin-top:.75rem}

/* ===== EMPLOYERS METRICS ===== */
.emp-metrics{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border)}
.emp-metric{padding:2.5rem;border-right:1px solid var(--border);text-align:center;transition:background var(--tr)}
.emp-metric:last-child{border-right:none}
.emp-metric:hover{background:var(--green-pale)}

/* ===== HOME PILLAR ACCORDION ===== */
.home-pillar-body{display:block;max-height:0;overflow:hidden;transition:max-height .35s ease,opacity .25s ease;opacity:0}
.home-pillar-body.open{max-height:200px;opacity:1}
.home-pillar-caret{transition:transform var(--tr)}

/* ===== FAQ ===== */
.faq-list{max-width:740px;margin:2rem auto 0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:1.5rem 0;font-size:.97rem;font-weight:500;color:var(--text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:none;border:none;font-family:var(--font-body);transition:color var(--tr);gap:1rem}
.faq-q:hover{color:var(--green)}
.faq-icon{color:var(--green);transition:transform var(--tr);flex-shrink:0;font-size:1.2rem;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-ans-in{padding-bottom:1.5rem;font-size:.93rem;color:var(--text-secondary);line-height:1.8}
.faq-item.open .faq-ans{max-height:400px}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}
.contact-opt{border-bottom:1px solid var(--border);padding:1.5rem 0}
.contact-opt:first-child{border-top:1px solid var(--border)}
.contact-opt-icon{width:40px;height:40px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:.875rem;color:var(--green);border-radius:50%;transition:all var(--tr)}
.contact-opt:hover .contact-opt-icon{border-color:var(--green);background:var(--green-pale)}
.contact-opt h4{font-size:.9rem;font-weight:500;margin-bottom:.25rem}
.contact-opt p{font-size:.85rem;color:var(--text-secondary)}
.contact-opt a{color:var(--green)}

/* ===== INTERVIEW PREP ===== */
.it-grid{display:grid;grid-template-columns:1fr 2fr;gap:3rem;margin-top:3rem}
.it-item{padding:.875rem 1rem;border:1px solid var(--border);cursor:pointer;font-size:.88rem;transition:all var(--tr);background:var(--bg);border-radius:var(--radius)}
.it-item:hover,.it-item.active{border-color:var(--green);background:var(--green-pale);color:var(--green)}
.it-content{background:var(--bg-secondary);padding:2rem;border-radius:var(--radius)}
.it-q{padding:1rem 1rem 1rem 1.25rem;border-left:2px solid var(--green);margin-bottom:1rem;background:var(--bg)}
.it-qt{font-weight:500;font-size:.93rem}
.it-tip{font-size:.8rem;color:var(--text-secondary);margin-top:.4rem;line-height:1.65}

/* ===== FEATURE GRID (fixed column counts so a 6-item grid never ends in a ragged row) ===== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:860px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.feature-grid{grid-template-columns:1fr}}

/* ===== UPLOAD ===== */
.upload-area{border:2px dashed var(--border);padding:2.5rem;text-align:center;cursor:pointer;transition:all var(--tr);border-radius:var(--radius)}
.upload-area:hover,.upload-area.drag{border-color:var(--green);background:var(--green-pale)}
.upload-area:hover .upload-icon,.upload-area.drag .upload-icon{transform:translateY(-4px);color:var(--green)}
.upload-icon{transition:transform var(--tr),color var(--tr);display:inline-block}
.success-msg{display:none;background:var(--green-pale);border:1px solid var(--green);padding:1.5rem;margin-top:1.25rem;font-size:.9rem;color:var(--text-primary);border-radius:var(--radius)}

/* ===== NOTICE / COMING SOON ===== */
.notice{background:var(--green-pale);border:1px solid rgba(124,92,255,.3);padding:1rem 1.25rem;font-size:.85rem;color:var(--text-primary);margin-bottom:2rem;line-height:1.6;border-radius:var(--radius)}
.coming-soon-badge{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:.35rem .8rem;border-radius:50px;margin-bottom:1.25rem}

/* ===== CHAT WIDGET ===== */
.chat-btn{position:fixed;bottom:2rem;right:2rem;z-index:900;background:var(--green);color:#fff;width:54px;height:54px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 18px var(--shadow-deep);transition:all var(--tr);border:none;border-radius:50%}
.chat-btn:hover{transform:translateY(-2px);background:var(--green-bright)}
.chat-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:#c44;border-radius:50%;font-size:.6rem;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid var(--bg)}
.chat-win{position:fixed;bottom:5rem;right:2rem;width:368px;max-height:540px;background:var(--bg-card);border:1px solid var(--border);box-shadow:0 18px 56px var(--shadow-deep);z-index:900;display:none;flex-direction:column;overflow:hidden;border-radius:var(--radius-lg)}
.chat-win.open{display:flex}
.chat-hdr{background:var(--green);color:#fff;padding:1.1rem 1.4rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.chat-av{width:38px;height:38px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.chat-av img{width:100%;height:100%;object-fit:contain;padding:5px}
.chat-hdr-info{flex:1}
.chat-name{font-weight:500;font-size:.9rem}
.chat-status{font-size:.7rem;opacity:.85;margin-top:.1rem;display:flex;align-items:center;gap:.4rem}
.status-dot{width:6px;height:6px;background:#7fffb0;border-radius:50%}
.chat-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem;opacity:.8;line-height:1}
.chat-close:hover{opacity:1}
.chat-msgs{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth}
.chat-msg{max-width:88%}
.chat-bot{align-self:flex-start}
.chat-user{align-self:flex-end}
.chat-bub{padding:.7rem .95rem;font-size:.85rem;line-height:1.55;border-radius:var(--radius-sm)}
.chat-bot .chat-bub{background:var(--bg-secondary);border-radius:2px var(--radius-sm) var(--radius-sm) var(--radius-sm)}
.chat-user .chat-bub{background:var(--green);color:#fff;border-radius:var(--radius-sm) 2px var(--radius-sm) var(--radius-sm)}
.chat-choices{display:flex;flex-direction:column;gap:.35rem;margin-top:.75rem}
.chat-choice{padding:.55rem .875rem;border:1px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:.8rem;cursor:pointer;text-align:left;transition:all var(--tr);font-family:var(--font-body);border-radius:var(--radius-sm)}
.chat-choice:hover{border-color:var(--green);color:var(--green);background:var(--green-pale)}
.chat-foot{padding:.875rem;border-top:1px solid var(--border);display:flex;gap:.5rem}
.chat-inp{flex:1;padding:.6rem .875rem;border:1.5px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:.83rem;outline:none;font-family:var(--font-body);border-radius:var(--radius-sm)}
.chat-inp:focus{border-color:var(--green)}
.chat-send{background:var(--green);color:#fff;border:none;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:1rem;border-radius:var(--radius-sm);transition:background var(--tr)}
.chat-send:hover{background:var(--green-bright)}

/* ===== FADE IN ===== */
.fi{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.fi.vis{opacity:1;transform:translateY(0)}

/* ===== MOBILE NAV ===== */
.m-nav{position:fixed;inset:0;background:var(--bg);z-index:999;padding:5rem 2rem 2rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;visibility:hidden;opacity:0;pointer-events:none;transition:opacity .2s ease,visibility .2s ease}
.m-nav.open{visibility:visible;opacity:1;pointer-events:all}
.m-nav .nav-link{font-size:1.4rem;font-family:var(--font-display);color:var(--text-primary);padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.m-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-primary)}
.m-nav-drop{border-bottom:1px solid var(--border)}
.m-nav-drop-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;font-size:1.4rem;font-family:var(--font-display);color:var(--text-primary);padding-bottom:.5rem;cursor:pointer}
.m-nav-drop-trigger .nav-drop-caret{width:9px;height:9px;margin-top:0}
.m-nav-drop-panel{max-height:0;overflow:hidden;transition:max-height .3s ease}
.m-nav-drop.open .m-nav-drop-panel{max-height:420px}
.m-nav-drop.open .m-nav-drop-trigger .nav-drop-caret{transform:rotate(225deg)}
.m-nav-drop-link{display:flex;align-items:center;gap:.6rem;padding:.75rem 0;font-size:1rem;font-family:var(--font-body);color:var(--text-secondary)}
.m-nav-drop-link .branch-soon-tag{position:static}

/* ===== COOKIE CONSENT ===== */
.ck-banner{position:fixed;bottom:0;left:0;right:0;z-index:8900;background:var(--bg-card);border-top:1px solid var(--border);box-shadow:0 -4px 28px rgba(0,0,0,.08);transform:translateY(calc(100% + 1px));transition:transform .3s cubic-bezier(.4,0,.2,1);padding:1.1rem clamp(1rem,4vw,2rem)}
.ck-banner.ck-show{transform:translateY(0)}
.ck-banner-inner{max-width:1200px;margin:0 auto;display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.ck-banner-text{flex:1;min-width:220px}
.ck-banner-title{font-weight:500;font-size:.86rem;margin-bottom:.2rem;color:var(--text-primary)}
.ck-banner-copy{font-size:.78rem;color:var(--text-secondary);line-height:1.6}
.ck-link{color:var(--green)}
.ck-banner-btns{display:flex;gap:.625rem;flex-wrap:wrap;align-items:center;flex-shrink:0}
.ck-btn{font-size:.76rem;font-weight:500;padding:.5rem 1.05rem;border-radius:5px;cursor:pointer;font-family:var(--font-body);letter-spacing:.02em;transition:all var(--tr);white-space:nowrap;line-height:1}
.ck-btn-primary{background:var(--green);color:#fff;border:1.5px solid var(--green)}
.ck-btn-primary:hover{background:var(--green-bright)}
.ck-btn-outline{background:transparent;color:var(--text-primary);border:1.5px solid var(--border)}
.ck-btn-outline:hover{border-color:var(--green);color:var(--green)}
.ck-btn-ghost{background:none;color:var(--text-muted);border:none;text-decoration:underline;padding:.5rem .25rem}
.ck-btn-ghost:hover{color:var(--text-primary)}
.ck-modal-wrap{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.4);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}
.ck-modal-wrap.ck-show{opacity:1;pointer-events:all}
.ck-modal{background:var(--bg);border-top:1px solid var(--border);width:100%;max-width:520px;max-height:88vh;overflow-y:auto;padding:2rem clamp(1.25rem,4vw,2.25rem) 2.5rem;position:relative;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transform:translateY(20px);transition:transform .25s ease}
.ck-modal-wrap.ck-show .ck-modal{transform:translateY(0)}
@media(min-width:580px){.ck-modal-wrap{align-items:center;padding:1rem}.ck-modal{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:0 20px 56px rgba(0,0,0,.16)}}
.ck-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1rem;cursor:pointer;color:var(--text-muted);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--tr)}
.ck-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}
.ck-modal-title{font-family:var(--font-display);font-size:1.3rem;font-weight:500;margin-bottom:.4rem}
.ck-modal-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.65;margin-bottom:1.25rem}
.ck-row{display:flex;align-items:center;gap:1rem;padding:.875rem 0;border-top:1px solid var(--border)}
.ck-row-info{flex:1}
.ck-row-info strong{font-size:.84rem;font-weight:500;display:block;margin-bottom:.2rem}
.ck-row-info p{font-size:.76rem;color:var(--text-secondary);line-height:1.55;margin:0}
.ck-always-on{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;color:var(--green);border:1px solid rgba(124,92,255,.35);padding:.2rem .55rem;border-radius:50px;white-space:nowrap;flex-shrink:0}
.ck-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0;cursor:pointer}
.ck-switch input{opacity:0;width:0;height:0;position:absolute}
.ck-switch-track{position:absolute;inset:0;background:var(--border);border-radius:11px;transition:background .2s ease}
.ck-switch-track::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .2s ease}
.ck-switch input:checked + .ck-switch-track{background:var(--green)}
.ck-switch input:checked + .ck-switch-track::after{transform:translateX(18px)}
.ck-switch input:focus-visible + .ck-switch-track{outline:2px solid var(--green);outline-offset:2px}
.ck-sr{position:absolute;clip:rect(0,0,0,0);width:1px;height:1px;overflow:hidden}
.ck-modal-btns{display:flex;gap:.625rem;justify-content:flex-end;margin-top:1.25rem;border-top:1px solid var(--border);padding-top:1.25rem;flex-wrap:wrap}
@media(max-width:480px){.ck-banner-inner{flex-direction:column;align-items:flex-start}.ck-banner-btns{width:100%}.ck-btn{flex:1;justify-content:center;text-align:center}}

/* ===== NAV DROPDOWN (SOLUTIONS) ===== */
.nav-item-drop{position:relative}
.nav-drop-trigger{display:flex;align-items:center;gap:.4rem;font-size:.83rem;color:var(--text-secondary);background:none;border:none;cursor:pointer;font-family:var(--font-body);padding-bottom:2px;letter-spacing:.01em;transition:color var(--tr)}
.nav-drop-trigger:hover,.nav-drop-trigger[aria-expanded="true"],.nav-drop-trigger.active{color:var(--text-primary)}
.nav-drop-trigger.active .nav-drop-caret{border-color:var(--green)}
.nav-drop-caret{width:8px;height:8px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);transition:transform var(--tr);margin-top:-3px}
.nav-drop-trigger[aria-expanded="true"] .nav-drop-caret{transform:rotate(225deg);margin-top:3px}
.nav-drop-panel{position:absolute;top:calc(100% + 1.1rem);left:50%;transform:translateX(-50%) translateY(8px);width:min(560px,90vw);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 20px 48px var(--shadow-deep);padding:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.4rem;opacity:0;pointer-events:none;visibility:hidden;transition:opacity var(--tr),transform var(--tr),visibility var(--tr)}
.nav-item-drop.open .nav-drop-panel{opacity:1;pointer-events:all;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop-link{display:flex;gap:.875rem;align-items:flex-start;padding:1rem;border-radius:var(--radius);transition:background var(--tr)}
.nav-drop-link:hover{background:var(--green-pale)}
.nav-drop-icon{width:38px;height:38px;border-radius:50%;background:var(--mist);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--green);font-size:1rem}
.nav-drop-link h5{font-size:.88rem;font-weight:500;margin-bottom:.2rem;color:var(--text-primary);display:flex;align-items:center}
.nav-drop-link p{font-size:.76rem;color:var(--text-muted);line-height:1.5}
.nav-drop-tag{display:inline-block;margin-left:.5rem;font-family:var(--font-mono);font-size:.56rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:.1rem .4rem;border-radius:50px;vertical-align:middle}

/* ===== HERO SPLIT (asymmetric two-column hero) ===== */
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:center}
.hero-split-text{max-width:520px}
.hero-split-panel{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:clamp(1.5rem,2.6vw,2.25rem);box-shadow:0 18px 48px var(--shadow)}
.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.tool-card{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 1.4rem;transition:all var(--tr);position:relative;overflow:hidden}
.tool-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,var(--green-pale),transparent 70%);opacity:0;transition:opacity var(--tr);pointer-events:none}
.tool-card:hover{border-color:var(--green);box-shadow:0 16px 40px var(--shadow-deep);transform:translateY(-4px)}
.tool-card:hover::after{opacity:1}
.tool-card--lead{border-color:var(--green-light);box-shadow:0 0 0 3px var(--green-glow)}
.tool-card--lead::after{background:radial-gradient(circle at top right,var(--green-pale),transparent 70%);opacity:.5}
/* CV Checker featured variant — prominent green highlight */
.tool-card--cv{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow)}
.tool-card--cv::after{background:radial-gradient(circle at top right,var(--green-pale),transparent 65%);opacity:.7}
.tool-card--cv .tool-icon{background:var(--green);color:#fff;border-color:var(--green)}
.tool-icon{width:42px;height:42px;border-radius:var(--radius-sm);background:var(--green-pale);border:1px solid rgba(60,107,79,.2);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:1.1rem;flex-shrink:0;transition:all var(--tr);position:relative;z-index:1}
.tool-card:hover .tool-icon{background:var(--green);color:#fff;border-color:var(--green)}
.tool-card--cv:hover .tool-icon{background:var(--green-bright);border-color:var(--green-bright)}
.tool-card h4{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.3;position:relative;z-index:1}
.tool-card p{font-size:.74rem;color:var(--text-secondary);line-height:1.5;position:relative;z-index:1}
@media(max-width:900px){.hero-split{grid-template-columns:1fr}.hero-split-text{max-width:none}}
@media(max-width:480px){.tool-grid{grid-template-columns:1fr}}

/* ===== SCAN DIVIDER (telemetry line) ===== */
.ring-divider-wrap{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:clamp(2rem,4vw,3rem) 0}
.ring-divider{width:140px;height:1px;background:linear-gradient(90deg,transparent,var(--border) 15%,var(--border) 85%,transparent);position:relative}
.ring-divider::before{content:'';position:absolute;left:50%;top:50%;width:6px;height:6px;background:var(--amber);transform:translate(-50%,-50%);box-shadow:0 0 0 4px var(--bg)}
.ring-divider::after{content:'';position:absolute;left:50%;top:50%;width:14px;height:14px;border:1px solid var(--amber-glow);transform:translate(-50%,-50%)}
.ring-divider-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}

/* ===== PERSONALITY TEST RESULT ===== */
.pt-result-trait{font-family:var(--font-display);font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:600;color:var(--green)}
.pt-bars{display:flex;flex-direction:column;gap:.85rem;margin-top:2rem}
.pt-bar-row{display:flex;align-items:center;gap:1rem}
.pt-bar-label{width:150px;font-size:.78rem;color:var(--text-secondary);flex-shrink:0;font-family:var(--font-mono);letter-spacing:.02em}
.pt-bar-track{flex:1;height:10px;background:var(--mist);border-radius:50px;overflow:hidden}
.pt-bar-fill{height:100%;background:var(--green);border-radius:50px;transition:width .7s cubic-bezier(.4,0,.2,1);width:0}
.pt-bar-fill.is-top{background:var(--amber)}
.pt-bar-pct{width:40px;text-align:right;font-family:var(--font-mono);font-size:.76rem;color:var(--text-muted);flex-shrink:0}
@media(max-width:560px){.pt-bar-label{width:100px;font-size:.72rem}}

/* ===== FLIP CARD (interview prep practice) ===== */
.flip-wrap{max-width:600px;margin:2.5rem auto 0;perspective:1400px}
.flip-card{position:relative;width:100%;min-height:260px;cursor:pointer}
.flip-inner{position:relative;width:100%;height:100%;min-height:260px;transition:transform .5s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);padding:clamp(1.75rem,4vw,2.5rem);display:flex;flex-direction:column;justify-content:center;gap:.85rem;overflow-y:auto;transition:border-color var(--tr),box-shadow var(--tr)}
.flip-card:hover .flip-face{border-color:var(--green);box-shadow:0 12px 32px var(--shadow)}
.flip-face-back{transform:rotateY(180deg);background:var(--mist)}
.flip-cat{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.flip-q{font-family:var(--font-display);font-size:clamp(1.2rem,2.4vw,1.55rem);font-weight:400;line-height:1.4}
.flip-hint{font-size:.78rem;color:var(--text-muted);margin-top:.35rem}
.flip-tip-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:.2rem}
.flip-tip{font-size:.88rem;color:var(--text-secondary);line-height:1.7}
.flip-controls{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}
@media(prefers-reduced-motion:reduce){.flip-inner{transition:none}}
@media(max-width:480px){.flip-card,.flip-inner{min-height:320px}}

/* ===== BACKGROUND ART (swap these files for real photography any time) ===== */
.bg-canopy{background-image:url("../images/bg-canopy.svg");background-repeat:no-repeat;background-position:right -80px top -60px;background-size:560px}
.bg-roots{background-image:url("../images/bg-roots.svg");background-repeat:no-repeat;background-position:left -100px bottom -80px;background-size:520px}
.bg-rings{background-image:url("../images/bg-rings.svg");background-repeat:no-repeat;background-position:center top;background-size:cover}
@media(max-width:768px){.bg-canopy,.bg-roots{background-size:300px}}

/* Faint dotted-grid texture for sections that would otherwise be a flat fill */
.bg-dots{position:relative}
.bg-dots::before{content:'';position:absolute;inset:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:22px 22px;opacity:.55;pointer-events:none;mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,#000 18%,#000 82%,transparent)}
.bg-dots>.container{position:relative;z-index:1}
.bg-dots-inv::before{background-image:radial-gradient(rgba(255,255,255,.16) 1px,transparent 1px)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
  .proc-steps{grid-template-columns:1fr 1fr}
  .proc-steps::before{display:none}
  .why-grid{grid-template-columns:1fr}
  .why-l{border-right:none;border-bottom:1px solid var(--border);padding:3rem 0}
  .why-r{padding:3rem 0}
  .contact-grid{grid-template-columns:1fr}
  .it-grid{grid-template-columns:1fr}
  .emp-metrics{grid-template-columns:1fr 1fr}
  .emp-metric{border-right:none;border-bottom:1px solid var(--border)}
  .nav-links{display:none}
  .ham{display:flex}
  .nav-actions .btn{display:none}
  /* Mobile nav: theme toggle left, logo centered absolutely, hamburger right */
  .theme-toggle-mob{display:flex}
  .nav-actions .theme-toggle{display:none}
  .nav-inner{position:relative;justify-content:space-between}
  .nav-logo{position:absolute;left:50%;transform:translateX(-50%);z-index:1}
  .testi-grid{grid-template-columns:1fr 1fr}
  .blog-grid,.blog-full-grid,.blog-post-layout{grid-template-columns:1fr}
  .blog-post-sidebar{position:static;top:auto}
  .pf-rg{grid-template-columns:1fr 1fr}
  .chat-win{width:calc(100vw - 2rem);right:1rem}
  .team-grid{grid-template-columns:1fr 1fr}
  .split-cta-inner{flex-direction:column}
}
@media(max-width:860px){
  .elms-steps{grid-template-columns:1fr!important;gap:0!important}
  .elms-disc{grid-template-columns:1fr!important}
  .elms-values{grid-template-columns:1fr!important}
  .hero-split{grid-template-columns:1fr}
  .hero-split-text{max-width:none}
}
@media(max-width:768px){
  .nav-logo{max-width:180px}
  .bento-grid{grid-template-columns:1fr 1fr}
  .bento-cell--main{grid-row:auto;grid-column:1/3}
}
@media(max-width:640px){
  .grid-2,.form-grid-2{grid-template-columns:1fr}
  .emp-metrics{grid-template-columns:1fr}
  .emp-metric{border-bottom:1px solid var(--border)}
  .section{padding:3.5rem 0}
  .pf-card{padding:1.75rem}
  .pf-rg{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr}
  .footer-top{align-items:flex-start;flex-direction:column}
  .hero-stats{gap:1.75rem;flex-wrap:wrap}
  .hero-actions{flex-wrap:wrap}
  .testi-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .why-l,.why-r{padding:2.5rem 0}
  .cta-strip .flex-between{flex-direction:column;align-items:flex-start}
  .proc-steps{grid-template-columns:1fr 1fr}
  :root{--nav-main-h:72px;--nav-h:var(--nav-main-h)}
  .contact-grid{gap:2.5rem}
  .emp-metrics{border:none;gap:0}
  .feature-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .elms-applygrid{grid-template-columns:1fr!important}
  .elms-jobrow{grid-template-columns:1fr auto!important;gap:.9rem!important;padding-left:.25rem!important;padding-right:.25rem!important}
  .elms-jobrow>span:first-child{display:none!important}
  .elms-rowright{align-self:start!important}
}
@media(max-width:480px){
  .hero-actions .btn{width:100%;justify-content:center}
  .proc-steps{grid-template-columns:1fr}
  .bento-grid{grid-template-columns:1fr}
  .bento-cell--main{grid-column:auto}
  .testi-grid{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
  .tool-grid{grid-template-columns:1fr}
  .chat-btn{bottom:1rem;right:1rem}
  .chat-win{bottom:4.5rem;right:.5rem;width:calc(100vw - 1rem)}
  .certs-grid{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr}
  .hero-stats{flex-direction:column;gap:1.25rem;padding-top:1.5rem}
  .hero-stat+.hero-stat::before{display:none}
}
