/* ============================================================
   MILLE & UNE PISTES — feuille de style partagée (multi-pages)
   Design : luxe éditorial marocain · responsive mobile/tablette
============================================================ */
:root{
  --clay:#C75B39; --clay-deep:#8E3416; --ochre:#D98E32;
  --gold:#C9A24B; --gold-soft:#E3C77E;
  --majorelle:#2C4B9B; --majorelle-soft:#5B79CF;
  --ink:#1B130D; --ink-2:#2A1E14;
  --sand:#F3E9D7; --cream:#FBF5EA; --paper:#FDFAF3;
  --muted:#6F5F4E;
  --line:rgba(27,19,13,.12);
  --shadow:0 30px 70px -30px rgba(27,19,13,.45);
  --shadow-sm:0 12px 30px -12px rgba(27,19,13,.35);
  --r:22px; --r-sm:14px;
  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Jost",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.55}
::selection{background:var(--clay);color:#fff}
img{display:block;max-width:100%}
svg{stroke-linecap:round;stroke-linejoin:round}
a{color:inherit;text-decoration:none}
select{appearance:none;-webkit-appearance:none;font-family:var(--body);font-size:.95rem;color:var(--ink);background-color:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 44px 12px 14px;cursor:pointer;text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%231B130D' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px}
select:focus{outline:none;border-color:var(--clay)}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.04;letter-spacing:-.02em}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--clay)}
.serif-it{font-style:italic;font-weight:400}
.center{text-align:center}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:18px 0;transition:.4s;background:linear-gradient(180deg,rgba(27,19,13,.6),rgba(27,19,13,0))}
nav.scrolled,nav.solid{background:rgba(251,245,234,0.85);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--line);padding:11px 0}
.nav-in{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;color:var(--cream);transition:.4s}
nav.scrolled .brand,nav.solid .brand{color:var(--ink)}
.brand .mark{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:none;background:radial-gradient(circle at 35% 30%,var(--gold-soft),var(--clay) 70%);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.35)}
.brand .mark svg{width:24px;height:24px}
.brand b{font-family:var(--display);font-size:1.32rem;font-weight:600;line-height:1.05;white-space:nowrap}
.brand small{display:block;font-family:var(--body);font-size:.58rem;letter-spacing:.34em;text-transform:uppercase;opacity:.8;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:var(--cream);font-weight:600;font-size:.92rem;position:relative;transition:.3s;white-space:nowrap}
nav.scrolled .nav-links a,nav.solid .nav-links a{color:var(--ink)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--clay);transition:.3s}
.nav-links a:not(.btn):hover::after,.nav-links a.active:not(.btn)::after{width:100%}
.nav-links a.active:not(.btn){color:var(--gold-soft)}
nav.scrolled .nav-links a.active:not(.btn),nav.solid .nav-links a.active:not(.btn){color:var(--clay)}
.btn{display:inline-flex;align-items:center;gap:9px;border:none;cursor:pointer;font-family:var(--body);font-weight:700;font-size:.92rem;padding:13px 24px;border-radius:100px;transition:.35s cubic-bezier(.2,.8,.2,1);white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--clay);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
nav.scrolled .btn-ghost,nav.solid .btn-ghost{color:var(--ink);border-color:var(--line);background:transparent}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}
.btn-gold{background:var(--gold-soft);color:var(--ink)}
.btn-gold:hover{background:#fff;transform:translateY(-2px)}
.nav-toggle{display:none;place-items:center;width:44px;height:44px;border-radius:50%;background:rgba(27,19,13,.5);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);cursor:pointer;color:#fff;padding:0}
.nav-toggle svg{width:24px;height:24px}

/* ---------- HOME HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:var(--cream)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:kenburns 18s ease-out forwards}
@keyframes kenburns{to{transform:scale(1)}}
.hero-bg .hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.06);animation:heroFade 28s infinite;will-change:opacity}
.hero-bg .hero-slide:nth-child(2){animation-delay:0s}
.hero-bg .hero-slide:nth-child(3){animation-delay:7s}
.hero-bg .hero-slide:nth-child(4){animation-delay:14s}
.hero-bg .hero-slide:nth-child(5){animation-delay:21s}
@keyframes heroFade{0%{opacity:0;transform:scale(1.06)}3%{opacity:1}22%{opacity:1}27%{opacity:0;transform:scale(1.12)}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.hero-bg .hero-slide{animation:none}.hero-bg .hero-slide:nth-child(2){opacity:1}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,19,13,.55),rgba(27,19,13,.12) 30%,rgba(27,19,13,.35) 60%,rgba(27,19,13,.92)),radial-gradient(120% 80% at 80% 10%,transparent,rgba(142,52,22,.35))}
.hero-fallback{position:absolute;inset:0;background:radial-gradient(90% 70% at 75% 20%,var(--ochre),transparent 60%),radial-gradient(70% 60% at 15% 90%,var(--majorelle),transparent 55%),linear-gradient(160deg,var(--clay-deep),var(--ink) 70%)}
.hero-in{position:relative;z-index:2;width:100%;padding-bottom:7vh}
.hero h1{font-size:clamp(3rem,9vw,8rem);font-weight:600;letter-spacing:-.02em}
.hero h1 .l{display:inline-block;opacity:0;transform:translateY(40px);animation:rise .9s cubic-bezier(.2,.8,.2,1) forwards}
.hero p.kick{max-width:540px;margin:22px 0 30px;font-size:1.12rem;color:rgba(251,245,234,0.86);opacity:0;animation:rise .9s .7s forwards}
.hero .eyebrow{color:var(--gold-soft);opacity:0;animation:rise .8s .1s forwards}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:rise .9s .9s forwards}
@keyframes rise{to{opacity:1;transform:none}}
.hero-stats{display:flex;gap:38px;margin-top:46px;flex-wrap:wrap;opacity:0;animation:rise .9s 1.1s forwards}
.hero-stats .s b{font-family:var(--display);font-size:2.1rem;font-weight:500;display:block;color:#fff}
.hero-stats .s span{font-size:.82rem;color:rgba(251,245,234,0.92)}
.qstart{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:28px;opacity:0;animation:rise .9s 1s forwards}
.qstart .qlabel{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-right:2px}
.qchip{padding:9px 16px;border-radius:100px;background:rgba(251,245,234,0.32);border:1px solid rgba(251,245,234,0.52);color:var(--cream);font-weight:600;font-size:.85rem;backdrop-filter:blur(6px);transition:.25s;white-space:nowrap}
.qchip:hover{background:var(--clay);border-color:var(--clay);transform:translateY(-2px)}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(251,245,234,0.92);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint i{width:1px;height:38px;background:linear-gradient(var(--gold-soft),transparent);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- INNER PAGE HEADER ---------- */
.phead{position:relative;padding:160px 0 70px;color:var(--cream);overflow:hidden}
.phead .pbg{position:absolute;inset:0;z-index:0}
.phead .pbg img{width:100%;height:100%;object-fit:cover}
.phead .pbg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,19,13,.7),rgba(27,19,13,.55)),radial-gradient(100% 100% at 80% 0%,rgba(142,52,22,.4),transparent)}
.phead-in{position:relative;z-index:2}
.phead .eyebrow{color:var(--gold-soft)}
.phead h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:600;margin:12px 0 14px}
.phead p{max-width:600px;color:rgba(251,245,234,0.85);font-size:1.08rem}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--ink);color:var(--sand);padding:16px 0;overflow:hidden;border-top:1px solid rgba(227,199,126,.18);border-bottom:1px solid rgba(227,199,126,.18)}
.marquee-track{display:flex;gap:36px;white-space:nowrap;animation:scrollx 34s linear infinite;width:max-content;align-items:center}
.marquee-track span{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--gold-soft);display:flex;align-items:center;gap:36px}
.marquee-track .sep{width:14px;height:14px;color:var(--clay);flex:none}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- SECTION ---------- */
section{position:relative}
.sec{padding:clamp(60px,9vw,120px) 0}
.sec-head{max-width:760px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto}
.sec-head h2{font-size:clamp(2.1rem,5vw,3.9rem);margin:12px 0 14px;font-weight:500}
.sec-head p{color:var(--muted);font-size:1.06rem;max-width:580px}
.sec-head.center p{margin-left:auto;margin-right:auto}
.reveal{opacity:0;transform:translateY(30px);transition:.9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.bg-cream{background:var(--cream)}.bg-paper{background:var(--paper)}.bg-ink{background:var(--ink)}

/* ---------- CONCEPT ---------- */
.concept-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.concept-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cc{padding:26px;border-radius:var(--r-sm);background:var(--paper);border:1px solid var(--line);transition:.4s}
.cc:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm);border-color:transparent}
.cc .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(140deg,var(--sand),#fff);color:var(--clay)}
.cc .ic svg{width:24px;height:24px}
.cc:nth-child(2) .ic{color:var(--majorelle)}.cc:nth-child(3) .ic{color:var(--ochre)}.cc:nth-child(4) .ic{color:var(--gold)}
.cc h4{font-size:1.18rem;margin-bottom:6px}.cc p{font-size:.92rem;color:var(--muted)}
.concept-copy h2{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:500;margin:14px 0 18px}
.concept-copy p{color:var(--muted);margin-bottom:14px}

/* ---------- CITY RAIL + LIBRARY ---------- */
.city-rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(280px,1fr);gap:20px;overflow-x:auto;padding:6px 0 24px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--clay) transparent}
.city-rail::-webkit-scrollbar{height:6px}.city-rail::-webkit-scrollbar-thumb{background:var(--clay);border-radius:9px}
.cities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.city{position:relative;height:420px;border-radius:var(--r);overflow:hidden;scroll-snap-align:start;color:#fff;cursor:pointer;isolation:isolate}
.city .ph{position:absolute;inset:0;z-index:-2}
.city .ph img{width:100%;height:100%;object-fit:cover;transition:.7s}
.city:hover .ph img{transform:scale(1.07)}
.city::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 35%,rgba(27,19,13,.88))}
.city .meta{position:absolute;left:0;right:0;bottom:0;padding:24px}
.city .meta .tag{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.city .meta h3{font-size:1.6rem;margin:6px 0 4px;font-weight:500}
.city .meta p{font-size:.85rem;color:rgba(255,255,255,.8)}
.city .km{position:absolute;top:16px;right:16px;background:rgba(251,245,234,0.92);color:var(--ink);font-weight:700;font-size:.7rem;padding:6px 12px;border-radius:100px}
.city .more{position:absolute;top:16px;left:16px;background:rgba(27,19,13,.55);color:#fff;font-size:.7rem;font-weight:700;padding:6px 11px;border-radius:100px;display:flex;align-items:center;gap:5px;opacity:0;transition:.3s}
.city:hover .more{opacity:1}

/* library filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filters .chip{padding:9px 18px;border-radius:100px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;font-weight:600;font-size:.86rem;font-family:var(--body);transition:.25s}
.filters .chip:hover{border-color:var(--clay);color:var(--clay)}
.filters .chip.on{background:var(--clay);color:#fff;border-color:var(--clay)}
.lib-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.lib-grid figure{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:var(--sand)}
.lib-grid figure img{width:100%;height:100%;object-fit:cover;transition:.7s}
.lib-grid figure:hover img{transform:scale(1.1)}
.lib-grid figure figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;font-family:var(--display);font-style:italic;font-size:1.02rem;color:#fff;background:linear-gradient(transparent,rgba(27,19,13,.85))}
.g-big{grid-column:span 2;grid-row:span 2}.g-tall{grid-row:span 2}.g-wide{grid-column:span 2}

/* ---------- BUILDER ---------- */
.builder-page{background:linear-gradient(180deg,var(--ink),var(--ink-2));color:var(--sand)}
.builder{position:relative;overflow:hidden}
.builder::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(60% 50% at 85% 0%,rgba(217,142,50,.22),transparent 60%),radial-gradient(50% 50% at 0% 100%,rgba(44,75,155,.28),transparent 55%)}
.builder .sec-head h2{color:var(--cream)}.builder .sec-head p{color:rgba(243,233,215,0.92)}.builder .eyebrow{color:var(--gold-soft)}
.bx{position:relative;z-index:2;display:grid;grid-template-columns:1.5fr .95fr;gap:28px;align-items:start}
.panel{background:rgba(251,245,234,0.05);border:1px solid rgba(227,199,126,.18);border-radius:var(--r);padding:28px;backdrop-filter:blur(6px)}
.step-label{display:flex;align-items:center;gap:12px;margin:0 0 18px;flex-wrap:wrap}
.step-label .n{width:30px;height:30px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.85rem;flex:none}
.step-label h4{font-size:1.12rem;color:var(--cream)}
.step{margin-bottom:32px}
.daysctl{display:flex;align-items:center;gap:18px}
.daysctl button{width:52px;height:52px;border-radius:14px;border:1px solid rgba(227,199,126,.3);background:rgba(255,255,255,.05);color:var(--cream);cursor:pointer;transition:.25s;display:grid;place-items:center}
.daysctl button:hover{background:var(--clay);border-color:var(--clay)}
.daysctl button svg{width:20px;height:20px}
.daysctl .val{font-family:var(--display);font-weight:600;font-size:2.6rem;color:#fff;min-width:84px;text-align:center;line-height:1.05;display:flex;flex-direction:column;align-items:center;gap:3px}
.daysctl .val small{font-family:var(--body);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(243,233,215,0.82)}
.paxrow{display:flex;gap:10px;flex-wrap:wrap}
.chip{padding:10px 18px;border-radius:100px;border:1px solid rgba(227,199,126,.3);background:transparent;color:var(--sand);cursor:pointer;font-weight:600;font-size:.9rem;transition:.25s;font-family:var(--body)}
.chip:hover{border-color:var(--gold-soft)}
.chip.on{background:var(--gold-soft);color:var(--ink);border-color:var(--gold-soft)}
.optbtn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;background:var(--gold-soft);color:var(--ink);border:none;border-radius:100px;padding:8px 15px;font-family:var(--body);font-weight:700;font-size:.82rem;cursor:pointer;transition:.25s}
.optbtn:hover{background:#fff;transform:translateY(-1px)}
.itin{display:flex;flex-direction:column;gap:0}
.dayrow{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;background:rgba(255,255,255,.03);border:1px solid rgba(227,199,126,.14);border-radius:14px;padding:11px 13px;transition:.3s;animation:rise .5s both}
.dayrow .badge{font-family:var(--display);font-size:.88rem;font-weight:600;color:var(--gold-soft);background:rgba(217,142,50,.14);border-radius:9px;padding:8px 12px;white-space:nowrap}
.dayrow select{width:100%;background-color:#231a12;color:var(--cream);border:1px solid rgba(227,199,126,.3);border-radius:10px;padding:12px 44px 12px 14px;font-family:var(--body);font-size:.94rem;font-weight:600;cursor:pointer;appearance:none;-webkit-appearance:none;text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%23E3C77E' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px}
.dayrow select:focus{outline:none;border-color:var(--gold-soft)}
.dayrow .openbtn{background:none;border:1px solid rgba(227,199,126,.3);color:var(--gold-soft);border-radius:9px;width:40px;height:42px;cursor:pointer;flex:none;transition:.25s;display:grid;place-items:center}
.dayrow .openbtn:hover{background:var(--clay);border-color:var(--clay);color:#fff}
.dayrow .openbtn svg{width:18px;height:18px}
.leg{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:6px 0 6px 18px;margin:2px 0 2px 19px;border-left:2px dotted rgba(227,199,126,.35);font-size:.78rem;color:rgba(243,233,215,0.92)}
.leg .lbadge{width:9px;height:9px;border-radius:50%;flex:none}
.leg.g .lbadge{background:#3ad08a}.leg.o .lbadge{background:var(--ochre)}.leg.r .lbadge{background:#e74c3c}
.leg .lkm{color:var(--gold-soft);font-weight:700}
.leg .lexp{font-style:italic;opacity:.85}
.passrow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pass-toggle{display:flex;gap:12px;align-items:flex-start;border:1px solid rgba(227,199,126,.2);border-radius:14px;padding:14px;cursor:pointer;transition:.25s;background:rgba(255,255,255,.02)}
.pass-toggle:hover{border-color:var(--gold-soft)}
.pass-toggle.on{background:rgba(217,142,50,.12);border-color:var(--ochre)}
.pass-toggle .box{width:22px;height:22px;border-radius:6px;border:2px solid rgba(227,199,126,.5);flex:none;display:grid;place-items:center;transition:.25s;margin-top:2px}
.pass-toggle.on .box{background:var(--ochre);border-color:var(--ochre)}
.pass-toggle .box svg{width:12px;height:12px;opacity:0;transition:.2s}.pass-toggle.on .box svg{opacity:1}
.pass-toggle b{font-size:.94rem;color:var(--cream);display:block}
.pass-toggle small{font-size:.77rem;color:rgba(243,233,215,0.82)}
.pass-toggle .pr{margin-left:auto;color:var(--gold-soft);font-weight:700;font-size:.84rem;white-space:nowrap}
/* right column */
.rightcol{position:sticky;top:88px;display:flex;flex-direction:column;gap:16px}
.trip-map-wrap{background:var(--paper);border-radius:var(--r);padding:10px;box-shadow:var(--shadow)}
.trip-map{height:300px;border-radius:14px;overflow:hidden;background:var(--sand);z-index:1}
.leaflet-container{font-family:var(--body)}
.map-legend{display:flex;gap:16px;justify-content:center;padding:9px 4px 3px;font-size:.72rem;color:var(--muted);flex-wrap:wrap}
.map-legend i.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle}
.dot.dg{background:#2e9e6b}.dot.do{background:var(--ochre)}.dot.dr{background:#c0392b}
.feasbox{background:rgba(251,245,234,0.06);border:1px solid rgba(227,199,126,.22);border-radius:var(--r);padding:18px 20px}
.feasbox .ftop{display:flex;align-items:center;gap:12px}
.feasbox .fbadge{width:34px;height:34px;flex:none}
.feasbox .fttl{font-family:var(--display);font-size:1.18rem;color:var(--cream)}
.feasbox .fstats{display:flex;gap:18px;color:rgba(243,233,215,0.92);font-size:.82rem;margin-top:10px;flex-wrap:wrap}
.feasbox .fstats b{color:var(--gold-soft);font-weight:700}
.feasbox .fwarn{margin-top:10px;font-size:.79rem;color:#ffd9b0;background:rgba(192,57,43,.16);border-radius:9px;padding:8px 11px}
.summary{background:var(--paper);color:var(--ink);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.summary h4{font-size:1.3rem;margin-bottom:4px}
.summary .sub{color:var(--muted);font-size:.85rem;margin-bottom:18px}
.sumlist{display:flex;flex-direction:column;gap:10px;max-height:220px;overflow:auto;margin-bottom:16px;padding-right:4px}
.sumlist .li{display:flex;justify-content:space-between;font-size:.87rem;gap:10px}
.sumlist .li span:first-child{color:var(--muted)}.sumlist .li b{font-weight:700}
.sum-total{border-top:1px dashed var(--line);padding-top:16px;display:flex;justify-content:space-between;align-items:flex-end}
.sum-total .tlab{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sum-total .tval{font-family:var(--display);font-size:2.3rem;font-weight:500;color:var(--clay);line-height:1}
.summary .btn{width:100%;justify-content:center;margin-top:16px}
.summary .note{font-size:.72rem;color:var(--muted);text-align:center;margin-top:12px}

/* ---------- PASالسES ---------- */
.pass-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.45s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.pcard .ph{height:190px;position:relative;overflow:hidden;background:var(--sand)}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.pcard:hover .ph img{transform:scale(1.08)}
.pcard .ph .ribbon{position:absolute;top:14px;left:14px;background:var(--ink);color:var(--gold-soft);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;padding:6px 12px;border-radius:100px}
.pcard .body{padding:22px;flex:1;display:flex;flex-direction:column}
.pcard h3{font-size:1.4rem;margin-bottom:8px}
.pcard .body>p{font-size:.9rem;color:var(--muted);margin-bottom:14px}
.pcard ul{list-style:none;margin-bottom:18px;display:flex;flex-direction:column;gap:7px}
.pcard ul li{font-size:.85rem;display:flex;gap:9px;align-items:center;color:var(--ink-2)}
.pcard ul li svg{width:15px;height:15px;color:var(--clay);flex:none}
.pcard .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--line)}
.pcard .foot .price{font-family:var(--display);font-size:1.5rem;color:var(--clay)}
.pcard .foot .price small{font-family:var(--body);font-size:.72rem;color:var(--muted);display:block}

/* ---------- TESTIMONIALS ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{background:var(--cream);border-radius:var(--r);padding:30px;border:1px solid var(--line)}
.tcard .stars{display:flex;gap:3px;color:var(--gold);margin-bottom:14px}
.tcard .stars svg{width:18px;height:18px;fill:var(--gold)}
.tcard p{font-family:var(--display);font-style:italic;font-size:1.14rem;line-height:1.5;margin-bottom:20px}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .who .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(140deg,var(--ochre),var(--clay));color:#fff;display:grid;place-items:center;font-weight:800}
.tcard .who b{display:block;font-size:.95rem}.tcard .who span{font-size:.8rem;color:var(--muted)}

/* ---------- CTA ---------- */
.cta{background:var(--clay);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.18;background:radial-gradient(circle at 20% 20%,#fff,transparent 40%),radial-gradient(circle at 80% 80%,var(--gold-soft),transparent 45%)}
.cta-in{position:relative;z-index:2}
.cta h2{font-size:clamp(2.1rem,5vw,4rem);font-weight:500;margin-bottom:16px}
.cta p{max-width:520px;margin:0 auto 28px;color:rgba(255,255,255,.92)}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:30px}
.contact-list{display:flex;flex-direction:column;gap:18px;margin-top:10px}
.contact-list a{display:flex;gap:14px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--paper);transition:.3s}
.contact-list a:hover{border-color:var(--clay);transform:translateX(4px)}
.contact-list .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(140deg,var(--sand),#fff);color:var(--clay);flex:none}
.contact-list .ic svg{width:22px;height:22px}
.contact-list b{display:block;font-size:.97rem}.contact-list span{font-size:.84rem;color:var(--muted)}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:var(--sand);padding:64px 0 34px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:42px}
footer h5{font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:18px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer ul a{color:rgba(243,233,215,0.92);font-size:.92rem;transition:.25s}footer ul a:hover{color:#fff}
footer .brand{color:var(--cream);margin-bottom:14px}
footer .about{color:rgba(243,233,215,0.82);font-size:.9rem;max-width:300px}
.foot-bot{border-top:1px solid rgba(227,199,126,.15);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(243,233,215,0.72)}
.foot-bot a{color:var(--gold-soft)}

/* ---------- MODALS ---------- */
.overlay{position:fixed;inset:0;z-index:1000;background:rgba(27,19,13,.62);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:24px}
.overlay.show{display:flex;animation:fade .3s}
@keyframes fade{from{opacity:0}}
.modal{background:var(--paper);border-radius:24px;max-width:560px;width:100%;padding:38px;position:relative;box-shadow:var(--shadow);max-height:92vh;overflow:auto;animation:pop .35s cubic-bezier(.2,.8,.2,1)}
.modal.wide{max-width:680px;padding:0;overflow:hidden}
@keyframes pop{from{transform:translateY(20px) scale(.97);opacity:0}}
.modal h3{font-size:1.9rem;margin-bottom:6px}
.modal .x{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.85);cursor:pointer;color:var(--muted);display:grid;place-items:center;z-index:3}
.modal .x:hover{background:var(--sand)}.modal .x svg{width:18px;height:18px}
.field{margin-top:16px}
.field label{display:block;font-size:.8rem;font-weight:700;margin-bottom:6px;color:var(--ink-2)}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--body);font-size:.95rem;background:#fff}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--clay)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.recap{background:var(--cream);border-radius:14px;padding:16px;margin-top:18px;font-size:.88rem}
.recap .li{display:flex;justify-content:space-between;padding:4px 0;gap:12px}
.success{text-align:center;padding:20px 0}
.success .ok{width:74px;height:74px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;margin:0 auto 18px}
.success .ok svg{width:34px;height:34px}
/* city modal */
.citym-ph{height:240px;position:relative;background:var(--sand)}
.citym-ph img{width:100%;height:100%;object-fit:cover}
.citym-ph::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(27,19,13,.85))}
.citym-ph .cap{position:absolute;left:24px;bottom:18px;right:24px;color:#fff;z-index:2}
.citym-ph .cap .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.citym-ph .cap h3{font-size:2rem;color:#fff;margin-top:4px}
.citym-body{padding:26px 30px 30px}
.citym-body .hist{color:var(--ink-2);font-size:.98rem;line-height:1.65;margin-bottom:18px}
.citym-body h5{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);margin-bottom:10px}
.citym-body ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.citym-body ul li{display:flex;gap:9px;align-items:center;font-size:.9rem}
.citym-body ul li svg{width:16px;height:16px;color:var(--ochre);flex:none}

/* ---------- DASHBOARD ---------- */
.dash-wrap{padding-top:84px;min-height:100vh;background:var(--cream)}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px}
.kpi{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:24px}
.kpi .lab{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.kpi .num{font-family:var(--display);font-size:2.5rem;color:var(--ink);margin-top:8px;line-height:1}
.kpi .num small{font-size:1rem;color:var(--clay)}
.kpi.accent{background:var(--ink);color:var(--cream)}.kpi.accent .lab{color:var(--gold-soft)}.kpi.accent .num{color:#fff}
.dash-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:24px;margin-bottom:22px}
.dash-card h3{font-size:1.3rem;margin-bottom:4px}.dash-card .sub{color:var(--muted);font-size:.86rem;margin-bottom:18px}
table{width:100%;border-collapse:collapse;font-size:.88rem}
th{text-align:left;padding:12px;color:var(--muted);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;border-bottom:2px solid var(--line)}
td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top}
tr:hover td{background:var(--cream)}
.statut{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:100px;background:var(--sand);color:var(--clay-deep)}
.empty{text-align:center;padding:50px;color:var(--muted)}
.bars{display:flex;flex-direction:column;gap:12px}
.bar{display:grid;grid-template-columns:170px 1fr auto;gap:14px;align-items:center;font-size:.85rem}
.bar .track{height:12px;background:var(--sand);border-radius:100px;overflow:hidden}
.bar .fill{height:100%;background:linear-gradient(90deg,var(--ochre),var(--clay));border-radius:100px;transition:1s}
.lock{max-width:380px;margin:12vh auto;text-align:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:40px 30px}
.lock .mark{width:54px;height:54px;margin:0 auto 18px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-soft),var(--clay) 70%);display:grid;place-items:center}
.lock .mark svg{width:28px;height:28px}
.lock input{margin-top:16px;text-align:center;letter-spacing:.3em;font-size:1.1rem}

/* ---------- B2B / ENTREPRISES ---------- */
.b2b-trust{display:flex;gap:40px;flex-wrap:wrap;margin-top:38px;opacity:0;animation:rise .9s 1.1s forwards}
.b2b-trust .s b{font-family:var(--display);font-size:2rem;font-weight:500;display:block;color:#fff}
.b2b-trust .s span{font-size:.82rem;color:rgba(251,245,234,0.92)}
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.offer{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:.4s;position:relative;overflow:hidden}
.offer:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
.offer .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(140deg,var(--clay),var(--clay-deep));color:#fff}
.offer .ic svg{width:26px;height:26px}
.offer:nth-child(2) .ic{background:linear-gradient(140deg,var(--majorelle),#1b2f6b)}
.offer:nth-child(3) .ic{background:linear-gradient(140deg,var(--ochre),var(--clay))}
.offer:nth-child(4) .ic{background:linear-gradient(140deg,var(--gold),var(--clay-deep))}
.offer:nth-child(5) .ic{background:linear-gradient(140deg,var(--majorelle-soft),var(--majorelle))}
.offer:nth-child(6) .ic{background:linear-gradient(140deg,var(--clay-deep),var(--ink))}
.offer h3{font-size:1.4rem;margin-bottom:8px}
.offer p{font-size:.92rem;color:var(--muted)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{display:flex;gap:14px;align-items:flex-start;padding:20px;border:1px solid rgba(227,199,126,.18);border-radius:var(--r-sm);background:rgba(251,245,234,0.05)}
.svc .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(217,142,50,.16);color:var(--gold-soft);flex:none}
.svc .ic svg{width:21px;height:21px}
.svc b{display:block;color:var(--cream);font-size:.98rem;margin-bottom:3px}
.svc span{font-size:.85rem;color:rgba(243,233,215,0.92)}
/* signature */
.sig{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sigcard{position:relative;height:380px;border-radius:var(--r);overflow:hidden;color:#fff;isolation:isolate}
.sigcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:.7s}
.sigcard:hover img{transform:scale(1.07)}
.sigcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(27,19,13,.2) 30%,rgba(27,19,13,.92))}
.sigcard .c{position:absolute;bottom:0;padding:26px}
.sigcard .badge{display:inline-block;background:var(--gold-soft);color:var(--ink);font-size:.64rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:5px 11px;border-radius:100px;margin-bottom:10px}
.sigcard h3{font-size:1.6rem;color:#fff;margin-bottom:6px}
.sigcard p{font-size:.88rem;color:rgba(255,255,255,.82)}
.b2b-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.b2b-form .full{grid-column:1/-1}
.est-out{display:flex;align-items:baseline;gap:10px;margin:6px 0 2px}
.est-out .v{font-family:var(--display);font-size:2.6rem;color:var(--clay);line-height:1}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step}
.pstep{position:relative;padding-top:14px}
.pstep .nb{font-family:var(--display);font-size:2.4rem;color:var(--gold-soft);line-height:1;margin-bottom:8px}
.pstep h4{font-size:1.1rem;margin-bottom:6px}.pstep p{font-size:.88rem;color:var(--muted)}

/* ============================================================
   RESPONSIVE — TABLETTE & MOBILE (dernière génération)
============================================================ */
/* menu burger : bascule dédiée (avant que les liens ne se chevauchent) */
@media(max-width:1180px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;padding:40px;gap:22px;transform:translateX(100%);transition:.4s;z-index:210;box-shadow:-30px 0 60px rgba(0,0,0,.4)}
  .nav-links.open{transform:none}
  .nav-links a{color:var(--cream)!important;font-size:1.18rem}
  .nav-links a.active:not(.btn){color:var(--gold-soft)!important}
  .nav-links .btn{width:100%;justify-content:center}
  .nav-toggle{display:grid;z-index:220}
}
@media(max-width:1024px){
  .bx{grid-template-columns:1fr}
  .rightcol{position:static}
  .concept-grid{grid-template-columns:1fr;gap:34px}
  .cities-grid{grid-template-columns:repeat(2,1fr)}
  .lib-grid{grid-template-columns:repeat(3,1fr)}
  .pass-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:repeat(2,1fr)}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .bar{grid-template-columns:130px 1fr auto}
  .offer-grid,.svc-grid,.sig{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .wrap{padding:0 18px}
  .hero-stats{gap:24px}
  .concept-cards{grid-template-columns:1fr}
  .cities-grid{grid-template-columns:1fr}
  .lib-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .g-big{grid-column:span 2;grid-row:span 1}
  .pass-grid,.testi-grid{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .passrow{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .offer-grid,.svc-grid,.sig,.process,.b2b-form{grid-template-columns:1fr}
  .phead{padding:130px 0 54px}
  .modal{padding:28px}
  .bar{grid-template-columns:1fr;gap:6px}.bar .track{order:3}
  table{font-size:.8rem}td,th{padding:9px 8px}
}
@media(max-width:430px){
  .kpis{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .lib-grid{grid-template-columns:1fr;grid-auto-rows:180px}
  .g-big,.g-wide{grid-column:span 1}
  .daysctl .val{font-size:2.4rem}
  .brand small{display:none}
}

/* ---------- LOGO RÉEL + SPLASH D'OUVERTURE ---------- */
.brand .mark.logo{background:none!important;box-shadow:none!important}
.brand .mark.logo img{width:100%;height:100%;object-fit:contain;display:block}
#splash{position:fixed;inset:0;z-index:3000;background:var(--cream);display:grid;place-items:center;animation:splashOut .8s ease 1.9s forwards}
#splash img{width:min(72vw,440px);opacity:0;transform:scale(.92) translateY(8px);animation:splashIn 1.1s cubic-bezier(.2,.8,.2,1) .1s forwards;filter:drop-shadow(0 20px 50px rgba(142,52,22,.18))}
@keyframes splashIn{to{opacity:1;transform:none}}
@keyframes splashOut{to{opacity:0;visibility:hidden;pointer-events:none}}
@media(prefers-reduced-motion:reduce){#splash{animation-delay:.4s}}

/* ---------- HÉBERGEMENT (cartes catégorie) ---------- */
.lodge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.lodge{position:relative;border:1px solid rgba(227,199,126,.2);border-radius:14px;overflow:hidden;cursor:pointer;background:rgba(255,255,255,.02);transition:.25s}
.lodge:hover{border-color:var(--gold-soft);transform:translateY(-2px)}
.lodge.on{border-color:var(--ochre);box-shadow:0 0 0 2px var(--ochre) inset}
.lodge .ph{height:104px;overflow:hidden;background:var(--sand)}
.lodge .ph img{width:100%;height:100%;object-fit:cover}
.lodge .lb{padding:11px 13px}
.lodge .lb b{color:var(--cream);font-size:1.05rem;display:block;font-family:var(--display);font-weight:600}
.lodge .lb small{color:rgba(243,233,215,0.87);font-size:.78rem;line-height:1.35;display:block;margin-top:2px}
.lodge .lcheck{position:absolute;top:9px;right:9px;width:24px;height:24px;border-radius:50%;background:var(--ochre);display:grid;place-items:center;opacity:0;transform:scale(.6);transition:.2s;z-index:2}
.lodge.on .lcheck{opacity:1;transform:scale(1)}
.lodge .lcheck svg{width:13px;height:13px;color:#fff;stroke:#fff}
.lodge-note{font-size:.78rem;color:rgba(243,233,215,0.82);margin-top:10px;line-height:1.5}
@media(max-width:680px){.lodge-grid{grid-template-columns:1fr}.lodge{display:grid;grid-template-columns:96px 1fr;align-items:center}.lodge .ph{height:100%;min-height:84px}.lodge .lcheck{top:50%;transform:translateY(-50%) scale(.6)}.lodge.on .lcheck{transform:translateY(-50%) scale(1)}}

/* ---------- TRANSPORT (cartes véhicule) ---------- */
.trans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.trans{position:relative;display:flex;flex-direction:column;gap:7px;border:1px solid rgba(227,199,126,.2);border-radius:14px;padding:16px 14px;cursor:pointer;background:rgba(255,255,255,.02);transition:.25s}
.trans:hover{border-color:var(--gold-soft);transform:translateY(-2px)}
.trans.on{border-color:var(--ochre);box-shadow:0 0 0 2px var(--ochre) inset}
.trans .tic{width:42px;height:42px;border-radius:11px;background:rgba(217,142,50,.16);color:var(--gold-soft);display:grid;place-items:center}
.trans .tic svg{width:24px;height:24px}
.trans .tb b{color:var(--cream);font-family:var(--display);font-weight:600;font-size:1.02rem;display:block;line-height:1.15}
.trans .tb small{color:rgba(243,233,215,0.84);font-size:.77rem;line-height:1.35;display:block;margin-top:3px}
.trans .tcat{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.trans .tpr{position:absolute;top:14px;right:14px;color:var(--gold-soft);font-weight:700;font-size:.95rem}
.trans .tpr small{font-weight:400;color:rgba(243,233,215,0.72);font-size:.68rem}
.trans .lcheck{position:absolute;bottom:12px;right:12px;width:22px;height:22px;border-radius:50%;background:var(--ochre);display:grid;place-items:center;opacity:0;transform:scale(.6);transition:.2s}
.trans.on .lcheck{opacity:1;transform:scale(1)}
.trans .lcheck svg{width:12px;height:12px;color:#fff;stroke:#fff}
@media(max-width:980px){.trans-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.trans-grid{grid-template-columns:1fr}}
/* budget */
.budget-ok{background:rgba(46,158,107,.12);color:#1f7a52;border-radius:10px;padding:9px 12px;font-size:.8rem;font-weight:600;margin-bottom:8px;line-height:1.4}
.budget-over{background:rgba(199,91,57,.12);color:var(--clay-deep);border-radius:10px;padding:9px 12px;font-size:.8rem;font-weight:600;margin-bottom:8px;line-height:1.4}
/* récap devis lisible */
.recap{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:14px 18px;margin-top:14px;font-size:.9rem}
.recap .rrow{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--line)}
.recap .rrow>span{color:var(--muted)}
.recap .rrow b{text-align:right;font-weight:700}
.recap .rrow i{font-style:normal;color:var(--muted);font-weight:400;font-size:.85em}
.recap .rcol{padding:9px 0;border-bottom:1px solid var(--line)}
.recap .rcol>span{color:var(--muted);display:block;margin-bottom:7px}
.recap .rchips{display:flex;flex-wrap:wrap;gap:6px}
.recap .rchips em{font-style:normal;background:#fff;border:1px solid var(--line);border-radius:100px;padding:4px 11px;font-size:.8rem;font-weight:600;color:var(--ink-2)}
.recap .rtot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;margin-top:2px}
.recap .rtot>span{color:var(--muted);font-weight:600}
.recap .rtot b{font-family:var(--display);font-size:1.7rem;color:var(--clay);line-height:1}
/* partenaires */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1000px;margin:0 auto}
.partner{display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 24px;transition:.35s}
.partner:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm);border-color:transparent}
.partner .pmark{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(140deg,var(--ochre),var(--clay));color:#fff;margin-bottom:6px}
.partner .pmark svg{width:26px;height:26px}
.plogo{background:var(--ink);border-radius:12px;height:70px;width:100%;display:flex;align-items:center;justify-content:center;padding:11px;margin-bottom:10px}
.plogo img{max-height:100%;max-width:100%;object-fit:contain}
.partner b{font-family:var(--display);font-size:1.35rem;font-weight:600}
.partner span{font-size:.86rem;color:var(--muted)}
.partner .ptag{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:700}
@media(max-width:880px){.partners{grid-template-columns:1fr}}
/* page partenaires (features) */
.pfeats{display:flex;flex-direction:column;gap:30px;max-width:1000px;margin:0 auto}
.pfeat{display:grid;grid-template-columns:300px 1fr;gap:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.4s}
.pfeat:hover{box-shadow:var(--shadow);border-color:transparent}
.pfeat-v{align-self:stretch;min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;text-align:center;padding:30px;background:linear-gradient(155deg,#2a1e14,#1B130D)}
.pfeat-v .pflogo{height:86px;display:flex;align-items:center;justify-content:center}
.pfeat-v .pflogo img{max-height:86px;max-width:90%;object-fit:contain}
.pfeat-v span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft)}
.pfeat-v .pmark{width:66px;height:66px;border-radius:18px;background:rgba(255,255,255,.16);display:grid;place-items:center}
.pfeat-v .pmark svg{width:34px;height:34px}
.pfeat-v b{font-family:var(--display);font-size:1.7rem;font-weight:600}
.pfeat-v span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;opacity:.88}
.pfeat-c{padding:32px 34px}
.pfeat-c .ptag2{color:var(--clay);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.pfeat-c h3{font-size:1.7rem;margin:6px 0 10px;font-weight:600}
.pfeat-c p{color:var(--muted);margin-bottom:14px;line-height:1.65}
.pfeat-c ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.pfeat-c ul li{font-size:.82rem;background:var(--cream);border:1px solid var(--line);border-radius:100px;padding:5px 13px;color:var(--ink-2)}
@media(max-width:760px){.pfeat{grid-template-columns:1fr}.pfeat-v{min-height:170px}}
