
:root {
  --coral:       #FB926B;
  --coral-bg:    #fddfd8;
  --mint:        #BAFAEE;
  --mint-bg:     #dffdf7;
  --periwinkle:  #BFCCFB;
  --periwinkle-bg: #dee5fd;
  --cream:       #FEECC2;
  --cream-grid:  #fbefd3;
  --rose:        #FFCEEC;
  --rose-mid:    #FF9DB8;
  --lavender:    #CDB8FF;
  --lavender-bg: #ede6ff;
  --ink:      #161616;
  --ink-dark: #2a2a2a;
  --ink-mid:  #555555;
  --ink-soft: #888888;
  --body-bg:  #f2f2f2;
  --hero-bg:  #BFCCFB;
  --white:    #F2F2F2;
  --border:   #161616;
  --mid:      #c8c8c8;
  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --sans: 'Lato', system-ui, sans-serif;
  --r: 0px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--sans); background: var(--body-bg); color: var(--ink); overflow-x: hidden; cursor: none; font-size: 18px; line-height: 1.7; }

#cur { width: 9px; height: 9px; background: var(--coral); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); transition: transform .12s, background .2s; mix-blend-mode: multiply; }
#cur-r { width: 32px; height: 32px; border: 1.5px solid rgba(191,204,251,.6); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: transform .3s cubic-bezier(.23,1,.32,1); opacity: .5; }

nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; display: flex; align-items: center; justify-content: space-between; padding: 1.1rem 3rem; background: #f2f2f2; border-bottom: 1.5px solid var(--mid); }
.logo { font-family: var(--sans); font-size: 1.25rem; font-weight: 700; color: var(--ink); text-decoration: none; letter-spacing: -.03em; }
.logo em { font-style: normal; color: var(--coral); }
.nav-menu { display: flex; align-items: center; gap: 2rem; list-style: none; }
.nav-menu a { text-decoration: none; font-size: .92rem; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-mid); transition: color .2s; position: relative; }
.nav-menu a::after { content: ''; position: absolute; bottom: -3px; left: 0; right: 0; height: 1.5px; background: var(--coral); transform: scaleX(0); transform-origin: left; transition: transform .3s cubic-bezier(.23,1,.32,1); }
.nav-menu a:hover, .nav-menu a.active { color: var(--ink); }
.nav-menu a:hover::after, .nav-menu a.active::after { transform: scaleX(1); }
.nav-btn { background: var(--coral) !important; color: #fff !important; padding: .7rem 1.9rem !important; border-radius: var(--r) !important; opacity: 1 !important; border: 1.5px solid var(--coral) !important; font-weight: 600 !important; font-size: .92rem !important; transition: background .18s !important; }
.nav-btn::after { display: none !important; }
.nav-btn:hover { background: var(--ink) !important; border-color: var(--ink) !important; }

.hero { min-height: 100svh; position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding-top: 64px; background: var(--hero-bg); }
.hero-grid { position: absolute; inset: 0; z-index: 1; background-image: radial-gradient(circle, rgba(22,22,22,.1) 1.5px, transparent 1.5px); background-size: 36px 36px; animation: gridMove 30s linear infinite; }
@keyframes gridMove { from{background-position:0 0} to{background-position:36px 36px} }
.hero-botanical { position: absolute; right: 0; top: 0; bottom: 0; width: 50%; z-index: 2; pointer-events: none; }
.hero-botanical svg { width: 100%; height: 100%; display: block; }
.hero-botanical img { width: 100%; height: 100%; display: block; object-fit: cover; object-position: right center; }
.hero-inner { position: relative; z-index: 3; max-width: 1400px; margin: 0 auto; width: 100%; padding: 5rem 3rem 5rem; }
.breadcrumb { display: flex; align-items: center; gap: .4rem; font-size: .78rem; font-weight: 500; letter-spacing: .07em; text-transform: uppercase; color: rgba(22,22,22,.5); margin-bottom: 2rem; animation: up .5s .1s both; }
.breadcrumb a { text-decoration: none; color: inherit; }
.breadcrumb a:hover { color: var(--ink); }
.hero-cols { display: grid; grid-template-columns: 1fr 380px; gap: 5rem; align-items: end; }
h1.hero-title { font-family: var(--sans); font-size: clamp(3rem, 6vw, 6.5rem); font-weight: 700; line-height: 1.0; letter-spacing: -.04em; color: var(--ink); animation: up .7s .3s both; }
h1.hero-title em { font-style: italic; font-weight: 300; color: var(--ink-dark); }
.hero-intro { font-size: 1.1rem; font-weight: 400; line-height: 1.8; color: rgba(22,22,22,.65); max-width: 52ch; margin-top: 1.8rem; animation: up .7s .45s both; }
.hero-pillars { display: flex; flex-direction: column; gap: .75rem; animation: up .7s .5s both; }
.pillar{background-color:rgba(255,255,255,.82);background-image:radial-gradient(circle,rgba(22,22,22,.12) 1px,transparent 1px);background-size:18px 18px;border:1.5px solid rgba(22,22,22,.28);border-radius:16px;padding:1.2rem 1.6rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:3px 4px 0 rgba(0,0,0,.14);transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,border-color .2s}
.pillar:hover{border-color:var(--ink);transform:translateX(5px) translateY(-2px);box-shadow:5px 7px 0 rgba(0,0,0,.2)}
.pillar-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:10px}
.pillar-icon svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.pi-peri  { background: var(--periwinkle); color: #2a40a0; border: 1.5px solid rgba(22,22,22,.2); }
.pi-coral { background: var(--coral-bg); color: var(--coral); border: 1.5px solid var(--coral); }
.pi-lav   { background: var(--lavender-bg); color: #5530a0; border: 1.5px solid rgba(205,184,255,.5); }
.pillar-label { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-dark); margin-bottom: .25rem; }
.pillar-val { font-size: 1rem; font-weight: 400; color: var(--ink-dark); line-height: 1.6; }
.hero-scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: .5rem; animation: scrollBounce 2.5s ease-in-out infinite; opacity: .4; }
.hero-scroll span { font-size: .6rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink); }
.hero-scroll-line { width: 1px; height: 32px; background: linear-gradient(to bottom, var(--ink), transparent); }
@keyframes scrollBounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(6px)} }

.container { max-width: 1240px; margin: 0 auto; padding: 0 3rem; }
section { padding: 6rem 0; }
.section-kicker { font-size: .85rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--coral); display: flex; align-items: center; gap: .6rem; margin-bottom: 1rem; }
.section-kicker::before { content: ''; width: 22px; height: 2px; background: var(--coral); }
h2.s-title { font-family: 'Bricolage Grotesque', var(--display), sans-serif; font-size: clamp(2.2rem, 3.8vw, 3.4rem); font-weight: 700; letter-spacing: -.04em; line-height: 1.06; }
.s-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3.5rem; }
.link-all { display: inline-flex; align-items: center; gap: .55rem; font-size: 1rem; font-weight: 700; text-decoration: none; color: var(--ink); border-bottom: 2px solid var(--ink); padding-bottom: 3px; transition: color .2s, border-color .2s, gap .2s; }
.link-all:hover { color: var(--coral); border-color: var(--coral); gap: .9rem; }
.link-all svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.edito-section { background: var(--white); }
.edito-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 5rem; align-items: start; }
.edito-manifeste { background: var(--periwinkle-bg); padding: 2rem 2.2rem; border-left: 3px solid var(--coral); margin-top: 2rem; border-right: 1.5px solid var(--mid); border-top: 1.5px solid var(--mid); border-bottom: 1.5px solid var(--mid); }
.edito-manifeste p { font-size: 1.1rem; font-weight: 400; line-height: 1.88; color: var(--ink-dark); font-style: italic; }
.edito-body p { font-size: 1.1rem; font-weight: 400; line-height: 1.88; color: var(--ink-mid); margin-bottom: 1.2rem; }
.edito-body p:last-child { margin-bottom: 0; }
.positions { display: flex; flex-direction: column; gap: 1px; margin-top: 2rem; overflow: hidden; }
.position-card { padding: 1.6rem 1.8rem; display: flex; gap: 1.2rem; align-items: flex-start; border: 1.5px solid var(--mid); }
.pos-want { background: var(--periwinkle); border-color: rgba(22,22,22,.12); }
.pos-refuse { background: var(--rose); border-color: rgba(22,22,22,.12); }
.pos-icon { width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .1rem; }
.pos-icon svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.pw-icon { background: #fff; color: #2a40a0; border: 1.5px solid rgba(22,22,22,.15); }
.pr-icon { background: var(--rose-mid); color: #fff; border: 1.5px solid rgba(22,22,22,.1); }
.pos-label { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: .35rem; }
.pw-label { color: #2a40a0; }
.pr-label { color: #8a1040; }
.pos-text { font-size: 1.05rem; font-weight: 400; line-height: 1.75; color: var(--ink-dark); }
.obj-list { display: flex; flex-direction: column; gap: 1rem; margin-top: 2rem; }
.obj-item { display: flex; gap: 1rem; align-items: flex-start; }
.obj-bullet { width: 28px; height: 28px; background: var(--periwinkle-bg); border: 2px solid var(--coral); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .1rem; }
.obj-bullet svg { width: 12px; height: 12px; stroke: var(--coral); fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.obj-text { font-size: 1.05rem; font-weight: 400; line-height: 1.78; color: var(--ink-mid); }
.obj-text strong { color: var(--ink); font-weight: 700; }

.animations-section { background: var(--body-bg); }
.subtheme-nav { display: flex; gap: .5rem; margin-bottom: 3rem; flex-wrap: wrap; }
.stn-btn { background: var(--coral); border: 1.5px solid var(--coral); border-radius: var(--r); padding: .8rem 1.65rem; font-family: var(--sans); font-size: .95rem; font-weight: 700; color: #fff; cursor: pointer; transition: all .18s; }
.stn-btn:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.stn-btn.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.anims-grid-wrap { background: var(--periwinkle-bg); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.25rem; }
.anims-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.anim-card { background: var(--white); border: 1.5px solid var(--border); padding: 2.2rem; display: flex; flex-direction: column; cursor: pointer; transition: transform .25s cubic-bezier(.23,1,.32,1), box-shadow .25s; position: relative; overflow: hidden; box-shadow: 3px 3px 0 rgba(0,0,0,.1); }
.anim-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--coral); transform: scaleX(0); transform-origin: left; transition: transform .35s cubic-bezier(.23,1,.32,1); }
.anim-card:hover { transform: translateY(-3px); box-shadow: 5px 8px 0 rgba(0,0,0,.1); }
.anim-card:hover::before { transform: scaleX(1); }
.anim-card.featured { background: var(--ink); border-color: var(--ink); box-shadow: 3px 3px 0 rgba(22,22,22,.35); }
.anim-card.featured::before { background: var(--coral); transform: scaleX(1); }
.ac-badges { display: flex; gap: .45rem; margin-bottom: 1.2rem; flex-wrap: wrap; }
.ac-badge { font-size: .75rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; padding: .32rem .9rem; border-radius: var(--r); border: 1.5px solid transparent; }
.badge-coral { background: var(--coral-bg); color: #c05030; border-color: rgba(251,146,107,.4); }
.badge-mint  { background: var(--mint); color: #0d6b5e; border-color: rgba(22,22,22,.15); }
.badge-peri  { background: var(--periwinkle); color: #2a40a0; border-color: rgba(22,22,22,.12); }
.badge-lav   { background: var(--lavender-bg); color: #5530a0; border-color: rgba(205,184,255,.5); }
.badge-rose  { background: var(--rose); color: #8a1040; border-color: rgba(255,157,184,.4); }
.badge-white { background: rgba(255,255,255,.18); color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.25); }
.ac-title { font-family: var(--sans); font-size: 1.2rem; font-weight: 700; line-height: 1.28; margin-bottom: .75rem; transition: color .2s; }
.anim-card:not(.featured) .ac-title { color: var(--ink); }
.anim-card:not(.featured):hover .ac-title { color: var(--coral); }
.anim-card.featured .ac-title { color: #fff; }
.ac-desc { font-size: 1.02rem; font-weight: 400; line-height: 1.78; flex: 1; margin-bottom: 1.2rem; }
.anim-card:not(.featured) .ac-desc { color: var(--ink-mid); }
.anim-card.featured .ac-desc { color: rgba(255,255,255,.55); }
.ac-footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 1rem; border-top: 1.5px solid; }
.anim-card:not(.featured) .ac-footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;border- }
.anim-card.featured .ac-footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;border- }
.ac-info { font-size: .88rem; font-weight: 500; line-height: 1.55; display: flex; flex-direction: column; gap: .3rem; }
.ac-info span { display: flex; align-items: center; gap: .35rem; }
.ac-info svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.anim-card:not(.featured) .ac-info { color: var(--ink-soft); }
.anim-card.featured .ac-info { color: rgba(255,255,255,.4); }
.ac-arrow { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; transition: all .22s; flex-shrink: 0; }
.anim-card:not(.featured) .ac-arrow { background: var(--coral); border: 1.5px solid var(--coral); }
.anim-card.featured .ac-arrow { background: rgba(255,255,255,.12); border: 1.5px solid rgba(255,255,255,.2); }
.ac-arrow svg { width: 15px; height: 15px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.anim-card:hover .ac-arrow { background: var(--ink); border-color: var(--ink); transform: translateX(2px); }
.anim-card.featured:hover .ac-arrow { background: rgba(251,146,107,.5); border-color: var(--coral); }
.anim-cta { background: var(--periwinkle-bg) !important; border: 1.5px solid var(--coral) !important; box-shadow: none !important; justify-content: center; align-items: center; text-align: center; gap: 1.2rem; }
.anim-cta::before { display: none; }
.anim-cta:hover { transform: translateY(-3px) !important; }
.cta-icon { width: 52px; height: 52px; background: var(--coral-bg); border: 1.5px solid rgba(251,146,107,.3); display: flex; align-items: center; justify-content: center; margin: 0 auto; }
.cta-icon svg { stroke: var(--coral); }
.cta-title { font-family: var(--sans); font-size: 1.1rem; font-weight: 700; margin-bottom: .4rem; color: var(--ink); }
.cta-sub { font-size: .95rem; font-weight: 400; color: var(--ink-mid); line-height: 1.6; margin-bottom: 1rem; }
.btn-primary { display: inline-flex; align-items: center; gap: .6rem; background: var(--coral); color: #fff; padding: 1rem 2.2rem; border: 1.5px solid var(--coral); text-decoration: none; font-family: var(--sans); font-size: 1rem; font-weight: 700; transition: background .18s, border-color .18s; }
.btn-primary:hover { background: var(--ink); border-color: var(--ink); }
.btn-primary svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.subthema-strip { background: var(--hero-bg); }
.subthema-header { display: grid; grid-template-columns: 1fr 1fr 1fr; }
.subthema-col { padding: 4.5rem 3.5rem; border-right: 1px solid rgba(22,22,22,.1); }
.subthema-col:last-child { border-right: none; }
.st-kicker { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--coral); margin-bottom: .8rem; display: flex; align-items: center; gap: .5rem; }
.st-kicker::before { content: ''; width: 18px; height: 1.5px; background: var(--coral); }
h3.st-title { font-family: var(--sans); font-size: 1.8rem; font-weight: 700; color: var(--ink); margin-bottom: 1.1rem; line-height: 1.15; letter-spacing: -.03em; }
h3.st-title em { font-style: italic; font-weight: 300; color: var(--ink-mid); }
.st-text { font-size: .9rem; font-weight: 400; line-height: 1.85; color: var(--ink-mid); }
.st-def { margin-top: 1.5rem; background: rgba(255,255,255,.6); border: 1.5px solid rgba(22,22,22,.15); border-left: 3px solid var(--ink); padding: 1.2rem 1.5rem; }
.st-def p { font-size: .85rem; font-weight: 300; line-height: 1.75; color: var(--ink-dark); font-style: italic; }

.projets-section { background: var(--body-bg); }
.projets-wrap { background: var(--periwinkle-bg); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.25rem; }
.projets-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
.projet-card { background: var(--white); border: 1.5px solid var(--border); padding: 2rem; display: flex; flex-direction: column; cursor: pointer; transition: transform .25s cubic-bezier(.23,1,.32,1), box-shadow .25s; position: relative; overflow: hidden; box-shadow: 3px 3px 0 rgba(0,0,0,.1); }
.projet-card::after { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.pc-vi::after  { background: var(--periwinkle); }
.pc-sb::after  { background: var(--mint); }
.pc-ca::after  { background: var(--lavender); }
.pc-re::after  { background: var(--coral); }
.projet-card:hover { transform: translateY(-3px); box-shadow: 5px 8px 0 rgba(0,0,0,.1); }
.pc-icon { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; margin-bottom: 1.3rem; border: 1.5px solid var(--border); }
.pc-icon svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.pci-b { background: var(--periwinkle); color: #2a40a0; }
.pci-g { background: var(--mint); color: #0d6b5e; }
.pci-l { background: var(--lavender-bg); color: #5530a0; }
.pci-o { background: var(--coral-bg); color: var(--coral); }
.pc-year { font-size: .78rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .45rem; }
.pc-title { font-family: var(--sans); font-size: 1.1rem; font-weight: 700; line-height: 1.3; margin-bottom: .7rem; transition: color .2s; }
.projet-card:hover .pc-title { color: var(--coral); }
.pc-desc { font-size: 1rem; font-weight: 400; line-height: 1.75; color: var(--ink-mid); flex: 1; margin-bottom: 1rem; }
.pc-tag { display: inline-block; font-size: .75rem; font-weight: 600; background: var(--periwinkle-bg); color: #2a40a0; padding: .35rem 1rem; border: 1.5px solid var(--periwinkle); }
.pc-footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;padding-top: 1rem; border-top: 1.5px solid var(--mid); display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.pc-contact { font-size: .82rem; font-weight: 500; color: var(--ink-soft); }
.pc-arrow { width: 38px; height: 38px; background: var(--periwinkle); border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; transition: all .22s; }
.pc-arrow svg { width: 15px; height: 15px; stroke: #2a40a0; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.projet-card:hover .pc-arrow { background: var(--ink); border-color: var(--ink); }
.projet-card:hover .pc-arrow svg { stroke: #fff; }

.stats-band { background: var(--coral); padding: 4rem 0; }
.stats-inner { display: grid; grid-template-columns: repeat(4,1fr); border-left: 1.5px solid rgba(255,255,255,.2); }
.stat-box { padding: 2rem 2.5rem; border-right: 1.5px solid rgba(255,255,255,.2); text-align: center; }
.sb-num { font-family: var(--sans); font-size: 3.5rem; font-weight: 700; color: #fff; line-height: 1; margin-bottom: .5rem; letter-spacing: -.04em; }
.sb-label { font-size: .88rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.65); }

.focus-strip { background: linear-gradient(110deg, var(--lavender-bg) 0%, var(--periwinkle-bg) 100%); border-top: 1.5px solid var(--border); border-bottom: 1.5px solid var(--border); padding: 3rem 0; }
.focus-inner { display: flex; align-items: center; gap: 2.5rem; }
.focus-icon { width: 52px; height: 52px; background: rgba(22,22,22,.1); border: 1.5px solid rgba(22,22,22,.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.focus-icon svg { width: 22px; height: 22px; stroke: var(--ink); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.focus-kicker { font-size: .82rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-dark); margin-bottom: .4rem; }
.focus-title { font-family: var(--sans); font-size: 1.6rem; font-weight: 700; margin-bottom: .5rem; line-height: 1.2; color: var(--ink); }
.focus-desc { font-size: 1.07rem; font-weight: 400; line-height: 1.78; color: var(--ink-mid); max-width: 60ch; }
.focus-cta { margin-left: auto; flex-shrink: 0; }

.publi-section { background: var(--white); }
.publi-layout { display: grid; grid-template-columns: 1.5fr 1fr; gap: 1.5rem; }
.publi-featured { background: var(--ink); border: 1.5px solid var(--border); padding: 3rem; color: #fff; position: relative; overflow: hidden; min-height: 340px; display: flex; flex-direction: column; justify-content: flex-end; cursor: pointer; transition: transform .25s cubic-bezier(.23,1,.32,1); box-shadow: 5px 5px 0 rgba(22,22,22,.25); }
.publi-featured:hover { transform: translateY(-3px); }
.pf-deco { position: absolute; top: -60px; right: -60px; width: 280px; height: 280px; border-radius: 50%; background: rgba(191,204,251,.15); filter: blur(60px); }
.pf-deco2 { position: absolute; bottom: -30px; left: -30px; width: 180px; height: 180px; border-radius: 50%; background: rgba(205,184,255,.1); filter: blur(40px); }
.pf-cat { display: inline-flex; align-items: center; gap: .4rem; background: rgba(191,204,251,.2); color: var(--periwinkle); font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .35rem .95rem; border: 1.5px solid rgba(191,204,251,.4); margin-bottom: .9rem; position: relative; }
.pf-cat svg { width: 10px; height: 10px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.pf-title { font-family: var(--sans); font-size: 1.85rem; font-weight: 700; line-height: 1.18; margin-bottom: .9rem; position: relative; letter-spacing: -.03em; }
.pf-sub { font-size: .96rem; font-weight: 300; opacity: .55; font-style: italic; margin-bottom: .7rem; position: relative; }
.pf-meta { font-size: .84rem; font-weight: 400; opacity: .6; display: flex; flex-direction: column; gap: .4rem; position: relative; }
.pf-meta svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.publi-list { display: flex; flex-direction: column; gap: 1px; background: var(--mid); border: 1.5px solid var(--border); }
.publi-item { background: var(--white); padding: 1.4rem 1.6rem; cursor: pointer; display: flex; gap: 1rem; align-items: flex-start; border-left: 0px solid transparent; transition: all .2s; }
.publi-item:hover { background: var(--body-bg); transform: translateX(4px); border-left: 3px solid var(--coral); }
.pi-color { width: 8px; height: 8px; flex-shrink: 0; margin-top: .45rem; }
.pi-type { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--ink-soft); margin-bottom: .3rem; }
.pi-title { font-family: var(--sans); font-size: 1.05rem; font-weight: 600; line-height: 1.4; margin-bottom: .3rem; transition: color .2s; }
.publi-item:hover .pi-title { color: var(--coral); }
.pi-author { font-size: .82rem; font-weight: 400; color: var(--ink-soft); }

.extras-section { background: var(--body-bg); }
.extras-wrap { background: var(--periwinkle-bg); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.25rem; }
.extras-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.extra-card { background: var(--white); border: 1.5px solid var(--border); padding: 0; cursor: pointer; transition: transform .25s cubic-bezier(.23,1,.32,1), box-shadow .25s; box-shadow: 3px 3px 0 rgba(0,0,0,.08); overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: var(--ink); }
.extra-card:hover { transform: translateY(-3px); box-shadow: 5px 8px 0 rgba(0,0,0,.08); }
.ec-img { position: relative; height: 150px; overflow: hidden; flex-shrink: 0; }
.ec-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .35s ease; }
.extra-card:hover .ec-img img { transform: scale(1.05); }
.ec-img .badge { position: absolute; bottom: .65rem; left: .8rem; margin: 0; }
.ec-body { padding: 1.4rem 1.6rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.ec-num { font-family: var(--sans); font-size: 3rem; font-weight: 700; letter-spacing: -.04em; color: var(--mid); line-height: 1; transition: color .3s; }
.extra-card:hover .ec-num { color: rgba(191,204,251,.6); }
.ec-type { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); margin: -.2rem 0 .6rem; }
.ec-title { font-family: var(--sans); font-size: 1.08rem; font-weight: 600; line-height: 1.4; transition: color .3s; }
.extra-card:hover .ec-title { color: var(--coral); }
.ec-author { font-size: .85rem; font-weight: 400; color: var(--ink-soft); margin-top: .6rem; }

footer{background:var(--ink)!important;color:rgba(255,255,255,.85)!important;padding: 4.5rem 0 2rem}
.footer-top { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1.3fr; gap: 3.5rem; margin-bottom: 3.5rem; padding-bottom: 3.5rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-brand .logo { color: rgba(255,255,255,.85); display: block; margin-bottom: 1.1rem; }
.footer-brand p { font-size: .84rem; font-weight: 400; line-height: 1.75; color: rgba(255,255,255,.35); max-width: 28ch; margin-bottom: 1.6rem; }
.footer-social { display: flex; gap: .6rem; }
.social-btn { width: 32px; height: 32px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; transition: background .2s; text-decoration: none; }
.social-btn:hover { background: var(--coral); border-color: var(--coral); }
.social-btn svg { width: 14px; height: 14px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.footer-col h4 { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 1.1rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.footer-col ul a { text-decoration: none; font-size: .95rem; font-weight: 400; color: rgba(255,255,255,.5); transition: color .2s; }
.footer-col ul a:hover { color: var(--coral); }
.footer-newsletter input { width: 100%; background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.1); padding: .9rem 1.1rem; color: #fff; font-family: var(--sans); font-size: .95rem; font-weight: 400; margin-bottom: .7rem; outline: none; transition: border-color .2s; }
.footer-newsletter input::placeholder { color: rgba(255,255,255,.25); }
.footer-newsletter input:focus { border-color: var(--coral); }
.footer-newsletter .btn-nl { width: 100%; background: var(--coral); color: #fff; border: 1.5px solid var(--coral); padding: 1rem; font-family: var(--sans); font-size: .95rem; font-weight: 600; cursor: pointer; transition: background .2s, border-color .2s; }
.footer-newsletter .btn-nl:hover { background: #e07555; border-color: #e07555; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.footer-copy { font-size: .75rem; font-weight: 400; color: rgba(255,255,255,.25); }
.footer-legal { display: flex; gap: 2rem; }
.footer-legal a { font-size: .75rem; font-weight: 400; color: rgba(255,255,255,.25); text-decoration: none; transition: color .2s; }
.footer-legal a:hover { color: rgba(255,255,255,.6); }

@keyframes up { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(24px); transition: opacity .7s cubic-bezier(.23,1,.32,1), transform .7s; }
.reveal.in { opacity:1; transform:translateY(0); }
.rd1{transition-delay:.1s} .rd2{transition-delay:.2s} .rd3{transition-delay:.3s} .rd4{transition-delay:.4s}
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--body-bg); }
::-webkit-scrollbar-thumb { background: var(--mid); }
::-webkit-scrollbar-thumb:hover { background: var(--coral); }

/* ══════════════════════════════════════════
   RESPONSIVE — 768px
══════════════════════════════════════════ */
@media(max-width:768px){
  body { font-size: 16px; }
  /* Hero */
  .hero-cols { grid-template-columns: 1fr; gap: 2rem; }
  /* Sections */
  .edito-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .anims-grid { grid-template-columns: 1fr; gap: .75rem; }
  .projets-grid { grid-template-columns: 1fr 1fr; gap: .75rem; }
  .subthema-header { grid-template-columns: 1fr; gap: 0; }
  .publi-layout { grid-template-columns: 1fr; gap: 1rem; }
  .extras-grid { grid-template-columns: 1fr 1fr; gap: .75rem; }
  /* Stats bar — wrap */
  .stats-inner { grid-template-columns: repeat(2,1fr); border-left: none; }
  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: .6rem; }
  .footer-legal { flex-wrap: wrap; gap: 1rem; }
  /* Section headers */
  .s-header { flex-direction: column; align-items: flex-start; gap: .8rem; margin-bottom: 2rem; }
}
@media(max-width:480px){
  .projets-grid { grid-template-columns: 1fr; }
  .extras-grid { grid-template-columns: 1fr; }
  .stats-inner { grid-template-columns: 1fr 1fr; }
}
