/* FLORE Festival · feuille de styles partagée (design system + sections) */
:root{
  /* jour */
  --sky:#4DA9DF;--sky-deep:#2E7FB8;--sky-mid:#86C7EA;--sky-soft:#BFE4F7;--sky-pale:#E7F4FB;
  /* soleil */
  --sun:#DAEF52;--sun-deep:#92A824;--sun-pale:#F7FBD0;--gold:#F4EE34;
  /* crépuscule / nuit */
  --coral:#FF8B5E;--pink:#F2A0BE;--dusk:#5C4E92;--twilight:#27336A;--night:#0E1E3D;--navy:#0B1832;
  --white:#FFFFFF;--ink:#15395B;--ink-soft:#5C7993;
  --leaf:#84C254;--leaf-deep:#5E9E3E;--blush:#F2A7BB;
  --line:rgba(21,57,91,.1);
  --shadow:0 20px 48px rgba(21,57,91,.14);
  --shadow-lg:0 36px 80px rgba(21,57,91,.22);
  --shadow-sm:0 10px 26px rgba(21,57,91,.09);
  --ease:cubic-bezier(.34,.1,.2,1);
  --r-sm:16px;--r-md:24px;--r-lg:32px;--r-xl:42px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--ink);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;background:linear-gradient(180deg,#4FA0D2 0%,#3F93C4 45%,#2E7FB8 100%) no-repeat}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--sun);color:var(--ink)}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',system-ui,sans-serif;font-weight:700;line-height:1.04;letter-spacing:-.02em}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
section{position:relative}

/* ===== Ciel + nuages ===== */
.sky-bg{position:fixed;inset:0;z-index:-2;pointer-events:none}
.sky-bg::after{content:"";position:absolute;inset:0;background-image:radial-gradient(1.6px 1.6px at 12% 14%,rgba(255,255,255,.5),transparent 60%),radial-gradient(1.2px 1.2px at 78% 32%,rgba(255,255,255,.35),transparent 60%),radial-gradient(2px 2px at 45% 68%,rgba(218,239,82,.28),transparent 60%),radial-gradient(1.4px 1.4px at 88% 84%,rgba(255,255,255,.42),transparent 60%),radial-gradient(1.2px 1.2px at 22% 92%,rgba(255,255,255,.3),transparent 60%),radial-gradient(1.6px 1.6px at 64% 22%,rgba(218,239,82,.22),transparent 60%);background-size:680px 900px;opacity:.85;animation:twinkleStars 9s ease-in-out infinite;pointer-events:none}
@keyframes twinkleStars{0%,100%{opacity:.7}50%{opacity:.95}}

/* ===== Scrollbar custom premium ===== */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:rgba(11,24,50,.05)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--sky),var(--sky-deep));border-radius:10px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--sun),var(--sun-deep));background-clip:padding-box;border:2px solid transparent}
html{scrollbar-width:thin;scrollbar-color:var(--sky-deep) rgba(11,24,50,.05)}

/* ===== Focus rings universels ===== */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--sun);outline-offset:3px;border-radius:6px}

/* ===== Screen reader only (SEO + a11y) ===== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.grain{position:fixed;inset:0;z-index:98;pointer-events:none;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='180'%20height='180'%3E%3Cfilter%20id='n'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.86'%20numOctaves='3'%20stitchTiles='stitch'/%3E%3CfeColorMatrix%20type='saturate'%20values='0'/%3E%3C/filter%3E%3Crect%20width='100%25'%20height='100%25'%20filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}
.clouds{display:none}
.cloud{position:absolute;color:#fff;left:0;animation:drift linear infinite;will-change:transform;filter:blur(5px)}
@keyframes drift{from{transform:translateX(-44vw)}to{transform:translateX(144vw)}}
.cloud.cA{top:7%;width:220px;opacity:.4;animation-duration:94s;animation-delay:-12s}
.cloud.cB{top:21%;width:135px;opacity:.26;animation-duration:130s;animation-delay:-66s}
.cloud.cC{top:39%;width:290px;opacity:.36;animation-duration:106s;animation-delay:-34s}
.cloud.cD{top:55%;width:165px;opacity:.22;animation-duration:152s;animation-delay:-95s}
.cloud.cE{top:71%;width:240px;opacity:.34;animation-duration:118s;animation-delay:-48s}
.cloud.cF{top:86%;width:145px;opacity:.26;animation-duration:140s;animation-delay:-20s}

.daisy{display:inline-block;color:var(--white)}

/* ===== Kicker ===== */
.kicker{display:inline-flex;align-items:center;gap:9px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sun)}
.kicker svg.daisy{width:18px;height:18px;color:var(--sun)}
.kicker.on-dark{color:var(--sun)}
.kicker.center{justify-content:center}

/* ===== Buttons ===== */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1rem;padding:15px 30px;border-radius:100px;cursor:pointer;border:none;white-space:nowrap;overflow:hidden;transition:transform .32s cubic-bezier(.34,1.45,.5,1),box-shadow .3s var(--ease),background .3s var(--ease),color .3s var(--ease)}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);pointer-events:none;transition:left .6s var(--ease)}
.btn:hover{transform:translateY(-3px) scale(1.03)}
.btn:hover::after{left:150%}
.btn:active{transform:translateY(-1px) scale(.97);transition-duration:.1s}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #fff,0 0 0 6px var(--sky-deep)}
.btn svg{transition:transform .32s cubic-bezier(.34,1.45,.5,1)}
.btn:hover svg{transform:translateX(4px)}
.btn-sun{background:var(--sun);color:var(--ink);box-shadow:0 12px 28px rgba(146,168,36,.4)}
.btn-sun:hover{background:var(--sun-deep);box-shadow:0 20px 44px rgba(146,168,36,.52)}
.btn-ink{background:var(--ink);color:var(--white)}
.btn-ink:hover{background:var(--navy);box-shadow:0 16px 34px rgba(11,24,50,.34)}
.btn-ghost-w{background:rgba(255,255,255,.16);color:var(--white);border:2px solid rgba(255,255,255,.6)}
.btn-ghost-w:hover{background:var(--white);color:var(--sky-deep)}
.btn-ghost{background:var(--white);color:var(--ink);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--sky);box-shadow:var(--shadow-sm,0 10px 26px rgba(21,57,91,.09))}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 0;transition:all .35s var(--ease)}
.nav.scrolled{padding:10px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;border-radius:100px;padding:8px 8px 8px 24px;transition:background .35s var(--ease),box-shadow .35s var(--ease)}
.nav.scrolled .nav-inner{background:rgba(255,255,255,.96);box-shadow:var(--shadow-sm)}
.logo{display:flex;align-items:center;gap:9px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.62rem;color:var(--white);letter-spacing:-.01em;transition:color .35s var(--ease)}
.logo .daisy{width:30px;height:30px;flex-shrink:0}
.nav.scrolled .logo{color:var(--ink)}
.logo-img{height:34px;width:auto;display:block;filter:drop-shadow(0 2px 7px rgba(11,24,50,.22))}
.logo-dark{display:none}
.nav.scrolled .logo-light{display:none}
.nav.scrolled .logo-dark{display:block;filter:brightness(0) invert(47%) sepia(64%) saturate(560%) hue-rotate(174deg) brightness(95%) contrast(90%)}
.footer .logo-img{height:40px;filter:none}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a:not(.btn){font-weight:600;font-size:.96rem;color:var(--white);position:relative;transition:color .25s}
.nav.scrolled .nav-links a:not(.btn){color:var(--ink)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2.5px;background:var(--sun);border-radius:2px;transition:width .25s var(--ease)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:101}
.nav-toggle span{display:block;width:26px;height:2.6px;background:var(--white);border-radius:3px;transition:.3s var(--ease)}
.nav.scrolled .nav-toggle span{background:var(--ink)}
.nav-toggle span+span{margin-top:6px}
.nav .btn{padding:13px 22px;font-size:.95rem}
.mobile-menu{position:fixed;inset:0;background:linear-gradient(165deg,var(--sky),var(--sky-deep));z-index:99;display:flex;flex-direction:column;justify-content:flex-start;gap:4px;padding:92px 44px 48px;overflow-y:auto;transform:translateX(100%);transition:transform .42s var(--ease)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a:not(.btn){font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:2rem;color:var(--white);padding:11px 0;border-bottom:1px solid rgba(255,255,255,.22)}
.mobile-menu .btn{margin-top:24px;justify-content:center}

/* ===== Menu déroulant (desktop) ===== */
.nav-item{position:relative;display:flex;align-items:center}
.nav-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.96rem;color:var(--white);padding:0;transition:color .25s}
.nav.scrolled .nav-trigger{color:var(--ink)}
.nav-trigger svg{width:10px;height:10px;transition:transform .25s var(--ease)}
.nav-item:hover .nav-trigger svg,.nav-item:focus-within .nav-trigger svg{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:236px;background:#fff;border-radius:18px;box-shadow:0 22px 50px rgba(21,57,91,.2);padding:9px;display:flex;flex-direction:column;gap:1px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:60}
.dropdown::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-links .dropdown a{font-family:'DM Sans',sans-serif;font-weight:600;font-size:.92rem;color:var(--ink)!important;padding:11px 16px;border-radius:11px;white-space:nowrap;transition:background .2s,color .2s}
.nav-links .dropdown a::after{display:none!important}
.nav-links .dropdown a:hover{background:var(--sky-pale);color:var(--sky-deep)!important}

/* ===== Méga-menu (panneau développé avec emoji + description) ===== */
.dropdown.mega{width:500px;min-width:0;left:0;transform:translateY(8px);display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:12px}
.nav-item:hover .dropdown.mega,.nav-item:focus-within .dropdown.mega{transform:translateY(0)}
.dropdown.dd-right{left:auto;right:0;transform:translateY(8px)}
.nav-item:hover .dropdown.dd-right,.nav-item:focus-within .dropdown.dd-right{transform:translateY(0)}
.nav-item.nav-cta{align-items:center}
.nav-links .dropdown.mega a{display:flex;align-items:flex-start;gap:12px;padding:11px 13px;border-radius:13px}
.dropdown.mega .dd-ico{font-size:1.4rem;line-height:1;flex:none;margin-top:1px;filter:saturate(1.1)}
.dropdown.mega .dd-tt{display:flex;flex-direction:column;gap:2px;min-width:0}
.dropdown.mega .dd-tt b{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.94rem;color:var(--ink);transition:color .2s}
.dropdown.mega .dd-tt em{font-style:normal;font-size:.78rem;line-height:1.3;color:var(--ink-soft);font-weight:500}
.nav-links .dropdown.mega a:hover .dd-tt b{color:var(--sky-deep)}

/* ===== Sous-titres groupes (menu mobile) ===== */
.mobile-menu .m-label{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sun);margin:18px 0 2px;padding:0}
.mobile-menu a.m-sub{font-size:1.35rem;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.16)}

/* ===== Sélecteur de langue ===== */
.nav-links a.lang-switch{display:inline-flex;align-items:center;gap:5px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.03em;color:var(--white);border:1.6px solid rgba(255,255,255,.45);padding:7px 12px;border-radius:100px;transition:background .25s,color .25s,border-color .25s}
.nav.scrolled .nav-links a.lang-switch{color:var(--ink);border-color:rgba(21,57,91,.2)}
.nav-links a.lang-switch:hover{background:var(--sun);color:var(--ink)!important;border-color:var(--sun)}
.nav-links a.lang-switch::after{display:none!important}
.mobile-menu a.lang-switch{margin-top:22px;align-self:flex-start;border:1.6px solid rgba(255,255,255,.5);border-radius:100px;padding:9px 18px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;color:#fff;font-size:1rem}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:150px 0 100px;background:radial-gradient(120% 80% at 88% -6%,rgba(255,219,130,.5),rgba(255,219,130,0) 55%),radial-gradient(90% 55% at 50% 112%,rgba(255,255,255,.14),transparent 60%),linear-gradient(168deg,#56A2D2 0%,#3F93C4 46%,#29688F 100%);border-radius:0 0 var(--r-xl) var(--r-xl);overflow:hidden}
.hero .sun{position:absolute;top:-86px;right:-66px;width:320px;height:320px;z-index:1}
.hero .sun .rays{position:absolute;inset:0;border-radius:50%;background:repeating-conic-gradient(from 0deg,rgba(255,224,138,.6) 0deg 5deg,transparent 5deg 30deg);-webkit-mask:radial-gradient(circle,transparent 44%,#000 46%,#000 60%,transparent 63%);mask:radial-gradient(circle,transparent 44%,#000 46%,#000 60%,transparent 63%);animation:spin 64s linear infinite}
.hero .sun .core{position:absolute;inset:64px;border-radius:50%;background:radial-gradient(circle,#F8FC83 0%,var(--sun) 52%,rgba(218,239,82,.36) 74%,transparent 82%)}
@keyframes spin{to{transform:rotate(360deg)}}
.hero .h-cloud{position:absolute;color:#fff;animation:drift linear infinite;z-index:1;filter:blur(2.5px)}
.hc1{top:17%;width:210px;opacity:.95;animation-duration:82s;animation-delay:-8s}
.hc2{top:64%;width:160px;opacity:.72;animation-duration:112s;animation-delay:-50s}
.hc3{top:40%;width:115px;opacity:.55;animation-duration:134s;animation-delay:-92s}
/* Hero horizontal 2 colonnes · tout visible above the fold */
.hero-grid{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(0,1fr);gap:36px;align-items:center;width:100%;position:relative;z-index:3}
.hero-text{min-width:0}
.hero-tag{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.24);border:1.5px solid rgba(255,255,255,.45);padding:8px 16px;border-radius:100px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.8rem;color:var(--white);margin-bottom:18px}
.hero-tag .daisy{width:18px;height:18px}
.hero h1{margin-bottom:10px;line-height:1}
.hero h1 img{width:clamp(220px,30vw,360px);height:auto;display:block;filter:drop-shadow(0 14px 40px rgba(11,24,50,.3))}
.hero-tagline{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:clamp(1.3rem,2.6vw,1.85rem);color:var(--sun);line-height:1.12;margin-bottom:14px}
.hero p.lede{font-size:1rem;color:rgba(255,255,255,.96);max-width:38em;margin-bottom:20px;line-height:1.55}
.hero-facts{display:flex;flex-wrap:wrap;align-items:center;gap:9px 15px;margin:0 0 26px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.96rem;color:rgba(255,255,255,.94)}
.hero-facts .f{display:inline-flex;align-items:center;gap:8px}
.hero-facts svg{width:18px;height:18px;color:var(--sun);flex:none}
.hero-facts .sep{opacity:.4;font-weight:700}
.cd-intro{display:inline-flex;align-items:center;gap:8px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.76rem;letter-spacing:.09em;text-transform:uppercase;color:var(--sun);margin:0 0 9px}
.cd-intro .daisy{width:16px;height:16px;color:var(--sun)}
.countdown{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 20px}
.cd-cell{background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.34);border-radius:var(--r-sm);padding:10px 6px;min-width:68px;text-align:center}
.cd-num{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.65rem;color:var(--white);line-height:1;font-variant-numeric:tabular-nums}
.cd-lab{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sun);margin-top:5px}
.cd-done{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.4rem;color:var(--white)}
.hero-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.hero-meta .item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.32);padding:9px 14px;border-radius:var(--r-sm)}
.hero-meta .item svg{width:20px;height:20px;color:var(--sun)}
.hero-meta .item small{display:block;font-size:.62rem;color:rgba(255,255,255,.8);font-family:'Bricolage Grotesque',sans-serif;font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.hero-meta .item b{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.92rem;color:var(--white)}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:0}
.hero-cta .btn{padding:13px 24px;font-size:.92rem}

/* Florette · colonne droite, hauteur intégrée */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:380px}
.florette-wrap{position:relative;width:100%;max-width:360px;aspect-ratio:1;display:grid;place-items:center}
.florette-wrap .halo{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.55),transparent 65%)}
.florette-svg{position:relative;width:88%;max-width:300px;height:auto;filter:drop-shadow(0 26px 34px rgba(11,24,50,.3));animation:bob 6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-17px)}}
.florette-wrap .d-float{position:absolute;animation:bob 5s ease-in-out infinite}
.hd1{top:4%;left:2%;width:48px;animation-delay:.4s}
.hd2{bottom:8%;right:0%;width:62px;animation-delay:1.2s}
.hd3{top:18%;right:6%;width:36px;animation-delay:2s}

/* ===== Section ===== */
.sec{padding:112px 0;position:relative}
.sec-head{max-width:680px;margin-bottom:52px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2.4rem,5.4vw,4rem);margin:14px 0 14px;color:var(--white)}
.sec-head h2 .hl{color:var(--sun)}
.sec-head p{font-size:1.09rem;color:rgba(255,255,255,.88)}

/* ===== Concept ===== */
.concept-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;margin-bottom:56px}
.story-card{background:var(--white);border-radius:var(--r-lg);padding:44px;position:relative;box-shadow:0 32px 70px rgba(11,24,50,.22),0 1px 0 rgba(255,255,255,1) inset;border:1px solid rgba(21,57,91,.06)}
.story-card .big-daisy{position:absolute;top:-30px;right:-16px;width:88px;height:88px;color:var(--sun);filter:drop-shadow(0 8px 16px rgba(146,168,36,.3))}
.story-card p{font-size:1.14rem;color:var(--ink)}
.story-card p .em{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;color:var(--sky-deep)}
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.promesse-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.value-card{background:var(--white);border-radius:var(--r-md);padding:32px 26px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.value-card:hover{transform:translateY(-9px);box-shadow:var(--shadow)}
.value-card .v-ic{width:60px;height:60px;border-radius:var(--r-sm);display:grid;place-items:center;margin-bottom:18px;font-size:1.65rem}
.value-card h3{font-size:1.32rem;color:var(--ink);margin-bottom:7px}
.value-card p{font-size:.95rem;color:var(--ink-soft)}

/* ===== Lieu ===== */
.lieu-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.lieu-grid p{color:rgba(255,255,255,.94);font-size:1.08rem;margin-bottom:15px}
.lieu-grid p strong{color:var(--sun);font-weight:700}
.note-soft{font-size:.88rem;color:rgba(255,255,255,.78);font-style:italic;margin-top:12px}
.place-card{background:linear-gradient(155deg,var(--sky) 0%,var(--sky-deep) 70%,#1F5E96 100%);border-radius:var(--r-lg);padding:46px;color:var(--white);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.place-card .pc-cloud{position:absolute;color:rgba(255,255,255,.16);width:170px;top:22px;right:-34px}
.place-card .pin{width:68px;height:68px;border-radius:50%;background:var(--sun);display:grid;place-items:center;margin-bottom:20px;position:relative;box-shadow:0 10px 24px rgba(146,168,36,.4)}
.place-card h3{font-size:2.1rem;color:var(--white);margin-bottom:4px;position:relative}
.place-card .sub{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;color:var(--sun);margin-bottom:20px;position:relative}
.tags{display:flex;gap:10px;flex-wrap:wrap;position:relative}
.tag-pill{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);padding:8px 15px;border-radius:100px;font-size:.86rem;font-weight:600;transition:transform .25s var(--ease),background .25s var(--ease)}
.tag-pill:hover{transform:translateY(-2px);background:rgba(255,255,255,.26)}

/* ===== Espaces ===== */
.espaces-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:1024px){.espaces-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.espaces-grid{grid-template-columns:1fr}}
.espace-card{background:var(--white);border-radius:var(--r-lg);padding:32px 28px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.espace-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.espace-card .num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:4.8rem;background:linear-gradient(135deg,rgba(77,169,223,.22),rgba(218,239,82,.18));-webkit-background-clip:text;background-clip:text;color:transparent;position:absolute;top:10px;right:22px;line-height:1;z-index:0;letter-spacing:-.02em}
.espace-card .e-ic{width:64px;height:64px;border-radius:var(--r-sm);display:grid;place-items:center;margin-bottom:18px;font-size:1.75rem;position:relative;z-index:1}
.espace-card .e-pic{width:118px;height:118px;object-fit:contain;margin-bottom:14px;position:relative;z-index:1;filter:drop-shadow(0 14px 24px rgba(21,57,91,.18))}
.espace-card .e-kicker{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sky);position:relative;z-index:1}
.espace-card h3{font-size:1.55rem;color:var(--ink);margin:5px 0 11px;position:relative;z-index:1}
.espace-card p{font-size:.93rem;color:var(--ink-soft);margin-bottom:16px;position:relative;z-index:1}
.espace-card ul{list-style:none;display:flex;flex-direction:column;gap:9px;position:relative;z-index:1}
.espace-card li{display:flex;align-items:flex-start;gap:11px;font-size:.88rem;font-weight:500}
.espace-card li .daisy{width:18px;height:18px;color:var(--sky);flex-shrink:0;margin-top:2px}

/* ===== Services & pratique (pictos plush) ===== */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
@media(max-width:980px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.services-grid{grid-template-columns:1fr}}
.service-card{background:var(--white);border-radius:var(--r-md);padding:26px 22px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:flex;flex-direction:column;align-items:center;gap:8px;min-height:240px}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.service-card .s-pic{width:96px;height:96px;object-fit:contain;margin-bottom:6px;filter:drop-shadow(0 12px 20px rgba(21,57,91,.16))}
.service-card h4{font-size:1.15rem;color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;font-weight:700}
.service-card p{font-size:.86rem;color:var(--ink-soft);line-height:1.5}
.service-card a.s-link,.service-card span.s-link{margin-top:auto;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.78rem;color:var(--sky-deep);letter-spacing:.04em;display:inline-flex;align-items:center;gap:5px;text-decoration:none;border-bottom:1.5px solid transparent;transition:border-color .2s;padding:6px 0;min-height:24px}
.service-card a.s-link:hover{border-bottom-color:var(--sky-deep)}

/* Décor picto dans en-têtes de section (Programme · Billetterie) */
.sec-pic{display:block;width:88px;height:88px;object-fit:contain;margin:0 auto 14px;filter:drop-shadow(0 12px 22px rgba(21,57,91,.18))}

/* ===== Prolonge ton week-end · teaser compact ===== */
.sejour-teaser{background:var(--white);border-radius:var(--r-lg);padding:46px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center;overflow:hidden}
@media(max-width:900px){.sejour-teaser{grid-template-columns:1fr;padding:34px 28px;gap:30px}}
.st-body h2{font-size:clamp(1.8rem,3.6vw,2.4rem);color:var(--ink);margin:12px 0 14px;line-height:1.1}
.st-body h2 .hl{color:var(--sky)}
.st-body p{color:var(--ink-soft);font-size:1rem;line-height:1.6;margin-bottom:18px}
.st-body p strong{color:var(--ink);font-weight:700}
.st-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.st-tag{background:var(--sky-pale);color:var(--sky-deep);padding:6px 13px;border-radius:100px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.82rem;display:inline-flex;align-items:center;gap:6px;transition:transform .25s var(--ease),background .25s var(--ease)}
.st-tag:hover{transform:translateY(-2px);background:var(--sun-pale);color:var(--sun-deep)}
.st-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.st-link{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;color:var(--sky-deep);font-size:.88rem;border-bottom:2px solid transparent;transition:border-color .2s}
.st-link:hover{border-bottom-color:var(--sky-deep)}
.st-visual{position:relative;height:280px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:10px}
.st-card{border-radius:var(--r-md);padding:14px;display:flex;align-items:flex-end;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1rem;letter-spacing:-.01em;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease)}
.st-card:hover{transform:translateY(-4px)}
.st-card-1{grid-column:1;grid-row:1}
.st-card-2{grid-column:2;grid-row:1}
.st-card-3{grid-column:1;grid-row:2}
.st-card-4{grid-column:2;grid-row:2}
@media(max-width:480px){.st-visual{height:220px}.st-card{font-size:.9rem}}

/* ===== Florette · moment crépusculaire ===== */
.twilight{background:linear-gradient(165deg,#2E7FB8 0%,#1E5E8C 55%,#15395B 100%);color:var(--white);overflow:hidden;border-radius:var(--r-xl);max-width:1280px;margin:0 auto;box-shadow:0 32px 70px rgba(11,24,50,.22)}
@media(max-width:1340px){.twilight{margin:0 24px}}
@media(max-width:680px){.twilight{margin:0 12px;border-radius:var(--r-lg)}}
.stars{position:absolute;inset:0;pointer-events:none;animation:twinkle 5.5s ease-in-out infinite;
  background-image:
   radial-gradient(1.7px 1.7px at 32px 44px,#fff,transparent),
   radial-gradient(1.4px 1.4px at 128px 96px,rgba(255,255,255,.75),transparent),
   radial-gradient(2.1px 2.1px at 220px 150px,#fff,transparent),
   radial-gradient(1.4px 1.4px at 290px 60px,rgba(255,255,255,.8),transparent),
   radial-gradient(1.7px 1.7px at 360px 210px,#fff,transparent),
   radial-gradient(1.3px 1.3px at 90px 240px,rgba(255,255,255,.7),transparent),
   radial-gradient(1.8px 1.8px at 440px 110px,#fff,transparent),
   radial-gradient(1.4px 1.4px at 520px 200px,rgba(255,255,255,.7),transparent);
  background-size:560px 300px;
}
@keyframes twinkle{0%,100%{opacity:.55}50%{opacity:1}}
.florette-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center;position:relative;z-index:2}
.florette-stage{position:relative;display:grid;place-items:center;height:460px}
.florette-stage .glow{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(218,239,82,.42),rgba(218,239,82,.1) 45%,transparent 68%)}
.florette-stage .florette-svg{width:330px;filter:drop-shadow(0 0 40px rgba(255,210,120,.45)) drop-shadow(0 24px 30px rgba(0,0,0,.35));animation:bob 6.5s ease-in-out infinite}
.florette-stage .fd{position:absolute;width:48px;color:var(--sun)}
.twilight .kicker{color:var(--sun)}
.twilight .sec-head h2{color:var(--white)}
.twilight .sec-head h2 em{font-style:normal;color:var(--sun)}
.florette-txt p{font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:15px}
.florette-txt .quote{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:var(--r-md);padding:32px 36px 32px 64px;margin:22px 0;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.28rem;color:var(--white);line-height:1.36;position:relative}
.florette-txt .quote::before{content:"\201C";position:absolute;top:-8px;left:18px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:5.4rem;color:var(--sun);line-height:1;opacity:.95}

/* ===== Programme ===== */
.timeline{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.tl-row{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;padding:4px 0}
.tl-time{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.5rem;color:var(--ink);background:var(--sun);padding:14px 22px;border-radius:100px;min-width:96px;text-align:center;box-shadow:0 10px 22px rgba(146,168,36,.32);letter-spacing:-.01em;line-height:1;align-self:flex-start;margin-top:8px;transition:background .3s var(--ease)}
/* Le jour avance sur la timeline · pastilles vertes le jour, bleues le soir */
.timeline .tl-row:nth-child(6) .tl-time,
.timeline .tl-row:nth-child(7) .tl-time{background:linear-gradient(135deg,#3F93C4,#2E7FB8);color:var(--white);box-shadow:0 10px 22px rgba(46,127,184,.42)}
.tl-card{background:var(--white);border-radius:var(--r-md);padding:20px 26px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.tl-card:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.tl-card .tl-tag{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sky-deep);display:inline-block}
.tl-card h4{font-size:1.3rem;color:var(--ink);margin:6px 0 8px;line-height:1.18}
.tl-card p{font-size:.94rem;color:var(--ink-soft);line-height:1.6}
.prog-foot-wrap{text-align:center}
.prog-foot{margin-top:50px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;color:var(--ink);font-size:1.02rem;background:var(--white);border-radius:100px;padding:16px 34px;display:inline-block;box-shadow:0 18px 40px rgba(11,24,50,.16);border:1px solid rgba(255,255,255,.55)}
@media(max-width:480px){.prog-foot{font-size:.92rem;padding:13px 24px;line-height:1.4}}

/* ===== Public ===== */
.public-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.aud-card{background:var(--white);border-radius:var(--r-md);padding:30px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.aud-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.aud-card .a-ic{font-size:2rem;margin-bottom:11px}
.aud-card h4{font-size:1.2rem;color:var(--ink);margin-bottom:5px}
.aud-card p{font-size:.92rem;color:var(--ink-soft)}

/* ===== Qui sommes-nous ===== */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.about-grid .txt p{color:rgba(255,255,255,.94);font-size:1.08rem;margin-bottom:15px}
.about-grid .txt p strong{color:var(--sun);font-weight:700}
.about-grid .vals{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.about-grid .vals .v{background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-sm);padding:11px 19px;border-radius:100px;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.9rem;transition:transform .25s var(--ease),background .25s var(--ease)}
.about-grid .vals .v:hover{transform:translateY(-2px);background:rgba(255,255,255,.26)}
.manifesto{background:linear-gradient(150deg,#2E7FB8,#15395B);border-radius:var(--r-lg);padding:46px;color:var(--white);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.manifesto .m-stars{position:absolute;inset:0;opacity:.6;background-image:radial-gradient(1.5px 1.5px at 40px 30px,#fff,transparent),radial-gradient(1.5px 1.5px at 150px 90px,#fff,transparent),radial-gradient(1.5px 1.5px at 90px 140px,#fff,transparent);background-size:200px 180px}
.manifesto .m-in{position:relative;z-index:2}
.manifesto .tag{display:inline-flex;align-items:center;gap:8px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sun);margin-bottom:18px}
.manifesto blockquote{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.46rem;line-height:1.34;color:var(--white);margin-bottom:24px}
.manifesto .sign{display:flex;align-items:center;gap:14px;border-top:1px solid rgba(255,255,255,.22);padding-top:22px}
.manifesto .sign .av{width:56px;height:56px;border-radius:50%;background:var(--sun);display:grid;place-items:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.25rem;color:var(--ink);flex-shrink:0}
.manifesto .sign b{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.06rem;color:var(--white)}
.manifesto .sign span{font-size:.9rem;color:rgba(255,255,255,.78)}

/* ===== Infos ===== */
.infos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.info-card{background:var(--white);border-radius:var(--r-md);padding:32px 26px;box-shadow:var(--shadow-sm)}
.info-card .i-ic{width:54px;height:54px;border-radius:var(--r-sm);background:var(--sky-pale);display:grid;place-items:center;margin-bottom:15px}
.info-card .i-ic svg{width:27px;height:27px;color:var(--sky)}
.info-card h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.77rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sky);margin-bottom:7px}
.info-card .big{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.45rem;color:var(--ink);margin-bottom:3px}
.info-card p{font-size:.92rem;color:var(--ink-soft)}
.info-card ul{list-style:none;margin-top:4px}
.info-card li{font-size:.92rem;color:var(--ink-soft);padding:3px 0 3px 17px;position:relative}
.info-card li::before{content:"";position:absolute;left:0;top:12px;width:7px;height:7px;border-radius:50%;background:var(--sun)}

/* ===== Partenaires ===== */
.part-types{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:32px}
.part-type{background:var(--white);border-radius:var(--r-md);padding:36px;box-shadow:var(--shadow-sm);transition:transform .32s var(--ease),box-shadow .32s var(--ease)}
.part-type:hover{transform:translateY(-9px);box-shadow:var(--shadow)}
.part-type .pt-ic{width:60px;height:60px;border-radius:var(--r-sm);background:var(--sky-pale);display:grid;place-items:center;font-size:1.6rem;margin-bottom:16px}
.part-type h3{font-size:1.36rem;color:var(--ink);margin-bottom:12px}
.part-type ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.part-type li{display:flex;align-items:flex-start;gap:10px;font-size:.93rem;font-weight:500;color:var(--ink-soft)}
.part-type li .daisy{width:16px;height:16px;color:var(--sky);flex-shrink:0;margin-top:3px}
.part-cta{background:linear-gradient(150deg,var(--sky),var(--sky-deep) 70%,#1F5E96);border-radius:var(--r-lg);padding:54px;text-align:center;color:var(--white);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.part-cta .pc-cloud{position:absolute;color:rgba(255,255,255,.15);animation:drift linear infinite;top:18px;width:220px;animation-duration:92s}
.part-cta .inner2{position:relative;z-index:2}
.part-cta h3{font-size:clamp(1.8rem,3.6vw,2.5rem);color:var(--white);margin-bottom:10px}
.part-cta p{color:rgba(255,255,255,.92);max-width:34em;margin:0 auto 26px}
.part-cta .btn-row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}

/* ===== CTA · golden hour ===== */
.cta-card{background:linear-gradient(165deg,#56A2D2 0%,#3F93C4 52%,#2E7FB8 100%);border-radius:var(--r-xl);padding:88px 50px 96px;text-align:center;color:var(--white);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta-card .cta-stars{position:absolute;top:0;left:0;right:0;height:55%;opacity:.22;background-image:radial-gradient(1.6px 1.6px at 40px 30px,#fff,transparent),radial-gradient(1.5px 1.5px at 160px 80px,#fff,transparent),radial-gradient(1.8px 1.8px at 280px 50px,#fff,transparent),radial-gradient(1.4px 1.4px at 360px 120px,#fff,transparent),radial-gradient(1.5px 1.5px at 90px 110px,#fff,transparent);background-size:420px 200px}
.cta-card .set-sun{position:absolute;left:50%;bottom:-150px;transform:translateX(-50%);width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(218,239,82,.55) 0%,rgba(218,239,82,.3) 42%,rgba(218,239,82,.12) 64%,transparent 78%)}
.cta-card .c-cloud{position:absolute;color:rgba(255,255,255,.28);animation:drift linear infinite}
.cc1{top:46px;width:170px;animation-duration:88s}
.cc2{top:120px;width:230px;animation-duration:124s;animation-delay:-44s}
.cta-card .inner{position:relative;z-index:3}
.cta-card h2{font-size:clamp(2.6rem,6vw,4.4rem);color:var(--white);margin-bottom:14px;text-shadow:0 8px 28px rgba(11,24,50,.3)}
.cta-card h2 em{font-style:normal;color:var(--sun)}
.cta-card p{font-size:1.14rem;color:rgba(255,255,255,.95);max-width:33em;margin:0 auto 32px}
.signup{display:flex;gap:11px;max-width:480px;margin:0 auto;flex-wrap:wrap}
.signup input{flex:1;min-width:220px;padding:16px 24px;border-radius:100px;border:none;font-family:'DM Sans',sans-serif;font-size:1rem;background:var(--white);color:var(--ink);box-shadow:var(--shadow)}
.signup input::placeholder{color:rgba(21,57,91,.55)}
.signup input:focus{outline:none;box-shadow:0 0 0 3px var(--sun),0 14px 30px rgba(11,24,50,.2)}
.cta-card .smallnote{font-size:.86rem;color:rgba(255,255,255,.86);margin-top:15px}
/* billets */
.tickets{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:32px 0 16px;text-align:left;align-items:stretch}
.ticket{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-md);padding:22px 20px;position:relative;color:var(--ink);box-shadow:var(--shadow);border:2px solid transparent;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .25s var(--ease)}
.ticket:hover{transform:translateY(-6px);box-shadow:0 28px 56px rgba(11,24,50,.28)}
/* la surbrillance verte suit la sélection (clic) */
.ticket.selected{border-color:var(--sun);box-shadow:0 0 0 6px rgba(218,239,82,.2),0 30px 60px rgba(11,24,50,.32);transform:translateY(-8px)}
.ticket.selected:hover{transform:translateY(-12px)}
.ticket .t-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--sun),#C8E03A);color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.04em;padding:6px 15px;border-radius:100px;white-space:nowrap;box-shadow:0 6px 18px rgba(146,168,36,.4)}
.ticket .t-pick{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;background:var(--sun);color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.72rem;padding:4px 11px;border-radius:100px;margin-bottom:10px;animation:fadeIn .3s var(--ease)}
.ticket .t-ic{font-size:1.5rem;margin-bottom:4px}
.ticket h3{font-size:1.25rem;color:var(--ink);margin-bottom:2px}
.ticket .t-hours{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;color:var(--sky);margin-bottom:12px}
.ticket .t-price{display:flex;align-items:baseline;flex-wrap:wrap;gap:2px 8px;line-height:1}
.ticket .t-price .amt{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:2.1rem;color:var(--ink);line-height:1}
.ticket .t-price .was{font-size:1.05rem;font-weight:600;color:var(--ink-soft);text-decoration:line-through}
.ticket .t-price .t-save{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.72rem;background:var(--sky-pale);color:var(--sky-deep);padding:4px 10px;border-radius:100px;white-space:nowrap;width:100%;margin-top:6px}
.ticket.selected .t-price .t-save{background:var(--sun);color:var(--ink)}
.ticket .t-full{font-size:.82rem;color:var(--ink-soft);margin:8px 0 14px}
.ticket .t-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.ticket .t-list li{display:flex;gap:8px;align-items:flex-start;font-size:.85rem;font-weight:500;line-height:1.35}
.ticket .t-list li .daisy{width:13px;height:13px;color:var(--sky);flex-shrink:0;margin-top:3px}
.ticket .t-btn{margin-top:auto;display:block;text-align:center;padding:12px;border-radius:100px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.88rem;background:var(--sky-pale);color:var(--sky-deep);cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.ticket .t-btn:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(45,127,184,.32)}
.ticket.selected .t-btn{background:var(--sun);color:var(--ink)}
.ticket.selected .t-btn:hover{box-shadow:0 16px 32px rgba(146,168,36,.5)}
.ticket-note{color:rgba(255,255,255,.96);font-size:.93rem;margin-bottom:32px}
.signup-block{border-top:1px solid rgba(255,255,255,.26);padding-top:30px;max-width:540px;margin:0 auto}
.signup-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.18rem;color:var(--white);margin-bottom:4px}
.signup-block>p{color:rgba(255,255,255,.9);margin-bottom:16px;font-size:.98rem}
.signup-perks{list-style:none;display:flex;flex-direction:column;gap:9px;max-width:330px;margin:0 auto 20px;text-align:left}
.signup-perks li{display:flex;gap:9px;align-items:center;font-size:.93rem;color:rgba(255,255,255,.96);font-weight:500}
.signup-perks li .daisy{width:15px;height:15px;color:var(--sun);flex-shrink:0}
.signup-block .signup-fine{font-size:.8rem;color:rgba(255,255,255,.68);margin:14px 0 0}
.signup-success{display:flex;align-items:center;gap:16px;background:rgba(218,239,82,.14);border:1px solid rgba(218,239,82,.38);border-radius:var(--r-md);padding:26px 30px;max-width:520px;margin:18px auto;animation:fadeIn .4s var(--ease)}
.signup-success p{line-height:1.6}
.signup-success p strong{display:inline-block;margin-bottom:4px}
.signup-success .daisy{width:28px;height:28px;color:var(--sun);flex-shrink:0;margin-top:2px}
.signup-success p{margin:0;color:#fff;font-size:.95rem;line-height:1.5;text-align:left}
.signup-success p strong{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;color:var(--sun);font-size:1.02rem}
.signup-success p span{color:rgba(255,255,255,.85)}

/* ===== Line-up teaser (noms floutés) ===== */
.lineup-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.lu-card{position:relative;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:var(--r-md);padding:30px 20px 26px;text-align:center;overflow:hidden;transition:transform .3s var(--ease),background .3s var(--ease)}
.lu-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.18)}
.lu-card::after{content:"🔒";position:absolute;top:11px;right:13px;font-size:.85rem;opacity:.55}
.lu-tag{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sun);margin-bottom:10px;filter:blur(3px);user-select:none;pointer-events:none}
.lu-name{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.32rem;color:#fff;filter:blur(7px);user-select:none;pointer-events:none}
.lineup-foot{text-align:center;margin-top:32px;color:rgba(255,255,255,.9);font-family:'Bricolage Grotesque',sans-serif;font-weight:600}
@media(max-width:768px){.lineup-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== Formulaire (bénévoles, contact…) ===== */
.form-card{background:var(--white);border-radius:var(--r-lg);padding:40px;max-width:640px;margin:0 auto;box-shadow:var(--shadow);text-align:left}
.form-row{margin-bottom:18px}
.form-row label.fl{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:7px}
.form-row input[type=text],.form-row input[type=email],.form-row input[type=tel],.form-row textarea{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:var(--r-sm);font-family:'DM Sans',sans-serif;font-size:1rem;color:var(--ink);background:#fff;transition:border-color .2s}
.form-row input:focus,.form-row textarea:focus{border-color:var(--sky);outline:none}
.form-row textarea{min-height:110px;resize:vertical}
.form-checks{display:flex;flex-wrap:wrap;gap:10px}
.form-checks label{display:inline-flex;align-items:center;gap:8px;background:var(--sky-pale);border:1.5px solid transparent;border-radius:100px;padding:10px 16px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9rem;color:var(--ink);cursor:pointer;margin:0}
.form-checks input{accent-color:var(--sky-deep);width:16px;height:16px}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}
.form-success{background:rgba(218,239,82,.16);border:1px solid rgba(218,239,82,.45);border-radius:var(--r-md);padding:26px 28px;text-align:center;color:var(--ink);font-size:1.02rem;line-height:1.6}
.form-success strong{font-family:'Bricolage Grotesque',sans-serif;color:var(--sun-deep)}

/* ===== Transition de page · bouffée de nuages ===== */
.fx-veil{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0;visibility:hidden;background:radial-gradient(circle at 50% 55%,#fff 0%,#fff 40%,rgba(231,244,251,.92) 64%,rgba(255,255,255,0) 84%)}
.fx-veil .fx-cloud{position:absolute;color:#fff;filter:blur(2px);opacity:0;will-change:transform,opacity}
.fx-veil.fx-cover{visibility:visible;pointer-events:all;animation:fxFadeIn .48s var(--ease) forwards}
.fx-veil.fx-reveal{visibility:visible;opacity:1;animation:fxFadeOut .6s var(--ease) .05s forwards}
@keyframes fxFadeIn{from{opacity:0}to{opacity:1}}
@keyframes fxFadeOut{from{opacity:1}to{opacity:0;visibility:hidden}}
.fx-veil.fx-cover .fx-cloud{animation:fxCloudIn .5s var(--ease) forwards}
.fx-veil.fx-reveal .fx-cloud{animation:fxCloudOut .6s var(--ease) forwards}
@keyframes fxCloudIn{0%{transform:translateY(50px) scale(.6);opacity:0}60%{opacity:1}100%{transform:translateY(0) scale(1.7);opacity:1}}
@keyframes fxCloudOut{0%{transform:scale(1.7);opacity:1}100%{transform:translateY(-60px) scale(2.6);opacity:0}}
@media(prefers-reduced-motion:reduce){.fx-veil{display:none!important}}

/* pétales au clic */
.fx-petal{position:fixed;z-index:9998;pointer-events:none;left:0;top:0;font-size:18px;line-height:1;will-change:transform,opacity;animation:petalPop .9s cubic-bezier(.2,.6,.3,1) forwards}
@keyframes petalPop{0%{transform:translate(-50%,-50%) scale(.3) rotate(0);opacity:1}100%{transform:translate(calc(-50% + var(--tx)),calc(-50% + var(--ty))) scale(1) rotate(var(--rot));opacity:0}}

/* pollen / pétales dérivants en fond */
.fx-pollen{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.fx-pollen .pl{position:absolute;bottom:-50px;color:rgba(255,255,255,.55);animation:pollenRise linear infinite;will-change:transform,opacity}
@keyframes pollenRise{0%{transform:translateY(0) translateX(0) rotate(0);opacity:0}12%{opacity:.65}88%{opacity:.6}100%{transform:translateY(-112vh) translateX(50px) rotate(240deg);opacity:0}}

/* CTA flottant intelligent */
.sticky-cta{position:fixed;z-index:90;left:50%;bottom:18px;transform:translateX(-50%) translateY(130px);opacity:0;transition:transform .42s var(--ease),opacity .3s var(--ease);pointer-events:none}
.sticky-cta.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.sticky-cta .btn{box-shadow:0 16px 44px rgba(11,24,50,.34)}
@media(max-width:560px){.sticky-cta{left:14px;right:14px;bottom:14px;transform:translateY(130px)}.sticky-cta.show{transform:translateY(0)}.sticky-cta .btn{width:100%;justify-content:center}}

/* compteur : pulsation à chaque tick */
.cd-num.tick{animation:cdTick .55s var(--ease)}
@keyframes cdTick{0%{transform:scale(1)}40%{transform:scale(1.16)}100%{transform:scale(1)}}

/* stats animées (B2B) */
.stat-num{font-variant-numeric:tabular-nums}

/* effet tactile au clic */
.btn:active{transform:translateY(1px) scale(.985)}
.ticket:active,.value-card:active{transform:scale(.99)}

/* ===== Galerie / aftermovie teaser ===== */
.media-frame{position:relative;max-width:900px;margin:0 auto;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(150deg,#56A2D2,#3F93C4 55%,#2E7FB8);box-shadow:var(--shadow-lg);display:grid;place-items:center;border:1px solid rgba(255,255,255,.25)}
.media-frame .mf-cloud{position:absolute;color:rgba(255,255,255,.5);filter:blur(2px)}
.media-frame .mf-play{position:relative;z-index:2;width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;box-shadow:0 16px 40px rgba(11,24,50,.3);transition:transform .3s var(--ease)}
.media-frame:hover .mf-play{transform:scale(1.08)}
.media-frame .mf-play svg{width:34px;height:34px;color:var(--sky-deep);margin-left:5px}
.media-frame .mf-label{position:absolute;z-index:2;bottom:22px;left:0;right:0;text-align:center;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1rem;text-shadow:0 4px 16px rgba(11,24,50,.4)}
.media-frame .mf-soon{position:absolute;z-index:2;top:18px;right:18px;background:var(--sun);color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.04em;padding:6px 14px;border-radius:100px}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.signup-error{color:#FFB199;font-size:.92rem;margin:10px 0 0;text-align:center}
/* ===== FAQ ===== */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:21px 24px;display:flex;align-items:center;gap:14px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.04rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .daisy{width:19px;height:19px;color:var(--sun);flex-shrink:0}
.faq-item summary::after{content:"";margin-left:auto;width:10px;height:10px;border-right:2.6px solid var(--sky);border-bottom:2.6px solid var(--sky);transform:rotate(45deg);transition:transform .3s var(--ease);flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(-135deg)}
.faq-item .faq-a{padding:0 24px 22px 57px;color:var(--ink-soft);font-size:.99rem;line-height:1.6}

/* ===== Billetterie ===== */
#billetterie{background:transparent}

/* ===== Footer ===== */
.footer{background:linear-gradient(180deg,#1E5E8C 0%,#15395B 100%);color:rgba(255,255,255,.82);padding:74px 0 30px;margin-top:0;position:relative;overflow:hidden;isolation:isolate;border-top:4px solid var(--sun)}
.footer::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;mix-blend-mode:overlay;opacity:.85;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='180'%20height='180'%3E%3Cfilter%20id='n'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.86'%20numOctaves='3'%20stitchTiles='stitch'/%3E%3CfeColorMatrix%20type='saturate'%20values='0'/%3E%3C/filter%3E%3Crect%20width='100%25'%20height='100%25'%20filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}
.footer .f-stars{display:none}
.footer .wrap{position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:42px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer .logo{color:var(--white);margin-bottom:15px}
.footer .logo .daisy{color:var(--sun)}
.footer p.about{font-size:.95rem;max-width:32em}
.footer h5{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sun);margin-bottom:15px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a{font-size:.95rem;color:rgba(255,255,255,.92);transition:color .2s,transform .2s var(--ease);display:inline-block}
.footer ul a:hover{color:var(--sun);transform:translateX(4px)}
.footer .about{max-width:34em}
.footer p.about{color:rgba(255,255,255,.82)}
.lgl-link{background:none;border:none;color:rgba(255,255,255,.78);font:inherit;cursor:pointer;padding:0;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:3px;transition:color .2s}
.lgl-link:hover{color:var(--sun);text-decoration-color:var(--sun)}
.socials{display:flex;gap:11px;margin-top:18px}
.socials a{width:44px;height:44px;border-radius:var(--r-sm);background:rgba(255,255,255,.1);display:grid;place-items:center;transition:background .25s var(--ease),transform .25s var(--ease)}
.socials a:hover{background:var(--sun);transform:translateY(-3px)}
.socials a svg{width:20px;height:20px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:10px 28px;margin-top:26px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:.84rem;color:rgba(255,255,255,.66);flex-wrap:wrap}
.footer-legal{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-bottom .lgl-link{min-height:0;padding:0;display:inline}

[data-aos]{transition-property:transform,opacity}
@media(prefers-reduced-motion:reduce){
  .cloud,.h-cloud,.c-cloud,.pc-cloud,.florette-svg,.d-float,.stars,.hero .sun .rays{animation:none!important}
  .btn::after{display:none}
  .btn:hover{transform:translateY(-2px)}
  .btn:hover svg{transform:none}
}
@media(max-width:980px){
  .hero-grid,.concept-intro,.lieu-grid,.florette-grid,.about-grid{grid-template-columns:1fr;gap:24px}
  .hero-visual{min-height:auto;order:1}
  .florette-wrap{max-width:240px}
  .hero h1 img{width:clamp(200px,60vw,320px)}
  .hero-meta{gap:10px}
  .hero-meta .item{padding:10px 14px;flex:1 1 auto;min-width:140px}
  .florette-stage{height:340px}
  .values,.infos-grid,.part-types{grid-template-columns:repeat(2,1fr)}
  .espaces-grid{grid-template-columns:1fr}
  .public-grid{grid-template-columns:repeat(2,1fr)}
  .tickets{grid-template-columns:repeat(2,1fr);gap:30px 16px}
  .ticket.selected{transform:none}
}
@media(max-width:480px){
  .countdown{gap:6px}
  .cd-cell{min-width:62px;padding:9px 4px}
  .cd-num{font-size:1.5rem}
  .florette-wrap{max-width:200px}
  .hero-meta .item{padding:9px 12px}
  .hero-meta .item small{font-size:.62rem}
  .hero-meta .item b{font-size:.92rem}
}
@media(max-width:1024px){
  .nav-links{display:none}
  .nav-toggle{display:block}
}
@media(max-width:680px){
  .values,.infos-grid,.public-grid,.part-types,.tickets,.promesse-grid{grid-template-columns:1fr}
  .hero{padding:126px 0 70px}
  .tl-row{grid-template-columns:auto 1fr;gap:14px}
  .tl-time{font-size:1.1rem;padding:11px 16px;min-width:74px;margin-top:6px}
  .tl-card{padding:15px 18px}
  .tl-card h4{font-size:1.1rem}
  .footer-grid{grid-template-columns:1fr}
  .sec{padding:80px 0}
  .cta-card{padding:64px 26px 72px}
  .part-cta{padding:42px}
}

/* ============================================================
   RESPONSIVE POLISH MOBILE & TABLETTE (audit complet)
   ============================================================ */

/* Tap targets & accessibilité (toutes tailles) */
.lgl-link{padding:8px 6px;min-height:44px;display:inline-flex;align-items:center}
.nav-toggle{padding:10px;min-width:44px;min-height:44px}
.st-link{padding:8px 0;min-height:44px;display:inline-flex;align-items:center}
.faq-item summary{min-height:44px}

/* Typo lisible ≥ 12px partout */
.cd-lab{font-size:.66rem}
.hero-meta .item small{font-size:.66rem}
.footer-bottom{font-size:.86rem}

/* ===== TABLETTE (≤ 1024px) ===== */
@media(max-width:1024px){
  .sec{padding:88px 0}
  .concept-intro,.about-grid{gap:36px}
  .values{grid-template-columns:repeat(2,1fr)}
}

/* ===== MOBILE LARGE (≤ 768px) ===== */
@media(max-width:768px){
  /* Performance : couper animations coûteuses */
  .sky-bg::after,.stars,.m-stars,.cta-stars,.f-stars,.hero .sun .rays{animation:none}
  .grain{opacity:.28}
  /* Hero : on dégage la déco du logo blanc (sinon blanc sur blanc, illisible).
     Nuages masqués + soleil rangé dans le coin au-dessus du logo. */
  .hero .h-cloud{display:none}
  .hero .sun{width:180px;height:180px;top:-78px;right:-58px;opacity:.85}
  .hero .sun .core{inset:36px}
  .hero h1 img{filter:drop-shadow(0 8px 22px rgba(11,24,50,.45))}
}

/* ===== MOBILE STANDARD (≤ 680px) ===== */
@media(max-width:680px){
  /* Spacing cards */
  .story-card{padding:32px 24px;border-radius:var(--r-md)}
  .story-card .big-daisy{width:64px;height:64px;top:-22px;right:-8px}
  .place-card,.manifesto{padding:32px 24px;border-radius:var(--r-md)}
  .manifesto blockquote{font-size:1.18rem;line-height:1.36}
  .place-card h3{font-size:1.7rem}
  .florette-txt .quote{padding:24px 22px 24px 50px;font-size:1.1rem}
  .florette-txt .quote::before{font-size:4.4rem;left:14px;top:-2px}
  /* Ticket compact */
  .ticket{padding:26px 22px}
  .ticket h3{font-size:1.3rem}
  .ticket.selected{box-shadow:0 0 0 5px rgba(218,239,82,.18),0 22px 44px rgba(11,24,50,.32)}
}

/* ===== PETIT MOBILE (≤ 480px) ===== */
@media(max-width:480px){
  /* Hero compact - tout doit tenir avant scroll */
  .hero{padding:108px 0 56px;border-radius:0 0 24px 24px;min-height:auto}
  .hero h1 img{width:clamp(160px,52vw,220px)}
  .hero-tagline{font-size:clamp(1.1rem,5vw,1.4rem);margin-bottom:10px}
  .hero p.lede{font-size:.95rem;margin-bottom:16px;line-height:1.5}
  .hero-meta{gap:8px;margin-bottom:18px}
  .hero-meta .item{padding:9px 12px;min-width:0;flex:1 1 47%}
  .hero-cta{gap:8px;width:100%}
  .hero-cta .btn{flex:1 1 auto;justify-content:center;font-size:.92rem;padding:13px 18px}
  /* Countdown qui rentre sur 320-375px */
  .countdown{gap:5px}
  .cd-cell{min-width:0;flex:1 1 0;padding:9px 2px}
  .cd-num{font-size:1.3rem}
  .cd-lab{font-size:.6rem;letter-spacing:.04em;margin-top:4px}
  .cd-intro{margin-bottom:8px}
  /* Section spacing serré */
  .sec{padding:56px 0}
  /* Titres */
  .value-card h3{font-size:1.18rem}
  .espace-card{padding:24px 20px}
  .espace-card h3{font-size:1.3rem}
  .espace-card .num{font-size:3.4rem;top:6px;right:14px}
  .aud-card h4{font-size:1.1rem}
  /* Signup newsletter full width */
  .signup{flex-direction:column}
  .signup input{min-width:0;width:100%}
  .signup .btn{width:100%;justify-content:center}
  /* CTA card */
  .cta-card{padding:48px 18px 56px;border-radius:var(--r-lg)}
  .cta-card h2{font-size:clamp(1.9rem,8vw,2.4rem)}
  /* Programme */
  .timeline{gap:10px}
  .tl-time{font-size:1rem;padding:10px 14px;min-width:64px}
  .tl-card{padding:14px 16px}
  .tl-card h4{font-size:1.05rem;margin:4px 0 6px}
  .tl-card p{font-size:.9rem}
  .tl-card .tl-tag{font-size:.65rem}
  /* Tickets feat shadow plus discrète */
  .ticket.selected{box-shadow:0 0 0 4px rgba(218,239,82,.18),0 16px 32px rgba(11,24,50,.28)}
  /* About / Lieu textes plus compacts */
  .story-card p{font-size:1.04rem;line-height:1.55}
  .lieu-grid p{font-size:1rem}
  /* Sejour teaser visual */
  .st-visual{height:180px;gap:5px}
  .st-card{font-size:.78rem;padding:10px 12px;border-radius:18px}
  /* Twilight padding interne */
  .twilight{margin:0 8px;border-radius:24px}
  .twilight.sec{padding:64px 0}
  /* Border-radius hero plus terre-à-terre */
  .hero,.twilight{border-radius:0 0 24px 24px}
}

/* ===== TRÈS PETIT MOBILE (≤ 375px) ===== */
@media(max-width:375px){
  .hero-meta .item{flex:1 1 100%}
  .hero-cta .btn{padding:13px 14px;font-size:.88rem}
  .cd-num{font-size:1.2rem}
  .nav .btn{padding:11px 16px;font-size:.86rem}
}

/* ============================================================
   PERFORMANCE · rendu plus fluide (anti-lag)
   ============================================================ */
/* Accélération GPU : les éléments animés en transform passent sur leur
   propre couche -> drift/bob composités, sans repaint coûteux. */
.hero .h-cloud,.part-cta .pc-cloud,.cta-card .c-cloud,
.florette-svg,.florette-stage .florette-svg,.florette-wrap .d-float{will-change:transform}

@media(prefers-reduced-motion:reduce){
  .fx-pollen,.fx-veil{display:none!important}
  .florette-stage .florette-svg,.part-cta .pc-cloud,.cta-card .c-cloud,.sky-bg::after{animation:none!important}
}

/* Mobile : on coupe les animations continues restantes (coût > déco) */
@media(max-width:768px){
  .fx-pollen{display:none!important}
  .florette-svg,.florette-stage .florette-svg,.florette-wrap .d-float{animation:none!important}
  .part-cta .pc-cloud,.cta-card .c-cloud{animation:none!important}
}
