/* ============================================================
   ODSCO — Global staffing website
   v3 rebuild: calmer Randstad-style hierarchy, one coherent
   colour system, exact logo red (#DE2128), flat (no shadows).
   ============================================================ */

:root{
  --red:#DE2128;          /* exact logo red — used solid everywhere */
  --red-deep:#B5161C;     /* hover / pressed */
  --red-tint:#FBE9E9;     /* subtle hover fill */
  --ink:#171513;          /* primary text + dark sections */
  --ink-soft:#5C5853;     /* secondary text */
  --surface:#F5F3EF;      /* the single neutral surface */
  --line:rgba(23,21,19,.12);
  --line-light:rgba(255,255,255,.18);
  --white:#fff;
  --cw:1200px;
  --r:14px;
  --r-sm:10px;
  --pad-y:clamp(4rem,7vw,6rem);
  --pad-x:clamp(1.25rem,5vw,3rem);
  --shadow:none;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--white);
  font-family:"Hanken Grotesk",system-ui,Arial,sans-serif;
  font-size:1rem;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:6px}

/* ---------- Type hierarchy (calm, readable) ---------- */
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.02em;line-height:1.08}
.eyebrow{margin:0 0 .9rem;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red)}
h1,.section-title h2,.split-copy h2,.section-head h2,.employer-copy h2,
.proof-top h2,.process-head h2,.contact-modal h2{
  font-size:clamp(1.5rem,2.3vw,2.05rem);
}
.hero h1{font-size:clamp(1.9rem,3.1vw,2.7rem);line-height:1.06}
.cta h2{font-size:clamp(1.7rem,2.6vw,2.3rem);line-height:1.08}
h1 em,h2 em{font-style:normal;color:var(--red)}

/* ---------- Shared alignment column ---------- */
.hero,.section-title,.search-bar,.popular,.search-image,.split-intro,
.section-head,.industry-grid,.employers,.proof-top,.stats,.proof-image,
.process-head,.steps,.article-grid,.cta-inner,.footer-inner{
  max-width:var(--cw);margin-inline:auto;width:100%;
}

/* ---------- Buttons (solid red, no gradient) ---------- */
.primary-button,.ghost-button{
  display:inline-flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:700;
  padding:.85rem 1.4rem;border-radius:999px;border:2px solid transparent;
  transition:background .25s,color .25s,border-color .25s,transform .25s;
}
.primary-button{background:var(--red);color:#fff}
.primary-button:hover{background:var(--red-deep);transform:translateY(-2px)}
.ghost-button{background:transparent;color:var(--ink);border-color:var(--ink)}
.ghost-button:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.primary-button span,.ghost-button span{transition:transform .25s}
.primary-button:hover span,.ghost-button:hover span{transform:translate(2px,-2px)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:30;height:70px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad-x);background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{width:112px;height:46px;display:block}
.brand img{width:100%;height:100%;object-fit:contain;object-position:left center}
.site-header nav{display:flex;gap:1.7rem;font-size:.9rem;font-weight:600}
.site-header nav a{position:relative;padding:4px 0;transition:color .2s}
.site-header nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--red);transition:width .25s}
.site-header nav a:hover{color:var(--red)}
.site-header nav a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:1rem}
.text-button{border:2px solid var(--ink);border-radius:999px;background:none;padding:.55rem 1.05rem;font-size:.82rem;font-weight:700;transition:background .25s,color .25s}
.text-button:hover{background:var(--red);border-color:var(--red);color:#fff}
.menu-button{display:none;border:0;background:none;width:32px}
.menu-button span{display:block;height:2px;background:var(--ink);margin:7px 0;transition:transform .3s}

/* ---------- Section base ---------- */
section{padding:var(--pad-y) var(--pad-x)}

/* ---------- Hero ---------- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.5rem);align-items:center;
  padding-top:clamp(3rem,5vw,4rem)}
.hero-intro{max-width:33rem;color:var(--ink-soft);font-size:1rem;line-height:1.65;margin:1.4rem 0 0}
.hero-intro strong{color:var(--ink);font-weight:800}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-photo{position:relative;min-height:26rem;height:100%;border-radius:var(--r);overflow:hidden;
  background:url("https://images.unsplash.com/photo-1758518731706-be5d5230e5a5?auto=format&fit=crop&w=1500&q=85") center/cover;
  border:1px solid var(--line);will-change:transform;transition:transform .3s ease-out}

/* ---------- Job search (solid red) ---------- */
.job-search{background:var(--red);color:#fff}
.job-search .eyebrow{color:rgba(255,255,255,.85)}
.section-title{text-align:center;margin-bottom:2.4rem}
.section-title h2 em{color:#fff;opacity:.78}
.search-bar{background:#fff;color:var(--ink);padding:.6rem;border-radius:var(--r);
  display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem}
.search-bar label{padding:.6rem 1.1rem;border-right:1px solid var(--line);display:block}
.search-bar label span{display:block;font-size:.62rem;text-transform:uppercase;font-weight:700;letter-spacing:.08em;margin-bottom:.35rem;color:var(--ink-soft)}
.search-bar input{border:0;outline:0;width:100%;font-size:.95rem;background:none}
.search-bar button{border:0;background:var(--ink);color:#fff;padding:0 1.7rem;border-radius:var(--r-sm);
  font-size:.85rem;font-weight:700;display:inline-flex;align-items:center;gap:.5rem;transition:background .25s}
.search-bar button:hover{background:var(--red-deep)}
.popular{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-top:1.1rem;font-size:.82rem}
.popular button{border:1px solid rgba(255,255,255,.5);border-radius:999px;background:none;color:#fff;padding:.4rem .85rem;font-size:.78rem;font-weight:600;transition:background .25s,color .25s}
.popular button:hover{background:#fff;color:var(--red)}
.search-image{height:18rem;margin-top:3rem;border-radius:var(--r);overflow:hidden;position:relative;
  border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;text-align:center;
  background:linear-gradient(rgba(15,12,12,.5),rgba(15,12,12,.5)),
    url("https://images.unsplash.com/photo-1556484687-30636164638b?auto=format&fit=crop&w=1800&q=85") center/cover}
.search-image div{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:0 1.5rem}
.search-image strong{font-size:clamp(1.3rem,2vw,1.75rem);letter-spacing:-.02em}
.search-image span{font-size:.92rem;opacity:.92}

/* ---------- Split intro (talent) ---------- */
.split-intro{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.split-photo{min-height:30rem;border-radius:var(--r);overflow:hidden;position:relative;border:1px solid var(--line);
  background:url("https://images.unsplash.com/photo-1758518730384-be3d205838e8?auto=format&fit=crop&w=1300&q=85") center/cover;
  will-change:transform;transition:transform .3s ease-out}
.split-copy h2{margin:0 0 1.1rem}
.split-copy>p:not(.eyebrow){max-width:33rem;color:var(--ink-soft);line-height:1.65}
.feature-list{margin-top:2.2rem;border-top:1px solid var(--line)}
.feature-list a{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:1.1rem;
  padding:1.15rem .3rem;border-bottom:1px solid var(--line);transition:padding .25s,background .25s,color .25s}
.feature-list a:hover{background:var(--surface);padding-left:1rem;color:var(--red-deep)}
.feature-list span{font-size:.7rem;font-weight:700;color:var(--red)}
.feature-list strong{font-size:.98rem;font-weight:700}

/* ---------- Industries (uniform grid) ---------- */
.section-head{display:grid;grid-template-columns:1.3fr .9fr;gap:2rem;align-items:end;margin-bottom:2.6rem}
.section-head h2{margin:0}
.section-head>p{color:var(--ink-soft);line-height:1.6;align-self:end}
.industry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.industry-card{position:relative;aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;isolation:isolate;
  color:#fff;padding:1.4rem;display:flex;flex-direction:column;justify-content:space-between;
  background-size:cover;background-position:center;transform-style:preserve-3d;transition:transform .3s ease-out}
.industry-card::before{content:"";position:absolute;inset:0;z-index:-1;transition:opacity .35s;
  background:linear-gradient(180deg,rgba(10,8,8,.05) 0%,rgba(10,8,8,.8) 100%)}
.industry-card::after{content:"";position:absolute;inset:0;z-index:-1;opacity:0;transition:opacity .35s;
  background:linear-gradient(180deg,rgba(222,33,40,.15) 0%,rgba(181,22,28,.85) 100%)}
.industry-card:hover::after{opacity:1}
.card-no{font-size:.72rem;font-weight:700;letter-spacing:.08em;opacity:.9;transform:translateZ(30px)}
.industry-card h3{font-size:clamp(1.05rem,1.3vw,1.2rem);line-height:1.1;transform:translateZ(40px)}
.card-arrow{position:absolute;right:1.2rem;bottom:1.2rem;font-style:normal;font-weight:700;font-size:1rem;
  width:2.3rem;height:2.3rem;border:1px solid rgba(255,255,255,.6);border-radius:50%;display:grid;place-items:center;
  transition:background .3s,color .3s;transform:translateZ(30px)}
.industry-card:hover .card-arrow{background:#fff;color:var(--red)}
.industry-card.drivers{background-image:url("https://images.unsplash.com/photo-1574757974346-45bae947d89a?auto=format&fit=crop&w=1000&q=85")}
.industry-card.construction{background-image:url("https://images.unsplash.com/photo-1504307651254-35680f356dfd?auto=format&fit=crop&w=1000&q=85")}
.industry-card.logistics{background-image:url("https://images.unsplash.com/photo-1565043666747-69f6646db940?auto=format&fit=crop&w=1000&q=85")}
.industry-card.healthcare{background-image:url("https://images.unsplash.com/photo-1516841273335-e39b37888115?auto=format&fit=crop&w=1000&q=85")}
.industry-card.technology{background-image:url("https://images.unsplash.com/photo-1551434678-e076c223a692?auto=format&fit=crop&w=1000&q=85")}
.industry-card.finance{background-image:url("https://images.unsplash.com/photo-1551836022-d5d88e9218df?auto=format&fit=crop&w=1000&q=85")}

/* ---------- Employers (neutral surface) ---------- */
.employers{background:var(--surface);display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:start}
.employer-copy{position:sticky;top:90px}
.employer-copy h2{margin:0 0 1rem}
.employer-copy>p:not(.eyebrow){max-width:30rem;color:var(--ink-soft);line-height:1.65}
.employer-copy .primary-button{margin-top:1.6rem}
.employer-image{margin-top:1.8rem;height:18rem;border-radius:var(--r);border:1px solid var(--line);
  background:url("https://images.unsplash.com/photo-1521791136064-7986c2920216?auto=format&fit=crop&w=1200&q=85") center/cover;
  will-change:transform;transition:transform .3s ease-out}
.solutions{border-top:1px solid var(--line)}
.solution-card{display:grid;grid-template-columns:auto 1fr;column-gap:1.3rem;row-gap:.4rem;
  padding:1.8rem .3rem;border-bottom:1px solid var(--line);transition:padding .3s}
.solution-card:hover{padding-left:.9rem}
.solution-card .line-icon{grid-row:1/3;align-self:start}
.solution-card h3{font-size:clamp(1.1rem,1.4vw,1.3rem)}
.solution-card p{grid-column:2;max-width:34rem;color:var(--ink-soft);font-size:.95rem;line-height:1.55;margin:0}

/* line icons + hover */
.line-icon{width:2.6rem;height:2.6rem;fill:none;stroke:var(--red);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;
  transition:transform .35s,stroke .35s}
.solution-card:hover .line-icon{transform:scale(1.1);stroke:var(--red-deep)}

/* ---------- Proof / stats ---------- */
.proof-top{display:grid;grid-template-columns:1fr 1.4fr;gap:2rem;align-items:end;margin-bottom:3rem}
.proof-top h2{grid-column:1/-1;margin:0;max-width:20ch}
.proof-top>p:last-child{color:var(--ink-soft);line-height:1.6;align-self:end}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.stat{padding:1.9rem;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);
  display:flex;flex-direction:column;gap:.55rem;transition:background .3s,border-color .3s,transform .3s}
.stat:hover{background:#fff;border-color:var(--red);transform:translateY(-4px)}
.stat-value{display:flex;align-items:baseline;gap:.1em}
.stat-value strong{font-size:clamp(2rem,3vw,2.6rem);letter-spacing:-.03em;color:var(--red);line-height:1;font-weight:800}
.stat-value span{font-size:clamp(.95rem,1.4vw,1.2rem);font-weight:800;color:var(--red)}
.stat p{margin:0;font-size:.9rem;color:var(--ink-soft);line-height:1.45}
.proof-image{height:22rem;margin-top:3rem;border-radius:var(--r);border:1px solid var(--line);
  background:url("https://images.unsplash.com/photo-1522071820081-009f0129c71c?auto=format&fit=crop&w=1900&q=85") center/cover;
  will-change:transform;transition:transform .3s ease-out}

/* ---------- Process (dark, clean cards) ---------- */
.process{background:var(--ink);color:#fff}
.process .eyebrow{color:rgba(255,255,255,.6)}
.process-head{margin-bottom:2.6rem}
.process-head h2 em{color:#fff;opacity:.7}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.steps article{border:1px solid var(--line-light);border-radius:var(--r);padding:1.9rem;
  min-height:15rem;display:flex;flex-direction:column;gap:.45rem;transition:background .3s,border-color .3s,transform .3s}
.steps article:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.4);transform:translateY(-4px)}
.steps article>span{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.55);letter-spacing:.08em}
.steps .step-icon{width:3rem;height:3rem;stroke:#fff;margin:.5rem 0 .7rem;
  stroke-dasharray:240;stroke-dashoffset:240;transition:stroke-dashoffset 1.1s ease .15s,transform .35s}
.steps article.visible .step-icon{stroke-dashoffset:0}
.steps article:hover .step-icon{transform:scale(1.08)}
.steps h3{font-size:1.1rem;margin-top:auto}
.steps p{font-size:.92rem;line-height:1.55;color:#bdbab6;margin:0}

/* ---------- Insights ---------- */
.link-arrow{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--red);align-self:end;transition:color .2s}
.link-arrow:hover{color:var(--red-deep)}
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.article-card{display:flex;flex-direction:column;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  transition:transform .3s,border-color .3s}
.article-card:hover{transform:translateY(-5px);border-color:var(--red)}
.article-image{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative;overflow:hidden}
.article-image span{position:absolute;top:.9rem;left:.9rem;background:#fff;padding:.35rem .75rem;border-radius:999px;
  font-size:.62rem;text-transform:uppercase;font-weight:700;letter-spacing:.06em}
.article-one{background-image:url("https://images.unsplash.com/photo-1586528116311-ad8dd3c8310d?auto=format&fit=crop&w=1000&q=85")}
.article-two{background-image:url("https://images.unsplash.com/photo-1522202176988-66273c2fd55f?auto=format&fit=crop&w=1000&q=85")}
.article-three{background-image:url("https://images.unsplash.com/photo-1516841273335-e39b37888115?auto=format&fit=crop&w=1000&q=85")}
.article-card>p{margin:1.2rem 1.2rem .3rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:700}
.article-card h3{font-size:1.05rem;line-height:1.32;letter-spacing:-.005em;margin:0 1.2rem 1.2rem}

/* ---------- CTA (solid red, clean) ---------- */
.cta{background:var(--red);color:#fff}
.cta .eyebrow{color:rgba(255,255,255,.85)}
.cta h2{margin:0 0 2.2rem;max-width:16ch}
.cta h2 em{color:#fff;opacity:.78}
.cta-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cta-actions a,.cta-actions button{display:flex;justify-content:space-between;align-items:center;
  padding:1.2rem 1.4rem;border-radius:var(--r);border:1.5px solid rgba(255,255,255,.55);background:transparent;color:#fff;
  font-weight:700;font-size:.95rem;transition:background .3s,color .3s,border-color .3s}
.cta-actions button{background:#fff;color:var(--red);border-color:#fff}
.cta-actions a:hover{background:#fff;color:var(--red);border-color:#fff}
.cta-actions button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cta-actions i{font-style:normal;font-weight:800;transition:transform .25s}
.cta-actions a:hover i,.cta-actions button:hover i{transform:translate(2px,-2px)}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:#cbc7c2;padding:clamp(3.5rem,6vw,4.5rem) var(--pad-x) 1.5rem}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.4rem}
.footer-logo{width:128px;height:50px}
.footer-logo img{width:100%;height:100%;object-fit:contain;object-position:left center}
.footer-brand p{margin:1.1rem 0 1.3rem;font-size:.88rem;color:#928e89;max-width:30ch;line-height:1.55}
.social{list-style:none;display:flex;gap:.6rem;padding:0;margin:0}
.social a{width:2.3rem;height:2.3rem;border-radius:50%;border:1px solid var(--line-light);
  display:grid;place-items:center;color:#cbc7c2;transition:background .25s,color .25s,border-color .25s,transform .25s}
.social svg{width:1rem;height:1rem;fill:currentColor}
.social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-3px)}
.footer-col{display:flex;flex-direction:column;gap:.65rem}
.footer-col strong{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:#8d8984;margin-bottom:.5rem}
.footer-col a,.footer-col button{font-size:.9rem;color:#cbc7c2;background:none;border:0;padding:0;text-align:left;transition:color .2s}
.footer-col a:hover,.footer-col button:hover{color:#fff}
.footer-bottom{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;
  border-top:1px solid var(--line-light);margin-top:2.4rem;padding-top:1.3rem;font-size:.76rem;color:#8d8984}
.footer-legal{margin-left:auto;display:flex;gap:1.1rem}
.footer-legal a:hover{color:#fff}

/* ---------- Contact modal ---------- */
.contact-modal{width:min(92vw,680px);border:0;border-radius:var(--r);background:var(--surface);padding:clamp(1.8rem,4vw,2.8rem);max-height:92vh}
.contact-modal::backdrop{background:rgba(23,21,19,.7)}
.modal-close{position:absolute;right:1.1rem;top:1.1rem;width:2.4rem;height:2.4rem;border:1px solid var(--ink);
  border-radius:50%;background:none;font-size:1.3rem;transition:background .25s,color .25s}
.modal-close:hover{background:var(--red);border-color:var(--red);color:#fff}
.contact-modal h2{margin:.8rem 0 1.8rem}
.contact-modal form{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.contact-modal label{font-size:.66rem;text-transform:uppercase;font-weight:700;letter-spacing:.06em;color:var(--ink-soft);display:flex;flex-direction:column;gap:.5rem}
.contact-modal .full,.contact-modal form>button{grid-column:1/-1}
.contact-modal input,.contact-modal select,.contact-modal textarea{background:none;border:0;border-bottom:1px solid var(--ink);
  padding:.65rem 0;outline:0;font-size:1rem;color:var(--ink)}
.contact-modal textarea{height:5rem;resize:vertical}
.contact-modal form>button{border:0;border-radius:999px;background:var(--red);color:#fff;padding:.95rem;
  display:flex;justify-content:center;gap:.5rem;font-size:.85rem;font-weight:700;transition:background .25s}
.contact-modal form>button:hover{background:var(--red-deep)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;gap:2rem}
  .hero-photo{min-height:22rem;order:2}
  .industry-grid{grid-template-columns:repeat(2,1fr)}
  .employers{grid-template-columns:1fr;gap:2.5rem}
  .employer-copy{position:static}
}
@media(max-width:880px){
  .site-header nav{position:fixed;inset:70px 0 auto;flex-direction:column;background:#fff;padding:1.5rem var(--pad-x);
    border-bottom:1px solid var(--line);display:none;font-size:1.05rem;gap:1rem}
  .site-header nav.open{display:flex}
  .text-button{display:none}
  .menu-button{display:block}
  .split-intro{grid-template-columns:1fr;gap:2.5rem}
  .split-photo{min-height:22rem;order:2}
  .section-head{grid-template-columns:1fr;gap:1rem}
  .proof-top{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .steps,.article-grid{grid-template-columns:1fr}
  .cta-actions{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .search-bar{grid-template-columns:1fr}
  .search-bar label{border-right:0;border-bottom:1px solid var(--line)}
  .search-bar button{padding:1rem}
}
@media(max-width:560px){
  .industry-grid{grid-template-columns:1fr}
  .industry-card{aspect-ratio:5/4}
  .hero-actions{flex-direction:column;align-items:stretch}
  .footer-inner{grid-template-columns:1fr}
  .footer-legal{margin-left:0}
  .contact-modal form{grid-template-columns:1fr}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .steps .step-icon{stroke-dashoffset:0!important}
}
