/* =========================================================================
   Core Tech Recruitment — 2026 refresh layer (ctr-2026.css)
   Loaded AFTER liteframe.css + extra.css. Additive re-skin.
   - Light, safe global touches (font smoothing, brand vars, nav language pill).
   - Full component kit scoped under .ctr-page so new pages get the new design
     without altering legacy page layouts.
   Brand: Readex Pro, primary orange #e5682e.
   ========================================================================= */

:root{
  --ctr-orange:#e5682e; --ctr-orange-dark:#d5561a; --ctr-orange-light:#fb9157;
  --ctr-ink:#1f1f1f; --ctr-ink-soft:#3e3e3e; --ctr-grey:#9a9a9a;
  --ctr-panel:#f5f5f5; --ctr-line:#e3e3e3; --ctr-white:#fff;
}

/* ---- safe global touches ---- */
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* Language switcher pill in the nav (works inside the existing drawer <ul>) */
.nav .drawer ul li.lang-switch a{
  border:1.5px solid var(--ctr-orange);
  border-radius:999px;
  padding:4px 14px !important;
  font-weight:600;
  color:var(--ctr-orange) !important;
}
.nav .drawer ul li.lang-switch a:hover{background:var(--ctr-orange);color:#fff !important}

/* =========================================================================
   .ctr-page component kit (new pages only)
   ========================================================================= */
.ctr-page{font-family:'Readex Pro',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ctr-ink);line-height:1.6}
.ctr-page .ctr-wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.ctr-page h1,.ctr-page h2,.ctr-page h3{line-height:1.18;font-weight:700;letter-spacing:-.01em}
.ctr-page a{text-decoration:none}

/* hero — explicit resets so the site's global fixed `header{}` rule can never
   apply (we use a div, but guard anyway): static-flow, auto height, full width. */
.ctr-hero{position:relative;top:auto;left:auto;height:auto;width:auto;box-shadow:none;z-index:auto;overflow:hidden;color:#fff;padding:88px 0 92px;
  background:radial-gradient(900px 500px at 78% -10%, rgba(229,104,46,.55), transparent 60%),
             linear-gradient(135deg,#211d1b 0%, #1a1a1a 55%, #14110f 100%)}
.ctr-hero::after{content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;
  background-image:linear-gradient(var(--ctr-orange-light) 1px,transparent 1px),
                   linear-gradient(90deg,var(--ctr-orange-light) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(700px 360px at 80% 0,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(700px 360px at 80% 0,#000,transparent 70%)}
.ctr-hero .ctr-wrap{position:relative;z-index:2;max-width:840px}
.ctr-pill{display:inline-flex;align-items:center;gap:9px;background:rgba(229,104,46,.16);
  border:1px solid rgba(251,145,87,.5);color:#ffd9c5;font-weight:600;font-size:14px;
  padding:7px 15px;border-radius:999px;margin-bottom:22px}
.ctr-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ctr-orange-light);box-shadow:0 0 0 4px rgba(251,145,87,.25)}
.ctr-hero h1{font-size:48px;margin-bottom:18px;color:#fff}
.ctr-hero h1 em{font-style:normal;color:var(--ctr-orange-light)}
.ctr-hero p{font-size:19px;color:#d7d2cd;max-width:660px;margin-bottom:30px}
.ctr-btns{display:flex;gap:14px;flex-wrap:wrap}
.ctr-btn{padding:14px 26px;border-radius:9px;font-weight:600;font-size:16px;transition:.18s;display:inline-block;cursor:pointer}
.ctr-btn-primary{background:var(--ctr-orange);color:#fff}
.ctr-btn-primary:hover{background:var(--ctr-orange-dark);transform:translateY(-2px);color:#fff}
.ctr-btn-ghost{border:1.5px solid rgba(255,255,255,.4);color:#fff}
.ctr-btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07);color:#fff}
@media(max-width:640px){.ctr-hero h1{font-size:33px}.ctr-hero{padding:60px 0}}

/* sections */
.ctr-page section{padding:74px 0}
.ctr-eyebrow{color:var(--ctr-orange);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px}
.ctr-head{max-width:700px;margin-bottom:46px}
.ctr-head h2{font-size:33px;margin-bottom:12px}
.ctr-head p{color:var(--ctr-ink-soft);font-size:17px}

/* value cards */
.ctr-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:900px){.ctr-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.ctr-cards{grid-template-columns:1fr}}
.ctr-card{background:#fff;border:1px solid var(--ctr-line);border-radius:16px;padding:28px 24px;transition:.2s}
.ctr-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -22px rgba(31,31,31,.4);border-color:#f0d4c5}
.ctr-ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(229,104,46,.10);margin-bottom:18px}
.ctr-ico svg{width:24px;height:24px;stroke:var(--ctr-orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ctr-card h3{font-size:18px;margin-bottom:8px}
.ctr-card p{font-size:14.5px;color:var(--ctr-ink-soft)}

/* panel section */
.ctr-panel{background:var(--ctr-panel)}

/* module chips */
.ctr-chips{display:flex;flex-wrap:wrap;gap:12px}
.ctr-chip{background:#fff;border:1px solid var(--ctr-line);border-radius:999px;padding:11px 20px;font-weight:600;font-size:15px;transition:.18s;color:var(--ctr-ink)}
.ctr-chip:hover{border-color:var(--ctr-orange);color:var(--ctr-orange)}
.ctr-chip.lead{background:var(--ctr-orange);color:#fff;border-color:var(--ctr-orange)}

/* steps */
.ctr-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:760px){.ctr-steps{grid-template-columns:1fr;gap:22px}}
.ctr-num{width:52px;height:52px;border-radius:50%;background:var(--ctr-orange);color:#fff;font-weight:700;font-size:22px;display:grid;place-items:center;margin-bottom:18px;box-shadow:0 10px 24px -10px var(--ctr-orange)}
.ctr-step h3{font-size:19px;margin-bottom:8px}
.ctr-step p{color:var(--ctr-ink-soft);font-size:15px}
.ctr-badge{display:inline-block;background:#fff;border:1.5px solid var(--ctr-orange);color:var(--ctr-orange);font-weight:700;font-size:12px;padding:3px 11px;border-radius:999px;margin-top:10px}

/* proof / logos */
.ctr-proof{background:#1f1f1f;color:#fff}
.ctr-proof .ctr-head h2{color:#fff}
.ctr-logos{display:flex;flex-wrap:wrap;gap:34px;align-items:center;margin-bottom:46px}
.ctr-logos img{height:38px;width:auto;filter:brightness(0) invert(1);opacity:.82;transition:.2s}
.ctr-logos img:hover{opacity:1}
.ctr-logo-txt{font-weight:700;font-size:22px;letter-spacing:.01em;color:#fff;opacity:.9}
.ctr-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:760px){.ctr-quotes{grid-template-columns:1fr}}
.ctr-quote{background:#262220;border:1px solid #332c28;border-radius:14px;padding:24px}
.ctr-quote p{font-size:15px;color:#e7e2dd;margin-bottom:14px}
.ctr-quote .who{font-size:13px;color:var(--ctr-orange-light);font-weight:600}
.ctr-quote .stars{color:var(--ctr-orange-light);font-size:14px;margin-bottom:12px;letter-spacing:2px}

/* faq */
.ctr-faq details{border-bottom:1px solid var(--ctr-line);padding:6px 0}
.ctr-faq summary{cursor:pointer;list-style:none;font-weight:600;font-size:17px;padding:18px 0;display:flex;justify-content:space-between;align-items:center}
.ctr-faq summary::-webkit-details-marker{display:none}
.ctr-faq summary::after{content:"+";color:var(--ctr-orange);font-size:24px;font-weight:400;transition:.2s}
.ctr-faq details[open] summary::after{transform:rotate(45deg)}
.ctr-faq details .a{padding:0 0 20px;color:var(--ctr-ink-soft);font-size:15.5px;max-width:780px}

/* cta band */
.ctr-cta{background:linear-gradient(135deg,var(--ctr-orange) 0%, var(--ctr-orange-dark) 100%);color:#fff;text-align:center}
.ctr-cta h2{font-size:33px;margin-bottom:12px;color:#fff}
.ctr-cta p{font-size:18px;opacity:.95;margin-bottom:26px}
.ctr-cta .ctr-btn-primary{background:#fff;color:var(--ctr-orange-dark)}
.ctr-cta .ctr-btn-primary:hover{background:#1f1f1f;color:#fff}
.ctr-cta .ctr-btn-ghost{border-color:rgba(255,255,255,.6)}

/* reveal on scroll — progressive enhancement only: hidden ONLY when JS is on
   (html.js), so a JS failure never leaves content invisible on a live page. */
.js .ctr-rv{opacity:0;transform:translateY(22px);transition:.6s cubic-bezier(.2,.7,.2,1)}
.js .ctr-rv.in{opacity:1;transform:none}
