:root{
  --blue:#2e4b9b;
  --red:#e63335;
  --yellow:#ffe200;
  --white:#f8f8f8;
  --ink:#12192c;
  --ink-soft:#5f6984;
  --line:#dbe4fb;
  --surface:#ffffffbf;
  --surface-strong:#ffffffec;
  --shadow:0 24px 70px rgba(46,75,155,.12);
  --shadow-strong:0 30px 90px rgba(30,52,112,.18);
  --radius:32px;
  --move-blue:#2e4b9b;
  --move-red:#e30613;
  --move-cyan:#51beca;
  --move-yellow:#ffe200;
  --move-dark:#071326;
  --move-card:rgba(255,255,255,.82);
}
html[data-theme="dark"]{
  --white:#081222;
  --ink:#edf3ff;
  --ink-soft:#a8b8d8;
  --line:#193154;
  --surface:rgba(8,18,34,.76);
  --surface-strong:rgba(8,18,34,.92);
  --shadow:0 24px 70px rgba(0,0,0,.34);
  --shadow-strong:0 30px 90px rgba(0,0,0,.46);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(46,75,155,.15), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,226,0,.11), transparent 18%),
    radial-gradient(circle at bottom right, rgba(230,51,53,.10), transparent 28%),
    linear-gradient(180deg,#f4f7ff 0%,#f6f9ff 32%,#eef3ff 100%);
  min-width:320px;
  overflow-x:hidden;
}
html[data-theme="dark"] body{
  background:
    radial-gradient(circle at top left, rgba(46,75,155,.2), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,226,0,.08), transparent 18%),
    radial-gradient(circle at bottom right, rgba(230,51,53,.10), transparent 24%),
    linear-gradient(180deg,#06101d 0%,#081221 42%,#09162a 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container-wide{width:min(calc(100% - 56px),1600px);margin-inline:auto}
.site-shell{position:relative;overflow:hidden}
.background-grid{
  position:fixed;inset:0;pointer-events:none;opacity:.45;z-index:-3;
  background-image:linear-gradient(rgba(46,75,155,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px);
  background-size:44px 44px;
}
.background-glow{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:-2}
.glow-a{width:420px;height:420px;left:-90px;top:120px;background:rgba(46,75,155,.16)}
.glow-b{width:380px;height:380px;right:-80px;top:340px;background:rgba(230,51,53,.12)}

.entry-loader{position:fixed;inset:0;display:grid;place-items:center;background:linear-gradient(160deg,#102556,#08111f);z-index:3000;transition:opacity .8s ease,visibility .8s ease}
.entry-loader.is-hidden{opacity:0;visibility:hidden}
.entry-loader__core{position:relative;display:grid;place-items:center;gap:16px;color:#fff;font-weight:700;z-index:2}
.entry-loader__core img{width:90px}
.entry-loader__pulse{position:absolute;width:180px;height:180px;border-radius:50%;border:1px solid rgba(255,255,255,.14);animation:pulse 1.8s infinite ease}
@keyframes pulse{0%{transform:scale(.8);opacity:.8}100%{transform:scale(1.45);opacity:0}}

.top-alert{
  position:sticky;top:0;z-index:80;
  backdrop-filter:blur(18px);
  background:linear-gradient(90deg,rgba(46,75,155,.95),rgba(38,68,143,.85));
  color:#fff;border-bottom:1px solid rgba(255,255,255,.12)
}
.top-alert__inner{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;min-height:54px}
.top-alert__label{display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}
.signal-dot{width:10px;height:10px;border-radius:50%;background:var(--yellow);box-shadow:0 0 14px var(--yellow)}
.top-alert__ticker{overflow:hidden;display:flex;gap:18px;white-space:nowrap}
.top-alert__item{display:inline-flex;gap:10px;align-items:center;font-size:.92rem}
.top-alert__item span{color:#c8d6ff}
.top-alert__cta{font-weight:700;border:1px solid rgba(255,255,255,.18);padding:10px 16px;border-radius:999px}
.site-header{
  position:sticky;top:54px;z-index:70;
  background:rgba(255,255,255,.68);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(46,75,155,.08)
}
html[data-theme="dark"] .site-header{background:rgba(9,19,35,.72)}
.header-inner{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;min-height:92px}
.brand-lockup img{height:54px}
.main-nav{display:flex;align-items:center;gap:14px;justify-content:center}
.main-nav>a,.nav-mega>button{
  padding:14px 18px;border-radius:999px;border:none;background:transparent;color:var(--ink);
  font-weight:700;cursor:pointer;position:relative
}
.main-nav>a:hover,.nav-mega>button:hover{background:rgba(46,75,155,.08)}
.nav-mega{position:relative}
.nav-mega__panel{
  position:absolute;left:50%;transform:translateX(-50%) translateY(18px);top:100%;
  display:grid;grid-template-columns:1fr .9fr;gap:18px;min-width:620px;padding:22px;
  border-radius:28px;background:var(--surface-strong);border:1px solid var(--line);box-shadow:var(--shadow-strong);
  opacity:0;pointer-events:none;transition:all .25s ease
}
.nav-mega:hover .nav-mega__panel{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(8px)}
.nav-card,.nav-list{
  border-radius:24px;padding:22px;background:linear-gradient(180deg, rgba(46,75,155,.08), rgba(46,75,155,.03));border:1px solid var(--line)
}
.nav-card.premium{background:linear-gradient(145deg, rgba(230,51,53,.08), rgba(255,226,0,.12))}
.nav-card small,.fullscreen-col small,.eyebrow{
  display:inline-flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:800;color:var(--blue)
}
.nav-card h3,.fullscreen-col h3{margin:10px 0 14px;font-size:1.5rem;line-height:1}
.nav-card p{color:var(--ink-soft);line-height:1.65}
.nav-card a,.nav-list a,.fullscreen-col a{
  display:block;padding: 14px 18px;border-bottom:1px solid var(--line);font-weight:700
}
.nav-card a:last-child,.nav-list a:last-child,.fullscreen-col a:last-child{border-bottom:none}
.header-tools{display:flex;align-items:center;gap:12px}
.theme-toggle,.burger-futur,.close-menu{
  border:none;border-radius:18px;background:var(--surface);border:1px solid var(--line);color:var(--ink);cursor:pointer
}
.theme-toggle{width:48px;height:48px;font-size:1.1rem}
.burger-futur{width:54px;height:54px;display:grid;place-items:center;gap:5px;padding:12px}
.burger-futur span{display:block;width:22px;height:2px;background:var(--ink);border-radius:999px}
.fullscreen-menu{position:fixed;inset:0;display:none;z-index:200}
.fullscreen-menu.is-open{display:block}
.fullscreen-menu__backdrop{position:absolute;inset:0;background:rgba(4,11,22,.52);backdrop-filter:blur(6px)}
.fullscreen-menu__panel{
  position:relative;margin:24px auto;width:min(calc(100% - 48px),1440px);height:calc(100% - 48px);
  border-radius:36px;background:linear-gradient(180deg,var(--surface-strong),rgba(46,75,155,.05));
  border:1px solid var(--line);box-shadow:var(--shadow-strong);padding:28px;overflow:auto
}
.fullscreen-menu__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.fullscreen-menu__top img{height:64px}
.close-menu{width:48px;height:48px}
.fullscreen-menu__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fullscreen-col{padding:30px;border-radius:30px;background:var(--surface);border:1px solid var(--line)}

.hero-v6{padding:44px 0 30px}
.hero-v6__grid{display:grid;grid-template-columns:1.02fr .98fr;gap:24px;align-items:stretch}
.hero-v6__copy,.hero-v6__visual,.glass-card,.ticket-card,.ticket-showcase__intro,.news-module__viewer,.traffic-card-v6,.news-teaser{
  background:var(--surface);
  backdrop-filter:blur(18px);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:34px;
}
.hero-v6__copy{padding:48px}
.hero-v6__copy h1{font-size:clamp(3rem,6vw,6rem);line-height:.94;margin:14px 0 20px}
.hero-v6__copy h1 span:nth-child(1){color:var(--blue)}
.hero-v6__copy h1 span:nth-child(2){color:var(--red)}
.hero-v6__copy h1 span:nth-child(3){color:#8e65ff}
.hero-v6__copy p,.section-heading p,.ticket-showcase__intro p,.news-module__content p,.traffic-card-v6 p,.map-sidebar__header p,.stop-focus p{color:var(--ink-soft);line-height:1.78}
.hero-v6__actions,.hero-v6__chips,.section-heading__actions,.form-actions,.traffic-card-v6__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-v6__actions{margin-top:28px}
.hero-v6__chips{margin-top:26px}
.hero-v6__chips span,.pill-line,.ghost-link,.route-chip,.map-point-tag{
  display:inline-flex;align-items:center;gap:10px;padding:11px 15px;border-radius:999px;background:rgba(46,75,155,.07);border:1px solid var(--line);font-weight:700
}
.hero-v6__visual{
  position:relative;min-height:560px;padding:30px;
  background:
    radial-gradient(circle at top left, rgba(46,75,155,.18), transparent 35%),
    radial-gradient(circle at 85% 18%, rgba(255,226,0,.18), transparent 16%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(238,243,255,.94));
  overflow:hidden
}
html[data-theme="dark"] .hero-v6__visual{background:radial-gradient(circle at top left, rgba(46,75,155,.18), transparent 35%), radial-gradient(circle at 85% 18%, rgba(255,226,0,.12), transparent 16%), linear-gradient(180deg, rgba(8,18,34,.94), rgba(10,22,42,.94))}
.hero-logo{position:absolute;left:40px;right:40px;top:88px;max-width:78%}
.hero-silhouette{position:absolute;left:0;right:0;bottom:-4px;width:100%;opacity:.95}
.hero-frise{position:absolute;left:40px;right:40px;bottom:118px;width:88%;opacity:.95}
.hero-flower{position:absolute;filter:drop-shadow(0 16px 20px rgba(46,75,155,.12))}
.hero-flower--one{width:94px;right:42px;top:46px}
.hero-flower--two{width:140px;left:34px;bottom:76px}
.hero-panel{
  position:absolute;padding:18px 20px;border-radius:24px;background:var(--surface-strong);border:1px solid var(--line);box-shadow:var(--shadow);z-index:2
}
.hero-panel small{display:block;color:var(--ink-soft);margin-bottom:6px}
.hero-panel strong{display:block;font-size:1.05rem}
.hero-panel--top{top:24px;right:24px}
.hero-panel--bottom{left:24px;bottom:24px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 22px;border-radius:18px;border:none;font-weight:800;cursor:pointer
}
.btn-primary{
  color: white;
  background: linear-gradient(135deg, var(--red) 0%, #f14b4e 20%, var(--blue) 100%);
  box-shadow: 0 18px 38px rgba(46,75,155,.24);

}
.btn-secondary{
  color: #FFF;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #416bb9, #0a2e71);
}
html[data-theme="dark"] .btn-secondary{background:rgba(12,25,48,.86)}

.section-layout,.section-scroller{padding-top:64px;}
.section-heading{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:24px;margin-top: 30px;}
.section-heading.compact{margin-bottom:20px}
.section-heading h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.03;margin:10px 0 0}
.destinations-ribbon{
  overflow:hidden;padding:18px;border-radius:26px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow)
}
.destinations-ribbon__track{display:flex;gap:18px;width:max-content;animation:marquee 34s linear infinite}
.destinations-ribbon__track span{
  white-space:nowrap;border-radius:999px;background:rgba(46,75,155,.07);border:1px solid rgba(46,75,155,.12);font-weight:700
}
.split-layout{display:grid;grid-template-columns:1.12fr .88fr;gap:24px}
.glass-card{padding:34px}
.tabs--futur{display:flex;gap:10px;margin-bottom:20px}
.tabs--futur button{
  border:none;border-radius:999px;padding:14px 20px;background:rgba(46,75,155,.08);font-weight:800;color:var(--ink);cursor:pointer
}
.tabs--futur button.active{background:linear-gradient(135deg,var(--blue),#5f7fe0);color:#fff}
.tab-panel{display:none}
.tab-panel.active{display:block}
.lux-form{display:grid;gap:18px}
.form-grid{display:grid;gap:16px}
.form-grid.two{grid-template-columns:repeat(2,1fr)}
.form-grid.three{grid-template-columns:repeat(3,1fr)}
.form-field label{display:block;margin-bottom:8px;font-weight:700}
input,select,textarea{
  width:100%;padding:15px 16px;border-radius:18px;background:var(--surface-strong);border:1px solid var(--line);color:var(--ink);outline:none
}
.quick-links-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.quick-links-grid a{
  display:flex;align-items:center;gap:14px;min-height:92px;padding:18px;border-radius:24px;background:linear-gradient(180deg, rgba(46,75,155,.05), rgba(46,75,155,.02));border:1px solid var(--line);font-weight:800
}
.quick-links-grid i{
  width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-style:normal;color:#fff;background:linear-gradient(135deg,var(--blue),#5f7fe0);font-size:1.45rem
}

.ticket-showcase{display:grid;grid-template-columns:1fr repeat(3,1fr);gap:18px;align-items:stretch}
.ticket-showcase__intro{padding:30px}
.pill-line{margin-bottom:18px}
.pill-line img{width:38px;height:38px}
.ticket-card{padding:20px;display:grid;gap:18px}
.ticket-card img{border-radius:24px;border:1px solid var(--line);background:#fff}
.ticket-card small{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.ticket-card h3{margin:6px 0 8px;font-size:1.6rem}
.premium-blue{background:linear-gradient(180deg, rgba(46,75,155,.08), rgba(46,75,155,.03))}
.premium-yellow{background:linear-gradient(180deg, rgba(255,226,0,.18), rgba(255,255,255,.65))}
.premium-red{background:linear-gradient(180deg, rgba(230,51,53,.08), rgba(230,51,53,.03))}

.actualites-shell{position:relative}
.actualites-shell::before{
  content:'';position:absolute;right:2%;top:40px;width:220px;height:220px;border-radius:50%;
  background:url('../img/brand/pastille-flowers-soft.png') center/contain no-repeat;opacity:.08;pointer-events:none
}
.news-module{display:grid;grid-template-columns:.78fr 1.22fr;gap:20px}
.news-module__list{display:grid;gap:16px}
.news-teaser{
  padding:20px;text-align:left;cursor:pointer;transition:transform .2s ease, border-color .2s ease
}
.news-teaser:hover,.news-teaser.is-active{transform:translateY(-2px);border-color:rgba(46,75,155,.35)}
.news-teaser strong{display:block;font-size:1.08rem;margin:10px 0}
.news-teaser small{color:var(--ink-soft);line-height:1.6}
.news-module__viewer{display:grid;grid-template-columns:.85fr 1.15fr;overflow:hidden}
.news-module__viewer img{width:100%;height:100%;object-fit:cover;min-height:100%}
.news-module__content{padding:30px}
.news-module__content h3{font-size:2rem;line-height:1.08;margin:14px 0}

.traffic-grid-v6{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.traffic-card-v6{padding:26px;display:grid;gap:12px}
.traffic-card-v6__meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--ink-soft);font-size:.92rem}
.badge-traffic,.badge-info{
  display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase
}
.badge-info{background:rgba(46,75,155,.1);color:var(--blue)}
.badge-traffic{background:rgba(46,75,155,.1);color:var(--blue)}
.level-danger{border-color:rgba(230,51,53,.28)}
.level-warning{border-color:rgba(255,226,0,.42)}
.level-danger .badge-traffic{background:rgba(230,51,53,.11);color:var(--red)}
.level-warning .badge-traffic{background:rgba(255,226,0,.20);color:#6f6200}
.ghost-link{border:none;background:transparent;color:var(--blue);cursor:pointer;padding:0}

.map-composition{display:grid;grid-template-columns:1.06fr .64fr;gap:24px}
.map-composition__main,.map-composition__sidebar{padding:24px}
.map-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.legend-filter{
  padding:11px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(46,75,155,.06);font-weight:800;cursor:pointer;color:var(--ink)
}
.legend-filter.is-active{background:linear-gradient(135deg,var(--blue),#5f7fe0);color:#fff}
.premium-map{
  height:780px;border-radius:28px;border:1px solid var(--line);overflow:hidden;background:linear-gradient(180deg,#cfe3ff,#f8fbff)
}
html[data-theme="dark"] .premium-map{background:linear-gradient(180deg,#102544,#0b172a)}
.map-note{margin-top:14px;padding:14px 16px;border-radius:18px;background:rgba(46,75,155,.06);border:1px solid var(--line);color:var(--ink-soft)}
.map-sidebar__header h3{margin:8px 0 12px;font-size:2rem;line-height:1.06}
.stop-focus{
  margin:18px 0;padding:18px;border-radius:22px;background:linear-gradient(180deg, rgba(255,226,0,.16), rgba(255,255,255,.72));border:1px solid var(--line)
}
.route-stops-list{display:grid;gap:10px;max-height:520px;overflow:auto;padding-right:4px}
.route-stop-item{
  display:grid;gap:6px;padding:14px 16px;border-radius:18px;background:rgba(46,75,155,.05);border:1px solid var(--line)
}
.route-stop-item strong{display:flex;align-items:center;gap:10px}
.stop-pin{width:12px;height:12px;border-radius:50%;display:inline-block}
.site-footer{
  position:relative;margin-top:54px;padding:180px 0 28px;color:#fff;
  background:linear-gradient(180deg,#15306a 0%, #102556 42%, #0c1d43 100%)
}
.footer-decor{position:absolute;left:0;right:0;top:0;height:150px;overflow:hidden}
.footer-decor img{width:100%;height:100%;object-fit:cover}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px;position:relative;z-index:2}
.footer-brand img{max-width:360px;margin-bottom:16px}
.footer-grid h4{margin:0 0 12px}
.footer-grid p,.footer-grid a{color:rgba(255,255,255,.78);line-height:1.7;display:block;margin:7px 0}
.footer-socials{display:flex;gap:12px;margin-top:12px}
.footer-socials a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;border-top:1px solid rgba(255,255,255,.14);margin-top:24px;padding-top:18px;color:rgba(255,255,255,.64)}

.autocomplete-list{position:absolute;left:0;right:0;top:calc(100% + 8px);display:grid;gap:6px;z-index:20}
.autocomplete-list button{border:1px solid var(--line);background:var(--surface-strong);padding:10px 12px;border-radius:14px;text-align:left;color:var(--ink);cursor:pointer;box-shadow:var(--shadow)}
.card-link{display:inline-flex;margin-top:10px;color:var(--blue);font-weight:800}
.small-meta{color:var(--ink-soft)}

@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

@media (max-width:1320px){
  .hero-v6__grid,.split-layout,.ticket-showcase,.news-module,.map-composition,.footer-grid{grid-template-columns:1fr}
  .ticket-showcase{grid-template-columns:repeat(2,1fr)}
  .ticket-showcase__intro{grid-column:1 / -1}
  .news-module__viewer{grid-template-columns:1fr}
  .traffic-grid-v6{grid-template-columns:1fr}
  .main-nav{display:none}
  .fullscreen-menu__grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .container-wide{width:min(calc(100% - 24px),1600px)}
  .top-alert__inner{grid-template-columns:1fr;min-height:auto;padding:12px 0}
  .site-header{top:0}
  .header-inner{grid-template-columns:auto auto}
  .brand-lockup img{height:46px}
  .hero-v6__copy,.hero-v6__visual,.glass-card,.news-module__viewer,.traffic-card-v6,.news-teaser{padding:22px}
  .hero-v6__visual{min-height:440px}
  .hero-logo{max-width:88%;left:20px;right:20px;top:72px}
  .hero-panel{position:static;margin-top:14px}
  .hero-frise{left:14px;right:14px;bottom:96px;width:92%}
  .hero-flower--one{width:80px;right:18px;top:18px}
  .hero-flower--two{width:110px;left:18px;bottom:62px}
  .form-grid.two,.form-grid.three,.quick-links-grid,.ticket-showcase,.footer-grid{grid-template-columns:1fr}
  .premium-map{height:500px}
  .footer-bottom{flex-direction:column}
}


/* === V6.1 Ultra luxe header + hero fusion === */
.background-pattern{position:fixed;inset:auto auto 0 0;pointer-events:none;z-index:-1;opacity:.22}
.background-pattern--flowers{top:160px;right:-120px;left:auto;bottom:auto;width:520px;height:520px;background:url('../img/brand/pastille-flowers-soft.png') center/contain no-repeat;filter:blur(.2px)}
.background-pattern--frise{left:0;right:0;bottom:92px;height:110px;background:url('../img/brand/frise.png') center/contain repeat-x;opacity:.16}

.site-header{position:sticky;top:18px;z-index:30;background:transparent;border:none;box-shadow:none}
.header-backdrop{
  position:absolute;inset:0;border-radius:28px;
  background:linear-gradient(135deg, rgba(255,255,255,.88), rgba(246,249,255,.72) 45%, rgba(255,255,255,.58));
  border:1px solid rgba(46,75,155,.14);
  box-shadow:0 24px 60px rgba(38,58,110,.16), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter:blur(22px);
}
html[data-theme="dark"] .header-backdrop{
  background:linear-gradient(135deg, rgba(12,25,47,.92), rgba(18,35,66,.76));
  border-color:rgba(255,255,255,.08);
  box-shadow:0 24px 70px rgba(0,0,0,.38);
}
.header-inner{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:20px 28px}
.brand-lockup{display:flex;align-items:center;gap:16px}
.brand-logo{width:74px;height:74px;object-fit:contain;flex:0 0 auto}
.brand-copy strong{display:block;font-size:1.6rem;letter-spacing:-.03em;color:var(--blue)}
.brand-copy small{display:block;color:var(--ink-soft);margin-top:2px}
.desktop-nav{justify-self:center}
.nav-list{display:flex;gap:10px;list-style:none;padding:0;margin:0;align-items:center}
.nav-item{position:relative}
.nav-link{
  display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:18px;color:var(--ink);
  font-weight:700;transition:.25s ease;text-decoration:none;background:transparent;border:none;cursor:pointer;font-size:.98rem
}
.nav-link:hover,.nav-item:hover>.nav-link,.nav-item.is-open>.nav-link{background:rgba(46,75,155,.08);color:var(--blue)}
.nav-arrow{font-size:1rem;color:var(--red)}
.mega-panel{
  position:absolute;top:calc(100% + 14px);left:0;min-width:760px;padding:18px;border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,248,255,.96));
  border:1px solid rgba(46,75,155,.12);box-shadow:0 30px 70px rgba(24,40,76,.16);
  opacity:0;transform:translateY(10px);pointer-events:none;transition:.28s ease;
}
html[data-theme="dark"] .mega-panel{
  background:linear-gradient(180deg, rgba(10,22,42,.98), rgba(14,28,52,.98));
  border-color:rgba(255,255,255,.08);box-shadow:0 32px 80px rgba(0,0,0,.42)
}
.nav-item:hover .mega-panel,.nav-item.is-open .mega-panel{opacity:1;transform:translateY(0);pointer-events:auto}
.mega-grid{display:grid;grid-template-columns:1fr 1fr 1.05fr;gap:18px}
.mega-col h3{margin:0 0 12px;font-size:1rem;color:var(--blue)}
.mega-col ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.mega-col li a,.mobile-subgroup a,.mobile-links>a{
  display:block;padding:11px 12px;border-radius:14px;color:var(--ink);text-decoration:none;background:rgba(46,75,155,.04);transition:.22s
}
.mega-col li a:hover,.mobile-subgroup a:hover,.mobile-links>a:hover{background:rgba(230,51,53,.08);color:var(--red)}
.mega-feature{
  height:100%;padding:20px;border-radius:24px;color:#fff;
  background:linear-gradient(135deg, rgba(46,75,155,1), rgba(62,97,194,.88) 58%, rgba(255,226,0,.48));
  display:flex;flex-direction:column;justify-content:space-between;gap:12px;box-shadow:0 20px 40px rgba(46,75,155,.22)
}
.mega-feature.premium{background:linear-gradient(135deg, rgba(230,51,53,.95), rgba(255,115,55,.9) 54%, rgba(255,226,0,.38))}
.mega-feature p,.mega-feature strong,.mega-feature-kicker{color:#fff}
.mega-feature-kicker{font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;opacity:.8}
.btn.btn-mini{padding:10px 14px;border-radius:999px;background:#fff;color:var(--blue);font-weight:800;width:max-content}
.header-actions{display:flex;align-items:center;gap:12px}
.icon-btn{
  width:52px;height:52px;border-radius:16px;border:1px solid rgba(46,75,155,.14);background:rgba(255,255,255,.72);
  display:grid;place-items:center;font-size:1.2rem;cursor:pointer;box-shadow:0 10px 24px rgba(47,69,126,.08)
}
html[data-theme="dark"] .icon-btn{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;width:54px;height:54px;border-radius:18px;border:1px solid rgba(46,75,155,.16);background:linear-gradient(180deg, rgba(255,255,255,.8), rgba(244,249,255,.72));padding:0 14px;justify-content:center;cursor:pointer}
.burger span{display:block;height:2px;border-radius:99px;background:var(--blue)}
.search-drawer{
  max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 28px 0;position:relative
}
.search-drawer.is-open{max-height:180px;padding-bottom:18px}
.search-inner{
  display:flex;gap:16px;align-items:end;padding:16px 0 0
}
.search-inner label{flex:1;display:grid;gap:8px;color:var(--ink-soft);font-weight:700}
.search-inner input{
  width:100%;padding:18px 20px;border-radius:18px;border:1px solid rgba(46,75,155,.12);background:rgba(255,255,255,.9);font-size:1rem
}
.mobile-panel{
  position:fixed;inset:0 0 0 auto;width:min(420px,100%);transform:translateX(100%);transition:transform .32s ease;z-index:60;
  background:linear-gradient(180deg, rgba(248,250,255,.98), rgba(239,244,255,.98));border-left:1px solid rgba(46,75,155,.12);box-shadow:-20px 0 60px rgba(19,31,61,.16)
}
html[data-theme="dark"] .mobile-panel{background:linear-gradient(180deg, rgba(11,22,43,.98), rgba(14,28,52,.98));border-left-color:rgba(255,255,255,.08)}
.mobile-panel.is-open{transform:translateX(0)}
.mobile-panel-inner{padding:22px;display:grid;gap:18px;height:100%;overflow:auto}
.mobile-brand{display:flex;gap:14px;align-items:center}
.mobile-brand img{width:64px;height:64px;object-fit:contain}
.mobile-links{display:grid;gap:10px}
.mobile-links details,.mobile-links>a{padding:14px 16px;border-radius:20px;background:rgba(46,75,155,.05);border:1px solid rgba(46,75,155,.08)}
.mobile-links summary{cursor:pointer;font-weight:800;color:var(--ink)}
.mobile-subgroup{display:grid;gap:8px;margin-top:12px}
.mobile-subgroup h4{margin:8px 0 0;font-size:.85rem;color:var(--red);text-transform:uppercase;letter-spacing:.14em}
.btn-full{width:100%;justify-content:center}

.hero-section{padding:34px 0 34px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:30px;align-items:stretch}
.hero-copy,.hero-visual{
  position:relative;padding:48px;border-radius:34px;
  background:linear-gradient(180deg, rgba(255,255,255,.86), rgba(248,250,255,.86));
  border:1px solid rgba(46,75,155,.12);box-shadow:0 30px 70px rgba(25,42,80,.10), inset 0 1px 0 rgba(255,255,255,.92)
}
html[data-theme="dark"] .hero-copy,html[data-theme="dark"] .hero-visual{
  background:linear-gradient(180deg, rgba(10,22,42,.94), rgba(14,28,52,.92));border-color:rgba(255,255,255,.08)
}
.hero-kicker{display:inline-flex;padding:10px 14px;border-radius:999px;background:rgba(46,75,155,.08);color:var(--blue);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem}
.hero-copy h1{font-size:clamp(3.2rem,6vw,6.3rem);line-height:.92;margin:18px 0;color:var(--ink);letter-spacing:-.05em}
.hero-copy p{max-width:760px;color:var(--ink-soft);font-size:1.08rem;line-height:1.78}
.hero-actions,.hero-stats{display:flex;flex-wrap:wrap;gap:16px}
.hero-actions{margin-top:28px}
.hero-stats{margin-top:34px}
.hero-stats article{min-width:140px;padding:18px 18px;border-radius:22px;background:rgba(46,75,155,.05);border:1px solid rgba(46,75,155,.08)}
.hero-stats strong{display:block;font-size:2rem;color:var(--blue)}
.hero-stats span{color:var(--ink-soft)}
.hero-visual{overflow:hidden;min-height:560px;background:
  radial-gradient(circle at top right, rgba(255,226,0,.22), transparent 20%),
  radial-gradient(circle at 20% 14%, rgba(230,51,53,.13), transparent 18%),
  linear-gradient(180deg, rgba(241,246,255,.96), rgba(254,255,255,.88))}
html[data-theme="dark"] .hero-visual{background:
  radial-gradient(circle at top right, rgba(255,226,0,.12), transparent 18%),
  radial-gradient(circle at 20% 14%, rgba(230,51,53,.16), transparent 16%),
  linear-gradient(180deg, rgba(8,18,34,.96), rgba(10,22,42,.94))}
.hero-card{position:absolute;max-width:260px;padding:22px;border-radius:26px;color:var(--ink);background:rgba(255,255,255,.82);border:1px solid rgba(46,75,155,.12);box-shadow:0 18px 40px rgba(24,40,76,.12)}
html[data-theme="dark"] .hero-card{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.08)}
.card-route{top:48px;left:44px}
.card-ticket{right:38px;bottom:132px}
.route-badge,.mini-chip{display:inline-flex;padding:8px 12px;border-radius:999px;background:var(--blue);color:#fff;font-weight:800;font-size:.8rem;margin-bottom:12px}
.mini-chip{background:var(--red)}
.hero-map-orb{
  position:absolute;right:84px;top:76px;width:250px;height:250px;border-radius:50%;
  background:linear-gradient(180deg, rgba(255,255,255,.8), rgba(46,75,155,.08));display:grid;place-items:center;
  border:1px solid rgba(46,75,155,.14);box-shadow:0 22px 52px rgba(24,40,76,.14)
}
.hero-map-orb img{width:72%;height:72%;object-fit:contain}
.hero-motifs{position:absolute;left:50%;transform:translateX(-50%);pointer-events:none}
.motif-blue-line{bottom:34px;width:min(100%,1280px);height:48px;background:url('../img/brand/frise.png') center/contain no-repeat;opacity:.9}
.motif-red-skyline{bottom:4px;width:min(100%,1600px);height:150px;background:url('../img/brand/decor-long.png') center bottom/cover no-repeat;opacity:.16}
.hero-silhouette{position:absolute;left:20px;right:20px;bottom:0;width:94%;height:auto;opacity:.95}
.hero-frise{position:absolute;left:32px;right:32px;bottom:120px;width:92%}
.hero-flower--one{position:absolute;right:26px;top:20px;width:110px}
.hero-flower--two{position:absolute;left:20px;bottom:124px;width:126px}
.floating-card{animation:floatCard 5.8s ease-in-out infinite}
.card-ticket{animation-delay:1.2s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

#planifier .glass-card,#reseau .glass-card,.news-module__viewer,.traffic-card-v6,.news-teaser,.ticket-card,.ticket-showcase__intro{
  background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(248,250,255,.82));
  border:1px solid rgba(46,75,155,.10);box-shadow:0 24px 60px rgba(25,42,80,.08)
}
html[data-theme="dark"] #planifier .glass-card,
html[data-theme="dark"] #reseau .glass-card,
html[data-theme="dark"] .news-module__viewer,
html[data-theme="dark"] .traffic-card-v6,
html[data-theme="dark"] .news-teaser,
html[data-theme="dark"] .ticket-card,
html[data-theme="dark"] .ticket-showcase__intro{
  background:linear-gradient(180deg, rgba(10,22,42,.94), rgba(13,26,48,.92));border-color:rgba(255,255,255,.08)
}
.ticket-showcase{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:22px;align-items:stretch}
.ticket-showcase__intro{padding:28px;border-radius:28px;display:flex;flex-direction:column;justify-content:center}
.ticket-card{display:grid;grid-template-rows:240px 1fr;min-height:100%;padding:0;overflow:hidden;border-radius:30px}
.ticket-card img{width:100%;height:100%;object-fit:cover;background:#eef3ff}
.ticket-card > div{padding:24px;display:grid;gap:6px}
.ticket-card h3{margin:0;font-size:1.55rem}
.ticket-card small{display:inline-flex;width:max-content;padding:8px 12px;border-radius:999px;color:#fff;font-weight:800;background:rgba(46,75,155,.86)}
.premium-blue>div{background:linear-gradient(180deg, rgba(46,75,155,.08), rgba(46,75,155,.03))}
.premium-yellow>div{background:linear-gradient(180deg, rgba(255,226,0,.20), rgba(255,255,255,.64))}
.premium-red>div{background:linear-gradient(180deg, rgba(230,51,53,.14), rgba(255,255,255,.64))}
.premium-yellow small{background:linear-gradient(135deg, #c49d00, #f6c800)}
.premium-red small{background:linear-gradient(135deg, #d93a3d, #ff6a4d)}

.actualites-shell,.traffic-shell,.map-shell-section{position:relative}
.actualites-shell:before,.traffic-shell:before,.map-shell-section:before{
  content:"";position:absolute;inset:18px 24px auto 24px;height:1px;background:linear-gradient(90deg, transparent, rgba(46,75,155,.16), transparent)
}
.news-module__list{max-height:540px;overflow:auto;padding-right:8px}
.news-teaser{cursor:pointer;text-align:left;transition:.22s ease}
.news-teaser.is-active,.news-teaser:hover{transform:translateX(6px);border-color:rgba(230,51,53,.24);box-shadow:0 22px 44px rgba(230,51,53,.10)}
.news-module__viewer{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden}
.news-module__viewer img{width:100%;height:100%;object-fit:cover;min-height:420px}
.news-module__content{padding:34px;display:grid;align-content:start;gap:14px}
.badge-info,.badge-traffic{display:inline-flex;padding:8px 12px;border-radius:999px;font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.badge-info{background:rgba(46,75,155,.08);color:var(--blue)}
.badge-traffic{background:rgba(230,51,53,.10);color:var(--red)}

.traffic-grid-v6{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:18px}
.traffic-card-v6{
  position:relative;border-radius:30px;padding:26px;overflow:hidden;min-height:220px;
  background:
   linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,250,255,.84)),
   repeating-linear-gradient(90deg, rgba(46,75,155,.02) 0 46px, transparent 46px 92px)
}
.traffic-card-v6:before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg, var(--red), #ff8862)
}
.traffic-card-v6__meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:var(--ink-soft);font-weight:700;font-size:.9rem}
.traffic-card-v6 h3{margin:16px 0 12px;font-size:1.45rem;letter-spacing:-.03em}
.traffic-card-v6__actions a,.traffic-card-v6__actions button{
  padding:10px 14px;border-radius:999px;border:1px solid rgba(46,75,155,.12);background:rgba(46,75,155,.04);font-weight:700
}
.traffic-card-v6__actions button{cursor:pointer}

.map-composition{display:grid;grid-template-columns:1.15fr .85fr;gap:20px}
.premium-map{height:760px;border-radius:26px;overflow:hidden;border:1px solid rgba(46,75,155,.10)}
.map-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.legend-filter{padding:10px 14px;border-radius:999px;border:1px solid rgba(46,75,155,.12);background:#fff;font-weight:800;cursor:pointer}
.legend-filter.is-active{background:var(--blue);color:#fff}
.map-sidebar__header h3{font-size:2rem;line-height:1.02;margin:6px 0 12px}
.route-stop-item{padding:14px 14px;border-radius:18px;background:rgba(46,75,155,.04);margin-bottom:10px;border:1px solid rgba(46,75,155,.08)}
.map-note{margin-top:16px;color:var(--ink-soft)}

.site-footer{position:relative;margin-top:80px;padding:150px 0 38px;background:linear-gradient(180deg, #152b54, #0d1b35);overflow:hidden}
.footer-overlay{position:absolute;inset:0;background:radial-gradient(circle at top right, rgba(255,226,0,.10), transparent 20%), radial-gradient(circle at top left, rgba(230,51,53,.16), transparent 22%)}
.footer-grid,.footer-bottom{position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:26px}
.footer-pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.footer-pills span{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-weight:700}
.footer-mini-motif img{width:92px;height:92px;object-fit:contain;opacity:.95;margin-top:10px}
.footer-socials a:hover{background:rgba(255,255,255,.18)}
.footer-bottom{align-items:center}

@media (max-width:980px){
  .desktop-nav{display:none}
  .burger{display:flex}
  .hero-grid,.map-composition,.news-module,.ticket-showcase,.footer-grid{grid-template-columns:1fr}
  .ticket-card{grid-template-rows:220px 1fr}
  .header-inner{grid-template-columns:auto 1fr auto}
}
@media (max-width:760px){
  .site-header{top:8px}
  .header-inner{grid-template-columns:1fr auto auto;padding:0px}
  .brand-copy small,.brand-copy .eyebrow{display:none}
  .brand-copy strong{font-size:1.2rem}
  .brand-logo{width:56px;height:56px}
  .search-inner{flex-direction:column;align-items:stretch}
  .hero-copy,.hero-visual{padding:24px}
  .hero-copy h1{font-size:2.6rem}
  .hero-actions,.hero-stats{gap:12px}
  .hero-stats article{min-width:calc(50% - 6px)}
  .hero-map-orb{position:relative;inset:auto;margin:32px auto 0;width:180px;height:180px}
  .hero-card{position:relative;left:auto;right:auto;top:auto;bottom:auto;max-width:none;margin-top:16px}
  .hero-visual{min-height:auto}
  .motif-red-skyline{height:90px}
  .premium-map{height:520px}
  .news-module__viewer{grid-template-columns:1fr}
  .news-module__viewer img{min-height:260px}
  .footer-grid{grid-template-columns:1fr}
}

/* === V6.2 ultra luxe one-page fusion === */
.hero-map-orb--logo img{width:68%;height:68%;object-fit:contain}
.compact-heading h2{max-width:980px}
.plan-card{position:relative;overflow:hidden}
.plan-card::after{content:'';position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:url('../img/brand/pastille-flowers-soft.png') center/contain no-repeat;opacity:.08;pointer-events:none}
.iconized input{background-image:linear-gradient(90deg,rgba(46,75,155,.05),transparent)}
.ticket-showcase--equal{grid-template-columns:1.15fr repeat(3,1fr)}
.equal-card{display:grid;grid-template-rows:auto 1fr;min-height:100%}
.equal-card > div{display:grid;align-content:start}
.offer-mini-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.offer-mini-grid span,.mobility-pills span,.footer-pills span{padding:10px 14px;border-radius:999px;background:rgba(46,75,155,.08);border:1px solid var(--line);font-weight:700}
.traffic-hub{position:relative}
.traffic-hub::before{content:'';position:absolute;left:4%;top:30px;width:180px;height:180px;background:url('../img/brand/flower.png') center/contain no-repeat;opacity:.07;pointer-events:none}
.traffic-dashboard{display:grid;grid-template-columns:1.1fr 1.45fr .9fr;gap:20px;align-items:start}
.traffic-dashboard__controls,.traffic-dashboard__table,.traffic-dashboard__detail{padding:24px}
.traffic-filter-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.traffic-chip{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(46,75,155,.08);color:var(--ink);font-weight:800;cursor:pointer}
.traffic-chip.is-active{background:linear-gradient(135deg,var(--blue),#5d7fe5);color:#fff;border-color:transparent}
.traffic-chip--soft{background:rgba(255,255,255,.72)}
.traffic-search{display:grid;gap:8px;margin-top:8px;color:var(--ink-soft);font-weight:700}
.traffic-search input{padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:var(--surface-strong);color:var(--ink)}
.traffic-board-header,.traffic-row{display:grid;grid-template-columns:88px 110px 1fr 170px 90px;gap:14px;align-items:center}
.traffic-board-header{padding:0 14px 14px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:800;border-bottom:1px solid var(--line)}
.traffic-board-body{display:grid;gap:10px;margin-top:10px}
.traffic-row{padding:16px 14px;border-radius:20px;border:1px solid transparent;background:rgba(46,75,155,.04);text-align:left;cursor:pointer;transition:.22s ease;color:var(--ink)}
.traffic-row:hover,.traffic-row.is-active{transform:translateY(-1px);border-color:rgba(46,75,155,.25);background:linear-gradient(180deg,rgba(46,75,155,.08),rgba(255,255,255,.78))}
.traffic-line-tag{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:999px;font-weight:900;color:#fff;background:var(--blue)}
.traffic-line-tag.line-barge{background:#15306a}
.traffic-status{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;font-size:.74rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.traffic-status.status-urgent{background:rgba(230,51,53,.14);color:var(--red)}
.traffic-status.status-warning{background:rgba(255,226,0,.24);color:#ffd326}
.traffic-status.status-info{background:rgba(46,75,155,.12);color:#70c4dd;)}
.traffic-title-cell strong{display:block;font-size:14px;margin-bottom:6px}
.traffic-title-cell small,.traffic-time-cell{color:var(--ink-soft)}
.traffic-dashboard__detail{position:sticky;top:132px}
.traffic-detail-subtitle{color:var(--ink-soft);margin-top:-4px}
.traffic-detail-meta{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0}
.traffic-detail-meta span{padding:10px 14px;border-radius:999px;background:rgba(46,75,155,.08);border:1px solid var(--line);font-weight:700}
.traffic-impact-box{padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(46,75,155,.06),rgba(255,255,255,.72));border:1px solid var(--line)}
.traffic-impact-box ul{margin:12px 0 0;padding-left:18px;display:grid;gap:8px}
.traffic-detail-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.news-module__viewer{min-height:100%}
.news-module__viewer .card-link{margin-top:auto}
.faq-contact-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:22px;align-items:start}
.faq-card,.contact-card{padding:26px}
.faq-list{display:grid;gap:14px}
.faq-list details{border:1px solid var(--line);border-radius:20px;background:rgba(46,75,155,.04);padding:16px 18px}
.faq-list summary{cursor:pointer;font-weight:800;list-style:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list p{margin:12px 0 0;color:var(--ink-soft);line-height:1.7}
.contact-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.contact-mini-grid a{display:grid;gap:4px;padding:18px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.72)}
.contact-mini-grid strong{font-size:.98rem}
.contact-mini-grid span{color:var(--ink-soft)}
.compact-form textarea{resize:vertical}
.mobility-banner{padding:28px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;overflow:hidden;position:relative}
.mobility-banner::after{content:'';position:absolute;right:-60px;bottom:-60px;width:230px;height:230px;background:url('../img/brand/pastille-flowers-soft.png') center/contain no-repeat;opacity:.08;pointer-events:none}
.footer-decor-band{position:relative;margin-top:34px}
.footer-decor-band .footer-decor{position:relative;top:auto;height:120px}
.footer-decor-band .footer-decor img{object-fit:cover;object-position:center bottom}
.site-footer{margin-top:0;padding:64px 0 28px}
.footer-overlay{position:absolute;inset:0;background:radial-gradient(circle at 10% 0, rgba(255,255,255,.08), transparent 24%),radial-gradient(circle at 90% 10%, rgba(255,226,0,.07), transparent 18%);pointer-events:none}
.footer-grid,.footer-bottom{position:relative;z-index:2}
.footer-grid h4{font-size:1rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.9)}
.footer-mini-motif img{width:86px;height:86px;opacity:.88}
.header-actions .btn{white-space:nowrap}
.brand-logo{width:120px;height:auto}
.desktop-nav .nav-list{justify-content:center}
.mobility-grid{grid-template-columns:1fr 1fr 1.05fr}
.subtle-blue{background:linear-gradient(135deg, rgba(46,75,155,.95), rgba(84,121,214,.82) 62%, rgba(255,255,255,.18))}
@media (max-width:1320px){
  .traffic-dashboard,.faq-contact-grid{grid-template-columns:1fr}
  .traffic-dashboard__detail{position:relative;top:auto}
  .ticket-showcase--equal{grid-template-columns:repeat(2,1fr)}
  .ticket-showcase--equal .ticket-showcase__intro{grid-column:1/-1}
  .mobility-banner{grid-template-columns:1fr}
}
@media (max-width:760px){
  .traffic-board-header{display:none}
  .traffic-row{grid-template-columns:1fr;gap:8px}
  .traffic-zone-cell{display:block}
  .contact-mini-grid{grid-template-columns:1fr}
  .brand-logo{width:92px}
  .ticket-showcase--equal{grid-template-columns:1fr}
}


/* V6.3 premium refinements */
.site-header{backdrop-filter:blur(22px) saturate(160%)}
.brand-logo{filter:drop-shadow(0 18px 30px rgba(46,75,155,.22));}
.hero-section{padding-top:42px;}
.hero-copy h1{max-width:14ch;letter-spacing:-.04em}
.hero-kicker{box-shadow:0 8px 24px rgba(46,75,155,.12)}
.hero-card{border:1px solid rgba(46,75,155,.14);box-shadow:0 30px 60px rgba(14,32,67,.14)}
.ticket-showcase--equal{align-items:stretch}
.ticket-card.equal-card{min-height:100%;position:relative;overflow:hidden}
.ticket-card.equal-card::after{content:"";position:absolute;inset:auto -30% -50% auto;width:180px;height:180px;background:radial-gradient(circle, rgba(255,255,255,.35), rgba(255,255,255,0));pointer-events:none}
.ticket-card h3{font-size:clamp(1.4rem,2vw,1.9rem)}
.traffic-dashboard__table{background:linear-gradient(180deg,rgba(7,20,41,.95),rgba(10,26,52,.98));color:#eaf0ff;border:1px solid rgba(120,160,255,.18)}
.traffic-board-header{letter-spacing:.12em;text-transform:uppercase;font-size:.74rem;color:#c0dfff}
.traffic-row{background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.06)}
.traffic-row:hover,.traffic-row.is-active{background:linear-gradient(90deg,rgba(46,75,155,.28),rgba(230,51,53,.12));}
.traffic-title-cell strong{color:#fff}
.traffic-time-cell{color:#c4d2fb}
.traffic-dashboard__detail{box-shadow:0 24px 48px rgba(15,28,66,.14), inset 0 1px 0 rgba(255,255,255,.55)}
.news-module__viewer,.news-teaser{border:1px solid rgba(46,75,155,.12)}
.news-teaser:hover,.news-teaser.is-active{transform:translateY(-2px);box-shadow:0 18px 36px rgba(46,75,155,.12)}
.map-composition__main,.map-composition__sidebar,.faq-card,.contact-card,.quick-card-panel,.plan-card{box-shadow:0 24px 52px rgba(18,39,80,.1)}
.footer-decor-band{margin-top:54px;margin-bottom:-18px;z-index:2}
.footer-decor-band .footer-decor{height:152px;opacity:.96}
.site-footer{position:relative;z-index:1}
.footer-grid{padding-top:56px}
.footer-socials a{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}

.traffic-select{display:grid;gap:8px;margin-top:4px;color:var(--ink-soft);font-weight:700}
.traffic-select select{padding:15px 16px;border-radius:18px;border:1px solid var(--line);background:var(--surface-strong);color:var(--ink);font-weight:700}
.traffic-zone-cell{color:var(--ink-soft);font-weight:700;font-size: 14px}
.traffic-reco-box{margin-top:16px;padding:16px 18px;border-radius:20px;background:linear-gradient(135deg,rgba(255,226,0,.18),rgba(255,255,255,.92));border:1px solid rgba(230,51,53,.12)}
.traffic-reco-box strong{display:block;margin-bottom:6px}
.traffic-detail-meta span{backdrop-filter:blur(8px)}
.footer-decor-band{pointer-events:none}
.container-xl{width:min(1600px,calc(100% - 40px));margin-inline:auto}


/* V6.6 Smart Network Plus */
.traffic-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin:0 0 1.5rem}
.traffic-kpi{padding:1rem 1.1rem;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(240,246,255,.88));border:1px solid rgba(46,75,155,.12);box-shadow:0 18px 44px rgba(19,39,84,.08)}
[data-theme="dark"] .traffic-kpi{background:linear-gradient(180deg,rgba(12,24,47,.88),rgba(9,19,39,.92));border-color:rgba(255,255,255,.08)}
.traffic-kpi strong{display:block;font-size:1.8rem;color:var(--brand-blue,#2e4b9b)}
.traffic-kpi span{display:block;font-size:.93rem;opacity:.8}
.smart-stop-grid{display:grid;grid-template-columns:320px 1.05fr .95fr;gap:1.3rem;align-items:start}
.smart-stop-controls,.smart-stop-departures,.smart-stop-media{min-width:0}
.smart-stop-summary{margin-top:1rem;padding:1rem 1.05rem;border-radius:20px;background:rgba(46,75,155,.06);border:1px solid rgba(46,75,155,.12)}
.smart-stop-summary h3{margin:.35rem 0 .4rem;font-size:1.25rem}
.smart-stop-tags{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}
.smart-stop-tags span{padding:.5rem .75rem;border-radius:999px;background:rgba(230,51,53,.08);border:1px solid rgba(230,51,53,.16);font-size:.85rem;font-weight:600}
.smart-stop-headline{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.smart-stop-headline h3{margin:0}
.departure-list{display:grid;gap:.75rem}
.departure-item{display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;align-items:center;padding:.95rem 1rem;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(246,249,255,.92));border:1px solid rgba(46,75,155,.1)}
[data-theme="dark"] .departure-item{background:linear-gradient(180deg,rgba(11,23,45,.96),rgba(9,19,36,.92));border-color:rgba(255,255,255,.08)}
.departure-line{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:52px;border-radius:16px;color:#fff;font-weight:800;box-shadow:inset 0 -10px 22px rgba(0,0,0,.15)}
.departure-main strong{display:block;font-size:1rem}
.departure-main small{display:block;opacity:.75;margin-top:.18rem}
.departure-time{text-align:right}
.departure-time strong{display:block;font-size:1.15rem}
.departure-time span{font-size:.8rem;opacity:.75}
.smart-media-frame{position:relative;overflow:hidden;border-radius:24px;background:#091938;min-height:250px;border:1px solid rgba(46,75,155,.14);box-shadow:0 22px 58px rgba(19,39,84,.12)}
.smart-media-frame img,.smart-media-frame video{width:100%;height:100%;object-fit:cover;display:block}
.smart-media-copy{padding-top:1rem}
.smart-media-copy h3{margin:0 0 .45rem}
.smart-media-copy p{margin:0 0 .75rem}
.smart-media-meta{display:flex;flex-wrap:wrap;gap:.55rem}
.smart-media-meta span{padding:.5rem .75rem;border-radius:999px;background:rgba(255,226,0,.18);border:1px solid rgba(255,226,0,.35);font-size:.84rem;font-weight:700}
.map-popup-rich{font-family:Inter,sans-serif;max-width:290px}
.map-popup-rich__media{position:relative;overflow:hidden;border-radius:16px;margin-bottom:.75rem;background:#102247;aspect-ratio:16/9}
.map-popup-rich__media img,.map-popup-rich__media video{width:100%;height:100%;object-fit:cover;display:block}
.map-popup-rich__type{display:inline-flex;padding:.28rem .55rem;border-radius:999px;background:rgba(46,75,155,.12);font-size:.74rem;font-weight:700;margin-bottom:.45rem}
.map-popup-rich h4{margin:.15rem 0 .45rem;font-size:1rem;line-height:1.25;color:#102247}
.map-popup-rich p{margin:0 0 .55rem;font-size:.86rem;line-height:1.45;color:#334867}
.map-popup-rich__chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:.6rem 0}
.map-popup-rich__chips span{padding:.3rem .55rem;border-radius:999px;background:#f4f7ff;border:1px solid rgba(46,75,155,.12);font-size:.73rem;font-weight:700;color:#27417f}
.map-popup-rich__cta{display:inline-flex;margin-top:.25rem;font-size:.8rem;font-weight:800;color:#e63335;text-decoration:none}
.route-stops-list .route-stop-item.is-focus{border-color:rgba(230,51,53,.35);background:rgba(230,51,53,.04)}
@media (max-width: 1100px){.smart-stop-grid{grid-template-columns:1fr}.traffic-kpis{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 720px){.traffic-kpis{grid-template-columns:1fr}.departure-item{grid-template-columns:auto 1fr}.departure-time{grid-column:2;text-align:left}}

/* V6.8 Smart Network Immersive additions */
.service-day-switch{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;margin:.9rem 0 1rem}
.service-day-switch button{border:1px solid rgba(46,75,155,.14);background:rgba(255,255,255,.86);border-radius:16px;padding:.8rem .9rem;font-weight:800;color:var(--ink);cursor:pointer;transition:.25s ease}
.service-day-switch button.is-active{background:linear-gradient(135deg,#2e4b9b,#4366cb);color:#fff;box-shadow:0 12px 28px rgba(46,75,155,.25)}
[data-theme="dark"] .service-day-switch button{background:rgba(10,22,41,.92);border-color:rgba(255,255,255,.08);color:#e7efff}
.smart-stop-ops{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin-top:1rem}
.smart-stop-ops article{padding:1rem 1.1rem;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(244,247,255,.88));border:1px solid rgba(46,75,155,.08)}
.smart-stop-ops span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);margin-bottom:.35rem}
.smart-stop-ops strong{font-size:.96rem;line-height:1.45;color:var(--ink)}
[data-theme="dark"] .smart-stop-ops article{background:linear-gradient(180deg,rgba(9,19,36,.96),rgba(13,24,45,.92));border-color:rgba(255,255,255,.08)}
.smart-media-gallery{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem}
.gallery-thumb{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem .9rem;border-radius:999px;border:1px solid rgba(46,75,155,.12);background:rgba(255,255,255,.88);font-weight:700;color:var(--ink);cursor:pointer;transition:.25s ease}
.gallery-thumb.is-active{background:linear-gradient(135deg,rgba(230,51,53,.94),rgba(255,101,88,.92));color:#fff;border-color:transparent;box-shadow:0 12px 28px rgba(230,51,53,.24)}
[data-theme="dark"] .gallery-thumb{background:rgba(10,22,41,.92);border-color:rgba(255,255,255,.08);color:#edf3ff}
.map-popup-rich__gallery{display:flex;flex-wrap:wrap;gap:.4rem;margin:.55rem 0 .2rem}
.map-popup-rich__gallery span{font-size:.72rem;border-radius:999px;background:rgba(230,51,53,.08);color:#b52528;padding:.28rem .5rem;font-weight:700}
#stopBoardSearch{background-image:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,250,255,.9))}
@media (max-width: 860px){.smart-stop-ops{grid-template-columns:1fr}.service-day-switch{grid-template-columns:1fr}}


/* V6.8 additions */
.map-popup-rich__gallery img,.map-popup-rich__gallery video{border-radius:14px;box-shadow:0 10px 24px rgba(10,18,32,.18)}
.smart-media-gallery figure{margin:0;display:flex;flex-direction:column;gap:.4rem;padding:.55rem;border-radius:18px;background:rgba(255,255,255,.66);border:1px solid rgba(46,75,155,.08)}
.smart-media-gallery figcaption{font-size:.78rem;color:var(--ink-soft);font-weight:700}
[data-theme="dark"] .smart-media-gallery figure{background:rgba(9,19,36,.88);border-color:rgba(255,255,255,.08)}
.traffic-kpi-note{margin-top:.65rem;font-size:.84rem;color:var(--ink-soft)}


/* ===== V6.9 map and equal tickets upgrades ===== */
.ticket-showcase--equal{grid-auto-rows:1fr;align-items:stretch}
.ticket-showcase--equal .equal-card{display:flex;flex-direction:column;min-height:100%;height:100%}
.ticket-showcase--equal .equal-card img{height:280px;width:100%;object-fit:contain;object-position:center;display:block;filter:drop-shadow(0 24px 30px rgba(20,37,79,.12));margin-inline:auto}
.ticket-showcase--equal .equal-card > div{display:flex;flex-direction:column;gap:.4rem;flex:1}
.ticket-showcase--equal .equal-card h3{min-height:2.8em}
.map-live-deck{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.map-live-deck article{padding:16px 18px;border-radius:18px;background:linear-gradient(135deg,rgba(46,75,155,.10),rgba(230,51,53,.08));border:1px solid rgba(46,75,155,.12);box-shadow:0 18px 40px rgba(28,45,91,.08)}
.map-live-deck strong{display:block;font-size:1.25rem;letter-spacing:.04em;color:var(--blue)}
.map-live-deck span{font-size:.84rem;color:var(--ink-soft)}
.route-insights{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0 18px}
.route-insight-card{display:flex;flex-direction:column;gap:.35rem;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.85),rgba(232,239,255,.92));border:1px solid rgba(46,75,155,.14)}
.route-insight-card strong{color:var(--blue);font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}
.route-insight-card small{color:var(--ink-soft);line-height:1.55}
.premium-map{position:relative;overflow:hidden}
.premium-map::after{content:"";position:absolute;inset:12px;border-radius:24px;pointer-events:none;border:1px solid rgba(255,255,255,.28);box-shadow:inset 0 0 0 1px rgba(46,75,155,.05)}
.route-chip{transition:transform .24s ease, box-shadow .24s ease, background .24s ease}
.route-chip:hover,.route-chip.is-active{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 24px rgba(35,58,112,.16)}
.route-stop-item{position:relative;overflow:hidden}
.route-stop-item::before{content:"";position:absolute;inset:auto -20% -45% auto;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(255,226,0,.18),transparent 65%)}
.map-popup-rich{font-family:inherit;display:grid;gap:10px}
.map-popup-rich__media{border-radius:16px;overflow:hidden;background:#eef3ff;min-height:156px;display:grid;place-items:center}
.map-popup-rich__media img,.map-popup-rich__media video{width:100%;height:180px;object-fit:cover;display:block}
.map-popup-rich__chips span{transition:transform .18s ease, background .18s ease}
.map-popup-rich__chips span:hover{transform:translateY(-1px)}
@media (max-width: 1100px){
  .ticket-showcase--equal .equal-card img{height:240px}
  .map-live-deck,.route-insights{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .ticket-showcase--equal .equal-card img{height:210px}
}


.mobile-panel{
  position: fixed;
  top: 0;
  right: 0;
  height: 100dvh;
  width: min(420px, 100%);
  transform: translateX(100%);
  transition: transform .32s ease;
  z-index: 120;
  background:
    linear-gradient(180deg, rgba(9,19,36,.98), rgba(13,26,48,.98));
  border-left: 1px solid rgba(255,255,255,.08);
  box-shadow: -24px 0 64px rgba(0,0,0,.32);
  overflow: hidden;
}

.mobile-panel.is-open{
  transform: translateX(0);
}

.mobile-panel-inner{
  height: 100%;
  overflow-y: auto;
  padding: 20px 18px 24px;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 18px;
}

.mobile-panel-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.mobile-brand{
  display: flex;
  align-items: center;
  gap: 12px;
}

.mobile-brand img{
  width: 52px;
  height: 52px;
  object-fit: contain;
}

.mobile-brand strong{
  display: block;
  color: #fff;
  font-size: 1.08rem;
}

.mobile-brand small{
  display: block;
  color: rgba(255,255,255,.72);
  font-size: .82rem;
}

.mobile-close{
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  color: #fff;
  cursor: pointer;
  font-size: 1rem;
}

.mobile-panel-intro{
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}

.mobile-panel-intro p{
  margin: 8px 0 0;
  color: rgba(255,255,255,.74);
  line-height: 1.6;
  font-size: .92rem;
}

.mobile-links{
  display: grid;
  gap: 12px;
}

.mobile-links details,
.mobile-direct-link{
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}

.mobile-links summary{
  list-style: none;
  cursor: pointer;
  padding: 16px 18px;
  color: #fff;
  font-weight: 800;
}

.mobile-links summary::-webkit-details-marker{
  display: none;
}

.mobile-subgroup{
  display: grid;
  gap: 8px;
  padding: 0 14px 14px;
}

.mobile-subgroup h4{
  margin: 4px 4px 2px;
  font-size: .76rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #9fb7ff;
}

.mobile-subgroup a,
.mobile-direct-link{
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
  text-decoration: none;
  color: #fff;
  background: rgba(255,255,255,.04);
  font-weight: 600;
}

.mobile-direct-link{
  margin: 0;
}

.mobile-panel-footer{
  display: grid;
  gap: 10px;
}

.btn-full{
  width: 100%;
  justify-content: center;
}

body.menu-open{
  overflow: hidden;
}

@media (max-width: 768px){
  .site-header .header-actions > a.btn-primary{
    display: none;
  }
}

@media (max-width: 768px){
  .header-actions{
    gap: 8px;
  }

  .theme-toggle{
    display: none; /* optionnel */
  }
}

/* Bouton menu futuriste */
.burger-futuriste {
  position: relative;
  width: 54px;
  height: 54px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 18px;
  background: linear-gradient(180deg, rgb(4 28 101 / 95%), rgba(255, 255, 255, .04)), radial-gradient(circle at top left, rgb(23 148 174), #0043b5ab 35%), radial-gradient(circle at bottom right, rgb(46 75 155), transparent 45%);
  backdrop-filter: blur(14px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .18), inset 0 -1px 0 rgba(0, 0, 0, .16);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
  overflow: hidden;
}

.burger-futuriste::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(46,75,155,.18), rgba(230,51,53,.08));
  opacity:.9;
  z-index:0;
}

.burger-futuriste::after{
  content:"";
  position:absolute;
  width:120%;
  height:120%;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,.16) 50%, transparent 80%);
  transform: translateX(-130%) rotate(12deg);
  transition: transform .55s ease;
  z-index:0;
}

.burger-futuriste:hover{
  transform: translateY(-1px) scale(1.02);
  border-color: rgba(255,226,0,.28);
  box-shadow:
    0 18px 36px rgba(8,18,34,.30),
    0 0 0 1px rgba(255,226,0,.08),
    inset 0 1px 0 rgba(255,255,255,.20);
}

.burger-futuriste:hover::after{
  transform: translateX(130%) rotate(12deg);
}

.burger-futuriste:active{
  transform: scale(.97);
}

.burger-futuriste__inner{
  position: relative;
  z-index: 2;
  width: 22px;
  height: 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.burger-futuriste__inner span{
  display:block;
  width:100%;
  height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, #ffffff, #d9e5ff);
  box-shadow:
    0 0 10px rgba(255,255,255,.18),
    0 0 18px rgba(46,75,155,.18);
  transition: transform .28s ease, opacity .22s ease, width .22s ease;
}

.burger-futuriste__inner span:nth-child(2){
  width: 78%;
  align-self: flex-end;
}

.burger-futuriste__inner span:nth-child(3){
  width: 90%;
}

/* état ouvert */
.burger-futuriste[aria-expanded="true"] .burger-futuriste__inner span:nth-child(1){
  transform: translateY(7px) rotate(45deg);
  width:100%;
}

.burger-futuriste[aria-expanded="true"] .burger-futuriste__inner span:nth-child(2){
  opacity:0;
  transform: scaleX(0);
}

.burger-futuriste[aria-expanded="true"] .burger-futuriste__inner span:nth-child(3){
  transform: translateY(-7px) rotate(-45deg);
  width:100%;
}

.mobility-pills{
  display: flex;
  flex-wrap: wrap;
  gap: 10px; /* espace entre pills */
  margin-top: 16px;
}

.mobility-pills span{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 10px 14px;
  border-radius: 999px;

  font-size: 13px;
  font-weight: 500;

  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(10px);

  border: 1px solid rgba(0,0,0,0.06);

  box-shadow:
    0 6px 16px rgba(0,0,0,0.06),
    inset 0 1px 0 rgba(255,255,255,0.5);

  transition: all .2s ease;
  cursor: default;
}
.mobility-pills span:hover{
  transform: translateY(-2px);
  box-shadow:
    0 10px 22px rgba(0,0,0,0.10),
    0 0 0 1px rgba(230,51,53,0.08);
}

@media (max-width: 768px){
  .mobility-pills{
    gap: 8px;
  }

  .mobility-pills span{
    font-size: 12px;
    padding: 8px 12px;
  }
}

.mobility-pills span{
  background: linear-gradient(135deg, rgba(46,75,155,0.08), rgba(230,51,53,0.06));
  border: 1px solid rgba(46,75,155,0.12);
}

.btn-recharge {
  min-width: 190px;
  justify-content: center;
  white-space: nowrap;
}

@media (max-width: 1024px) {
  .desktop-nav {
    display: none;
  }

  .burger-futuriste {
    display: inline-flex;
  }

  .btn-recharge {
    display: none;
  }
}

.mega-panel {
  min-width: 360px;
}

.mega-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.mobility-grid {
  grid-template-columns: 1fr;
}

.mega-panel--single {
  min-width: 360px;
  max-width: 360px;
}

.mega-grid--single {
  grid-template-columns: 1fr;
}

.mega-grid--single .mega-col {
  width: 100%;
}

@media (max-width: 980px) {
  .mega-panel,
  .mega-panel--single {
    min-width: auto;
    max-width: none;
    width: min(92vw, 560px);
  }

  .mega-grid,
  .mobility-grid,
  .mega-grid--single {
    grid-template-columns: 1fr;
  }
}

.launch-lines {
  margin-top: 34px;
  position: relative;
  padding: 24px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,226,0,.20), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(230,51,53,.12), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(246,249,255,.68));
  border: 1px solid rgba(46,75,155,.13);
  box-shadow: 0 24px 58px rgba(18,39,80,.12), inset 0 1px 0 rgba(255,255,255,.78);
  overflow: hidden;
}

.launch-lines::before {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.42);
  pointer-events: none;
}

.launch-lines__head {
  position: relative;
  z-index: 1;
  margin-bottom: 18px;
}

.launch-lines__eyebrow {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(46,75,155,.08);
  color: var(--blue);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.launch-lines h2 {
  margin: 12px 0 0;
  font-size: clamp(1.45rem, 2.4vw, 2.15rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.launch-lines__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.launch-line {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  min-height: 72px;
  padding: 14px;
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(46,75,155,.10);
  color: var(--ink);
  overflow: hidden;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.launch-line::after {
  content: "";
  position: absolute;
  inset: auto -25% -70% auto;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.38), transparent 62%);
  pointer-events: none;
}

.launch-line:hover {
  transform: translateY(-3px) scale(1.01);
  border-color: rgba(46,75,155,.28);
  box-shadow: 0 18px 38px rgba(24,40,76,.14);
}

.launch-line__code {
  width: 54px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: 14px;
  color: #fff;
  font-weight: 950;
  letter-spacing: -.03em;
  box-shadow: inset 0 -10px 18px rgba(0,0,0,.18), 0 10px 22px rgba(20,37,79,.14);
}

.launch-line__route {
  font-size: .94rem;
  font-weight: 800;
  line-height: 1.25;
}

.launch-line__route strong {
  color: var(--red);
  padding-inline: 4px;
}

.launch-line__barge {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(46,75,155,.10);
  color: var(--blue);
  font-size: .7rem;
  font-weight: 900;
  text-transform: uppercase;
}

.launch-line--m1 .launch-line__code { background: linear-gradient(135deg, #e63335, #ff6264); }
.launch-line--m3 .launch-line__code { background: linear-gradient(135deg, #f3c300, #ffe200); color:#172044; }
.launch-line--m21 .launch-line__code { background: linear-gradient(135deg, #64c7d4, #2e9fb5); }
.launch-line--m20 .launch-line__code { background: linear-gradient(135deg, #8e44ad, #b66ad2); }
.launch-line--b1 .launch-line__code,
.launch-line--b2 .launch-line__code { background: linear-gradient(135deg, #3f4754, #111827); }

html[data-theme="dark"] .launch-lines {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,226,0,.10), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(230,51,53,.16), transparent 24%),
    linear-gradient(180deg, rgba(10,22,42,.94), rgba(14,28,52,.82));
  border-color: rgba(255,255,255,.08);
}

html[data-theme="dark"] .launch-line {
  background: rgba(255,255,255,.055);
  border-color: rgba(255,255,255,.08);
}

@media (max-width: 980px) {
  .launch-lines__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .launch-lines {
    padding: 18px;
    border-radius: 24px;
  }

  .launch-line {
    grid-template-columns: auto 1fr;
    min-height: auto;
  }

  .launch-line__barge {
    grid-column: 2;
    width: max-content;
  }

  .launch-line__code {
    width: 50px;
    height: 40px;
  }
}

.hero-grid--network-launch {
  grid-template-columns: 1.02fr .98fr;
  align-items: stretch;
}

.launch-lines {
  margin-top: 28px;
  padding: 20px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 10% 0%, rgba(255,226,0,.18), transparent 30%),
    radial-gradient(circle at 94% 14%, rgba(230,51,53,.14), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(246,249,255,.70));
  border: 1px solid rgba(46,75,155,.13);
  box-shadow: 0 24px 58px rgba(18,39,80,.12), inset 0 1px 0 rgba(255,255,255,.78);
}

.launch-lines__head {
  margin-bottom: 16px;
}

.launch-lines__eyebrow {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(46,75,155,.08);
  color: var(--blue);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.launch-lines h2 {
  margin: 10px 0 4px;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  letter-spacing: -.04em;
}

.launch-lines__head p {
  margin: 0;
  font-size: .9rem;
  color: var(--ink-soft);
}

.launch-lines__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.launch-line {
  position: relative;
  display: grid;
  grid-template-columns: 58px 1fr auto;
  align-items: center;
  gap: 10px;
  min-height: 64px;
  padding: 10px 12px;
  border-radius: 20px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(46,75,155,.10);
  overflow: hidden;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.launch-line::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,.38), transparent 78%);
  transform: translateX(-120%);
  transition: transform .65s ease;
}

.launch-line:hover {
  transform: translateY(-3px) scale(1.01);
  border-color: rgba(46,75,155,.28);
  box-shadow: 0 18px 38px rgba(24,40,76,.14);
}

.launch-line:hover::before {
  transform: translateX(120%);
}

.launch-line__icon {
  position: relative;
  z-index: 1;
  width: 54px;
  height: 42px;
  display: grid;
  place-items: center;
}

.launch-line__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 10px 16px rgba(0,0,0,.14));
}

.launch-line__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  font-size: .86rem;
  line-height: 1.2;
  font-weight: 800;
}

.launch-line__content em {
  font-style: normal;
  color: var(--red);
  font-weight: 950;
}

.launch-line__barge {
  position: relative;
  z-index: 1;
  width: 54px;
  min-width: 54px;
  padding: 5px;
  border-radius: 14px;
  background: rgba(46,75,155,.08);
  border: 1px solid rgba(46,75,155,.12);
}

.launch-line__barge img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.launch-line--maritime {
  background:
    linear-gradient(135deg, rgba(100,199,212,.16), rgba(255,255,255,.76));
}

.launch-line--barge-end {
  background:
    linear-gradient(135deg, rgba(63,71,84,.10), rgba(255,255,255,.78));
}

.hero-network-map {
  padding: 26px;
  display: grid;
  grid-template-rows: auto 1fr auto auto;
  gap: 16px;
  min-height: 640px;
  overflow: hidden;
}

.hero-network-map__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  position: relative;
  z-index: 2;
}

.hero-network-map__top span {
  padding: 9px 13px;
  border-radius: 999px;
  background: rgba(46,75,155,.10);
  color: var(--blue);
  font-size: .74rem;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.hero-network-map__top a {
  padding: 9px 14px;
  border-radius: 999px;
  background: var(--blue);
  color: #fff;
  font-size: .8rem;
  font-weight: 900;
}

.hero-network-map__frame {
  position: relative;
  z-index: 1;
  border-radius: 28px;
  padding: 12px;
  background:
    linear-gradient(135deg, rgba(46,75,155,.20), rgba(255,255,255,.78)),
    radial-gradient(circle at top right, rgba(255,226,0,.22), transparent 28%);
  border: 1px solid rgba(46,75,155,.14);
  box-shadow: 0 28px 70px rgba(18,39,80,.16);
  overflow: hidden;
}

.hero-network-map__frame::after {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.48);
  pointer-events: none;
}

.hero-network-map__frame img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  border-radius: 22px;
}

.hero-network-map__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  position: relative;
  z-index: 2;
}

.hero-network-map__note {
  display: grid;
  gap: 3px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(46,75,155,.07);
  border: 1px solid rgba(46,75,155,.10);
}

.hero-network-map__note strong {
  color: var(--blue);
  font-size: .9rem;
}

.hero-network-map__note span {
  color: var(--ink-soft);
  font-size: .86rem;
}

html[data-theme="dark"] .launch-lines,
html[data-theme="dark"] .launch-line,
html[data-theme="dark"] .hero-network-map__note {
  background: rgba(255,255,255,.055);
  border-color: rgba(255,255,255,.08);
}

@media (max-width: 1320px) {
  .hero-grid--network-launch {
    grid-template-columns: 1fr;
  }

  .hero-network-map {
    min-height: auto;
  }

  .hero-network-map__frame img {
    min-height: 520px;
  }
}

@media (max-width: 760px) {
  .launch-lines {
    padding: 16px;
    border-radius: 24px;
  }

  .launch-lines__grid {
    grid-template-columns: 1fr;
  }

  .launch-line {
    grid-template-columns: 52px 1fr;
    min-height: 58px;
  }

  .launch-line__barge {
    grid-column: 2;
    width: 68px;
  }

  .hero-network-map {
    padding: 20px;
  }

  .hero-network-map__frame img {
    min-height: 360px;
  }

  .hero-network-map__actions {
    display: grid;
  }

  .hero-network-map__actions .btn {
    width: 100%;
  }
}

.contact-card--neo {
  position: relative;
  overflow: hidden;
  padding: clamp(1rem, 2vw, 1.35rem);
  border-radius: 1.6rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(46,75,155,.18), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(246,249,255,.78));
  border: 1px solid rgba(46,75,155,.12);
}

.contact-card--neo::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.04) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.035) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 74%);
  pointer-events: none;
}

.contact-card--neo > * {
  position: relative;
  z-index: 1;
}

.neo-contact-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1rem;
}

.neo-contact-head h2 {
  margin: .25rem 0;
  font-size: clamp(1.65rem, 2.4vw, 2.5rem);
  line-height: 1;
  letter-spacing: -.05em;
}

.neo-contact-head p {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 650;
}

.neo-phone {
  display: grid;
  min-width: 210px;
  padding: .95rem 1rem;
  border-radius: 1.15rem;
  background: linear-gradient(135deg, #071326, var(--blue));
  color: #fff;
  text-decoration: none;
  box-shadow: 0 18px 42px rgba(15,23,42,.18);
}

.neo-phone strong {
  font-size: 1.25rem;
  line-height: 1;
}

.neo-phone span {
  margin-top: .25rem;
  color: rgba(255,255,255,.72);
  font-size: .76rem;
  font-weight: 850;
}

.neo-claim-form {
  display: grid;
  gap: .75rem;
}

.neo-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.neo-form-grid label,
.neo-message {
  display: grid;
  gap: .35rem;
}

.neo-form-grid span,
.neo-message span {
  font-size: .72rem;
  font-weight: 950;
  color: var(--ink-soft);
}

.neo-form-grid input,
.neo-form-grid select,
.neo-message textarea {
  width: 100%;
  border: 1px solid rgba(46,75,155,.12);
  border-radius: .9rem;
  background: rgba(255,255,255,.88);
  padding: .78rem .85rem;
  color: var(--ink);
  font-weight: 750;
  outline: none;
}

.neo-form-grid input:focus,
.neo-form-grid select:focus,
.neo-message textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(46,75,155,.10);
}

.neo-message textarea {
  resize: vertical;
  min-height: 7rem;
}

.neo-form-bottom {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .7rem;
  align-items: center;
}

.neo-upload input {
  display: none;
}

.neo-upload span {
  display: inline-flex;
  align-items: center;
  min-height: 2.8rem;
  padding: 0 .9rem;
  border-radius: .9rem;
  background: rgba(46,75,155,.08);
  border: 1px solid rgba(46,75,155,.12);
  color: var(--blue);
  font-weight: 950;
  cursor: pointer;
}

.neo-consent {
  display: flex;
  gap: .5rem;
  align-items: center;
  color: var(--ink-soft);
  font-size: .78rem;
  font-weight: 750;
}

.neo-form-bottom .btn {
  min-height: 2.8rem;
  border-radius: .9rem;
}

@media (max-width: 920px) {
  .neo-contact-head,
  .neo-form-bottom {
    grid-template-columns: 1fr;
  }

  .neo-phone {
    min-width: 0;
  }

  .neo-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .neo-form-grid {
    grid-template-columns: 1fr;
  }
}

.faq-card--compact {
  height: 100%;
  min-height: 0;
  padding: clamp(1rem, 2vw, 1.35rem);
  border-radius: 1.6rem;
  overflow: hidden;
}

.faq-compact-head {
  margin-bottom: .85rem;
}

.faq-compact-head h2 {
  margin: .25rem 0;
  font-size: clamp(1.65rem, 2.3vw, 2.4rem);
  line-height: 1;
  letter-spacing: -.05em;
}

.faq-compact-head p {
  margin: 0;
  color: var(--ink-soft);
  font-weight: 650;
}

.faq-list--compact {
  display: grid;
  gap: .55rem;
  max-height: 520px;
  overflow: auto;
  padding-right: .25rem;
}

.faq-list--compact details {
  border-radius: 1rem;
  background: rgba(46,75,155,.055);
  border: 1px solid rgba(46,75,155,.09);
  overflow: hidden;
}

.faq-list--compact summary {
  cursor: pointer;
  padding: .78rem .9rem;
  font-size: .88rem;
  font-weight: 900;
  color: var(--ink);
}

.faq-list--compact p {
  margin: 0;
  padding: 0 .9rem .85rem;
  color: var(--ink-soft);
  font-size: .82rem;
  line-height: 1.45;
  font-weight: 650;
}

.faq-contact-grid {
  align-items: stretch;
}

.faq-contact-grid > .glass-card {
  height: 100%;
}

.footer-decor-band--blue {
  margin-top: clamp(2rem, 5vw, 4rem);
  background: transparent;
  overflow: hidden;
}

.footer-decor-band--blue .footer-decor {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  min-height: 6rem;
}


.site-footer--blue {
  position: relative;
  overflow: hidden;
  padding: clamp(2.4rem, 4vw, 3.4rem) 0 1rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,226,0,.18), transparent 24%),
    linear-gradient(145deg, #071326 0%, #102b63 56%, #2e4b9b 100%);
  color: #fff;
}

.site-footer--blue::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 32px 32px;
  opacity: .55;
  pointer-events: none;
}

.site-footer--blue > * {
  position: relative;
  z-index: 1;
}

.footer-blue-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.05fr) minmax(420px, 1.45fr) minmax(180px, .55fr);
  gap: clamp(1.4rem, 3vw, 2.6rem);
  align-items: center;
}

.footer-blue-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
}

.footer-blue-logos img:first-child {
  width: min(245px, 70vw);
  height: auto;
}

.footer-blue-logos img:last-child {
  width: 92px;
  height: auto;
  filter: brightness(0) invert(1);
  opacity: .95;
}

.footer-blue-brand p,
.footer-blue-nav p {
  margin: 0;
  color: rgba(255,255,255,.74);
  line-height: 1.55;
  font-weight: 650;
}

.footer-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1rem;
}

.footer-pills span {
  padding: .48rem .7rem;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
}

.footer-blue-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.8rem);
}

.footer-blue-nav h4 {
  margin: 0 0 .85rem;
  color: #fff;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.footer-blue-nav a {
  display: table;
  margin: 0 0 .55rem;
  color: rgba(255,255,255,.76);
  text-decoration: none;
  font-size: .86rem;
  font-weight: 750;
  transition: .2s ease;
}

.footer-blue-nav a:hover {
  color: #ffe200;
  transform: translateX(4px);
}

.footer-socials {
  display: flex;
  gap: .45rem;
  margin-top: .8rem;
}

.footer-socials a {
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  font-weight: 950;
}

.footer-blue-institution {
  justify-self: end;
  display: grid;
  place-items: center;
  padding: 1rem;
  border-radius: 1.4rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.13);
}

.footer-blue-institution img {
  width: min(170px, 42vw);
  height: auto;
  filter: brightness(0) invert(1);
}

.footer-blue-bottom {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: clamp(1.6rem, 3vw, 2.4rem);
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.66);
  font-size: .76rem;
  font-weight: 750;
}

.footer-blue-bottom div {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}

.footer-blue-bottom nav {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  justify-content: flex-end;
}

.footer-blue-bottom a {
  color: rgba(255,255,255,.72);
  text-decoration: none;
}

.footer-blue-bottom a:hover {
  color: #ffe200;
}

@media (max-width: 1080px) {
  .footer-blue-grid {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .footer-blue-institution {
    justify-self: start;
  }
}

@media (max-width: 760px) {
  .footer-blue-nav {
    grid-template-columns: 1fr;
  }

  .footer-blue-bottom {
    display: grid;
  }

  .footer-blue-bottom nav {
    justify-content: flex-start;
  }
}

.site-footer--blue::before {
  display: none;
}

.footer-blue-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.25fr) repeat(3, minmax(160px, 1fr));
  gap: clamp(1.4rem, 3vw, 2.6rem);
  align-items: start;
}

.footer-blue-nav {
  display: contents;
}

.footer-blue-institution {
  display: none;
}

@media (max-width: 1080px) {
  .footer-blue-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-blue-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .footer-blue-grid {
    grid-template-columns: 1fr;
  }

  .footer-blue-brand {
    grid-column: auto;
  }
}

.footer-decor-band--blue {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow: hidden;
}

.footer-decor-band--blue .footer-decor {
  width: 100%;
}

.footer-decor-band--blue .footer-decor img {
  width: 100vw;
  max-width: none;
  height: auto;
  display: block;
}

.departures-live-shell {
  position: relative;
}

.departures-live-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}

.departures-live-clock {
  display: grid;
  justify-items: end;
  gap: .12rem;
  padding: .75rem 1rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(46,75,155,.12);
  box-shadow: 0 14px 34px rgba(15,23,42,.08);
  backdrop-filter: blur(16px);
}

.departures-live-clock strong {
  font-size: 1.25rem;
  color: var(--blue);
  line-height: 1;
}

.departures-live-clock span {
  font-size: .72rem;
  font-weight: 900;
  color: var(--ink-soft);
}

.destinations-ribbon--live {
  position: relative;
  margin-top: 1rem;
  padding: .6rem;
  border-radius: 1.35rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(46,75,155,.18), transparent 34%),
    linear-gradient(135deg, rgba(7,19,38,.96), rgba(16,35,75,.92));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 28px 70px rgba(7,19,38,.22);
  overflow: hidden;
}

.destinations-ribbon--live::before,
.destinations-ribbon--live::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 6rem;
  z-index: 2;
  pointer-events: none;
}

.destinations-ribbon--live::before {
  left: 0;
  background: linear-gradient(90deg, rgba(7,19,38,.98), transparent);
}

.destinations-ribbon--live::after {
  right: 0;
  background: linear-gradient(270deg, rgba(7,19,38,.98), transparent);
}

.destinations-ribbon--live .destinations-ribbon__track {
  display: flex;
  align-items: center;
  gap: .75rem;
  width: max-content;
  animation: liveDepartureScroll 42s linear infinite;
}

.destinations-ribbon--live:hover .destinations-ribbon__track {
  animation-play-state: paused;
}

.departure-pill {
  display: grid;
  grid-template-columns: auto minmax(220px, 1fr) auto;
  align-items: center;
  gap: .75rem;
  min-width: 420px;
  padding: .75rem .85rem;
  border-radius: 1rem;
  color: #fff;
  text-decoration: none;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--line-color) 28%, rgba(255,255,255,.08)), rgba(255,255,255,.06));
  border: 1px solid color-mix(in srgb, var(--line-color) 42%, rgba(255,255,255,.16));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  transition: .2s ease;
}

.departure-pill:hover {
  transform: translateY(-2px);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--line-color) 42%, rgba(255,255,255,.1)), rgba(255,255,255,.1));
}

.departure-pill__code {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: .9rem;
  background: var(--line-color);
  color: #fff;
  font-size: 1rem;
  font-weight: 950;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--line-color) 36%, transparent);
}

.departure-pill__content {
  display: grid;
  gap: .18rem;
  min-width: 0;
}

.departure-pill__content strong {
  font-size: .9rem;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.departure-pill__content small {
  color: rgba(255,255,255,.68);
  font-size: .7rem;
  font-weight: 800;
}

.departure-pill__time {
  display: grid;
  justify-items: end;
  gap: .1rem;
}

.departure-pill__time strong {
  font-size: 1.25rem;
  line-height: 1;
}

.departure-pill__time small {
  font-size: .68rem;
  font-weight: 900;
  color: #ffe200;
  white-space: nowrap;
}

.departure-pill--empty {
  min-width: 360px;
}

@keyframes liveDepartureScroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (max-width: 760px) {
  .departures-live-heading {
    display: grid;
  }

  .departures-live-clock {
    justify-items: start;
  }

  .departure-pill {
    min-width: 320px;
    grid-template-columns: auto 1fr;
  }

  .departure-pill__time {
    grid-column: 1 / -1;
    grid-template-columns: auto auto;
    justify-content: space-between;
    justify-items: start;
    padding-top: .45rem;
    border-top: 1px solid rgba(255,255,255,.12);
  }
}

.move-page{
  position:relative;
  overflow:hidden;
}

.move-hero{
  position:relative;
  padding:clamp(3rem,7vw,6rem) 0 clamp(2rem,4vw,3.6rem);
  background:
    radial-gradient(circle at 12% 10%, rgba(46,75,155,.18), transparent 28%),
    radial-gradient(circle at 85% 8%, rgba(255,226,0,.2), transparent 18%),
    linear-gradient(180deg,#f8fbff 0%,#edf5ff 100%);
}

.move-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:7rem;
  background:url("../img/brand/decor-long.png") center/cover no-repeat;
  opacity:.18;
  pointer-events:none;
}

.move-hero__grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);
  gap:clamp(1.4rem,3vw,2.8rem);
  align-items:center;
}

.move-hero__content h1{
  max-width:850px;
  margin:.7rem 0 1rem;
  font-size:clamp(2.6rem,5.4vw,5.8rem);
  line-height:.92;
  letter-spacing:-.07em;
}

.move-hero__content p{
  max-width:700px;
  color:#475569;
  font-size:clamp(1rem,1.25vw,1.2rem);
  line-height:1.6;
  font-weight:650;
}

.move-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1.5rem;
}

.move-hero__panel{
  position:relative;
  overflow:hidden;
  padding:2rem;
  min-height:360px;
  display:grid;
  align-content:end;
  border-radius:2rem;
  background:
    radial-gradient(circle at 50% 0%, rgba(46,75,155,.25), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.88), rgba(241,245,249,.72));
}

.move-orbit{
  position:absolute;
  inset:1.2rem;
  border:1px solid rgba(46,75,155,.16);
  border-radius:2rem;
}

.move-orbit span{
  position:absolute;
  display:grid;
  place-items:center;
  width:3.5rem;
  height:3.5rem;
  border-radius:1.2rem;
  background:white;
  box-shadow:0 18px 42px rgba(15,23,42,.12);
  font-size:1.5rem;
}

.move-orbit span:nth-child(1){top:12%;left:12%}
.move-orbit span:nth-child(2){top:20%;right:14%}
.move-orbit span:nth-child(3){bottom:22%;left:18%}
.move-orbit span:nth-child(4){bottom:16%;right:18%}

.move-hero__panel strong{
  font-size:1.7rem;
  letter-spacing:-.04em;
}

.move-hero__panel p{
  color:#64748b;
  line-height:1.5;
}

.move-hero__kpis{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.65rem;
  margin-top:1rem;
}

.move-hero__kpis span{
  padding:.8rem;
  border-radius:1rem;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(226,232,240,.9);
  font-size:.72rem;
  font-weight:800;
  color:#64748b;
}

.move-hero__kpis strong{
  display:block;
  font-size:1rem;
  color:#111827;
}

.move-shortcuts{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}

.move-shortcuts a,
.move-info-grid article{
  position:relative;
  overflow:hidden;
  padding:1.25rem;
  border-radius:1.5rem;
  text-decoration:none;
  color:#111827;
  background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(248,250,252,.75));
  border:1px solid rgba(226,232,240,.9);
  box-shadow:0 18px 44px rgba(15,23,42,.08);
  transition:.2s ease;
}

.move-shortcuts a:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 70px rgba(15,23,42,.14);
}

.move-shortcuts i,
.move-info-grid i{
  display:grid;
  place-items:center;
  width:3rem;
  height:3rem;
  border-radius:1rem;
  background:linear-gradient(135deg,var(--blue),#51beca);
  color:#fff;
  font-style:normal;
  font-size:1.35rem;
  margin-bottom:.8rem;
}

.move-shortcuts strong,
.move-info-grid h3{
  display:block;
  margin:0 0 .35rem;
  font-size:1.05rem;
}

.move-shortcuts span,
.move-info-grid p{
  color:#64748b;
  font-size:.88rem;
  line-height:1.45;
}

.move-map-module{
  display:grid;
  grid-template-columns:290px minmax(0,1fr) 330px;
  gap:1rem;
  padding:1rem;
  border-radius:2rem;
}

.move-map-lines,
.move-map-detail{
  min-height:680px;
  overflow:hidden;
  border-radius:1.5rem;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(226,232,240,.9);
  padding:1rem;
}

.move-map-main{
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
  min-height:680px;
}

.move-map-stage{
  min-height:640px;
  border-radius:1.5rem;
}

.timetable-shell{
  position:relative;
}

.timetable-command--neo{
  overflow:hidden;
  padding:clamp(1rem,2vw,1.5rem);
  border-radius:2rem;
  background:
    radial-gradient(circle at 14% 0%, rgba(46,75,155,.16), transparent 32%),
    linear-gradient(145deg,rgba(255,255,255,.94),rgba(248,250,252,.76));
}

.timetable-command__hero--neo{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  align-items:end;
  padding:1rem;
}

.timetable-command__hero--neo h2{
  margin:.4rem 0;
  font-size:clamp(1.8rem,3vw,3.2rem);
  line-height:1;
  letter-spacing:-.055em;
}

.timetable-command__hero--neo p{
  max-width:760px;
  color:#64748b;
  line-height:1.55;
}

.timetable-command__stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.6rem;
}

.timetable-command__stats span{
  min-width:110px;
  padding:.85rem;
  border-radius:1rem;
  background:rgba(15,23,42,.92);
  color:rgba(255,255,255,.68);
  font-size:.7rem;
  font-weight:850;
}

.timetable-command__stats strong{
  display:block;
  color:#fff;
  font-size:.95rem;
}

.timetable-command__search--neo{
  display:grid;
  grid-template-columns:1.2fr .8fr auto;
  gap:.8rem;
  margin:1rem 0 1.3rem;
  padding:1rem;
  border-radius:1.4rem;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(226,232,240,.95);
}

.timetable-field{
  display:grid;
  gap:.4rem;
}

.timetable-field label{
  font-size:.75rem;
  font-weight:900;
  color:#475569;
}

.timetable-searchbox,
.timetable-field select{
  min-height:3.15rem;
  border-radius:1rem;
  border:1px solid rgb(29 29 29 / 21%);
  background:rgba(255,255,255,.08);
  color:white;
}

.timetable-searchbox{
  display:grid;
  grid-template-columns:2.6rem 1fr;
  align-items:center;
  padding:0 .8rem;
}

.timetable-searchbox span{
  color:var(--blue);
  font-size:1.35rem;
}

.timetable-searchbox input,
.timetable-field select{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  font-weight:750;
  color:#111827;
}

.timetable-command__grid--neo{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}

.timetable-card--neo{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:1rem;
  padding:1rem;
  border-radius:1.4rem;
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb,var(--line-color) 18%, transparent), transparent 34%),
    linear-gradient(145deg,rgba(255,255,255,.96),rgba(248,250,252,.82));
  border:1px solid color-mix(in srgb,var(--line-color) 22%,rgba(226,232,240,1));
  box-shadow:0 18px 44px rgba(15,23,42,.08);
}

.timetable-card__line{
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  background:var(--line-color);
}

.timetable-card__top{
  display:flex;
  align-items:center;
  gap:.75rem;
}

.timetable-card__icon{
  display:grid;
  place-items:center;
  width:3.6rem;
  height:3.6rem;
  border-radius:1.1rem;
  background:color-mix(in srgb,var(--line-color) 12%,white);
}

.timetable-card__icon img{
  width:2.5rem;
  height:2.5rem;
  object-fit:contain;
}

.timetable-card__top span{
  font-size:.75rem;
  font-weight:900;
  color:#64748b;
}

.timetable-card__top h3{
  margin:0;
  font-size:1.7rem;
  letter-spacing:-.05em;
}

.timetable-card__body strong{
  display:block;
  font-size:1rem;
  line-height:1.25;
}

.timetable-card__body p{
  margin:.35rem 0 0;
  color:#64748b;
  font-size:.85rem;
}

.timetable-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
}

.timetable-card__meta span{
  padding:.35rem .55rem;
  border-radius:999px;
  background:rgba(241,245,249,.95);
  border:1px solid rgba(226,232,240,.95);
  font-size:.68rem;
  font-weight:900;
  color:#475569;
}

.timetable-card__actions--icons{
  display:flex;
  justify-content:flex-end;
  gap:.55rem;
}

.timetable-icon-action{
  display:grid;
  place-items:center;
  width:2.75rem;
  height:2.75rem;
  border-radius:1rem;
  text-decoration:none;
  font-size:1.35rem;
  font-weight:950;
  color:#fff;
  background:rgba(15,23,42,.92);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 14px 30px rgba(15,23,42,.16);
  transition:.2s ease;
}

.timetable-icon-action:hover{
  transform:translateY(-3px) scale(1.04);
}

.timetable-icon-action.is-download{
  background:linear-gradient(135deg,var(--line-color),#111827);
}

.timetable-icon-action.is-map{
  color:var(--line-color);
  background:rgba(255,255,255,.86);
  border-color:color-mix(in srgb,var(--line-color) 32%,rgba(226,232,240,1));
}

.route-planner{
  display:grid;
  grid-template-columns:.75fr 1.25fr;
  gap:1.2rem;
  padding:1.4rem;
  border-radius:2rem;
  background:
    radial-gradient(circle at 100% 0%,rgba(81,190,202,.16),transparent 34%),
    linear-gradient(145deg,rgba(255,255,255,.94),rgba(248,250,252,.78));
}

.route-planner__intro h2{
  margin:.4rem 0;
  font-size:clamp(1.8rem,3vw,3rem);
  line-height:1;
  letter-spacing:-.055em;
}

.route-planner__intro p{
  color:#64748b;
  line-height:1.55;
}

.route-planner__form{
  display:grid;
  gap:.85rem;
}

.route-planner__field{
  display:grid;
  gap:.4rem;
}

.route-planner__field label,
.route-planner__options span{
  font-size:.74rem;
  font-weight:900;
  color:#475569;
}

.route-planner__field div{
  display:grid;
  grid-template-columns:2.8rem 1fr;
  align-items:center;
  min-height:3.4rem;
  padding:0 .8rem;
  border-radius:1.1rem;
  background:white;
  border:1px solid rgba(226,232,240,.95);
}

.route-planner__field input,
.route-planner__options input,
.route-planner__options select{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  font-weight:750;
}

.route-planner__swap{
  justify-self:center;
  width:2.8rem;
  height:2.8rem;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,var(--blue),#51beca);
  color:#fff;
  font-size:1.3rem;
  cursor:pointer;
}

.route-planner__options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.75rem;
}

.route-planner__options label{
  display:grid;
  gap:.35rem;
  padding:.8rem;
  border-radius:1rem;
    background: #ffffff12;
    border: 1px solid rgb(226 232 240 / 9%);
}

.route-planner__actions{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem;
}

.route-planner__preview{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.8rem;
}

.route-planner__preview article{
  padding:1rem;
  border-radius:1.2rem;
  background:rgba(15,23,42,.92);
  color:white;
}

.route-planner__preview span{
  color:#ffe200;
  font-weight:950;
}

.route-planner__preview p{
  margin:.3rem 0 0;
  color:rgba(255,255,255,.72);
}

.move-info-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}

@media (max-width:1180px){
  .move-map-module{
    grid-template-columns:1fr;
  }

  .move-map-lines,
  .move-map-detail,
  .move-map-main{
    min-height:auto;
  }

  .move-map-stage{
    min-height:560px;
  }

  .timetable-command__grid--neo{
    grid-template-columns:repeat(2,1fr);
  }

  .move-shortcuts,
  .move-info-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:820px){
  .move-hero__grid,
  .route-planner{
    grid-template-columns:1fr;
  }

  .move-hero__panel{
    min-height:300px;
  }

  .timetable-command__hero--neo,
  .timetable-command__search--neo{
    grid-template-columns:1fr;
  }

  .timetable-command__stats{
    grid-template-columns:1fr;
  }

  .timetable-command__grid--neo,
  .route-planner__options,
  .route-planner__preview{
    grid-template-columns:1fr;
  }

  .move-map-stage{
    min-height:460px;
  }
}

@media (max-width:560px){
  .move-shortcuts,
  .move-info-grid{
    grid-template-columns:1fr;
  }

  .move-hero__kpis{
    grid-template-columns:1fr;
  }

  .move-hero__content h1{
    font-size:2.45rem;
  }
}


/* =========================================================
   PAGE TITRES & ABONNEMENTS — M'SAFARA
========================================================= */

.fares-page{
  position:relative;
  overflow:hidden;
}

/* =========================================================
   HERO
========================================================= */

.fares-hero{
  position:relative;
  padding:
    clamp(5.5rem,8vw,8rem)
    0
    clamp(2rem,4vw,4rem);
  z-index:2;
}

.fares-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 12% 18%, rgba(46,75,155,.16), transparent 30%),
    radial-gradient(circle at 88% 12%, rgba(227,6,19,.14), transparent 26%);
  pointer-events:none;
}

.fares-hero__grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) 420px;
  gap:2rem;
  align-items:center;
}

.fares-hero__content h1{
  margin:.8rem 0 1rem;
  max-width:780px;
  font-size:clamp(3rem,5vw,5.2rem);
  line-height:.95;
  letter-spacing:-.05em;
}

.fares-hero__content p{
  max-width:760px;
  color:#5c6b84;
  font-size:1.05rem;
  line-height:1.7;
}

.fares-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
  margin-top:1.8rem;
}

/* =========================================================
   HERO CARD
========================================================= */

.fares-hero__card{
  position:relative;
  overflow:hidden;
  padding:1.4rem;
  border-radius:2rem;
  background:
    linear-gradient(145deg,
      rgba(9,21,44,.98),
      rgba(15,33,64,.92)
    );
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 40px 90px rgba(2,6,23,.28);
  color:#fff;
}

.fares-hero__card::before{
  content:"";
  position:absolute;
  inset:-30%;
  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,.08), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(46,75,155,.35), transparent 24%);
  pointer-events:none;
}

.fares-hero__card > *{
  position:relative;
  z-index:1;
}

.fares-hero__card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.fares-hero__logos{
  display:flex;
  align-items:center;
  gap:.9rem;
}

.fares-hero__logos img{
  height:48px;
  width:auto;
  object-fit:contain;
}

.fares-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.45rem .8rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.fares-hero__card strong{
  display:block;
  margin-top:1.2rem;
  font-size:1.3rem;
  line-height:1.2;
}

.fares-hero__card p{
  margin:.6rem 0 0;
  color:rgba(255,255,255,.72);
  line-height:1.6;
}

.fares-hero__stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.7rem;
  margin-top:1.5rem;
}

.fares-hero__stats span{
  display:grid;
  gap:.2rem;
  padding:.85rem;
  border-radius:1rem;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
}

.fares-hero__stats strong{
  margin:0;
  font-size:1.15rem;
}

/* =========================================================
   SHORTCUTS
========================================================= */

.fares-shortcuts{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}

.fares-shortcuts a{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:.55rem;
  padding:1.3rem;
  border-radius:1.5rem;
  text-decoration:none;
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.88),
      rgba(248,250,255,.72)
    );
  border:1px solid rgba(46,75,155,.08);
  box-shadow:
    0 20px 45px rgba(15,23,42,.06);
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease;
}

.fares-shortcuts a:hover{
  transform:translateY(-4px);
  border-color:rgba(46,75,155,.22);
  box-shadow:
    0 28px 70px rgba(15,23,42,.1);
}

.fares-shortcuts i{
  width:3.1rem;
  height:3.1rem;
  display:grid;
  place-items:center;
  border-radius:1rem;
  background:
    linear-gradient(145deg,#2e4b9b,#4f72d8);
  color:#fff;
  font-size:1.25rem;
  font-style:normal;
  box-shadow:
    0 18px 34px rgba(46,75,155,.22);
}

.fares-shortcuts strong{
  color:#091833;
  font-size:1rem;
}

.fares-shortcuts span{
  color:#64748b;
  line-height:1.5;
  font-size:.9rem;
}

/* =========================================================
   MODULES
========================================================= */

.fares-module{
  position:relative;
  overflow:hidden;
  padding:1.7rem;
  border-radius:2rem;
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.92),
      rgba(248,250,255,.82)
    );
  border:1px solid rgba(46,75,155,.08);
  box-shadow:
    0 30px 80px rgba(15,23,42,.08);
}

.fares-module::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(15,23,42,.03) 1px, transparent 1px),
    linear-gradient(180deg, rgba(15,23,42,.03) 1px, transparent 1px);
  background-size:28px 28px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.6), transparent 80%);
  pointer-events:none;
}

.fares-module > *{
  position:relative;
  z-index:1;
}

.fares-module__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:2rem;
  margin-bottom:1.5rem;
}

.fares-module__top h2{
  margin:.5rem 0;
  font-size:clamp(2rem,3vw,3rem);
  letter-spacing:-.04em;
}

.fares-module__top p{
  max-width:760px;
  color:#64748b;
  line-height:1.7;
}

.fares-module__cta{
  white-space:nowrap;
}

/* =========================================================
   TABS
========================================================= */

.fares-tabs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-bottom:1.5rem;
}

.fares-tabs button{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:.55rem;
  align-content:start;
  min-height:170px;
  padding:1rem;
  border:none;
  border-radius:1.5rem;
  cursor:pointer;
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.9),
      rgba(245,248,255,.72)
    );
  border:1px solid rgba(46,75,155,.08);
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    border-color .2s ease;
}

.fares-tabs button:hover{
  transform:translateY(-4px);
}

.fares-tabs button.is-active{
  border-color:rgba(46,75,155,.24);
  box-shadow:
    0 26px 60px rgba(15,23,42,.1);
}

.fares-tabs button::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  background:var(--tab-color,#2e4b9b);
}

.fares-tabs button img{
  width:64px;
  height:64px;
  object-fit:contain;
  filter:drop-shadow(0 12px 20px rgba(0,0,0,.14));
}

.fares-tabs button strong{
  color:#091833;
  font-size:.95rem;
}

.fares-tabs button small{
  color:#64748b;
  line-height:1.4;
}

.fares-tabs button span{
  display:inline-flex;
  width:fit-content;
  padding:.3rem .55rem;
  border-radius:999px;
  background:rgba(46,75,155,.08);
  color:#2e4b9b;
  font-size:.68rem;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* =========================================================
   PANEL
========================================================= */

.fares-panel{
  display:none;
}

.fares-panel.is-active{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
  gap:1.5rem;
  animation:farePanelIn .3s ease;
}

@keyframes farePanelIn{
  from{
    opacity:0;
    transform:translateY(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.fares-panel__visual{
  position:relative;
  overflow:hidden;
  border-radius:2rem;
  min-height:420px;
  padding:1.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,.18), transparent 30%),
    linear-gradient(145deg,#0b1d39,#16325f);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 30px 80px rgba(15,23,42,.18);
}

.fares-panel__visual img{
  max-width:88%;
  max-height:320px;
  object-fit:contain;
  filter:drop-shadow(0 28px 50px rgba(0,0,0,.35));
}

.fares-panel__content{
  display:grid;
  gap:1rem;
  align-content:start;
}

.fares-panel__content h3{
  margin:0;
  font-size:clamp(2rem,3vw,3rem);
  line-height:1;
  letter-spacing:-.05em;
}

.fares-panel__content p{
  color:#5c6b84;
  line-height:1.7;
}

.fares-kicker{
  display:inline-flex;
  width:fit-content;
  padding:.42rem .8rem;
  border-radius:999px;
  background:rgba(46,75,155,.08);
  color:#2e4b9b;
  font-size:.72rem;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* =========================================================
   PRICE GRID
========================================================= */

.fares-price-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}

.fares-price-grid span{
  display:grid;
  gap:.25rem;
  padding:1rem;
  border-radius:1.25rem;
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.94),
      rgba(244,247,255,.84)
    );
  border:1px solid rgba(46,75,155,.08);
}

.fares-price-grid strong{
  font-size:1.55rem;
  color:#091833;
}

/* =========================================================
   PROFILES
========================================================= */

.fares-profiles{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}

.fares-profile{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:1rem;
  align-items:center;
  padding:1rem;
  border-radius:1.4rem;
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.94),
      rgba(245,248,255,.82)
    );
  border:1px solid rgba(46,75,155,.08);
}

.fares-profile img{
  width:72px;
  height:72px;
  object-fit:contain;
}

.fares-profile strong{
  display:block;
  margin-bottom:.3rem;
  color:#091833;
}

.fares-profile span{
  color:#64748b;
  line-height:1.5;
  font-size:.9rem;
}

/* =========================================================
   ACTIONS
========================================================= */

.fares-actions{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  margin-top:.5rem;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width:1280px){

  .fares-tabs{
    grid-template-columns:repeat(2,1fr);
  }

  .fares-panel.is-active{
    grid-template-columns:1fr;
  }

  .fares-panel__visual{
    min-height:320px;
  }
}

@media (max-width:980px){

  .fares-hero__grid{
    grid-template-columns:1fr;
  }

  .fares-shortcuts{
    grid-template-columns:repeat(2,1fr);
  }

  .fares-module__top{
    flex-direction:column;
  }
}

@media (max-width:720px){

  .fares-tabs{
    grid-template-columns:1fr;
  }

  .fares-shortcuts{
    grid-template-columns:1fr;
  }

  .fares-profiles{
    grid-template-columns:1fr;
  }

  .fares-price-grid{
    grid-template-columns:1fr;
  }

  .fares-hero__stats{
    grid-template-columns:1fr;
  }

  .fares-panel__visual{
    min-height:260px;
  }

  .fares-module{
    padding:1.2rem;
    border-radius:1.5rem;
  }
}

/* ===============================
   FIX MODULE CATALOGUE TARIFAIRE
================================ */

.fare-command {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 2vw, 2rem);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(46, 75, 155, .14), transparent 28%),
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(246,249,255,.9));
}

.fare-command__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: start;
  margin-bottom: 1.4rem;
}

.fare-command__head h2 {
  margin: .35rem 0 .45rem;
  max-width: 760px;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1;
  letter-spacing: -.05em;
}

.fare-command__head p {
  max-width: 700px;
  color: #64748b;
  line-height: 1.65;
}

.fare-command__cta {
  white-space: nowrap;
}

.fare-tabs--visual {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.fare-tabs--visual button {
  position: relative;
  overflow: hidden;
  min-height: 190px;
  padding: 1rem;
  display: grid;
  gap: .45rem;
  align-content: start;
  text-align: left;
  border: 1px solid rgba(46,75,155,.12);
  border-radius: 1.45rem;
  background: linear-gradient(145deg, #fff, #f5f8ff);
  cursor: pointer;
  box-shadow: 0 18px 45px rgba(15,23,42,.07);
  transition: .25s ease;
}

.fare-tabs--visual button:hover,
.fare-tabs--visual button.is-active {
  transform: translateY(-4px);
  border-color: rgba(46,75,155,.28);
  box-shadow: 0 28px 70px rgba(15,23,42,.12);
}

.fare-tabs--visual button span {
  width: fit-content;
  padding: .28rem .55rem;
  border-radius: 999px;
  background: #edf3ff;
  color: #2e4b9b;
  font-size: .68rem;
  font-weight: 950;
}

.fare-tabs--visual button img {
  width: 100%;
  height: 82px;
  object-fit: contain;
  margin: .2rem 0;
  filter: drop-shadow(0 14px 24px rgba(15,23,42,.18));
}

.fare-tabs--visual button strong {
  color: #091833;
  font-size: .98rem;
}

.fare-tabs--visual button small {
  color: #64748b;
  font-weight: 700;
}

.fare-panels {
  position: relative;
}

.fare-panel {
  display: none;
}

.fare-panel.is-active {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 1.5rem;
  align-items: stretch;
}

.fare-panel__visual {
  min-height: 380px;
  padding: 1.5rem;
  display: grid;
  place-items: center;
  border-radius: 1.7rem;
  background: linear-gradient(145deg, #0d2348, #183c7a);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14);
}

.fare-panel__visual--red {
  background: linear-gradient(145deg, #e30613, #102a5c);
}

.fare-panel__visual--yellow {
  background: linear-gradient(145deg, #ffe8a3, #2e4b9b);
}

.fare-panel__visual--blue {
  background: linear-gradient(145deg, #2e4b9b, #071326);
}

.fare-panel__visual--vehicle {
  background: linear-gradient(145deg, #2e4b9b, #11315f);
}

.fare-panel__visual img {
  max-width: 92%;
  max-height: 290px;
  object-fit: contain;
  filter: drop-shadow(0 26px 45px rgba(0,0,0,.35));
}

.fare-panel__content {
  padding: clamp(1rem, 2vw, 1.5rem);
  border-radius: 1.7rem;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(46,75,155,.1);
}

.fare-kicker {
  display: inline-flex;
  width: fit-content;
  padding: .38rem .75rem;
  border-radius: 999px;
  background: rgba(46,75,155,.09);
  color: #2e4b9b;
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.fare-panel__content h3 {
  margin: .7rem 0 .7rem;
  font-size: clamp(1.8rem, 2.6vw, 2.8rem);
  line-height: 1;
  letter-spacing: -.045em;
}

.fare-panel__content p {
  color: #64748b;
  line-height: 1.65;
}

.fare-price-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
  margin: 1.2rem 0;
}

.fare-price-grid span {
  display: grid;
  gap: .25rem;
  padding: 1rem;
  border-radius: 1.1rem;
  background: #fff;
  border: 1px solid rgba(46,75,155,.1);
}

.fare-price-grid strong {
  color: #091833;
  font-size: 1.5rem;
}

.fare-profile-list--visual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
  margin: 1.2rem 0;
}

.fare-profile-list--visual div {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: .8rem;
  align-items: center;
  padding: .9rem;
  border-radius: 1.1rem;
  background: #fff;
  border: 1px solid rgba(46,75,155,.1);
}

.fare-profile-list--visual img {
  width: 58px;
  height: 58px;
  object-fit: contain;
}

.fare-profile-list--visual strong,
.fare-profile-list--visual span {
  grid-column: 2;
}

.fare-profile-list--visual strong {
  color: #091833;
}

.fare-profile-list--visual span {
  color: #64748b;
  font-size: .88rem;
  line-height: 1.45;
}

.fare-note-box {
  margin: 1.2rem 0;
  padding: 1rem;
  border-radius: 1.2rem;
  background: #fff7d6;
  border: 1px solid rgba(250, 180, 0, .25);
}

.fare-note-box strong {
  color: #091833;
}

.fare-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.2rem;
}

@media (max-width: 1100px) {
  .fare-tabs--visual {
    grid-template-columns: repeat(2, 1fr);
  }

  .fare-panel.is-active {
    grid-template-columns: 1fr;
  }

  .fare-panel__visual {
    min-height: 300px;
  }
}

@media (max-width: 720px) {
  .fare-command__head {
    grid-template-columns: 1fr;
  }

  .fare-tabs--visual,
  .fare-price-grid,
  .fare-profile-list--visual {
    grid-template-columns: 1fr;
  }

  .fare-tabs--visual button {
    min-height: auto;
  }

  .fare-tabs--visual button img {
    height: 70px;
  }

  .fare-panel__visual {
    min-height: 240px;
  }

  .fare-panel__content {
    padding: 1rem;
  }
}

/* ===============================
   PAGE INFOS PRATIQUES
================================ */

.info-page {
  position: relative;
}

.info-hero .move-hero__panel {
  min-height: 360px;
}

.info-news-grid,
.info-service-grid,
.info-status-grid {
  display: grid;
  gap: 1rem;
}

.info-news-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.info-news-card {
  padding: 1.4rem;
  border-radius: 1.5rem;
}

.info-news-card span,
.info-news-card small {
  color: #2e4b9b;
  font-weight: 900;
}

.info-news-card h3 {
  margin: .7rem 0;
  font-size: 1.25rem;
}

.info-news-card p {
  color: #64748b;
  line-height: 1.55;
}

.info-traffic-card {
  padding: clamp(1.3rem, 2.5vw, 2rem);
  border-radius: 2rem;
  display: grid;
  gap: 1.4rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(46,75,155,.16), transparent 32%),
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(245,248,255,.92));
}

.info-status-grid {
  grid-template-columns: repeat(3, 1fr);
}

.info-status-grid article,
.info-service-card {
  padding: 1.2rem;
  border-radius: 1.3rem;
  background: #fff;
  border: 1px solid rgba(46,75,155,.1);
  box-shadow: 0 18px 45px rgba(15,23,42,.06);
}

.info-status-grid i,
.info-service-card i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  margin-bottom: .8rem;
  border-radius: 1rem;
  background: #edf3ff;
  color: #2e4b9b;
  font-style: normal;
  font-weight: 950;
}

.info-status-grid strong,
.info-service-card h3 {
  display: block;
  color: #091833;
  margin-bottom: .35rem;
}

.info-status-grid span,
.info-service-card p {
  color: #64748b;
  line-height: 1.5;
}

.info-traffic-actions,
.info-final-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}

.info-service-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.faq-contact-grid--compact {
  align-items: stretch;
}

.faq-card--compact,
.contact-card--neo {
  height: 100%;
}

.faq-list--compact {
  display: grid;
  gap: .7rem;
}

.faq-list--compact details {
  padding: .85rem 1rem;
  border-radius: 1rem;
}

.contact-hotline {
  width: 100%;
  display: grid;
  gap: .15rem;
  margin-bottom: 1rem;
  padding: 1rem;
  border-radius: 1.2rem;
  background: linear-gradient(135deg, #2e4b9b, #071326);
  color: #fff;
}

.contact-hotline strong {
  font-size: 1.5rem;
}

.contact-hotline span {
  color: rgba(255,255,255,.76);
}

.claim-form {
  display: grid;
  gap: .9rem;
}

.claim-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
}

.claim-form label {
  display: grid;
  gap: .35rem;
  color: #091833;
  font-weight: 800;
}

.claim-form input,
.claim-form select,
.claim-form textarea {
  width: 100%;
  border: 1px solid rgba(46,75,155,.14);
  border-radius: .95rem;
  padding: .82rem .95rem;
  background: rgba(255,255,255,.9);
  color: #091833;
  outline: none;
}

.claim-form textarea {
  resize: vertical;
}

.info-final-card {
  padding: clamp(1.4rem, 3vw, 2.2rem);
  border-radius: 2rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: center;
  background:
    radial-gradient(circle at 0% 0%, rgba(227,6,19,.12), transparent 30%),
    linear-gradient(145deg, #fff, #f5f8ff);
}

@media (max-width: 1050px) {
  .info-news-grid,
  .info-status-grid,
  .info-service-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .info-final-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .info-news-grid,
  .info-status-grid,
  .info-service-grid,
  .claim-form__grid {
    grid-template-columns: 1fr;
  }
}


.move-shortcuts--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.move-shortcuts--three a {
  min-height: 190px;
  position: relative;
  overflow: hidden;
}

.move-shortcuts--three a i {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: clamp(5rem, 10vw, 9rem);
  opacity: 0.13;
  transform: scale(1.08);
  pointer-events: none;
}

.move-shortcuts--three a strong,
.move-shortcuts--three a span {
  position: relative;
  z-index: 1;
}



.hero-section--move-map .section-heading {
  margin-bottom: 2rem;
}

.hero-section--move-map .hero-network-layout {
  align-items: stretch;
}

@media (max-width: 980px) {
  .move-shortcuts--three {
    grid-template-columns: 1fr;
  }

  .move-shortcuts--three a {
    min-height: 150px;
  }
}

.move-live-board {
  padding: 0;
  overflow: hidden;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  background:
    radial-gradient(circle at top left, rgba(81, 190, 202, .22), transparent 34%),
    radial-gradient(circle at bottom right, rgba(227, 6, 19, .18), transparent 34%),
    linear-gradient(145deg, rgba(4, 20, 48, .96), rgba(8, 33, 76, .92));
  color: #fff;
}

.move-live-board__top {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.2rem;
  align-items: center;
}

.move-live-board__top strong {
  display: block;
  font-size: 1.25rem;
  letter-spacing: -.03em;
}

.move-live-board__clock {
  text-align: right;
  padding: .7rem .9rem;
  border-radius: 18px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
}

.move-live-board__clock strong {
  font-size: 1.35rem;
  line-height: 1;
}

.move-live-board__clock span,
.move-live-board__top .eyebrow {
  color: rgba(255,255,255,.68);
}

.move-live-board__screen {
  position: relative;
  margin: 0 1.1rem;
  padding: .7rem;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.05)),
    rgba(2, 10, 28, .74);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 0 45px rgba(81,190,202,.12);
  overflow: hidden;
  flex: 1;
}

.move-live-board__scan {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(81,190,202,.12),
    transparent
  );
  height: 34%;
  animation: boardScan 4s linear infinite;
  pointer-events: none;
}

@keyframes boardScan {
  from { transform: translateY(-120%); }
  to { transform: translateY(320%); }
}

.move-live-board__head {
  display: grid;
  grid-template-columns: 72px 1fr 92px;
  gap: .7rem;
  padding: .55rem .7rem .75rem;
  color: rgba(255,255,255,.52);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.move-live-board__rows {
  display: grid;
  gap: .55rem;
}

.move-live-row {
  display: grid;
  grid-template-columns: 72px 1fr 92px;
  gap: .7rem;
  align-items: center;
  padding: .72rem;
  border-radius: 18px;
  color: #fff;
  text-decoration: none;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--line-color) 24%, transparent), rgba(255,255,255,.06));
  border: 1px solid rgba(255,255,255,.13);
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.move-live-row:hover {
  transform: translateX(4px) scale(1.01);
  border-color: rgba(255,255,255,.34);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--line-color) 38%, transparent), rgba(255,255,255,.1));
}

.move-live-row__code {
  width: 52px;
  height: 42px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  font-weight: 950;
  background: var(--line-color);
  box-shadow: 0 10px 26px color-mix(in srgb, var(--line-color) 42%, transparent);
}

.move-live-row__destination {
  min-width: 0;
}

.move-live-row__destination strong {
  display: block;
  font-size: .92rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.move-live-row__destination small,
.move-live-row__time small {
  color: rgba(255,255,255,.62);
  font-size: .73rem;
}

.move-live-row__time {
  text-align: right;
}

.move-live-row__time strong {
  display: block;
  font-size: 1.05rem;
}

.move-live-row--loading {
  grid-template-columns: 42px 1fr;
  color: rgba(255,255,255,.75);
}

.move-live-board__actions {
  display: flex;
  gap: .5rem;
  padding: 1rem 1.1rem 1.15rem;
  flex-wrap: wrap;
}

.move-live-board__actions button,
.move-live-board__actions a {
  border: 0;
  border-radius: 999px;
  padding: .68rem .9rem;
  background: rgba(255,255,255,.1);
  color: #fff;
  text-decoration: none;
  font-weight: 850;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,.15);
}

.move-live-board__actions button.is-active,
.move-live-board__actions button:hover,
.move-live-board__actions a:hover {
  background: #fff;
  color: #10234a;
}

@media (max-width: 720px) {
  .move-live-board__head,
  .move-live-row {
    grid-template-columns: 58px 1fr 76px;
  }

  .move-live-row__code {
    width: 44px;
    height: 38px;
  }

  .move-live-row__destination strong {
    font-size: .82rem;
  }
}

.move-live-board__screen {
  max-height: 520px;
}

.move-live-board__rows {
  max-height: 430px;
  overflow-y: auto;
  padding-right: .35rem;
}

.move-live-board__rows::-webkit-scrollbar {
  width: 8px;
}

.move-live-board__rows::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(255,255,255,.28);
}

.move-live-board__rows::-webkit-scrollbar-track {
  background: rgba(255,255,255,.06);
  border-radius: 999px;
}

@media (max-width: 720px) {
  .move-live-board__screen {
    max-height: 460px;
  }

  .move-live-board__rows {
    max-height: 360px;
  }
}

.fares-hero-showcase {
  position: relative;
  min-height: 430px;
  padding: 0;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(232,241,255,.96));
}

.fare-showcase-bottom {
  display: none !important;
}

.fare-showcase-slider {
  position: absolute;
  inset: 0;
}

.fare-showcase-slide {
  position: absolute;
  inset: 0;
  padding: 0;
  opacity: 0;
  animation: fareHeroShow 12s infinite;
  overflow: hidden;
}

.fare-showcase-slide:nth-child(2) {
  animation-delay: 4s;
}

.fare-showcase-slide:nth-child(3) {
  animation-delay: 8s;
}

.fare-showcase-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(to top, rgba(7,19,38,.78), rgba(7,19,38,.08) 58%, rgba(255,255,255,.05)),
    radial-gradient(circle at 15% 20%, rgba(255,255,255,.55), transparent 28%);
  pointer-events: none;
}

.fare-showcase-slide img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.04) contrast(1.02);
}

.fare-showcase-slide div {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 3;
  padding: 18px 20px;
  border-radius: 24px;
  color: #071326;
  background: rgb(255 255 255 / 48%);
  border: 1px solid rgb(255 255 255 / 36%);
  box-shadow: 0 24px 54px rgba(7, 19, 38, .20);
}

.fare-showcase-slide span,
.fare-showcase-slide small {
  display: block;
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #2b55a2;
}

.fare-showcase-slide strong {
  display: block;
  margin: 4px 0;
  font-size: clamp(1.5rem, 3vw, 2.6rem);
  line-height: .95;
}

@keyframes fareHeroShow {
  0%, 28% {
    opacity: 1;
    transform: scale(1);
  }

  33%, 100% {
    opacity: 0;
    transform: scale(1.035);
  }
}

.fare-tabs--cover {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 28px 0;
}

.fare-tabs--cover button {
  position: relative;
  min-height: 285px;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(43,85,162,.13);
  border-radius: 30px;
  cursor: pointer;
  background: #fff;
  box-shadow: 0 22px 54px rgba(43,85,162,.13);
}

.fare-tabs--cover button::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(to top, rgba(255,255,255,.96), rgba(255,255,255,.58) 32%, rgba(255,255,255,.05) 65%),
    radial-gradient(circle at 18% 15%, rgba(255,255,255,.72), transparent 26%);
  pointer-events: none;
}

.fare-tabs--cover button::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  z-index: 4;
  height: 4px;
  border-radius: 999px;
  background: rgba(43,85,162,.18);
  transition: .25s ease;
}

.fare-tabs--cover button.is-active::after {
  background: linear-gradient(90deg, #ef3340, #2b55a2);
  box-shadow: 0 0 24px rgba(43,85,162,.35);
}

.fare-tabs--cover img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: .35s ease;
}

.fare-tabs--cover button:hover img,
.fare-tabs--cover button.is-active img {
  transform: scale(1.06);
}

.fare-tabs--cover span {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 5;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(255,255,255,.92);
  color: #2b55a2;
  font-weight: 950;
  box-shadow: 0 12px 28px rgba(43,85,162,.14);
}

.fare-tabs--cover strong,
.fare-tabs--cover small {
  position: absolute;
  left: 18px;
  right: 18px;
  z-index: 5;
  text-align: left;
  color: #071326;
}

.fare-tabs--cover strong {
  bottom: 54px;
  font-size: 1.08rem;
  line-height: 1.05;
}

.fare-tabs--cover small {
  bottom: 34px;
  font-size: .76rem;
  font-weight: 900;
  color: #2b55a2;
}

@media (max-width: 1100px) {
  .fare-tabs--cover {
    grid-template-columns: repeat(2, 1fr);
  }

  .fare-tabs--cover button {
    min-height: 260px;
  }
}

@media (max-width: 720px) {
  .fares-hero-showcase {
    min-height: 390px;
  }

  .fare-tabs--cover {
    grid-template-columns: 1fr;
  }

  .fare-tabs--cover button {
    min-height: 270px;
  }
}

.fare-tabs--cover {
  align-items: stretch;
}

.fare-tabs--cover button {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.55);
  background: #fff;
}

.fare-tabs--cover button img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain; /* ne déforme pas */
  object-position: center;
  padding: 18px;
  z-index: 1;
}

.fare-tabs--cover button::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(to top, rgba(7,19,38,.88), rgba(7,19,38,.22) 50%, rgba(255,255,255,.08)),
    radial-gradient(circle at 18% 16%, rgba(255,255,255,.65), transparent 28%);
  pointer-events: none;
}

.fare-tabs--cover button span,
.fare-tabs--cover button strong,
.fare-tabs--cover button small {
  position: relative;
  z-index: 3;
  color: #fff;
  text-shadow: 0 8px 22px rgba(7,19,38,.55);
}

.fare-tabs--cover button span {
  background: rgba(43,85,162,.92);
}

.fare-tabs--cover button small {
  color: rgba(255,255,255,.84);
}

.fare-tabs--cover button.is-active {
  border-color: rgba(227,6,19,.75);
  box-shadow: 0 22px 55px rgba(43,85,162,.22);
}


.fare-tabs--cover button {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 6px;
  padding: 22px;
}

.fare-tabs--cover button::after {
  content: "";
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 14px;
  height: 3px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  z-index: 4;
}

.fare-tabs--cover button span {
  position: absolute;
  top: 18px;
  left: 18px;
}

.fare-tabs--cover button strong {
  margin-top: auto;
  font-size: 1.8rem;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.03em;
}

.fare-tabs--cover button small {
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  transform: translateY(-14px);
}

.fare-tabs--cover button.is-active::after {
  background: linear-gradient(90deg, #e30613, #2b55a2);
  box-shadow: 0 0 18px rgba(227,6,19,.35);
}

.fare-profile-list--visual {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px, 1fr));
  gap: 14px;
  margin-top: 20px;
}

.fare-profile-list--visual > div {
  position: relative;
  min-height: 230px;
  overflow: hidden;
  border-radius: 26px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background:
    linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.04)),
    radial-gradient(circle at 20% 10%, rgba(81,190,202,.45), transparent 34%),
    linear-gradient(145deg, #102a68, #071326);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 24px 55px rgba(7,19,38,.18);
}

.fare-profile-list--visual > div::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7,19,38,.92), rgba(7,19,38,.18) 62%, transparent);
  z-index: 2;
}

.fare-profile-list--visual > div::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 12px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #e30613, #51beca);
  z-index: 4;
}

.fare-profile-list--visual img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center top;
  padding: 18px 12px 70px;
  z-index: 1;
  filter: drop-shadow(0 18px 28px rgba(7,19,38,.25));
}

.fare-profile-list--visual strong,
.fare-profile-list--visual span {
  position: relative;
  z-index: 3;
  color: #fff;
  text-shadow: 0 10px 24px rgba(7,19,38,.45);
}

.fare-profile-list--visual strong {
  font-size: .98rem;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.03em;
  margin-bottom: 6px;
  padding-bottom: 12px;
}

.fare-profile-list--visual span {
  font-size: .78rem;
  font-weight: 750;
  line-height: 1.35;
  color: rgba(255,255,255,.82);
  padding-bottom: 10px;
}

.fare-profile-list--visual > div:hover {
  transform: translateY(-6px);
  border-color: rgba(81,190,202,.65);
  box-shadow: 0 30px 70px rgba(43,85,162,.28);
}

@media (max-width: 1100px) {
  .fare-profile-list--visual {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .fare-profile-list--visual {
    grid-template-columns: 1fr;
  }

  .fare-profile-list--visual > div {
    min-height: 210px;
  }
}

.site-loader,
#loader,
.loader,
.preloader,
[data-loader] {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.network-map-loader {
  position: absolute;
  inset: 0;
  z-index: 40;
  overflow: hidden;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 20% 15%, rgba(81, 190, 202, .28), transparent 34%),
    radial-gradient(circle at 85% 20%, rgba(227, 6, 19, .16), transparent 30%),
    linear-gradient(145deg, rgba(239, 246, 255, .96), rgba(222, 232, 246, .94));
  border-radius: inherit;
  transition: opacity .7s ease, visibility .7s ease;
}

.network-map-loader.is-done {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.network-map-loader__sky {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(43, 85, 162, .08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(43, 85, 162, .06) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(to bottom, black, transparent 82%);
}

.network-map-loader__scene {
  position: relative;
  width: min(760px, 88%);
  min-height: 290px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.network-map-loader__bus {
  position: absolute;
  bottom: 92px;
  left: -42%;
  width: min(520px, 70vw);
  max-height: 190px;
  object-fit: contain;
  filter: drop-shadow(0 28px 32px rgba(7, 19, 38, .28));
  animation: msafaraBusDrive 3.4s cubic-bezier(.18, .82, .2, 1) infinite;
}

.network-map-loader.is-done .network-map-loader__bus {
  animation: msafaraBusStop .9s cubic-bezier(.16, .8, .22, 1) forwards;
}

.network-map-loader__line {
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: 78px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, #e30613, #2b55a2, #51beca);
  box-shadow:
    0 0 0 8px rgba(255,255,255,.75),
    0 18px 35px rgba(43,85,162,.24);
}

.network-map-loader__line::before {
  content: "";
  position: absolute;
  inset: -5px;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.9), transparent);
  animation: msafaraLineScan 1.35s linear infinite;
}

.network-map-loader__line span,
.network-map-loader__line i {
  position: absolute;
  top: 50%;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #fff;
  border: 5px solid #2b55a2;
  transform: translate(-50%, -50%);
  box-shadow: 0 8px 18px rgba(7,19,38,.18);
}

.network-map-loader__line span { left: 8%; border-color: #e30613; }
.network-map-loader__line i:nth-child(2) { left: 28%; }
.network-map-loader__line i:nth-child(3) { left: 48%; border-color: #fab400; }
.network-map-loader__line i:nth-child(4) { left: 68%; border-color: #944091; }
.network-map-loader__line i:nth-child(5) { left: 88%; border-color: #51beca; }

.network-map-loader__text {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: min(520px, 92%);
  transform: translateX(-50%);
  padding: 18px 22px;
  text-align: center;
  border-radius: 24px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.9);
  box-shadow: 0 22px 55px rgba(7,19,38,.13);
  backdrop-filter: blur(18px);
}

.network-map-loader__text strong {
  display: block;
  color: #071326;
  font-size: 1rem;
  font-weight: 950;
  letter-spacing: -.03em;
}

.network-map-loader__text small {
  display: block;
  margin-top: 4px;
  color: rgba(7,19,38,.62);
  font-weight: 750;
}

@keyframes msafaraBusDrive {
  0% {
    left: -48%;
    transform: translateY(0) scale(.98);
  }

  55% {
    transform: translateY(-3px) scale(1);
  }

  100% {
    left: 112%;
    transform: translateY(0) scale(.98);
  }
}

@keyframes msafaraBusStop {
  from {
    left: 20%;
    transform: translateY(-2px) scale(1);
  }

  to {
    left: 50%;
    transform: translateX(-50%) translateY(0) scale(1);
  }
}

@keyframes msafaraLineScan {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(100%);
  }
}

@media (max-width: 700px) {
  .network-map-loader__scene {
    min-height: 240px;
  }

  .network-map-loader__bus {
    width: 82vw;
    bottom: 88px;
  }

  .network-map-loader__text {
    padding: 14px 16px;
  }
}

.timetable-searchbox input {
  color: #0f172a; 
  background: transparent;
}

.timetable-searchbox input::placeholder {
  color: rgba(15, 23, 42, 0.45);
}

.timetable-searchbox span {
  color: #f59e0b;
  pointer-events: none;
}


.move-page{
  --move-blue:#2e4b9b;
  --move-red:#e30613;
  --move-cyan:#51beca;
  --move-yellow:#ffe200;
  --move-dark:#071326;
  --move-card:rgba(255,255,255,.82);

}

.move-page::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 8% 6%, rgba(46,75,155,.16), transparent 28%),
    radial-gradient(circle at 92% 4%, rgba(255,226,0,.18), transparent 20%),
    radial-gradient(circle at 82% 42%, rgba(81,190,202,.12), transparent 24%);
  pointer-events:none;
}

.move-hero{
  overflow:hidden;
  border-bottom:1px solid rgba(46,75,155,.08);
}

.move-hero__content{
  position:relative;
}

.move-hero__content h1 {
  text-wrap: balance;
  background: linear-gradient(135deg,#071326 0%,var(--move-blue) 48%,var(--move-red) 100%);
 background-clip: text;
	color: transparent;
}
.move-hero__content h1 {
  max-width: 850px;
  margin: .7rem 0 1rem;
  font-size: clamp(2.6rem,5.4vw,5.8rem);
  line-height: .92;
  letter-spacing: -.07em;
}





/* =========================================================
   TIMETABLE SEARCH LIVE
========================================================= */

.timetable-card[hidden]{
  display:none !important;
}

.timetable-searchbox input{
  color:#071326;
}

.timetable-searchbox input::placeholder{
  color:rgba(7,19,38,.42);
}

.timetable-no-result .timetable-command__grid::after{
  content:"Aucune ligne trouvée";
  grid-column:1/-1;
  padding:2rem;
  border-radius:1.4rem;
  text-align:center;
  font-weight:800;
  color:#64748b;
  background:rgba(255,255,255,.72);
  border:1px dashed rgba(46,75,155,.18);
}


.home-timetable-quick {
  margin-top: 1.1rem;
  align-items: end;
}

.home-timetable-quick__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: end;
  justify-content: flex-end;
}

.home-timetable-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: 1rem;
}

.home-timetable-pill {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .8rem;
  align-items: center;
  min-width: 0;
  padding: .8rem;
  border-radius: 22px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--line-color) 24%, transparent), transparent 38%),
    linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.045));
  border: 1px solid color-mix(in srgb, var(--line-color) 35%, rgba(255,255,255,.14));
  box-shadow: 0 16px 42px rgba(5, 15, 35, .14);
  overflow: hidden;
  position: relative;
}

.home-timetable-pill::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--line-color);
  box-shadow: 0 0 18px var(--line-color);
}

.home-timetable-pill__icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: color-mix(in srgb, var(--line-color) 18%, rgba(255,255,255,.12));
  border: 1px solid color-mix(in srgb, var(--line-color) 38%, rgba(255,255,255,.18));
  flex: 0 0 auto;
}

.home-timetable-pill__icon img {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.home-timetable-pill__body {
  min-width: 0;
  display: grid;
  gap: .16rem;
}

.home-timetable-pill__body span {
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .72;
}

.home-timetable-pill__body strong {
  min-width: 0;
  font-size: .92rem;
  line-height: 1.18;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-timetable-pill__body small {
  min-width: 0;
  font-size: .76rem;
  opacity: .72;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-timetable-pill__actions {
  display: flex;
  gap: .45rem;
  align-items: center;
  justify-content: flex-end;
}

.home-timetable-pill__actions .btn {
  padding: .55rem .75rem;
  font-size: .78rem;
  white-space: nowrap;
}

.home-timetable-footer {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1rem;
}

.home-timetable-footer a {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .7rem .9rem;
  border-radius: 999px;
  text-decoration: none;
  color: inherit;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  font-weight: 800;
  font-size: .82rem;
}

.home-timetable-footer a:hover {
  transform: translateY(-2px);
}

@media (max-width: 980px) {
  .home-timetable-strip {
    grid-template-columns: 1fr;
  }

  .home-timetable-pill {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .home-timetable-pill__actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }

  .home-timetable-pill__actions .btn {
    flex: 1;
  }
}

@media (max-width: 680px) {
  .home-timetable-quick__actions {
    justify-content: stretch;
  }

  .home-timetable-quick__actions .btn {
    flex: 1 1 100%;
  }

  .home-timetable-footer a {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   M'SAFARA — MOVE LIVE BOARD FUTURISTIC AIRPORT SKIN
========================================================= */

.move-live-board {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(130, 220, 255, 0.25);
  background:
    radial-gradient(circle at 20% 0%, rgba(81, 190, 202, 0.28), transparent 34%),
    radial-gradient(circle at 90% 20%, rgba(46, 75, 155, 0.32), transparent 38%),
    linear-gradient(145deg, rgba(5, 10, 28, 0.92), rgba(8, 18, 42, 0.86));
  box-shadow:
    0 30px 80px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(22px);
}

.move-live-board::before {
  content: "";
  position: absolute;
  inset: -40%;
  background:
    linear-gradient(115deg, transparent 35%, rgba(255,255,255,.08) 50%, transparent 65%);
  transform: translateX(-35%);
  animation: moveBoardLight 8s linear infinite;
  pointer-events: none;
}

.move-live-board__top {
  position: relative;
  z-index: 2;
}

.move-live-board__top .eyebrow {
  color: #7ee7ff;
  letter-spacing: .16em;
}

.move-live-board__top strong {
  color: #fff;
  text-shadow: 0 0 18px rgba(126, 231, 255, .35);
}

.move-live-board__clock {
  min-width: 92px;
  padding: .7rem .9rem;
  border-radius: 18px;
  border: 1px solid rgba(126, 231, 255, .25);
  background: rgba(2, 8, 24, .58);
  box-shadow: inset 0 0 22px rgba(81, 190, 202, .12);
}

.move-live-board__clock strong {
  font-variant-numeric: tabular-nums;
  color: #7ee7ff;
}

.move-live-board__clock span {
  color: rgba(255,255,255,.62);
}

.move-live-board__screen {
  position: relative;
  overflow: hidden;
  margin-top: 1.1rem;
  border-radius: 26px;
  border: 1px solid rgba(126, 231, 255, .22);
  background:
    linear-gradient(180deg, rgba(2, 8, 24, .95), rgba(3, 13, 34, .88)),
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,.035) 0,
      rgba(255,255,255,.035) 1px,
      transparent 1px,
      transparent 9px
    );
  box-shadow:
    inset 0 0 36px rgba(81, 190, 202, .12),
    0 20px 50px rgba(0,0,0,.32);
}

.move-live-board__screen::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(126,231,255,.04) 1px, transparent 1px),
    linear-gradient(180deg, rgba(126,231,255,.035) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent);
  pointer-events: none;
}

.move-live-board__scan {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(126, 231, 255, .16),
    transparent
  );
  height: 38%;
  animation: moveBoardScan 4.2s linear infinite;
  opacity: .7;
  pointer-events: none;
}

.move-live-board__head {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 88px 1fr 118px;
  gap: .75rem;
  padding: .9rem 1rem;
  color: rgba(255,255,255,.55);
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .14em;
  border-bottom: 1px solid rgba(126, 231, 255, .15);
  background: rgba(255,255,255,.035);
}

.move-live-board__rows {
  position: relative;
  z-index: 2;
  display: grid;
  gap: .7rem;
  padding: .9rem;
}

.move-live-row {
  position: relative;
  display: grid;
  grid-template-columns: 76px 1fr 126px;
  align-items: center;
  gap: .8rem;
  width: 100%;
  min-height: 74px;
  padding: .85rem .95rem;
  border: 1px solid rgba(126, 231, 255, .16);
  border-radius: 22px;
  background:
    radial-gradient(circle at 0% 50%, color-mix(in srgb, var(--line-color, #51beca) 30%, transparent), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.095), rgba(255,255,255,.035));
  color: #fff;
  cursor: pointer;
  text-align: left;
  box-shadow:
    0 12px 30px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.11);
  transition:
    transform .22s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    background .22s ease;
}

.move-live-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18%;
  bottom: 18%;
  width: 4px;
  border-radius: 0 999px 999px 0;
  background: var(--line-color, #51beca);
  box-shadow: 0 0 18px var(--line-color, #51beca);
}

.move-live-row:hover,
.move-live-row:focus-visible {
  transform: translateY(-3px) scale(1.01);
  border-color: rgba(126, 231, 255, .46);
  box-shadow:
    0 18px 44px rgba(0,0,0,.38),
    0 0 28px color-mix(in srgb, var(--line-color, #51beca) 38%, transparent),
    inset 0 1px 0 rgba(255,255,255,.18);
  outline: none;
}

.move-live-row span {
  display: inline-grid;
  place-items: center;
  min-width: 58px;
  height: 44px;
  border-radius: 16px;
  background:
    linear-gradient(145deg, var(--line-color, #51beca), color-mix(in srgb, var(--line-color, #51beca) 58%, #000));
  color: #fff;
  font-size: 1rem;
  font-weight: 950;
  letter-spacing: .06em;
  font-variant-numeric: tabular-nums;
  box-shadow:
    0 0 24px color-mix(in srgb, var(--line-color, #51beca) 52%, transparent),
    inset 0 1px 0 rgba(255,255,255,.28);
}

.move-live-row strong {
  min-width: 0;
  color: #fff;
  font-size: clamp(.95rem, 1.7vw, 1.14rem);
  font-weight: 850;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.move-live-row em {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  padding: .55rem .7rem;
  border-radius: 999px;
  background: rgba(126, 231, 255, .1);
  border: 1px solid rgba(126, 231, 255, .2);
  color: #7ee7ff;
  font-style: normal;
  font-size: .82rem;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 14px rgba(126,231,255,.35);
}

.move-live-row--loading {
  grid-template-columns: 54px 1fr;
  cursor: default;
}

.move-live-row--loading span {
  min-width: 44px;
}

.move-live-board__actions {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 1rem;
}

.move-live-board__actions button,
.move-live-board__actions a {
  border: 1px solid rgba(126, 231, 255, .2);
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.78);
  padding: .65rem .9rem;
  font-weight: 800;
  text-decoration: none;
  transition: .22s ease;
}

.move-live-board__actions button:hover,
.move-live-board__actions a:hover,
.move-live-board__actions .is-active {
  background: rgba(126, 231, 255, .16);
  color: #fff;
  border-color: rgba(126, 231, 255, .45);
  box-shadow: 0 0 24px rgba(126, 231, 255, .18);
}

/* Responsive tablette */
@media (max-width: 780px) {
  .move-live-board__head {
    grid-template-columns: 72px 1fr 92px;
    font-size: .64rem;
  }

  .move-live-row {
    grid-template-columns: 64px 1fr;
    min-height: 78px;
  }

  .move-live-row em {
    grid-column: 2;
    justify-self: start;
    min-width: auto;
    margin-top: -.35rem;
  }
}

/* Responsive mobile */
@media (max-width: 520px) {
  .move-live-board {
    border-radius: 26px;
  }

  .move-live-board__screen {
    border-radius: 22px;
  }

  .move-live-board__head {
    display: none;
  }

  .move-live-board__rows {
    padding: .75rem;
    gap: .65rem;
  }

  .move-live-row {
    grid-template-columns: 56px 1fr;
    gap: .65rem;
    padding: .8rem;
    border-radius: 19px;
  }

  .move-live-row span {
    min-width: 50px;
    height: 42px;
    border-radius: 14px;
    font-size: .9rem;
  }

  .move-live-row strong {
    font-size: .94rem;
  }

  .move-live-row em {
    font-size: .76rem;
    padding: .46rem .62rem;
  }

  .move-live-board__actions {
    gap: .45rem;
  }

  .move-live-board__actions button,
  .move-live-board__actions a {
    flex: 1 1 auto;
    text-align: center;
    padding: .62rem .7rem;
    font-size: .82rem;
  }
}

@keyframes moveBoardScan {
  0% {
    transform: translateY(-120%);
  }
  100% {
    transform: translateY(280%);
  }
}

@keyframes moveBoardLight {
  0% {
    transform: translateX(-45%) rotate(0.001deg);
  }
  100% {
    transform: translateX(45%) rotate(0.001deg);
  }
}

.move-live-board__rows {
  gap: .45rem;
  padding: .65rem;
}

.move-live-row {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 92px;
  align-items: center;
  gap: .55rem;
  min-height: 56px;
  padding: .55rem .65rem;
  border-radius: 16px;
}

.move-live-row span {
  min-width: 46px;
  height: 36px;
  border-radius: 12px;
  font-size: .82rem;
}

.move-live-row strong {
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  line-height: 1.15;
  font-size: .88rem;
  max-width: none;
}

.move-live-row em {
  min-width: 84px;
  padding: .4rem .5rem;
  font-size: .72rem;
  line-height: 1;
  white-space: nowrap;
}

/* Mobile : titre entier aussi */
@media (max-width: 520px) {
  .move-live-row {
    grid-template-columns: 50px 1fr;
    min-height: 64px;
    padding: .55rem;
  }

  .move-live-row strong {
    grid-column: 2;
    font-size: .84rem;
    line-height: 1.18;
  }

  .move-live-row em {
    grid-column: 2;
    justify-self: start;
    margin-top: -.2rem;
    min-width: auto;
  }
}

/* =========================================================
   FIX BTN PRIMARY — PDF + VOIR PLAN
========================================================= */

a.btn.btn-primary[href$=".pdf"],
a.btn.btn-primary[href="#plan-du-reseau"] {
  min-height: 2.9rem;
  padding: 0 1.25rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.18);

  color: #fff !important;
  font-weight: 900;

  background:
    linear-gradient(135deg, #e30613 0%, #ff4d57 22%, #2e4b9b 100%) !important;

  box-shadow:
    0 18px 38px rgba(46,75,155,.24),
    inset 0 1px 0 rgba(255,255,255,.22);

  transition: .18s ease;
}

a.btn.btn-primary[href$=".pdf"]:hover,
a.btn.btn-primary[href="#plan-du-reseau"]:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
  box-shadow:
    0 24px 52px rgba(46,75,155,.34),
    inset 0 1px 0 rgba(255,255,255,.28);
}


/* =========================================================
   MAP PRO CONTROLS — DESIGN FUTURISTE
========================================================= */

.map-pro-controls.map-pro-controls--top {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .45rem;
  border-radius: 999px;
  background: rgba(7, 19, 38, .76);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(16px);
  box-shadow: 0 18px 42px rgba(15,23,42,.22);
}

.map-pro-controls.map-pro-controls--top button {
  width: 2.45rem;
  height: 2.45rem;
  border-radius: 999px;

  border: 1px solid rgba(255,255,255,.14);
  background:
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(225,235,255,.78));

  color: #10234b;
  font-weight: 950;
  cursor: pointer;

  box-shadow:
    0 10px 22px rgba(0,0,0,.16),
    inset 0 1px 0 rgba(255,255,255,.8);

  transition:
    transform .18s ease,
    background .18s ease,
    color .18s ease,
    box-shadow .18s ease;
}

.map-pro-controls.map-pro-controls--top button:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #e30613, #2e4b9b);
  color: #fff;
  box-shadow:
    0 16px 34px rgba(46,75,155,.32),
    0 0 0 1px rgba(255,255,255,.12);
}

.map-pro-controls.map-pro-controls--top button.is-active {
  background: linear-gradient(135deg, #51beca, #ffe200);
  color: #071326;
  border-color: rgba(255,226,0,.45);
  box-shadow:
    0 14px 32px rgba(81,190,202,.28),
    inset 0 1px 0 rgba(255,255,255,.7);
}

.map-pro-controls.map-pro-controls--top button:active {
  transform: scale(.96);
}


/* Responsive */
@media (max-width: 760px) {
  .map-pro-controls.map-pro-controls--top {
    flex-wrap: wrap;
    justify-content: flex-end;
    border-radius: 1rem;
    gap: .35rem;
  }

  .map-pro-controls.map-pro-controls--top button {
    width: 2.25rem;
    height: 2.25rem;
    font-size: .78rem;
  }

  a.btn.btn-primary[href$=".pdf"],
  a.btn.btn-primary[href="#plan-du-reseau"] {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   FIX TITRES + RECHARGER + CLOCK
========================================================= */

/* Titre réseau : même style que “Planifiez…” */
.hero-network-heading h1,
.hero-network-heading h1 span,
.hero-network-heading .move-hero__content h1 {
  color: transparent !important;
  background: linear-gradient(
    135deg,
    #071326 0%,
    #2e4b9b 42%,
    #7b2d74 72%,
    #e30613 100%
  ) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
}

/* Tous les boutons Recharger mon titre */
a.btn.btn-primary.btn-recharge,
a.btn.btn-primary.fare-command__cta,
a.btn.btn-primary[href*="boutique.msafara.yt"],
.header-actions a.btn.btn-primary,
.site-header a.btn.btn-primary {
  min-height: 2.9rem;
  padding: 0 1.25rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.18);

  color: #fff !important;
  font-weight: 900;
  white-space: nowrap;

  background:
    linear-gradient(135deg, #e30613 0%, #ff4d57 24%, #2e4b9b 100%) !important;

  box-shadow:
    0 18px 38px rgba(46,75,155,.24),
    inset 0 1px 0 rgba(255,255,255,.24);

  opacity: 1 !important;
  visibility: visible !important;
  filter: none !important;
}

a.btn.btn-primary.btn-recharge:hover,
a.btn.btn-primary.fare-command__cta:hover,
a.btn.btn-primary[href*="boutique.msafara.yt"]:hover,
.header-actions a.btn.btn-primary:hover,
.site-header a.btn.btn-primary:hover {
  transform: translateY(-2px);
  filter: brightness(1.05) !important;
  box-shadow:
    0 24px 52px rgba(46,75,155,.34),
    inset 0 1px 0 rgba(255,255,255,.28);
}

/* Horloge live */
.departures-live-clock,
.move-live-board__clock {
  color: #fff;
  background:
    linear-gradient(145deg, rgba(7,19,38,.95), rgba(46,75,155,.72)) !important;
  border: 1px solid rgba(126,231,255,.28) !important;
  box-shadow:
    0 18px 42px rgba(15,23,42,.22),
    inset 0 1px 0 rgba(255,255,255,.16) !important;
}

.departures-live-clock strong,
.move-live-board__clock strong {
  color: #7ee7ff !important;
}

.departures-live-clock span,
.move-live-board__clock span {
  color: rgba(255,255,255,.72) !important;
}

/* Mobile */
@media (max-width: 760px) {
  a.btn.btn-primary.btn-recharge,
  a.btn.btn-primary.fare-command__cta,
  a.btn.btn-primary[href*="boutique.msafara.yt"] {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   INDEX — MODULE APPEL FICHES HORAIRES
========================================================= */

.schedule-callout-shell {
  padding: clamp(1.5rem, 3vw, 3rem) 0;
}

.schedule-callout {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, .78fr);
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: center;

  padding: clamp(1.2rem, 2.6vw, 2rem);
  border-radius: 2rem;

  background:
    radial-gradient(circle at 12% 0%, rgba(46,75,155,.22), transparent 34%),
    radial-gradient(circle at 88% 10%, rgba(255,226,0,.20), transparent 24%),
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(246,249,255,.76));

  border: 1px solid rgba(46,75,155,.13);
  box-shadow:
    0 30px 80px rgba(15,23,42,.12),
    inset 0 1px 0 rgba(255,255,255,.85);
}

.schedule-callout::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.045) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 78%);
  pointer-events: none;
}

.schedule-callout > * {
  position: relative;
  z-index: 1;
}

.schedule-callout__content h2 {
  max-width: 760px;
  margin: .55rem 0 .6rem;
  font-size: clamp(2rem, 4vw, 3.7rem);
  line-height: .96;
  letter-spacing: -.06em;

  color: transparent;
  background: linear-gradient(135deg, #071326 0%, #2e4b9b 45%, #7b2d74 72%, #e30613 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.schedule-callout__content p {
  max-width: 620px;
  margin: 0;
  color: var(--ink-soft);
  font-weight: 650;
  line-height: 1.6;
}

.schedule-callout__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
  margin-top: 1.25rem;
}

.schedule-callout__link {
  display: inline-flex;
  align-items: center;
  min-height: 2.9rem;
  padding: 0 1rem;
  border-radius: 1rem;
  color: var(--blue);
  font-weight: 900;
  background: rgba(46,75,155,.08);
  border: 1px solid rgba(46,75,155,.12);
}

.schedule-callout__link:hover {
  transform: translateY(-2px);
  background: rgba(46,75,155,.12);
}

.schedule-callout__panel {
  padding: .75rem;
  border-radius: 1.5rem;
  background:
    linear-gradient(145deg, rgba(7,19,38,.96), rgba(16,35,75,.9));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 60px rgba(7,19,38,.24);
}

.schedule-mini-board {
  display: grid;
  gap: .5rem;
}

.schedule-mini-board__top,
.schedule-mini-row {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 54px;
  gap: .6rem;
  align-items: center;
}

.schedule-mini-board__top {
  padding: .55rem .65rem;
  color: rgba(255,255,255,.55);
  font-size: .62rem;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.schedule-mini-row {
  min-height: 3.5rem;
  padding: .55rem .65rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.09);
}

.schedule-mini-row strong {
  display: grid;
  place-items: center;
  height: 2.3rem;
  border-radius: .75rem;
  color: #fff;
  font-weight: 950;
  background: linear-gradient(135deg, #e30613, #2e4b9b);
}

.schedule-mini-row span {
  color: #fff;
  font-size: .82rem;
  font-weight: 850;
  line-height: 1.2;
}

.schedule-mini-row em {
  display: grid;
  place-items: center;
  height: 2rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #51beca, #ffe200);
  color: #071326;
  font-style: normal;
  font-size: .66rem;
  font-weight: 950;
}

@media (max-width: 980px) {
  .schedule-callout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .schedule-callout {
    border-radius: 1.5rem;
  }

  .schedule-callout__actions .btn,
  .schedule-callout__link {
    width: 100%;
    justify-content: center;
  }

  .schedule-mini-board__top {
    display: none;
  }

  .schedule-mini-row {
    grid-template-columns: 52px 1fr;
  }

  .schedule-mini-row em {
    grid-column: 2;
    width: max-content;
  }
}

.schedule-mini-row {
  background:
    radial-gradient(circle at 0% 50%, color-mix(in srgb, var(--line-color, #2e4b9b) 28%, transparent), transparent 38%),
    rgba(255,255,255,.075);
  border-color: color-mix(in srgb, var(--line-color, #2e4b9b) 38%, rgba(255,255,255,.1));
}

.schedule-mini-row strong {
  background: var(--line-color, #2e4b9b);
  box-shadow: 0 0 20px color-mix(in srgb, var(--line-color, #2e4b9b) 45%, transparent);
}

.schedule-mini-row em {
  background: color-mix(in srgb, var(--line-color, #2e4b9b) 18%, white);
  color: color-mix(in srgb, var(--line-color, #2e4b9b) 82%, #071326);
}


.ticketing-command-shell {
  padding: clamp(2rem, 5vw, 5rem) 0;
}

.ticketing-command {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 2.8vw, 2.2rem);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(46,75,155,.24), transparent 34%),
    radial-gradient(circle at 90% 12%, rgba(255,226,0,.18), transparent 24%),
    linear-gradient(145deg, rgba(255,255,255,.94), rgba(246,249,255,.78));
  border: 1px solid rgba(46,75,155,.14);
  box-shadow: 0 34px 90px rgba(15,23,42,.13);
}

.ticketing-command::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.045) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.58), transparent 78%);
  pointer-events: none;
}

.ticketing-command > * {
  position: relative;
  z-index: 1;
}

.ticketing-command__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1.4rem;
}

.ticketing-command__head h2 {
  max-width: 880px;
  margin: .45rem 0 .6rem;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .96;
  letter-spacing: -.065em;
  color: transparent;
  background: linear-gradient(135deg, #071326 0%, #2e4b9b 46%, #7b2d74 72%, #e30613 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.ticketing-command__head p {
  max-width: 760px;
  margin: 0;
  color: var(--ink-soft);
  font-weight: 650;
  line-height: 1.6;
}

.ticketing-command__cta {
  white-space: nowrap;
}

.ticketing-command__grid {
  display: grid;
  grid-template-columns: minmax(280px, .78fr) minmax(0, 1.22fr);
  gap: 1rem;
  margin-bottom: 1rem;
}

.ticketing-howto-card,
.ticketing-prices-card,
.ticketing-pass-card,
.ticketing-subscriptions {
  border-radius: 1.5rem;
  border: 1px solid rgba(46,75,155,.12);
  box-shadow: 0 24px 60px rgba(15,23,42,.09);
}

.ticketing-howto-card {
  overflow: hidden;
  background: #102b63;
}

.ticketing-howto-card img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
}

.ticketing-prices-card {
  padding: 1rem;
  background:
    linear-gradient(145deg, rgba(7,19,38,.97), rgba(16,35,75,.92));
  color: #fff;
}

.ticketing-chip {
  display: inline-flex;
  padding: .45rem .75rem;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #7ee7ff;
  font-size: .75rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: .8rem;
}

.ticketing-price-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}

.ticketing-price-grid article {
  min-height: 9rem;
  padding: 1rem;
  border-radius: 1.15rem;
  background:
    radial-gradient(circle at 100% 0%, rgba(81,190,202,.24), transparent 36%),
    rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.11);
}

.ticketing-price-grid strong {
  display: block;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: .9;
  color: #fff;
}

.ticketing-price-grid span {
  display: block;
  margin-top: .45rem;
  color: #ffe200;
  font-weight: 950;
}

.ticketing-price-grid small {
  display: block;
  margin-top: .35rem;
  color: rgba(255,255,255,.72);
  line-height: 1.35;
  font-weight: 700;
}

.ticketing-pass-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.ticketing-pass-card {
  overflow: hidden;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 1rem;
  align-items: center;
  padding: .9rem;
  background: rgba(255,255,255,.78);
}

.ticketing-pass-card img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 1rem;
  background: #fff;
  box-shadow: 0 18px 38px rgba(15,23,42,.12);
}

.ticketing-pass-card span {
  display: inline-flex;
  width: fit-content;
  padding: .3rem .58rem;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 950;
  color: #fff;
}

.ticketing-pass-card--red span { background: #e30613; }
.ticketing-pass-card--blue span { background: #2e4b9b; }
.ticketing-pass-card--ticket span { background: #51beca; color: #071326; }

.ticketing-pass-card strong {
  display: block;
  margin-top: .45rem;
  font-size: 1.1rem;
  color: var(--ink);
}

.ticketing-pass-card p {
  margin: .35rem 0 0;
  color: var(--ink-soft);
  font-size: .86rem;
  line-height: 1.45;
  font-weight: 650;
}

.ticketing-subscriptions {
  padding: 1rem;
  background: rgba(255,255,255,.76);
}

.ticketing-subscriptions__head {
  margin-bottom: .85rem;
}

.ticketing-subscriptions__head h3 {
  margin: .35rem 0 0;
  font-size: clamp(1.5rem, 2.4vw, 2.4rem);
  line-height: 1;
  letter-spacing: -.045em;
}

.ticketing-subscription-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.ticketing-subscription-grid article {
  display: grid;
  gap: .35rem;
  padding: .85rem;
  border-radius: 1rem;
  background:
    linear-gradient(135deg, rgba(46,75,155,.1), rgba(230,51,53,.07));
  border: 1px solid rgba(46,75,155,.1);
}

.ticketing-subscription-grid span {
  color: var(--ink-soft);
  font-size: .78rem;
  font-weight: 850;
}

.ticketing-subscription-grid strong {
  color: var(--blue);
  font-size: 1.25rem;
}

.ticketing-subscription-grid em {
  color: var(--red);
  font-style: normal;
  font-size: .86rem;
  font-weight: 900;
}

.ticketing-note {
  margin: .9rem 0 0;
  color: var(--ink-soft);
  font-size: .86rem;
  font-weight: 650;
}

@media (max-width: 1080px) {
  .ticketing-command__head,
  .ticketing-command__grid,
  .ticketing-pass-grid {
    grid-template-columns: 1fr;
  }

  .ticketing-command__cta {
    width: fit-content;
  }

  .ticketing-howto-card img {
    max-height: 620px;
  }

  .ticketing-subscription-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .ticketing-command {
    border-radius: 1.45rem;
  }

  .ticketing-command__cta {
    width: 100%;
    justify-content: center;
  }

  .ticketing-price-grid,
  .ticketing-subscription-grid {
    grid-template-columns: 1fr;
  }

  .ticketing-pass-card {
    grid-template-columns: 92px 1fr;
  }

  .ticketing-pass-card img {
    width: 92px;
    height: 92px;
  }
}


/* =========================================================
   BILLETTERIE — IMAGE COMMENT VOYAGER PLUS COMPACTE
========================================================= */

.ticketing-howto-card {
  display: grid;
  place-items: center;
  min-height: 0;
  padding: 1rem;
  background:
    radial-gradient(circle at 20% 0%, rgba(81,190,202,.18), transparent 34%),
    linear-gradient(145deg, #102b63, #071326);
}

.ticketing-howto-card img {
  width: auto;
  max-width: 100%;
  height: clamp(260px, 32vw, 360px);
  min-height: 0 !important;
  object-fit: contain;
  object-position: center;
  border-radius: 1.25rem;
  box-shadow:
    0 22px 54px rgba(7,19,38,.28),
    0 0 0 1px rgba(255,255,255,.18);
}

/* Desktop : évite que la carte force la hauteur du bloc tickets */
.ticketing-command__grid {
  align-items: start;
}

/* Mobile */
@media (max-width: 640px) {
  .ticketing-howto-card img {
    height: clamp(240px, 80vw, 330px);
  }
}

/* =========================================================
   BILLETTERIE — ABONNEMENTS PREMIUM
========================================================= */

.ticketing-subscriptions {
  position: relative;
  overflow: hidden;
  padding: clamp(1rem, 2vw, 1.4rem);
  border-radius: 1.6rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(46,75,155,.18), transparent 34%),
    radial-gradient(circle at 90% 8%, rgba(230,51,53,.14), transparent 26%),
    linear-gradient(145deg, rgba(255,255,255,.94), rgba(246,249,255,.8));
}

.ticketing-subscriptions::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.045) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 78%);
  pointer-events: none;
}

.ticketing-subscriptions > * {
  position: relative;
  z-index: 1;
}

.ticketing-subscriptions__head {
  display: grid;
  gap: .35rem;
  margin-bottom: 1rem;
}

.ticketing-subscriptions__head h3 {
  margin: 0;
  font-size: clamp(1.55rem, 2.6vw, 2.7rem);
  line-height: .98;
  letter-spacing: -.055em;
  color: transparent;
  background: linear-gradient(135deg, #071326, #2e4b9b 50%, #e30613);
  -webkit-background-clip: text;
  background-clip: text;
}

.ticketing-subscriptions__head p {
  margin: 0;
  color: #e30613;
  font-weight: 900;
}

.ticketing-subscription-board {
  display: grid;
  gap: .5rem;
}

.ticketing-subscription-board__head,
.ticketing-subscription-row {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(110px, .7fr) minmax(110px, .7fr);
  gap: .55rem;
  align-items: stretch;
}

.ticketing-subscription-board__head span {
  padding: .65rem .8rem;
  border-radius: .9rem;
  background: #2e4b9b;
  color: #fff;
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-align: center;
}

.ticketing-subscription-board__head span:nth-child(3) {
  background: linear-gradient(135deg, #e30613, #ee7041);
}

.ticketing-subscription-row span,
.ticketing-subscription-row strong,
.ticketing-subscription-row em {
  display: flex;
  align-items: center;
  min-height: 3.1rem;
  padding: .7rem .85rem;
  border-radius: .9rem;
  font-style: normal;
  font-weight: 950;
}

.ticketing-subscription-row span {
  background: #2e4b9b;
  color: #fff;
  line-height: 1.15;
}

.ticketing-subscription-row strong {
  justify-content: center;
  background: #6b78ad;
  color: #fff;
  font-size: 1.35rem;
  text-align: center;
}

.ticketing-subscription-row em {
  justify-content: center;
  background: linear-gradient(135deg, #e30613, #ee7041);
  color: #fff;
  font-size: 1.35rem;
  text-align: center;
}

.ticketing-subscription-row.is-free strong,
.ticketing-subscription-row.is-free em {
  font-size: 1rem;
  text-transform: uppercase;
}

.ticketing-subscription-row.is-specific strong,
.ticketing-subscription-row.is-specific em {
  font-size: .9rem;
  text-transform: uppercase;
  line-height: 1.1;
}

.ticketing-subscription-alert {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  width: fit-content;
  margin: 1rem 0 0 auto;
  padding: .8rem 1rem;
  border-radius: 1rem;
  background: linear-gradient(135deg, #e30613, #ee7041);
  color: #fff;
  box-shadow: 0 18px 38px rgba(230,51,53,.22);
}

.ticketing-subscription-alert strong {
  font-size: 1.05rem;
}

.ticketing-subscription-alert span {
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(255,226,0,.22);
  font-size: .82rem;
  font-weight: 900;
}

.ticketing-note {
  margin-top: .9rem;
  color: #e30613;
  font-size: .82rem;
  font-weight: 800;
  line-height: 1.45;
}

/* Responsive tablette */
@media (max-width: 820px) {
  .ticketing-subscription-board__head {
    display: none;
  }

  .ticketing-subscription-row {
    grid-template-columns: 1fr 1fr;
    padding: .55rem;
    border-radius: 1.1rem;
    background: rgba(255,255,255,.62);
    border: 1px solid rgba(46,75,155,.1);
  }

  .ticketing-subscription-row span {
    grid-column: 1 / -1;
  }
}

/* Responsive mobile */
@media (max-width: 520px) {
  .ticketing-subscription-row {
    grid-template-columns: 1fr;
  }

  .ticketing-subscription-alert {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

/* =========================================================
   FIX — APPARITION IMMÉDIATE DES CONTENUS AU SCROLL
========================================================= */

[data-animate],
[data-reveal],
.reveal,
.fade-up,
.scroll-reveal,
.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  translate: none !important;
  filter: none !important;
  transition: none !important;
  animation: none !important;
}

/* Sécurité pour les sections / cards qui restent invisibles */
section,
article,
.glass-card,
.ticketing-command,
.ticketing-pass-card,
.ticketing-subscriptions,
.network-detail-card,
.timetable-command,
.fare-command {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Respecte aussi les utilisateurs qui désactivent les animations */
@media (prefers-reduced-motion: reduce) {
  * {
    scroll-behavior: auto !important;
    transition-duration: 0ms !important;
    animation-duration: 0ms !important;
    animation-delay: 0ms !important;
  }
}

/* =========================================================
   TITRES & ABONNEMENTS PAGE
========================================================= */

.fares-page {
  position: relative;
  overflow: hidden;
}

.fares-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  background:
    radial-gradient(circle at top left, rgba(46,75,155,.15), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,226,0,.11), transparent 18%),
    radial-gradient(circle at bottom right, rgba(230,51,53,.10), transparent 28%),
    linear-gradient(180deg,#f4f7ff 0%,#f6f9ff 32%,#eef3ff 100%);
}

.fares-page::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px);
  background-size: 44px 44px;
}

.fares-hero-heading h1 {
  color: transparent !important;
  background: linear-gradient(135deg, #071326 0%, #2e4b9b 42%, #7b2d74 72%, #e30613 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
}

.fares-command-shell {
  padding: clamp(1rem, 3vw, 2.5rem) 0 clamp(3rem, 6vw, 5rem);
}

.fares-command {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 2.8vw, 2.2rem);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(46,75,155,.24), transparent 34%),
    radial-gradient(circle at 90% 12%, rgba(255,226,0,.18), transparent 24%),
    linear-gradient(145deg, rgba(255,255,255,.94), rgba(246,249,255,.78));
  border: 1px solid rgba(46,75,155,.14);
  box-shadow: 0 34px 90px rgba(15,23,42,.13);
}

.fares-command::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.045) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.58), transparent 78%);
  pointer-events: none;
}

.fares-command > * {
  position: relative;
  z-index: 1;
}

.fares-command__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1.2rem;
}

.fares-command__head h2 {
  max-width: 900px;
  margin: .45rem 0 .6rem;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .96;
  letter-spacing: -.065em;
  color: transparent;
  background: linear-gradient(135deg, #071326 0%, #2e4b9b 46%, #7b2d74 72%, #e30613 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.fares-command__head p {
  max-width: 780px;
  margin: 0;
  color: var(--ink-soft);
  font-weight: 650;
  line-height: 1.6;
}

.fares-command__cta {
  white-space: nowrap;
}

.fares-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .6rem;
  margin-bottom: 1rem;
}

.fares-quick-grid a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: .7rem .9rem;
  border-radius: 1rem;
  background: rgba(46,75,155,.08);
  border: 1px solid rgba(46,75,155,.12);
  color: var(--blue);
  font-weight: 950;
  text-align: center;
}

.fares-quick-grid a:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #e30613, #2e4b9b);
  color: #fff;
}

.fares-visual-grid {
  display: grid;
  grid-template-columns: minmax(280px, .75fr) minmax(0, 1.25fr);
  gap: 1rem;
  margin-bottom: 1rem;
}

.fares-howto-card,
.fares-ticket-card,
.fares-section,
.fares-media-card {
  border-radius: 1.5rem;
  border: 1px solid rgba(46,75,155,.12);
  box-shadow: 0 24px 60px rgba(15,23,42,.09);
}

.fares-howto-card {
  display: grid;
  place-items: center;
  padding: 1rem;
  background: linear-gradient(145deg, #102b63, #071326);
}

.fares-howto-card img {
  width: auto;
  max-width: 100%;
  height: clamp(260px, 32vw, 360px);
  object-fit: contain;
  border-radius: 1.25rem;
}

.fares-ticket-card {
  padding: 1rem;
  background: linear-gradient(145deg, rgba(7,19,38,.97), rgba(16,35,75,.92));
  color: #fff;
}

.fares-pill {
  display: inline-flex;
  width: fit-content;
  padding: .42rem .72rem;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #7ee7ff;
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
}

.fares-ticket-card h3,
.fares-section__head h3 {
  margin: .55rem 0 .9rem;
  font-size: clamp(1.55rem, 2.7vw, 2.7rem);
  line-height: .98;
  letter-spacing: -.055em;
}

.fares-steps {
  display: grid;
  gap: .65rem;
}

.fares-steps article {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: .8rem;
  align-items: center;
  padding: .75rem;
  border-radius: 1rem;
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.11);
}

.fares-steps strong {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  background: #e30613;
  font-size: 1.4rem;
}

.fares-steps span {
  font-weight: 850;
  line-height: 1.3;
}

.fares-section {
  padding: clamp(1rem, 2vw, 1.4rem);
  margin-top: 1rem;
  background: rgba(255,255,255,.76);
}

.fares-section__head {
  margin-bottom: .9rem;
}

.fares-price-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .7rem;
}

.fares-price-grid article {
  min-height: 9rem;
  padding: 1rem;
  border-radius: 1.15rem;
  background: linear-gradient(145deg, #2e4b9b, #6b78ad);
  color: #fff;
}

.fares-price-grid span {
  display: block;
  color: #ffe200;
  font-weight: 950;
}

.fares-price-grid strong {
  display: block;
  margin: .4rem 0;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: .9;
}

.fares-price-grid p {
  margin: 0;
  color: rgba(255,255,255,.76);
  font-size: .84rem;
  line-height: 1.35;
  font-weight: 700;
}

.fares-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
}

.fares-media-card {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 1rem;
  align-items: center;
  padding: .9rem;
  background: rgba(255,255,255,.82);
}

.fares-media-card img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 1rem;
  background: #fff;
}

.fares-media-card span {
  display: inline-flex;
  width: fit-content;
  padding: .3rem .58rem;
  border-radius: 999px;
  color: #fff;
  font-size: .68rem;
  font-weight: 950;
}

.fares-media-card--blue span { background: #2e4b9b; }
.fares-media-card--red span { background: #e30613; }
.fares-media-card--cyan span { background: #51beca; color: #071326; }

.fares-media-card strong {
  display: block;
  margin-top: .45rem;
  color: var(--ink);
  font-size: 1.08rem;
}

.fares-media-card p {
  margin: .35rem 0 0;
  color: var(--ink-soft);
  font-size: .86rem;
  line-height: 1.45;
  font-weight: 650;
}

.fares-subscription-board {
  display: grid;
  gap: .5rem;
}

.fares-subscription-board__head,
.fares-subscription-board article {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(110px, .7fr) minmax(110px, .7fr);
  gap: .55rem;
}

.fares-subscription-board__head span,
.fares-subscription-board article span,
.fares-subscription-board article strong,
.fares-subscription-board article em {
  display: flex;
  align-items: center;
  min-height: 3.05rem;
  padding: .7rem .85rem;
  border-radius: .9rem;
  font-style: normal;
  font-weight: 950;
}

.fares-subscription-board__head span,
.fares-subscription-board article span {
  background: #2e4b9b;
  color: #fff;
}

.fares-subscription-board article strong {
  justify-content: center;
  background: #6b78ad;
  color: #fff;
  text-align: center;
}

.fares-subscription-board__head span:nth-child(3),
.fares-subscription-board article em {
  justify-content: center;
  background: linear-gradient(135deg, #e30613, #ee7041);
  color: #fff;
  text-align: center;
}

.fares-alert {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  width: fit-content;
  margin: 1rem 0 0 auto;
  padding: .8rem 1rem;
  border-radius: 1rem;
  background: linear-gradient(135deg, #e30613, #ee7041);
  color: #fff;
}

.fares-alert span {
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(255,226,0,.22);
  font-size: .82rem;
  font-weight: 900;
}

.fares-note {
  margin: .9rem 0 0;
  color: #e30613;
  font-size: .82rem;
  font-weight: 800;
}

.fares-barge-panel {
  display: grid;
  grid-template-columns: 1fr 170px;
  gap: 1rem;
  align-items: center;
  padding: 1rem;
  border-radius: 1.25rem;
  background: linear-gradient(145deg, rgba(7,19,38,.96), rgba(46,75,155,.86));
  color: #fff;
}

.fares-barge-panel h3 {
  margin: .55rem 0;
  font-size: clamp(1.5rem, 2.5vw, 2.4rem);
  line-height: 1;
}

.fares-barge-panel p {
  margin: 0;
  color: rgba(255,255,255,.76);
  font-weight: 700;
  line-height: 1.5;
}

.fares-barge-panel img {
  width: 170px;
  height: 170px;
  object-fit: cover;
  border-radius: 1rem;
  background: #fff;
}

@media (max-width: 1080px) {
  .fares-command__head,
  .fares-visual-grid,
  .fares-card-grid {
    grid-template-columns: 1fr;
  }

  .fares-quick-grid,
  .fares-price-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fares-command__cta {
    width: fit-content;
  }
}

@media (max-width: 760px) {
  .fares-quick-grid,
  .fares-price-grid {
    grid-template-columns: 1fr;
  }

  .fares-command__cta {
    width: 100%;
    justify-content: center;
  }

  .fares-subscription-board__head {
    display: none;
  }

  .fares-subscription-board article {
    grid-template-columns: 1fr 1fr;
    padding: .55rem;
    border-radius: 1.1rem;
    background: rgba(255,255,255,.62);
    border: 1px solid rgba(46,75,155,.1);
  }

  .fares-subscription-board article span {
    grid-column: 1 / -1;
  }

  .fares-barge-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .fares-media-card {
    grid-template-columns: 92px 1fr;
  }

  .fares-media-card img,
  .fares-barge-panel img {
    width: 92px;
    height: 92px;
  }

  .fares-subscription-board article {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   TITRES & ABONNEMENTS — TICKETS PREMIUM CARDS
========================================================= */

.fares-price-grid {
  gap: 1rem;
}

.fares-price-grid article {
  position: relative;
  isolation: isolate;
  overflow: hidden;

  min-height: 13.5rem;
  padding: 1.15rem;
  border-radius: 1.6rem;

  display: grid;
  align-content: space-between;
  gap: .75rem;

  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.32), transparent 32%),
    linear-gradient(145deg, #2e4b9b 0%, #213f85 52%, #10234b 100%);

  border: 1px solid rgba(255,255,255,.22);

  box-shadow:
    0 26px 70px rgba(15,23,42,.18),
    inset 0 1px 0 rgba(255,255,255,.22);

  color: #fff;
}

.fares-price-grid article::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;

  background:
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 26px 26px;

  mask-image: linear-gradient(to bottom, rgba(0,0,0,.75), transparent 78%);
}

.fares-price-grid article::after {
  content: "M";
  position: absolute;
  right: -1rem;
  bottom: -2.4rem;

  font-size: 9rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: -.08em;

  color: rgba(255,255,255,.075);
  pointer-events: none;
}

.fares-price-grid article span {
  width: fit-content;
  padding: .48rem .75rem;
  border-radius: 999px;

  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);

  color: #ffe200;
  font-size: .78rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.fares-price-grid article strong {
  margin: 0;
  font-size: clamp(2.8rem, 5vw, 4.7rem);
  line-height: .82;
  color: #fff;
  text-shadow: 0 18px 38px rgba(0,0,0,.22);
}

.fares-price-grid article p {
  max-width: 18rem;
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: .86rem;
  line-height: 1.35;
  font-weight: 800;
}

/* Variantes par ticket */
.fares-price-grid article:nth-child(1) {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.32), transparent 32%),
    linear-gradient(145deg, #2e4b9b 0%, #213f85 52%, #10234b 100%);
}

.fares-price-grid article:nth-child(2) {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.34), transparent 32%),
    linear-gradient(145deg, #51beca 0%, #2e4b9b 58%, #10234b 100%);
}

.fares-price-grid article:nth-child(3) {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.34), transparent 32%),
    linear-gradient(145deg, #6b78ad 0%, #2e4b9b 54%, #10234b 100%);
}

.fares-price-grid article:nth-child(4) {
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.34), transparent 32%),
    linear-gradient(145deg, #e30613 0%, #ee7041 46%, #2e4b9b 100%);
}

/* Petit logo/pastille premium */
.fares-price-grid article span::before {
  content: "";
  display: inline-grid;
  width: .62rem;
  height: .62rem;
  margin-right: .4rem;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 16px currentColor;
}

/* Hover premium */
.fares-price-grid article {
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    filter .22s ease;
}

.fares-price-grid article:hover {
  transform: translateY(-5px) scale(1.015);
  filter: brightness(1.05);
  box-shadow:
    0 34px 86px rgba(15,23,42,.26),
    0 0 0 1px rgba(255,255,255,.16),
    inset 0 1px 0 rgba(255,255,255,.28);
}

/* Responsive */
@media (max-width: 760px) {
  .fares-price-grid article {
    min-height: 11rem;
    border-radius: 1.35rem;
  }

  .fares-price-grid article::after {
    font-size: 7rem;
    right: -.8rem;
    bottom: -1.8rem;
  }

  .fares-price-grid article strong {
    font-size: 3.2rem;
  }
  }


.infos-page {
  position: relative;
  overflow: hidden;
}

.infos-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  background:
    radial-gradient(circle at top left, rgba(46,75,155,.15), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,226,0,.11), transparent 18%),
    radial-gradient(circle at bottom right, rgba(230,51,53,.10), transparent 28%),
    linear-gradient(180deg,#f4f7ff 0%,#f6f9ff 32%,#eef3ff 100%);
}

.infos-page::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px);
  background-size: 44px 44px;
}

.infos-hero-heading h1,
.infos-section-head h2 {
  color: transparent !important;
  background: linear-gradient(135deg, #071326 0%, #2e4b9b 42%, #7b2d74 72%, #e30613 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
}

.infos-command-shell {
  padding: clamp(1rem, 3vw, 2.5rem) 0 clamp(3rem, 6vw, 5rem);
}

.infos-command {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 2.8vw, 2.2rem);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(46,75,155,.24), transparent 34%),
    radial-gradient(circle at 90% 12%, rgba(255,226,0,.18), transparent 24%),
    linear-gradient(145deg, rgba(255,255,255,.94), rgba(246,249,255,.78));
  border: 1px solid rgba(46,75,155,.14);
  box-shadow: 0 34px 90px rgba(15,23,42,.13);
}

.infos-command::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(46,75,155,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(46,75,155,.045) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.58), transparent 78%);
  pointer-events: none;
}

.infos-command > * {
  position: relative;
  z-index: 1;
}

.infos-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin-bottom: 1.3rem;
}

.infos-quick-grid a {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 3.2rem;
  padding: .8rem 1rem;
  border-radius: 1rem;
  color: var(--blue, #2e4b9b);
  background: rgba(46,75,155,.08);
  border: 1px solid rgba(46,75,155,.12);
  font-weight: 950;
  text-align: center;
  text-decoration: none;
}

.infos-quick-grid a.is-active,
.infos-quick-grid a:hover {
  color: #fff;
  background: linear-gradient(135deg, #e30613, #2e4b9b);
}

.infos-section-head {
  margin: 2rem 0 1rem;
}

.infos-section-head:first-child {
  margin-top: 0;
}

.infos-section-head h2 {
  max-width: 900px;
  margin: .45rem 0 .6rem;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .96;
  letter-spacing: -.065em;
}

.infos-section-head p {
  max-width: 780px;
  margin: 0;
  color: var(--ink-soft, #64748b);
  font-weight: 650;
  line-height: 1.6;
}

.infos-news-grid,
.infos-traffic-grid {
  display: grid;
  grid-template-columns: 1.2fr .9fr .9fr;
  gap: 1rem;
}

.infos-traffic-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.infos-news-card,
.infos-traffic-card {
  position: relative;
  overflow: hidden;
  min-height: 18rem;
  padding: 1rem;
  border-radius: 1.5rem;
  background:
    radial-gradient(circle at 10% 0%, rgba(81,190,202,.22), transparent 34%),
    linear-gradient(145deg, rgba(7,19,38,.97), rgba(16,35,75,.92));
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  box-shadow: 0 24px 60px rgba(15,23,42,.16);
}

.infos-news-card--major {
  display: grid;
  grid-template-columns: .85fr 1fr;
  gap: 1rem;
}

.infos-news-card__media img {
  width: 100%;
  height: 100%;
  min-height: 17rem;
  object-fit: cover;
  border-radius: 1.1rem;
  background: #fff;
}

.infos-news-card__icon {
  display: grid;
  place-items: center;
  width: 4rem;
  height: 4rem;
  border-radius: 1.1rem;
  background: linear-gradient(135deg, #e30613, #2e4b9b);
  font-size: 1.2rem;
  font-weight: 950;
}

.infos-news-card__content,
.infos-traffic-card {
  display: grid;
  gap: .65rem;
  align-content: start;
}

.infos-news-card__content span,
.infos-traffic-card span {
  width: fit-content;
  padding: .35rem .65rem;
  border-radius: 999px;
  color: #ffe200;
  background: rgba(255,255,255,.1);
  font-size: .7rem;
  font-weight: 950;
  text-transform: uppercase;
}

.infos-news-card__content strong,
.infos-traffic-card strong {
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  line-height: 1.05;
}

.infos-news-card__content p,
.infos-traffic-card p {
  margin: 0;
  color: rgba(255,255,255,.76);
  font-weight: 700;
  line-height: 1.5;
}

.infos-news-card__content small,
.infos-traffic-card em {
  color: #7ee7ff;
  font-weight: 900;
  font-style: normal;
}

.infos-traffic-card.is-normal {
  background: linear-gradient(145deg, #0f9f6e, #10234b);
}

.infos-traffic-card.is-warning {
  background: linear-gradient(145deg, #ee7041, #10234b);
}

.infos-traffic-card.is-info {
  background: linear-gradient(145deg, #2e4b9b, #10234b);
}

.infos-claim-form {
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 2vw, 1.4rem);
  border-radius: 1.5rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(46,75,155,.18), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(246,249,255,.78));
  border: 1px solid rgba(46,75,155,.12);
  box-shadow: 0 24px 60px rgba(15,23,42,.09);
}

.infos-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
}

.infos-form-grid label,
.infos-message {
  display: grid;
  gap: .4rem;
}

.infos-form-grid span,
.infos-message span {
  color: var(--ink-soft, #64748b);
  font-size: .78rem;
  font-weight: 950;
}

.infos-form-grid input,
.infos-form-grid select,
.infos-message textarea {
  width: 100%;
  min-height: 3rem;
  padding: 0 .9rem;
  border-radius: 1rem;
  border: 1px solid rgba(46,75,155,.13);
  background: rgba(255,255,255,.92);
  color: var(--ink, #071326);
  font-weight: 750;
  outline: none;
}

.infos-message textarea {
  padding: .9rem;
  resize: vertical;
}

.infos-form-bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}

.infos-form-bottom p {
  margin: 0;
  color: var(--ink-soft, #64748b);
  font-size: .86rem;
  font-weight: 650;
  line-height: 1.5;
}

.infos-form-bottom .btn-primary {
  color: #fff !important;
  background: linear-gradient(135deg, #e30613, #2e4b9b) !important;
}

.infos-form-success,
.infos-form-error {
  display: grid;
  gap: .25rem;
  margin-bottom: 1rem;
  padding: 1rem;
  border-radius: 1rem;
  color: #fff;
}

.infos-form-success {
  background: linear-gradient(135deg, #0f9f6e, #2e4b9b);
}

.infos-form-error {
  background: linear-gradient(135deg, #e30613, #ee7041);
}

@media (max-width: 1120px) {
  .infos-news-grid,
  .infos-news-card--major,
  .infos-traffic-grid,
  .infos-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .infos-quick-grid,
  .infos-form-bottom {
    grid-template-columns: 1fr;
  }

  .infos-form-bottom .btn {
    width: 100%;
    justify-content: center;
  }
}


/* =========================================================
   INFOS PRATIQUES — RYTHME VERTICAL HOMOGÈNE SITE
========================================================= */

.infos-page {
  --section-y: clamp(4rem, 6vw, 5.5rem);
  --section-y-compact: clamp(3.5rem, 5vw, 4rem);
  --card-gap: clamp(1.2rem, 2vw, 1.6rem);
}

/* Hero comme index */
.infos-page .hero-network-heading {
  padding: clamp(2rem, 4vw, 3.4rem) 0 clamp(1.8rem, 3vw, 2.6rem);
  margin: 0;
}

/* Bloc principal */
.infos-command-shell {
  padding: 0 0 var(--section-y);
}

/* Card principale */
.infos-command {
  display: grid;
  gap: var(--section-y-compact);
}

/* Navigation interne */
.infos-quick-grid {
  margin: 0 0 clamp(.5rem, 1vw, .8rem);
}

/* Sections internes */
.infos-news-section,
.infos-traffic-section,
.infos-claim-section {
  display: grid;
  gap: var(--card-gap);
  margin: 0;
  padding: 0;
}

/* Séparation équilibrée entre sections */
.infos-traffic-section,
.infos-claim-section {
  padding-top: var(--section-y-compact);
  border-top: 1px solid rgba(46,75,155,.10);
}

/* Titres de section */
.infos-section-head {
  margin: 0;
}

.infos-section-head h2 {
  margin: .55rem 0 .75rem;
}

.infos-section-head p {
  margin: 0;
}

/* Grilles */
.infos-news-grid,
.infos-traffic-grid,
.infos-claim-form {
  margin: 0;
}


.schedule-callout__actions .btn.btn-primary,
.schedule-callout .btn.btn-primary {
  color: #fff !important;
  background: linear-gradient(135deg, #ff3347, #2e4b9b) !important;
  border: 0 !important;
  box-shadow: 0 18px 38px rgba(46, 75, 155, .22) !important;
}

.schedule-callout__actions .btn.btn-primary:hover,
.schedule-callout .btn.btn-primary:hover {
  color: #fff !important;
  background: linear-gradient(135deg, #e30613, #203a8c) !important;
  transform: translateY(-2px);
}


.schedule-mini-row {
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

.schedule-mini-row:hover,
.schedule-mini-row:focus-visible {
  transform: translateX(6px) scale(1.01);
  background: color-mix(in srgb, var(--line-color) 92%, #ffffff);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

.schedule-mini-row:hover strong,
.schedule-mini-row:focus-visible strong {
  background: var(--line-color);
  color: #fff;
}

.schedule-mini-row:hover em,
.schedule-mini-row:focus-visible em {
  background: var(--line-color);
  color: #fff;
}

@media (max-width: 560px){
  .schedule-mini-row{
    grid-template-columns: 44px minmax(0,1fr) 38px !important;
    gap: .45rem !important;
    padding: .65rem .55rem !important;
  }

  .schedule-mini-row strong{
    width: 44px !important;
    font-size: .78rem !important;
  }

  .schedule-mini-row span{
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-size: .72rem !important;
  }

  .schedule-mini-row em{
    width: 30px !important;
    height: 30px !important;
    font-size: .55rem !important;
  }
}

.schedule-mini-row{
  display:grid !important;
  grid-template-columns:52px minmax(0,1fr) 44px !important;
  align-items:center !important;
  column-gap:.75rem !important;
}

.schedule-mini-row strong{
  grid-column:1 !important;
}

.schedule-mini-row span{
  grid-column:2 !important;
  min-width:0 !important;
}

.schedule-mini-row em{
  grid-column:3 !important;
  justify-self:end !important;
  align-self:center !important;
  display:inline-grid !important;
  place-items:center !important;
  width:34px !important;
  height:34px !important;
  border-radius:999px !important;
  background:#fff !important;
  color:var(--line-color) !important;
  font-size:.62rem !important;
  font-style:normal !important;
  font-weight:950 !important;
}

.legal-sitemap{
  display:grid;
  gap:.8rem;
}

.legal-sitemap a,
.cookie-manager label{
  display:flex;
  align-items:center;
  gap:.75rem;
  padding:1rem;
  border-radius:1rem;
  background:rgba(46,75,155,.06);
  border:1px solid rgba(46,75,155,.1);
  font-weight:800;
}

.cookie-manager{
  display:grid;
  gap:1rem;
}

.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1rem;
}