/* ===== Nettoyeur Arc-en-Ciel — clean teal with rainbow accent ===== */
:root{
  --teal:#0096a8;        /* matched to vibrant cyan-teal in storefront branding */
  --teal-dk:#005a68;
  --teal-soft:#cdf2f7;
  --rb-1:#ef4444;
  --rb-2:#f59e0b;
  --rb-3:#10b981;
  --rb-4:#3b82f6;
  --rb-5:#a855f7;
  --cream:#f0fdfa;
  --ink:#0f1f1d;
  --ink-soft:#3f5f5b;
  --paper:#fff;
  --line:#d4eee8;
  --shadow:0 6px 24px rgba(13,148,136,.08);
  --shadow-lg:0 24px 60px rgba(13,148,136,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--teal)}
.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}
.uppercase{text-transform:uppercase;letter-spacing:.16em}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem 1.6rem;border-radius:8px;font-weight:600;font-size:.85rem;letter-spacing:.04em;transition:all .25s;cursor:pointer;border:none;font-family:inherit}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 18px rgba(13,148,136,.32)}
.btn-primary:hover{background:var(--teal-dk);transform:translateY(-2px);box-shadow:0 12px 28px rgba(17,94,89,.4)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}

.rainbow-bar{height:4px;background:linear-gradient(90deg,var(--rb-1) 0%,var(--rb-2) 25%,var(--rb-3) 50%,var(--rb-4) 75%,var(--rb-5) 100%)}

.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--rb-1) 0%,var(--rb-2) 25%,var(--rb-3) 50%,var(--rb-4) 75%,var(--rb-5) 100%);display:grid;place-items:center;color:#fff;font-size:1.4rem;box-shadow:var(--shadow)}
.brand-name{font-family:'Manrope',sans-serif;font-size:1.4rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.brand-sub{font-size:.7rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em}
.nav-links{display:flex;gap:1.8rem;list-style:none}
.nav-links a{font-size:.88rem;font-weight:600;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--teal)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-cta .btn{padding:.65rem 1.2rem;font-size:.75rem}
.lang-toggle{display:inline-flex;align-items:center;gap:.15rem;border:1px solid var(--line);border-radius:8px;padding:.2rem;background:var(--cream)}
.lang-toggle button{background:transparent;border:none;padding:.35rem .65rem;border-radius:5px;font:600 .68rem/1 inherit;letter-spacing:.06em;cursor:pointer;color:var(--ink-soft);opacity:.7;transition:.2s;font-family:inherit}
.lang-toggle button.active{background:var(--teal);color:#fff;opacity:1}
.lang-toggle button:hover{opacity:1}
.burger{display:none;width:40px;height:40px;background:transparent;border:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer}
.burger span{width:22px;height:2px;background:var(--ink);transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.page-hero{padding:9rem 0 4rem;background:linear-gradient(180deg,var(--teal-soft) 0%,var(--cream) 100%);text-align:center;border-bottom:1px solid var(--line)}
.page-hero .crumb{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:1rem;font-weight:700}
.page-hero h1{font-family:'Manrope',sans-serif;font-size:clamp(2.4rem,6vw,4.4rem);font-weight:700;line-height:1.05;margin-bottom:1rem;letter-spacing:-.02em}
.page-hero h1 em{font-style:italic;color:var(--teal)}
.page-hero p{font-size:1.05rem;color:var(--ink-soft);max-width:600px;margin:0 auto}

.svc-list{max-width:880px;margin:0 auto}
.svc-row{display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;padding:2rem 0;border-bottom:1px solid var(--line)}
.svc-row-num{font-family:'Manrope',sans-serif;font-size:2.2rem;color:var(--teal);min-width:60px;font-weight:700}
.svc-row-info h3{font-family:'Manrope',sans-serif;font-size:1.3rem;font-weight:700;margin-bottom:.3rem}
.svc-row-info p{color:var(--ink-soft)}
.svc-row-price{font-family:'Manrope',sans-serif;font-size:1.3rem;color:var(--ink);font-weight:700}
@media (max-width:700px){.svc-row{grid-template-columns:1fr;gap:.5rem}.svc-row-price{margin-top:.4rem}.page-hero{padding:7rem 0 3rem}}

.hero{position:relative;min-height:80vh;display:grid;place-items:center;overflow:hidden;background:linear-gradient(180deg,var(--teal-soft) 0%,var(--cream) 100%)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(13,148,136,.16),transparent 50%),radial-gradient(circle at 80% 70%,rgba(168,85,247,.10),transparent 50%);pointer-events:none}
.hero-inner{position:relative;text-align:center;padding:7rem 0 5rem;max-width:880px;z-index:2}
.hero-tag{display:inline-block;font-size:.72rem;color:var(--teal-dk);font-weight:700;margin-bottom:1.4rem;padding:.45rem 1rem;background:#fff;border-radius:999px;border:1px solid var(--line)}
.hero h1{font-family:'Manrope',sans-serif;font-weight:800;font-size:clamp(2.6rem,7vw,5rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:1.5rem}
.hero h1 .line{display:block}
.hero-desc{font-size:1.1rem;color:var(--ink-soft);max-width:620px;margin:0 auto 2.2rem}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.hero-trust{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;padding-top:2rem;border-top:1px solid var(--line)}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:.2rem}
.trust-item strong{font-family:'Manrope',sans-serif;font-size:1.5rem;color:var(--teal-dk);font-weight:700}
.trust-item span{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}

section{padding:6rem 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 4rem}
.section-kicker{display:inline-flex;align-items:center;gap:.8rem;font-size:.72rem;font-weight:700;color:var(--teal);margin-bottom:1rem}
.section-kicker::before,.section-kicker::after{content:"";display:inline-block;width:30px;height:1px;background:var(--teal)}
.section-title{font-family:'Manrope',sans-serif;font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.1;font-weight:700;text-align:center;margin-bottom:1rem;letter-spacing:-.02em}
.section-sub{color:var(--ink-soft);font-size:1.05rem}

.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
.about-img-wrap{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg)}
.about-img-wrap img{aspect-ratio:4/5;object-fit:cover;width:100%}
.about-badge{position:absolute;right:-15px;bottom:25px;background:var(--teal);color:#fff;padding:1.3rem 1.6rem;border-radius:12px;text-align:center;box-shadow:var(--shadow-lg)}
.about-badge .num{font-family:'Manrope',sans-serif;font-size:2rem;line-height:1;font-weight:700}
.about-badge .lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;margin-top:.2rem}
.about p{margin-bottom:1.2rem;color:var(--ink-soft)}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--line)}
.stat{text-align:center}
.stat .n{font-family:'Manrope',sans-serif;font-size:1.6rem;color:var(--teal-dk);font-weight:700}
.stat .l{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-top:.2rem}

.services{background:var(--cream)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc{background:#fff;padding:2.4rem 2rem;border-radius:14px;border:1px solid var(--line);box-shadow:var(--shadow);transition:.3s;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);opacity:.3;transition:opacity .3s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--teal)}
.svc:hover::before{opacity:1}
.svc-icon{font-size:2.4rem;margin-bottom:1rem}
.svc h3{font-family:'Manrope',sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:.6rem}
.svc p{color:var(--ink-soft);font-size:.95rem}
.svc-note{text-align:center;margin-top:2.5rem;color:var(--ink-soft);font-style:italic}

.gallery{background:var(--paper)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.tile{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow);transition:transform .35s}
.tile:hover{transform:scale(1.02)}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.tile:hover img{transform:scale(1.08)}

.reviews{background:linear-gradient(180deg,var(--teal-soft) 0%,var(--cream) 100%)}
.rating-big{margin-top:1.5rem}
.rating-big .stars{color:var(--rb-2);font-size:1.8rem;letter-spacing:.1em}
.rating-big .meta{font-size:.85rem;color:var(--ink-soft);margin-top:.4rem;text-transform:uppercase;letter-spacing:.1em}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.rev-card{background:#fff;padding:2rem;border-radius:14px;box-shadow:var(--shadow);border-top:3px solid var(--teal)}
.rev-stars{color:var(--rb-2);margin-bottom:1rem;letter-spacing:.1em}
.rev-text{font-style:italic;color:var(--ink-soft);margin-bottom:1.4rem}
.rev-person{display:flex;align-items:center;gap:.8rem}
.rev-avatar{width:42px;height:42px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-weight:700}
.rev-name{font-weight:700;font-size:.95rem}
.rev-when{font-size:.75rem;color:var(--ink-soft)}

.contact{background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-list{list-style:none;margin:1.6rem 0;border-top:1px solid var(--line)}
.contact-list li{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--line);gap:1rem}
.contact-list li strong{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);font-weight:700}
.contact-list li a,.contact-list li span{font-weight:600;text-align:right}
.contact-list li a:hover{color:var(--teal)}
.contact-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem}
.map-wrap{border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);height:100%;min-height:380px;border:1px solid var(--line)}
.map-wrap iframe{width:100%;height:100%;border:none;display:block;min-height:380px}

.footer{background:var(--ink);color:#d4eee8;padding:4rem 0 2rem}
.footer .brand-name{color:#fff}
.footer .brand-sub{color:rgba(212,238,232,.6)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.ft-about{margin-top:1rem;color:rgba(212,238,232,.7);font-size:.95rem}
.footer h5{font-family:'Manrope',sans-serif;font-size:1.05rem;margin-bottom:1rem;color:#fff;font-weight:700}
.footer ul{list-style:none}
.footer ul li{padding:.4rem 0;font-size:.92rem;color:rgba(212,238,232,.7)}
.footer ul li a:hover{color:var(--teal-soft)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:2rem;border-top:1px solid rgba(212,238,232,.15);font-size:.8rem;color:rgba(212,238,232,.5)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.12s}
.reveal.delay-2{transition-delay:.24s}
.reveal.delay-3{transition-delay:.36s}

@media (max-width:900px){
  .nav-links{display:none;position:fixed;top:74px;left:0;right:0;flex-direction:column;background:#fff;padding:1.5rem;gap:.4rem;box-shadow:var(--shadow-lg);border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .nav-links a{display:block;padding:.7rem 0;font-size:1rem}
  .burger{display:flex}
  .nav-cta .btn{display:none}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .services-grid,.review-grid{grid-template-columns:1fr;gap:1rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  section{padding:4rem 0}
  .hero{min-height:75vh}
  .hero-inner{padding:4rem 0 3rem}
  .hero-trust{gap:1.4rem}
  .trust-item strong{font-size:1.2rem}
  .section-head{margin-bottom:2.5rem}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .map-wrap{min-height:280px}
  .map-wrap iframe{min-height:280px}
}
@media (max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .container{padding:0 1.1rem}
  .contact-list li{flex-direction:column;align-items:flex-start;gap:.3rem}
  .contact-list li a,.contact-list li span{text-align:left}
}
