
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --ocre:#C8823A; --siene:#A0522D; --ivoire:#F5EFE0; --ivoire-dim:#EDE4D0;
      --or:#D4A84B; --olive:#6B7B3A; --bleu:#2C4A6E; --bleu-dim:#1A3050;
      --charbon:#1C1A17; --gris-doux:#8B8070; --blanc:#FDFBF7;
      --font-serif:'Playfair Display',Georgia,serif; --font-sans:'Inter',system-ui,sans-serif;
      --radius:4px; --shadow:0 8px 40px rgba(28,26,23,.18); --shadow-sm:0 2px 16px rgba(28,26,23,.10);
      --trans:all .35s cubic-bezier(.4,0,.2,1);
    }
    html { scroll-behavior:smooth; font-size:16px; }
    body { font-family:var(--font-sans); background:var(--charbon); color:var(--charbon); line-height:1.6; overflow-x:hidden; }
    img { display:block; max-width:100%; }
    a { text-decoration:none; color:inherit; }
    .container { width:min(1200px,92%); margin-inline:auto; }
    .tag { display:inline-block; font-size:.7rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--ocre); margin-bottom:.8rem; }
    .section-title { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:600; line-height:1.15; }
    .section-title em { font-style:italic; color:var(--ocre); }
    .section-subtitle { font-size:1.05rem; max-width:52ch; margin-top:.8rem; line-height:1.7; }
    .btn { display:inline-flex; align-items:center; gap:.5rem; padding:.85rem 2rem; border-radius:var(--radius); font-family:var(--font-sans); font-size:.85rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; border:none; transition:var(--trans); }
    .btn-primary { background:var(--ocre); color:var(--blanc); }
    .btn-primary:hover { background:var(--siene); transform:translateY(-1px); box-shadow:0 6px 24px rgba(200,130,58,.35); }
    .btn-outline-light { background:transparent; color:var(--blanc); border:1.5px solid rgba(255,255,255,.5); }
    .btn-outline-light:hover { background:rgba(255,255,255,.1); }

    /* NAV */
    .nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:1.2rem 0; background:rgba(28,26,23,.92); backdrop-filter:blur(12px); transition:var(--trans); }
    .nav-inner { display:flex; align-items:center; justify-content:space-between; }
    .nav-logo { display:flex; flex-direction:column; line-height:1; }
    .nav-logo-main { font-family:var(--font-serif); font-size:1.3rem; font-weight:700; color:var(--blanc); }
    .nav-logo-sub { font-size:.65rem; font-weight:400; letter-spacing:.22em; text-transform:uppercase; color:var(--or); margin-top:2px; }
    .nav-links { display:flex; align-items:center; gap:2rem; list-style:none; }
    .nav-links a { font-size:.8rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.8); transition:var(--trans); }
    .nav-links a:hover, .nav-links a.active { color:var(--or); }
    .nav-cta { background:var(--ocre); color:var(--blanc)!important; padding:.5rem 1.2rem; border-radius:var(--radius); }
    .nav-cta:hover { background:var(--siene)!important; }
    .nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:.4rem; }
    .nav-hamburger span { display:block; width:22px; height:2px; background:var(--blanc); }

    /* HERO */
    .hero-page { position:relative; height:100svh; min-height:580px; display:flex; align-items:flex-end; overflow:hidden; }
    .hero-bg { position:absolute; inset:0; background-image:url('../images/photo_23.jpg'); background-size:cover; background-position:center; }
    .hero-bg::before { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(28,26,23,.15) 0%, rgba(28,26,23,0) 30%, rgba(28,26,23,.55) 70%, rgba(28,26,23,.92) 100%); }
    .hero-content { position:relative; z-index:2; padding:0 0 5rem; width:100%; }
    .hero-eyebrow { display:flex; align-items:center; gap:1rem; margin-bottom:1.2rem; }
    .hero-eyebrow-line { width:40px; height:1px; background:var(--or); }
    .hero-eyebrow span { font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--or); }
    .hero-title { font-family:var(--font-serif); font-size:clamp(2.8rem,6vw,4.8rem); font-weight:700; color:var(--blanc); line-height:1.08; max-width:18ch; margin-bottom:1.2rem; }
    .hero-title em { font-style:italic; color:var(--or); }
    .hero-desc { font-size:1.1rem; color:rgba(255,255,255,.75); max-width:50ch; line-height:1.65; margin-bottom:2rem; }
    .hero-actions { display:flex; gap:1rem; flex-wrap:wrap; }

    /* ROUTE STRIP */
    .route-strip { background:var(--bleu-dim); border-bottom:1px solid rgba(255,255,255,.06); }
    .route-inner { display:flex; align-items:center; justify-content:center; gap:0; padding:.8rem 0; overflow-x:auto; }
    .route-point { display:flex; align-items:center; gap:.6rem; padding:.4rem 1.2rem; white-space:nowrap; }
    .route-point-name { font-size:.8rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.8); }
    .route-point-dist { font-size:.7rem; color:var(--or); }
    .route-arrow { color:rgba(255,255,255,.3); font-size:1rem; flex-shrink:0; }
    .route-point.active .route-point-name { color:var(--or); }

    /* SERVICES */
    .services-section { background:var(--charbon); padding:7rem 0; position:relative; overflow:hidden; }
    .services-section::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(44,74,110,.25) 0%,transparent 50%),radial-gradient(ellipse 70% 50% at 80% 50%,rgba(212,168,75,.04) 0%,transparent 60%); }
    .services-section .tag { color:var(--or); }
    .services-section .section-title { color:var(--ivoire); }
    .services-section .section-subtitle { color:rgba(245,239,224,.6); }

    .services-layout { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-top:3.5rem; }

    .services-img { width:100%; aspect-ratio:16/10; border-radius:2px; background-image:url('../images/photo_23.jpg'); background-size:cover; background-position:center; position:relative; overflow:hidden; }
    .services-img::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 30% 60%,rgba(44,74,110,.5) 0%,transparent 60%),linear-gradient(to right,rgba(28,26,23,.6) 0%,transparent 60%); }

    .services-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }

    .service-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); border-radius:var(--radius); padding:1.6rem; transition:var(--trans); }
    .service-card:hover { background:rgba(212,168,75,.07); border-color:rgba(212,168,75,.25); transform:translateY(-2px); }
    .service-icon { font-size:1.8rem; margin-bottom:.8rem; color:var(--or); }
    .service-icon svg { width:1.8rem; height:1.8rem; }
    .service-title { font-family:var(--font-serif); font-size:1rem; font-weight:600; color:var(--or); margin-bottom:.4rem; }
    .service-text { font-size:.8rem; color:rgba(245,239,224,.55); line-height:1.6; }

    /* GHAZOUA SECTION */
    .ghazoua-section { background:var(--blanc); padding:7rem 0; }

    .ghazoua-layout { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-top:3.5rem; }

    .ghazoua-text .section-subtitle { color:var(--gris-doux); }

    .route-cards { display:flex; flex-direction:column; gap:1rem; margin-top:2rem; }
    .route-card { display:flex; gap:1.2rem; align-items:flex-start; padding:1.2rem; background:var(--ivoire); border-radius:var(--radius); border:1px solid transparent; transition:var(--trans); }
    .route-card:hover { border-color:var(--or); transform:translateX(4px); }
    .route-card-icon { width:44px; height:44px; border-radius:var(--radius); background:var(--ocre); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
    .route-card-title { font-family:var(--font-serif); font-size:.95rem; font-weight:600; color:var(--charbon); margin-bottom:.2rem; }
    .route-card-text { font-size:.8rem; color:var(--gris-doux); line-height:1.5; }

    .ghazoua-img-grid { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }
    .ghazoua-img { border-radius:2px; background-size:cover; background-position:center; }
    .gi1 { aspect-ratio:3/4; grid-row:span 2; background-image:url('../images/photo_23.jpg'); }
    .gi2 { aspect-ratio:4/3; background-image:url('../images/photo_11.jpg'); }
    .gi3 { aspect-ratio:4/3; background-image:url('../images/photo_33.jpg'); }

    /* GPS MAP */
    .gps-section { background:var(--charbon); padding:5rem 0; }
    .gps-section .tag { color:var(--or); }
    .gps-inner { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; margin-top:2rem; }

    .gps-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius); padding:2rem; }
    .gps-card-title { font-family:var(--font-serif); font-size:1.1rem; font-weight:600; color:var(--or); margin-bottom:1.5rem; }
    .gps-row { display:flex; justify-content:space-between; padding:.65rem 0; border-bottom:1px solid rgba(255,255,255,.07); gap:1rem; }
    .gps-row:last-child { border-bottom:none; }
    .gps-row-key { font-size:.8rem; color:rgba(255,255,255,.45); flex-shrink:0; }
    .gps-row-val { font-size:.85rem; color:var(--ivoire); font-weight:500; font-family:var(--font-sans); text-align:right; }
    .gps-row-val a { color:var(--or); }
    .gps-row-val a:hover { color:var(--ivoire); }

    .gps-coords-display { background:rgba(44,74,110,.2); border:1px solid rgba(44,74,110,.4); border-radius:var(--radius); padding:1.5rem; text-align:center; margin-top:1.2rem; }
    .gps-coords-label { font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:.5rem; }
    .gps-coords-value { font-family:monospace; font-size:1.1rem; color:var(--or); font-weight:600; }

    /* CTA MOTARDS */
    .cta-motos { background:var(--bleu-dim); padding:5rem 0; text-align:center; position:relative; overflow:hidden; }
    .cta-motos::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 70% 50%,rgba(44,74,110,.6) 0%,transparent 60%); }
    .cta-motos-title { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--blanc); margin-bottom:.8rem; position:relative; }
    .cta-motos-sub { font-size:1rem; color:rgba(255,255,255,.7); margin-bottom:2rem; position:relative; }
    .cta-motos-actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; position:relative; }

    /* FOOTER */
    .footer { background:var(--charbon); padding:5rem 0 2rem; border-top:1px solid rgba(255,255,255,.06); }
    .footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:4rem; }
    .footer-brand-name { font-family:var(--font-serif); font-size:1.4rem; font-weight:700; color:var(--blanc); margin-bottom:.3rem; }
    .footer-brand-sub { font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:var(--or); margin-bottom:1rem; }
    .footer-brand-desc { font-size:.82rem; color:rgba(255,255,255,.45); line-height:1.65; max-width:30ch; }
    .footer-social { display:flex; gap:.7rem; margin-top:1.5rem; }
    .footer-social-btn { width:36px; height:36px; border-radius:var(--radius); background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); font-size:.8rem; font-weight:700; transition:var(--trans); cursor:pointer; text-decoration:none; }
    .footer-social-btn:hover { background:var(--ocre); border-color:var(--ocre); color:var(--blanc); }
    .footer-col-title { font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--or); margin-bottom:1.2rem; }
    .footer-links { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
    .footer-links a { font-size:.82rem; color:rgba(255,255,255,.45); transition:var(--trans); }
    .footer-links a:hover { color:var(--ivoire); padding-left:.3rem; }
    .footer-contact-item { display:flex; gap:.8rem; align-items:flex-start; margin-bottom:.9rem; }
    .footer-contact-icon { font-size:.9rem; margin-top:.1rem; flex-shrink:0; }
    .footer-contact-text { font-size:.82rem; color:rgba(255,255,255,.45); line-height:1.5; }
    .footer-contact-text a { color:var(--or); }
    .footer-bottom { border-top:1px solid rgba(255,255,255,.06); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
    .footer-copy { font-size:.75rem; color:rgba(255,255,255,.25); }
    .footer-platforms { display:flex; gap:.8rem; }
    .footer-platform-badge { font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.3); border:1px solid rgba(255,255,255,.1); padding:.2rem .7rem; border-radius:2px; }

    /* WA FLOAT */
    .wa-float { position:fixed; bottom:2rem; right:2rem; z-index:999; display:flex; flex-direction:column; align-items:flex-end; gap:.8rem; }
    .wa-float-popup { background:var(--blanc); border-radius:var(--radius); padding:1rem 1.2rem; box-shadow:var(--shadow); max-width:220px; font-size:.82rem; color:var(--charbon); line-height:1.5; opacity:0; transform:translateY(8px); transition:var(--trans); pointer-events:none; }
    .wa-float:hover .wa-float-popup { opacity:1; transform:translateY(0); }
    .wa-float-popup strong { display:block; font-weight:700; margin-bottom:.2rem; color:#075E54; }
    .wa-float-btn { width:58px; height:58px; border-radius:50%; background:#25D366; box-shadow:0 6px 24px rgba(37,211,102,.45); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:var(--trans); animation:waPulse 3s ease-in-out infinite; text-decoration:none; }
    .wa-float-btn:hover { transform:scale(1.1); background:#128C7E; animation:none; }
    .wa-float-btn svg { width:28px; height:28px; }
    @keyframes waPulse { 0%,100%{box-shadow:0 6px 24px rgba(37,211,102,.45);}50%{box-shadow:0 6px 40px rgba(37,211,102,.7),0 0 0 8px rgba(37,211,102,.12);} }

    .fade-up { opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease; }
    .fade-up.visible { opacity:1; transform:translateY(0); }
    .fade-up.delay-1 { transition-delay:.1s; }
    .fade-up.delay-2 { transition-delay:.2s; }
    .fade-up.delay-3 { transition-delay:.3s; }

    @media (max-width:1024px) {
      .services-layout,.ghazoua-layout,.gps-inner { grid-template-columns:1fr; gap:3rem; }
      .footer-grid { grid-template-columns:1fr 1fr; }
    }
    @media (max-width:768px) {
      .nav-links { display:none; }
      .nav-hamburger { display:flex; }
      .services-grid { grid-template-columns:1fr; }
      .ghazoua-img-grid { grid-template-columns:1fr; }
      .gi1 { grid-row:auto; aspect-ratio:16/9; }
      .footer-grid { grid-template-columns:1fr; gap:2rem; }
      .route-inner { justify-content:flex-start; }
    }
  