/* ============================================================
   LA CLINIQUE D'ORIENT — CANNES & CÔTE D'AZUR
   Design system : Ivoire / Bordeaux persan / Or antique
   Typographies : Cormorant Garamond (display) + Jost (texte)
   ============================================================ */

:root{
  --ivoire:#F7F1E6;
  --blanc:#FFFDF8;
  --encre:#201712;
  --encre-soft:#3A2E26;
  --bordeaux:#7B2D35;
  --bordeaux-dark:#5C2027;
  --or:#C9A227;
  --or-light:#E2C566;
  --taupe:#8C7B66;
  --display:'Cormorant Garamond',serif;
  --body:'Jost',sans-serif;
  --shadow:0 18px 50px rgba(32,23,18,.10);
  --shadow-hover:0 26px 60px rgba(32,23,18,.16);
  --transition:.3s cubic-bezier(.25,.6,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--ivoire);
  color:var(--encre);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.15;color:var(--encre)}
h1{font-size:clamp(2.4rem,5.2vw,4.3rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.35rem,2.2vw,1.8rem)}

.container{width:min(1180px,92%);margin:0 auto}
section{padding:96px 0;position:relative}
.section-tight{padding:72px 0}

/* ---------- Eyebrow + ligne or signature ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bordeaux);font-weight:500;margin-bottom:18px;
}
.eyebrow::before{
  content:"";width:0;height:1px;background:var(--or);
  transition:width 1s ease .2s;
}
.revealed .eyebrow::before{width:56px}
.dark .eyebrow{color:var(--or)}
.section-head{max-width:720px;margin-bottom:56px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head p{margin-top:16px;color:var(--encre-soft)}

/* ---------- Frise kilim (élément signature) ---------- */
.kilim{
  height:14px;width:100%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='14' viewBox='0 0 56 14'%3E%3Cpath d='M0 7 7 0l7 7-7 7zM28 7l7-7 7 7-7 7z' fill='%23C9A227' fill-opacity='.55'/%3E%3Cpath d='M14 7l7-7 7 7-7 7zM42 7l7-7 7 7-7 7z' fill='%237B2D35' fill-opacity='.45'/%3E%3C/svg%3E");
  background-repeat:repeat-x;background-position:center;
  opacity:.9;
}
.kilim.on-dark{opacity:.65}

/* ---------- Header ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(247,241,230,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(201,162,39,.25);
  transition:var(--transition);
}
.header-inner{
  width:min(1320px,94%);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:88px;transition:var(--transition);
}
.header.scrolled .header-inner{height:68px}
.logo img{height:52px;width:auto;transition:var(--transition)}
.header.scrolled .logo img{height:44px}

.nav{display:flex;align-items:center;gap:30px}
.nav>li{position:relative}
.nav a{font-size:.92rem;font-weight:500;letter-spacing:.04em;padding:8px 0;position:relative}
.nav>li>a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--or);transition:width .3s ease;
}
.nav>li>a:hover::after,.nav>li>a.active::after{width:100%}

.dropdown{position:relative}
.dropdown>a::before{content:"";display:none}
.submenu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,8px);
  background:var(--blanc);border:1px solid rgba(201,162,39,.3);
  min-width:300px;padding:10px 0;opacity:0;visibility:hidden;
  transition:var(--transition);box-shadow:var(--shadow);
}
.dropdown:hover .submenu{opacity:1;visibility:visible;transform:translate(-50%,0)}
.submenu a{display:block;padding:11px 22px;font-size:.9rem}
.submenu a:hover{background:var(--ivoire);color:var(--bordeaux);padding-left:28px}

.header-cta{display:flex;align-items:center;gap:18px}
.phone-link{
  font-family:var(--display);font-size:1.15rem;font-weight:700;color:var(--bordeaux);
  display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.phone-link svg{width:17px;height:17px;fill:var(--or)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--bordeaux);color:var(--ivoire)!important;
  padding:14px 30px;font-size:.9rem;font-weight:500;letter-spacing:.06em;
  border:1px solid var(--bordeaux);border-radius:3px;cursor:pointer;
  transition:var(--transition);text-transform:uppercase;
}
.btn:hover{background:var(--or);border-color:var(--or);color:var(--encre)!important;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ivoire)!important;border-color:var(--or)}
.btn-outline:hover{background:var(--or);color:var(--encre)!important}
.btn-light{background:var(--ivoire);color:var(--bordeaux)!important;border-color:var(--ivoire)}
.btn-light:hover{background:var(--or);border-color:var(--or);color:var(--encre)!important}
.header .btn{padding:11px 22px;font-size:.8rem}

.burger{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;gap:6px;align-items:center}
.burger span{display:block;width:26px;height:2px;background:var(--encre);transition:var(--transition)}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  min-height:92vh;display:flex;align-items:center;
  position:relative;overflow:hidden;color:var(--ivoire);
  padding:160px 0 110px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(24,15,12,.88) 0%,rgba(24,15,12,.72) 45%,rgba(60,25,28,.45) 100%);
}
.hero-content{position:relative;z-index:2;max-width:760px}
.hero h1{color:var(--ivoire);margin:14px 0 22px}
.hero h1 em{font-style:italic;color:var(--or-light)}
.hero p.lead{font-size:1.12rem;color:rgba(247,241,230,.88);max-width:600px;margin-bottom:36px;font-weight:300}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}

.hero-compact{min-height:62vh;padding:150px 0 80px}

.trustbar{
  position:relative;z-index:3;background:var(--encre);color:var(--ivoire);
  border-top:1px solid rgba(201,162,39,.35);
}
.trustbar-inner{
  width:min(1180px,92%);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);gap:24px;padding:22px 0;
}
.trust-item{display:flex;align-items:center;gap:12px;font-size:.85rem;letter-spacing:.03em}
.trust-item svg{width:22px;height:22px;fill:var(--or);flex-shrink:0}

/* ---------- Sections sombres ---------- */
.dark{background:var(--encre);color:rgba(247,241,230,.85)}
.dark h2,.dark h3{color:var(--ivoire)}

/* ---------- Compteurs ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat .num{
  font-family:var(--display);font-size:clamp(3rem,5.5vw,4.6rem);
  font-weight:700;color:var(--or);line-height:1;
}
.stat .num span{font-size:.55em}
.stat .label{margin-top:10px;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,241,230,.65)}

/* ---------- Cartes services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:34px}
.service-card{
  background:var(--blanc);border:1px solid rgba(201,162,39,.22);
  overflow:hidden;transition:var(--transition);position:relative;display:block;
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);border-color:var(--or)}
.service-card .img-wrap{height:280px;overflow:hidden}
.service-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.service-card:hover img{transform:scale(1.07)}
.service-card .card-body{padding:32px 34px 38px}
.service-card h3{margin-bottom:12px;transition:var(--transition)}
.service-card:hover h3{color:var(--bordeaux)}
.service-card p{font-size:.95rem;color:var(--encre-soft)}
.card-link{
  display:inline-flex;align-items:center;gap:10px;margin-top:20px;
  font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bordeaux);font-weight:600;
}
.card-link::after{content:"→";transition:transform .3s ease;color:var(--or)}
.service-card:hover .card-link::after{transform:translateX(6px)}

/* ---------- Atelier (2 colonnes) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}
.split .img-frame{position:relative}
.split .img-frame img{width:100%;height:540px;object-fit:cover}
.split .img-frame::before{
  content:"";position:absolute;inset:-16px 16px 16px -16px;
  border:1px solid var(--or);z-index:-1;
}
.split-text p{margin-bottom:18px;color:var(--encre-soft)}
.split-text p strong{color:var(--bordeaux)}

/* ---------- Galerie réalisations ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gallery figure{position:relative;overflow:hidden;height:320px;cursor:pointer}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.gallery figure:hover img{transform:scale(1.08)}
.gallery figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:40px 22px 18px;
  background:linear-gradient(transparent,rgba(24,15,12,.85));
  color:var(--ivoire);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
}

/* ---------- Avantages ---------- */
.adv-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.adv{
  background:var(--blanc);border:1px solid rgba(201,162,39,.22);
  padding:36px 24px;text-align:center;transition:var(--transition);
}
.adv:hover{transform:translateY(-6px);border-color:var(--or);box-shadow:var(--shadow)}
.adv svg{width:38px;height:38px;fill:none;stroke:var(--bordeaux);stroke-width:1.4;margin:0 auto 18px}
.adv h4{font-size:1.18rem;margin-bottom:10px}
.adv p{font-size:.84rem;color:var(--taupe);line-height:1.55}

/* ---------- Process ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;counter-reset:step}
.step{position:relative;padding-top:26px}
.step::before{
  counter-increment:step;content:"0" counter(step);
  font-family:var(--display);font-size:3.4rem;font-weight:700;
  color:transparent;-webkit-text-stroke:1px var(--or);
  position:absolute;top:-18px;left:0;line-height:1;
}
.step h4{font-size:1.2rem;margin-bottom:10px;position:relative}
.step p{font-size:.9rem;color:var(--encre-soft)}
.dark .step p{color:rgba(247,241,230,.7)}

/* ---------- Zones ---------- */
.zones-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.zones-grid{display:flex;flex-wrap:wrap;gap:12px}
.zone-pill{
  border:1px solid rgba(201,162,39,.45);padding:10px 20px;font-size:.88rem;
  border-radius:40px;transition:var(--transition);background:var(--blanc);
}
.zone-pill:hover{background:var(--bordeaux);color:var(--ivoire);border-color:var(--bordeaux)}

/* ---------- Témoignages ---------- */
.testimonials{position:relative;max-width:820px;margin:0 auto;text-align:center;min-height:300px}
.testimonial{
  position:absolute;inset:0;opacity:0;transition:opacity .9s ease;
  display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 20px;
}
.testimonial.active{opacity:1;position:relative}
.stars{color:var(--or);letter-spacing:6px;font-size:1.1rem;margin-bottom:22px}
.testimonial blockquote{
  font-family:var(--display);font-size:clamp(1.25rem,2.4vw,1.7rem);
  font-style:italic;line-height:1.5;color:var(--encre);
}
.dark .testimonial blockquote{color:var(--ivoire)}
.testimonial cite{margin-top:24px;font-style:normal;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bordeaux)}
.dark .testimonial cite{color:var(--or)}
.t-dots{display:flex;gap:10px;justify-content:center;margin-top:34px}
.t-dots button{width:9px;height:9px;border-radius:50%;border:1px solid var(--or);background:transparent;cursor:pointer;padding:0;transition:var(--transition)}
.t-dots button.active{background:var(--or)}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(201,162,39,.3)}
.faq-q{
  width:100%;background:none;border:none;text-align:left;cursor:pointer;
  font-family:var(--display);font-size:1.25rem;font-weight:600;color:var(--encre);
  padding:24px 50px 24px 0;position:relative;transition:var(--transition);
}
.faq-q:hover{color:var(--bordeaux)}
.faq-q::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:var(--body);font-weight:300;font-size:1.7rem;color:var(--or);transition:transform .35s ease;
}
.faq-item.open .faq-q::after{transform:translateY(-50%) rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s ease}
.faq-a p{padding:0 0 26px;color:var(--encre-soft);font-size:.97rem;max-width:760px}

/* ---------- CTA / Formulaire ---------- */
.cta{background:var(--bordeaux);color:var(--ivoire);overflow:hidden;position:relative}
.cta::before{
  content:"";position:absolute;inset:0;opacity:.07;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cpath d='M40 0l12 28 28 12-28 12-12 28-12-28L0 40l28-12z' fill='%23F7F1E6'/%3E%3C/svg%3E");
  background-size:80px;
}
.cta-wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;position:relative;z-index:1}
.cta h2{color:var(--ivoire)}
.cta .eyebrow{color:var(--or-light)}
.cta p{color:rgba(247,241,230,.85);margin:18px 0 30px}
.cta-contact{margin-top:8px}
.cta-contact a{display:flex;align-items:center;gap:14px;margin-bottom:16px;font-size:1.05rem;transition:var(--transition)}
.cta-contact a:hover{color:var(--or-light);transform:translateX(4px)}
.cta-contact svg{width:20px;height:20px;fill:var(--or)}
.cta-contact .big-phone{font-family:var(--display);font-size:1.9rem;font-weight:700}

.form{background:var(--blanc);padding:44px;color:var(--encre);box-shadow:var(--shadow)}
.form h3{margin-bottom:6px}
.form .form-sub{font-size:.88rem;color:var(--taupe);margin-bottom:26px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;color:var(--bordeaux);font-weight:500}
.field input,.field textarea,.field select{
  width:100%;border:1px solid rgba(140,123,102,.4);background:var(--ivoire);
  padding:14px 16px;font-family:var(--body);font-size:.95rem;color:var(--encre);
  transition:var(--transition);border-radius:2px;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--or);background:#fff}
.form .btn{width:100%;margin-top:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* ---------- Liens internes bas de page service ---------- */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related a{
  border:1px solid rgba(201,162,39,.3);background:var(--blanc);
  padding:26px 28px;font-family:var(--display);font-size:1.25rem;font-weight:600;
  transition:var(--transition);display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.related a::after{content:"→";color:var(--or);transition:transform .3s ease}
.related a:hover{border-color:var(--or);transform:translateY(-4px);box-shadow:var(--shadow)}

/* ---------- Footer ---------- */
.footer{background:var(--encre);color:rgba(247,241,230,.72);padding:80px 0 0;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1.3fr 1fr;gap:50px;padding-bottom:60px}
.footer h4{color:var(--ivoire);font-size:1.25rem;margin-bottom:22px;position:relative;padding-bottom:14px}
.footer h4::after{content:"";position:absolute;left:0;bottom:0;width:42px;height:1px;background:var(--or)}
.footer .f-logo{height:54px;width:auto;margin-bottom:20px;filter:brightness(1.1)}
.footer li{margin-bottom:11px}
.footer a:hover{color:var(--or-light)}
.footer .f-cities{display:flex;flex-wrap:wrap;gap:8px 0}
.footer .f-cities li{width:50%;font-size:.85rem}
.footer-bottom{
  border-top:1px solid rgba(201,162,39,.2);padding:24px 0;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.8rem;color:rgba(247,241,230,.45);
}

/* ---------- Flottants ---------- */
.whatsapp-float{
  position:fixed;right:24px;bottom:24px;z-index:900;
  width:58px;height:58px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.25);transition:var(--transition);
}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:30px;height:30px;fill:#fff}

.mobile-bar{display:none}

/* ---------- Animations reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .85s ease,transform .85s ease}
.reveal.revealed{opacity:1;transform:none}
.reveal-d1{transition-delay:.12s}
.reveal-d2{transition-delay:.24s}
.reveal-d3{transition-delay:.36s}
.reveal-d4{transition-delay:.48s}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .services-grid{grid-template-columns:1fr 1fr}
  .adv-grid{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:50px 20px}
  .split,.zones-wrap,.cta-wrap{grid-template-columns:1fr;gap:50px}
  .split .img-frame img{height:420px}
  .process{grid-template-columns:repeat(2,1fr);gap:44px 30px}
  .trustbar-inner{grid-template-columns:repeat(2,1fr);gap:14px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .related{grid-template-columns:1fr}
}

@media (max-width:860px){
  .nav{
    position:fixed;top:0;right:-100%;width:min(380px,86vw);height:100vh;
    background:var(--encre);flex-direction:column;align-items:flex-start;
    padding:110px 38px 40px;gap:6px;transition:right .45s cubic-bezier(.7,0,.3,1);z-index:990;
    overflow-y:auto;
  }
  .nav.open{right:0}
  .nav a{color:var(--ivoire);font-size:1.05rem;display:block;padding:12px 0}
  .submenu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:transparent;border:none;min-width:0;padding:0 0 0 18px}
  .submenu a{font-size:.92rem;color:rgba(247,241,230,.7);padding:8px 0}
  .burger{display:flex;z-index:995}
  .burger.open span{background:var(--ivoire)}
  .header-cta .btn{display:none}
  .phone-link span{display:none}
  body{font-size:16px}
  section{padding:70px 0}
  .hero{min-height:auto;padding:140px 0 90px}
  .mobile-bar{
    display:grid;grid-template-columns:1fr 1fr;position:fixed;bottom:0;left:0;right:0;z-index:900;
  }
  .mobile-bar a{padding:16px;text-align:center;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
  .mobile-bar .m-call{background:var(--encre);color:var(--ivoire)}
  .mobile-bar .m-devis{background:var(--bordeaux);color:var(--ivoire)}
  .whatsapp-float{bottom:78px;right:16px;width:52px;height:52px}
  body{padding-bottom:54px}
}

@media (max-width:640px){
  .services-grid,.adv-grid,.gallery,.stats,.process,.form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form{padding:30px 22px}
  .hero-actions .btn{width:100%}
  .split .img-frame::before{display:none}
}

/* ---------- Vidéos ---------- */
.hero-bg video{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.img-frame video{width:100%;height:540px;object-fit:cover;display:block}
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:start}
.video-card{background:var(--blanc);border:1px solid rgba(201,162,39,.25);transition:var(--transition)}
.video-card:hover{border-color:var(--or);box-shadow:var(--shadow)}
.video-card video{width:100%;display:block;background:#000}
.video-card figcaption{padding:16px 20px;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bordeaux);font-weight:500}
@media (max-width:1024px){.video-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.video-grid{grid-template-columns:1fr}.img-frame video{height:420px}}

/* ============ PASSE D'AMÉLIORATION GLOBALE ============ */

/* Accessibilité */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--bordeaux);color:var(--ivoire);padding:12px 22px;z-index:2000}
.skip-link:focus{left:12px;top:12px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--or);outline-offset:3px}
::selection{background:var(--bordeaux);color:var(--ivoire)}

/* Fil d'Ariane */
.breadcrumbs{background:var(--blanc);border-bottom:1px solid rgba(201,162,39,.2);font-size:.8rem;letter-spacing:.04em}
.breadcrumbs .container{display:flex;gap:10px;align-items:center;padding:13px 0;flex-wrap:wrap;color:var(--taupe)}
.breadcrumbs a{color:var(--bordeaux)}
.breadcrumbs a:hover{color:var(--or)}
.breadcrumbs span[aria-current]{color:var(--encre-soft)}
.breadcrumbs .sep{color:var(--or)}

/* Indicateur de scroll hero */
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;width:24px;height:40px;border:1.5px solid rgba(247,241,230,.6);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-cue::after{content:"";width:3px;height:8px;border-radius:3px;background:var(--or);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:translateY(0);opacity:1}55%{transform:translateY(12px);opacity:.2}}
.hero-compact .scroll-cue{display:none}

/* Badge hero */
.hero-badge{display:inline-flex;align-items:center;gap:10px;margin-top:26px;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(247,241,230,.75)}
.hero-badge::before{content:"";width:34px;height:1px;background:var(--or)}

/* Formulaire : select */
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237B2D35' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}

/* Teaser vidéos accueil */
.video-card .play-hint{font-size:.72rem;color:var(--taupe);letter-spacing:.04em;text-transform:none;display:block;margin-top:4px}

/* Page 404 */
.page-404{min-height:70vh;display:flex;align-items:center;text-align:center}
.page-404 .num{font-family:var(--display);font-size:clamp(6rem,16vw,11rem);color:transparent;-webkit-text-stroke:1.5px var(--or);line-height:1}

/* Carte intégrée */
.map-embed{border:1px solid rgba(201,162,39,.3);width:100%;height:380px;display:block;filter:sepia(.15) saturate(.9)}

/* Micro-polish */
.service-card .card-body{position:relative}
.gallery figure,.video-card{border-radius:2px;overflow:hidden}
.btn:active{transform:translateY(0) scale(.98)}
.footer a{transition:var(--transition)}

/* ============ LOGO V2 (plaque marine) ============ */
.logo img{height:72px;border-radius:8px;box-shadow:0 4px 14px rgba(16,28,46,.18)}
.header.scrolled .logo img{height:56px}
.footer .f-logo{height:96px;border-radius:10px}
@media (max-width:860px){.logo img{height:58px}.header.scrolled .logo img{height:48px}}

/* ============ ANIMATIONS 3D LÉGÈRES ============ */
.services-grid,.gallery,.adv-grid,.video-grid,.related{perspective:1100px}
.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .35s cubic-bezier(.2,.7,.3,1),box-shadow .35s ease,border-color .35s ease}
.tilt:hover{box-shadow:var(--shadow-hover)}
.tilt .card-body,.tilt figcaption{transform:translateZ(22px)}

/* Entrée 3D au scroll */
.reveal{transform:translateY(34px) rotateX(7deg);transform-origin:center 80%}
.reveal.revealed{transform:none}

/* Boutons : relief 3D + reflet */
.btn{position:relative;overflow:hidden;transform-style:preserve-3d;box-shadow:0 6px 0 -2px rgba(60,22,27,.45),0 12px 24px rgba(32,23,18,.18)}
.btn:hover{transform:translateY(-3px);box-shadow:0 9px 0 -2px rgba(60,22,27,.4),0 18px 32px rgba(32,23,18,.22)}
.btn:active{transform:translateY(1px);box-shadow:0 3px 0 -2px rgba(60,22,27,.5),0 6px 14px rgba(32,23,18,.2)}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,253,248,.35),transparent);transform:skewX(-20deg);transition:left .6s ease}
.btn:hover::after{left:140%}
.btn-outline{box-shadow:0 6px 0 -2px rgba(201,162,39,.35),0 12px 24px rgba(0,0,0,.25)}

/* Stat : léger pop 3D */
.stat{transition:transform .4s ease}
.stat:hover{transform:translateZ(0) scale(1.06) rotateX(4deg)}

@media (prefers-reduced-motion:reduce){
  .tilt,.tilt:hover{transform:none!important}
  .btn::after{display:none}
  .reveal{transform:none}
}
@media (hover:none){.tilt:hover{transform:none}}
