/* =========================================================
   Travel Agency — CSS modernisé (garde le même HTML)
   ========================================================= */

/* ---------- Thème & tokens ---------- */
:root{
  --bg:#0e1b25;            /* bleu nuit */
  --surface:#0f2433;       /* cartes/nav */
  --surface-2:#122b3b;     /* variante */
  --line:#1e3a4b;          /* bordures discrètes */

  --ink:#eef7ff;           /* texte principal */
  --ink-dim:#c7d3e2;       /* texte secondaire */
  --muted:#8fa6ba;

  --accent:#1ec2d8;        /* cyan (CTA) */
  --accent-2:#ffb703;      /* sable (accent complémentaire) */

  --radius:16px;
  --shadow:0 12px 32px rgba(0,0,0,.25);
}

/* ---------- Reset léger ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0; padding:0; overflow-x:hidden; scroll-behavior:smooth;}
img{max-width:100%; display:block}
a{text-decoration:none; color:inherit}
button,input,select,textarea{font:inherit}

/* ---------- Base ---------- */
body{
  background:
    radial-gradient(1200px 600px at 80% -20%, rgba(30,194,216,.10), transparent),
    var(--bg);
  color:var(--ink);
  font-size:15px;
  line-height:1.6;
}

/* ---------- Header / Nav ---------- */
header{
  position:sticky; top:0; z-index:50;
  background:linear-gradient(0deg, rgba(14,27,37,.0), rgba(14,27,37,.85));
  backdrop-filter:saturate(130%) blur(6px);
  height:auto; border-bottom:1px solid rgba(255,255,255,.06);
}
.hautmenu{
  max-width:1200px; margin:0 auto; padding:18px 16px;
  display:flex; align-items:center; justify-content:space-between;
}
.logo{font-size:34px; letter-spacing:.5px}
.textelogo{ color:var(--accent-2); }

nav .menu{ list-style:none; display:flex; gap:22px; align-items:center; }
.droitmenu > a{
  color:var(--ink-dim); font-weight:700; letter-spacing:.04em;
  position:relative; padding:8px 4px; transition:color .25s ease, opacity .25s ease;
}
.droitmenu > a::after{
  content:""; position:absolute; left:6px; right:6px; bottom:-6px; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.droitmenu > a:hover{ color:#fff; }
.droitmenu > a:hover::after{ transform:scaleX(1); }

/* ---------- HERO (#main) ---------- */
p.texteimg1 {
    margin-top: unset;
}
#main{
  min-height: 72vh;
  background: url("main.jpg") center/cover no-repeat;
  position:relative;
}
#main::before{
  /* voile pour lisibilité du texte */
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.45) 60%, rgba(0,0,0,.25) 100%);
}
.texteimg1{
  position:relative; z-index:1;
  font-size: clamp(32px, 6vw, 64px);
  text-align:center; color:#eaf2fb;
  padding: 160px 12px 24px;
  text-shadow: 0 4px 24px rgba(0,0,0,.35);
}
.texteimg1 span{ color:#fff; font-weight:800; }

.conteneur{
  position:relative; z-index:1; display:flex; justify-content:center; align-items:center;
}
.boutonimg{
  margin-bottom: 32px; margin-top:32px; padding:14px 24px; min-width:140px;
  border:none; cursor:pointer; border-radius:999px;
  background:linear-gradient(90deg, var(--accent), #4be0f0);
  color:#04212a; font-weight:800; letter-spacing:.04em;
  box-shadow: 0 10px 28px rgba(30,194,216,.35);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.boutonimg:hover{ transform: translateY(-2px); box-shadow:0 16px 36px rgba(30,194,216,.45); filter:saturate(110%); }
.boutonimg:active{ transform: translateY(0); }

/* ---------- STEP (icônes) ---------- */
#step{ width:100%; padding: 0 10px; margin: 60px 0; }
#step1{
 margin:60px auto 60ox; padding:0 16px;
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
#step1 > div{
  flex:1 1 280px; min-width:260px;
  background: var(--surface); border:1px solid var(--line);
  border-radius: var(--radius); padding:24px 18px; text-align:center;
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
#step1 > div:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  border-color: var(--accent);
}
.icon1{ margin: 0 auto 12px; width:72px; height:auto; }
.txt2{ margin-top: 6px; font-size: 22px; color:#fff; }
.txt1{
  margin-top: 10px; color: var(--ink-dim);
  max-width: 40ch; margin-inline:auto;
}

/* ---------- Possibilities (cartes avec overlay) ---------- */
#posibilities{
  background: #f3f6fa;
  padding: 60px 0;
  display:flex; justify-content:center; gap:24px; flex-wrap:wrap;
}
.back{
  width: 460px; height: 270px; border-radius: 16px; overflow:hidden;
  background-size: cover; background-position:center; position:relative;
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
}
.overlay{
  position:absolute; inset:0;
  display:flex; align-items:center;
  background: linear-gradient(90deg, rgba(255,255,255,.95) 0 58%, rgba(255,255,255,0) 58%);
}
.txt-overlay{ width:58%; text-align:center; margin:0 auto; color:#0d2230; }
.txt-overlay h4{ text-transform:uppercase; font-size:20px; letter-spacing:.06em; padding-bottom:10px; }
.txt-overlay p{ padding-bottom:20px; color:#3d5568; }
.txt-overlay .btn1{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:140px; padding:12px 18px; border-radius:999px; font-weight:800;
  color:#053342; background: linear-gradient(90deg, var(--accent-2), #ffd166);
  box-shadow: 0 10px 26px rgba(255,183,3,.25);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.txt-overlay .btn1:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(255,183,3,.35); filter:saturate(110%); }

/* ===== Contact – layout & cartes ===== */
#CONTACT{
  background: var(--surface-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 48px 16px 64px;
}

.contact-wrap{
  max-width: 1100px; margin: 0 auto;
  display: grid; gap: 24px;
  grid-template-columns: 1fr 1.4fr;           /* infos / formulaire */
}

.contact-card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px;
}

/* ===== Colonne infos ===== */
.contact-info .p-txt{ margin: 6px 0 18px; color: var(--ink-dim); }

.contact-list{ list-style:none; padding:0; margin: 0 0 18px; display:grid; gap:10px;}
.contact-chip{
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius: 999px;
  background: #0f2230; color:#e9f2ff; border:1px solid #2a4356;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.contact-chip:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0,0,0,.25);
  border-color: var(--accent);
}
.chip-ico{ font-size: 18px; }

.hours{ margin: 16px 0; }
.hours h4{ margin:0 0 6px; font-size: 16px; color:#fff; }
.hours p{ margin:0; color: var(--ink-dim); }

.mini-map{
  margin-top: 12px; padding:16px; border-radius: 12px;
  background: #0f2230; border:1px solid #2a4356; color:#cfe2f3;
  display:grid; gap:6px; text-align:center;
}
.map-pin{ font-size:18px; }

/* ===== Colonne formulaire ===== */
.form1{ text-align:left; margin:0; }
.input-row{ display:grid; gap:8px; margin-bottom:14px; }

.form1 label{ color:#dfeafb; font-weight:700; }
.pad-lm{
  width:100%; height: 46px; padding: 0 14px;
  border-radius: 12px; border:1px solid #2a4356; background:#0f2230;
  color:#e9f2ff; outline:none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.pad-lm:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(30,194,216,.25);
}
.textarea{ height:auto; padding:12px 14px; resize:vertical; min-height:120px; }

/* Consent + actions */
.consent{
  display:flex; gap:10px; align-items:flex-start;
  color: var(--ink-dim); margin: 8px 0 12px;
  font-size: 14px;
}
.consent input{ margin-top: 3px; }

.actions{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }

.btn-send{
  background: linear-gradient(90deg, var(--accent), #4be0f0);
  color:#04212a; font-weight:800; cursor:pointer;
  border:none; border-radius: 999px; padding:12px 24px;
  box-shadow: 0 10px 28px rgba(30,194,216,.35);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.btn-send:hover{ transform: translateY(-2px); box-shadow:0 16px 36px rgba(30,194,216,.45); }

.form-help{ margin:0; color: var(--muted); font-size: 13px; }

/* ===== Responsive ===== */
@media (max-width: 960px){
  .contact-wrap{ grid-template-columns: 1fr; }
}

/* ---------- Footer ---------- */
footer{
  background: #0b1a25; padding: 60px 16px 80px; border-top:1px solid rgba(255,255,255,.06);
}
footer h1{ color:#fff; text-align:center; margin-bottom:8px; font-size:42px; }
footer h1 span{ color: var(--accent-2); }
.Copyright{ margin-top: 8px; color:#a9b8c9; text-align:center; font-weight:600; }

/* ---------- Animations apparitions ---------- */
[data-animate]{ opacity:0; transform: translateY(10px); }
.in-view{ opacity:1; transform:none; transition: opacity .6s ease, transform .6s cubic-bezier(.2,.65,.2,1); }

/* ---------- Responsive ---------- */
@media (max-width: 992px){
  .logo{ font-size:28px; }
  nav .menu{ gap:16px; }
}

@media (max-width: 768px){
  .hautmenu{ flex-direction:column; gap:10px; }
  nav .menu{ flex-wrap:wrap; justify-content:center; padding-left: unset ;
}
  .texteimg1{ padding-top:120px; }
  #step1{ gap:16px; }
}

@media (max-width: 520px){
  .logo{ font-size:24px; }
  .texteimg1{ font-size: clamp(28px, 9vw, 44px); }
  .txt-overlay{ width: 100%; padding: 0 18px; }
  .overlay{ background: rgba(255,255,255,.94); }
  .back{ width: 100%; max-width: 520px; }
}
