:root {
  /* Savane & Lagon — Palette Afrique × Maurice */
  --bg:#fdf4e8;        /* Ivoire chaud — sable de plage */
  --bg2:#faf0de;       /* Ivoire soutenu */
  --tc:#b84818;        /* Terracotta rouge — argile africaine */
  --coral:#d46832;     /* Corail — coucher de soleil sur l'Indien */
  --must:#c98820;      /* Or — bijoux africains × soleil mauricien */
  --sage:#2e7856;      /* Vert tropical — palmiers × baobabs */
  --teal:#157070;      /* Lagon — turquoise de l'océan Indien */
  --sand:#e8c890;      /* Sable doré — plages de l'île */
  --sand2:#d4a870;     /* Sable ocre — terre africaine */
  --dark:#1a0e04;      /* Espresso volcanique — basalte × ébène */
  --mid:#563618;       /* Brun bois — tronc de baobab */
  --muted:#8a6038;     /* Ocre atténué — latérite séchée */
  --r:16px; --sh:0 8px 40px rgba(26,14,4,.10); --sh2:0 16px 56px rgba(26,14,4,.18);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);background-image:radial-gradient(rgba(201,136,32,.03) 1.5px,transparent 1.5px);background-size:28px 28px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:400;overflow-x:hidden}
*:focus-visible{outline:2px solid var(--tc);outline-offset:3px;border-radius:4px}
body::before{content:'';position:fixed;top:-10%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(201,136,32,.14),transparent 70%);pointer-events:none;z-index:0}
body::after{content:'';position:fixed;bottom:-10%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(21,112,112,.10),transparent 70%);pointer-events:none;z-index:0}
 /* NAV */
nav{position:fixed;top:0;width:100%;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 5%;transition:all .4s}
nav.scrolled{background:rgba(253,244,232,.95);backdrop-filter:blur(16px);box-shadow:0 2px 20px rgba(26,14,4,.07)}
.logo{font-family:'Dancing Script',cursive;font-size:1.9rem;color:var(--tc);text-decoration:none}
.logo span{color:var(--must)}
.nav-links{display:flex;gap:2.2rem;list-style:none;align-items:center}
.nav-links a{color:var(--mid);text-decoration:none;font-size:.88rem;font-weight:400;transition:color .25s;position:relative}
.nav-links a:hover{color:var(--tc)}
.nav-links a.active{color:var(--tc)}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--tc);border-radius:2px}
.nav-cta{background:var(--tc)!important;color:#fff!important;padding:.55rem 1.4rem;border-radius:50px;font-weight:500!important;transition:background .3s,transform .2s!important}
.nav-cta:hover{background:var(--coral)!important;transform:translateY(-1px)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none}
.hamburger span{width:22px;height:2px;background:var(--tc);display:block;border-radius:2px}
 /* HERO */
#hero{min-height:100vh;display:flex;align-items:center;padding:7rem 5% 5rem;position:relative;overflow:hidden}
.blob{position:absolute;border-radius:50%;pointer-events:none}
.b1{width:380px;height:380px;background:radial-gradient(circle,rgba(201,136,32,.26),rgba(201,136,32,.04));top:10%;right:8%;animation:fb 8s ease-in-out infinite}
.b2{width:220px;height:220px;background:radial-gradient(circle,rgba(184,72,24,.16),transparent);bottom:15%;right:22%;animation:fb 6s ease-in-out infinite reverse}
.b3{width:150px;height:150px;background:radial-gradient(circle,rgba(21,112,112,.22),transparent);top:25%;left:5%;animation:fb 10s ease-in-out infinite}
@keyframes fb{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-18px) scale(1.03)}}
.hc{position:relative;z-index:2;max-width:660px}
.hbadge{display:inline-flex;align-items:center;gap:.5rem;background:var(--sand);color:var(--tc);font-size:.78rem;font-weight:500;letter-spacing:.08em;padding:.5rem 1.1rem;border-radius:50px;margin-bottom:2rem;opacity:0;animation:popIn .6s .3s cubic-bezier(.34,1.56,.64,1) forwards}
.hbadge::before{content:'✦';color:var(--must)}
.htitle{font-family:'Playfair Display',serif;font-size:clamp(3rem,7vw,6.5rem);font-weight:400;line-height:1.05;color:var(--dark);margin-bottom:1.5rem;opacity:0;animation:slideUp .9s .5s cubic-bezier(.22,1,.36,1) forwards}
.htitle em{font-style:italic;color:var(--tc);position:relative}
.htitle em::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:4px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 10'%3E%3Cpath d='M0,5 Q10,0 20,5 Q30,10 40,5 Q50,0 60,5 Q70,10 80,5 Q90,0 100,5' stroke='%23c98820' stroke-width='2.5' fill='none'/%3E%3C/svg%3E") repeat-x;background-size:60px 4px}
.hdesc{font-size:1.05rem;color:var(--mid);line-height:1.8;max-width:460px;margin-bottom:2.5rem;opacity:0;animation:slideUp .9s .8s cubic-bezier(.22,1,.36,1) forwards}
.hbtns{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:slideUp .9s 1s cubic-bezier(.22,1,.36,1) forwards}
.btn-p{background:var(--tc);color:#fff;text-decoration:none;padding:1rem 2.2rem;border-radius:50px;font-size:.9rem;font-weight:500;transition:background .3s,transform .25s,box-shadow .25s;box-shadow:0 4px 20px rgba(184,72,24,.3)}
.btn-p:hover{background:var(--coral);transform:translateY(-2px);box-shadow:0 8px 28px rgba(184,72,24,.38)}
.btn-s{background:transparent;color:var(--tc);text-decoration:none;padding:1rem 2.2rem;border-radius:50px;border:1.5px solid var(--tc);font-size:.9rem;font-weight:500;transition:background .3s,color .3s,transform .25s}
.btn-s:hover{background:var(--tc);color:#fff;transform:translateY(-2px)}
.hvisual{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:min(420px,38vw);opacity:0;animation:floatIn 1s .7s cubic-bezier(.22,1,.36,1) forwards}
.hframe{position:relative}
.hframe img{width:100%;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;display:block;box-shadow:var(--sh2);animation:morph 10s ease-in-out infinite;object-fit:cover;aspect-ratio:4/5;background:var(--sand)}
.hframe::before{content:'';position:absolute;top:-12px;left:-12px;right:-12px;bottom:-12px;border:2.5px dashed rgba(232,184,75,.4);border-radius:33% 67% 67% 33%/33% 33% 67% 67%;animation:morph 10s ease-in-out infinite reverse}
@keyframes morph{0%,100%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}25%{border-radius:58% 42% 75% 25%/76% 46% 54% 24%}50%{border-radius:50% 50% 33% 67%/55% 27% 73% 45%}75%{border-radius:33% 67% 58% 42%/63% 68% 32% 37%}}
.spill{position:absolute;background:#fff;border-radius:50px;padding:.6rem 1.1rem;box-shadow:var(--sh);display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--dark);animation:fb 6s ease-in-out infinite}
.spill .pn{font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;color:var(--tc)}
.spill-ico{width:18px;height:18px;color:var(--tc);flex-shrink:0}
.sp1{top:8%;right:-10%}
.sp2{bottom:12%;left:-8%;animation-delay:-3s}
 /* SECTIONS */
section{position:relative;z-index:1}
.wrap{max-width:1200px;margin:0 auto;padding:0 5%}
.ltag{display:inline-flex;align-items:center;gap:.6rem;font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--tc);margin-bottom:1rem}
.ltag::before{content:'';width:32px;height:3px;background:repeating-linear-gradient(90deg,var(--must) 0,var(--must) 8px,var(--tc) 8px,var(--tc) 12px,var(--teal) 12px,var(--teal) 16px,var(--must) 16px,var(--must) 24px,var(--tc) 24px,var(--tc) 32px);border-radius:1px;flex-shrink:0}
.bigtitle{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:400;line-height:1.15;color:var(--dark);margin-bottom:1rem}
.bigtitle em{font-style:italic;color:var(--tc)}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
 /* ABOUT */
#about{padding:8rem 0;background:var(--bg2)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:6rem;align-items:center}
.aic{position:relative}
.amain{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:40% 60% 55% 45%/40% 45% 55% 60%;box-shadow:0 20px 60px rgba(212,96,58,.15);display:block;background:var(--sand)}
.aaccent{position:absolute;bottom:-2rem;right:-2rem;width:42%;aspect-ratio:1;object-fit:cover;border-radius:20px;box-shadow:var(--sh2);border:5px solid #fff;background:var(--sand2)}
.pdots{position:absolute;top:-1.5rem;left:-1.5rem;display:flex;flex-direction:column;gap:.5rem}
.pdr{display:flex;gap:.5rem}
.pd{width:18px;height:18px;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.about-text p{color:var(--mid);line-height:1.85;font-size:1rem;margin-bottom:1.4rem}
.about-text strong{color:var(--tc);font-weight:500}
.chips{display:flex;flex-wrap:wrap;gap:.75rem;margin:1.8rem 0}
.chip{display:flex;align-items:center;gap:.45rem;background:#fff;border:1.5px solid var(--sand2);border-radius:50px;padding:.45rem 1rem;font-size:.82rem;font-weight:500;color:var(--dark);box-shadow:0 2px 8px rgba(26,14,4,.06)}
.sband{display:flex;margin-top:2.5rem;background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--sh)}
.sbox{flex:1;padding:1.5rem;text-align:center;border-right:1.5px solid var(--sand)}
.sbox:last-child{border-right:none}
.snum{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:var(--tc);line-height:1}
.slbl{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
 /* APERÇU GALERIE (6 œuvres + lien) */
#galerie-apercu{padding:8rem 0}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:3rem 0}
.pgi{border-radius:16px;overflow:hidden;position:relative;cursor:pointer;background:var(--sand);box-shadow:0 4px 20px rgba(26,14,4,.08);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s;aspect-ratio:2/3}
.pgi:nth-child(2),.pgi:nth-child(5){aspect-ratio:4/5}
.pgi.pgi-missing{background:linear-gradient(160deg,var(--sand2),var(--sand))}
.pgi img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.88);transition:transform .5s,filter .5s}
.pgi:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 16px 40px rgba(26,14,4,.16)}
.pgi:hover img{transform:scale(1.04);filter:saturate(1.05)}
.pgi-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,15,8,.82) 0%,rgba(42,15,8,.3) 50%,transparent 75%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:1.2rem}
.pgi:hover .pgi-overlay{opacity:1}
.pgi-overlay h3{font-family:'Playfair Display',serif;font-size:1rem;color:#fff;margin-bottom:.15rem}
.pgi-overlay span{font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--must)}
.galerie-cta{text-align:center;margin-top:2rem}
 /* AWARDS */
#awards{padding:8rem 0;background:linear-gradient(135deg,#fef4e2 0%,#fdf8f0 40%,#e8f4f0 100%)}
.awards-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3.5rem}
.acard{background:#fff;border-radius:var(--r);padding:2.2rem;box-shadow:var(--sh);transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s;border-top:3px solid transparent;cursor:default;position:relative;overflow:hidden}
.acard::before{content:'★';position:absolute;top:1.2rem;right:1.6rem;font-size:3rem;opacity:.04;line-height:1}
.acard:nth-child(1){border-top-color:var(--tc)}.acard:nth-child(2){border-top-color:var(--must)}.acard:nth-child(3){border-top-color:var(--teal)}.acard:nth-child(4){border-top-color:var(--sage)}
.acard:hover{transform:translateY(-5px);box-shadow:var(--sh2)}
.ayr{display:inline-block;background:var(--sand);color:var(--tc);font-size:.75rem;font-weight:700;letter-spacing:.1em;padding:.3rem .8rem;border-radius:50px;margin-bottom:1rem}
.atitle{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--dark);margin-bottom:.6rem;line-height:1.3}
.adesc{font-size:.86rem;color:var(--muted);line-height:1.75}
.atype{display:inline-flex;align-items:center;gap:.35rem;margin-top:1.2rem;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--tc)}
.atype::before{content:'★';color:var(--must)}
 /* PRESSE */
#press{padding:8rem 0;background:var(--bg)}
.ticker{background:var(--tc);overflow:hidden;padding:.9rem 0;margin-bottom:5rem;position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:1;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(to right,var(--tc),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--tc),transparent)}
.ticker-in{display:flex;gap:5rem;white-space:nowrap;animation:tick 20s linear infinite}
.ticker-in span{font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.9)}
.ticker-in span::before{content:'✦  ';color:var(--must)}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.press-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.pcard{background:#fff;border-radius:var(--r);padding:2rem 2rem 1.6rem;box-shadow:var(--sh);transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}
.pcard::after{content:'\201C';position:absolute;bottom:-.4rem;right:1rem;font-family:'Playfair Display',serif;font-size:7rem;line-height:1;color:var(--sand2);pointer-events:none;z-index:0}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh2)}
.psrc{font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--tc);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;position:relative;z-index:1}
.psrc::before{content:'';display:inline-block;width:24px;height:2px;background:var(--must);border-radius:2px}
.pq{font-family:'Playfair Display',serif;font-style:italic;font-size:1.05rem;color:var(--dark);line-height:1.7;margin-bottom:1.2rem;position:relative;z-index:1}
.pdate{font-size:.75rem;color:var(--muted);position:relative;z-index:1}
 /* CONTACT */
#contact{padding:8rem 0;background:linear-gradient(150deg,#fef4e2 0%,#faf0da 35%,#e4f2ee 100%)}
.cgrid{display:grid;grid-template-columns:1.1fr 1fr;gap:6rem;align-items:start}
.cinfo p{color:var(--mid);line-height:1.8;font-size:1rem;margin-bottom:2.5rem}
.citem{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.6rem}
.cico{width:44px;height:44px;flex-shrink:0;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--tc);box-shadow:var(--sh)}
.ctxt small{display:block;font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem}
.ctxt a,.ctxt span{color:var(--dark);text-decoration:none;font-size:.92rem;transition:color .25s}
.ctxt a:hover{color:var(--tc)}
.socials{display:flex;gap:.8rem;margin-top:2rem}
.soc{width:44px;height:44px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--mid);text-decoration:none;box-shadow:var(--sh);transition:background .3s,color .3s,transform .25s}
.soc:hover{background:var(--tc);color:#fff;transform:translateY(-2px)}
.soc svg{width:18px;height:18px;fill:currentColor}
.cform{background:#fff;border-radius:28px;padding:2.8rem;box-shadow:var(--sh2);display:flex;flex-direction:column;gap:1.4rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.5rem}
.fg label{font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--mid)}
.fg input,.fg textarea,.fg select{background:var(--bg);border:1.5px solid var(--sand2);border-radius:12px;padding:.9rem 1.1rem;font-family:'Inter',sans-serif;font-size:.92rem;color:var(--dark);outline:none;transition:border-color .25s,box-shadow .25s}
.fg input:hover,.fg textarea:hover,.fg select:hover{border-color:var(--coral)}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--tc);box-shadow:0 0 0 3px rgba(212,96,58,.1)}
.fg textarea{resize:none;height:110px}
.btsub{background:var(--tc);color:#fff;border:none;border-radius:50px;padding:1.1rem 2.5rem;font-family:'Inter',sans-serif;font-size:.9rem;font-weight:500;cursor:pointer;align-self:flex-start;transition:background .3s,transform .25s,box-shadow .25s;box-shadow:0 4px 18px rgba(212,96,58,.28);display:flex;align-items:center;gap:.6rem}
.btsub::after{content:'→';font-size:1rem;transition:transform .25s}
.btsub:hover{background:var(--coral);transform:translateY(-2px);box-shadow:0 8px 26px rgba(212,96,58,.38)}
.btsub:hover::after{transform:translateX(4px)}
 /* FOOTER */
footer{background:var(--dark);padding:0;overflow:hidden}
footer::before{content:'';display:block;height:4px;background:repeating-linear-gradient(90deg,var(--must) 0,var(--must) 20px,var(--tc) 20px,var(--tc) 30px,var(--teal) 30px,var(--teal) 40px,var(--sage) 40px,var(--sage) 50px,var(--must) 50px,var(--must) 70px,var(--tc) 70px,var(--tc) 80px,var(--teal) 80px,var(--teal) 90px)}
.footer-inner{padding:3rem 5%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
.flogo{font-family:'Dancing Script',cursive;font-size:1.7rem;color:var(--must);text-decoration:none;transition:opacity .25s}
.flogo:hover{opacity:.8}
.fcopy{font-size:.8rem;color:rgba(255,255,255,.35);letter-spacing:.02em}
.flinks{display:flex;gap:1.8rem;list-style:none}
.flinks a{font-size:.8rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .25s}
.flinks a:hover{color:var(--must)}
 @keyframes popIn{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
@keyframes slideUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes floatIn{from{opacity:0;transform:translateY(-50%) scale(.9)}to{opacity:1;transform:translateY(-50%) scale(1)}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
 @media(max-width:960px){
  nav{padding:1rem 5%}
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;inset:0;background:var(--bg);align-items:center;justify-content:center;gap:2rem;z-index:200}
  .nav-links.open a{font-size:1.2rem}
  .hvisual{display:none}
  .hc{max-width:100%}
  .about-grid,.cgrid{grid-template-columns:1fr;gap:3rem}
  .awards-grid{grid-template-columns:1fr}
  .press-cards{grid-template-columns:1fr}
  .preview-grid{grid-template-columns:repeat(2,1fr)}
  .frow{grid-template-columns:1fr}
}
@media(max-width:540px){
  .preview-grid{grid-template-columns:1fr}
  .sband{flex-direction:column}
  .sbox{border-right:none;border-bottom:1.5px solid var(--sand)}
  .sbox:last-child{border-bottom:none}
}
