@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM Sans:wght@400;500;600;700;800;900&display=swap');

:root{
  --dark:#090909;
  --panel:#141414;
  --panel-2:#1b1b1b;
  --line:#2b2b2b;
  --orange:#ff7a00;
  --orange-dark:#e66f00;
  --text:#eeeeee;
  --muted:#b5b5b5;
  --shadow:0 18px 45px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Montserrat, DM Sans, Arial,sans-serif;color:var(--text);background:var(--dark)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

.header{
  height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:0 clamp(18px,5vw,70px);background:#1b1b1b;position:sticky;top:0;z-index:50;
  box-shadow:0 1px 0 rgba(255,255,255,.08);
}
.header a {
  font-size: 15px;
}
.logo{display:flex;align-items:center;gap:10px;font-size:12px;font-weight:700;line-height:1.1;color:#fff}
.logo-icon{ width: 120px; height:90px;border-radius:12px;color:var(--orange);display:grid;place-items:center;font-weight:900;}
.logo strong{font-size:14px;color:var(--orange)}
.nav{display:flex;gap:26px;font-size:15px;font-weight:600;color:#fff}
.nav a{position:relative;color:#fff}
.nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:95%;height:5px;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
.nav a:hover::after{transform:scaleX(1)}
.nav a:hover{color:#fff}
.header-phone{background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white;border-radius:5px;padding:12px 18px;font-weight:800;font-size:13px}
.menu-btn{display:none;background:none;border:0;flex-direction:column;gap:5px}
.menu-btn span{width:26px;height:3px;background:#fff;border-radius:99px}

.hero{position:relative;min-height:580px;overflow:hidden;background:#0b0b0b}

.hero-bg{
  position:absolute;
  inset:0;
  overflow:hidden;
}

.hero-bg::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(
    90deg,
    rgba(0,0,0,.96),
    rgba(18,18,18,.82) 48%,
    rgba(18,18,18,.35)
  );
}

.hero-bg img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity 1.2s ease;
}

.hero-bg img.active{
  opacity:1;
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) 370px;gap:55px;align-items:center;padding:50px clamp(18px,5vw,70px)}

.tag{color:var(--orange);font-weight:800;margin:0 0 12px}
.hero h1{font-size:clamp(42px,6vw,72px);margin:0 0 18px;color:white;letter-spacing:-.04em}
.hero h1::after{content:"";display:none;width:320px;max-width:72%;height:8px;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);border-radius:99px;margin-top:2px}
.hero .hero-text h1{
font-weight: 600;
}
.hero p{color:#e8e8e8;line-height:1.65;max-width:720px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;padding:14px 22px;font-weight:800;font-size:14px}
.btn-orange{background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white}
.btn-orange:hover{background:var(--orange-dark)}
.btn-light{background:#171717;color:#fff;border:1px solid rgba(255,122,0,.35)}
.btn-blue{background:linear-gradient(135deg,#ff9a1f00 90%,#ff7a00 45%,#ff4d00 100%);color:white;filter: brightness(0.95)}

.estimate-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.estimate-top{background:rgba(211, 211, 211, 0.164);color:white;padding:22px}
.estimate-top h2{font-size:19px;margin:0 0 8px}
.estimate-top p{font-size:13px;color:#d8d8d8;margin:0 0 14px}
.estimate-top a{display:block;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white;text-align:center;border-radius:999px;padding:12px;font-weight:800;font-size:13px}
.estimate-top a:hover{background:var(--orange-dark)}
.mini-title{padding:20px 22px 0;margin:0;color:#fff!important;font-weight:800;font-size:14px}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:18px 22px 24px}
.choice-grid a{min-height:82px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;text-align:center;font-weight:700;color:#fff;font-size:13px;background:#181818}
.choice-grid a:hover{border-color:var(--orange);color:var(--orange)}

.section-title{text-align:center;max-width:800px;margin:0 auto 40px;}
.section-title h2{font-size:clamp(28px,4vw,42px);line-height:1.1;margin:0 0 10px;color:#fff;letter-spacing:-.03em; border: solid 2px var(--orange-gradient-soft);}
.section-title p{color:var(--muted);margin:0;line-height:1.6}

.services{padding:80px clamp(18px,5vw,70px);background:#1b1b1b}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1180px;margin:0 auto}
.card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel);box-shadow:var(--shadow)}

.card:hover{border-color:rgba(255,122,0,.45); transform:scale(1.015); transition: transform .45s ease; }
.image{
  height:165px;
  position:relative;
  overflow:hidden;
  background:#111;
}

.image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .45s ease;
}

.card:hover .image img{
  transform:scale(1.06);
}
.image::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.55))}
.image span{position:absolute;z-index:1;top:10px;left:10px;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white;border-radius:4px;padding:5px 8px;font-weight:800;font-size:10px}
.card h3{font-size:18px;color:#fff;margin:18px 18px 8px}
.card p{color:var(--muted);font-size:14px;line-height:1.6;margin:0 18px 22px}

.difference{display:grid;grid-template-columns:1.1fr .9fr;gap:95px;align-items:start;padding:90px clamp(18px,5vw,70px);background:#101010}
.eyebrow{text-transform:uppercase;font-weight:900;color:var(--orange);letter-spacing:.04em}
.diff-left h2{font-size:clamp(30px,4vw,48px);line-height:1.05;color:#fff;margin:0 0 24px;letter-spacing:-.04em}
.pills{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:24px}
.pills span{border:1px solid rgba(255,122,0,.35);background:#151515;border-radius:999px;padding:12px 16px;color:#fff;font-weight:700}
.zone-box{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px;margin-bottom:24px}
.zone-box h3{margin:0 0 8px;color:#fff}
.zone-box p{color:var(--muted);margin:0 0 14px}
.towns{display:flex;flex-wrap:wrap;gap:8px}
.towns span{background-color:rgba(211, 211, 211, 0.112);border-radius:999px;padding:8px 12px;font-size:13px;font-weight:700;color:#fff}
.map-window{position:absolute;right:28px;top:28px;background:#151515;border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:var(--shadow);text-align:left}
.map-window strong{display:block;color:#fff}
.map-window span{font-size:13px;color:var(--muted)}
.pin{width:36px;height:36px;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);position:absolute;left:50%;top:52%;border-radius:50% 50% 50% 0;transform:translate(-50%,-50%) rotate(-45deg);box-shadow:0 0 0 18px rgba(255,122,0,.18)}
.map-card {
  max-width: 75%;
}
.map-card p{position:absolute;left:0;right:0;bottom:22px;color:var(--muted);font-weight:700}

.why{padding:80px clamp(18px,5vw,70px);background:#0b0b0b}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:1180px;margin:0 auto}
.why article{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:28px;text-align:center;box-shadow:var(--shadow)}
.why article:hover{border-color:rgba(255,122,0,.45)}
.why span{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white;display:grid;place-items:center;margin:0 auto 18px;font-weight:900}
.why h3{color:#fff;margin:0 0 10px}
.why p{color:var(--muted);line-height:1.55;margin:0}

.reviews{padding:80px clamp(18px,5vw,70px);background:#0b0b0b}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1050px;margin:0 auto}
.review-grid article{border:1px solid var(--line);border-radius:10px;padding:24px;background:var(--panel)}
.review-grid article:hover{border-color:rgba(255,122,0,.45)}
.review-grid div{color:var(--orange)}
.review-grid p{color:var(--muted);font-size:14px;line-height:1.6}
.review-grid strong{display:block;color:#fff}
.review-grid span{color:var(--muted);font-size:13px}

.faq{padding:25px clamp(18px,5vw,70px);background:#0b0b0b}
.faq-list{max-width:900px;margin:0 auto;display:grid;gap:14px}
details{border:1px solid var(--line);border-radius:10px;background:var(--panel);padding:0 18px}
details:hover{border-color:rgba(255,122,0,.45)}
summary{cursor:pointer;padding:18px 0;font-weight:800;color:#fff}
details p{color:var(--muted);line-height:1.6;margin:0 0 18px}

.contact-section{padding:85px clamp(18px,5vw,70px);background:#1b1b1b}
.contact-form{max-width:660px;margin:0 auto;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:26px;box-shadow:var(--shadow)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;color:#fff;font-weight:700;font-size:13px;margin-bottom:14px}
input,select,textarea{width:100%;margin-top:7px;border:1px solid var(--line);background:#181818;border-radius:6px;padding:13px;color:#fff}
textarea{min-height:110px;resize:vertical}
.check{display:flex;gap:10px;align-items:flex-start;font-weight:500;color:var(--muted); font-size: 11px;}
.check input{width:auto;margin-top:2px}
.contact-form button{width:100%;border:0;background:linear-gradient(135deg,#ff9a1f 0%,#ff7a00 45%,#ff4d00 100%);color:white;border-radius:6px;padding:15px;font-weight:900;cursor:pointer}
.contact-form button:hover{background:var(--orange-dark)}

.form-message{
  margin:8px 0 0;
  font-size:12px;
  font-weight:500;
  text-align:center;
  opacity:.85;
}

.form-message.success{
  color:#58d68d;
}

.form-message.error{
  color:#ff7676;
}

.cta-band{background:linear-gradient(135deg,#111,#1c1c1c);color:white;text-align:center;padding:75px clamp(18px,5vw,70px);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band h2{font-size:clamp(26px,4vw,42px);margin:0 0 25px}
.cta-band div{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

.footer{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;background:#050505;color:white;padding:55px clamp(18px,5vw,70px)}
.footer h3,.footer h4{margin-top:0;color:var(white); font-weight: 500;}
.footer p,.footer a{display:block;color:#d5d5d5;line-height:1.8;font-size:14px; margin-top: 0;}

.footer{
  position:relative;
}

.footer-legal{
  width:100%;
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:10px;
}

.footer-legal a{
  font-size:11px;
  color:#8f8f8f;
  opacity:.8;
  transition:.2s ease;
  text-align:right;
}

.footer-legal a:hover{
  color:#ff7a00;
  opacity:1;
}

.footer-bottom{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;

  margin-top:35px;
  padding-top:18px;

  border-top:1px solid rgba(255,255,255,.08);
  grid-column:1/-1;
}

.footer-copyright p{
  font-size:11px;
  color:#6f6f6f;
  opacity:.75;
  margin:0;
}

.legal-page{
  padding:90px clamp(18px,5vw,70px);
  background:#0b0b0b;
  min-height:70vh;
}

.legal-page .legal-container{
  max-width:900px;
  margin:0 auto;
}

.legal-page h1{
  color:#fff;
  font-size:clamp(32px,5vw,48px);
  margin:0 0 14px;
}

.legal-page .legal-intro{
  color:var(--muted);
  margin-bottom:34px;
  line-height:1.7;
}

.legal-accordion{
  display:grid;
  gap:14px;
}

.legal-page .faq-item{
  background:linear-gradient(145deg,rgba(26,26,26,.98),rgba(14,14,14,.98));
  border:1px solid rgba(255,255,255,.09);
  border-radius:10px;
  overflow:hidden;
}

.legal-page .faq-item.is-open{
  border-color:rgba(255,122,0,.58);
}

.legal-page .faq-question{
  width:100%;
  min-height:58px;
  padding:18px 20px;
  background:transparent;
  border:0;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-weight:800;
  cursor:pointer;
  text-align:left;
}

.legal-page .faq-answer{
  max-height:0;
  overflow:hidden;
  padding:0 20px;
  transition:max-height .35s ease;
}

.legal-page .faq-answer p{
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
  padding-bottom:16px;
}

.legal-page .faq-answer a{
  color:#ff7a00;
  text-decoration:underline;
}

.legal-page .faq-icon{
  width:14px;
  height:14px;
  position:relative;
  flex-shrink:0;
}

.legal-page .faq-icon::before,
.legal-page .faq-icon::after{
  content:"";
  position:absolute;
  top:50%;
  left:0;
  width:100%;
  height:2px;
  background:#ff7a00;
  border-radius:99px;
  transition:transform .25s ease;
}

.legal-page .faq-icon::after{
  transform:rotate(90deg);
}

.legal-page .faq-item.is-open .faq-icon::after{
  transform:rotate(0);
}
.legal-return {
  padding-top: 65px;
}

@media(max-width:980px){
  .menu-btn{display:flex}
  .nav{position:absolute;left:18px;right:18px;top:74px;background:#1b1b1b;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);display:none;flex-direction:column;padding:20px}
  .nav.is-open{display:flex}
  .nav a::after{bottom:-5px}
  .header-phone{display:none}
  .hero-inner{grid-template-columns:1fr}
  .estimate-card{max-width:520px}
  .cards,.why-grid,.review-grid,.difference,.footer{grid-template-columns:1fr}
  .pills{grid-template-columns:1fr}
}
@media(max-width:620px){
  .header{padding:0 14px}
  .hero-inner{padding:30px 18px}
  .hero h1{font-size:42px}
  .hero h1::after{height:6px;width:240px}
  .services,.difference,.why,.reviews,.faq,.contact-section,.cta-band{padding-left:18px;padding-right:18px}
}
@media(max-width:1325px){
.difference  {
  display: flex;
  flex-wrap: wrap; 
  padding-bottom: 0;
}
.map-card img {
  display: none;
}

}

/* Améliorations premium Montserrat / orange */
:root{
  --orange-gradient: linear-gradient(135deg,#ffb347 0%,#ff7a00 42%,#ff4d00 100%);
  --orange-gradient-soft: linear-gradient(135deg,rgba(255,179,71,.22),rgba(255,122,0,.12),rgba(255,77,0,.05));
}

body{
  font-family:DM Sans, sans-serif;
  letter-spacing:-.01em;
}

.accent-text{
  color:#ff8a12;
  background:linear-gradient(135deg,#ffb347,#ff7a00 48%,#ff4d00);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.logo strong,
.tag,
.eyebrow,
.review-grid div{
  background:linear-gradient(135deg,#ffb347,#ff7a00 48%,#ff4d00);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.nav a::after{
  background:linear-gradient(90deg,#ffb347,#ff7a00,#ff4d00);
  height:3px;
  border-radius:999px;
  box-shadow:0 0 18px rgba(255,122,0,.55);
}

.header-phone,
.btn-orange,
.btn-blue,
.contact-form button,
.estimate-top a,
.image span{
  background:var(--orange-gradient);
  box-shadow:0 12px 28px rgba(255,94,0,.28);
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
}


.btn-orange:hover,
.btn-blue:hover,
.contact-form button:hover,
.estimate-top a:hover{
  transform:translateY(-2px);
  filter:saturate(1.08) brightness(1.05);
  box-shadow:0 18px 38px rgba(255,94,0,.36);
}

.btn-light{
  background:linear-gradient(135deg,#171717,#242424);
  border:1px solid rgba(255,122,0,.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 10px 28px rgba(0,0,0,.25);
}

.card,
.why article,
.review-grid article,
.contact-form,
.estimate-card,
.zone-box,
details,
.map-window{
  background:linear-gradient(145deg,rgba(26,26,26,.98),rgba(14,14,14,.98));
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 22px 55px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.04);
}

.card:hover,
.why article:hover,
.review-grid article:hover,
details:hover,
.choice-grid a:hover{
  border-color:rgba(255,122,0,.58);
  box-shadow:0 24px 60px rgba(0,0,0,.38), 0 0 0 1px rgba(255,122,0,.12);
}

.hero h1{
  font-weight:900;
}

.hero h1::after{
  background:linear-gradient(90deg,#ffb347,#ff7a00,#ff4d00);
  box-shadow:0 0 24px rgba(255,122,0,.45);
}

.estimate-card{
  backdrop-filter:blur(16px);
}

.choice-grid a{
  background:linear-gradient(145deg,#1a1a1a,#111);
}

.pills span{
  background:linear-gradient(145deg,#1b1b1b,#121212);
  border-color:rgba(255,122,0,.28);
}

.cta-band{
  background:
    linear-gradient(135deg,rgba(255,122,0,.16),rgba(255,77,0,.05)),
    linear-gradient(135deg,#111,#1c1c1c);
}

input:focus,
select:focus,
textarea:focus{
  outline:none;
  border-color:rgba(255,122,0,.78);
  box-shadow:0 0 0 3px rgba(255,122,0,.14);
}
