/* ============================================================
   China Nails Art v2 — frontend.css
   CSS critique frontend: variables, composants, utilitaires.
   Fichier extrait de l'inline <style> pour mise en cache navigateur.
   ============================================================ */
:root{--primary:#e91e63;--primary-dark:#c2185b;--secondary:#ff4081;--accent:#ffc107;--dark:#2c2c2c;--gradient:linear-gradient(135deg,#e91e63 0%,#ff4081 100%);--shadow:0 10px 30px rgba(0,0,0,.10);--shadow-hover:0 20px 40px rgba(0,0,0,.15);--radius:20px;--transition:all .3s cubic-bezier(.4,0,.2,1)}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',Tahoma,Arial,sans-serif;color:var(--dark);overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}
.navbar-modern{background:linear-gradient(135deg,#e63e72,#ff5b8d)!important;box-shadow:0 2px 20px rgba(233,30,99,.3);position:fixed;top:0;width:100%;z-index:1000}
.navbar-brand-text{font-family:'Trebuchet MS','Segoe UI',sans-serif;font-size:1.4rem;font-weight:700;color:white!important;text-shadow:0 2px 5px rgba(0,0,0,.2)}
.navbar-modern .nav-link{color:white!important;font-weight:500;transition:var(--transition)}
.navbar-modern .nav-link.active,.navbar-modern .nav-link[aria-current="page"]{background:rgba(0,0,0,.2);border-radius:8px}
.navbar-modern .nav-link:hover{background:rgba(0,0,0,.15);border-radius:8px}
.navbar-modern .navbar-toggler{border:2px solid rgba(255,255,255,.5)}
.navbar-modern .navbar-toggler-icon{filter:brightness(0) invert(1)}
@media(max-width:991px){.navbar-modern .navbar-collapse{background:#c2185b;padding:.5rem;border-radius:0 0 12px 12px}}
.hero-section{min-height:100vh;background:linear-gradient(150deg,#e91e63 0%,#c2185b 50%,#880e4f 100%);display:flex;align-items:center;padding-top:76px;position:relative;overflow:hidden}
.hero-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 1000'%3E%3Ccircle cx='200' cy='200' r='100' fill='rgba(255,255,255,0.07)'/%3E%3Ccircle cx='800' cy='300' r='150' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='400' cy='700' r='120' fill='rgba(255,255,255,0.06)'/%3E%3C/svg%3E");animation:floatBg 20s ease-in-out infinite}
@keyframes floatBg{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes slideInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-content{position:relative;z-index:2;color:white}
.hero-title{font-size:clamp(2rem,6vw,3.5rem);font-weight:700;animation:slideInUp .9s ease-out}
.hero-subtitle{font-size:clamp(1rem,3vw,1.3rem);font-weight:300;animation:slideInUp .9s ease-out .2s both}
.hero-buttons{animation:slideInUp .9s ease-out .4s both}
.btn-hero{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.8rem;background:rgba(255,255,255,.2);color:white;text-decoration:none;border-radius:50px;font-weight:600;border:2px solid rgba(255,255,255,.4);transition:var(--transition);backdrop-filter:blur(10px)}
.btn-hero:hover{background:rgba(255,255,255,.35);color:white;transform:translateY(-2px)}
.hero-logo img{border-radius:50%;box-shadow:0 20px 40px rgba(0,0,0,.3);animation:slideInUp .9s ease-out .6s both}
.hero-wave-sep{height:56px;margin-top:-2px;line-height:0;overflow:hidden;background:transparent}
.hero-wave-sep svg{display:block;width:100%;height:100%}
.hero-stats{display:flex;gap:2rem;margin-top:1.5rem;flex-wrap:wrap}
.hero-stat-item{text-align:center}
.hero-stat-num{display:block;font-size:1.6rem;font-weight:800;color:#fff;line-height:1}
.hero-stat-lbl{font-size:.72rem;color:rgba(255,255,255,.75);letter-spacing:.1em;text-transform:uppercase}
.section-eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);background:rgba(233,30,99,.1);padding:.28rem .85rem;border-radius:999px;margin-bottom:.6rem}
.section-header-center{text-align:center;margin-bottom:2.5rem}
.section-header-center .section-title{margin-bottom:0}
.section-modern{padding:80px 0}
.section-title{text-align:center;margin-bottom:3rem;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;color:var(--primary);position:relative}
.section-title::after{content:'';display:block;margin:.5rem auto 0;width:80px;height:4px;background:var(--gradient);border-radius:2px}
.service-card,.gallery-card,.review-card,.video-card{background:white;border-radius:var(--radius);box-shadow:var(--shadow);transition:var(--transition);height:100%;overflow:hidden}
.service-card:hover,.gallery-card:hover,.review-card:hover,.video-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.service-card-body{padding:1.5rem}
.service-image{width:100%;height:200px;object-fit:cover}
.service-icon{width:80px;height:80px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:1.5rem auto;font-size:2rem;color:white}
.service-title{font-size:1.2rem;font-weight:600;color:var(--primary);text-align:center;margin:.75rem 1rem .5rem}
.service-description{color:#555;text-align:center;font-size:.9rem;padding:0 1rem}
.service-price{font-size:1.1rem;font-weight:700;color:var(--accent);text-align:center;padding:.5rem 1rem 1.2rem}
.gallery-image{width:100%;height:220px;object-fit:cover}
.gallery-title{font-size:1rem;font-weight:600;color:var(--primary);margin:.75rem 1rem .25rem}
.gallery-description{font-size:.85rem;color:#666;margin:0 1rem 1rem}
.review-card{padding:1.5rem}
.review-rating{color:#ffc107;margin-bottom:.75rem}
.review-text{font-style:italic;color:#444;margin-bottom:.75rem}
.review-author{font-weight:700;color:var(--primary);margin-bottom:.25rem}
.review-date{font-size:.85rem;color:#888}
.review-photos img{width:60px;height:60px;object-fit:cover;border-radius:8px;margin:.25rem}
.video-card .video-body{padding:.75rem 1rem 1rem}
.video-preview-container{position:relative;width:100%;height:220px;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;overflow:hidden}
.video-preview-canvas{width:100%;height:100%;object-fit:cover;display:block}
.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3)}
.about-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}
.contact-section{background:var(--gradient);color:white}
.contact-section .section-title{color:white}
.contact-section .section-title::after{background:rgba(255,255,255,.6)}
.contact-item{text-align:center;padding:1rem}
.contact-icon{font-size:2.5rem;margin-bottom:1rem}
.show-more-container{text-align:center;margin-top:1.5rem}
.show-more-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:var(--gradient);color:white;border:none;border-radius:50px;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none}
.show-more-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);color:white}
.hidden-item{display:none}
footer{background:var(--dark);color:white;padding:3rem 0 1rem}
footer h5{color:var(--primary)}
footer a{color:rgba(255,255,255,.6);text-decoration:none;transition:var(--transition)}
footer a:hover{color:white}
.social-links a{width:38px;height:38px;background:var(--gradient);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:white;margin:.2rem;transition:var(--transition)}
.social-links a:hover{transform:translateY(-3px)}
.whatsapp-float{position:fixed;bottom:25px;right:25px;z-index:999;width:55px;height:55px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:1.6rem;box-shadow:0 4px 20px rgba(37,211,102,.5);text-decoration:none;transition:var(--transition)}
.whatsapp-float:hover{transform:scale(1.1);color:white}
.page-hero{background:var(--gradient);color:white;padding:6rem 0 3rem;margin-top:76px}
.page-hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:700}
.brand-logo{border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.7)}
.brand-logo-fallback{color:white;font-size:1.5rem}
.nav-lang{color:white;text-decoration:none;font-size:.85rem}
.nav-whatsapp{color:white;font-size:1.2rem}
.hero-badge{color:rgba(255,255,255,.8);letter-spacing:2px;font-size:.85rem}
.hero-logo-col{animation:slideInUp .9s ease-out .6s both}
.hero-logo-image{max-width:280px;border-radius:50%;box-shadow:0 20px 40px rgba(0,0,0,.3)}
.section-title-highlight{color:var(--primary);font-weight:700;margin-bottom:1rem}
.about-image{border-radius:20px;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.service-duration{font-size:.85rem}
.service-meta-small{font-size:.85rem}
.review-author-icon{color:var(--primary)}
.review-photo-clickable{cursor:pointer}
.btn-accent-green{background:linear-gradient(135deg,#4caf50,#66bb6a);color:white;text-decoration:none}
.btn-whatsapp-gradient{background:linear-gradient(135deg,#25d366,#128c7e)}
.contact-link-light{color:white}
.contact-link-primary{color:var(--primary)}
.contact-icon-circle{width:48px;height:48px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:1rem}
.contact-card-title{color:var(--primary);font-weight:700;margin-bottom:1.5rem}
.form-container-narrow{max-width:700px}
.form-card-title{color:var(--primary);font-weight:700;margin-bottom:1.5rem;text-align:center}
.modal-media{max-height:80vh;border-radius:8px}
.gallery-card-clickable{cursor:pointer}
.btn-outline-pink{--bs-btn-color:#e91e63;--bs-btn-border-color:#e91e63;--bs-btn-hover-bg:#e91e63;--bs-btn-hover-color:#ffffff}
.visually-hidden-field{display:none}
.video-fallback-box{height:220px;background:#eee;display:flex;align-items:center;justify-content:center}
.video-play-icon{font-size:3rem;color:rgba(255,255,255,.95);text-shadow:0 2px 8px rgba(0,0,0,.7)}
.video-source{display:none}
.dynamic-video-player{width:100%;max-height:70vh}
.footer-divider{border-color:rgba(255,255,255,.15)}
/* Scroll-to-top */
.scroll-top{position:fixed;bottom:5.5rem;right:1.5rem;z-index:89;width:42px;height:42px;border-radius:50%;background:var(--primary);color:#fff;font-size:1.3rem;display:none;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(233,30,99,.35);transition:all .3s ease;border:none;cursor:pointer;line-height:1}
.scroll-top:hover{background:var(--primary-dark);transform:translateY(-2px)}
.scroll-top.visible{display:flex}
/* WhatsApp emoji fallback (data-saver / FA absent) */
.wa-emoji-fb{display:none;align-items:center;justify-content:center;font-size:1.5rem;line-height:1}
/* Data-saver */
.data-saver *{animation:none!important;transition:none!important}
.data-saver .hero-section::before{display:none}
.data-saver .video-preview-container{background:linear-gradient(135deg,#505050,#2f2f2f)}
.data-saver .hero-logo-col{animation:none}
.data-saver .service-card,.data-saver .gallery-card,.data-saver .review-card,.data-saver .video-card{box-shadow:none!important}
.data-saver .fas,.data-saver .fab,.data-saver .far{display:none!important}
.data-saver .wa-emoji-fb{display:flex!important}
/* ── WhatsApp pulse + tooltip ───────────────────────────── */
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.whatsapp-float{animation:wa-pulse 2.4s infinite}
.wa-tooltip{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#fff;color:#128c7e;font-weight:700;font-size:.82rem;white-space:nowrap;padding:.3rem .65rem;border-radius:6px;box-shadow:0 2px 10px rgba(0,0,0,.14);opacity:0;pointer-events:none;transition:opacity .2s}
.whatsapp-float:hover .wa-tooltip{opacity:1}
/* ── FAQ accordion ──────────────────────────────────────── */
.faq-section{position:relative;background:linear-gradient(165deg,#fff6fa 0%,#ffeef5 45%,#fff 100%);overflow:hidden}
.faq-section::before{content:"";position:absolute;top:-90px;right:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(233,30,99,.2) 0%,rgba(233,30,99,0) 70%);pointer-events:none}
.faq-layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:1.1rem;align-items:start}
.faq-intro-card{background:linear-gradient(165deg,#ffffff 0%,#fff3f8 100%);border:1px solid rgba(233,30,99,.24);border-radius:18px;padding:1.15rem;box-shadow:0 12px 28px rgba(194,24,91,.08);position:sticky;top:96px}
.faq-kicker{margin:0 0 .4rem;font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#c2185b}
.faq-intro-card h3{margin:0 0 .45rem;font-size:1.18rem;color:#7a123d}
.faq-intro-card p{margin:0;color:#5a5f6c;line-height:1.55}
.faq-points{margin:.9rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.55rem}
.faq-points li{display:flex;gap:.5rem;align-items:flex-start;color:#424a59;font-size:.9rem;line-height:1.45}
.faq-points i{color:#e91e63;margin-top:.12rem;flex-shrink:0}
.faq-side-cta{display:inline-flex;align-items:center;gap:.45rem;margin-top:1rem;padding:.62rem .95rem;border-radius:999px;background:var(--gradient);color:#fff;text-decoration:none;font-weight:700;box-shadow:0 10px 24px rgba(194,24,91,.2);transition:transform .2s ease,box-shadow .2s ease}
.faq-side-cta:hover{color:#fff;transform:translateY(-2px);box-shadow:0 14px 28px rgba(194,24,91,.28)}
.faq-accordion{display:flex;flex-direction:column;gap:.7rem}
.faq-item{background:#fff;border:1px solid #f7cfde;border-radius:15px;overflow:hidden;box-shadow:0 8px 22px rgba(15,23,42,.04);transition:border-color .22s ease,box-shadow .22s ease}
.faq-item:hover{border-color:#f2b5cd;box-shadow:0 12px 28px rgba(194,24,91,.12)}
.faq-item.open{border-color:#ea8eb2;box-shadow:0 16px 32px rgba(194,24,91,.16)}
.faq-question{width:100%;background:none;border:0;padding:.95rem 1rem;display:flex;align-items:center;gap:.78rem;cursor:pointer;text-align:left;color:#1f2533}
.faq-question-index{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#fde7f0;color:#bc255f;font-size:.72rem;font-weight:800;letter-spacing:.05em;flex-shrink:0}
.faq-question-text{flex:1;font-weight:700;font-size:1rem;line-height:1.35}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid #f3bfd4;background:#fff;color:#c2185b;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:transform .22s ease,background .22s ease,color .22s ease,border-color .22s ease}
.faq-item.open .faq-icon{transform:rotate(45deg);background:#e91e63;color:#fff;border-color:#e91e63}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-item.open .faq-answer{max-height:460px}
.faq-answer-inner{padding:0 1rem 1rem 4.25rem;border-top:1px solid #fde3ee}
.faq-answer p{margin:.7rem 0 0;color:#4b5563;line-height:1.68;font-size:.95rem}
/* ── Diseño del mes ─────────────────────────────────────── */
.design-month-section{background:linear-gradient(135deg,#fff0f5 0%,#fce4ec 100%)}
.design-featured-img{border-radius:1.2rem;box-shadow:0 12px 40px rgba(233,30,99,.18);max-height:420px;object-fit:cover;width:100%}
.design-month-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--gradient);color:#fff;font-weight:700;font-size:.8rem;padding:.35rem .85rem;border-radius:999px;margin-bottom:.8rem;letter-spacing:.04em}
/* ── Instagram grid ─────────────────────────────────────── */
.insta-section{background:#fff}
.insta-handle{font-size:1.05rem;color:var(--primary);font-weight:700}
.insta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;border-radius:1rem;overflow:hidden}
.insta-post{display:block;position:relative;aspect-ratio:1;overflow:hidden;background:#f1f5f9}
.insta-post img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.insta-post:hover img{transform:scale(1.07)}
.insta-overlay{position:absolute;inset:0;background:rgba(233,30,99,.45);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s;color:#fff;font-size:1.8rem}
.insta-post:hover .insta-overlay{opacity:1}
/* ── Animated counters ─────────────────────────────────── */
.hero-stat-num{display:inline-block;transition:color .2s}
.hero-stat-num.counting{color:#fce4ec}
/* ── Navbar scroll-shrink ─────────────────────────────── */
.navbar-modern{transition:padding .28s ease,box-shadow .28s ease}
.navbar-modern.scrolled{padding-top:.3rem!important;padding-bottom:.3rem!important;box-shadow:0 6px 32px rgba(233,30,99,.55)!important}
/* ── Hamburger rotate-to-X ───────────────────────────── */
.navbar-toggler{transition:transform .3s ease}
.navbar-toggler[aria-expanded="true"]{transform:rotate(90deg)}
/* ── Scroll reveal ──────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .62s cubic-bezier(.4,0,.2,1),transform .62s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}
.data-saver .reveal{opacity:1!important;transform:none!important;transition:none!important}
/* ── Service card CTA button ────────────────────────── */
.service-card{position:relative}
.service-card-cta{padding:.5rem 1.2rem 1.25rem;text-align:center}
.service-card-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.5rem;background:var(--gradient);color:#fff;text-decoration:none;border-radius:50px;font-size:.88rem;font-weight:700;transition:var(--transition);box-shadow:0 4px 14px rgba(233,30,99,.25)}
.service-card-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(233,30,99,.35);color:#fff}
/* ── Review card accent ──────────────────────────────── */
.review-card{border-top:4px solid var(--primary)!important}
/* ── Contact items hover ─────────────────────────────── */
.contact-item{transition:transform .28s ease,background .28s ease;border-radius:14px}
.contact-item:hover{transform:translateY(-6px);background:rgba(255,255,255,.12)}
.contact-icon{font-size:2.5rem;margin-bottom:1rem;transition:transform .28s ease}
.contact-item:hover .contact-icon{transform:scale(1.15)}
/* ── Gallery filter pills ────────────────────────────── */
.gallery-filter-btn{display:inline-flex;align-items:center;padding:.42rem 1.1rem;border-radius:50px;font-weight:600;font-size:.88rem;transition:var(--transition);text-decoration:none;border:2px solid transparent;white-space:nowrap;cursor:pointer}
.gallery-filter-btn.active-filter,.gallery-filter-btn.btn-primary{background:var(--gradient)!important;color:#fff!important;border-color:transparent!important;box-shadow:0 4px 14px rgba(233,30,99,.3)}
.gallery-filter-btn:not(.active-filter):not(.btn-primary){background:#f5f5f5;color:#555;border-color:#e0e0e0}
.gallery-filter-btn:not(.active-filter):not(.btn-primary):hover{border-color:var(--primary);color:var(--primary);background:#fff4f7}
/* ── Hero stats visual separator ─────────────────────── */
.hero-stat-item{padding:.4rem 1.1rem}
.hero-stat-item+.hero-stat-item{border-left:1px solid rgba(255,255,255,.28)}
/* ── Page-hero wave for sub-pages ────────────────────── */
.page-hero-wave{height:50px;margin-top:-2px;line-height:0;overflow:hidden;background:transparent}
.page-hero-wave svg{display:block;width:100%;height:100%}
/* ── About image frame effect ────────────────────────── */
.about-image-wrap{position:relative;display:inline-block;max-width:400px}
.about-image-wrap::before{content:'';position:absolute;top:-10px;left:-10px;right:10px;bottom:10px;border:3px solid rgba(233,30,99,.28);border-radius:24px;pointer-events:none}
/* ── Section eyebrow pop ─────────────────────────────── */
.section-eyebrow{animation:none}
/* ── Responsive */
@media(max-width:768px){
  .hero-section{padding-top:100px;min-height:auto;padding-bottom:3rem}
  .section-modern{padding:50px 0}
  .hero-stats{gap:1.2rem}
  .hero-stat-num{font-size:1.3rem}
  .hero-wave-sep{height:40px}
  .faq-layout{grid-template-columns:1fr;gap:.9rem}
  .faq-intro-card{position:static;padding:1rem;border-radius:15px}
  .faq-question{padding:.85rem .82rem;gap:.62rem}
  .faq-question-index{width:30px;height:30px;border-radius:9px}
  .faq-question-text{font-size:.94rem}
  .faq-answer-inner{padding:0 .82rem .9rem .82rem}
  .faq-answer p{font-size:.92rem;line-height:1.62}
  input,textarea,select{font-size:16px}
  .whatsapp-float{width:50px;height:50px;font-size:1.4rem;bottom:18px;right:18px}
  .scroll-top{bottom:4.8rem;right:1.1rem;width:38px;height:38px;font-size:1.1rem}
  .wa-tooltip{display:none}
}

/* ── Très petits écrans (< 480px) ──────────────────────── */
@media(max-width:479px){
  /* Instagram 2 colonnes sur téléphones étroits */
  .insta-grid{grid-template-columns:repeat(2,1fr);gap:4px}
  /* Hero plus compact */
  .hero-section{padding-top:90px;padding-bottom:2rem}
  .hero-title{font-size:1.85rem}
  .hero-subtitle{font-size:.95rem}
  /* Stats hero: empiler verticalement sous 400px */
  .hero-stats{flex-direction:column;align-items:center;gap:.6rem}
  .hero-stat-item+.hero-stat-item{border-left:0;border-top:1px solid rgba(255,255,255,.22);padding-top:.6rem}
  .hero-stat-num{font-size:1.4rem}
  /* Galerie 2 colonnes + hauteur réduite */
  .gallery-image{height:160px}
  /* Cartes vidéo un peu moins hautes */
  .video-preview-container,.video-fallback-box{height:180px}
  .video-preview-poster{height:180px}
  /* Services: pas de padding excessif */
  .section-modern{padding:40px 0}
  /* Footer links plein écran */
  .social-links a{width:42px;height:42px;font-size:1rem}
}

/* ── Tablette (769px – 991px) ───────────────────────────── */
@media(min-width:769px) and (max-width:991px){
  .hero-section{min-height:80vh}
  .hero-logo-image{max-width:220px}
  .faq-layout{grid-template-columns:minmax(220px,260px) minmax(0,1fr)}
  .gallery-image{height:200px}
  .service-image{height:180px}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
  .section-modern{padding:60px 0}
}

/* ── Appareils tactiles : désactiver les hover d'élévation ─ */
@media(hover:none){
  .service-card:hover,.gallery-card:hover,.review-card:hover,.video-card:hover{
    transform:none!important;box-shadow:var(--shadow)!important
  }
  .show-more-btn:hover{transform:none}
  .btn-hero:hover{transform:none}
  .social-links a:hover{transform:none}
  .faq-side-cta:hover{transform:none}
  /* Activer l'overlay Instagram au tap */
  .insta-post:active .insta-overlay{opacity:1}
}

/* ── Image poster pour les cartes vidéo ─────────────────── */
.video-preview-poster{
  width:100%;height:220px;object-fit:cover;display:block
}
@media(max-width:479px){
  .video-preview-poster{height:180px}
}

/* ── Galerie homepage : curseur pointer et transition ──── */
.gallery-card-clickable{cursor:pointer;outline:none}
.gallery-card-clickable:focus-visible{box-shadow:0 0 0 3px rgba(233,30,99,.45),var(--shadow)}
.gallery-card-clickable .gallery-image{transition:transform .3s ease}
.gallery-card-clickable:hover .gallery-image{transform:scale(1.04)}
@media(hover:none){
  .gallery-card-clickable:hover .gallery-image{transform:none}
  .gallery-card-clickable:active .gallery-image{transform:scale(1.02)}
}

/* ════════════════════════════════════════════════════════
   AMÉLIORATIONS SPECTACULAIRES
   ════════════════════════════════════════════════════════ */

/* ── Sparkles / étincelles hero (CSS pur, 0 JS) ─────────── */
@keyframes sparkle{
  0%{opacity:0;transform:scale(.3) rotate(0deg)}
  40%{opacity:1;transform:scale(1) rotate(180deg)}
  100%{opacity:0;transform:scale(.5) rotate(360deg)}
}
.hero-sparkle{
  position:absolute;pointer-events:none;
  width:10px;height:10px;
  background:radial-gradient(circle,rgba(255,255,255,.95) 0%,rgba(255,255,255,0) 70%);
  border-radius:50%;animation:sparkle 3s ease-in-out infinite
}
/* 8 étincelles positionnées dans le hero */
.hero-sparkle:nth-child(1){top:15%;left:8%;animation-delay:0s;width:8px;height:8px}
.hero-sparkle:nth-child(2){top:25%;right:12%;animation-delay:.6s;width:12px;height:12px}
.hero-sparkle:nth-child(3){top:60%;left:5%;animation-delay:1.2s;width:6px;height:6px}
.hero-sparkle:nth-child(4){top:75%;right:8%;animation-delay:1.8s;width:10px;height:10px}
.hero-sparkle:nth-child(5){top:40%;left:48%;animation-delay:.4s;width:7px;height:7px}
.hero-sparkle:nth-child(6){top:10%;right:30%;animation-delay:2.2s;width:9px;height:9px}
.hero-sparkle:nth-child(7){top:85%;left:35%;animation-delay:1.5s;width:6px;height:6px}
.hero-sparkle:nth-child(8){top:50%;right:25%;animation-delay:.9s;width:11px;height:11px}
.data-saver .hero-sparkle{display:none!important}

/* ── Badge "Nouveau design" sur images galerie ───────────── */
.gallery-card{position:relative}
.gallery-card-new-badge{
  position:absolute;top:.55rem;left:.55rem;
  background:var(--gradient);color:#fff;font-size:.68rem;
  font-weight:800;padding:.18rem .55rem;border-radius:999px;
  letter-spacing:.04em;z-index:2;pointer-events:none
}

/* ── Service card améliorée ─────────────────────────────── */
.service-card{transition:var(--transition);overflow:hidden}
.service-image{transition:transform .4s ease}
.service-card:hover .service-image{transform:scale(1.06)}
@media(hover:none){.service-card:hover .service-image{transform:none}}

/* ── Ligne décorative sous les h2 de section ─────────────── */
.section-title{position:relative}

/* ── Effet de brillance sur les boutons CTA ─────────────── */
@keyframes shine{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
.show-more-btn,.btn-hero{
  background-size:200% auto;position:relative;overflow:hidden
}
.show-more-btn::after,.btn-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.18) 50%,transparent 100%);
  transform:translateX(-100%);transition:transform .5s ease
}
.show-more-btn:hover::after,.btn-hero:hover::after{transform:translateX(100%)}
@media(hover:none){
  .show-more-btn::after,.btn-hero::after{display:none}
}

/* ── Cartes service: ruban de prix plus visible ──────────── */
.service-price{
  background:linear-gradient(135deg,rgba(255,193,7,.15),rgba(255,193,7,.05));
  border-top:1px solid rgba(255,193,7,.3);
  font-size:1.05rem;letter-spacing:.02em
}

/* ── Section contact: icônes plus grandes et arrondies ───── */
.contact-icon{
  display:flex;align-items:center;justify-content:center;
  width:60px;height:60px;
  background:rgba(255,255,255,.2);
  border-radius:50%;margin:0 auto 1rem;
  backdrop-filter:blur(4px);
  transition:transform .3s ease,background .3s ease
}
.contact-item:hover .contact-icon{
  background:rgba(255,255,255,.35);transform:scale(1.12) rotate(-5deg)
}
@media(hover:none){
  .contact-item:hover .contact-icon{transform:none}
}

/* ── Reviews: effet de profondeur card ───────────────────── */
.review-card{
  position:relative;overflow:hidden
}
.review-card::before{
  content:'❝';position:absolute;top:-10px;right:12px;
  font-size:5rem;color:rgba(233,30,99,.07);
  font-family:Georgia,serif;line-height:1;pointer-events:none
}

/* ── Barre de progression globale au chargement ─────────── */
#page-load-bar{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:9999;
  background:linear-gradient(90deg,#e91e63,#ff4081,#ffc107);
  transition:width .3s ease;pointer-events:none
}

/* ── Dropdown langue navbar ──────────────────────────────── */
.nav-lang{color:white;text-decoration:none;font-size:.85rem;background:none;padding:.25rem .5rem;border-radius:6px}
.nav-lang:hover{background:rgba(255,255,255,.15)}
.navbar-modern .dropdown-menu{border:1px solid rgba(233,30,99,.2);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.navbar-modern .dropdown-item{font-size:.87rem;padding:.4rem .85rem;border-radius:7px;margin:.1rem .3rem;width:calc(100% - .6rem)}
.navbar-modern .dropdown-item:hover{background:rgba(233,30,99,.1);color:var(--primary)}

/* ── Améliorations visuelles spectaculaires (suite) ────── */

/* Barre colorée en haut de page (theme-color bar) */
body::before{
  content:'';display:block;height:3px;
  background:linear-gradient(90deg,#e91e63,#ff4081,#ffc107,#ff4081,#e91e63);
  background-size:200% auto;
  animation:shimmer 3s linear infinite;
  position:fixed;top:0;left:0;right:0;z-index:1001
}
@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}
.data-saver body::before{animation:none}

/* Amélioration hero: gradient plus riche */
.hero-section{
  background:linear-gradient(150deg,#e91e63 0%,#c2185b 35%,#880e4f 70%,#6a0536 100%)
}

/* Logo hero: animation d'entrée et effet de brillance */
.hero-logo-image{
  filter:drop-shadow(0 0 24px rgba(255,255,255,.2));
  transition:transform .3s ease
}
.hero-logo-image:hover{transform:scale(1.04) rotate(1deg)}
@media(hover:none){.hero-logo-image:hover{transform:none}}

/* Cartes galerie: aspect-ratio fixe pour cohérence */
.gallery-card{aspect-ratio:auto}
.gallery-image{height:220px;transition:transform .35s ease}
.gallery-card:hover .gallery-image{transform:scale(1.04)}
@media(hover:none){.gallery-card:hover .gallery-image{transform:none}}

/* Section design du mois: amélioration */
.design-featured-img{transition:transform .4s ease,box-shadow .4s ease}
.design-featured-img:hover{
  transform:scale(1.02) rotate(-.5deg);
  box-shadow:0 20px 60px rgba(233,30,99,.25)
}
@media(hover:none){.design-featured-img:hover{transform:none}}

/* Footer: liens sociaux plus grands sur mobile */
@media(max-width:575px){
  .social-links{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap}
  footer h5{text-align:center}
  footer .text-white-50{text-align:center}
}

/* WhatsApp float: légèrement plus visible sur petits écrans */
@media(max-width:479px){
  .whatsapp-float{bottom:14px;right:14px;width:46px;height:46px;font-size:1.3rem}
  .scroll-top{bottom:4.3rem;right:12px;width:36px;height:36px;font-size:1rem}
}

/* Reviews: photo miniature arrondie et cliquable */
.review-photos img{
  width:64px;height:64px;object-fit:cover;border-radius:10px;
  margin:.2rem;cursor:pointer;border:2px solid transparent;
  transition:border-color .2s ease,transform .2s ease
}
.review-photos img:hover{border-color:var(--primary);transform:scale(1.08)}
@media(hover:none){.review-photos img:hover{transform:none}}

/* Galerie: indicateur "Cliquer pour agrandir" */
.gallery-card-clickable::after{
  content:'🔍';position:absolute;bottom:.5rem;right:.5rem;
  font-size:.85rem;opacity:0;transition:opacity .25s ease;
  background:rgba(0,0,0,.5);color:#fff;border-radius:50%;
  width:28px;height:28px;display:flex;align-items:center;justify-content:center
}
.gallery-card-clickable:hover::after{opacity:1}
@media(hover:none){.gallery-card-clickable::after{display:none}}

/* ── Améliorations accessibilité focus ───────────────────── */
a:focus-visible,button:focus-visible{
  outline:3px solid rgba(233,30,99,.6);
  outline-offset:3px;border-radius:4px
}
.btn-hero:focus-visible,.show-more-btn:focus-visible{
  outline-color:rgba(255,255,255,.8)
}

/* ═══════════════════════════════════════════════════════════
   WOW v3 — Performance + Design spectaculaire connexion lente
   ═══════════════════════════════════════════════════════════ */

/* ── Smooth scroll natif (ancres internes) ─────────────────── */
html{scroll-behavior:smooth}
html.data-saver{scroll-behavior:auto}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* ── Optimisation GPU pour cartes animées (uniquement au survol) */
@media(hover:hover){
  .service-card:hover,.gallery-card:hover,.review-card:hover,.video-card:hover{
    will-change:transform
  }
}

/* ── Texte optimisé ─────────────────────────────────────────── */
body{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ── Hero title : éclat blanc spectaculaire ────────────────── */
.hero-title{
  text-shadow:0 2px 20px rgba(255,255,255,.15),0 1px 0 rgba(0,0,0,.1)
}

/* ── Page hero (sous-pages) : gradient plus profond ─────────── */
.page-hero{
  background:linear-gradient(150deg,#e91e63 0%,#c2185b 40%,#880e4f 100%);
  position:relative;overflow:hidden
}
.page-hero::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 400'%3E%3Ccircle cx='650' cy='80' r='180' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='100' cy='300' r='120' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E");
  pointer-events:none
}
.page-hero .container{position:relative;z-index:1}

/* ── Hero logo : halo lumineux ──────────────────────────────── */
.hero-logo-image{
  animation:heroLogoFloat 6s ease-in-out infinite
}
@keyframes heroLogoFloat{
  0%,100%{filter:drop-shadow(0 0 24px rgba(255,255,255,.22))}
  50%{filter:drop-shadow(0 0 38px rgba(255,255,255,.38)) drop-shadow(0 8px 20px rgba(0,0,0,.2))}
}
.data-saver .hero-logo-image{animation:none;filter:none}

/* ── Boutons CTA : gradient animé au hover ──────────────────── */
.show-more-btn,.btn-hero{
  background:linear-gradient(135deg,#e91e63 0%,#ff4f8b 50%,#e91e63 100%);
  background-size:200% 100%;
  transition:background-position .4s ease,transform .3s ease,box-shadow .3s ease
}
.show-more-btn:hover,.btn-hero:hover{
  background-position:100% 0
}
.btn-accent-green{
  background:linear-gradient(135deg,#43a047 0%,#66bb6a 50%,#43a047 100%)!important;
  background-size:200% 100%!important
}
.btn-accent-green:hover{background-position:100% 0!important}
.btn-whatsapp-gradient{
  background:linear-gradient(135deg,#128c7e 0%,#25d366 50%,#128c7e 100%)!important;
  background-size:200% 100%!important
}
.btn-whatsapp-gradient:hover{background-position:100% 0!important}

/* ── Cards galerie : overlay pink au survol ─────────────────── */
.gallery-card-clickable::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(233,30,99,.18) 0%,transparent 50%);
  opacity:0;transition:opacity .3s ease;z-index:1;pointer-events:none;border-radius:var(--radius)
}
.gallery-card-clickable:hover::before{opacity:1}
@media(hover:none){.gallery-card-clickable::before{display:none}}

/* ── Section about : fond subtil ────────────────────────────── */
.about-section{
  background:linear-gradient(165deg,#fdf6f9 0%,#fff3f8 50%,#f8f9fa 100%)
}

/* ── Footer : top-border gradient ───────────────────────────── */
footer{
  border-top:3px solid transparent;
  border-image:linear-gradient(90deg,#e91e63,#ff4081,#ffc107,#ff4081,#e91e63) 1
}

/* ── Review card : badge étoiles stylisé ────────────────────── */
.review-rating .fa-star.text-warning{
  filter:drop-shadow(0 1px 3px rgba(255,193,7,.5))
}

/* ── Scroll-to-top : gradient ────────────────────────────────── */
.scroll-top{
  background:linear-gradient(135deg,#e91e63,#ff4081)
}

/* ── WhatsApp float : ombre plus visible ─────────────────────── */
.whatsapp-float{
  box-shadow:0 6px 24px rgba(37,211,102,.55),0 2px 8px rgba(0,0,0,.15)
}

/* ── Formulaires : focus ring rose ──────────────────────────── */
.form-control:focus,.form-select:focus{
  border-color:var(--primary)!important;
  box-shadow:0 0 0 3px rgba(233,30,99,.18)!important
}

/* ── Section eyebrow pop (animation légère) ─────────────────── */
.section-eyebrow{
  transition:letter-spacing .3s ease
}

/* ── Carrousel sparkle plus grands sur desktop ──────────────── */
@media(min-width:992px){
  .hero-sparkle:nth-child(2){width:16px;height:16px}
  .hero-sparkle:nth-child(6){width:13px;height:13px}
}

/* ── Correction: contact icon-circle couleur blanche ─────────── */
.contact-icon-circle i{color:#fff!important}

/* ── Transitions de page : fade-in au chargement ──────────────── */
@keyframes pageFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
main,section:first-of-type{animation:pageFadeIn .45s ease-out both}
.data-saver main,.data-saver section:first-of-type{animation:none}

/* ════════════════════════════════════════════════════════════════
   HAVANA GOLD LUXE — v3 Design System
   Palette : Fuchsia #e91e63 · Gold #ffc107 · Deep Wine #880e4f
   Contraintes : CSS pur, data-saver respecté, pas de JS
   ════════════════════════════════════════════════════════════════ */

/* ── Tokens luxe ─────────────────────────────────────────────── */
:root{
  --gold:#ffc107;
  --gold-light:#ffe082;
  --gold-dark:#f9a825;
  --wine:#880e4f;
  --wine-deep:#6a0536;
  --glass-bg:rgba(255,255,255,.72);
  --glass-border:rgba(255,255,255,.55);
  --glass-shadow:0 8px 32px rgba(136,14,79,.12);
  --luxury-radius:22px;
  --gold-gradient:linear-gradient(135deg,#f9a825 0%,#ffc107 45%,#ffe082 70%,#f9a825 100%);
  --wine-gradient:linear-gradient(150deg,#880e4f 0%,#c2185b 60%,#e91e63 100%)
}

/* ── Navbar : profondeur wine + liseret or ───────────────────── */
.navbar-modern{
  background:linear-gradient(135deg,#ad1457 0%,#e91e63 55%,#ff5b8d 100%)!important;
  box-shadow:0 4px 28px rgba(136,14,79,.4),inset 0 -1px 0 rgba(255,193,7,.35)!important
}
.navbar-brand-text{
  font-size:1.45rem;
  letter-spacing:.02em;
  text-shadow:0 1px 8px rgba(0,0,0,.25),0 0 20px rgba(255,193,7,.18)
}

/* ── Hero : halo lumineux central + orbes décoratifs ─────────── */
.hero-section{
  background:linear-gradient(150deg,#e91e63 0%,#ad1457 30%,#880e4f 65%,#6a0536 100%)
}
/* Orbe lumineux central (CSS radial) */
.hero-section::after{
  content:'';
  position:absolute;top:35%;left:50%;
  transform:translate(-50%,-50%);
  width:min(600px,110vw);height:min(400px,80vw);
  background:radial-gradient(ellipse at center,rgba(255,193,7,.12) 0%,rgba(255,64,129,.08) 40%,transparent 70%);
  pointer-events:none;z-index:1
}
.hero-content{z-index:3}

/* ── Hero badge : or scintillant ────────────────────────────── */
.hero-badge{
  display:inline-block;
  background:linear-gradient(90deg,rgba(255,193,7,.22),rgba(255,224,130,.35),rgba(255,193,7,.22));
  border:1px solid rgba(255,193,7,.45);
  border-radius:999px;
  padding:.28rem 1rem;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.14em;
  color:rgba(255,255,255,.95);
  text-transform:uppercase;
  backdrop-filter:blur(4px)
}

/* ── Section eyebrow : shimmer or ───────────────────────────── */
@keyframes eyebrowShimmer{
  0%,100%{background-position:0% center}
  50%{background-position:100% center}
}
.section-eyebrow{
  background:linear-gradient(90deg,rgba(233,30,99,.12),rgba(255,193,7,.18),rgba(233,30,99,.12))!important;
  background-size:200% auto!important;
  border:1px solid rgba(255,193,7,.25);
  color:#b5093c!important;
  font-weight:800!important
}
.data-saver .section-eyebrow{animation:none!important}

/* ── Section titles : lettre-espacement + sous-ligne or ─────── */
.section-title{
  letter-spacing:-.01em;
  font-weight:800!important
}
.section-title::after{
  background:linear-gradient(90deg,#e91e63,#ffc107,#e91e63)!important;
  background-size:200% auto;
  animation:eyebrowShimmer 4s ease infinite
}
.data-saver .section-title::after{animation:none}

/* ── Service cards : glassmorphism luxe ──────────────────────── */
.service-card{
  background:var(--glass-bg);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border)!important;
  border-radius:var(--luxury-radius)!important;
  /* Ligne or en haut via inset shadow — respecte border-radius */
  box-shadow:var(--glass-shadow),inset 0 3px 0 rgba(255,193,7,.7)!important
}
.service-card:hover{
  box-shadow:0 24px 56px rgba(136,14,79,.18),inset 0 3px 0 rgba(255,193,7,.9)!important
}
.data-saver .service-card{
  backdrop-filter:none;-webkit-backdrop-filter:none;
  background:#fff!important;
  box-shadow:var(--shadow),inset 0 3px 0 rgba(255,193,7,.6)!important
}

/* ── Service prix : badge or ─────────────────────────────────── */
.service-price{
  display:inline-block;
  margin:.5rem 1rem 1.25rem;
  background:linear-gradient(135deg,rgba(255,193,7,.18),rgba(249,168,37,.12));
  border:1px solid rgba(255,193,7,.4);
  border-radius:999px;
  padding:.28rem .9rem;
  color:#7a5800;
  font-weight:800;
  font-size:1rem;
  letter-spacing:.02em
}

/* ── Gallery cards : zoom + overlay éditorial ────────────────── */
.gallery-card{
  border-radius:var(--luxury-radius)!important;
  overflow:hidden
}
.gallery-card-clickable::after{
  content:'🔍';
  background:linear-gradient(135deg,rgba(136,14,79,.7),rgba(233,30,99,.5))!important;
  border-radius:8px!important;
  width:32px!important;height:32px!important;
  font-size:.9rem!important;
  box-shadow:0 2px 8px rgba(0,0,0,.3)
}

/* ── Review cards : éditorial magazine ───────────────────────── */
.review-card{
  background:linear-gradient(165deg,#fff 0%,#fff9fc 100%);
  border:1px solid rgba(233,30,99,.12)!important;
  border-top:3px solid var(--gold)!important;
  border-radius:var(--luxury-radius)!important;
  box-shadow:0 8px 28px rgba(136,14,79,.08)!important
}
.review-card:hover{
  box-shadow:0 20px 48px rgba(136,14,79,.15)!important;
  border-color:rgba(255,193,7,.45)!important
}
/* Guillemet décoratif redesigné */
.review-card::before{
  content:'\201C';
  top:-4px!important;right:14px!important;
  font-size:6rem!important;
  background:var(--gold-gradient);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  opacity:.55!important
}
.review-author{
  font-weight:800;
  font-size:.95rem;
  color:var(--wine);
  background:var(--wine-gradient);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text
}
.data-saver .review-author{
  -webkit-text-fill-color:var(--primary);
  background:none
}

/* ── Section "Sobre Nosotros" : wine accent ──────────────────── */
.about-section{
  background:linear-gradient(165deg,#fff6fa 0%,#fce4ec 40%,#fff0f5 100%)!important;
  position:relative;overflow:hidden
}
.about-section::before{
  content:'';
  position:absolute;bottom:-80px;right:-80px;
  width:280px;height:280px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,193,7,.18) 0%,transparent 70%);
  pointer-events:none
}
.section-title-highlight{
  color:var(--wine);
  background:var(--wine-gradient);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-size:clamp(1.4rem,3.5vw,2rem);
  line-height:1.2
}
.data-saver .section-title-highlight{
  -webkit-text-fill-color:var(--primary);
  background:none
}

/* ── FAQ : cartes plus luxueuses ─────────────────────────────── */
.faq-item{
  border-radius:18px!important;
  box-shadow:0 4px 18px rgba(233,30,99,.05)!important
}
.faq-item.open{
  box-shadow:0 12px 36px rgba(136,14,79,.14)!important;
  border-color:rgba(255,193,7,.45)!important
}
.faq-question-index{
  background:linear-gradient(135deg,#fce4ec,#ffd6e7)!important;
  color:#880e4f!important;
  font-weight:900!important
}
.faq-item.open .faq-question-index{
  background:var(--wine-gradient)!important;
  color:#fff!important
}
.faq-side-cta{
  background:linear-gradient(135deg,#880e4f,#c2185b,#e91e63)!important;
  font-weight:800
}

/* ── Contact section : plus dramatique ───────────────────────── */
.contact-section{
  background:linear-gradient(150deg,#6a0536 0%,#880e4f 35%,#c2185b 70%,#e91e63 100%)!important;
  position:relative;overflow:hidden
}
.contact-section::before{
  content:'';
  position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,193,7,.15) 0%,transparent 65%);
  pointer-events:none
}
.contact-section::after{
  content:'';
  position:absolute;bottom:-80px;left:-60px;
  width:280px;height:280px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 70%);
  pointer-events:none
}
.contact-section .container{position:relative;z-index:2}
.contact-item h5{
  font-weight:800;
  letter-spacing:.02em;
  font-size:1.05rem
}
.contact-item p{
  opacity:.88;
  font-size:.95rem
}

/* ── Instagram grid : bordure or au survol ───────────────────── */
.insta-post{
  border-radius:10px;overflow:hidden
}
.insta-post::after{
  content:'';
  position:absolute;inset:0;
  border:2px solid transparent;
  border-radius:10px;
  transition:border-color .25s ease
}
.insta-post:hover::after{
  border-color:rgba(255,193,7,.7)
}

/* ── Boutons CTA : effet reflet or ──────────────────────────── */
.show-more-btn,.btn-hero{
  font-weight:700;
  letter-spacing:.02em;
  box-shadow:0 6px 20px rgba(233,30,99,.32)
}
.show-more-btn:hover,.btn-hero:hover{
  box-shadow:0 10px 28px rgba(233,30,99,.42),0 0 0 1px rgba(255,193,7,.35)
}

/* ── Video cards : poster plus stylisé ───────────────────────── */
.video-card{
  border-radius:var(--luxury-radius)!important
}
.video-preview-container{
  background:linear-gradient(150deg,#6a0536,#880e4f,#ad1457)!important;
  border-radius:var(--luxury-radius) var(--luxury-radius) 0 0
}
.video-play-icon{
  filter:drop-shadow(0 2px 12px rgba(255,193,7,.6));
  color:#fff!important
}

/* ── Footer : riche et profond ───────────────────────────────── */
footer{
  background:linear-gradient(165deg,#1a0a14 0%,#2c0d1e 40%,#1e0a10 100%)!important
}
footer h5{
  color:var(--gold)!important;
  font-weight:800;
  letter-spacing:.04em;
  text-shadow:0 0 12px rgba(255,193,7,.25)
}
.social-links a{
  background:linear-gradient(135deg,#880e4f,#e91e63)!important;
  box-shadow:0 4px 12px rgba(136,14,79,.4)
}
.social-links a:hover{
  background:linear-gradient(135deg,#ffc107,#f9a825)!important;
  box-shadow:0 6px 18px rgba(255,193,7,.45)!important;
  transform:translateY(-4px)!important
}

/* ── About image frame : liseret or ─────────────────────────── */
.about-image-wrap::before{
  border-color:rgba(255,193,7,.45)!important;
  border-width:2px!important
}
.about-image{
  box-shadow:0 16px 48px rgba(136,14,79,.22)!important
}

/* ── Hero logo : halo or pulsé ───────────────────────────────── */
@keyframes heroLogoGlow{
  0%,100%{
    filter:drop-shadow(0 0 18px rgba(255,193,7,.22)) drop-shadow(0 0 40px rgba(233,30,99,.15));
    transform:scale(1)
  }
  50%{
    filter:drop-shadow(0 0 32px rgba(255,193,7,.42)) drop-shadow(0 0 60px rgba(233,30,99,.22));
    transform:scale(1.015)
  }
}
.hero-logo-image{
  animation:heroLogoGlow 5s ease-in-out infinite!important
}
.data-saver .hero-logo-image{animation:none!important;filter:none!important}

/* ── Stat items hero : séparateur or ─────────────────────────── */
.hero-stat-num{
  color:#fff;
  text-shadow:0 0 20px rgba(255,255,255,.3)
}
.hero-stat-item+.hero-stat-item{
  border-left-color:rgba(255,193,7,.4)!important
}

/* ── Design du mois : badge or ───────────────────────────────── */
.design-month-badge{
  background:linear-gradient(135deg,#f9a825,#ffc107,#ffe082)!important;
  color:#5a3900!important;
  font-weight:800;
  box-shadow:0 4px 16px rgba(255,193,7,.4)
}

/* ── Page hero (sous-pages) : titre gras ─────────────────────── */
.page-hero h1{
  font-weight:800;
  letter-spacing:-.01em;
  text-shadow:0 2px 16px rgba(0,0,0,.2)
}

/* ── Scroll-to-top : gold gradient ──────────────────────────── */
.scroll-top:hover{
  background:linear-gradient(135deg,#f9a825,#ffc107)!important;
  color:#5a3900!important
}

/* ── WhatsApp float : glass luxury ──────────────────────────── */
.whatsapp-float{
  background:linear-gradient(135deg,#1a8c3e,#25d366)!important;
  box-shadow:0 8px 28px rgba(37,211,102,.5),0 2px 8px rgba(0,0,0,.2)!important
}

/* ── Responsive adjustments luxe ─────────────────────────────── */
@media(max-width:768px){
  .review-card::before{font-size:4.5rem!important}
  .service-price{margin:.35rem .75rem 1rem;font-size:.92rem}
}
@media(max-width:479px){
  .hero-badge{font-size:.72rem;padding:.22rem .7rem}
  .section-eyebrow{font-size:.68rem}
}

/* ── data-saver : désactiver glassmorphism lourd ─────────────── */
.data-saver .service-card,
.data-saver .gallery-card,
.data-saver .review-card{
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  background:#fff!important
}
.data-saver .section-title::after,
.data-saver .section-eyebrow{animation:none!important}
.data-saver .review-author{
  background:none!important;
  -webkit-text-fill-color:var(--primary)!important
}
.data-saver .section-title-highlight{
  background:none!important;
  -webkit-text-fill-color:var(--wine)!important
}
.data-saver .hero-logo-image{
  animation:none!important;filter:none!important
}
.data-saver .review-card::before{display:none}

/* ============================================================
   LUXURY CUBAN GLAM v3.0
   Zero external resources. Pure CSS magic.
   Inspired by: polished nails catching Cuban sunlight
   ============================================================ */

/* === GOLDEN SHIMMER VARIABLES === */
:root {
    --gold: #d4a853;
    --gold-light: #f0d48a;
    --gold-glow: rgba(212,168,83,0.35);
    --rose-deep: #880e4f;
    --rose-hot: #e91e63;
    --rose-soft: #fce4ec;
    --pearl: #fdf6f0;
    --onyx: #1a0a12;
    --glass: rgba(255,255,255,0.06);
    --glass-border: rgba(255,255,255,0.12);
}

/* === BODY TEXTURE — subtle noise grain === */
body::after {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 9998;
    mix-blend-mode: overlay;
}

/* === HERO — Cinematic entrance === */
.hero-section {
    background: linear-gradient(160deg, #4a0028 0%, #880e4f 35%, #ad1457 55%, #c2185b 75%, #e91e63 100%) !important;
    position: relative;
    overflow: hidden;
}

/* Animated light sweep across hero */
.hero-section::before {
    content: '';
    position: absolute;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background:
        radial-gradient(ellipse at 25% 30%, rgba(212,168,83,0.2), transparent 45%),
        radial-gradient(ellipse at 75% 70%, rgba(255,255,255,0.08), transparent 40%),
        radial-gradient(circle at 50% 50%, rgba(233,30,99,0.15), transparent 60%);
    animation: hero-light 12s ease-in-out infinite;
    pointer-events: none;
}
@keyframes hero-light {
    0%, 100% { transform: translate(0,0) rotate(0deg); opacity: .7; }
    33% { transform: translate(3%,-3%) rotate(2deg); opacity: 1; }
    66% { transform: translate(-2%,2%) rotate(-1deg); opacity: .8; }
}

/* Hero title — gold text with shimmer */
.hero-title {
    background: linear-gradient(135deg, #fff 0%, var(--gold-light) 40%, #fff 50%, var(--gold-light) 60%, #fff 100%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: gold-shimmer 4s linear infinite;
    text-shadow: none;
}
@keyframes gold-shimmer {
    0% { background-position: 0% center; }
    100% { background-position: 200% center; }
}

/* Hero badge — glass pill */
.hero-badge {
    background: rgba(255,255,255,0.12) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 50px;
    padding: 8px 20px;
    font-size: 0.85rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--gold-light);
}

/* Hero stats — glass cards */
.hero-stat-item {
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 14px;
    padding: 14px 18px;
}
.hero-stat-num {
    color: var(--gold-light) !important;
    font-weight: 800;
}

/* Hero sparkles — floating diamonds */
.hero-sparkle {
    position: absolute;
    width: 6px; height: 6px;
    background: var(--gold-light);
    border-radius: 1px;
    transform: rotate(45deg);
    opacity: 0;
    animation: sparkle-float 6s ease-in-out infinite;
    pointer-events: none;
}
.hero-sparkle:nth-child(1) { top: 15%; left: 10%; animation-delay: 0s; }
.hero-sparkle:nth-child(2) { top: 25%; right: 15%; animation-delay: .8s; width: 4px; height: 4px; }
.hero-sparkle:nth-child(3) { top: 60%; left: 20%; animation-delay: 1.6s; width: 5px; height: 5px; }
.hero-sparkle:nth-child(4) { top: 40%; right: 25%; animation-delay: 2.4s; width: 3px; height: 3px; }
.hero-sparkle:nth-child(5) { bottom: 20%; left: 35%; animation-delay: 3.2s; }
.hero-sparkle:nth-child(6) { top: 35%; left: 65%; animation-delay: 4s; width: 4px; height: 4px; }
.hero-sparkle:nth-child(7) { bottom: 30%; right: 10%; animation-delay: 1s; width: 5px; height: 5px; }
.hero-sparkle:nth-child(8) { top: 70%; left: 50%; animation-delay: 2s; width: 3px; height: 3px; }
@keyframes sparkle-float {
    0%, 100% { opacity: 0; transform: rotate(45deg) scale(0.5) translateY(0); }
    20% { opacity: 0.9; transform: rotate(45deg) scale(1.2) translateY(-8px); }
    50% { opacity: 0.5; transform: rotate(225deg) scale(1) translateY(-16px); }
    80% { opacity: 0.8; transform: rotate(45deg) scale(0.8) translateY(-4px); }
}

/* Hero wave — refined shape */
.hero-wave-sep svg { filter: drop-shadow(0 -4px 12px rgba(136,14,79,0.3)); }

/* === BUTTONS — Luxe feel === */
.btn-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--gold), var(--gold-light)) !important;
    color: var(--onyx) !important;
    border: none;
    border-radius: 50px;
    padding: 14px 32px;
    font-weight: 700;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 20px var(--gold-glow);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-hero:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 32px var(--gold-glow), 0 0 0 2px rgba(212,168,83,0.3);
}
.btn-hero::after {
    content: '';
    position: absolute;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: linear-gradient(45deg, transparent 30%, rgba(255,255,255,0.4) 50%, transparent 70%);
    transform: translateX(-100%);
    transition: none;
}
.btn-hero:hover::after {
    animation: btn-shine 0.6s ease forwards;
}
@keyframes btn-shine {
    100% { transform: translateX(100%); }
}

/* === SECTION HEADERS — Editorial style === */
.section-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 20px;
    background: linear-gradient(135deg, rgba(136,14,79,0.08), rgba(212,168,83,0.08));
    border-radius: 50px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--rose-deep);
    border: 1px solid rgba(136,14,79,0.12);
}
.section-eyebrow::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--gold);
    border-radius: 50%;
    animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
    0%, 100% { opacity: .5; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.3); }
}

.section-title {
    position: relative;
}
.section-header-center .section-title::after {
    content: '';
    display: block;
    width: 60px; height: 3px;
    background: linear-gradient(90deg, var(--rose-hot), var(--gold));
    border-radius: 3px;
    margin: 12px auto 0;
}

/* === SERVICE CARDS — Elevated luxury === */
.service-card {
    position: relative;
    background: #fff;
    border-radius: 20px;
    border: 1px solid rgba(136,14,79,0.06);
    overflow: hidden;
    transition: all 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
.service-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--rose-hot), var(--gold), var(--rose-hot));
    background-size: 200% 100%;
    opacity: 0;
    transition: opacity 0.4s;
}
.service-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 24px 48px rgba(136,14,79,0.12), 0 0 0 1px rgba(136,14,79,0.08);
}
.service-card:hover::before {
    opacity: 1;
    animation: gradient-slide 2s linear infinite;
}
@keyframes gradient-slide {
    0% { background-position: 0% 0%; }
    100% { background-position: 200% 0%; }
}

.service-price {
    background: linear-gradient(135deg, var(--rose-deep), var(--rose-hot));
    color: #fff;
    display: inline-block;
    padding: 6px 18px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.9rem;
}

.service-card-btn {
    background: linear-gradient(135deg, var(--gold), var(--gold-light)) !important;
    color: var(--onyx) !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    padding: 10px 24px !important;
    transition: all 0.3s ease !important;
}
.service-card-btn:hover {
    box-shadow: 0 6px 20px var(--gold-glow) !important;
    transform: translateY(-2px) !important;
}

/* === GALLERY — Masonry-like feel === */
.gallery-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.gallery-card::after {
    content: '\2728';
    position: absolute;
    bottom: 12px; right: 12px;
    font-size: 1.4rem;
    opacity: 0;
    transform: scale(0.5) rotate(-20deg);
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}
.gallery-card:hover {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 16px 40px rgba(136,14,79,0.15);
}
.gallery-card:hover::after {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}
.gallery-card img {
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.gallery-card:hover img {
    transform: scale(1.1);
}

/* === REVIEW CARDS — Testimonial luxury === */
.review-card {
    background: #fff;
    border-radius: 20px;
    border: 1px solid rgba(136,14,79,0.06);
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
}
.review-card::before {
    content: '\201C';
    position: absolute;
    top: -10px; left: 16px;
    font-size: 5rem;
    font-family: Georgia, serif;
    color: rgba(136,14,79,0.06);
    line-height: 1;
    pointer-events: none;
}
.review-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(136,14,79,0.1);
    border-color: rgba(212,168,83,0.3);
}
.review-rating .fa-star.text-warning {
    color: var(--gold) !important;
    filter: drop-shadow(0 1px 2px rgba(212,168,83,0.4));
}

/* === CONTACT SECTION — Dark luxury === */
.contact-section {
    background: linear-gradient(160deg, #1a0a12 0%, #3d0c27 40%, #4a148c 100%) !important;
    position: relative;
    overflow: hidden;
}
.contact-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 80%, rgba(212,168,83,0.1), transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(233,30,99,0.08), transparent 50%);
    pointer-events: none;
}
.contact-section .section-title { color: #fff; }
.contact-section .section-title::after { margin-left: auto; margin-right: auto; }
.contact-section .section-eyebrow {
    color: var(--gold-light);
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.15);
}

.contact-item {
    background: rgba(255,255,255,0.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 20px;
    padding: 32px 24px;
    text-align: center;
    color: #fff;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.contact-item:hover {
    background: rgba(255,255,255,0.12);
    transform: translateY(-6px);
    border-color: var(--gold-glow);
    box-shadow: 0 16px 40px rgba(0,0,0,0.2);
}
.contact-item h5 { color: var(--gold-light) !important; font-weight: 700; }
.contact-icon {
    width: 60px; height: 60px;
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 18px;
    font-size: 1.3rem;
    color: var(--onyx);
    box-shadow: 0 8px 24px var(--gold-glow);
    transform: rotate(-5deg);
    transition: transform 0.3s ease;
}
.contact-item:hover .contact-icon {
    transform: rotate(0deg) scale(1.1);
}

/* === FAQ — Refined accordion === */
.faq-item {
    border: 1px solid rgba(136,14,79,0.08);
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.3s ease;
    background: #fff;
}
.faq-item:hover {
    box-shadow: 0 4px 20px rgba(136,14,79,0.06);
}
.faq-item.open {
    border-color: var(--rose-hot);
    box-shadow: 0 8px 32px rgba(233,30,99,0.1);
}
.faq-question-index {
    background: linear-gradient(135deg, var(--rose-hot), var(--gold));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 800;
}

/* === DESIGN DU MOIS — Spotlight === */
.design-month-section {
    background: linear-gradient(135deg, var(--pearl) 0%, #fff 50%, var(--rose-soft) 100%) !important;
}
.design-month-badge {
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    color: var(--onyx);
    padding: 6px 18px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.5px;
    display: inline-block;
}
.design-featured-img {
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(136,14,79,0.15);
    transition: transform 0.5s ease;
}
.design-featured-img:hover {
    transform: scale(1.03) rotate(-1deg);
}

/* === ABOUT — Warm and personal === */
.about-image-wrap {
    position: relative;
}
.about-image-wrap::before {
    content: '';
    position: absolute;
    inset: -8px;
    background: linear-gradient(135deg, var(--rose-hot), var(--gold));
    border-radius: 28px;
    z-index: -1;
    opacity: 0.2;
    animation: about-glow 4s ease-in-out infinite;
}
@keyframes about-glow {
    0%, 100% { opacity: .15; transform: scale(1); }
    50% { opacity: .25; transform: scale(1.02); }
}
.about-image {
    border-radius: 22px;
    box-shadow: 0 16px 40px rgba(136,14,79,0.12);
}

/* === SHOW MORE BUTTON === */
.show-more-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 28px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.9rem;
    border: 2px solid var(--rose-hot);
    color: var(--rose-hot);
    background: transparent;
    transition: all 0.35s ease;
    cursor: pointer;
    text-decoration: none;
}
.show-more-btn:hover {
    background: var(--rose-hot);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(233,30,99,0.2);
}

/* === WHATSAPP FLOAT — Premium pulse === */
.whatsapp-float {
    box-shadow: 0 6px 24px rgba(37,211,102,0.3);
    transition: all 0.3s ease;
}
.whatsapp-float:hover {
    transform: scale(1.1) translateY(-4px);
    box-shadow: 0 10px 40px rgba(37,211,102,0.4);
}
@keyframes whatsapp-pulse {
    0%, 100% { box-shadow: 0 4px 16px rgba(37,211,102,0.3), 0 0 0 0 rgba(37,211,102,0.3); }
    50% { box-shadow: 0 4px 16px rgba(37,211,102,0.3), 0 0 0 12px rgba(37,211,102,0); }
}
.whatsapp-float { animation: whatsapp-pulse 2.5s ease-in-out infinite; }

/* === REVEAL ANIMATIONS === */
.reveal {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}
.reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Staggered reveals for grid items */
.reveal:nth-child(2) { transition-delay: 0.1s; }
.reveal:nth-child(3) { transition-delay: 0.2s; }
.reveal:nth-child(4) { transition-delay: 0.15s; }
.reveal:nth-child(5) { transition-delay: 0.25s; }
.reveal:nth-child(6) { transition-delay: 0.2s; }

/* === PAGE LOAD BAR — Gold streak === */
#page-load-bar {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 3px;
    background: linear-gradient(90deg, var(--rose-hot), var(--gold), var(--rose-hot));
    background-size: 200% 100%;
    animation: loadbar 1.2s ease-in-out infinite;
    z-index: 9999;
    opacity: 0;
    transition: opacity 0.3s;
}
@keyframes loadbar { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
body.loading #page-load-bar { opacity: 1; }

/* === INSTAGRAM GRID — Hover reveal === */
.insta-post {
    border-radius: 14px;
    overflow: hidden;
    transition: transform 0.4s ease;
}
.insta-post:hover {
    transform: scale(1.05);
    z-index: 2;
}
.insta-overlay {
    background: linear-gradient(135deg, rgba(136,14,79,0.7), rgba(212,168,83,0.5)) !important;
}

/* === FOOTER — Dark elegance === */
footer {
    background: linear-gradient(180deg, var(--onyx), #0d0509) !important;
}
footer h5 { color: var(--gold-light) !important; }
footer .social-links a {
    transition: all 0.3s ease;
}
footer .social-links a:hover {
    transform: translateY(-4px) scale(1.15);
    color: var(--gold-light) !important;
}

/* === NAVBAR — Glass on scroll === */
.navbar.scrolled {
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    background: rgba(26,10,18,0.85) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.15);
}

/* === VIDEO CARDS === */
.video-card {
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(136,14,79,0.06);
    transition: all 0.4s ease;
    background: #fff;
}
.video-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 48px rgba(136,14,79,0.12);
}
.video-play-overlay {
    background: radial-gradient(circle, rgba(136,14,79,0.5), transparent 70%) !important;
}
.video-play-icon {
    filter: drop-shadow(0 4px 12px rgba(0,0,0,0.3));
    transition: transform 0.3s ease;
}
.video-card:hover .video-play-icon {
    transform: scale(1.2);
}

/* === CUSTOM SCROLLBAR === */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--pearl); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--rose-hot), var(--gold));
    border-radius: 8px;
}
::-webkit-scrollbar-thumb:hover { background: var(--rose-deep); }

/* === SELECTION COLOR === */
::selection {
    background: var(--rose-hot);
    color: #fff;
}

/* === PRINT === */
@media print {
    .whatsapp-float, footer, .hero-section, #page-load-bar,
    .hero-sparkle, body::after { display: none !important; }
    body { font-size: 12pt; color: #000; }
    .service-card, .review-card { break-inside: avoid; page-break-inside: avoid; }
}

/* === REDUCED MOTION === */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
    .reveal { opacity: 1; transform: none; }
}

/* === LOGO CIRCLE — glow effect === */
.hero-logo-image {
    border-radius: 50%;
    box-shadow: 0 0 40px rgba(212,168,83,0.3), 0 0 80px rgba(212,168,83,0.15);
    animation: logo-glow 4s ease-in-out infinite;
}
@keyframes logo-glow {
    0%, 100% { box-shadow: 0 0 40px rgba(212,168,83,0.3), 0 0 80px rgba(212,168,83,0.15); }
    50% { box-shadow: 0 0 50px rgba(212,168,83,0.45), 0 0 100px rgba(212,168,83,0.2); }
}
.about-image {
    border-radius: 50% !important;
    box-shadow: 0 16px 48px rgba(136,14,79,0.15), 0 0 30px rgba(212,168,83,0.1);
}
