/* assets/css/style.css — Marrakech Cars
   Direction : luxe minéral. Terre cuite / ocre Marrakech, sable, vert palmeraie,
   typographie éditoriale. Soutient LTR + RTL. */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,900&family=Outfit:wght@300;400;500;600&family=Tajawal:wght@400;500;700&display=swap');

:root{
  --terracotta:#C75B39;
  --terracotta-dark:#9E3F26;
  --ocre:#D99A4E;
  --sable:#F4ECE0;
  --sable-2:#EADFCC;
  --nuit:#241A14;        /* brun très foncé, presque noir */
  --palmeraie:#3E5641;
  --blanc:#FBF7F0;
  --ink:#2B201A;
  --shadow:0 18px 40px -18px rgba(36,26,20,.45);
  --radius:18px;
  --maxw:1180px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
}
[lang="ar"]{ --sans:'Tajawal',system-ui,sans-serif; --serif:'Tajawal',serif; }

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--sable);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 12% 8%, rgba(217,154,78,.12), transparent 45%),
                   radial-gradient(circle at 88% 0%, rgba(199,91,57,.10), transparent 40%);
}
[dir="rtl"] body{ text-align:right; }

h1,h2,h3{font-family:var(--serif);line-height:1.05;font-weight:900;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,240,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(43,32,26,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--serif);font-weight:900;font-size:1.45rem;letter-spacing:-.02em;color:var(--nuit)}
.brand b{color:var(--terracotta)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-weight:500;font-size:.96rem;position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--terracotta);transition:width .25s}
.nav-links a:hover::after{width:100%}
.switchers{display:flex;gap:10px;align-items:center}
.switcher{font-size:.82rem;border:1px solid rgba(43,32,26,.2);border-radius:999px;padding:5px 10px;background:transparent;cursor:pointer;font-family:var(--sans)}
.burger{display:none;font-size:1.6rem;background:none;border:0;cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;padding:90px 0 70px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-block;font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:var(--terracotta);font-weight:600;margin-bottom:18px}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:var(--nuit)}
.hero h1 em{font-style:italic;color:var(--terracotta)}
.hero p{font-size:1.18rem;margin:22px 0 30px;max-width:46ch;color:#5a4a3e}
.hero-visual{aspect-ratio:4/5;border-radius:var(--radius);background:linear-gradient(140deg,var(--ocre),var(--terracotta) 60%,var(--terracotta-dark));box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero-visual::after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23ffffff22' stroke-width='1'/%3E%3C/svg%3E")}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:1rem;padding:14px 28px;border-radius:999px;cursor:pointer;border:0;transition:transform .15s,box-shadow .15s;font-family:var(--sans)}
.btn-primary{background:var(--terracotta);color:#fff;box-shadow:0 10px 24px -8px var(--terracotta)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -8px var(--terracotta)}
.btn-ghost{background:transparent;border:1.5px solid var(--nuit);color:var(--nuit)}

/* ---------- Barre de recherche ---------- */
.searchbar{background:var(--blanc);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;display:grid;grid-template-columns:repeat(3,1fr) auto;gap:14px;margin-top:-30px;position:relative;z-index:5}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:#8a7a6c;font-weight:600}
.field input,.field select{border:1px solid rgba(43,32,26,.18);border-radius:12px;padding:11px 12px;font-family:var(--sans);font-size:.95rem;background:#fff}
.field input:focus,.field select:focus{outline:2px solid var(--ocre);border-color:transparent}

/* ---------- Section ---------- */
.section{padding:72px 0}
.section-head{margin-bottom:40px;max-width:60ch}
.section-head .eyebrow{font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:var(--terracotta);font-weight:600}
.section-head h2{font-size:clamp(2rem,4vw,3rem);margin-top:10px;color:var(--nuit)}

/* ---------- Grille véhicules ---------- */
.fleet{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.card{background:var(--blanc);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 26px -16px rgba(36,26,20,.4);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card-media{aspect-ratio:16/10;background:linear-gradient(135deg,var(--sable-2),var(--ocre));position:relative}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-tag{position:absolute;top:12px;inset-inline-start:12px;background:var(--nuit);color:#fff;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;padding:5px 11px;border-radius:999px}
.card-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.card-body h3{font-size:1.3rem;color:var(--nuit)}
.specs{display:flex;flex-wrap:wrap;gap:8px;font-size:.82rem;color:#6a5a4c}
.spec{background:var(--sable);padding:4px 10px;border-radius:8px}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:8px}
.price{font-family:var(--serif);font-weight:900;font-size:1.5rem;color:var(--terracotta)}
.price small{font-family:var(--sans);font-weight:400;font-size:.8rem;color:#8a7a6c}

/* ---------- Bandeau atouts ---------- */
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:var(--nuit);border-radius:var(--radius);padding:38px;color:var(--sable)}
.perk h4{font-family:var(--serif);font-size:1.15rem;margin-bottom:6px;color:var(--ocre)}
.perk p{font-size:.9rem;color:#cdbfae}

/* ---------- Formulaire ---------- */
.form-card{background:var(--blanc);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;max-width:680px;margin:0 auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.full{grid-template-columns:1fr}
.form-card label{display:block;font-size:.8rem;font-weight:600;color:#6a5a4c;margin-bottom:6px}
.form-card input,.form-card select,.form-card textarea{width:100%;border:1px solid rgba(43,32,26,.18);border-radius:12px;padding:12px;font-family:var(--sans);font-size:.95rem;background:#fff}
.form-card textarea{min-height:130px;resize:vertical}
.alert{padding:14px 18px;border-radius:12px;margin-bottom:20px;font-weight:500}
.alert-ok{background:#e7f1e8;color:var(--palmeraie)}
.alert-err{background:#fae3dc;color:var(--terracotta-dark)}

/* ---------- Footer ---------- */
.site-footer{background:var(--nuit);color:var(--sable-2);padding:54px 0 30px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
.site-footer h5{font-family:var(--serif);color:var(--ocre);font-size:1.1rem;margin-bottom:14px}
.site-footer a{color:#cdbfae;font-size:.92rem;display:block;padding:3px 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:18px;font-size:.82rem;color:#9a8a7c;text-align:center}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .searchbar{grid-template-columns:1fr 1fr}
  .perks{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .nav-links{display:none;position:absolute;top:74px;inset-inline-start:0;right:0;flex-direction:column;background:var(--blanc);padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.08)}
  .nav-links.open{display:flex}
  .burger{display:block}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:520px){ .searchbar{grid-template-columns:1fr} .perks{grid-template-columns:1fr} }

/* ========== Fiche véhicule ========== */
.vehicle-detail{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;margin-top:24px;align-items:start}
.vd-main{position:relative;aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:linear-gradient(135deg,var(--sable-2),var(--ocre))}
.vd-main img{width:100%;height:100%;object-fit:cover}
.vd-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.vd-thumbs img{width:84px;height:60px;object-fit:cover;border-radius:10px;cursor:pointer;opacity:.6;border:2px solid transparent;transition:.2s}
.vd-thumbs img.active,.vd-thumbs img:hover{opacity:1;border-color:var(--terracotta)}
.vd-info h1{font-family:var(--serif)}

/* ========== Suivi mécanique ========== */
.maint-block{margin-top:56px;background:var(--blanc);border-radius:var(--radius);padding:34px;box-shadow:0 8px 26px -16px rgba(36,26,20,.4)}
.maint-timeline{display:grid;gap:14px}
.maint-item{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;background:var(--sable);border-radius:12px;border-inline-start:3px solid var(--palmeraie)}
.maint-icon{font-size:1.4rem;line-height:1}

/* ========== Réseaux sociaux ========== */
.footer-social{display:flex;gap:12px;margin-top:10px}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--ocre);transition:.2s;padding:0}
.footer-social a:hover{background:var(--terracotta);color:#fff;transform:translateY(-2px)}

.social-float{position:fixed;inset-inline-end:16px;bottom:18px;z-index:60;display:flex;flex-direction:column;gap:10px}
.social-float a{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;color:#fff;box-shadow:var(--shadow);transition:transform .2s}
.social-float a:hover{transform:scale(1.08)}
.sf-whatsapp{background:#25D366}
.sf-facebook{background:#1877F2}
.sf-instagram{background:radial-gradient(circle at 30% 110%,#fdf497,#fd5949 45%,#d6249f 60%,#285AEB 90%)}
.sf-tiktok{background:#010101}
.sf-youtube{background:#FF0000}
.sf-x{background:#000}
.sf-linkedin{background:#0A66C2}

@media(max-width:880px){
  .vehicle-detail{grid-template-columns:1fr}
  .social-float{flex-direction:row;inset-inline-end:50%;transform:translateX(50%);bottom:14px}
  [dir="rtl"] .social-float{transform:translateX(-50%)}
  .social-float a{width:42px;height:42px}
}

/* ========== Modes de paiement ========== */
.pay-methods{display:grid;gap:10px;margin-bottom:18px}
.pay-opt{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1.5px solid rgba(43,32,26,.15);border-radius:12px;cursor:pointer;transition:.18s;background:#fff}
.pay-opt:hover{border-color:var(--ocre)}
.pay-opt input{accent-color:var(--terracotta);width:18px;height:18px}
.pay-opt:has(input:checked){border-color:var(--terracotta);background:#fdf3ee;box-shadow:0 0 0 1px var(--terracotta)}
.pay-opt span{font-weight:500}
.pay-zone{margin-bottom:10px}

/* ========== Section vocation ========== */
.vocation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:34px 48px}
.vocation-item{text-align:center;padding:10px}
.vocation-icon{font-size:2.6rem;margin-bottom:14px;filter:saturate(.9)}
.vocation-item h3{font-size:1.3rem;color:var(--nuit);margin-bottom:10px}
.vocation-item p{color:#5a4a3e;font-size:.96rem;max-width:42ch;margin:0 auto}

/* ========== Bannière promo pleine page ========== */
.promo-banner{background-size:cover;background-position:center;color:#fff;padding:96px 0;text-align:center}
.promo-inner{max-width:740px}
.promo-inner h2{font-size:clamp(2rem,4.5vw,3.2rem);color:#fff;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.promo-inner p{font-size:1.2rem;margin-bottom:26px;color:#f4ece0;text-shadow:0 1px 8px rgba(0,0,0,.4)}

/* ========== Accordéon (CGV / FAQ) ========== */
.accordion{display:flex;flex-direction:column;gap:12px}
.acc-item{background:var(--blanc);border:1px solid rgba(43,32,26,.1);border-radius:12px;overflow:hidden;transition:box-shadow .2s}
.acc-item[open]{box-shadow:0 8px 26px -16px rgba(36,26,20,.4)}
.acc-item summary{list-style:none;cursor:pointer;padding:18px 22px;font-family:var(--serif);font-weight:600;font-size:1.08rem;color:var(--nuit);display:flex;align-items:center;justify-content:space-between;gap:16px;transition:color .2s}
.acc-item summary::-webkit-details-marker{display:none}
.acc-item summary:hover{color:var(--terracotta)}
.acc-plus{position:relative;flex-shrink:0;width:18px;height:18px}
.acc-plus::before,.acc-plus::after{content:"";position:absolute;background:var(--terracotta);border-radius:2px;transition:transform .25s}
.acc-plus::before{top:8px;left:0;width:18px;height:2px}
.acc-plus::after{top:0;left:8px;width:2px;height:18px}
.acc-item[open] .acc-plus::after{transform:rotate(90deg);opacity:0}
.acc-body{padding:0 22px 20px}
.acc-body p{color:#5a4a3e;font-size:.96rem;line-height:1.7;margin:0}
[dir="rtl"] .acc-item summary{flex-direction:row-reverse}

@media(max-width:880px){
  .vocation-grid{grid-template-columns:1fr;gap:28px}
  .promo-banner{padding:70px 0}
}

/* Lien admin discret dans le footer */
.admin-link{color:#9a8a7c;opacity:.35;text-decoration:none;padding:0 6px;transition:opacity .2s}
.admin-link:hover{opacity:1;color:var(--ocre)}

/* ========== Avis clients ========== */
.reviews-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.review-card{background:var(--blanc);border:1px solid rgba(43,32,26,.08);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 26px -18px rgba(36,26,20,.4)}
.review-text{color:#5a4a3e;font-size:.94rem;line-height:1.6;font-style:italic;flex:1}
.review-author{display:flex;flex-direction:column;gap:2px;border-top:1px solid rgba(43,32,26,.08);padding-top:10px}
.review-author strong{color:var(--nuit)}
.review-author span{font-size:.82rem;color:#8a7a6c}
.stars{color:#d8c9b6;font-size:1.05rem;letter-spacing:2px}
.stars .star.on{color:var(--ocre)}

.review-form-wrap{text-align:center}
.review-form-wrap summary{list-style:none;cursor:pointer}
.review-form-wrap summary::-webkit-details-marker{display:none}
.review-form{max-width:620px;margin:22px auto 0;text-align:start}
.star-input{display:inline-flex;flex-direction:row;gap:4px;font-size:1.8rem}
.star-input .star-pick input{position:absolute;opacity:0;width:0;height:0}
.star-input .star-pick span{color:#d8c9b6;cursor:pointer;transition:color .15s}
/* étoiles en ordre DOM décroissant (5..1) : survol/sélection allume l'étoile + ses suivantes (notes inférieures) */
.star-input .star-pick:hover span,
.star-input .star-pick:hover ~ .star-pick span,
.star-input .star-pick input:checked ~ span,
.star-input .star-pick:has(input:checked) span,
.star-input .star-pick:has(input:checked) ~ .star-pick span{color:var(--ocre)}

@media(max-width:980px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.reviews-grid{grid-template-columns:1fr}}

/* ========== Localisation / carte ========== */
.map-wrap{position:relative;width:100%;aspect-ratio:16/8;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%}
/* placeholder de consentement (RGPD) : aucune requête Google avant le clic */
.map-consent{position:absolute;inset:0;cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 38px,rgba(255,255,255,.5) 38px,rgba(255,255,255,.5) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 38px,rgba(255,255,255,.5) 38px,rgba(255,255,255,.5) 40px),
    linear-gradient(135deg,var(--sable-2),var(--ocre));
  transition:filter .2s}
.map-consent:hover{filter:brightness(1.03)}
.map-consent-inner{background:rgba(251,247,240,.92);backdrop-filter:blur(2px);border-radius:14px;padding:26px 30px;max-width:340px;box-shadow:0 10px 30px -12px rgba(36,26,20,.5)}
.map-pin{font-size:2.4rem;line-height:1;margin-bottom:8px}
.map-consent-title{font-family:var(--serif);font-weight:600;font-size:1.2rem;color:var(--nuit);margin-bottom:14px}
.map-consent-btn{color:#fff;pointer-events:none}
.map-consent-note{font-size:.78rem;color:#8a7a6c;margin-top:12px;line-height:1.5}
.map-info{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:center;margin-top:22px;color:#5a4a3e}
.map-info a{color:var(--terracotta);font-weight:500}
.map-info .btn{color:#fff}
@media(max-width:680px){.map-wrap{aspect-ratio:4/3}}

/* ========== Logo (header & footer) ========== */
.brand{display:flex;align-items:center;height:100%}
.brand-logo{height:46px;max-height:calc(74px - 18px);width:auto;display:block;object-fit:contain}
.footer-logo{display:inline-block;background:var(--blanc);border-radius:12px;padding:10px 14px;box-shadow:0 8px 24px -14px rgba(0,0,0,.5)}
.footer-logo img{height:50px;width:auto;display:block;object-fit:contain}
@media(max-width:880px){.brand-logo{height:40px}}

/* ========== Bannières pleine largeur en tête de section ========== */
.section-banner{position:relative;width:100%;line-height:0}
.section-banner-img{display:block;width:100%;height:auto}
.section-banner-caption{position:absolute;left:0;right:0;bottom:0;line-height:1.2;padding:40px 24px 28px;text-align:center;
  background:linear-gradient(to top,rgba(36,26,20,.6),rgba(36,26,20,0))}
.section-banner-caption .eyebrow{font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;font-weight:600;display:block;margin-bottom:8px;text-shadow:0 2px 10px rgba(0,0,0,.6)}
.section-banner-caption h2{color:#fff;font-size:clamp(1.6rem,4vw,3.2rem);text-shadow:0 2px 16px rgba(0,0,0,.6);margin:0}

/* Marge aérée entre le formulaire de recherche et la section flotte */
.search-spacer{height:64px}
@media(max-width:680px){.search-spacer{height:40px}}

/* Bouton bannière promo : fond transparent, doré attractif, ne masque pas l'image */
.btn-promo{background:transparent;color:#fff;border:2px solid var(--ocre);
  text-shadow:0 1px 6px rgba(0,0,0,.45);backdrop-filter:blur(1px);transition:.22s}
.btn-promo:hover{background:var(--ocre);color:var(--nuit);border-color:var(--ocre);
  transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(200,160,101,.7);text-shadow:none}

/* ===== Menu admin responsive : bouton X de fermeture ===== */
.nav-close{display:none;position:absolute;top:14px;inset-inline-end:18px;
  font-size:1.5rem;line-height:1;background:none;border:0;cursor:pointer;color:var(--nuit)}
@media(max-width:880px){
  /* le menu admin (nombreuses entrées) : occupe le haut, scrollable, pas tout l'écran */
  .nav-links{gap:4px;max-height:calc(100vh - 74px);overflow-y:auto;box-shadow:0 12px 24px -12px rgba(0,0,0,.3);padding-top:44px}
  .nav-links .nav-close{display:block}
  .nav-links a{padding:12px 6px;border-bottom:1px solid rgba(0,0,0,.05)}
}
