/* LA FLAMBEE BOLLENE — ITALIAN ARTISANAL DESIGN (Red + Green) */

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

:root{
--brown:#3a2a1a;--brown-light:#5c4033;
--red:#C8102E;--red-dark:#9B111E;--red-bright:#E63946;
--green:#1B7340;--green-light:#2D8E57;--green-dark:#145A32;
--gold:#c8a96e;--gold-light:#e0c992;--cream:#F5E6C8;--cream-dark:#E8D5B0;
--cream-light:#FBF5EB;--olive:#6b7c4e;--olive-dark:#4a5a30;
--white:#fff;--text:#3a2a1a;--text-light:#7a6a5a;
--shadow:0 4px 30px rgba(58,42,26,0.08);
--shadow-md:0 8px 40px rgba(58,42,26,0.1);
--shadow-lg:0 20px 60px rgba(58,42,26,0.12);
--shadow-glow:0 0 30px rgba(200,169,110,0.08);
--radius:12px;--radius-sm:8px;--radius-lg:16px;
--transition:0.4s cubic-bezier(0.25,0.46,0.45,0.94);
--transition-bounce:0.5s cubic-bezier(0.34,1.56,0.64,1);
--transition-smooth:0.6s cubic-bezier(0.16,1,0.3,1);
}

html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeSpeed}
body{font-family:'Josefin Sans',sans-serif;background:var(--cream-light);color:var(--text);overflow-x:hidden;line-height:1.7}
img{content-visibility:auto}
::selection{background:rgba(200,16,46,0.15);color:var(--brown)}
.container{max-width:1140px;margin:0 auto;padding:0 24px}

/* Particle Canvas */
#particles-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}

/* Scattered Decorations */
.deco-scattered{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}
.deco{position:absolute}
.deco-wheat-1{top:8%;left:2%;animation:gentleSway 15s ease-in-out infinite}
.deco-olive-1{top:45%;right:0;animation:gentleSway 20s ease-in-out infinite reverse}
.deco-tomato{bottom:20%;left:5%;animation:gentleSway 18s ease-in-out infinite}
.deco-basil{top:65%;right:4%;animation:gentleSway 22s ease-in-out infinite reverse}
@keyframes gentleSway{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(8px,-12px) rotate(3deg)}}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:18px 0;transition:all 0.5s cubic-bezier(0.16,1,0.3,1);background:transparent}
.navbar.scrolled{background:rgba(251,245,235,0.97);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);box-shadow:0 1px 30px rgba(58,42,26,0.06),0 0 0 1px rgba(200,169,110,0.06);padding:12px 0}
.nav-container{max-width:1140px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{text-decoration:none}
.logo-wrapper{display:flex;align-items:center;gap:12px}
.logo-svg{transition:transform 0.6s ease}
.logo-wrapper:hover .logo-svg{transform:rotate(15deg) scale(1.05)}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-tradi{font-family:'Great Vibes',cursive;font-size:1.15rem;color:var(--green);margin-bottom:-3px;margin-left:2px}
.logo-pizza{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--red);letter-spacing:2px;text-transform:uppercase}
.logo-city{font-family:'Josefin Sans',sans-serif;font-size:0.55rem;color:var(--gold);letter-spacing:3px;font-weight:300;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links li a{text-decoration:none;color:var(--brown);font-size:0.85rem;font-weight:400;letter-spacing:1px;text-transform:uppercase;position:relative;transition:color 0.3s ease}
.nav-links li a::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:linear-gradient(90deg,var(--green),var(--red));transition:width 0.4s cubic-bezier(0.16,1,0.3,1),left 0.4s cubic-bezier(0.16,1,0.3,1);border-radius:1px}
.nav-links li a:hover{color:var(--red)}
.nav-links li a:hover::after{width:100%;left:0}
.nav-cta-item{display:flex;gap:8px;margin-left:8px}
.nav-social-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;color:white;text-decoration:none;transition:all 0.3s ease;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.nav-social-btn:hover{transform:scale(1.15) translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.nav-insta{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.nav-fb{background:#1877F2}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--brown);transition:var(--transition);border-radius:2px}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== PHONE MODAL ===== */
.phone-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(58,42,26,0.6);backdrop-filter:blur(12px) saturate(0.8);-webkit-backdrop-filter:blur(12px) saturate(0.8);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all 0.5s cubic-bezier(0.16,1,0.3,1)}
.phone-modal-overlay.active{opacity:1;visibility:visible}
.phone-modal{position:relative;background:var(--cream-light);border-radius:var(--radius-lg);padding:50px 40px;max-width:420px;width:90%;text-align:center;box-shadow:0 25px 80px rgba(58,42,26,0.2),0 0 0 1px rgba(200,169,110,0.15);border:1px solid rgba(200,169,110,0.2);transform:scale(0.85) translateY(30px);transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1)}
.phone-modal-overlay.active .phone-modal{transform:scale(1) translateY(0)}
.phone-modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:1.8rem;color:var(--text-light);cursor:pointer;transition:color 0.3s;line-height:1}
.phone-modal-close:hover{color:var(--red)}
.modal-wreath{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;opacity:0.6}
.phone-modal-content{position:relative;z-index:1}
.modal-tag{font-family:'Josefin Sans',sans-serif;font-size:0.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--green);display:block;margin-bottom:8px}
.phone-modal-content h3{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--brown);margin-bottom:24px}
.modal-numbers{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.modal-phone-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 28px;border-radius:50px;text-decoration:none;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;transition:all 0.3s;letter-spacing:1px}
.modal-phone-btn:not(.secondary){background:var(--red);color:white;box-shadow:0 4px 20px rgba(200,16,46,0.25)}
.modal-phone-btn:not(.secondary):hover{background:var(--green);transform:translateY(-2px);box-shadow:0 8px 30px rgba(27,115,64,0.3)}
.modal-phone-btn.secondary{background:transparent;color:var(--brown);border:1.5px solid var(--green)}
.modal-phone-btn.secondary:hover{background:var(--green);color:white;transform:translateY(-2px)}
.modal-hours{font-size:0.8rem;color:var(--text-light);font-style:italic}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;z-index:2}
.hero-img-wrap{position:absolute;top:0;left:0;width:100%;height:100%}
.hero-img{width:100%;height:100%;object-fit:cover;will-change:transform}
.hero-img-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,rgba(58,42,26,0.5) 0%,rgba(58,42,26,0.65) 40%,rgba(58,42,26,0.8) 80%,rgba(58,42,26,0.92) 100%)}
.hero-grain{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1}
.hero-corner{position:absolute;z-index:2;pointer-events:none}
.hero-corner-tl{top:24px;left:24px}
.hero-corner-br{bottom:24px;right:24px}
.hero-content{position:relative;z-index:3;max-width:750px;padding:120px 24px 80px}
.hero-badges{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:20px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(200,169,110,0.12);border:1px solid rgba(200,169,110,0.25);padding:8px 20px;border-radius:50px;font-size:0.75rem;font-weight:400;color:var(--gold-light);letter-spacing:2px;text-transform:uppercase;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all 0.4s ease;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.hero-badge:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.hero-badge-champ{background:rgba(200,16,46,0.2);border-color:rgba(255,255,255,0.3)}
.hero-badge-champion{background:rgba(27,115,64,0.25);border-color:rgba(45,142,87,0.4);color:#90EE90;font-weight:600;box-shadow:0 2px 16px rgba(27,115,64,0.2)}
.hero-title{margin-bottom:8px}
.title-script{display:block;font-family:'Great Vibes',cursive;font-size:clamp(1.8rem,4vw,2.8rem);color:var(--gold-light);font-weight:400;margin-bottom:-8px}
.title-main{display:block;font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,7vw,5.5rem);font-weight:700;color:var(--cream);line-height:1.05;letter-spacing:2px}
.title-main em{font-style:italic;color:var(--gold-light)}
.hero-separator{margin:12px 0 20px}
.hero-subtitle{font-size:clamp(0.95rem,1.8vw,1.15rem);color:rgba(245,230,200,0.8);font-weight:300;letter-spacing:0.5px;line-height:1.8;margin-bottom:32px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;text-decoration:none;font-weight:600;font-size:0.9rem;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);cursor:pointer;border:none;font-family:'Josefin Sans',sans-serif;letter-spacing:1px;text-transform:uppercase;position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.1);border-radius:50%;transform:translate(-50%,-50%);transition:width 0.5s ease,height 0.5s ease}
.btn:active::before{width:300px;height:300px}
.btn-primary{background:var(--red);color:white;box-shadow:0 4px 20px rgba(200,16,46,0.3)}
.btn-primary:hover{background:var(--green);transform:translateY(-3px);box-shadow:0 10px 35px rgba(27,115,64,0.35)}
.btn-outline{background:transparent;color:var(--cream);border:1.5px solid rgba(245,230,200,0.5)}
.btn-outline:hover{background:var(--cream);color:var(--brown);transform:translateY(-3px);box-shadow:0 8px 30px rgba(245,230,200,0.15)}
.btn-green{background:var(--green);color:white;box-shadow:0 4px 20px rgba(27,115,64,0.3)}
.btn-green:hover{background:var(--red);transform:translateY(-3px);box-shadow:0 10px 35px rgba(200,16,46,0.35)}
.hero-cta-group{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}

/* Hero Social */
.hero-social-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.social-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:50px;text-decoration:none;font-weight:500;font-size:0.85rem;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);letter-spacing:0.5px;position:relative;overflow:hidden}
.social-insta{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:white;box-shadow:0 3px 16px rgba(220,39,67,0.25)}
.social-insta:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 8px 28px rgba(220,39,67,0.4)}
.social-fb{background:#1877F2;color:white;box-shadow:0 3px 16px rgba(24,119,242,0.25)}
.social-fb:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 8px 28px rgba(24,119,242,0.4)}

/* Scroll Indicator */
.scroll-indicator{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3;animation:scrollBounce 2.5s ease-in-out infinite;text-decoration:none;cursor:pointer}
.scroll-mouse{width:22px;height:36px;border:1.5px solid rgba(245,230,200,0.4);border-radius:20px;display:flex;justify-content:center;padding-top:8px}
.scroll-wheel{width:3px;height:7px;background:var(--gold);border-radius:3px;animation:scrollWheel 2s ease-in-out infinite}
.scroll-indicator span{font-size:0.65rem;color:rgba(245,230,200,0.5);letter-spacing:3px;text-transform:uppercase;font-weight:300}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes scrollWheel{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(8px)}}

/* ===== SECTIONS ===== */
.section{position:relative;padding:100px 0;z-index:2}
.section-header{text-align:center;margin-bottom:56px}
.section-tag{display:block;font-family:'Great Vibes',cursive;font-size:1.4rem;color:var(--green);margin-bottom:4px;transition:opacity 0.3s}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--brown);letter-spacing:1px;background:linear-gradient(180deg,var(--brown) 0%,var(--brown-light) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-title em{font-style:italic;-webkit-text-fill-color:var(--red);background:none}
.section-divider{margin-top:12px}
.section-desc{color:var(--text-light);margin-top:14px;font-size:0.95rem;font-weight:300;letter-spacing:0.5px}

/* Italian flag divider */
.italian-divider{display:flex;align-items:center;justify-content:center;gap:0;margin-top:12px}
.italian-divider span{height:2px;width:40px}
.italian-divider .it-green{background:var(--green)}
.italian-divider .it-white{background:#fff}
.italian-divider .it-red{background:var(--red)}
.italian-divider .it-dot{width:8px;height:8px;border-radius:50%;margin:0 12px}

/* ===== ABOUT ===== */
.about{background:var(--cream-light);background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c8a96e' fill-opacity='0.03'%3E%3Ccircle cx='20' cy='20' r='1.5'/%3E%3C/g%3E%3C/svg%3E"),linear-gradient(180deg,var(--cream-light) 0%,rgba(232,213,176,0.15) 50%,var(--cream-light) 100%)}
.about-content{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-img-col{position:relative}
.about-img-wrapper{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);transition:all 0.5s ease}
.about-img-wrapper:hover{box-shadow:0 25px 70px rgba(58,42,26,0.18);transform:translateY(-4px)}
.about-img-wrapper img{width:100%;height:350px;object-fit:cover;display:block;transition:transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.about-img-wrapper:hover img{transform:scale(1.04)}
.about-img-frame{position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(200,169,110,0.3);border-radius:6px;pointer-events:none;transition:opacity 0.4s}
.about-img-wrapper:hover .about-img-frame{opacity:0.6}
.about-img-small{width:65%;margin-top:-60px;margin-left:auto;position:relative;z-index:2;border:4px solid var(--cream-light);border-radius:var(--radius)}
.about-img-small img{height:220px}
.about-intro{font-family:'Cormorant Garamond',serif;font-size:1.25rem;line-height:1.8;color:var(--brown);margin-bottom:28px}
.about-features{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}
.about-feat{display:flex;gap:16px;align-items:flex-start;padding:12px;border-radius:var(--radius-sm);transition:all 0.3s ease}
.about-feat:hover{background:rgba(200,169,110,0.04);transform:translateX(4px)}
.about-feat h4{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--brown);margin-bottom:2px}
.about-feat p{font-size:0.88rem;color:var(--text-light);font-weight:300;line-height:1.6}
.about-member{font-size:0.85rem;color:var(--green);font-style:italic;border-left:2px solid var(--green);padding-left:16px}

/* Champion badge in about */
.champion-highlight{background:linear-gradient(135deg,var(--red),var(--red-dark));color:white;padding:16px 24px;border-radius:var(--radius-sm);margin-top:20px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px rgba(200,16,46,0.2);transition:all 0.4s ease;position:relative;overflow:hidden}
.champion-highlight::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,0.08) 0%,transparent 60%);opacity:0;transition:opacity 0.5s}
.champion-highlight:hover{box-shadow:0 8px 30px rgba(200,16,46,0.3);transform:translateY(-2px)}
.champion-highlight:hover::before{opacity:1}
.champion-highlight svg{flex-shrink:0}
.champion-highlight span{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;letter-spacing:0.5px}

/* ===== IMAGE BAND ===== */
.image-band{display:grid;grid-template-columns:repeat(4,1fr);z-index:2;position:relative}
.band-item{overflow:hidden;height:220px;position:relative}
.band-item::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,transparent 50%,rgba(58,42,26,0.2) 100%);opacity:0;transition:opacity 0.4s;pointer-events:none}
.band-item:hover::after{opacity:1}
.band-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s cubic-bezier(0.16,1,0.3,1),filter 0.4s}
.band-item:hover img{transform:scale(1.1);filter:brightness(1.05) contrast(1.02)}

/* ===== CHAMPIONSHIP ===== */
.championship{background:var(--brown);color:var(--cream);overflow:hidden}
.championship .section-tag{color:var(--gold-light)}
.championship .section-title{color:var(--cream);background:none;-webkit-text-fill-color:var(--cream)}
.championship .section-title em{color:var(--gold-light);-webkit-text-fill-color:var(--gold-light)}
.championship .section-desc{color:rgba(245,230,200,0.6)}
.champ-content{display:grid;grid-template-columns:auto 1fr;gap:60px;align-items:start}
.champ-trophy{display:flex;align-items:center;justify-content:center;padding:20px;transition:transform 0.3s ease}
.champ-trophy:hover{transform:scale(1.05)}
.champ-trophy svg{opacity:0.9;filter:drop-shadow(0 4px 20px rgba(200,169,110,0.15));transition:filter 0.4s ease}
.champ-trophy:hover svg{filter:drop-shadow(0 0 25px rgba(255,215,0,0.4))}
.champ-details{display:flex;flex-direction:column;gap:32px}
.champ-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.champ-card{background:rgba(255,255,255,0.04);border:1px solid rgba(200,169,110,0.12);border-radius:var(--radius-sm);padding:28px 20px;text-align:center;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden}
.champ-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--green),var(--gold),var(--red));transform:scaleX(0);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);transform-origin:left}
.champ-card:hover{background:rgba(255,255,255,0.08);transform:translateY(-4px);border-color:rgba(200,169,110,0.25);box-shadow:0 8px 30px rgba(0,0,0,0.15)}
.champ-card:hover::before{transform:scaleX(1)}
.champ-card-number{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:700;color:var(--gold-light);line-height:1}
.champ-card-label{font-family:'Josefin Sans',sans-serif;font-size:0.75rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin:8px 0 12px;font-weight:400}
.champ-card p{font-size:0.82rem;color:rgba(245,230,200,0.5);line-height:1.6;font-weight:300}
.champ-story{background:rgba(255,255,255,0.03);border-radius:var(--radius);padding:32px;border:1px solid rgba(200,169,110,0.08)}
.champ-story blockquote{display:flex;gap:16px;align-items:flex-start}
.champ-story blockquote p{font-family:'Cormorant Garamond',serif;font-size:1.1rem;line-height:1.8;color:rgba(245,230,200,0.75);font-style:italic}
.champ-story blockquote svg{flex-shrink:0;margin-top:4px}
.champ-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.champ-tag{padding:5px 14px;border-radius:50px;font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;font-weight:400;background:rgba(200,169,110,0.1);color:var(--gold);border:1px solid rgba(200,169,110,0.15);transition:all 0.3s ease}
.champ-tag:hover{background:rgba(200,169,110,0.2);border-color:rgba(200,169,110,0.3);transform:translateY(-1px)}

/* ===== DISTINCTIONS ===== */
.distinctions{background:linear-gradient(135deg,#fefefe 0%,var(--cream-light) 100%);border-top:3px solid var(--green);border-bottom:3px solid var(--red)}
.distinctions .section-tag{color:var(--red)}
.distinctions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}
.distinction-card{background:white;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(200,169,110,0.12);transition:all 0.45s cubic-bezier(0.16,1,0.3,1)}
.distinction-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(58,42,26,0.15),0 0 0 1px rgba(200,169,110,0.1)}
.distinction-card img{width:100%;height:220px;object-fit:cover;transition:transform 0.7s cubic-bezier(0.16,1,0.3,1)}
.distinction-card:hover img{transform:scale(1.06)}
.distinction-card-body{padding:20px;text-align:center}
.distinction-card-body h4{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--brown);margin-bottom:6px}
.distinction-card-body p{font-size:0.85rem;color:var(--text-light);font-weight:300}
.distinction-main-badge{text-align:center;padding:36px;background:linear-gradient(135deg,var(--red),var(--red-dark));border-radius:var(--radius-lg);color:white;box-shadow:0 8px 30px rgba(200,16,46,0.25);position:relative;overflow:hidden;transition:all 0.4s ease}
.distinction-main-badge::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,0.1),transparent 50%)}
.distinction-main-badge:hover{box-shadow:0 12px 40px rgba(200,16,46,0.35);transform:translateY(-3px)}
.distinction-main-badge h3{font-family:'Cormorant Garamond',serif;font-size:2rem;margin-bottom:8px}
.distinction-main-badge p{font-size:1rem;opacity:0.9;font-weight:300}
.distinction-main-badge .badge-count{font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:700;line-height:1;margin:12px 0}

/* ===== DIPLÔMES — CARROUSEL ===== */
.diplomes-section{margin-top:48px}
.diplomes-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--text-light);display:flex;align-items:center;gap:10px;margin-bottom:20px;letter-spacing:0.3px}
.diplomes-title svg{opacity:0.5;flex-shrink:0}

/* Diplôme Cards — style champion */
.diplome-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.diplome-card{background:rgba(255,255,255,0.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(200,169,110,0.12);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative}
.diplome-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--green),var(--gold),var(--red));transform:scaleX(0);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);transform-origin:left;z-index:1}
.diplome-card:hover{background:white;transform:translateY(-4px);border-color:rgba(200,169,110,0.25);box-shadow:0 8px 30px rgba(58,42,26,0.1)}
.diplome-card:hover::before{transform:scaleX(1)}
.diplome-card-img{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--cream-light)}
.diplome-card-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:brightness(1.03) contrast(1.04);transition:transform 0.5s ease}
.diplome-card:hover .diplome-card-img img{transform:scale(1.03)}
/* Recadrage par photo — centré sur le certificat */
.diplome-card[data-index="0"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="1"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="2"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="3"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="4"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="5"] .diplome-card-img img{object-position:center center}
.diplome-card[data-index="6"] .diplome-card-img img{object-position:center 30%}
.diplome-card[data-index="6"]{grid-column:2/3}
.diplome-badge{position:absolute;top:10px;left:10px;padding:3px 12px;border-radius:50px;background:rgba(255,255,255,0.88);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:0.65rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--brown);border:1px solid rgba(200,169,110,0.2);z-index:1}
.diplome-badge-gold{background:linear-gradient(135deg,rgba(200,169,110,0.9),rgba(218,190,130,0.9));color:var(--brown);border-color:transparent;font-weight:700}
.diplome-card-info{padding:14px 16px 16px;text-align:center}
.diplome-card-info h4{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:var(--brown);margin-bottom:2px;line-height:1.3}
.diplome-card-info p{font-size:0.75rem;font-weight:300;color:var(--text-light);opacity:0.65;line-height:1.4}

/* ===== LIGHTBOX ===== */
.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,8,5,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:99999;display:flex;align-items:center;justify-content:center;flex-direction:column;opacity:0;visibility:hidden;transition:opacity 0.35s ease,visibility 0.35s ease}
.lightbox-overlay.active{opacity:1;visibility:visible}
.lightbox-content{display:flex;align-items:center;justify-content:center;flex:1;width:100%;padding:60px 80px 20px}
.lightbox-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:6px;box-shadow:0 12px 60px rgba(0,0,0,0.5);transform:scale(0.92);transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);filter:brightness(1.03) contrast(1.04)}
.lightbox-overlay.active .lightbox-content img{transform:scale(1)}
.lightbox-close{position:absolute;top:16px;right:20px;background:none;border:none;color:rgba(255,255,255,0.7);font-size:2.2rem;cursor:pointer;z-index:3;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all 0.3s ease}
.lightbox-close:hover{color:white;background:rgba(255,255,255,0.1)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.8);width:52px;height:52px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s ease;z-index:3}
.lightbox-nav:hover{background:rgba(255,255,255,0.15);color:white}
.lightbox-prev{left:16px}
.lightbox-next{right:16px}
.lightbox-info{text-align:center;padding:12px 24px 24px;width:100%}
.lightbox-caption{color:rgba(255,255,255,0.85);font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:500;margin-bottom:4px}
.lightbox-counter{color:rgba(255,255,255,0.4);font-size:0.75rem;letter-spacing:2px;text-transform:uppercase}

/* ===== STATS ===== */
.stats-banner{position:relative;padding:90px 0;z-index:2;overflow:hidden}
.stats-bg-img{position:absolute;top:0;left:0;width:100%;height:100%}
.stats-bg-img img{width:100%;height:100%;object-fit:cover}
.stats-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(58,42,26,0.88) 0%,rgba(26,18,9,0.92) 100%)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center;position:relative;z-index:1}
.stat-item{color:var(--cream);padding:20px;border-radius:var(--radius-sm);transition:all 0.4s ease;position:relative}
.stat-item::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transition:all 0.5s cubic-bezier(0.16,1,0.3,1);transform:translateX(-50%)}
.stat-item:hover::after{width:80%}
.stat-item:hover{background:rgba(255,255,255,0.03)}
.stat-number{font-family:'Cormorant Garamond',serif;font-size:3.2rem;font-weight:700;color:var(--gold-light);display:inline;text-shadow:0 2px 20px rgba(200,169,110,0.15)}
.stat-suffix{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--gold-light)}
.stat-label{display:block;font-size:0.8rem;letter-spacing:2px;text-transform:uppercase;opacity:0.7;margin-top:4px;font-weight:300}

/* ===== MENU ===== */
.menu{background:var(--cream-light);background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0L30 60M0 30L60 30' stroke='%23c8a96e' stroke-width='0.3' opacity='0.04'/%3E%3C/svg%3E")}
.menu-categories{display:flex;justify-content:center;gap:12px;margin-bottom:40px;flex-wrap:wrap}
.menu-tab{padding:10px 28px;border-radius:50px;border:1.5px solid var(--green);background:transparent;color:var(--green);font-weight:500;font-size:0.8rem;cursor:pointer;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);font-family:'Josefin Sans',sans-serif;letter-spacing:1px;text-transform:uppercase;position:relative;overflow:hidden}
.menu-tab::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:var(--green);transform:scaleX(0);transform-origin:right;transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);z-index:-1}
.menu-tab:hover::before{transform:scaleX(1);transform-origin:left}
.menu-tab.active,.menu-tab:hover{background:var(--green);color:white;box-shadow:0 4px 16px rgba(27,115,64,0.2)}
.menu-tab.active{box-shadow:0 4px 16px rgba(27,115,64,0.25)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.menu-item{background:rgba(255,255,255,0.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:var(--radius-sm);padding:20px 24px;border:1px solid rgba(200,169,110,0.12);transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative}
.menu-item::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--green),var(--red));border-radius:3px 0 0 3px;opacity:0;transition:opacity 0.3s}
.menu-item:hover{background:white;box-shadow:0 8px 30px rgba(58,42,26,0.08);transform:translateY(-3px)}
.menu-item:hover::before{opacity:1}
.menu-item-header{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.menu-item-header::after{content:'';flex:1;border-bottom:1.5px dotted var(--gold);opacity:0.4;min-width:20px;position:relative;top:-4px}
.menu-item h3{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;color:var(--brown);white-space:nowrap}
.menu-price{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:700;color:var(--red);white-space:nowrap}
.menu-item p,.menu-desc{color:var(--text-light);font-size:0.85rem;line-height:1.5;font-weight:300}
.menu-veg-badge{display:inline-block;margin-top:8px;padding:2px 10px;border-radius:50px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:rgba(27,115,64,0.12);color:var(--green)}
.menu-badge{display:inline-block;margin-top:8px;padding:2px 10px;border-radius:50px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:rgba(200,16,46,0.08);color:var(--red)}
.menu-badge.best{background:rgba(27,115,64,0.12);color:var(--green)}
.menu-badge.new{background:rgba(200,16,46,0.08);color:var(--red)}
.menu-badge.hot{background:rgba(200,16,46,0.12);color:var(--red-bright)}
.menu-badge.vege{background:rgba(27,115,64,0.12);color:var(--green)}

.menu-cta{text-align:center;margin-top:44px;padding:36px;background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid rgba(200,169,110,0.1);transition:all 0.4s ease}
.menu-cta:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.menu-cta p{color:var(--text-light);margin-bottom:20px;font-weight:300}
.menu-cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-insta-full{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:white;padding:12px 24px;border-radius:50px;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);font-size:0.85rem;letter-spacing:0.5px;box-shadow:0 3px 16px rgba(220,39,67,0.2)}
.btn-insta-full:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 28px rgba(220,39,67,0.35)}
.btn-fb-full{background:#1877F2;color:white;padding:12px 24px;border-radius:50px;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);font-size:0.85rem;letter-spacing:0.5px;box-shadow:0 3px 16px rgba(24,119,242,0.2)}
.btn-fb-full:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 28px rgba(24,119,242,0.35)}

/* ===== GALLERY ===== */
.social-showcase{background:var(--cream-dark)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:12px;margin-bottom:48px;perspective:1200px}
.gallery-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;text-decoration:none;transform-style:preserve-3d;transition:transform 0.4s cubic-bezier(0.03,0.98,0.52,0.99),box-shadow 0.4s ease;will-change:transform;box-shadow:0 4px 15px rgba(0,0,0,0.15)}
.gallery-item:hover{box-shadow:0 20px 40px rgba(0,0,0,0.3),0 0 20px rgba(200,169,110,0.15)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease,filter 0.4s ease}
.gallery-item:hover img{transform:scale(1.06);filter:brightness(1.05) contrast(1.05)}
.gallery-item::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,transparent 50%,rgba(0,0,0,0.1) 100%);opacity:0;transition:opacity 0.4s ease;pointer-events:none;z-index:1}
.gallery-item:hover::after{opacity:1}
.gallery-large{grid-column:span 2;grid-row:span 2}
.gallery-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(58,42,26,0.5);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity 0.3s;z-index:2}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{color:white;font-size:0.85rem;font-weight:500;letter-spacing:1px}

/* Social Mega CTA */
.social-mega-cta{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mega-cta-card{border-radius:var(--radius-lg);padding:44px 32px;text-align:center;color:white;transition:all 0.45s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden}
.mega-cta-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,0.1),transparent 50%)}
.mega-cta-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,0.2)}
.mega-cta-insta{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.mega-cta-fb{background:linear-gradient(135deg,#1877F2,#0d5fc9)}
.mega-cta-content{position:relative;z-index:1}
.mega-cta-content h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;margin:14px 0 6px;letter-spacing:1px}
.mega-cta-content p{opacity:0.85;font-size:0.9rem;margin-bottom:18px;font-weight:300}
.mega-cta-btn{display:inline-block;padding:10px 28px;background:rgba(255,255,255,0.15);border:1.5px solid white;border-radius:50px;color:white;text-decoration:none;font-weight:600;font-size:0.85rem;transition:all 0.35s cubic-bezier(0.16,1,0.3,1);letter-spacing:0.5px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.mega-cta-btn:hover{background:white;color:var(--brown);transform:translateY(-2px);box-shadow:0 4px 20px rgba(255,255,255,0.2)}

/* ===== FACEBOOK SECTION ===== */
.facebook-section{background:var(--cream-light);border-top:3px solid #1877F2}
.facebook-section .section-tag{color:#1877F2}
.fb-widget-wrapper{max-width:500px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:white;transition:all 0.4s ease;border:1px solid rgba(24,119,242,0.08)}
.fb-widget-wrapper:hover{box-shadow:0 25px 70px rgba(24,119,242,0.12);transform:translateY(-4px)}
.fb-widget-wrapper iframe{width:100%;height:600px;border:none;display:block;overflow:hidden}

/* ===== CONTACT ===== */
.contact{background:var(--cream-light)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-card{display:flex;gap:16px;align-items:flex-start;padding:20px;background:white;border-radius:var(--radius);box-shadow:0 2px 10px rgba(58,42,26,0.04);margin-bottom:12px;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);border:1px solid rgba(200,169,110,0.08);position:relative;overflow:hidden}
.contact-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--green),var(--gold));opacity:0;transition:opacity 0.3s;border-radius:3px 0 0 3px}
.contact-card:hover{transform:translateX(6px);box-shadow:0 8px 30px rgba(58,42,26,0.08)}
.contact-card:hover::before{opacity:1}
.contact-icon{width:44px;height:44px;background:rgba(27,115,64,0.06);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.3s}
.contact-card:hover .contact-icon{background:rgba(27,115,64,0.1);transform:scale(1.05)}
.contact-card h4{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--brown);margin-bottom:4px}
.contact-card p,.contact-card a{color:var(--text-light);font-size:0.88rem;text-decoration:none;line-height:1.6;font-weight:300}
.contact-card a:hover{color:var(--red)}
.hours-table{display:flex;flex-direction:column;gap:3px}
.hours-row{display:flex;justify-content:space-between;font-size:0.82rem;color:var(--text-light);gap:12px;font-weight:300}
.hours-row .closed{color:var(--red);font-weight:500}
.map-wrapper{width:100%;height:100%;min-height:420px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid white;transition:all 0.4s ease}
.map-wrapper:hover{box-shadow:0 20px 60px rgba(58,42,26,0.15);transform:translateY(-3px)}
.map-wrapper iframe{width:100%;height:100%;min-height:420px}

/* ===== FLOATING SOCIAL ===== */
.floating-social{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:8px;z-index:999;opacity:0;transform:translateY(20px);transition:all 0.5s cubic-bezier(0.16,1,0.3,1)}
.floating-social.visible{opacity:1;transform:translateY(0)}
.floating-social-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border-radius:50px;color:white;text-decoration:none;font-weight:500;font-size:0.8rem;box-shadow:0 4px 20px rgba(0,0,0,0.15);transition:all 0.35s cubic-bezier(0.16,1,0.3,1);border:none;cursor:pointer;font-family:'Josefin Sans',sans-serif}
.floating-social-btn span{max-width:0;overflow:hidden;transition:max-width 0.35s cubic-bezier(0.16,1,0.3,1),margin 0.35s;margin-left:0;white-space:nowrap}
.floating-social-btn:hover span{max-width:100px;margin-left:4px}
.floating-social-btn:hover{transform:translateX(-6px);box-shadow:0 6px 28px rgba(0,0,0,0.25)}
.floating-insta{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.floating-fb{background:#1877F2}
.floating-phone{background:var(--green)}

/* ===== FOOTER ===== */
.footer{background:linear-gradient(180deg,var(--brown) 0%,#2a1c10 100%);color:var(--cream);padding:70px 0 30px;position:relative;z-index:2}
.footer::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--green) 33%,white 33%,white 66%,var(--red) 66%)}
.footer::after{content:'';position:absolute;top:4px;left:0;width:100%;height:80px;background:linear-gradient(180deg,rgba(200,169,110,0.03),transparent);pointer-events:none}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand p{color:rgba(245,230,200,0.5);margin-top:14px;font-size:0.85rem;line-height:1.7;font-weight:300}
.footer-links h4,.footer-social h4{font-family:'Cormorant Garamond',serif;margin-bottom:18px;font-size:1.1rem;color:var(--gold)}
.footer-links a{display:block;color:rgba(245,230,200,0.5);text-decoration:none;font-size:0.85rem;padding:4px 0;transition:all 0.3s cubic-bezier(0.16,1,0.3,1);font-weight:300;position:relative}
.footer-links a:hover{color:var(--gold);padding-left:10px}
.footer-links a::before{content:'';position:absolute;left:0;top:50%;width:0;height:1px;background:var(--gold);transition:width 0.3s;transform:translateY(-50%)}
.footer-links a:hover::before{width:4px}
.footer-social-links{display:flex;flex-direction:column;gap:10px}
.footer-social-links a{display:inline-flex;align-items:center;gap:8px;color:rgba(245,230,200,0.5);text-decoration:none;font-size:0.85rem;transition:all 0.3s ease;font-weight:300}
.footer-social-links a:hover{color:var(--gold);transform:translateX(3px)}
.footer-bottom{text-align:center;padding-top:28px;border-top:1px solid rgba(245,230,200,0.08);position:relative}
.footer-bottom::before{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.footer-bottom p{font-size:0.8rem;color:rgba(245,230,200,0.35);font-weight:300}
.footer-legal{margin-top:4px;font-size:0.7rem!important}
.footer-legal-links{margin-top:8px;font-size:0.78rem!important}
.footer-legal-links a{color:#c8a96e;text-decoration:none;transition:color .3s}
.footer-legal-links a:hover{color:#C8102E;text-decoration:underline}

/* ===== ANIMATIONS ===== */
.animate-on-scroll{opacity:0;transform:translateY(32px);transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}

/* Staggered animation for child elements */
.animate-on-scroll.visible .about-feat:nth-child(1){transition-delay:0.1s}
.animate-on-scroll.visible .about-feat:nth-child(2){transition-delay:0.2s}
.animate-on-scroll.visible .about-feat:nth-child(3){transition-delay:0.3s}

/* Smooth image loading */
img[loading="lazy"]{opacity:0;transition:opacity 0.5s ease}
img[loading="lazy"].loaded{opacity:1}

/* ===== LOADING SKELETON ===== */
.menu-loading{text-align:center;padding:40px;color:var(--text-light);font-style:italic}

/* ===== FOCUS STATES (Accessibility) ===== */
a:focus-visible,.btn:focus-visible,.menu-tab:focus-visible,.floating-social-btn:focus-visible,.nav-social-btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ===== SUBTLE GLOW EFFECTS ===== */
.title-main{text-shadow:0 2px 40px rgba(245,230,200,0.1)}
.champ-card-number{text-shadow:0 2px 20px rgba(200,169,110,0.2)}
.badge-count{text-shadow:0 4px 30px rgba(255,255,255,0.15)}

/* ===== ITALIAN DIVIDER ENHANCEMENT ===== */
.italian-divider span{transition:width 0.6s cubic-bezier(0.16,1,0.3,1)}
.section-header.animate-on-scroll.visible .italian-divider span{animation:dividerGrow 0.8s cubic-bezier(0.16,1,0.3,1) both}
@keyframes dividerGrow{from{width:0;opacity:0}to{width:40px;opacity:1}}

/* ===== RESPONSIVE ===== */
@media(max-width:968px){
.about-content{grid-template-columns:1fr;gap:40px}
.contact-grid{grid-template-columns:1fr}
.footer-top{grid-template-columns:1fr;gap:30px}
.gallery-grid{grid-template-columns:repeat(3,1fr)}.gallery-large{grid-column:span 1;grid-row:span 1}
.stats-grid{grid-template-columns:repeat(2,1fr)}
.image-band{grid-template-columns:repeat(2,1fr)}.band-item{height:180px}
.champ-content{grid-template-columns:1fr}
.champ-trophy{display:none}
.champ-cards{grid-template-columns:repeat(3,1fr)}
.distinctions-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
.deco-scattered{display:none}
#particles-canvas{display:none}
.nav-toggle{display:flex}
.nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;flex-direction:column;background:var(--cream-light);padding:100px 36px 40px;gap:20px;box-shadow:-10px 0 40px rgba(0,0,0,0.08);transition:right 0.4s ease}
.nav-links.active{right:0}
.nav-cta-item{margin-left:0;margin-top:16px}
.hero-content{padding:80px 20px 60px}
.hero-badge{font-size:0.65rem;padding:6px 14px;letter-spacing:1px}
.section{padding:60px 0}
.menu-grid{grid-template-columns:1fr}
.social-mega-cta{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:1fr 1fr}
.champ-cards{grid-template-columns:1fr}
.champ-story{padding:24px}
.champ-story blockquote{flex-direction:column}
.distinctions-grid{grid-template-columns:1fr}
.diplome-cards{grid-template-columns:repeat(2,1fr)}
.diplome-card[data-index="6"]{grid-column:1/-1;justify-self:center;max-width:calc(50% - 8px)}
.lightbox-content{padding:60px 40px 20px}
.lightbox-nav{width:44px;height:44px}
.fb-widget-wrapper{max-width:100%}
}
@media(max-width:480px){
.hero-cta-group{flex-direction:column;align-items:center}
.hero-social-links{flex-direction:column}
.social-cta{justify-content:center;width:100%}
.image-band{grid-template-columns:1fr 1fr}.band-item{height:140px}
.stats-grid{grid-template-columns:1fr 1fr;gap:20px}
.gallery-grid{grid-template-columns:1fr}
.phone-modal{padding:36px 24px}
.diplome-cards{grid-template-columns:1fr}
.diplome-card[data-index="6"]{grid-column:auto;justify-self:auto;max-width:none}
.diplome-card-info h4{font-size:0.92rem}
.lightbox-content{padding:50px 16px 16px}
.lightbox-nav{width:38px;height:38px}
.lightbox-prev{left:8px}
.lightbox-next{right:8px}
.lightbox-caption{font-size:0.95rem}
}

/* ==================== COOKIE BANNER (CNIL Conforme) ==================== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#1e150d,#1a1209);color:#F5E6C8;padding:24px 28px;z-index:100000;box-shadow:0 -8px 40px rgba(0,0,0,0.35);transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1);font-family:'Josefin Sans',sans-serif;border-top:1px solid rgba(200,169,110,0.1)}
.cookie-banner.cookie-visible{transform:translateY(0)}
.cookie-banner-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.cookie-banner-text{flex:1;min-width:280px}
.cookie-banner-text p{font-size:0.88rem;line-height:1.7;font-weight:300;margin:0}
.cookie-banner-text a{color:#c8a96e;text-decoration:none;border-bottom:1px solid rgba(200,169,110,0.3);transition:all .3s}
.cookie-banner-text a:hover{color:#C8102E;border-bottom-color:#C8102E}
.cookie-banner-btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.cookie-btn{padding:11px 24px;border-radius:8px;font-family:'Josefin Sans',sans-serif;font-size:0.85rem;font-weight:500;cursor:pointer;transition:all 0.3s;border:none;letter-spacing:0.5px;position:relative;overflow:hidden}
.cookie-btn::after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.1);border-radius:50%;transform:translate(-50%,-50%);transition:width .4s,height .4s}
.cookie-btn:active::after{width:200px;height:200px}
.cookie-btn-accept{background:linear-gradient(135deg,#1B7340,#2D8E57);color:white;box-shadow:0 2px 8px rgba(27,115,64,0.25)}
.cookie-btn-accept:hover{background:linear-gradient(135deg,#2D8E57,#34a063);transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,115,64,0.35)}
.cookie-btn-refuse{background:linear-gradient(135deg,#C8102E,#E63946);color:white;box-shadow:0 2px 8px rgba(200,16,46,0.25)}
.cookie-btn-refuse:hover{background:linear-gradient(135deg,#E63946,#f04c5a);transform:translateY(-1px);box-shadow:0 4px 14px rgba(200,16,46,0.35)}
.cookie-btn-params{background:transparent;color:#c8a96e;border:1px solid rgba(200,169,110,0.3);backdrop-filter:blur(4px)}
.cookie-btn-params:hover{background:rgba(200,169,110,0.08);border-color:#c8a96e;transform:translateY(-1px)}
/* Cookie details panel */
.cookie-details{display:none;margin-top:20px;padding-top:20px;border-top:1px solid rgba(200,169,110,0.12);width:100%;animation:cookieSlideDown 0.3s ease}
.cookie-details.cookie-details-open{display:block}
@keyframes cookieSlideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.cookie-detail-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(200,169,110,0.06);border-radius:8px;margin-bottom:4px;transition:background .3s}
.cookie-detail-row:hover{background:rgba(200,169,110,0.04)}
.cookie-detail-row:last-child{border-bottom:none}
.cookie-detail-info h4{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:#F5E6C8;margin-bottom:3px}
.cookie-detail-info p{font-size:0.8rem;color:#8a7a6a;margin:0}
.cookie-toggle{position:relative;width:48px;height:26px;flex-shrink:0}
.cookie-toggle input{opacity:0;width:0;height:0}
.cookie-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#3a2a1a;border-radius:26px;transition:0.3s;border:1px solid rgba(200,169,110,0.1)}
.cookie-toggle-slider::before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:2px;background:white;border-radius:50%;transition:0.3s;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.cookie-toggle input:checked+.cookie-toggle-slider{background:linear-gradient(135deg,#1B7340,#2D8E57);border-color:transparent}
.cookie-toggle input:checked+.cookie-toggle-slider::before{transform:translateX(22px)}
.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:0.4;cursor:not-allowed}
@media(max-width:768px){
.cookie-banner-inner{flex-direction:column;align-items:stretch;gap:16px}
.cookie-banner-btns{justify-content:stretch}
.cookie-btn{flex:1;text-align:center;padding:13px 16px}
}
@media(max-width:480px){
.cookie-banner{padding:18px 16px}
.cookie-btn{font-size:0.82rem;padding:11px 12px}
.cookie-detail-row{padding:12px}
}
@media(prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
.deco-scattered{display:none}
#particles-canvas{display:none}
}
