*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;color:#1a1a2e;overflow-x:hidden;-webkit-font-smoothing:antialiased}

:root{
  --teal:#0cb8b8;--teal-bright:#00dede;--teal-dark:#0a9e9e;
  --teal-10:rgba(12,184,184,0.1);--teal-5:rgba(12,184,184,0.05);
  --bg:#ffffff;--bg-soft:#f7f9fb;--bg-card:#ffffff;
  --text:#1a1a2e;--text-mid:#4a5568;--text-light:#94a3b8;
  --border:#f0f0f5;--radius:18px;--radius-sm:12px;
}

/* ═══ DYNAMIC BACKGROUND (subtle, premium) ═══ */
body{
  background: linear-gradient(120deg, rgba(12,184,184,.06), rgba(255,106,213,.05), rgba(255,199,0,.06));
  background-size: 300% 300%;
  animation: bgShift 14s ease-in-out infinite;
}
@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
body::before, body::after{
  content:"";
  position:fixed;
  inset:-30vmax;
  z-index:-1;
  pointer-events:none;
  background: radial-gradient(circle at 20% 30%, rgba(12,184,184,.22), transparent 55%),
              radial-gradient(circle at 80% 25%, rgba(255,106,213,.16), transparent 55%),
              radial-gradient(circle at 55% 85%, rgba(255,199,0,.18), transparent 60%);
  filter: blur(60px);
  transform: translate3d(0,0,0);
  opacity:.85;
}
body::before{animation: blobs 18s ease-in-out infinite alternate;}
body::after{animation: blobs 24s ease-in-out infinite alternate-reverse; opacity:.6}
@keyframes blobs{
  0%{transform:translate(-2%, -1%) scale(1)}
  50%{transform:translate(2%, 1%) scale(1.06)}
  100%{transform:translate(-1%, 2%) scale(1.02)}
}

/* ═══ TYPO DYNAMIQUE (MAJUSCULES + ESPACEMENT) ═══ */
h1,h2,h3,h4{ text-transform:uppercase; letter-spacing:.06em; }
.bt, .n-right a{ text-transform:uppercase; letter-spacing:.08em; }
p{ letter-spacing:0; }

/* Section backgrounds with movement */
.sc-gray{background: linear-gradient(135deg, rgba(12,184,184,.06), rgba(255,255,255,1) 55%, rgba(255,199,0,.06)); background-size:220% 220%; animation:bgShift 18s ease-in-out infinite}
.sc-dark{background: linear-gradient(135deg, #0b1220, #0f172a 60%, #08101f); color:#fff}
.sc-teal{background: linear-gradient(135deg, var(--teal-dark), var(--teal) 60%, var(--teal-bright)); color:#fff}

/* ═══ NAV ═══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:14px 32px;
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(30px) saturate(180%);
  -webkit-backdrop-filter:blur(30px) saturate(180%);
  border-bottom:1px solid rgba(0,0,0,0.04);
  display:flex;justify-content:space-between;align-items:center;
  transition:padding 0.3s;
}
nav.scrolled{padding:8px 32px;background:rgba(255,255,255,0.92)}
.n-left{display:flex;align-items:center;gap:10px;text-decoration:none}
.n-left img{height:38px;border-radius:8px}
.n-left span{font-weight:800;font-size:15px;color:var(--text);letter-spacing:0.5px;text-transform:uppercase}
.n-right{display:flex;gap:24px;align-items:center}
.n-right a{color:var(--text-mid);text-decoration:none;font-size:13px;font-weight:700;transition:color 0.2s;letter-spacing:0.5px;text-transform:uppercase}
.n-right a:hover{color:var(--teal)}
.n-cta{
  background:var(--teal)!important;color:#fff!important;
  padding:9px 22px!important;border-radius:100px;
  font-weight:700!important;transition:all 0.2s!important;
}
.n-cta:hover{background:var(--teal-dark)!important;transform:translateY(-1px)}
.ham{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.ham span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:0.3s}

/* ═══ HERO ═══ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 32px 80px;
  position:relative;overflow:hidden;
  background:var(--bg);
}
.hero-inner{
  max-width:1100px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
.hero-text{position:relative;z-index:2}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--teal-10);color:var(--teal-dark);
  padding:7px 16px;border-radius:100px;
  font-size:12px;font-weight:700;margin-bottom:24px;
  animation:fadeUp 0.8s ease both;
}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:blink 2s ease infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

.hero h1{
  font-size:clamp(38px,5.5vw,64px);font-weight:900;
  line-height:1.05;letter-spacing:1px;
  margin-bottom:20px;text-transform:uppercase;
  animation:fadeUp 0.8s ease 0.1s both;
}
.hero h1 .gr{
  background:linear-gradient(135deg,var(--teal),var(--teal-bright));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-p{
  font-size:16px;line-height:1.75;color:var(--text-mid);
  max-width:420px;margin-bottom:32px;font-weight:500;
  animation:fadeUp 0.8s ease 0.2s both;
}
.hero-actions{
  display:flex;gap:12px;flex-wrap:wrap;
  animation:fadeUp 0.8s ease 0.3s both;
}

/* Buttons */
.bt{
  display:inline-flex;align-items:center;gap:6px;
  padding:14px 30px;border-radius:100px;font-weight:700;
  font-size:14px;text-decoration:none;transition:all 0.25s;
  font-family:'Outfit',sans-serif;border:none;cursor:pointer;
  letter-spacing:-0.2px;
}
.bt-teal{
  background:var(--teal);color:#fff;
  box-shadow:0 4px 16px rgba(12,184,184,0.25);
}
.bt-teal:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(12,184,184,0.35)}
.bt-soft{background:var(--teal-10);color:var(--teal-dark)}
.bt-soft:hover{background:var(--teal);color:#fff}
.bt-outline{background:transparent;color:var(--teal);border:2px solid var(--teal)}
.bt-outline:hover{background:var(--teal);color:#fff}
.bt-white{background:#fff;color:var(--teal);font-weight:800;box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.bt-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.12)}

.hero-photo{
  position:relative;
  animation:fadeUp 0.8s ease 0.2s both;
}
.hero-photo img{
  width:100%;border-radius:var(--radius);
  box-shadow:0 24px 64px rgba(0,0,0,0.1);
}
.hero-photo .float-card{
  position:absolute;bottom:-16px;left:-16px;
  background:#fff;border-radius:var(--radius-sm);
  padding:14px 20px;box-shadow:0 8px 32px rgba(0,0,0,0.08);
  display:flex;align-items:center;gap:10px;
  animation:float 3s ease-in-out infinite;
}
.float-card .fc-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--teal-10);display:flex;align-items:center;justify-content:center;font-size:20px;
}
.float-card .fc-text strong{display:block;font-size:14px;font-weight:800;letter-spacing:-0.3px}
.float-card .fc-text span{font-size:11px;color:var(--text-light);font-weight:600}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.hero-photo .float-card2{
  position:absolute;top:20px;right:-12px;
  background:#fff;border-radius:100px;
  padding:10px 18px;box-shadow:0 8px 32px rgba(0,0,0,0.08);
  display:flex;align-items:center;gap:8px;
  animation:float 3s ease-in-out 1s infinite;
}
.float-card2 span{font-size:13px;font-weight:700;letter-spacing:-0.2px}

/* ═══ TICKER ═══ */
.ticker{
  background:var(--teal);padding:14px 0;overflow:hidden;
  white-space:nowrap;
}
.ticker-track{
  display:inline-flex;
  animation:scroll 22s linear infinite;
}
.ticker-track span{
  font-weight:800;font-size:13px;color:#fff;
  padding:0 20px;letter-spacing:0.5px;
}
.ticker-track .sep{opacity:0.35;font-size:10px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ SECTIONS ═══ */
.sc{padding:100px 32px;max-width:1100px;margin:0 auto}
.sc-gray{background: linear-gradient(135deg, rgba(12,184,184,.06), rgba(255,255,255,1) 55%, rgba(255,199,0,.06)); background-size:220% 220%; animation:bgShift 18s ease-in-out infinite}
.sc-dark{background: linear-gradient(135deg, #0b1220, #0f172a 60%, #08101f); color:#fff}
.sc-teal{background: linear-gradient(135deg, var(--teal-dark), var(--teal) 60%, var(--teal-bright)); color:#fff}

.hd{text-align:center;margin-bottom:52px}
.hd .tag{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--teal-10);color:var(--teal-dark);
  padding:5px 14px;border-radius:100px;
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;margin-bottom:14px;
}
.sc-dark .tag,.sc-teal .tag{background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.8)}
.hd h2{
  font-size:clamp(28px,4vw,44px);font-weight:900;
  letter-spacing:1px;line-height:1.1;margin-bottom:12px;text-transform:uppercase;
}
.hd p{font-size:15px;color:var(--text-mid);max-width:480px;margin:0 auto;line-height:1.7;font-weight:500}
.sc-dark .hd p,.sc-teal .hd p{color:rgba(255,255,255,0.7)}

/* ═══ ABOUT ═══ */
.ab-grid{display:grid;grid-template-columns:5fr 7fr;gap:48px;align-items:center}
.ab-img{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,0.08)}
.ab-img img{width:100%;display:block}
.ab-img .badge{
  position:absolute;bottom:14px;left:14px;
  background:var(--teal);color:#fff;padding:8px 16px;
  border-radius:var(--radius-sm);font-weight:800;font-size:11px;
  letter-spacing:0.3px;text-transform:uppercase;
  backdrop-filter:blur(8px);
}
.ab-txt h3{font-size:28px;font-weight:900;letter-spacing:0.5px;margin-bottom:4px;text-transform:uppercase}
.ab-txt .sub{color:var(--teal);font-weight:700;font-size:14px;margin-bottom:18px}
.ab-txt p{color:var(--text-mid);line-height:1.8;font-size:14px;margin-bottom:12px;font-weight:500}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}
.tg{
  background:var(--teal-5);border:1px solid var(--teal-10);color:var(--teal-dark);
  padding:6px 14px;border-radius:100px;font-size:12px;font-weight:700;
  transition:all 0.2s;
}
.tg:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ═══ CTA BAND ═══ */
.cta-band{
  background:linear-gradient(135deg,var(--teal),var(--teal-bright));
  padding:64px 32px;text-align:center;color:#fff;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;top:-80px;right:-80px;
  width:300px;height:300px;border-radius:50%;
  background:rgba(255,255,255,0.08);
}
.cta-band::after{
  content:'';position:absolute;bottom:-60px;left:-60px;
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,0.05);
}
.cta-band h2{font-size:clamp(22px,3.5vw,34px);font-weight:900;letter-spacing:1px;margin-bottom:10px;position:relative;text-transform:uppercase}
.cta-band p{font-size:16px;opacity:0.85;margin-bottom:28px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7;position:relative;font-weight:500}

/* ═══ PLANS ═══ */
.pl-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:640px;margin:0 auto}
.pl{
  background:var(--bg-card);border-radius:var(--radius);padding:36px 28px;
  text-align:center;border:2px solid var(--border);
  transition:all 0.3s;position:relative;
}
.pl:hover{border-color:var(--teal);transform:translateY(-6px);box-shadow:0 16px 48px rgba(12,184,184,0.12)}
.pl.hot{border-color:var(--teal)}
.pl.hot::before{
  content:'Le + populaire';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--teal);color:#fff;padding:5px 16px;
  border-radius:100px;font-size:10px;font-weight:800;letter-spacing:0.5px;white-space:nowrap;
}
.pl-ico{font-size:52px;margin-bottom:14px}
.pl h4{font-size:20px;font-weight:900;letter-spacing:0.5px;margin-bottom:8px;text-transform:uppercase}
.pl .big{
  font-size:22px;font-weight:900;color:var(--teal);
  letter-spacing:-0.5px;line-height:1.25;margin-bottom:8px;
}
.pl .sm{color:var(--text-mid);font-size:13px;line-height:1.6;margin-bottom:24px;font-weight:500}

/* ═══ DA ═══ */
.da-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.da{
  background:var(--bg-card);border-radius:var(--radius);padding:32px 22px;
  text-align:center;border:1px solid var(--border);transition:all 0.3s;
}
.da:hover{transform:translateY(-5px);box-shadow:0 12px 36px rgba(0,0,0,0.06);border-color:var(--teal)}
.da .ico{
  width:56px;height:56px;border-radius:14px;background:var(--teal-10);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;margin:0 auto 14px;
  transition:all 0.3s;
}
.da:hover .ico{background:var(--teal);transform:scale(1.1);filter:brightness(1.2)}
.da h4{font-size:16px;font-weight:800;letter-spacing:0.3px;margin-bottom:6px;text-transform:uppercase}
.da p{color:var(--text-mid);font-size:13px;line-height:1.6;font-weight:500}

/* ═══ INFO ═══ */
.info-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ic{
  background:var(--bg-card);border-radius:var(--radius);padding:28px 22px;
  text-align:center;border:1px solid var(--border);
}
.ic .ico{font-size:32px;margin-bottom:10px}
.ic h4{font-size:16px;font-weight:800;color:var(--teal);margin-bottom:6px;letter-spacing:0.3px;text-transform:uppercase}
.ic p{color:var(--text-mid);font-size:13px;line-height:1.6;font-weight:500}

/* ═══ GALLERY ═══ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gi{
  border-radius:var(--radius-sm);overflow:hidden;
  aspect-ratio:1;position:relative;
  transition:all 0.4s;cursor:pointer;
}
.gi::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.3));
  opacity:0;transition:opacity 0.3s;
}
.gi:hover{transform:scale(1.03);border-radius:var(--radius)}
.gi:hover::after{opacity:1}
.gi img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s}
.gi:hover img{transform:scale(1.08)}
.gi.big{grid-column:span 2;aspect-ratio:2/1}

/* ═══ TESTIMONIALS ═══ */
.te-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.te{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius);padding:28px;
  transition:all 0.3s;
}
.te:hover{background:rgba(255,255,255,0.08);transform:translateY(-4px)}
.te-stars{color:#fbbf24;font-size:14px;margin-bottom:10px;letter-spacing:2px}
.te p{color:rgba(255,255,255,0.7);font-size:13px;line-height:1.7;font-style:italic;margin-bottom:14px;font-weight:500}
.te .nm{font-weight:800;font-size:14px;color:#fff}
.te .ag{font-size:11px;color:rgba(255,255,255,0.4);font-weight:600}

/* ═══ MAP ═══ */
.map-wrap{
  border-radius:var(--radius);overflow:hidden;height:320px;
  box-shadow:0 4px 20px rgba(0,0,0,0.05);margin-top:28px;
  border:1px solid var(--border);
}
.map-wrap iframe{width:100%;height:100%;border:0}

/* ═══ CONTACT ═══ */
.co-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.cc{
  display:flex;align-items:center;gap:14px;
  background:var(--bg-card);border-radius:var(--radius-sm);
  padding:16px 18px;border:1px solid var(--border);
  text-decoration:none;color:var(--text);transition:all 0.25s;
}
.cc:hover{border-color:var(--teal);transform:translateX(6px);box-shadow:0 4px 16px rgba(12,184,184,0.08)}
.cc-i{
  width:44px;height:44px;border-radius:10px;
  background:var(--teal-10);display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;transition:all 0.3s;
}
.cc:hover .cc-i{background:var(--teal);filter:brightness(1.2)}
.cc h4{font-size:14px;font-weight:800;margin-bottom:1px;letter-spacing:0.3px;text-transform:uppercase}
.cc p{color:var(--text-light);font-size:12px;font-weight:500}
.fm{
  background:var(--bg-card);border-radius:var(--radius);padding:28px;
  border:1px solid var(--border);
}
.fm h3{font-size:20px;font-weight:900;margin-bottom:18px;color:var(--teal);letter-spacing:0.5px;text-transform:uppercase}
.fg{margin-bottom:12px}
.fg label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-light);margin-bottom:5px}
.fg input,.fg textarea,.fg select{
  width:100%;padding:11px 14px;border-radius:var(--radius-sm);
  border:1.5px solid var(--border);font-family:'Outfit',sans-serif;
  font-size:13px;font-weight:500;transition:border-color 0.2s;outline:none;
  background:#fff;color:var(--text);
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--teal)}
.fg textarea{resize:vertical;min-height:70px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ═══ FOOTER ═══ */
footer{
  background:#0f172a;color:#fff;padding:44px 28px;text-align:center;
}
.fb{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px}
.fb img{height:34px;border-radius:6px}
.fb span{font-weight:800;font-size:14px;letter-spacing:-0.3px}
.fl{display:flex;justify-content:center;gap:20px;margin-bottom:16px}
.fl a{color:rgba(255,255,255,0.4);text-decoration:none;font-size:13px;font-weight:600;transition:color 0.2s}
.fl a:hover{color:var(--teal-bright)}
.fs{display:flex;justify-content:center;gap:10px;margin-bottom:20px}
.fs a{
  width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.4);text-decoration:none;font-size:15px;transition:all 0.2s;
}
.fs a:hover{border-color:var(--teal-bright);color:var(--teal-bright)}
.fc{color:rgba(255,255,255,0.15);font-size:11px;font-weight:600}

/* ═══ ANIMATIONS ═══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.fi{opacity:0;transform:translateY(28px);transition:opacity 0.7s cubic-bezier(0.16,1,0.3,1),transform 0.7s cubic-bezier(0.16,1,0.3,1)}
.fi.v{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  .n-right{
    display:none;position:fixed;top:60px;left:0;right:0;bottom:0;
    background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);
    flex-direction:column;padding:28px;gap:18px;
  }
  .n-right.open{display:flex}
  .ham{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .hero-photo{max-width:400px;margin:0 auto}
  .ab-grid{grid-template-columns:1fr;gap:28px}
  .pl-row{grid-template-columns:1fr;max-width:340px}
  .da-row,.info-row{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr}
  .gi.big{grid-column:span 2}
  .te-row{grid-template-columns:1fr}
  .co-grid{grid-template-columns:1fr}
  .fr{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-actions{flex-direction:column}
  .hero-actions .bt{width:100%;justify-content:center}
}