*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--vanille:#C8A96E;--terre:#6B4226;--foret:#2D4A35;--foret-light:#3D6147;--creme:#F5EDD8;--creme-dark:#EAD9BC;--brun:#3A1F0D;--ecru:#FAF6ED;--text:#2C1A0E;--text-light:#7A5C40;}
html{scroll-behavior:smooth;}
body{font-family:'Jost',sans-serif;background:var(--ecru);color:var(--text);overflow-x:hidden;cursor:none;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9000;}

.cursor{width:12px;height:12px;background:var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:multiply;}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 60px;display:flex;align-items:center;justify-content:space-between;background:rgba(250,246,237,.95);backdrop-filter:blur(12px);box-shadow:0 2px 40px rgba(58,31,13,.06);}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;letter-spacing:.12em;color:var(--brun);text-decoration:none;text-transform:uppercase;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);text-decoration:none;font-weight:400;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--vanille);transition:right .3s;}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-links a.active{color:var(--foret);}
.nav-cta{color:var(--brun)!important;background:var(--vanille);padding:10px 24px;border-radius:2px;font-weight:500!important;}
.nav-cta:hover{background:var(--creme-dark);}
.nav-cta::after{display:none!important;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--brun);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--brun);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--creme);text-decoration:none;transition:color .3s;}
.mobile-menu a:hover{color:var(--vanille);}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;color:var(--creme);font-size:1.5rem;cursor:none;}

/* HERO */
.blog-hero{padding:150px 80px 70px;background:var(--brun);position:relative;overflow:hidden;}
.blog-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 90% 50%,rgba(45,74,53,.4) 0%,transparent 65%);pointer-events:none;}
.bh-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px;position:relative;z-index:2;}
.bh-eyebrow span{font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;color:var(--vanille);}
.eline{width:36px;height:1px;background:var(--vanille);opacity:.6;}
.blog-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.08;color:var(--creme);position:relative;z-index:2;}
.blog-hero h1 em{font-style:italic;color:var(--vanille);}
.blog-hero p{font-size:1rem;line-height:1.8;color:rgba(245,237,216,.55);max-width:500px;margin-top:20px;font-weight:300;position:relative;z-index:2;}
.hero-deco{position:absolute;right:80px;top:50%;transform:translateY(-50%);opacity:.05;font-family:'Cormorant Garamond',serif;font-size:20rem;font-weight:300;color:var(--vanille);line-height:1;z-index:1;pointer-events:none;user-select:none;}

/* CATEGORIES */
.cat-bar{background:var(--creme);padding:0 80px;display:flex;align-items:center;gap:0;border-bottom:1px solid var(--creme-dark);overflow-x:auto;}
.cat-btn{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);font-weight:400;padding:20px 24px;border:none;background:none;cursor:none;border-bottom:2px solid transparent;transition:color .3s,border-color .3s;white-space:nowrap;}
.cat-btn:hover{color:var(--foret);}
.cat-btn.active{color:var(--foret);border-bottom-color:var(--foret);font-weight:500;}

/* BLOG MAIN */
.blog-main{padding:80px 80px;background:var(--ecru);}

/* FEATURED POST */
.featured-post{display:grid;grid-template-columns:1.2fr 1fr;gap:0;border-radius:6px;overflow:hidden;background:var(--creme);margin-bottom:60px;cursor:none;transition:box-shadow .4s;}
.featured-post:hover{box-shadow:0 20px 60px rgba(58,31,13,.12);}
.fp-thumb{min-height:420px;background:linear-gradient(145deg,#1a0d06 0%,#3D2510 35%,#2D4A35 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.fp-thumb::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 60%,rgba(200,169,110,.1) 0%,transparent 60%);}
.fp-thumb-icon{font-size:7rem;filter:drop-shadow(0 16px 32px rgba(0,0,0,.4));position:relative;z-index:2;transition:transform .5s ease;}
.featured-post:hover .fp-thumb-icon{transform:scale(1.06) rotate(-3deg);}
.fp-featured-badge{position:absolute;top:20px;left:20px;background:var(--vanille);color:var(--brun);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;padding:6px 14px;border-radius:2px;font-weight:500;z-index:3;}
.fp-body{padding:52px 48px;display:flex;flex-direction:column;justify-content:center;}
.fp-meta{display:flex;align-items:center;gap:16px;margin-bottom:18px;}
.fp-cat{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--foret);font-weight:500;}
.fp-date{font-size:.75rem;color:var(--text-light);opacity:.6;}
.fp-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--text-light);opacity:.3;}
.fp-body h2{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:400;line-height:1.2;color:var(--brun);margin-bottom:16px;}
.fp-body h2 em{font-style:italic;color:var(--foret);}
.fp-excerpt{font-size:.9rem;line-height:1.75;color:var(--text-light);font-weight:300;margin-bottom:32px;}
.read-more{display:inline-flex;align-items:center;gap:10px;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--foret);text-decoration:none;font-weight:500;transition:gap .3s;}
.read-more:hover{gap:16px;}
.read-more svg{transition:transform .3s;}
.read-more:hover svg{transform:translateX(4px);}

/* POSTS GRID */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px;}
.post-card{background:var(--creme);border-radius:4px;overflow:hidden;cursor:none;transition:transform .4s,box-shadow .4s;}
.post-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(58,31,13,.1);}
.pc-thumb{height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.pct-1{background:linear-gradient(145deg,#5C3A1E,#8B5E3C);}
.pct-2{background:linear-gradient(145deg,#2D3A1E,#4A6337);}
.pct-3{background:linear-gradient(145deg,#1a2d1f,#2D4A35);}
.pct-4{background:linear-gradient(145deg,#2D1A4A,#4A3570);}
.pct-5{background:linear-gradient(145deg,#4A1E10,#8B3A1E);}
.pct-6{background:linear-gradient(145deg,#1E2D4A,#3A5C8B);}
.pc-icon{font-size:3.5rem;filter:drop-shadow(0 8px 16px rgba(0,0,0,.3));transition:transform .4s;}
.post-card:hover .pc-icon{transform:scale(1.1) rotate(-2deg);}
.pc-cat-tag{position:absolute;bottom:14px;left:14px;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--vanille);border:1px solid rgba(200,169,110,.3);padding:4px 10px;border-radius:1px;background:rgba(0,0,0,.3);backdrop-filter:blur(4px);}
.pc-body{padding:24px 26px;}
.pc-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.pc-date{font-size:.72rem;color:var(--text-light);opacity:.55;}
.pc-read-time{font-size:.72rem;color:var(--text-light);opacity:.55;}
.pc-body h3{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:400;line-height:1.25;color:var(--brun);margin-bottom:10px;transition:color .3s;}
.post-card:hover .pc-body h3{color:var(--foret);}
.pc-body p{font-size:.82rem;line-height:1.65;color:var(--text-light);font-weight:300;}
.pc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--creme-dark);}
.pc-tags{display:flex;gap:6px;}
.pc-tag-pill{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--foret);background:rgba(45,74,53,.07);padding:3px 9px;border-radius:1px;}
.pc-arrow-sm{font-size:.9rem;color:var(--foret);text-decoration:none;opacity:.5;transition:opacity .3s,transform .3s;}
.post-card:hover .pc-arrow-sm{opacity:1;transform:translateX(4px);}

/* PAGINATION */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px 0 0;}
.pg-btn{width:40px;height:40px;border-radius:2px;border:1px solid var(--creme-dark);background:transparent;font-family:'Jost',sans-serif;font-size:.82rem;color:var(--text-light);cursor:none;transition:background .3s,color .3s,border-color .3s;}
.pg-btn:hover,.pg-btn.active{background:var(--foret);color:var(--creme);border-color:var(--foret);}
.pg-sep{color:var(--text-light);opacity:.3;padding:0 4px;}

/* NEWSLETTER BAND */
.newsletter{background:var(--foret);padding:80px;display:flex;align-items:center;justify-content:space-between;gap:60px;}
.nl-content h3{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--creme);margin-bottom:8px;}
.nl-content h3 em{font-style:italic;color:var(--vanille);}
.nl-content p{font-size:.9rem;color:rgba(245,237,216,.55);font-weight:300;}
.nl-form{display:flex;gap:0;flex-shrink:0;}
.nl-input{width:300px;background:rgba(245,237,216,.08);border:1px solid rgba(245,237,216,.15);border-right:none;border-radius:2px 0 0 2px;padding:14px 20px;font-family:'Jost',sans-serif;font-size:.88rem;color:var(--creme);outline:none;transition:border-color .3s;cursor:none;}
.nl-input::placeholder{color:rgba(245,237,216,.3);}
.nl-input:focus{border-color:rgba(200,169,110,.4);}
.nl-btn{background:var(--vanille);color:var(--brun);border:none;font-family:'Jost',sans-serif;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:14px 28px;border-radius:0 2px 2px 0;cursor:none;transition:background .3s;}
.nl-btn:hover{background:var(--creme);}

/* FOOTER */
footer{background:#0D0604;color:rgba(245,237,216,.4);padding:60px 80px 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid rgba(245,237,216,.07);margin-bottom:40px;}
.footer-brand .brand-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--creme);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;}
.footer-brand p{font-size:.85rem;line-height:1.7;font-weight:300;max-width:240px;}
.footer-socials{display:flex;gap:12px;margin-top:24px;}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(245,237,216,.12);display:flex;align-items:center;justify-content:center;color:rgba(245,237,216,.4);text-decoration:none;font-size:.8rem;transition:border-color .3s,color .3s;}
.social-btn:hover{border-color:var(--vanille);color:var(--vanille);}
.footer-col h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,237,216,.6);margin-bottom:20px;font-weight:500;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:rgba(245,237,216,.35);text-decoration:none;font-size:.85rem;font-weight:300;transition:color .3s;}
.footer-col ul li a:hover{color:var(--vanille);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:.75rem;letter-spacing:.08em;}
.footer-langs{display:flex;gap:20px;}
.footer-langs a{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,237,216,.3);text-decoration:none;transition:color .3s;}
.footer-langs a:hover,.footer-langs a.active{color:var(--vanille);}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

@media(max-width:768px){
  nav{padding:16px 24px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .blog-hero{padding:110px 24px 55px;}
  .hero-deco{display:none;}
  .cat-bar{padding:0 24px;}
  .blog-main{padding:60px 24px;}
  .featured-post{grid-template-columns:1fr;}
  .fp-thumb{min-height:240px;}
  .fp-body{padding:32px 28px;}
  .posts-grid{grid-template-columns:1fr;}
  .newsletter{padding:60px 24px;flex-direction:column;gap:32px;}
  .nl-form{flex-direction:column;width:100%;}
  .nl-input{width:100%;border-right:1px solid rgba(245,237,216,.15);border-bottom:none;border-radius:2px 2px 0 0;}
  .nl-btn{border-radius:0 0 2px 2px;padding:14px;}
  footer{padding:50px 24px 30px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
}
@media(max-width:480px){.footer-top{grid-template-columns:1fr;}}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --vanille:#C8A96E; --terre:#6B4226; --foret:#2D4A35; --foret-light:#3D6147;
  --creme:#F5EDD8; --creme-dark:#EAD9BC; --brun:#3A1F0D; --ecru:#FAF6ED;
  --text:#2C1A0E; --text-light:#7A5C40;
}
html { scroll-behavior:smooth; }
body { font-family:'Jost',sans-serif;background:var(--ecru);color:var(--text);overflow-x:hidden;cursor:none; }
body::before { content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9000; }

/* CURSOR */
.cursor{width:12px;height:12px;background:var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:multiply;}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 60px;display:flex;align-items:center;justify-content:space-between;background:rgba(250,246,237,.95);backdrop-filter:blur(12px);box-shadow:0 2px 40px rgba(58,31,13,.06);}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;letter-spacing:.12em;color:var(--brun);text-decoration:none;text-transform:uppercase;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);text-decoration:none;font-weight:400;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--vanille);transition:right .3s;}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-links a.active{color:var(--foret);}
.nav-cta{color:var(--brun)!important;background:var(--vanille);padding:10px 24px;border-radius:2px;font-weight:500!important;}
.nav-cta:hover{background:var(--creme-dark);}
.nav-cta::after{display:none!important;}

/* PAGE HERO */
.page-hero{padding:150px 80px 90px;background:var(--brun);position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 85% 50%,rgba(45,74,53,.45) 0%,transparent 65%),radial-gradient(ellipse 40% 50% at 10% 90%,rgba(107,66,38,.4) 0%,transparent 55%);pointer-events:none;}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px;position:relative;z-index:2;}
.hero-eyebrow span{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--vanille);}
.eline{width:40px;height:1px;background:var(--vanille);opacity:.6;}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.08;color:var(--creme);position:relative;z-index:2;}
.page-hero h1 em{font-style:italic;color:var(--vanille);}
.page-hero p{font-size:1rem;line-height:1.8;color:rgba(245,237,216,.6);max-width:520px;margin-top:20px;font-weight:300;position:relative;z-index:2;}
.hero-deco{position:absolute;right:60px;top:50%;transform:translateY(-50%);opacity:.06;font-family:'Cormorant Garamond',serif;font-size:22rem;font-weight:300;color:var(--vanille);line-height:1;z-index:1;pointer-events:none;user-select:none;}

/* FILTER BAR */
.filter-bar{background:var(--creme);padding:0 80px;display:flex;align-items:center;gap:0;border-bottom:1px solid var(--creme-dark);position:sticky;top:65px;z-index:50;}
.filter-btn{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);font-weight:400;padding:20px 28px;border:none;background:none;cursor:none;border-bottom:2px solid transparent;transition:color .3s,border-color .3s;}
.filter-btn:hover{color:var(--foret);}
.filter-btn.active{color:var(--foret);border-bottom-color:var(--foret);font-weight:500;}
.filter-count{margin-left:8px;background:var(--foret);color:var(--creme);font-size:.6rem;padding:2px 7px;border-radius:10px;letter-spacing:.05em;}

/* PRODUITS SECTION */
.produits-section{padding:80px 80px;background:var(--ecru);}

/* FEATURED PRODUCT */
.featured-product{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:6px;overflow:hidden;margin-bottom:60px;background:var(--creme);}
.fp-visual{background:linear-gradient(145deg,#1a0d06 0%,#3D2510 40%,#2D4A35 100%);min-height:480px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.fp-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(200,169,110,.12) 0%,transparent 60%);}
.fp-emoji{font-size:8rem;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4));position:relative;z-index:2;transition:transform .5s ease;}
.featured-product:hover .fp-emoji{transform:scale(1.05) rotate(-4deg);}
.fp-badge{position:absolute;top:24px;left:24px;background:var(--vanille);color:var(--brun);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;padding:7px 16px;border-radius:2px;font-weight:500;z-index:3;}
.fp-content{padding:60px 56px;display:flex;flex-direction:column;justify-content:center;}
.fp-tag{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--foret);font-weight:500;margin-bottom:16px;}
.fp-content h2{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:300;line-height:1.1;color:var(--brun);margin-bottom:20px;}
.fp-content h2 em{font-style:italic;color:var(--foret);}
.fp-content p{font-size:.95rem;line-height:1.85;color:var(--text-light);font-weight:300;margin-bottom:32px;}
.fp-specs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px;}
.spec-pill{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);border:1px solid var(--creme-dark);padding:6px 14px;border-radius:2px;}
.fp-actions{display:flex;gap:16px;align-items:center;}
.btn-primary{display:inline-block;background:var(--vanille);color:var(--brun);text-decoration:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:15px 32px;border-radius:2px;transition:background .3s,transform .2s,box-shadow .3s;border:none;cursor:none;}
.btn-primary:hover{background:var(--creme-dark);transform:translateY(-2px);box-shadow:0 12px 40px rgba(200,169,110,.3);}
.btn-outline{display:inline-block;border:1px solid rgba(44,26,14,.2);color:var(--text-light);text-decoration:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;padding:15px 32px;border-radius:2px;transition:border-color .3s,color .3s;cursor:none;}
.btn-outline:hover{border-color:var(--foret);color:var(--foret);}

/* PRODUCTS GRID */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.product-card{background:var(--creme);border-radius:4px;overflow:hidden;transition:transform .4s,box-shadow .4s;cursor:none;}
.product-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(58,31,13,.1);}
.pc-visual{height:240px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.pc-v1{background:linear-gradient(145deg,#5C3A1E,#8B5E3C);}
.pc-v2{background:linear-gradient(145deg,#2D3A1E,#4A6337);}
.pc-v3{background:linear-gradient(145deg,#2D1A4A,#4A3570);}
.pc-v4{background:linear-gradient(145deg,#1a2d1f,#2D4A35);}
.pc-v5{background:linear-gradient(145deg,#4A1E10,#8B3A1E);}
.pc-emoji{font-size:4rem;filter:drop-shadow(0 8px 20px rgba(0,0,0,.3));transition:transform .4s;}
.product-card:hover .pc-emoji{transform:scale(1.1) rotate(-3deg);}
.pc-tag{position:absolute;top:16px;left:16px;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--vanille);border:1px solid rgba(200,169,110,.3);padding:4px 10px;border-radius:1px;background:rgba(0,0,0,.2);backdrop-filter:blur(4px);}
.pc-body{padding:24px 28px;}
.pc-body h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--brun);margin-bottom:8px;}
.pc-body p{font-size:.85rem;color:var(--text-light);line-height:1.65;font-weight:300;}
.pc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:16px;border-top:1px solid var(--creme-dark);}
.pc-detail{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--foret);font-weight:500;}
.pc-arrow{width:34px;height:34px;border-radius:50%;background:var(--foret);display:flex;align-items:center;justify-content:center;color:var(--creme);text-decoration:none;font-size:.85rem;transition:background .3s,transform .3s;}
.pc-arrow:hover{background:var(--vanille);color:var(--brun);transform:rotate(45deg);}

/* CONDITIONNEMENT */
.cond-section{background:var(--foret);color:var(--creme);padding:100px 80px;}
.cond-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:center;}
.cond-content h2.display{color:var(--creme);}
.cond-content h2.display em{color:var(--vanille);}
.cond-content p{font-size:1rem;line-height:1.85;color:rgba(245,237,216,.6);font-weight:300;margin-top:20px;}
.cond-table{margin-top:0;}
.cond-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;border-bottom:1px solid rgba(245,237,216,.08);}
.cond-row.header{border-bottom:1px solid rgba(245,237,216,.2);}
.cond-cell{padding:18px 20px;font-size:.83rem;color:rgba(245,237,216,.55);font-weight:300;}
.cond-row.header .cond-cell{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,237,216,.4);font-weight:400;}
.cond-row:not(.header):hover .cond-cell{color:rgba(245,237,216,.85);background:rgba(245,237,216,.03);}
.cond-cell.highlight{color:var(--vanille);font-weight:400;}

/* CTA BAND */
.cta-band{background:var(--vanille);padding:60px 80px;display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-band h3{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;color:var(--brun);line-height:1.2;}
.cta-band h3 em{font-style:italic;}
.btn-dark{display:inline-block;background:var(--brun);color:var(--creme);text-decoration:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:16px 36px;border-radius:2px;transition:background .3s,transform .2s;white-space:nowrap;cursor:none;}
.btn-dark:hover{background:#1a0d06;transform:translateY(-2px);}

/* MARQUEE */
.marquee-band{background:var(--foret);padding:16px 0;overflow:hidden;}
.marquee-track{display:flex;animation:marqueeScroll 25s linear infinite;white-space:nowrap;}
.marquee-item{display:inline-flex;align-items:center;gap:24px;padding:0 24px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,237,216,.7);font-weight:300;}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--vanille);opacity:.6;}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* FOOTER */
footer{background:#0D0604;color:rgba(245,237,216,.4);padding:60px 80px 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid rgba(245,237,216,.07);margin-bottom:40px;}
.footer-brand .brand-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--creme);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;}
.footer-brand p{font-size:.85rem;line-height:1.7;font-weight:300;max-width:240px;}
.footer-socials{display:flex;gap:12px;margin-top:24px;}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(245,237,216,.12);display:flex;align-items:center;justify-content:center;color:rgba(245,237,216,.4);text-decoration:none;font-size:.8rem;transition:border-color .3s,color .3s;}
.social-btn:hover{border-color:var(--vanille);color:var(--vanille);}
.footer-col h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,237,216,.6);margin-bottom:20px;font-weight:500;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:rgba(245,237,216,.35);text-decoration:none;font-size:.85rem;font-weight:300;transition:color .3s;}
.footer-col ul li a:hover{color:var(--vanille);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:.75rem;letter-spacing:.08em;}
.footer-langs{display:flex;gap:20px;}
.footer-langs a{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,237,216,.3);text-decoration:none;transition:color .3s;}
.footer-langs a:hover,.footer-langs a.active{color:var(--vanille);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

/* MOBILE */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--brun);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--brun);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--creme);text-decoration:none;transition:color .3s;}
.mobile-menu a:hover{color:var(--vanille);}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;color:var(--creme);font-size:1.5rem;cursor:none;}
h2.display{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.1;color:var(--brun);}
h2.display em{font-style:italic;color:var(--foret);}
.section-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.section-eyebrow span{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--foret);font-weight:500;}
.eyebrow-line-dark{width:40px;height:1px;background:var(--foret);opacity:.4;}

@media(max-width:768px){
  nav{padding:16px 24px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .page-hero{padding:110px 24px 60px;}
  .hero-deco{display:none;}
  .filter-bar{padding:0 24px;overflow-x:auto;top:58px;}
  .filter-btn{padding:18px 16px;white-space:nowrap;}
  .produits-section{padding:60px 24px;}
  .featured-product{grid-template-columns:1fr;}
  .fp-visual{min-height:280px;}
  .fp-content{padding:36px 28px;}
  .products-grid{grid-template-columns:1fr;}
  .cond-section{padding:70px 24px;}
  .cond-grid{grid-template-columns:1fr;gap:40px;}
  .cta-band{padding:50px 24px;flex-direction:column;text-align:center;}
  footer{padding:50px 24px 30px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
}
@media(max-width:480px){
  .footer-top{grid-template-columns:1fr;}
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--vanille:#C8A96E;--terre:#6B4226;--foret:#2D4A35;--foret-light:#3D6147;--creme:#F5EDD8;--creme-dark:#EAD9BC;--brun:#3A1F0D;--ecru:#FAF6ED;--text:#2C1A0E;--text-light:#7A5C40;}
html{scroll-behavior:smooth;}
body{font-family:'Jost',sans-serif;background:var(--ecru);color:var(--text);overflow-x:hidden;cursor:none;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9000;}

/* CURSOR */
.cursor{width:12px;height:12px;background:var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:multiply;}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 60px;display:flex;align-items:center;justify-content:space-between;background:rgba(250,246,237,.95);backdrop-filter:blur(12px);box-shadow:0 2px 40px rgba(58,31,13,.06);}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;letter-spacing:.12em;color:var(--brun);text-decoration:none;text-transform:uppercase;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);text-decoration:none;font-weight:400;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--vanille);transition:right .3s;}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-links a.active{color:var(--foret);}
.nav-cta{color:var(--brun)!important;background:var(--vanille);padding:10px 24px;border-radius:2px;font-weight:500!important;}
.nav-cta:hover{background:var(--creme-dark);}
.nav-cta::after{display:none!important;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--brun);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--brun);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--creme);text-decoration:none;transition:color .3s;}
.mobile-menu a:hover{color:var(--vanille);}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;color:var(--creme);font-size:1.5rem;cursor:none;}

/* CONTACT LAYOUT */
.contact-layout{display:grid;grid-template-columns:1fr 1.1fr;min-height:100vh;}

/* LEFT PANEL */
.contact-left{background:var(--brun);padding:150px 70px 80px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;}
.contact-left::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 80%,rgba(45,74,53,.4) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 80% 20%,rgba(200,169,110,.08) 0%,transparent 50%);pointer-events:none;}
.cl-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px;position:relative;z-index:2;}
.cl-eyebrow span{font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;color:var(--vanille);}
.eline{width:36px;height:1px;background:var(--vanille);opacity:.6;}
.contact-left h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.5rem,4vw,4rem);font-weight:300;line-height:1.1;color:var(--creme);position:relative;z-index:2;margin-bottom:24px;}
.contact-left h1 em{font-style:italic;color:var(--vanille);}
.contact-left .intro{font-size:.95rem;line-height:1.85;color:rgba(245,237,216,.55);font-weight:300;max-width:340px;position:relative;z-index:2;margin-bottom:60px;}

.contact-infos{position:relative;z-index:2;}
.contact-info-item{display:flex;align-items:flex-start;gap:18px;margin-bottom:28px;}
.ci-icon{width:40px;height:40px;border-radius:50%;background:rgba(245,237,216,.07);border:1px solid rgba(245,237,216,.1);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;transition:background .3s,border-color .3s;}
.contact-info-item:hover .ci-icon{background:rgba(200,169,110,.12);border-color:rgba(200,169,110,.25);}
.ci-label{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,237,216,.35);margin-bottom:4px;}
.ci-value{font-size:.9rem;color:rgba(245,237,216,.75);font-weight:300;line-height:1.4;}
.ci-value a{color:rgba(245,237,216,.75);text-decoration:none;transition:color .3s;}
.ci-value a:hover{color:var(--vanille);}

.contact-socials{display:flex;gap:12px;margin-top:48px;position:relative;z-index:2;}
.social-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(245,237,216,.1);color:rgba(245,237,216,.4);text-decoration:none;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;padding:8px 16px;border-radius:2px;transition:border-color .3s,color .3s;}
.social-pill:hover{border-color:var(--vanille);color:var(--vanille);}

.cl-deco{position:absolute;bottom:-40px;right:-40px;font-family:'Cormorant Garamond',serif;font-size:18rem;font-weight:300;color:rgba(200,169,110,.04);line-height:1;user-select:none;pointer-events:none;}

/* RIGHT PANEL — FORM */
.contact-right{background:var(--ecru);padding:150px 70px 80px;display:flex;flex-direction:column;justify-content:center;}
.form-header{margin-bottom:48px;}
.form-type-tabs{display:flex;gap:0;margin-bottom:40px;border:1px solid var(--creme-dark);border-radius:3px;overflow:hidden;}
.tab-btn{flex:1;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-light);background:transparent;border:none;padding:14px 20px;cursor:none;transition:background .3s,color .3s;font-family:'Jost',sans-serif;}
.tab-btn.active{background:var(--foret);color:var(--creme);}
.tab-btn:hover:not(.active){background:var(--creme-dark);color:var(--text);}

.form-group{margin-bottom:24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
label{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-light);margin-bottom:8px;font-weight:400;}
label span{color:var(--vanille);margin-left:2px;}
input,select,textarea{width:100%;background:var(--creme);border:1px solid var(--creme-dark);border-radius:2px;padding:14px 18px;font-family:'Jost',sans-serif;font-size:.9rem;color:var(--text);font-weight:300;transition:border-color .3s,box-shadow .3s;outline:none;appearance:none;cursor:none;}
input:focus,select:focus,textarea:focus{border-color:var(--foret);box-shadow:0 0 0 3px rgba(45,74,53,.08);}
input::placeholder,textarea::placeholder{color:var(--text-light);opacity:.5;}
textarea{height:130px;resize:vertical;line-height:1.6;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A5C40' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;}

.checkbox-group{display:flex;align-items:flex-start;gap:12px;margin-bottom:28px;}
.checkbox-group input[type="checkbox"]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--foret);}
.checkbox-group label{font-size:.82rem;letter-spacing:.02em;text-transform:none;color:var(--text-light);margin-bottom:0;line-height:1.5;}
.checkbox-group label a{color:var(--foret);text-decoration:none;}
.checkbox-group label a:hover{text-decoration:underline;}

.btn-submit{width:100%;background:var(--foret);color:var(--creme);border:none;font-family:'Jost',sans-serif;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;padding:18px;border-radius:2px;cursor:none;transition:background .3s,transform .2s,box-shadow .3s;position:relative;overflow:hidden;}
.btn-submit::before{content:'';position:absolute;inset:0;background:rgba(245,237,216,.05);transform:translateX(-100%);transition:transform .4s;}
.btn-submit:hover::before{transform:translateX(0);}
.btn-submit:hover{background:#1f3527;transform:translateY(-2px);box-shadow:0 12px 40px rgba(45,74,53,.25);}

.form-note{font-size:.75rem;color:var(--text-light);opacity:.6;text-align:center;margin-top:16px;line-height:1.5;}

/* SUCCESS STATE */
.form-success{display:none;text-align:center;padding:60px 40px;}
.success-icon{font-size:3rem;margin-bottom:20px;}
.success-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--brun);margin-bottom:12px;}
.success-desc{font-size:.9rem;color:var(--text-light);line-height:1.7;margin-bottom:32px;}

/* GUARANTEES */
.guarantees{background:var(--creme);padding:80px;}
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--creme-dark);border:1px solid var(--creme-dark);border-radius:4px;overflow:hidden;}
.g-cell{background:var(--creme);padding:36px 28px;text-align:center;transition:background .3s;}
.g-cell:hover{background:var(--ecru);}
.g-icon{font-size:2rem;margin-bottom:14px;}
.g-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;color:var(--brun);margin-bottom:6px;}
.g-desc{font-size:.8rem;color:var(--text-light);line-height:1.6;}

/* FOOTER */
footer{background:#0D0604;color:rgba(245,237,216,.4);padding:60px 80px 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid rgba(245,237,216,.07);margin-bottom:40px;}
.footer-brand .brand-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--creme);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;}
.footer-brand p{font-size:.85rem;line-height:1.7;font-weight:300;max-width:240px;}
.footer-socials{display:flex;gap:12px;margin-top:24px;}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(245,237,216,.12);display:flex;align-items:center;justify-content:center;color:rgba(245,237,216,.4);text-decoration:none;font-size:.8rem;transition:border-color .3s,color .3s;}
.social-btn:hover{border-color:var(--vanille);color:var(--vanille);}
.footer-col h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,237,216,.6);margin-bottom:20px;font-weight:500;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:rgba(245,237,216,.35);text-decoration:none;font-size:.85rem;font-weight:300;transition:color .3s;}
.footer-col ul li a:hover{color:var(--vanille);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:.75rem;letter-spacing:.08em;}
.footer-langs{display:flex;gap:20px;}
.footer-langs a{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,237,216,.3);text-decoration:none;transition:color .3s;}
.footer-langs a:hover,.footer-langs a.active{color:var(--vanille);}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

@media(max-width:900px){
  .contact-layout{grid-template-columns:1fr;min-height:auto;}
  .contact-left{padding:120px 28px 60px;}
  .contact-right{padding:60px 28px 80px;}
  .cl-deco{display:none;}
  nav{padding:16px 24px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .guarantees{padding:60px 24px;}
  .g-grid{grid-template-columns:1fr 1fr;}
  footer{padding:50px 24px 30px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
  .form-row{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .g-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--vanille:#C8A96E;--terre:#6B4226;--foret:#2D4A35;--foret-light:#3D6147;--creme:#F5EDD8;--creme-dark:#EAD9BC;--brun:#3A1F0D;--ecru:#FAF6ED;--text:#2C1A0E;--text-light:#7A5C40;}
html{scroll-behavior:smooth;}
body{font-family:'Jost',sans-serif;background:var(--ecru);color:var(--text);overflow-x:hidden;cursor:none;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9000;}

.cursor{width:12px;height:12px;background:var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:multiply;}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--vanille);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 60px;display:flex;align-items:center;justify-content:space-between;background:rgba(250,246,237,.95);backdrop-filter:blur(12px);box-shadow:0 2px 40px rgba(58,31,13,.06);}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;letter-spacing:.12em;color:var(--brun);text-decoration:none;text-transform:uppercase;}
.nav-links{display:flex;gap:40px;list-style:none;}
.nav-links a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);text-decoration:none;font-weight:400;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--vanille);transition:right .3s;}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-links a.active{color:var(--foret);}
.nav-cta{color:var(--brun)!important;background:var(--vanille);padding:10px 24px;border-radius:2px;font-weight:500!important;}
.nav-cta:hover{background:var(--creme-dark);}
.nav-cta::after{display:none!important;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--brun);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--brun);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--creme);text-decoration:none;transition:color .3s;}
.mobile-menu a:hover{color:var(--vanille);}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;color:var(--creme);font-size:1.5rem;cursor:none;}

/* HERO */
.page-hero{padding:150px 80px 90px;background:var(--brun);position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 85% 50%,rgba(45,74,53,.45) 0%,transparent 65%),radial-gradient(ellipse 40% 50% at 10% 90%,rgba(107,66,38,.4) 0%,transparent 55%);pointer-events:none;}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px;position:relative;z-index:2;}
.hero-eyebrow span{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--vanille);}
.eline{width:40px;height:1px;background:var(--vanille);opacity:.6;}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.08;color:var(--creme);position:relative;z-index:2;}
.page-hero h1 em{font-style:italic;color:var(--vanille);}
.page-hero p{font-size:1rem;line-height:1.8;color:rgba(245,237,216,.6);max-width:540px;margin-top:20px;font-weight:300;position:relative;z-index:2;}
.hero-deco{position:absolute;right:60px;top:50%;transform:translateY(-50%);opacity:.05;font-family:'Cormorant Garamond',serif;font-size:22rem;font-weight:300;color:var(--vanille);line-height:1;z-index:1;pointer-events:none;user-select:none;}

/* SHARED */
h2.display{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;line-height:1.1;color:var(--brun);}
h2.display em{font-style:italic;color:var(--foret);}
.section-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.section-eyebrow span{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--foret);font-weight:500;}
.eyebrow-line-dark{width:40px;height:1px;background:var(--foret);opacity:.4;}
.btn-primary{display:inline-block;background:var(--vanille);color:var(--brun);text-decoration:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:16px 36px;border-radius:2px;transition:background .3s,transform .2s;cursor:none;}
.btn-primary:hover{background:var(--creme-dark);transform:translateY(-2px);}

/* INTRO SPLIT */
.intro-split{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;padding:100px 80px;background:var(--creme);}
.intro-visual{position:relative;height:500px;}
.iv-main{position:absolute;top:0;left:0;width:75%;height:80%;border-radius:4px;background:linear-gradient(145deg,#1a0d06,#3D2510 50%,#2D4A35);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.iv-accent{position:absolute;bottom:0;right:0;width:55%;height:45%;border-radius:4px;background:var(--foret);display:flex;align-items:center;justify-content:center;}
.iv-text{font-family:'Cormorant Garamond',serif;font-size:5rem;font-weight:300;color:rgba(245,237,216,.08);user-select:none;}
.iv-badge{position:absolute;top:50%;left:58%;transform:translate(-50%,-50%);background:var(--vanille);color:var(--brun);width:110px;height:110px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;box-shadow:0 10px 40px rgba(200,169,110,.35);}
.iv-badge .num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;line-height:1;}
.iv-badge .lbl{font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;opacity:.7;margin-top:2px;}
.intro-content p{font-size:1rem;line-height:1.9;color:var(--text-light);font-weight:300;margin-top:20px;}
.intro-content p+p{margin-top:16px;}
.intro-content .highlight-quote{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;font-style:italic;color:var(--foret);line-height:1.5;border-left:3px solid var(--vanille);padding-left:24px;margin:32px 0;}

/* TIMELINE */
.timeline-section{padding:100px 80px;background:var(--ecru);}
.tl-header{text-align:center;margin-bottom:70px;}
.tl-header .section-eyebrow{justify-content:center;}
.timeline{position:relative;max-width:800px;margin:0 auto;}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--creme-dark);transform:translateX(-50%);}
.tl-item{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:60px;position:relative;}
.tl-item:nth-child(even) .tl-content{order:-1;}
.tl-item:nth-child(even) .tl-year-wrap{text-align:left;}
.tl-year-wrap{text-align:right;}
.tl-year{display:inline-block;font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--vanille);line-height:1;}
.tl-dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:var(--vanille);border:3px solid var(--ecru);box-shadow:0 0 0 1px var(--vanille);z-index:2;}
.tl-content{background:var(--creme);border-radius:4px;padding:28px 32px;border:1px solid var(--creme-dark);transition:box-shadow .3s;}
.tl-content:hover{box-shadow:0 8px 30px rgba(58,31,13,.08);}
.tl-content h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--brun);margin-bottom:8px;}
.tl-content p{font-size:.85rem;color:var(--text-light);line-height:1.65;font-weight:300;}

/* VALEURS */
.valeurs{padding:100px 80px;background:var(--foret);color:var(--creme);}
.valeurs h2.display{color:var(--creme);}
.valeurs h2.display em{color:var(--vanille);}
.valeurs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:60px;background:rgba(245,237,216,.05);border-radius:4px;overflow:hidden;}
.valeur-cell{background:rgba(245,237,216,.03);padding:50px 40px;border:1px solid rgba(245,237,216,.05);transition:background .3s,border-color .3s;}
.valeur-cell:hover{background:rgba(245,237,216,.07);border-color:rgba(200,169,110,.15);}
.valeur-icon{font-size:2.5rem;margin-bottom:20px;display:block;}
.valeur-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--creme);margin-bottom:12px;}
.valeur-desc{font-size:.88rem;color:rgba(245,237,216,.55);line-height:1.75;font-weight:300;}

/* EQUIPE */
.equipe{padding:100px 80px;background:var(--creme);}
.equipe-header{margin-bottom:60px;}
.equipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.membre-card{background:var(--ecru);border-radius:4px;overflow:hidden;transition:transform .4s,box-shadow .4s;}
.membre-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(58,31,13,.1);}
.membre-visual{height:220px;display:flex;align-items:center;justify-content:center;position:relative;}
.mv-1{background:linear-gradient(145deg,#2D4A35,#4A6337);}
.mv-2{background:linear-gradient(145deg,#3A1F0D,#6B4226);}
.mv-3{background:linear-gradient(145deg,#1a2d1f,#2D4A35);}
.membre-initiales{font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;color:rgba(245,237,216,.25);}
.membre-body{padding:28px;}
.membre-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--brun);margin-bottom:4px;}
.membre-role{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--foret);font-weight:500;margin-bottom:12px;}
.membre-bio{font-size:.83rem;color:var(--text-light);line-height:1.65;font-weight:300;}

/* ENGAGEMENT */
.engagement{padding:100px 80px;background:var(--ecru);}
.engagement-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.eng-content p{font-size:1rem;line-height:1.85;color:var(--text-light);font-weight:300;margin-top:20px;}
.eng-list{margin-top:36px;display:flex;flex-direction:column;gap:16px;}
.eng-item{display:flex;align-items:flex-start;gap:16px;padding:20px 24px;background:var(--creme);border-radius:4px;border:1px solid var(--creme-dark);transition:border-color .3s;}
.eng-item:hover{border-color:var(--vanille);}
.eng-item-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px;}
.eng-item-text h4{font-size:.88rem;font-weight:500;color:var(--brun);margin-bottom:4px;}
.eng-item-text p{font-size:.82rem;color:var(--text-light);line-height:1.55;font-weight:300;}
.eng-visual{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.ev-cell{border-radius:4px;padding:40px 28px;display:flex;flex-direction:column;align-items:center;text-align:center;}
.ev-cell-1{background:var(--foret);grid-row:span 2;}
.ev-cell-2{background:var(--terre);}
.ev-cell-3{background:var(--brun);}
.ev-num{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;color:var(--vanille);line-height:1;}
.ev-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,237,216,.55);margin-top:6px;}

/* CTA */
.cta-section{background:var(--vanille);padding:80px;display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-section h3{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--brun);line-height:1.2;}
.cta-section h3 em{font-style:italic;}
.btn-dark{display:inline-block;background:var(--brun);color:var(--creme);text-decoration:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:16px 36px;border-radius:2px;transition:background .3s,transform .2s;white-space:nowrap;cursor:none;}
.btn-dark:hover{background:#1a0d06;transform:translateY(-2px);}

/* FOOTER */
footer{background:#0D0604;color:rgba(245,237,216,.4);padding:60px 80px 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid rgba(245,237,216,.07);margin-bottom:40px;}
.footer-brand .brand-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--creme);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;}
.footer-brand p{font-size:.85rem;line-height:1.7;font-weight:300;max-width:240px;}
.footer-socials{display:flex;gap:12px;margin-top:24px;}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(245,237,216,.12);display:flex;align-items:center;justify-content:center;color:rgba(245,237,216,.4);text-decoration:none;font-size:.8rem;transition:border-color .3s,color .3s;}
.social-btn:hover{border-color:var(--vanille);color:var(--vanille);}
.footer-col h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,237,216,.6);margin-bottom:20px;font-weight:500;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:rgba(245,237,216,.35);text-decoration:none;font-size:.85rem;font-weight:300;transition:color .3s;}
.footer-col ul li a:hover{color:var(--vanille);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:.75rem;}
.footer-langs{display:flex;gap:20px;}
.footer-langs a{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,237,216,.3);text-decoration:none;transition:color .3s;}
.footer-langs a:hover,.footer-langs a.active{color:var(--vanille);}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}
.reveal-delay-4{transition-delay:.4s;}

@media(max-width:900px){
  nav{padding:16px 24px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .page-hero{padding:110px 24px 60px;}
  .hero-deco{display:none;}
  .intro-split{grid-template-columns:1fr;gap:40px;padding:70px 24px;}
  .intro-visual{height:280px;}
  .timeline-section{padding:70px 24px;}
  .timeline::before{left:20px;}
  .tl-item{grid-template-columns:1fr;gap:16px;padding-left:50px;}
  .tl-item:nth-child(even) .tl-content{order:0;}
  .tl-year-wrap,.tl-item:nth-child(even) .tl-year-wrap{text-align:left;}
  .tl-dot{left:20px;top:20px;}
  .valeurs{padding:70px 24px;}
  .valeurs-grid{grid-template-columns:1fr;}
  .equipe{padding:70px 24px;}
  .equipe-grid{grid-template-columns:1fr;}
  .engagement{padding:70px 24px;}
  .engagement-grid{grid-template-columns:1fr;}
  .cta-section{padding:60px 24px;flex-direction:column;text-align:center;}
  footer{padding:50px 24px 30px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
}
@media(max-width:480px){.footer-top{grid-template-columns:1fr;}}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  :root {
    --vanille:     #C8A96E;
    --terre:       #6B4226;
    --foret:       #2D4A35;
    --foret-light: #3D6147;
    --creme:       #F5EDD8;
    --creme-dark:  #EAD9BC;
    --brun:        #3A1F0D;
    --ecru:        #FAF6ED;
    --text:        #2C1A0E;
    --text-light:  #7A5C40;
  }

  html { scroll-behavior: smooth; }

  body {
    font-family: 'Jost', sans-serif;
    background: var(--ecru);
    color: var(--text);
    overflow-x: hidden;
    cursor: none;
  }

  /* CUSTOM CURSOR */
  .cursor {
    width: 12px; height: 12px;
    background: var(--vanille);
    border-radius: 50%;
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
    transition: transform 0.15s ease, width 0.3s ease, height 0.3s ease, background 0.3s ease;
    mix-blend-mode: multiply;
  }
  .cursor-ring {
    width: 36px; height: 36px;
    border: 1.5px solid var(--vanille);
    border-radius: 50%;
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%, -50%);
    transition: transform 0.35s ease, width 0.3s ease, height 0.3s ease, opacity 0.3s ease;
    opacity: 0.6;
  }

  /* GRAIN OVERLAY */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
    opacity: 0.03;
    pointer-events: none;
    z-index: 9000;
  }

  /* NAV */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 28px 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background 0.4s ease, padding 0.4s ease, backdrop-filter 0.4s ease;
  }
  nav.scrolled {
    background: rgba(250, 246, 237, 0.92);
    backdrop-filter: blur(12px);
    padding: 18px 60px;
    box-shadow: 0 2px 40px rgba(58, 31, 13, 0.08);
  }
  .nav-logo {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    color: var(--ecru);
    text-decoration: none;
    text-transform: uppercase;
    transition: color 0.4s;
  }
  nav.scrolled .nav-logo { color: var(--brun); }
  .nav-links { display: flex; gap: 40px; list-style: none; }
  .nav-links a {
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(250,246,237,0.85);
    text-decoration: none;
    font-weight: 400;
    transition: color 0.3s;
    position: relative;
  }
  nav.scrolled .nav-links a { color: var(--text-light); }
  .nav-links a::after {
    content: '';
    position: absolute;
    bottom: -3px; left: 0; right: 100%;
    height: 1px;
    background: var(--vanille);
    transition: right 0.3s ease;
  }
  .nav-links a:hover::after { right: 0; }
  .nav-cta {
    font-size: 0.75rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--brun) !important;
    background: var(--vanille);
    padding: 10px 24px;
    border-radius: 2px;
    text-decoration: none;
    font-weight: 500;
    transition: background 0.3s, transform 0.2s;
  }
  .nav-cta:hover { background: var(--creme); transform: translateY(-1px); }
  .nav-cta::after { display: none !important; }

  
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--ecru);transition:all .3s;}
nav.scrolled .hamburger span{background:var(--brun);}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--brun);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--creme);text-decoration:none;transition:color .3s;}
.mobile-menu a:hover{color:var(--vanille);}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;color:var(--creme);font-size:1.5rem;cursor:none;}
@media(max-width:768px){.nav-links{display:none;}.hamburger{display:flex;}}

  /* HERO */
  .hero {
    height: 100vh;
    min-height: 700px;
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--brun);
  }
  .hero-bg {
    position: absolute;
    inset: 0;
    background:
      radial-gradient(ellipse 60% 80% at 70% 50%, rgba(45, 74, 53, 0.5) 0%, transparent 70%),
      radial-gradient(ellipse 40% 60% at 20% 80%, rgba(107, 66, 38, 0.6) 0%, transparent 60%),
      linear-gradient(135deg, #1a0d06 0%, #3A1F0D 40%, #2D3A1E 100%);
  }
  /* Botanical SVG decorations */
  .hero-botanical {
    position: absolute;
    right: -40px;
    top: 50%;
    transform: translateY(-50%);
    width: 55%;
    max-width: 700px;
    opacity: 0.18;
    animation: floatSlow 8s ease-in-out infinite;
  }
  @keyframes floatSlow {
    0%, 100% { transform: translateY(-50%) rotate(0deg); }
    50% { transform: translateY(-52%) rotate(1.5deg); }
  }
  .hero-content {
    position: relative;
    z-index: 2;
    padding: 0 80px;
    max-width: 700px;
  }
  .hero-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 28px;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.3s forwards;
  }
  .hero-eyebrow span {
    font-size: 0.72rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--vanille);
    font-weight: 400;
  }
  .eyebrow-line {
    width: 50px;
    height: 1px;
    background: var(--vanille);
    opacity: 0.6;
  }
  .hero h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(3.5rem, 7vw, 6rem);
    font-weight: 300;
    line-height: 1.05;
    color: var(--creme);
    letter-spacing: -0.01em;
    margin-bottom: 8px;
    opacity: 0;
    animation: fadeUp 0.9s ease 0.5s forwards;
  }
  .hero h1 em {
    font-style: italic;
    color: var(--vanille);
    font-weight: 300;
  }
  .hero-subtitle {
    font-size: 1rem;
    line-height: 1.7;
    color: rgba(245, 237, 216, 0.65);
    max-width: 480px;
    margin: 28px 0 44px;
    font-weight: 300;
    opacity: 0;
    animation: fadeUp 0.9s ease 0.75s forwards;
  }
  .hero-actions {
    display: flex;
    gap: 20px;
    align-items: center;
    opacity: 0;
    animation: fadeUp 0.9s ease 0.95s forwards;
  }
  .btn-primary {
    display: inline-block;
    background: var(--vanille);
    color: var(--brun);
    text-decoration: none;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 500;
    padding: 16px 36px;
    border-radius: 2px;
    transition: background 0.3s, transform 0.2s, box-shadow 0.3s;
  }
  .btn-primary:hover {
    background: var(--creme);
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(200, 169, 110, 0.3);
  }
  .btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: rgba(245, 237, 216, 0.7);
    text-decoration: none;
    font-size: 0.78rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    font-weight: 400;
    transition: color 0.3s;
  }
  .btn-ghost:hover { color: var(--creme); }
  .btn-ghost svg { transition: transform 0.3s; }
  .btn-ghost:hover svg { transform: translateX(4px); }

  .hero-stats {
    position: absolute;
    bottom: 50px;
    right: 80px;
    display: flex;
    gap: 50px;
    opacity: 0;
    animation: fadeUp 0.9s ease 1.2s forwards;
  }
  .stat-item { text-align: right; }
  .stat-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.8rem;
    font-weight: 300;
    color: var(--vanille);
    line-height: 1;
  }
  .stat-label {
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(245, 237, 216, 0.45);
    margin-top: 4px;
  }

  .scroll-indicator {
    position: absolute;
    bottom: 40px;
    left: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0;
    animation: fadeUp 0.9s ease 1.4s forwards;
  }
  .scroll-line {
    width: 1px;
    height: 50px;
    background: linear-gradient(to bottom, var(--vanille), transparent);
    animation: scrollPulse 2s ease-in-out infinite;
  }
  .scroll-text {
    font-size: 0.62rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: rgba(245, 237, 216, 0.4);
    writing-mode: vertical-rl;
  }
  @keyframes scrollPulse {
    0%, 100% { opacity: 1; transform: scaleY(1); }
    50% { opacity: 0.3; transform: scaleY(0.6); }
  }

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

  /* MARQUEE BAND */
  .marquee-band {
    background: var(--foret);
    padding: 16px 0;
    overflow: hidden;
  }
  .marquee-track {
    display: flex;
    gap: 0;
    animation: marqueeScroll 25s linear infinite;
    white-space: nowrap;
  }
  .marquee-item {
    display: inline-flex;
    align-items: center;
    gap: 24px;
    padding: 0 24px;
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(245, 237, 216, 0.7);
    font-weight: 300;
  }
  .marquee-dot {
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--vanille);
    opacity: 0.6;
  }
  @keyframes marqueeScroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }

  /* SECTION STYLES */
  section { padding: 120px 80px; }

  .section-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
  }
  .section-eyebrow span {
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--foret);
    font-weight: 500;
  }
  .eyebrow-line-dark {
    width: 40px; height: 1px;
    background: var(--foret);
    opacity: 0.4;
  }

  h2.display {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 300;
    line-height: 1.1;
    color: var(--brun);
    letter-spacing: -0.01em;
  }
  h2.display em {
    font-style: italic;
    color: var(--foret);
  }

  /* HISTOIRE */
  .histoire {
    background: var(--creme);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }
  .histoire-visual {
    position: relative;
    height: 520px;
  }
  .histoire-card {
    position: absolute;
    border-radius: 4px;
    overflow: hidden;
    background: var(--foret);
  }
  .histoire-card-main {
    width: 72%;
    height: 78%;
    top: 0; left: 0;
    background: linear-gradient(145deg, #2D4A35 0%, #1a2d1f 100%);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .histoire-card-accent {
    width: 52%;
    height: 42%;
    bottom: 0; right: 0;
    background: var(--terre);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .card-inner-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 4rem;
    font-weight: 300;
    color: rgba(245,237,216,0.15);
    line-height: 1;
    text-align: center;
    padding: 20px;
    user-select: none;
  }
  .histoire-year-badge {
    position: absolute;
    top: 50%;
    left: 55%;
    transform: translate(-50%, -50%);
    background: var(--vanille);
    color: var(--brun);
    width: 100px;
    height: 100px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 10;
    box-shadow: 0 8px 30px rgba(200, 169, 110, 0.4);
  }
  .histoire-year-badge .year {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2rem;
    font-weight: 300;
    line-height: 1;
  }
  .histoire-year-badge .year-label {
    font-size: 0.55rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-top: 2px;
    opacity: 0.7;
  }

  .histoire-content p {
    font-size: 1rem;
    line-height: 1.85;
    color: var(--text-light);
    font-weight: 300;
    margin-top: 24px;
  }
  .timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 40px;
    border-left: 1px solid var(--creme-dark);
    padding-left: 28px;
  }
  .timeline-item {
    position: relative;
    padding-bottom: 28px;
  }
  .timeline-item::before {
    content: '';
    position: absolute;
    left: -33px;
    top: 6px;
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--vanille);
    border: 2px solid var(--creme);
  }
  .timeline-year {
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--vanille);
    font-weight: 500;
    margin-bottom: 4px;
  }
  .timeline-desc {
    font-size: 0.88rem;
    color: var(--text-light);
    line-height: 1.6;
  }

  /* PRODUITS */
  .produits {
    background: var(--ecru);
  }
  .produits-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 60px;
  }
  .produits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .produit-card {
    border-radius: 4px;
    overflow: hidden;
    background: var(--creme);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    cursor: none;
  }
  .produit-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 24px 60px rgba(58, 31, 13, 0.12);
  }
  .produit-card:first-child {
    grid-column: span 2;
  }
  .produit-visual {
    height: 280px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .produit-card:first-child .produit-visual { height: 340px; }
  .pv-gousses {
    background: linear-gradient(135deg, #1a0d06 0%, #3D2510 50%, #2D4A35 100%);
  }
  .pv-poudre {
    background: linear-gradient(135deg, #5C3A1E 0%, #8B5E3C 100%);
  }
  .pv-extrait {
    background: linear-gradient(135deg, #2D3A1E 0%, #4A6337 100%);
  }
  .produit-icon-wrap {
    position: relative;
    z-index: 2;
    text-align: center;
  }
  .produit-icon {
    font-size: 5rem;
    opacity: 0.9;
    filter: drop-shadow(0 8px 20px rgba(0,0,0,0.3));
    display: block;
    margin-bottom: 12px;
    transition: transform 0.4s ease;
  }
  .produit-card:hover .produit-icon {
    transform: scale(1.08) rotate(-3deg);
  }
  .produit-tag {
    display: inline-block;
    font-size: 0.62rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--vanille);
    border: 1px solid rgba(200, 169, 110, 0.3);
    padding: 4px 12px;
    border-radius: 1px;
  }
  .produit-body {
    padding: 28px 32px;
  }
  .produit-body h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem;
    font-weight: 400;
    color: var(--brun);
    margin-bottom: 10px;
    line-height: 1.2;
  }
  .produit-body p {
    font-size: 0.88rem;
    color: var(--text-light);
    line-height: 1.7;
    font-weight: 300;
  }
  .produit-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--creme-dark);
  }
  .produit-footer span {
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--foret);
    font-weight: 500;
  }
  .arrow-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--foret);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--creme);
    text-decoration: none;
    transition: background 0.3s, transform 0.3s;
    font-size: 0.9rem;
  }
  .arrow-btn:hover {
    background: var(--vanille);
    transform: rotate(45deg);
    color: var(--brun);
  }

  /* TERROIR */
  .terroir {
    background: var(--foret);
    color: var(--creme);
    position: relative;
    overflow: hidden;
  }
  .terroir::before {
    content: '';
    position: absolute;
    top: -100px; right: -100px;
    width: 500px; height: 500px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(200, 169, 110, 0.08) 0%, transparent 70%);
    pointer-events: none;
  }
  .terroir-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }
  .terroir h2.display { color: var(--creme); }
  .terroir h2.display em { color: var(--vanille); }
  .terroir-content p {
    font-size: 1rem;
    line-height: 1.85;
    color: rgba(245, 237, 216, 0.65);
    font-weight: 300;
    margin-top: 24px;
  }
  .terroir-features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-top: 40px;
  }
  .feature-item {
    padding: 24px;
    background: rgba(245, 237, 216, 0.05);
    border-radius: 4px;
    border: 1px solid rgba(245, 237, 216, 0.08);
    transition: background 0.3s, border-color 0.3s;
  }
  .feature-item:hover {
    background: rgba(245, 237, 216, 0.09);
    border-color: rgba(200, 169, 110, 0.2);
  }
  .feature-icon {
    font-size: 1.8rem;
    margin-bottom: 12px;
  }
  .feature-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 400;
    color: var(--creme);
    margin-bottom: 6px;
  }
  .feature-desc {
    font-size: 0.82rem;
    color: rgba(245, 237, 216, 0.5);
    line-height: 1.6;
  }
  .terroir-visual-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 12px;
    height: 480px;
  }
  .tv-cell {
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
  }
  .tv-cell-1 {
    grid-column: span 2;
    background: linear-gradient(135deg, #1a2d1f 0%, #3D6147 100%);
  }
  .tv-cell-2 { background: linear-gradient(145deg, #2C4A1E, #4A6337); }
  .tv-cell-3 { background: linear-gradient(145deg, #3A2010, #6B4226); }
  .tv-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 3.5rem;
    font-weight: 300;
    color: rgba(245,237,216,0.08);
    user-select: none;
    letter-spacing: -0.02em;
  }
  .tv-badge {
    position: absolute;
    bottom: 16px; left: 16px;
    background: rgba(0,0,0,0.4);
    backdrop-filter: blur(8px);
    padding: 6px 14px;
    border-radius: 2px;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(245,237,216,0.7);
  }

  /* CHIFFRES */
  .chiffres {
    background: var(--creme);
    padding: 80px;
  }
  .chiffres-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--creme-dark);
    border: 1px solid var(--creme-dark);
    border-radius: 4px;
    overflow: hidden;
  }
  .chiffre-cell {
    background: var(--creme);
    padding: 50px 40px;
    text-align: center;
    transition: background 0.3s;
  }
  .chiffre-cell:hover { background: var(--ecru); }
  .chiffre-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 3.5rem;
    font-weight: 300;
    color: var(--foret);
    line-height: 1;
    margin-bottom: 8px;
  }
  .chiffre-unit {
    font-size: 1.5rem;
    color: var(--vanille);
  }
  .chiffre-label {
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-light);
    line-height: 1.5;
  }

  /* TEMOIGNAGES */
  .temoignages {
    background: var(--ecru);
    position: relative;
  }
  .temoignages-header {
    text-align: center;
    margin-bottom: 60px;
  }
  .temoignages-header .section-eyebrow {
    justify-content: center;
  }
  .temoignages-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .temoignage-card {
    background: var(--creme);
    border-radius: 4px;
    padding: 36px;
    border: 1px solid var(--creme-dark);
    transition: box-shadow 0.3s, transform 0.3s;
    position: relative;
  }
  .temoignage-card:hover {
    box-shadow: 0 16px 50px rgba(58, 31, 13, 0.08);
    transform: translateY(-4px);
  }
  .quote-mark {
    font-family: 'Cormorant Garamond', serif;
    font-size: 5rem;
    color: var(--vanille);
    opacity: 0.3;
    line-height: 0.6;
    margin-bottom: 20px;
    display: block;
  }
  .temoignage-text {
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--text-light);
    font-weight: 300;
    font-style: italic;
    margin-bottom: 28px;
  }
  .temoignage-author {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-top: 20px;
    border-top: 1px solid var(--creme-dark);
  }
  .author-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--foret);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    color: var(--vanille);
    flex-shrink: 0;
  }
  .author-name {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--brun);
  }
  .author-role {
    font-size: 0.72rem;
    color: var(--text-light);
    letter-spacing: 0.05em;
    margin-top: 2px;
  }
  .stars {
    color: var(--vanille);
    font-size: 0.75rem;
    letter-spacing: 2px;
    position: absolute;
    top: 36px;
    right: 36px;
  }

  /* CONTACT */
  .contact-section {
    background: var(--brun);
    color: var(--creme);
    position: relative;
    overflow: hidden;
    text-align: center;
    padding: 140px 80px;
  }
  .contact-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
      radial-gradient(ellipse 80% 60% at 50% 100%, rgba(45, 74, 53, 0.35) 0%, transparent 60%),
      radial-gradient(ellipse 40% 50% at 20% 0%, rgba(200, 169, 110, 0.1) 0%, transparent 50%);
    pointer-events: none;
  }
  .contact-section .section-eyebrow { justify-content: center; }
  .contact-section .section-eyebrow span { color: var(--vanille); }
  .contact-section h2.display { color: var(--creme); margin: 0 auto; max-width: 700px; }
  .contact-section h2.display em { color: var(--vanille); }
  .contact-desc {
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(245, 237, 216, 0.55);
    max-width: 500px;
    margin: 24px auto 48px;
    font-weight: 300;
  }
  .contact-actions {
    display: flex;
    gap: 20px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
  }
  .btn-secondary {
    display: inline-block;
    border: 1px solid rgba(245, 237, 216, 0.25);
    color: rgba(245, 237, 216, 0.7);
    text-decoration: none;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 400;
    padding: 16px 36px;
    border-radius: 2px;
    transition: border-color 0.3s, color 0.3s, background 0.3s;
  }
  .btn-secondary:hover {
    border-color: var(--vanille);
    color: var(--vanille);
    background: rgba(200, 169, 110, 0.05);
  }

  /* FOOTER */
  footer {
    background: #0D0604;
    color: rgba(245, 237, 216, 0.4);
    padding: 60px 80px 40px;
  }
  .footer-top {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 60px;
    padding-bottom: 50px;
    border-bottom: 1px solid rgba(245, 237, 216, 0.07);
    margin-bottom: 40px;
  }
  .footer-brand .brand-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 400;
    color: var(--creme);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .footer-brand p {
    font-size: 0.85rem;
    line-height: 1.7;
    font-weight: 300;
    max-width: 240px;
  }
  .footer-socials {
    display: flex;
    gap: 12px;
    margin-top: 24px;
  }
  .social-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(245, 237, 216, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(245, 237, 216, 0.4);
    text-decoration: none;
    font-size: 0.8rem;
    transition: border-color 0.3s, color 0.3s, background 0.3s;
  }
  .social-btn:hover {
    border-color: var(--vanille);
    color: var(--vanille);
    background: rgba(200, 169, 110, 0.08);
  }
  .footer-col h4 {
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(245, 237, 216, 0.6);
    margin-bottom: 20px;
    font-weight: 500;
  }
  .footer-col ul { list-style: none; }
  .footer-col ul li { margin-bottom: 10px; }
  .footer-col ul li a {
    color: rgba(245, 237, 216, 0.35);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 300;
    transition: color 0.3s;
  }
  .footer-col ul li a:hover { color: var(--vanille); }
  .footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .footer-copy {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
  }
  .footer-langs {
    display: flex;
    gap: 20px;
  }
  .footer-langs a {
    font-size: 0.72rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(245, 237, 216, 0.3);
    text-decoration: none;
    transition: color 0.3s;
  }
  .footer-langs a:hover,
  .footer-langs a.active { color: var(--vanille); }

  /* SCROLL REVEAL */
  .reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
  }
  .reveal.visible {
    opacity: 1;
    transform: translateY(0);
  }
  .reveal-delay-1 { transition-delay: 0.1s; }
  .reveal-delay-2 { transition-delay: 0.2s; }
  .reveal-delay-3 { transition-delay: 0.3s; }
  .reveal-delay-4 { transition-delay: 0.4s; }

  @media (max-width: 900px) {
    nav { padding: 20px 24px; }
    nav.scrolled { padding: 14px 24px; }
    .nav-links { display: none; }
    section { padding: 80px 24px; }
    .hero-content { padding: 0 24px; }
    .hero-stats { right: 24px; bottom: 30px; gap: 30px; }
    .scroll-indicator { left: 24px; }
    .histoire { grid-template-columns: 1fr; gap: 40px; }
    .histoire-visual { height: 300px; }
    .produits-grid { grid-template-columns: 1fr; }
    .produit-card:first-child { grid-column: span 1; }
    .terroir-grid { grid-template-columns: 1fr; }
    .terroir-visual-grid { display: none; }
    .chiffres-grid { grid-template-columns: 1fr 1fr; }
    .temoignages-grid { grid-template-columns: 1fr; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
    .chiffres { padding: 60px 24px; }
    .contact-section { padding: 100px 24px; }
    footer { padding: 50px 24px 30px; }
  }
/* =============================================
   WORDPRESS SPECIFIC ADDITIONS
   ============================================= */

/* Footer */
.site-footer { background: var(--brun); color: var(--creme); padding: 80px 60px 40px; }
.footer-inner { display: flex; gap: 80px; max-width: 1200px; margin: 0 auto; flex-wrap: wrap; }
.footer-logo { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--creme); margin-bottom: 16px; }
.footer-desc { color: rgba(245,237,216,.6); font-size: .85rem; line-height: 1.7; max-width: 280px; margin-bottom: 24px; }
.footer-social { display: flex; gap: 16px; }
.footer-social a { color: rgba(245,237,216,.5); transition: color .3s; }
.footer-social a:hover { color: var(--vanille); }
.footer-links { display: flex; gap: 60px; flex: 1; flex-wrap: wrap; }
.footer-col h4 { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--vanille); margin-bottom: 20px; }
.footer-col ul { list-style: none; }
.footer-col li, .footer-col a { font-size: .85rem; color: rgba(245,237,216,.55); line-height: 2; text-decoration: none; transition: color .3s; }
.footer-col a:hover { color: var(--creme); }
.footer-bottom { border-top: 1px solid rgba(245,237,216,.1); margin-top: 60px; padding-top: 32px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.footer-bottom p { font-size: .75rem; color: rgba(245,237,216,.35); letter-spacing: .08em; }

/* Blog */
.blog-section { padding: 80px 60px; max-width: 1200px; margin: 0 auto; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 40px; }
.blog-card { background: white; border-radius: 4px; overflow: hidden; transition: transform .3s, box-shadow .3s; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(44,26,14,.1); }
.blog-card-img img { width: 100%; height: 220px; object-fit: cover; display: block; }
.blog-card-body { padding: 28px; }
.blog-card-meta { display: flex; gap: 12px; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-light); margin-bottom: 12px; }
.blog-card h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; font-weight: 400; color: var(--brun); margin-bottom: 12px; line-height: 1.3; }
.blog-card h2 a { text-decoration: none; color: inherit; }
.blog-card p { font-size: .9rem; color: var(--text-light); line-height: 1.7; margin-bottom: 20px; }
.blog-read-more { font-size: .75rem; letter-spacing: .15em; text-transform: uppercase; color: var(--foret); text-decoration: none; font-weight: 500; }
.blog-empty { text-align: center; padding: 80px 20px; grid-column: 1/-1; }
.blog-pagination { margin-top: 60px; text-align: center; }
.blog-pagination .nav-links { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.blog-pagination a, .blog-pagination span { padding: 8px 16px; border: 1px solid var(--creme-dark); color: var(--text-light); text-decoration: none; font-size: .82rem; border-radius: 2px; }
.blog-pagination .current { background: var(--vanille); color: var(--brun); border-color: var(--vanille); }

/* Single Post */
.single-post-hero { background: var(--brun); padding: 120px 80px 80px; }
.single-post-meta { display: flex; gap: 16px; font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: rgba(245,237,216,.5); margin-bottom: 20px; }
.single-post-hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem,5vw,4rem); font-weight: 300; color: var(--creme); max-width: 800px; line-height: 1.1; }
.single-post-thumbnail img { width: 100%; max-height: 500px; object-fit: cover; margin-top: 40px; border-radius: 4px; }
.single-post-content { max-width: 780px; margin: 60px auto; padding: 0 40px; }
.post-body { font-size: 1rem; line-height: 1.85; color: var(--text); }
.post-body h2,h3 { font-family: 'Cormorant Garamond', serif; color: var(--brun); margin: 40px 0 16px; }
.post-body p { margin-bottom: 20px; }
.post-author-box { display: flex; gap: 20px; align-items: center; padding: 32px; background: var(--ecru); border-radius: 4px; margin: 48px 0; }
.author-avatar { width: 52px; height: 52px; background: var(--vanille); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .75rem; letter-spacing: .1em; color: var(--brun); font-weight: 600; flex-shrink: 0; }
.post-nav { display: flex; justify-content: space-between; gap: 20px; margin-top: 48px; border-top: 1px solid var(--creme-dark); padding-top: 32px; }
.post-nav a { text-decoration: none; color: var(--foret); font-size: .85rem; font-weight: 500; }

/* Contact Form */
.contact-section { padding: 80px 60px; max-width: 1200px; margin: 0 auto; }
.contact-inner { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; }
.contact-info-item { display: flex; gap: 16px; margin-bottom: 32px; }
.ci-icon { font-size: 1.4rem; flex-shrink: 0; margin-top: 2px; }
.contact-info-item strong { display: block; font-size: .75rem; letter-spacing: .15em; text-transform: uppercase; color: var(--vanille); margin-bottom: 4px; }
.contact-info-item p, .contact-info-item a { font-size: .9rem; color: var(--text-light); text-decoration: none; line-height: 1.6; }
.contact-certifs { margin-top: 32px; padding-top: 32px; border-top: 1px solid var(--creme-dark); }
.certif-item { font-size: .82rem; color: var(--text-light); margin-bottom: 10px; }
.contact-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: var(--text-light); margin-bottom: 8px; font-weight: 500; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 14px 16px; border: 1px solid var(--creme-dark); background: white; font-family: 'Jost', sans-serif; font-size: .9rem; color: var(--text); border-radius: 2px; outline: none; transition: border-color .3s; box-sizing: border-box; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--vanille); }
.btn-full { width: 100%; text-align: center; }
.form-success { background: #e8f5e9; border: 1px solid #a5d6a7; padding: 24px; border-radius: 4px; text-align: center; margin-bottom: 32px; }
.form-success span { font-size: 2rem; display: block; margin-bottom: 8px; }
.form-error { background: #ffebee; border: 1px solid #ef9a9a; padding: 16px; border-radius: 4px; margin-bottom: 24px; color: #c62828; font-size: .9rem; }

/* FAQ */
.faq-section { padding: 80px 60px; background: var(--ecru); }
.faq-list { max-width: 800px; margin: 48px auto 0; }
.faq-item { border-bottom: 1px solid var(--creme-dark); }
.faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 20px 0; background: none; border: none; font-family: 'Jost', sans-serif; font-size: 1rem; color: var(--text); cursor: pointer; text-align: left; }
.faq-icon { font-size: 1.4rem; color: var(--vanille); transition: transform .3s; flex-shrink: 0; }
.faq-item.open .faq-answer { display: block; }
.faq-answer { display: none; padding: 0 0 20px; color: var(--text-light); font-size: .9rem; line-height: 1.7; }

/* CTA Section */
.cta-section { background: var(--foret); padding: 80px 60px; text-align: center; }
.cta-section--small { padding: 60px 40px; }
.cta-content h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem,4vw,3.5rem); font-weight: 300; color: var(--creme); margin-bottom: 32px; }
.cta-content h2 em { color: var(--vanille); font-style: italic; }
.cta-content p { color: rgba(245,237,216,.7); margin-bottom: 32px; font-size: .95rem; }
.cta-actions { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; }
.btn-ghost-light { color: rgba(245,237,216,.8); text-decoration: none; font-size: .78rem; letter-spacing: .15em; text-transform: uppercase; font-weight: 400; display: inline-flex; align-items: center; gap: 6px; transition: color .3s; }
.btn-ghost-light:hover { color: var(--creme); }

/* Page Hero */
.page-hero { background: var(--brun); padding: 140px 80px 80px; position: relative; overflow: hidden; }
.page-hero::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 85% 50%,rgba(45,74,53,.45) 0%,transparent 65%); pointer-events:none; }
.page-hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(2.8rem,6vw,5rem); font-weight:300; line-height:1.08; color:var(--creme); position:relative; z-index:2; }
.page-hero h1 em { font-style:italic; color:var(--vanille); }
.page-hero-sub { color:rgba(245,237,216,.65); max-width:560px; font-size:1rem; line-height:1.7; margin-top:20px; position:relative; z-index:2; }
.hero-badges-row { display:flex; gap:12px; margin-top:32px; position:relative; z-index:2; flex-wrap:wrap; }
.hero-badge { background:rgba(200,169,110,.15); border:1px solid rgba(200,169,110,.3); color:var(--vanille); padding:6px 16px; border-radius:2px; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; }

/* Responsive */
@media(max-width:900px){
  .contact-inner { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; gap: 40px; }
  .footer-links { gap: 32px; }
  .contact-form .form-row { grid-template-columns: 1fr; }
  .blog-section, .contact-section, .faq-section, .cta-section { padding: 60px 24px; }
  .page-hero { padding: 120px 32px 60px; }
  .single-post-hero { padding: 120px 32px 60px; }
  .single-post-content { padding: 0 24px; }
}
