/*
Theme Name: JobMarket
Theme URI: https://jobmarket.fr
Author: JobMarket
Author URI: https://jobmarket.fr
Description: Theme sur-mesure pour JobMarket — recrutement d'extras qualifiés en hôtellerie, ménage et BTP. Style minimaliste, sable & noir, photographie d'architecture. Prêt à l'emploi pour IONOS WordPress.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jobmarket
*/

/* ====================================================================
   1. VARIABLES & RESET
   ==================================================================== */
:root{
  --sand:        #E7DFD5;
  --sand-deep:   #DED4C7;
  --sand-soft:   #EFE9E1;
  --ink:         #101010;
  --ink-soft:    #2a2926;
  --muted:       #5a574f;
  --white:       #ffffff;
  --line:        rgba(16,16,16,.12);
  --line-strong: rgba(16,16,16,.85);
  --shadow:      0 24px 60px -28px rgba(16,16,16,.35);
  --maxw:        1180px;
  --r:           4px;
  --ease:        cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:'Mulish',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink);
  background:var(--sand);
  font-size:18px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3,h4{
  font-family:'Poppins',sans-serif;
  font-weight:500;
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--ink);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
strong{font-weight:700;color:var(--ink)}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}

/* ====================================================================
   2. HEADER
   ==================================================================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(231,223,213,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.site-header.is-scrolled{border-color:var(--line);background:rgba(231,223,213,.94)}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand svg{width:38px;height:38px;flex:none}
.brand-name{
  font-family:'Poppins',sans-serif;font-weight:600;font-size:20px;
  letter-spacing:.01em;
}
.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-size:15px;font-weight:600;letter-spacing:.02em;
  position:relative;padding:6px 0;color:var(--ink-soft);
  transition:color .2s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;
  background:var(--ink);transition:width .28s var(--ease);
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--ink);color:var(--sand-soft);
  font-family:'Poppins',sans-serif;font-weight:500;font-size:15px;
  letter-spacing:.01em;padding:13px 26px;border-radius:50px;
  transition:transform .25s var(--ease),background .25s var(--ease);
  border:none;cursor:pointer;
}
.btn:hover{transform:translateY(-2px);background:#000}
.btn-ghost{
  background:transparent;color:var(--ink);
  border:1.5px solid var(--line-strong);
}
.btn-ghost:hover{background:var(--ink);color:var(--sand-soft)}
.nav-toggle{display:none}

/* ====================================================================
   3. HERO
   ==================================================================== */
.hero{
  display:grid;grid-template-columns:1fr 1fr;align-items:stretch;
  min-height:calc(100vh - 84px);
}
.hero-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(40px,7vw,96px) clamp(28px,6vw,90px);
  background:var(--sand);
}
.hero-text .eyebrow{
  font-family:'Poppins',sans-serif;font-weight:600;font-size:14px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  margin-bottom:28px;
}
.hero-text h1{
  font-size:clamp(38px,5.2vw,68px);font-weight:500;line-height:1.04;
}
.hero-text .lede{
  margin-top:30px;max-width:38ch;color:var(--ink-soft);font-size:18px;
}
.hero-text .hero-cta{margin-top:42px;display:flex;gap:14px;flex-wrap:wrap}
.hero-media{
  background:#1c1c1c center/cover no-repeat;
  position:relative;min-height:340px;
}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(0,0,0,.05),rgba(0,0,0,.18));
}

/* entrance animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}

/* ====================================================================
   4. ABOUT
   ==================================================================== */
.about{background:var(--white);padding:clamp(72px,11vw,140px) 0}
.about .wrap{max-width:920px;text-align:center}
.section-mark{display:flex;justify-content:center;margin-bottom:18px}
.section-mark svg{width:54px;height:54px}
.about h2{
  font-size:clamp(40px,6vw,76px);font-weight:400;margin-bottom:48px;
}
.about p{font-size:clamp(17px,1.4vw,19px);color:var(--ink-soft);margin-bottom:26px}
.about p:last-child{margin-bottom:0;margin-top:38px;font-size:19px}

/* ====================================================================
   5. EXPERTISE
   ==================================================================== */
.expertise{background:var(--sand);padding:clamp(72px,11vw,140px) 0}
.expertise h2{
  text-align:center;font-size:clamp(40px,6vw,76px);font-weight:400;
  margin-bottom:clamp(48px,7vw,86px);
}
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,2.4vw,34px);align-items:start;
}
.card{
  background:var(--white);border-radius:var(--r);
  padding:64px 34px 40px;position:relative;
  box-shadow:0 1px 0 rgba(16,16,16,.04);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.card-icon{
  position:absolute;top:-34px;left:50%;transform:translateX(-50%);
  width:68px;height:68px;border-radius:50%;background:var(--ink);
  display:grid;place-items:center;
}
.card-icon svg{width:30px;height:30px;stroke:var(--sand-soft)}
.card h3{
  font-family:'Poppins',sans-serif;font-weight:700;font-size:20px;
  letter-spacing:.04em;text-transform:uppercase;text-align:center;
  margin-bottom:24px;
}
.card ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.card li{
  position:relative;padding-left:22px;font-size:16px;color:var(--ink-soft);
  line-height:1.55;
}
.card li::before{
  content:"";position:absolute;left:0;top:9px;width:7px;height:7px;
  border-radius:50%;background:var(--ink);
}

/* ====================================================================
   6. BANNER
   ==================================================================== */
.banner{background:var(--white);padding:clamp(56px,8vw,104px) 0 0}
.banner h2{
  text-align:center;font-size:clamp(34px,5vw,62px);font-weight:400;
  max-width:18ch;margin:0 auto clamp(44px,6vw,72px);line-height:1.08;
}
.banner-media{
  height:clamp(280px,42vw,520px);
  background:#1c1c1c center/cover no-repeat;
}

/* ====================================================================
   7. CONTACT
   ==================================================================== */
.contact{background:var(--sand-deep);padding:clamp(64px,9vw,120px) 0}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);
  align-items:center;
}
.contact-photo{
  aspect-ratio:1/1;border-radius:var(--r);
  background:#1c1c1c center/cover no-repeat;box-shadow:var(--shadow);
}
.contact h2{
  font-size:clamp(40px,6vw,80px);font-weight:500;line-height:1.02;
  text-transform:uppercase;letter-spacing:-.01em;margin-bottom:44px;
}
.contact-list{display:flex;flex-direction:column;gap:20px}
.contact-line{display:flex;align-items:center;gap:16px;font-size:19px;font-weight:600}
.contact-line .ic{
  width:46px;height:46px;border-radius:50%;background:var(--ink);
  display:grid;place-items:center;flex:none;
}
.contact-line .ic svg{width:20px;height:20px;stroke:var(--sand-soft)}
.contact-line a{transition:opacity .2s var(--ease)}
.contact-line a:hover{opacity:.6}

/* ====================================================================
   8. FOOTER
   ==================================================================== */
.site-footer{background:var(--ink);color:#c9c4bb;padding:46px 0}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;font-size:14px;
}
.footer-inner .brand-name{color:var(--sand-soft)}
.footer-inner svg{width:30px;height:30px}
.footer-inner svg path,.footer-inner svg rect{stroke:var(--sand-soft)}

/* ====================================================================
   9. GENERIC PAGE / POSTS
   ==================================================================== */
.page-body{background:var(--white);padding:clamp(60px,9vw,120px) 0}
.page-body .wrap{max-width:780px}
.page-body h1{font-size:clamp(34px,5vw,56px);margin-bottom:32px;font-weight:400}
.page-body h2{font-size:28px;margin:36px 0 14px}
.page-body p,.page-body li{color:var(--ink-soft);margin-bottom:18px}
.page-body ul{padding-left:22px}

/* ====================================================================
   10. RESPONSIVE
   ==================================================================== */
@media(max-width:920px){
  .hero{grid-template-columns:1fr}
  .hero-media{min-height:46vh;order:-1}
  .hero{min-height:auto}
  .cards{grid-template-columns:1fr;gap:48px;max-width:440px;margin-inline:auto}
  .contact-grid{grid-template-columns:1fr}
  .contact-photo{max-width:420px;margin-inline:auto;width:100%}
  .nav{
    position:fixed;inset:84px 0 auto;flex-direction:column;gap:0;
    background:var(--sand-soft);padding:8px 0;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s var(--ease);
  }
  .nav.open{transform:none}
  .nav a{padding:16px 28px;width:100%;border-bottom:1px solid var(--line)}
  .nav a::after{display:none}
  .nav .btn{margin:14px 28px;justify-content:center}
  .nav-toggle{
    display:flex;flex-direction:column;gap:5px;background:none;border:none;
    cursor:pointer;padding:8px;
  }
  .nav-toggle span{width:26px;height:2px;background:var(--ink);transition:.3s var(--ease)}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:520px){
  body{font-size:16px}
  .hero-text .hero-cta{flex-direction:column;align-items:stretch}
  .btn{justify-content:center}
}
