/* =========================================================
   Cabinet Tournesol — Pop-art rétro 1960s
   Palette : cyan / jaune / cramoisi
   ========================================================= */

:root{
  --cyan:#0BB7C9;
  --cyan-deep:#0894A3;
  --yellow:#FFD200;
  --crimson:#E63558;
  --ink:#171312;
  --paper:#FBF4E4;
  --paper-2:#F3E7CC;
  --white:#ffffff;
  --shadow:6px 6px 0 var(--ink);
  --shadow-lg:10px 10px 0 var(--ink);
  --maxw:1180px;
  --halftone:radial-gradient(var(--ink) 1.4px, transparent 1.6px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
}
h1,h2,h3,.display{font-family:'Archivo Black','Space Grotesk',sans-serif;line-height:1;letter-spacing:-.01em}
a{color:inherit}
img{max-width:100%;display:block}
section{padding:84px 0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---- buttons ---- */
.btn{
  display:inline-block;cursor:pointer;border:3px solid var(--ink);
  background:var(--yellow);color:var(--ink);font-weight:700;
  font-family:'Space Grotesk',sans-serif;font-size:1.02rem;
  padding:14px 26px;border-radius:50px;text-decoration:none;
  box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;
}
.btn:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.btn:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}
.btn--crimson{background:var(--crimson);color:var(--white)}
.btn--cyan{background:var(--cyan);color:var(--ink)}
.btn--ghost{background:var(--white)}

/* ---- header ---- */
header{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:4px solid var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-family:'Archivo Black';font-size:1.25rem}
.brand .logo{width:42px;height:42px;flex:none}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{text-decoration:none;font-weight:600;position:relative}
.nav-links a:not(.btn):after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:3px;background:var(--crimson);transition:width .2s}
.nav-links a:not(.btn):hover:after{width:100%}
.burger{display:none;background:none;border:3px solid var(--ink);border-radius:10px;width:48px;height:44px;cursor:pointer}
.burger span{display:block;width:22px;height:3px;background:var(--ink);margin:3px auto}

/* ---- hero ---- */
.hero{position:relative;background:var(--cyan);border-bottom:4px solid var(--ink);overflow:hidden;padding:70px 0 90px}
.hero:before{content:"";position:absolute;inset:0;background-image:var(--halftone);background-size:18px 18px;opacity:.18}
.hero .blob{position:absolute;border-radius:50%;z-index:0}
.hero .b1{width:240px;height:240px;background:var(--yellow);top:-60px;right:8%;border:4px solid var(--ink)}
.hero .b2{width:120px;height:120px;background:var(--crimson);bottom:30px;left:4%;border:4px solid var(--ink)}
.hero .tri{position:absolute;width:0;height:0;border-left:70px solid transparent;border-right:70px solid transparent;border-bottom:120px solid var(--crimson);bottom:-20px;right:18%;transform:rotate(18deg);z-index:0}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.eyebrow{display:inline-block;background:var(--ink);color:var(--yellow);font-weight:700;padding:7px 16px;border-radius:40px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px}
.hero h1{font-size:clamp(2.3rem,5vw,3.9rem);color:var(--ink)}
.hero h1 .pop{color:var(--white);-webkit-text-stroke:2px var(--ink);text-stroke:2px var(--ink)}
.hero p.lead{font-size:1.18rem;margin:22px 0 30px;max-width:30em;font-weight:500}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art img{border:4px solid var(--ink);border-radius:18px;box-shadow:var(--shadow-lg);background:var(--paper-2);aspect-ratio:4/5;object-fit:cover;width:100%}
.hero-badge{position:absolute;bottom:-26px;left:-26px;background:var(--yellow);border:4px solid var(--ink);border-radius:50%;width:120px;height:120px;display:grid;place-items:center;text-align:center;font-family:'Archivo Black';font-size:.78rem;line-height:1.05;transform:rotate(-12deg);box-shadow:var(--shadow)}
.hero-badge b{font-size:1.7rem;display:block}

/* ---- marquee ---- */
.marquee{background:var(--ink);color:var(--yellow);overflow:hidden;border-bottom:4px solid var(--ink);padding:14px 0}
.marquee .track{display:flex;gap:46px;white-space:nowrap;font-family:'Archivo Black';font-size:1.05rem;animation:scroll 26s linear infinite;width:max-content}
.marquee .track span{display:flex;align-items:center;gap:46px}
.marquee .dot{color:var(--crimson)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---- section heading ---- */
.sec-head{max-width:42em;margin-bottom:46px}
.sec-tag{font-family:'Archivo Black';color:var(--crimson);font-size:.9rem;letter-spacing:.18em;text-transform:uppercase}
.sec-head h2{font-size:clamp(2rem,4.4vw,3rem);margin-top:10px}
.sec-head p{margin-top:14px;font-size:1.08rem;color:#3b3330}

/* ---- services ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--white);border:3px solid var(--ink);border-radius:18px;padding:30px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s;position:relative}
.card:hover{transform:translate(-4px,-4px);box-shadow:10px 10px 0 var(--ink)}
.card .num{position:absolute;top:18px;right:22px;font-family:'Archivo Black';font-size:2.4rem;color:var(--paper-2)}
.card .ic{width:58px;height:58px;border-radius:14px;display:grid;place-items:center;border:3px solid var(--ink);margin-bottom:18px;font-size:1.7rem}
.card:nth-child(1) .ic{background:var(--yellow)}
.card:nth-child(2) .ic{background:var(--cyan)}
.card:nth-child(3) .ic{background:var(--crimson)}
.card:nth-child(4) .ic{background:var(--cyan)}
.card:nth-child(5) .ic{background:var(--crimson)}
.card:nth-child(6) .ic{background:var(--yellow)}
.card h3{font-size:1.25rem;margin-bottom:10px}
.card p{font-size:.98rem;color:#403733}

/* ---- approach / process ---- */
.approach{background:var(--yellow);border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);position:relative}
.approach:before{content:"";position:absolute;inset:0;background-image:var(--halftone);background-size:20px 20px;opacity:.12}
.steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{background:var(--paper);border:3px solid var(--ink);border-radius:16px;padding:26px;box-shadow:var(--shadow)}
.step .st-n{font-family:'Archivo Black';font-size:1.4rem;background:var(--ink);color:var(--yellow);width:48px;height:48px;border-radius:50%;display:grid;place-items:center;margin-bottom:16px}
.step h3{font-size:1.12rem;margin-bottom:8px}
.step p{font-size:.93rem}

/* ---- split feature ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.split img{border:4px solid var(--ink);border-radius:18px;box-shadow:var(--shadow-lg);aspect-ratio:5/4;object-fit:cover;width:100%;background:var(--paper-2)}
.split ul{list-style:none;margin-top:20px;display:grid;gap:14px}
.split li{display:flex;gap:12px;align-items:flex-start;font-weight:500}
.split li b{flex:none;width:26px;height:26px;border-radius:50%;background:var(--crimson);color:#fff;display:grid;place-items:center;font-size:.85rem;border:2px solid var(--ink)}

/* ---- pricing ---- */
.pricing{background:var(--cyan);border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);position:relative}
.pricing:before{content:"";position:absolute;inset:0;background-image:var(--halftone);background-size:18px 18px;opacity:.14}
.plans{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.plan{background:var(--paper);border:3px solid var(--ink);border-radius:20px;padding:32px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.plan.feat{background:var(--ink);color:var(--paper);transform:translateY(-12px);box-shadow:var(--shadow-lg)}
.plan.feat .price,.plan.feat h3{color:var(--yellow)}
.plan .tagline{font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--crimson)}
.plan.feat .tagline{color:var(--cyan)}
.plan h3{font-size:1.5rem;margin:8px 0 4px}
.plan .price{font-family:'Archivo Black';font-size:2.8rem;margin:14px 0 2px}
.plan .price small{font-size:.95rem;font-family:'Space Grotesk';font-weight:600}
.plan .per{font-size:.86rem;opacity:.8;margin-bottom:18px}
.plan ul{list-style:none;display:grid;gap:11px;margin:8px 0 26px;font-size:.96rem}
.plan li{display:flex;gap:10px;align-items:flex-start}
.plan li:before{content:"✚";color:var(--crimson);font-weight:700;flex:none}
.plan.feat li:before{color:var(--cyan)}
.plan .btn{margin-top:auto;text-align:center}
.price-note{position:relative;text-align:center;margin-top:30px;font-weight:600;background:var(--paper);display:inline-block;padding:12px 22px;border:3px solid var(--ink);border-radius:40px;box-shadow:var(--shadow);left:50%;transform:translateX(-50%)}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.stat{border:3px solid var(--ink);border-radius:16px;padding:26px 14px;box-shadow:var(--shadow)}
.stat:nth-child(1){background:var(--yellow)}
.stat:nth-child(2){background:var(--cyan)}
.stat:nth-child(3){background:var(--crimson);color:#fff}
.stat:nth-child(4){background:var(--paper-2)}
.stat b{display:block;font-family:'Archivo Black';font-size:2.6rem}
.stat span{font-weight:600;font-size:.95rem}

/* ---- testimonials ---- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:var(--white);border:3px solid var(--ink);border-radius:18px;padding:28px;box-shadow:var(--shadow);position:relative}
.quote .mark{font-family:'Archivo Black';font-size:3rem;color:var(--cyan);line-height:.6}
.quote p{margin:14px 0 18px;font-weight:500}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .av{width:46px;height:46px;border-radius:50%;border:3px solid var(--ink);display:grid;place-items:center;font-family:'Archivo Black';background:var(--yellow)}
.quote .who b{font-size:.98rem}
.quote .who span{font-size:.82rem;color:#5a504c}

/* ---- contact ---- */
.contact{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.contact:before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--cyan) 1.4px,transparent 1.6px);background-size:22px 22px;opacity:.16}
.contact-grid{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:46px}
.contact h2{color:var(--yellow);font-size:clamp(2rem,4vw,2.8rem)}
.contact .info{margin-top:24px;display:grid;gap:18px}
.info-item{display:flex;gap:14px;align-items:flex-start}
.info-item .ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--cyan);color:var(--ink);display:grid;place-items:center;font-size:1.2rem;border:3px solid var(--paper)}
.info-item b{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan)}
.info-item a,.info-item span{color:var(--paper);text-decoration:none;font-weight:600}
.info-item a:hover{color:var(--yellow)}
form{background:var(--paper);color:var(--ink);border:3px solid var(--paper);border-radius:20px;padding:30px;box-shadow:var(--shadow-lg)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;border:3px solid var(--ink);border-radius:12px;padding:12px 14px;
  font-family:inherit;font-size:1rem;background:var(--white);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:3px solid var(--cyan);outline-offset:1px}
.field textarea{resize:vertical;min-height:110px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.88rem}
.check input{width:auto;flex:none;margin-top:4px}
.form-msg{margin-top:14px;font-weight:700;display:none;padding:12px 16px;border-radius:12px;border:3px solid var(--ink)}
.form-msg.ok{display:block;background:var(--cyan)}
.form-msg.err{display:block;background:var(--crimson);color:#fff}

/* ---- footer ---- */
footer{background:var(--paper-2);border-top:4px solid var(--ink);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.foot-grid h4{font-family:'Archivo Black';font-size:1rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.05em}
.foot-grid ul{list-style:none;display:grid;gap:9px}
.foot-grid a{text-decoration:none;font-weight:500}
.foot-grid a:hover{color:var(--crimson)}
.foot-brand p{margin-top:12px;max-width:28em;font-size:.95rem}
.foot-bottom{margin-top:40px;border-top:3px solid var(--ink);padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.86rem;font-weight:500}

/* ---- cookie banner ---- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:90;background:var(--ink);color:var(--paper);
  border:4px solid var(--yellow);border-radius:18px;padding:20px 24px;box-shadow:var(--shadow-lg);
  display:none;gap:20px;align-items:center;flex-wrap:wrap;justify-content:space-between;max-width:980px;margin:0 auto}
.cookie.show{display:flex}
.cookie p{font-size:.94rem;flex:1;min-width:250px}
.cookie a{color:var(--yellow);text-decoration:underline}
.cookie .c-btns{display:flex;gap:12px;flex-wrap:wrap}
.cookie .btn{font-size:.92rem;padding:10px 20px}

/* ---- legal pages ---- */
.legal{max-width:820px;margin:0 auto;padding:60px 22px 80px}
.legal h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:10px}
.legal .updated{color:var(--crimson);font-weight:700;margin-bottom:30px}
.legal h2{font-size:1.4rem;margin:34px 0 12px;border-left:6px solid var(--cyan);padding-left:14px}
.legal p,.legal li{margin-bottom:12px}
.legal ul{padding-left:22px}
.back-home{display:inline-block;margin-bottom:30px;font-weight:700;text-decoration:none;border:3px solid var(--ink);border-radius:40px;padding:8px 18px;box-shadow:var(--shadow);background:var(--yellow)}
.back-home:hover{transform:translate(-2px,-2px)}

/* ---- responsive ---- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-art{max-width:420px;margin:0 auto}
  .cards,.plans,.quotes{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .plan.feat{transform:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  section{padding:60px 0}
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--paper);flex-direction:column;
    padding:24px;border-bottom:4px solid var(--ink);display:none;gap:18px}
  .nav-links.open{display:flex}
  .burger{display:block}
  .cards,.plans,.quotes,.steps,.stats,.foot-grid,.row{grid-template-columns:1fr}
  .hero-badge{width:96px;height:96px;left:auto;right:-10px;bottom:-20px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}
