/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --carbon:#0a0a0a;--gun:#141414;--surface:#181818;--surface2:#1e1e1e;
  --red:#C8102E;--red2:#e8152f;--bone:#f0f0ee;
  --muted:rgba(255,255,255,0.38);--muted2:rgba(255,255,255,0.18);
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --fd:'Barlow Condensed',sans-serif;--fb:'Barlow',sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--carbon);color:#fff;font-family:var(--fb);font-weight:300;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul{list-style:none}
input,select,textarea,button{font-family:var(--fb)}
.red{color:var(--red)}

/* ── GLOBAL STEAM CANVAS ── */
#steamCanvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}

/* ── NAVBAR ── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .4s var(--ease),backdrop-filter .4s}
#navbar.scrolled{background:rgba(10,10,10,.92);backdrop-filter:blur(12px);border-bottom:.5px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--fd);font-size:18px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center}
.logo-t{color:#fff}.logo-o{color:var(--red)}.logo-ro{color:#fff}.logo-gap{width:12px}.logo-steam{color:#fff}
.nav-links{display:flex;gap:28px}
.nav-link{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .2s;font-weight:400}
.nav-link:hover{color:#fff}
.nav-cta{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;background:var(--red);color:#fff;padding:10px 22px;border-radius:2px;transition:background .2s}
.nav-cta:hover{background:var(--red2)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:1.5px;background:#fff;transition:transform .3s,opacity .3s}
.hamburger.open span:first-child{transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:last-child{transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:0;background:var(--gun);border-top:.5px solid var(--border);padding:8px 0 16px}
.mobile-menu a{padding:14px 28px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border-bottom:.5px solid var(--border)}
.mobile-menu .mobile-cta{margin:12px 28px 0;background:var(--red);color:#fff;text-align:center;padding:12px;border-radius:2px;border:none}

/* ── HERO ── */
#hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--carbon)}
#globeCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:all;z-index:2;cursor:grab}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(200,16,46,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(200,16,46,.04) 1px,transparent 1px);background-size:52px 52px;z-index:1}
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 15% 70%,rgba(200,16,46,.08) 0%,transparent 70%),linear-gradient(to top,#0a0a0a 0%,transparent 50%),linear-gradient(to right,#0a0a0a 0%,transparent 45%);z-index:3;pointer-events:none}
.hero-badge{position:absolute;top:88px;left:50%;transform:translateX(-50%);z-index:8;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.03);border:.5px solid var(--border);border-radius:2px;padding:6px 16px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.badge-dot{width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.hero-content{position:relative;z-index:8;padding:0 48px 72px;max-width:640px;opacity:0;animation:heroIn 1s var(--ease) .3s forwards}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--red)}
.hero-h1{font-family:var(--fd);font-size:clamp(64px,8vw,96px);font-weight:600;line-height:.95;letter-spacing:-.01em;margin-bottom:20px;display:flex;flex-direction:column;gap:4px}
.h1-line{display:block;opacity:0;animation:lineIn .8s var(--ease) forwards}
.h1-line:nth-child(1){animation-delay:.5s}
.h1-line:nth-child(2){animation-delay:.65s;color:var(--red)}
.h1-line:nth-child(3){animation-delay:.8s;color:rgba(255,255,255,.2)}
@keyframes lineIn{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
.hero-sub{font-size:13px;color:var(--muted);margin-bottom:28px;letter-spacing:.04em;line-height:1.7}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;background:var(--red);color:#fff;font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:14px 28px;border-radius:2px;transition:background .2s,transform .2s}
.btn-primary:hover{background:var(--red2);transform:translateY(-2px)}


.hero-services-rail{position:absolute;right:48px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:4px;z-index:8}
.rail-pill{background:rgba(255,255,255,.03);border:.5px solid var(--border);border-radius:2px;padding:10px 16px;min-width:160px;cursor:pointer;transition:background .2s,border-color .2s}
.rail-pill:hover,.rail-pill.active{background:rgba(200,16,46,.12);border-color:rgba(200,16,46,.45)}
.pill-num{display:block;font-size:8px;letter-spacing:.18em;color:rgba(255,255,255,.22);text-transform:uppercase;margin-bottom:4px}
.rail-pill.active .pill-num{color:var(--red)}
.pill-name{font-size:11px;font-weight:500;color:rgba(255,255,255,.65)}
.rail-pill.active .pill-name{color:#fff}
.hero-scroll{position:absolute;bottom:36px;right:48px;display:flex;flex-direction:column;align-items:center;gap:6px;z-index:8}
.scroll-label{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18);writing-mode:vertical-rl}
.scroll-bar{width:.5px;height:36px;background:rgba(200,16,46,.5);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}

/* ── STATS ── */
#stats{background:var(--red);position:relative;z-index:10}
.stats-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:24px 0;text-align:center;border-right:.5px solid rgba(255,255,255,.2)}
.stat-item:last-child{border-right:none}
.stat-num{display:block;font-family:var(--fd);font-size:32px;font-weight:600;color:#fff;letter-spacing:-.02em;line-height:1}
.stat-label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:4px}

/* ── SECTION BASE ── */
.section-inner{max-width:1200px;margin:0 auto;padding:100px 48px}
.section-header{margin-bottom:56px}
.section-eyebrow{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.section-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--red)}
.section-title{font-family:var(--fd);font-size:clamp(40px,5vw,60px);font-weight:600;line-height:1;letter-spacing:-.01em;color:#fff}
.section-sub{font-size:14px;color:var(--muted);margin-top:12px;line-height:1.7}

/* ── SERVICES ── */
#services{background:var(--carbon)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.svc-card{position:relative;background:var(--gun);border:.5px solid var(--border);border-top:1.5px solid var(--red);border-radius:4px;padding:24px 20px 20px;transition:transform .22s var(--ease),border-top-color .2s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-5px);border-top-color:var(--red2)}
.svc-card.featured{border-top-color:var(--red2);background:#1a0c0e}
.svc-badge-featured{position:absolute;top:16px;right:16px;background:var(--red);color:#fff;font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:2px}
.svc-num{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.svc-title{font-family:var(--fd);font-size:22px;font-weight:600;color:#fff;margin-bottom:10px;letter-spacing:.02em}
.svc-desc{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:0;flex:0}

/* Accordion details */
.svc-details{overflow:hidden;max-height:0;transition:max-height .5s var(--ease),opacity .4s ease,margin .4s ease;opacity:0;margin-top:0}
.svc-details.open{max-height:300px;opacity:1;margin-top:14px}
.svc-features{display:flex;flex-direction:column;gap:6px}
.svc-features li{font-size:12px;color:rgba(255,255,255,.5);padding-left:14px;position:relative;line-height:1.4}
.svc-features li::before{content:'';position:absolute;left:0;top:7px;width:5px;height:1px;background:var(--red)}
.svc-toggle{margin-top:14px;background:transparent;border:none;color:rgba(255,255,255,.4);font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;gap:6px;padding:0;transition:color .2s}
.svc-toggle:hover{color:var(--red)}
.svc-toggle[aria-expanded="true"]{color:var(--red)}
.toggle-arrow{display:inline-block;transition:transform .4s var(--ease);font-style:normal}
.svc-toggle[aria-expanded="true"] .toggle-arrow{transform:rotate(180deg)}
.svc-footer{display:flex;align-items:center;justify-content:space-between;border-top:.5px solid var(--border);padding-top:16px;margin-top:auto;padding-top:16px;margin-top:16px}
.svc-price{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff;letter-spacing:.02em}
.svc-link{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);transition:letter-spacing .2s}
.svc-link:hover{letter-spacing:.16em}

/* ── TARIFS ── */
#tarifs{background:var(--gun);border-top:.5px solid var(--border);border-bottom:.5px solid var(--border)}
.tarif-block{background:var(--carbon);border:.5px solid var(--border);border-radius:6px;padding:36px 32px;margin-bottom:16px}
.tarif-block:last-child{margin-bottom:0}
.tarif-block-header{margin-bottom:28px}
.tarif-block-title{font-family:var(--fd);font-size:26px;font-weight:600;color:#fff;letter-spacing:.02em;margin-bottom:6px}
.tarif-block-sub{font-size:12px;color:var(--muted);letter-spacing:.04em}
.tier-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
.tier-card{background:var(--surface);border:.5px solid var(--border);border-radius:4px;padding:28px 22px;display:flex;flex-direction:column;position:relative}
.tier-card.recommended{border-color:rgba(200,16,46,.4);background:#1a0c0e}
.tier-rec-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:3px 12px;border-radius:0 0 4px 4px}
.tier-badge{font-family:var(--fd);font-size:13px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}
.tier-badge.silver{color:#c0c0c0}
.tier-badge.gold{color:#ffd700}
.tier-duration{font-size:11px;color:var(--muted);margin-bottom:16px;letter-spacing:.06em}
.tier-price{font-family:var(--fd);font-size:36px;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:20px;line-height:1}
.tier-features{flex:1;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.tier-features li{font-size:12px;color:rgba(255,255,255,.5);padding-left:14px;position:relative;line-height:1.4}
.tier-features li::before{content:'';position:absolute;left:0;top:7px;width:5px;height:1px;background:var(--red)}
.tier-cta{display:block;text-align:center;background:var(--red);color:#fff;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:11px;border-radius:2px;transition:background .2s}
.tier-card.recommended .tier-cta{background:var(--red2)}
.tier-cta:hover{background:var(--red2)}
.tint-grid{margin-bottom:20px;border:.5px solid var(--border);border-radius:4px;overflow:hidden}
.tint-row{display:grid;grid-template-columns:1.8fr 1.5fr 1fr 1fr;align-items:center;padding:14px 18px;border-bottom:.5px solid var(--border);gap:12px}
.tint-row:last-child{border-bottom:none}
.tint-row.header-row{background:var(--surface);padding:10px 18px}
.tint-row.header-row span{font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.tint-row.extraction-row{background:rgba(255,255,255,.02)}
.tint-type{font-size:13px;font-weight:500;color:#fff}
.tint-windows{font-size:12px;color:var(--muted)}
.tint-price{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff}
.tint-price.ceramic{color:#ffd700}
.polish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.polish-card{background:var(--surface);border:.5px solid var(--border);border-radius:4px;padding:22px 18px;position:relative}
.polish-type{font-family:var(--fd);font-size:16px;font-weight:600;color:#fff;margin-bottom:8px;letter-spacing:.04em}
.polish-price{font-family:var(--fd);font-size:28px;font-weight:700;color:var(--red);letter-spacing:-.02em;margin-bottom:12px;line-height:1}
.polish-desc{font-size:12px;color:var(--muted);line-height:1.6}
.polish-tag{display:inline-block;margin-top:10px;background:rgba(200,16,46,.12);color:var(--red);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:2px}
.tarif-devis{border-color:rgba(200,16,46,.2)}
.devis-text{font-size:14px;color:var(--muted);line-height:1.7;max-width:580px}
.tarif-note{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:rgba(200,16,46,.05);border:.5px solid rgba(200,16,46,.15);border-radius:4px;font-size:12px;color:rgba(255,255,255,.45);line-height:1.55;margin-top:0}
.tarif-note svg{flex-shrink:0;margin-top:1px}

/* ── PRO-SHOP ── */
#proshop{background:var(--carbon)}
.shop-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:32px}
.shop-card{background:var(--gun);border:.5px solid var(--border);border-radius:6px;overflow:hidden;transition:transform .22s var(--ease),border-color .2s;position:relative}
.shop-card:hover{transform:translateY(-4px);border-color:var(--border2)}
.shop-card.coming-soon{opacity:.7}
.shop-img-wrap{position:relative;aspect-ratio:1;background:var(--surface);display:flex;align-items:center;justify-content:center;overflow:hidden}
.shop-img-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px}
.shop-img-placeholder span{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.25)}
.coming-soon-overlay{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:2px}
.shop-info{padding:16px 14px}
.shop-category{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.shop-name{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff;margin-bottom:6px;letter-spacing:.02em}
.shop-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:14px}
.shop-footer{display:flex;align-items:center;justify-content:space-between;border-top:.5px solid var(--border);padding-top:12px}
.shop-price{font-family:var(--fd);font-size:20px;font-weight:600;color:#fff}
.shop-cta{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);transition:letter-spacing .2s}
.shop-cta:hover{letter-spacing:.16em}
.shop-notify{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.shop-cta-bar{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;background:var(--gun);border:.5px solid var(--border);border-radius:6px}
.shop-cta-bar p{font-size:14px;color:var(--muted)}

/* ── AUTRES SERVICES ── */
#autres{background:var(--gun);border-top:.5px solid var(--border)}
.autres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.autre-card{background:var(--carbon);border:.5px solid var(--border);border-radius:6px;padding:24px 20px;display:flex;align-items:flex-start;gap:16px;transition:transform .2s var(--ease),border-color .2s}
.autre-card:hover{transform:translateY(-3px);border-color:var(--border2)}
.autre-icon{width:40px;height:40px;background:rgba(200,16,46,.08);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.autre-content{flex:1}
.autre-title{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff;margin-bottom:8px;letter-spacing:.02em}
.autre-desc{font-size:12px;color:var(--muted);line-height:1.6}
.autre-price{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--red);white-space:nowrap;letter-spacing:-.01em;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.autre-eval{font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-family:var(--fb);font-weight:400}

/* ── BULL SECTION ── */
/* ── WHY ── */
#pourquoi{background:var(--gun);border-top:.5px solid var(--border)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.why-card{background:var(--carbon);border:.5px solid var(--border);border-radius:4px;padding:28px 22px;transition:transform .22s var(--ease)}
.why-card:hover{transform:translateY(-4px)}
.why-icon{width:44px;height:44px;background:rgba(200,16,46,.08);border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.why-title{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff;margin-bottom:10px;letter-spacing:.02em}
.why-desc{font-size:13px;color:var(--muted);line-height:1.65}

/* ── CONTACT ── */
#contact{background:var(--carbon)}
.contact-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.contact-sub{font-size:14px;color:var(--muted);margin-top:16px;margin-bottom:32px}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-item{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}
.contact-item a:hover{color:#fff}
.contact-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.form-group input,.form-group select,.form-group textarea{background:var(--surface);border:.5px solid rgba(255,255,255,.1);border-radius:2px;padding:12px 14px;color:#fff;font-size:13px;outline:none;transition:border-color .2s;appearance:none;-webkit-appearance:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.22)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:rgba(200,16,46,.5)}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='rgba(255,255,255,0.3)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-group select option{background:#1a1a1a;color:#fff}
.form-group textarea{resize:vertical;min-height:80px}
.btn-submit{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--red);color:#fff;font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:15px 28px;border-radius:2px;border:none;cursor:pointer;transition:background .2s,transform .2s;margin-top:4px}
.btn-submit:hover{background:var(--red2);transform:translateY(-2px)}
.btn-arrow{font-size:14px;transition:transform .2s}
.btn-submit:hover .btn-arrow{transform:translateX(4px)}
.form-success{display:none;align-items:center;gap:10px;font-size:13px;color:#97C459;padding:12px 16px;background:rgba(99,153,34,.08);border:.5px solid rgba(99,153,34,.25);border-radius:2px}
.form-success.show{display:flex}

/* ── FOOTER ── */
#footer{background:var(--gun);border-top:.5px solid var(--border);padding:48px 48px 36px}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.footer-logo{font-family:var(--fd);font-size:22px;font-weight:600;letter-spacing:.2em;display:flex;align-items:center}
.footer-tagline{font-size:11px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.footer-links{display:flex;gap:28px}
.footer-links a{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-copy{font-size:11px;color:rgba(255,255,255,.2);margin-top:8px}

/* ── AOS ── */
[data-aos]{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-aos].visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .shop-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .hero-services-rail,.hero-scroll{display:none}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .mobile-menu.open{display:flex}
  .hero-content{padding:0 24px 80px}
  .section-inner{padding:72px 24px}
  .services-grid,.shop-grid,.autres-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:.5px solid rgba(255,255,255,.2)}
  .stat-item:nth-child(odd){border-right:.5px solid rgba(255,255,255,.2)}
  .stat-item:last-child,.stat-item:nth-last-child(2){border-bottom:none}
  .form-row{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr;gap:48px}
  .tier-grid,.polish-grid{grid-template-columns:1fr}
  .tint-row{grid-template-columns:1fr 1fr;gap:6px}
  .tint-row.header-row{display:none}
  .tint-windows{display:none}
  .tarif-block{padding:24px 18px}
  .autre-card{flex-direction:column;gap:12px}
  .autre-price{align-items:flex-start}
  .shop-cta-bar{flex-direction:column;gap:16px;text-align:center}
  #footer{padding:40px 24px 28px}
}
@media(max-width:480px){
  .why-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .btn-primary,
}

/* ── HERO RAIL DETAIL PANEL ── */
/* ── HERO RAIL PILLS + DETAIL PANEL ── */
.rail-pill{
  position:relative;
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.02);
  border:.5px solid var(--border);
  border-radius:2px;
  padding:9px 14px;
  font-size:11px;
  color:var(--muted);
  letter-spacing:.04em;
  cursor:pointer;
  transition:background .22s var(--ease),border-color .22s var(--ease),color .22s var(--ease),transform .18s var(--ease);
  overflow:hidden;
  width:168px;
}
.rail-pill::before{
  /* Sweep highlight on hover */
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(200,16,46,0.12) 50%,transparent 100%);
  transform:translateX(-100%);
  transition:transform .5s var(--ease);
  pointer-events:none;
}
.rail-pill:hover::before{transform:translateX(100%)}
.rail-pill:hover{
  background:rgba(200,16,46,0.06);
  border-color:rgba(200,16,46,0.4);
  color:#fff;
  transform:translateX(-3px);
}
.rail-pill:active{transform:translateX(-3px) scale(.98)}
.rail-pill.active{
  background:rgba(200,16,46,0.12);
  border-color:var(--red);
  color:#fff;
  transform:translateX(-5px);
}
.rail-pill.active::after{
  /* Vertical indicator line on left */
  content:'';
  position:absolute;
  left:-1px;top:0;bottom:0;
  width:2px;
  background:var(--red);
  box-shadow:0 0 8px rgba(200,16,46,.8);
}
.pill-num{
  font-family:var(--fd);
  font-size:9px;
  font-weight:600;
  color:rgba(200,16,46,0.7);
  letter-spacing:.12em;
  transition:color .22s;
}
.rail-pill.active .pill-num,.rail-pill:hover .pill-num{color:var(--red)}
.pill-name{flex:1;font-size:11px;font-weight:500;letter-spacing:.02em}
.pill-arrow{
  margin-left:auto;
  font-size:14px;
  font-weight:400;
  color:rgba(200,16,46,0.45);
  line-height:1;
  transition:transform .25s var(--ease),color .22s,opacity .22s;
}
.rail-pill:hover .pill-arrow{color:var(--red);transform:translateX(4px)}
.rail-pill.active .pill-arrow{color:var(--red);transform:translateX(6px)}

/* ── Detail panel ── */
.rail-detail-panel{
  position:absolute;
  right:calc(168px + 24px);
  top:50%;
  transform:translateY(-50%) translateX(20px) scale(.96);
  width:300px;
  background:rgba(10,10,10,0.92);
  border:.5px solid rgba(200,16,46,0.4);
  border-radius:4px;
  padding:26px 22px 22px;
  z-index:10;
  opacity:0;
  pointer-events:none;
  transition:
    opacity .32s var(--ease),
    transform .4s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 20px 60px -10px rgba(0,0,0,.5),0 0 40px -10px rgba(200,16,46,.3);
}
.rail-detail-panel.open{
  opacity:1;
  pointer-events:all;
  transform:translateY(-50%) translateX(0) scale(1);
}
.rail-detail-panel::before{
  /* Corner HUD tick — top-right */
  content:'';
  position:absolute;
  top:8px;right:8px;
  width:14px;height:14px;
  border-top:1px solid var(--red);
  border-right:1px solid var(--red);
  opacity:.5;
  pointer-events:none;
}
.rail-detail-panel::after{
  /* Corner HUD tick — bottom-left */
  content:'';
  position:absolute;
  bottom:8px;left:8px;
  width:14px;height:14px;
  border-bottom:1px solid var(--red);
  border-left:1px solid var(--red);
  opacity:.5;
  pointer-events:none;
}
.rail-detail-close{
  position:absolute;top:10px;right:12px;
  background:none;border:none;
  color:rgba(255,255,255,0.3);
  font-size:14px;cursor:pointer;
  line-height:1;padding:4px 6px;
  transition:color .2s,transform .2s;
  z-index:2;
}
.rail-detail-close:hover{color:#fff;transform:rotate(90deg)}
.rail-detail-num{
  font-family:var(--fd);
  font-size:10px;letter-spacing:.22em;
  color:var(--red);text-transform:uppercase;
  margin-bottom:6px;font-weight:600;
  display:flex;align-items:center;gap:8px;
  transition:opacity .18s var(--ease);
}
.rail-detail-num::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(to right,rgba(200,16,46,0.4),transparent);
  max-width:120px;
}
.rail-detail-title{
  font-family:var(--fd);
  font-size:22px;font-weight:700;
  color:#fff;margin-bottom:4px;
  letter-spacing:-.005em;line-height:1.1;
  transition:opacity .22s var(--ease);
}
.rail-detail-price{
  font-family:var(--fd);
  font-size:15px;font-weight:500;
  color:var(--red);margin-bottom:14px;
  letter-spacing:.02em;
  transition:opacity .26s var(--ease);
}
.rail-detail-desc{
  font-size:12px;color:var(--muted);
  line-height:1.6;margin-bottom:14px;
  transition:opacity .3s var(--ease);
}
.rail-detail-list{
  display:flex;flex-direction:column;gap:7px;
  margin-bottom:18px;
  border-top:.5px solid rgba(200,16,46,0.15);
  padding-top:14px;
  transition:opacity .34s var(--ease);
}
.rail-detail-list li{
  font-size:11px;color:rgba(255,255,255,0.5);
  padding-left:16px;position:relative;line-height:1.45;
  letter-spacing:.01em;
  opacity:0;
  animation:listItemIn .4s var(--ease) forwards;
}
@keyframes listItemIn{
  0%{opacity:0;transform:translateX(-6px)}
  100%{opacity:1;transform:translateX(0)}
}
.rail-detail-list li::before{
  content:'';
  position:absolute;
  left:0;top:7px;
  width:8px;height:1px;
  background:var(--red);
}
.rail-detail-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--red);color:#fff;
  font-family:var(--fd);
  font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:12px 14px;
  text-align:center;border-radius:2px;
  transition:background .22s,transform .15s,box-shadow .22s;
  position:relative;
  overflow:hidden;
}
.rail-detail-cta:hover{
  background:var(--red2);
  transform:translateY(-1px);
  box-shadow:0 6px 16px -4px rgba(200,16,46,.5);
}
.rail-detail-cta:active{transform:translateY(0)}
.rail-detail-cta::after{
  content:'→';
  transition:transform .22s;
}
.rail-detail-cta:hover::after{transform:translateX(4px)}

/* ── GALLERY SECTION ── */
#galerie{background:var(--carbon)}
.gallery-tabs{display:flex;gap:8px;margin-bottom:32px}
.gtab{background:transparent;border:.5px solid var(--border);color:var(--muted);font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:10px 22px;border-radius:2px;cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.gtab:hover{border-color:var(--border2);color:#fff}
.gtab.active{background:var(--red);border-color:var(--red);color:#fff}
.gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.gallery-upload-cta{grid-column:1/-1;background:var(--gun);border:.5px dashed rgba(200,16,46,0.3);border-radius:6px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
.upload-icon{width:56px;height:56px;background:rgba(200,16,46,0.08);border-radius:8px;display:flex;align-items:center;justify-content:center}
.upload-title{font-family:var(--fd);font-size:18px;font-weight:600;color:#fff}
.upload-desc{font-size:13px;color:var(--muted);max-width:500px;line-height:1.6}
.upload-desc code{background:rgba(200,16,46,0.12);color:var(--red);padding:1px 6px;border-radius:3px;font-family:var(--font-mono,monospace);font-size:11px}
.upload-format{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.2)}
.gallery-card{background:var(--gun);border:.5px solid var(--border);border-radius:6px;overflow:hidden;transition:transform .2s var(--ease),border-color .2s}
.gallery-card:hover{transform:translateY(-3px);border-color:var(--border2)}
.ph-img{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.ph-img img{width:100%;height:100%;object-fit:cover;display:block}
.ph-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,transparent 60%);display:flex;align-items:flex-end;padding:12px;opacity:0;transition:opacity .25s}
.gallery-card:hover .ph-overlay{opacity:1}
.ph-overlay span{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,0.7)}
.ph-meta{display:flex;justify-content:space-between;align-items:center;padding:10px 12px}
.ph-service{font-size:11px;font-weight:500;color:#fff;letter-spacing:.06em}
.ph-loc{font-size:10px;color:var(--red);letter-spacing:.1em;text-transform:uppercase}
.add-photo .add-img{aspect-ratio:4/3;background:rgba(200,16,46,0.04);border:.5px dashed rgba(200,16,46,0.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.add-photo .add-img span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(200,16,46,0.4)}
.vid-thumb{aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0d0d0d;gap:10px}
.vid-play{width:44px;height:44px;background:rgba(200,16,46,0.9);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}
.gallery-card:hover .vid-play{transform:scale(1.1);background:var(--red)}
.vid-label{font-size:10px;color:rgba(255,255,255,0.35);padding:0 16px;text-align:center;line-height:1.4;letter-spacing:.04em}

/* ── AUTRES GRID FIX for 6 items ── */
.autres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}

/* ── GALLERY INSTRUCTIONS BOX ── */
.gallery-how-to{margin-top:24px;background:var(--gun);border:.5px solid var(--border);border-radius:6px;padding:20px 22px}
.gallery-how-to h4{font-family:var(--fd);font-size:16px;font-weight:600;color:#fff;margin-bottom:12px;letter-spacing:.04em}
.how-step{display:flex;gap:12px;margin-bottom:10px;align-items:flex-start}
.how-num{width:22px;height:22px;border-radius:50%;background:var(--red);color:#fff;font-size:10px;font-weight:500;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.how-txt{font-size:12px;color:var(--muted);line-height:1.5}
.how-txt code{background:rgba(200,16,46,0.1);color:var(--red);padding:1px 5px;border-radius:3px;font-size:11px}

/* ── RESPONSIVE ADDITIONS ── */
@media(max-width:900px){
  .rail-detail-panel{right:auto;left:0;top:auto;bottom:calc(100% + 8px);transform:translateX(12px) translateY(0);width:calc(100vw - 40px);max-width:320px}
  .rail-detail-panel.open{transform:translateX(0) translateY(0)}
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:600px){
  .gallery-grid{grid-template-columns:1fr}
  .autres-grid{grid-template-columns:1fr}
}


/* ═══════════════════ BULL SECTION — STATIC HERO ═══════════════════ */
#bull-section{
  position:relative;
  background:#050505;
  overflow:hidden;
  border-top:.5px solid rgba(200,16,46,.12);
  border-bottom:.5px solid rgba(200,16,46,.12);
}
.bull-stage{
  position:relative;
  min-height:620px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:80px 40px;
}

/* Glow halo behind bull */
.bull-glow{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:560px;height:560px;
  background:radial-gradient(circle,rgba(200,16,46,.12) 0%,rgba(200,16,46,.04) 40%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
  animation:pulseGlow 4s ease-in-out infinite;
  z-index:1;
}
@keyframes pulseGlow{
  0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}
}

/* Background smoke layers */
.smoke-layer{
  position:absolute;
  inset:-20%;
  pointer-events:none;
  filter:blur(40px);
  mix-blend-mode:screen;
  opacity:.35;
}
.smoke-1{
  background:radial-gradient(ellipse 60% 40% at 30% 50%,rgba(200,16,46,.25) 0%,transparent 60%);
  animation:smokeDrift1 18s ease-in-out infinite;
}
.smoke-2{
  background:radial-gradient(ellipse 50% 60% at 70% 60%,rgba(140,10,30,.3) 0%,transparent 55%);
  animation:smokeDrift2 22s ease-in-out infinite;
}
.smoke-3{
  background:radial-gradient(ellipse 40% 30% at 50% 30%,rgba(200,16,46,.18) 0%,transparent 60%);
  animation:smokeDrift3 26s ease-in-out infinite;
}
@keyframes smokeDrift1{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(80px,-40px) scale(1.2)}
}
@keyframes smokeDrift2{
  0%,100%{transform:translate(0,0) scale(1.1)}
  50%{transform:translate(-60px,50px) scale(.9)}
}
@keyframes smokeDrift3{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-40px,-60px) scale(1.15)}
}

/* Static bull logo */
.bull-logo-wrap{
  position:relative;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
  filter:drop-shadow(0 0 28px rgba(200,16,46,.35)) drop-shadow(0 0 50px rgba(200,16,46,.18));
  animation:bullBreathe 3.5s ease-in-out infinite;
}
#bullLogo{
  width:min(340px,50vw);
  height:auto;
  display:block;
}
@keyframes bullBreathe{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 28px rgba(200,16,46,.35)) drop-shadow(0 0 50px rgba(200,16,46,.18))}
  50%{transform:scale(1.015);filter:drop-shadow(0 0 36px rgba(200,16,46,.5)) drop-shadow(0 0 70px rgba(200,16,46,.25))}
}

/* Steam puffs — floating upward around the bull */
.steam-container{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:480px;height:480px;
  pointer-events:none;
  z-index:2;
}
.steam-puff{
  position:absolute;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.22) 0%,rgba(255,255,255,.06) 40%,transparent 70%);
  filter:blur(2px);
  will-change:transform,opacity;
}
.puff-1{width:60px;height:60px;left:18%;top:70%;animation:steamRise 5s ease-out infinite;animation-delay:0s}
.puff-2{width:80px;height:80px;left:68%;top:72%;animation:steamRise 6s ease-out infinite;animation-delay:1.2s}
.puff-3{width:50px;height:50px;left:30%;top:75%;animation:steamRise 5.5s ease-out infinite;animation-delay:2.5s}
.puff-4{width:90px;height:90px;left:55%;top:78%;animation:steamRise 7s ease-out infinite;animation-delay:3.2s}
.puff-5{width:45px;height:45px;left:78%;top:68%;animation:steamRise 5.8s ease-out infinite;animation-delay:0.8s}
.puff-6{width:70px;height:70px;left:12%;top:73%;animation:steamRise 6.5s ease-out infinite;animation-delay:2s}

@keyframes steamRise{
  0%{
    opacity:0;
    transform:translate(0,0) scale(.6);
  }
  15%{
    opacity:.7;
  }
  100%{
    opacity:0;
    transform:translate(var(--driftX,-40px),-260px) scale(1.8);
  }
}
.puff-1{--driftX:-30px}
.puff-2{--driftX:40px}
.puff-3{--driftX:-50px}
.puff-4{--driftX:20px}
.puff-5{--driftX:50px}
.puff-6{--driftX:-40px}

/* Text overlay */
.bull-text{
  position:absolute;
  left:48px;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  max-width:380px;
}
.bull-eyebrow{
  display:inline-block;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:20px;
  position:relative;
  padding-left:32px;
}
.bull-eyebrow::before{
  content:'';
  position:absolute;
  left:0;top:50%;
  width:24px;height:1px;
  background:var(--red);
}
.bull-heading{
  font-family:var(--fd);
  font-size:clamp(40px,5vw,64px);
  font-weight:700;
  line-height:.95;
  letter-spacing:-.01em;
  color:#fff;
  margin-bottom:18px;
}
.bull-heading .red{color:var(--red)}
.bull-sub{
  font-size:14px;
  color:var(--muted);
  line-height:1.6;
  letter-spacing:.01em;
}

@media (max-width:900px){
  .bull-stage{min-height:520px;padding:60px 24px;flex-direction:column;gap:40px}
  .bull-text{position:relative;left:auto;top:auto;transform:none;text-align:center;max-width:100%;margin-bottom:20px}
  .bull-eyebrow::before{display:none}
  .bull-eyebrow{padding-left:0}
  .bull-glow{width:380px;height:380px}
  .steam-container{width:340px;height:340px}
  #bullLogo{width:min(260px,65vw)}
}

@media (max-width:1024px){
  
}
@media (max-width:768px){
  
  
  
}

/* ═══════════════════════ INSTAGRAM TAB ═══════════════════════ */
.instagram-grid{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
}
.ig-profile-card{
  grid-column:1/-1;
  display:flex;
  gap:28px;
  align-items:center;
  padding:28px 32px;
  background:linear-gradient(135deg,rgba(245,133,41,.06),rgba(221,42,123,.06),rgba(129,52,175,.06));
  border:.5px solid rgba(221,42,123,.25);
  border-radius:8px;
}
.ig-avatar-ring{
  width:82px;height:82px;
  border-radius:50%;
  background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF);
  padding:3px;
  flex-shrink:0;
}
.ig-avatar-inner{
  width:100%;height:100%;
  border-radius:50%;
  background:#0a0a0a;
  display:flex;
  align-items:center;
  justify-content:center;
}
.ig-profile-info{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.ig-handle{
  font-family:var(--fd);
  font-size:22px;
  font-weight:700;
  color:#fff;
  letter-spacing:-.005em;
  margin:0;
}
.ig-bio{
  font-size:13px;
  color:var(--muted);
  line-height:1.55;
  max-width:560px;
  margin:0;
}
.ig-follow-btn{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:8px;
  padding:9px 18px;
  background:linear-gradient(135deg,#F58529,#DD2A7B,#8134AF);
  color:#fff;
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  border-radius:2px;
  transition:transform .2s,box-shadow .2s;
}
.ig-follow-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(221,42,123,.4);
}

.ig-card{
  position:relative;
  cursor:pointer;
}
.ig-thumb{
  aspect-ratio:1/1;
  display:flex;
  align-items:flex-end;
  padding:12px;
  position:relative;
  overflow:hidden;
}
.ig-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  padding:12px;
  opacity:1;
}
.ig-stats{
  font-size:11px;
  color:#fff;
  font-weight:600;
  letter-spacing:.05em;
  margin-left:auto;
}
.ig-meta{
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.ig-caption{
  font-size:12px;
  color:#fff;
  line-height:1.35;
  letter-spacing:.005em;
}
.ig-time{
  font-size:10px;
  color:rgba(221,42,123,.7);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-weight:500;
}
.ig-follow-card{
  grid-column:1/-1;
  background:linear-gradient(135deg,rgba(245,133,41,.08),rgba(221,42,123,.08),rgba(129,52,175,.08));
  border:.5px dashed rgba(221,42,123,.35);
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .25s,border-color .25s;
}
.ig-follow-card:hover{
  background:linear-gradient(135deg,rgba(245,133,41,.12),rgba(221,42,123,.15),rgba(129,52,175,.12));
  border-color:rgba(221,42,123,.6);
}
.ig-follow-content{
  display:flex;
  align-items:center;
  gap:16px;
}
.ig-follow-text{
  font-family:var(--fd);
  font-size:15px;
  font-weight:600;
  color:#fff;
  letter-spacing:.01em;
}
.ig-follow-arrow{
  color:#DD2A7B;
  font-size:20px;
  transition:transform .25s;
}
.ig-follow-card:hover .ig-follow-arrow{transform:translateX(4px)}

@media (max-width:768px){
  .ig-profile-card{flex-direction:column;text-align:center;gap:16px;padding:24px}
  .ig-follow-btn{align-self:center}
}

/* ═══════════════════════ STICKY CONTACT BUTTONS ═══════════════════════ */
.sticky-contact{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transform:translateY(20px) scale(.9);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.sticky-contact.visible{
  opacity:1;
  pointer-events:all;
  transform:translateY(0) scale(1);
}
.sticky-expand{
  width:58px;height:58px;
  border-radius:50%;
  background:var(--red);
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 24px -6px rgba(200,16,46,.6),0 0 0 0 rgba(200,16,46,.5);
  transition:transform .25s var(--ease),box-shadow .25s;
  position:relative;
  overflow:visible;
  animation:stickyPulse 2.8s ease-in-out infinite;
}
@keyframes stickyPulse{
  0%,100%{box-shadow:0 8px 24px -6px rgba(200,16,46,.6),0 0 0 0 rgba(200,16,46,.4)}
  50%{box-shadow:0 8px 24px -6px rgba(200,16,46,.7),0 0 0 14px rgba(200,16,46,0)}
}
.sticky-expand:hover{
  transform:scale(1.08);
  animation:none;
  box-shadow:0 10px 28px -4px rgba(200,16,46,.7);
}
.sticky-expand.open{
  transform:rotate(135deg) scale(1.05);
  background:var(--red2);
  animation:none;
}
.sticky-expand.open svg{opacity:0;transition:opacity .15s}
.sticky-expand.open::before{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:18px;height:2px;
  background:#fff;
  border-radius:2px;
}
.sticky-expand.open::after{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(90deg);
  width:18px;height:2px;
  background:#fff;
  border-radius:2px;
}
.sticky-badge{
  position:absolute;
  top:6px;right:6px;
  width:10px;height:10px;
  background:#4ade80;
  border-radius:50%;
  border:2px solid var(--carbon);
  animation:badgeBeat 2s ease-in-out infinite;
}
@keyframes badgeBeat{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.2)}
}
.sticky-menu{
  position:absolute;
  bottom:calc(100% + 14px);
  right:0;
  display:flex;
  flex-direction:column-reverse;
  gap:10px;
  opacity:0;
  pointer-events:none;
  transform:translateY(10px);
  transition:opacity .25s var(--ease),transform .25s var(--ease);
}
.sticky-menu.open{
  opacity:1;
  pointer-events:all;
  transform:translateY(0);
}
.sticky-option{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 16px 11px 14px;
  border-radius:30px;
  font-size:13px;
  font-weight:500;
  color:#fff;
  letter-spacing:.01em;
  white-space:nowrap;
  transition:transform .2s,box-shadow .2s;
  animation:optionIn .4s cubic-bezier(.34,1.56,.64,1) backwards;
  box-shadow:0 4px 16px -4px rgba(0,0,0,.5);
}
.sticky-menu.open .sticky-option:nth-child(1){animation-delay:.0s}
.sticky-menu.open .sticky-option:nth-child(2){animation-delay:.06s}
.sticky-menu.open .sticky-option:nth-child(3){animation-delay:.12s}
.sticky-menu.open .sticky-option:nth-child(4){animation-delay:.18s}
@keyframes optionIn{
  0%{opacity:0;transform:translateX(14px) scale(.9)}
  100%{opacity:1;transform:translateX(0) scale(1)}
}
.sticky-option:hover{
  transform:translateX(-3px);
  box-shadow:0 8px 20px -4px rgba(0,0,0,.6);
}
.sticky-whatsapp{background:#25D366}
.sticky-call{background:#0088ff}
.sticky-sms{background:#8b5cf6}
.sticky-quote{background:var(--red)}
.sticky-option svg{flex-shrink:0}

@media (max-width:600px){
  .sticky-contact{bottom:16px;right:16px}
  .sticky-expand{width:52px;height:52px}
  .sticky-option .sticky-label{display:none}
  .sticky-option{padding:11px;border-radius:50%;width:44px;height:44px;justify-content:center}
}


/* ═══════════════════════ REAL LOGO (nav + footer) ═══════════════════════ */
.nav-logo-link{
  display:flex;
  align-items:center;
  text-decoration:none;
  transition:opacity .2s var(--ease);
  padding:4px 0;
}
.nav-logo-link:hover{opacity:.82}
.nav-logo-img{
  height:11px;
  width:auto;
  display:block;
  user-select:none;
  -webkit-user-drag:none;
}
.footer-logo-img{
  height:15px;
  width:auto;
  display:block;
  opacity:.8;
}
@media (max-width:600px){
  .nav-logo-img{height:10px}
  .footer-logo-img{height:13px}
}

/* ── Subtle partner/cert line in footer ── */
.footer-certs{
  margin-top:28px;
  padding-top:18px;
  border-top:.5px solid rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.footer-certs-label{
  font-size:9px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.25);
  font-weight:500;
}
.footer-certs-list{
  font-size:10px;
  letter-spacing:.14em;
  color:rgba(255,255,255,.35);
  font-weight:400;
}
@media(max-width:600px){
  .footer-certs{gap:8px;flex-direction:column}
  .footer-certs-list{letter-spacing:.08em}
}

/* ═══════════════════════ TESTIMONIALS — compact ═══════════════════════ */






/* Compact rating summary — single row */











/* Compact review cards */
















@media (max-width:1024px){
  
}
@media (max-width:640px){
  
  
  
  
  
  
}






/* ═══════════════════════════════════════════════════════════════════════
   EDITORIAL POLISH PASS — proper design system
   ═══════════════════════════════════════════════════════════════════════ */

/* Unified system tokens */
:root{
  --ink-0: #ffffff;
  --ink-1: rgba(255,255,255,0.90);
  --ink-2: rgba(255,255,255,0.58);
  --ink-3: rgba(255,255,255,0.38);
  --ink-4: rgba(255,255,255,0.22);
}

/* ── NAV REFINEMENT ── */
.nav-link{
  color: rgba(255,255,255,0.72) !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  transition: color .2s ease;
}
.nav-link:hover{color: #fff !important}

/* Ghost nav CTA — no longer a loud red block */
.nav-cta{
  background: transparent !important;
  border: 0.5px solid rgba(200,16,46,0.55) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  padding: 10px 18px !important;
  border-radius: 2px !important;
  transition: background .22s ease, border-color .22s ease, transform .15s ease !important;
  position: relative;
}
.nav-cta:hover{
  background: var(--red) !important;
  border-color: var(--red) !important;
  transform: translateY(-1px);
}


/* ═══════════════════════ TESTIMONIALS — editorial ═══════════════════════ */
#testimonials{
  background: #0a0a0a;
  padding: 100px 0 90px;
  position: relative;
}
#testimonials .section-inner{
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 48px;
}

/* Header — two-column layout */
.reviews-header{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: flex-end;
  padding-bottom: 40px;
  margin-bottom: 48px;
  border-bottom: 0.5px solid rgba(255,255,255,0.06);
}
.reviews-intro{
  max-width: 520px;
}
.reviews-headline{
  font-family: var(--fd);
  font-size: clamp(36px, 4.2vw, 52px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--ink-0);
  margin: 0;
}

/* Rating block — top-right, calm & premium */
.reviews-summary{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  text-align: right;
}
.rs-score-wrap{
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.rs-score-num{
  font-family: var(--fd);
  font-size: 48px;
  font-weight: 700;
  color: var(--ink-0);
  line-height: 1;
  letter-spacing: -0.02em;
}
.rs-score-denom{
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 500;
  color: var(--ink-3);
  line-height: 1;
}
.rs-stars-row{
  color: #FFD700;
  font-size: 13px;
  letter-spacing: 4px;
  line-height: 1;
  margin-top: 2px;
}
.rs-count-row{
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  margin-top: 6px;
}

/* Review cards — premium editorial */
.reviews-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;   /* Hairline divider between cards, no card bg */
  background: rgba(255,255,255,0.05);
  border: 0.5px solid rgba(255,255,255,0.05);
}
.review-card{
  background: #0a0a0a;   /* Match section bg so grid gap becomes hairlines */
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  transition: background .3s ease;
  min-height: 260px;
}
.review-card:hover{
  background: #101010;
}
/* Big decorative quote mark */
.review-quote{
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 56px;
  line-height: 1;
  color: var(--red);
  margin: -10px 0 -18px;
  font-weight: 700;
  letter-spacing: -0.05em;
  user-select: none;
}
.review-text{
  font-size: 14px;
  line-height: 1.7;
  color: var(--ink-1);
  margin: 0;
  flex: 1;
  letter-spacing: 0.003em;
  font-weight: 400;
}
.review-meta{
  padding-top: 18px;
  border-top: 0.5px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.review-name{
  font-family: var(--fd);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-0);
  letter-spacing: 0.01em;
}
.review-context{
  font-size: 10px;
  color: var(--ink-3);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
}

/* Footer with Google logo */
.reviews-footer{
  display: flex;
  justify-content: center;
  margin-top: 56px;
  padding-top: 40px;
  border-top: 0.5px solid rgba(255,255,255,0.06);
}
.reviews-google-link{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  background: rgba(255,255,255,0.03);
  border: 0.5px solid rgba(255,255,255,0.08);
  border-radius: 2px;
  color: var(--ink-0);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background .22s ease, border-color .22s ease, transform .15s ease;
}
.reviews-google-link:hover{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.18);
  transform: translateY(-1px);
}
.rgl-google{flex-shrink: 0}
.rgl-arrow{color: var(--ink-3); font-size: 13px; transition: transform .22s}
.reviews-google-link:hover .rgl-arrow{transform: translate(2px, -2px); color: var(--ink-0)}

/* Responsive */
@media (max-width: 1024px){
  .reviews-grid{grid-template-columns: repeat(2, 1fr)}
}
@media (max-width: 768px){
  #testimonials{padding: 72px 0}
  #testimonials .section-inner{padding: 0 24px}
  .reviews-header{
    grid-template-columns: 1fr;
    align-items: flex-start;
    gap: 32px;
  }
  .reviews-summary{align-items: flex-start; text-align: left}
  .reviews-grid{grid-template-columns: 1fr}
  .review-card{min-height: auto; padding: 28px 24px 24px}
}



/* ═══════════════════════════════════════════════════════════════════════
   NEW FEATURES v3 — Preloader, Compare, Loyalty, FAQ
   ═══════════════════════════════════════════════════════════════════════ */

/* ── CERAMIC COMPARISON TABLE ── */
.compare-wrap{
  margin-top: 64px;
  padding-top: 56px;
  border-top: 0.5px solid rgba(255,255,255,0.06);
}
.compare-header{
  max-width: 560px;
  margin-bottom: 40px;
}
.compare-eyebrow{
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--red);
  font-weight: 600;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.compare-eyebrow::before{
  content: '';
  width: 28px;
  height: 1px;
  background: var(--red);
  display: inline-block;
}
.compare-title{
  font-family: var(--fd);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  color: #fff;
}
.compare-title .red{color: var(--red)}
.compare-sub{
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.55);
  max-width: 480px;
  margin: 0;
}

.compare-table{
  background: var(--gun);
  border: 0.5px solid rgba(255,255,255,0.06);
  border-radius: 4px;
  overflow: hidden;
}
.compare-row{
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  border-bottom: 0.5px solid rgba(255,255,255,0.04);
  transition: background .2s ease;
}
.compare-row:last-child{border-bottom: none}
.compare-row:not(.compare-row-head):not(.compare-row-cta):hover{
  background: rgba(255,255,255,0.015);
}
.compare-cell{
  padding: 16px 22px;
  display: flex;
  align-items: center;
  font-size: 13px;
  color: rgba(255,255,255,0.82);
  letter-spacing: 0.01em;
  border-right: 0.5px solid rgba(255,255,255,0.04);
  min-height: 52px;
}
.compare-cell:last-child{border-right: none}

.compare-feat{
  color: rgba(255,255,255,0.5);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
}

/* Header row */
.compare-row-head .compare-cell{
  padding: 24px 22px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  border-bottom: 0.5px solid rgba(255,255,255,0.1);
}
.compare-silver{
  background: rgba(180,180,180,0.02);
}
.compare-gold{
  background: rgba(200,16,46,0.04);
  position: relative;
}
.compare-gold::before{
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--red);
}
.tier-tag{
  font-family: var(--fd);
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
}
.tier-tag-popular em{
  font-style: normal;
  font-family: var(--fb);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--red);
  padding: 3px 8px;
  border: 0.5px solid rgba(200,16,46,0.5);
  border-radius: 2px;
}
.tier-price{
  font-family: var(--fd);
  font-size: 16px;
  font-weight: 500;
  color: rgba(255,255,255,0.6);
}

/* Highlight gold column */
.compare-highlight{
  background: rgba(200,16,46,0.03);
  color: #fff;
  font-weight: 500;
}
.compare-muted{color: rgba(255,255,255,0.3)}

.check{
  color: var(--red);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
}

/* CTA row */
.compare-row-cta{
  border-top: 0.5px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.015);
}
.compare-row-cta .compare-cell{
  padding: 18px 22px;
}
.compare-btn{
  display: inline-block;
  padding: 10px 18px;
  border: 0.5px solid rgba(255,255,255,0.16);
  border-radius: 2px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  transition: all .22s ease;
}
.compare-btn:hover{
  border-color: rgba(255,255,255,0.35);
  color: #fff;
  transform: translateY(-1px);
}
.compare-btn-gold{
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}
.compare-btn-gold:hover{
  background: var(--red2);
  border-color: var(--red2);
  transform: translateY(-1px);
}

@media (max-width: 768px){
  .compare-row{grid-template-columns: 1.2fr 1fr 1fr}
  .compare-cell{padding: 12px 14px; font-size: 12px}
  .tier-tag{font-size: 18px}
  .tier-tag-popular em{display: block; margin-top: 4px}
  .compare-btn{padding: 8px 12px; font-size: 9px; letter-spacing: 0.14em}
}


/* ── LOYALTY / REFERRAL SECTION ── */
#loyalty{
  background: #0a0a0a;
  padding: 100px 0;
  border-top: 0.5px solid rgba(255,255,255,0.04);
  border-bottom: 0.5px solid rgba(255,255,255,0.04);
}
#loyalty .section-inner{
  max-width: 1280px;
  padding: 0 48px;
  margin: 0 auto;
}
.loyalty-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.loyalty-content{
  max-width: 480px;
}
.loyalty-title{
  font-family: var(--fd);
  font-size: clamp(36px, 4.5vw, 52px);
  font-weight: 700;
  line-height: 1.03;
  letter-spacing: -0.02em;
  margin: 16px 0 18px;
  color: #fff;
}
.loyalty-title .red{color: var(--red)}
.loyalty-sub{
  font-size: 14px;
  line-height: 1.7;
  color: rgba(255,255,255,0.6);
  margin-bottom: 36px;
}
.loyalty-steps{
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 36px;
  padding: 24px 0;
  border-top: 0.5px solid rgba(255,255,255,0.06);
  border-bottom: 0.5px solid rgba(255,255,255,0.06);
}
.ls-item{
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.ls-num{
  font-family: var(--fd);
  font-size: 11px;
  font-weight: 600;
  color: var(--red);
  letter-spacing: 0.12em;
  width: 28px;
  flex-shrink: 0;
  padding-top: 2px;
}
.ls-text{display: flex; flex-direction: column; gap: 2px}
.ls-title{
  font-family: var(--fd);
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.01em;
}
.ls-desc{
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  line-height: 1.5;
}
.loyalty-cta{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  background: var(--red);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 2px;
  transition: background .22s, transform .15s, box-shadow .22s;
}
.loyalty-cta:hover{
  background: var(--red2);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px -6px rgba(200,16,46,0.5);
}
.loyalty-cta .cta-arrow{
  color: #fff;
  font-size: 14px;
  transition: transform .22s;
}
.loyalty-cta:hover .cta-arrow{transform: translateX(3px)}

/* Loyalty card visual */
.loyalty-visual{
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
.loyalty-card{
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1.586 / 1;
  background: linear-gradient(135deg, #1a1a1a 0%, #0f0f0f 50%, #1a0608 100%);
  border: 0.5px solid rgba(200,16,46,0.25);
  border-radius: 12px;
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.03);
  transform: perspective(1000px) rotateY(-3deg) rotateX(1deg);
  transition: transform .5s cubic-bezier(.2,1,.4,1);
}
.loyalty-card::before{
  content: '';
  position: absolute;
  top: -50%; right: -50%;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(200,16,46,0.18), transparent 70%);
  pointer-events: none;
}
.loyalty-card:hover{
  transform: perspective(1000px) rotateY(0deg) rotateX(0deg);
}
.lc-header{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.lc-brand{
  display: flex;
  align-items: center;
  gap: 8px;
}
.lc-dot{
  width: 8px; height: 8px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(200,16,46,0.8);
}
.lc-label{
  font-family: var(--fd);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.22em;
  color: rgba(255,255,255,0.7);
}
.lc-tier{
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--red);
  font-weight: 600;
  padding: 4px 10px;
  border: 0.5px solid rgba(200,16,46,0.45);
  border-radius: 2px;
}
.lc-number{
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Courier New', monospace;
  font-size: 18px;
  color: #fff;
  letter-spacing: 0.08em;
  font-weight: 500;
}
.lc-number span{opacity: 0.9}
.lc-number span:nth-child(even){opacity: 0.4}
.lc-footer{
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-top: 16px;
  border-top: 0.5px solid rgba(255,255,255,0.08);
}
.lc-field{
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.lc-k{
  font-size: 8px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}
.lc-v{
  font-family: var(--fd);
  font-size: 17px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
}
.lc-v-active{
  color: #22c55e;
  font-size: 13px;
}
.loyalty-note{
  font-size: 10px;
  text-align: center;
  color: rgba(255,255,255,0.35);
  letter-spacing: 0.08em;
  max-width: 360px;
  line-height: 1.6;
}

@media (max-width: 900px){
  .loyalty-grid{grid-template-columns: 1fr; gap: 48px}
  .loyalty-visual{order: -1}
  .loyalty-card{max-width: 360px}
}


/* ── FAQ ── */
#faq{
  background: var(--carbon);
  padding: 100px 0;
}
#faq .section-inner{
  max-width: 1280px;
  padding: 0 48px;
  margin: 0 auto;
}
.faq-grid{
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 80px;
  align-items: flex-start;
}
.faq-header{
  position: sticky;
  top: 120px;
}
.faq-title{
  font-family: var(--fd);
  font-size: clamp(36px, 4.5vw, 54px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 14px 0 20px;
}
.faq-title .red{color: var(--red)}
.faq-sub{
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.55);
  margin-bottom: 24px;
}
.faq-ask-btn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  background: transparent;
  border: 0.5px solid rgba(200,16,46,0.45);
  border-radius: 2px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: all .22s ease;
}
.faq-ask-btn:hover{
  background: rgba(200,16,46,0.08);
  border-color: var(--red);
  transform: translateY(-1px);
}

.faq-list{
  display: flex;
  flex-direction: column;
  border-top: 0.5px solid rgba(255,255,255,0.08);
}
.faq-item{
  border-bottom: 0.5px solid rgba(255,255,255,0.06);
  transition: background .25s ease;
}
.faq-item[open]{
  background: rgba(255,255,255,0.01);
}
.faq-q{
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  cursor: pointer;
  font-family: var(--fd);
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.002em;
  transition: color .2s;
  list-style: none;
  user-select: none;
}
.faq-q::-webkit-details-marker{display: none}
.faq-q:hover{color: var(--red)}
.faq-item[open] .faq-q{color: var(--red); padding-bottom: 12px}

/* Plus/minus icon */
.faq-ic{
  position: relative;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.faq-ic::before,
.faq-ic::after{
  content: '';
  position: absolute;
  background: currentColor;
  left: 50%; top: 50%;
  transform-origin: center;
  transition: transform .3s cubic-bezier(.3,1,.3,1), background .2s;
}
.faq-ic::before{
  width: 14px; height: 1px;
  transform: translate(-50%, -50%);
}
.faq-ic::after{
  width: 1px; height: 14px;
  transform: translate(-50%, -50%);
}
.faq-item[open] .faq-ic::after{
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.faq-a{
  padding: 0 0 24px;
  font-size: 14px;
  line-height: 1.75;
  color: rgba(255,255,255,0.65);
  max-width: 640px;
}
.faq-a p{margin: 0}
.faq-a b{color: #fff; font-weight: 600}

@media (max-width: 900px){
  .faq-grid{grid-template-columns: 1fr; gap: 40px}
  .faq-header{position: static}
  .faq-q{font-size: 14px; padding: 18px 0}
}



/* ═══════ PRELOADER — minimal luxury wordmark ═══════ */
#preloader{
  position: fixed;
  inset: 0;
  background: #050505;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  transition: opacity .7s cubic-bezier(.6,0,.4,1), visibility 0s .7s;
}
#preloader.done{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* Wordmark — custom typography match */
.pl-mark{
  display: flex;
  align-items: center;
  gap: 14px;
  opacity: 0;
  animation: plMarkIn .7s cubic-bezier(.2,.8,.3,1) .1s forwards;
}
.pl-word{
  font-family: var(--fd, 'Barlow Condensed', sans-serif);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.32em;
  color: #fff;
  line-height: 1;
  text-transform: uppercase;
}
.pl-word-toro{
  color: #fff;
}
.pl-word-toro::before{
  /* Red 'R' overlay trick — match your logo */
  /* Simpler: just highlight middle with red via gradient */
}
/* Use actual brand color accent on the R in TORO */
.pl-word-toro{
  background: linear-gradient(90deg, #fff 0%, #fff 33%, var(--red) 33%, var(--red) 66%, #fff 66%, #fff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.pl-word-steam{
  color: rgba(255,255,255,0.92);
}
.pl-dot{
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--red);
  opacity: 0;
  animation: plDotIn .5s ease-out .55s forwards, plDotPulse 1.4s ease-in-out .9s infinite;
}

@keyframes plMarkIn{
  0%  {opacity: 0; transform: translateY(8px)}
  100%{opacity: 1; transform: translateY(0)}
}
@keyframes plDotIn{
  0%  {opacity: 0; transform: scale(0.3)}
  100%{opacity: 1; transform: scale(1)}
}
@keyframes plDotPulse{
  0%,100%{opacity: 1; transform: scale(1)}
  50%    {opacity: 0.4; transform: scale(0.8)}
}

/* Hairline progress bar */
.pl-bar{
  width: 180px;
  height: 1px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
  opacity: 0;
  animation: plMarkIn .6s ease-out .3s forwards;
}
.pl-fill{
  width: 0;
  height: 100%;
  background: var(--red);
  animation: plProg 1.4s cubic-bezier(.6,0,.2,1) .4s forwards;
}
@keyframes plProg{
  0%  {width: 0}
  70% {width: 82%}
  100%{width: 100%}
}

@media (max-width: 600px){
  .pl-word{font-size: 18px; letter-spacing: 0.28em}
  .pl-bar{width: 140px}
}

/* ═══════════════════════════════════════════════════════
   REDESIGN STYLES
   Added: Silver vs Gold compare cards (cmp2),
   Loyalty 3-step (loy2), FAQ compact (faq2)
   ═══════════════════════════════════════════════════════ */

/* --- tokens for this block --- */
:root{
  --gold: #d4a445;
  --gold-soft: rgba(212,164,69,0.14);
  --silver-tone: #c2c5cb;
  --silver-soft: rgba(194,197,203,0.12);
}

/* ═══════════════════════════════════════════════════════
   1 · COMPARE (Silver vs Gold) — two aligned cards
   ═══════════════════════════════════════════════════════ */
.cmp2-wrap{
  margin-top: 80px;
  padding: 60px 0 20px;
  border-top: 1px solid var(--border);
}
.cmp2-header{
  text-align: center;
  max-width: 640px;
  margin: 0 auto 48px;
}
.cmp2-eyebrow{
  font-family: var(--fd);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 14px;
}
.cmp2-eyebrow::before,
.cmp2-eyebrow::after{
  content: '';
  display: inline-block;
  width: 22px;
  height: 1px;
  background: var(--red);
  vertical-align: middle;
  margin: 0 12px;
}
.cmp2-title{
  font-family: var(--fd);
  font-size: clamp(34px, 4.5vw, 56px);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1;
  margin: 0 0 18px;
  color: var(--ink-0);
}
.cmp2-sub{
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.6;
  max-width: 540px;
  margin: 0 auto;
}

.cmp2-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 920px;
  margin: 0 auto;
}

.cmp2-card{
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 36px 32px 32px;
  transition: transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.cmp2-card:hover{
  transform: translateY(-4px);
}

.cmp2-silver{
  border-color: rgba(194,197,203,0.14);
  background:
    linear-gradient(180deg, var(--silver-soft) 0%, transparent 35%),
    var(--surface);
}
.cmp2-silver:hover{ border-color: rgba(194,197,203,0.28); }

.cmp2-gold{
  border-color: rgba(212,164,69,0.32);
  background:
    linear-gradient(180deg, var(--gold-soft) 0%, transparent 35%),
    var(--surface);
  box-shadow: 0 30px 80px -30px rgba(212,164,69,0.22);
}
.cmp2-gold:hover{
  border-color: rgba(212,164,69,0.55);
  box-shadow: 0 40px 100px -30px rgba(212,164,69,0.35);
}

.cmp2-badge{
  position: absolute;
  top: -12px;
  right: 28px;
  background: var(--gold);
  color: #0a0a0a;
  padding: 6px 14px;
  border-radius: 999px;
  font-family: var(--fd);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.cmp2-tier{
  font-family: var(--fd);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.cmp2-gold .cmp2-tier{ color: var(--gold); }
.cmp2-silver .cmp2-tier{ color: var(--silver-tone); }

.cmp2-name{
  font-family: var(--fd);
  font-size: 44px;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1;
  margin-bottom: 14px;
  color: var(--ink-0);
}

.cmp2-price{
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 6px;
}
.cmp2-amount{
  font-family: var(--fd);
  font-size: 40px;
  font-weight: 700;
  color: var(--ink-0);
}
.cmp2-curr{
  font-family: var(--fd);
  font-size: 22px;
  color: var(--ink-2);
}

.cmp2-dur{
  font-size: 13px;
  color: var(--ink-3);
  margin-bottom: 26px;
  letter-spacing: 0.02em;
}

.cmp2-features{
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}
.cmp2-features li{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}
.cmp2-k{ color: var(--ink-2); }
.cmp2-v{
  color: var(--ink-0);
  font-weight: 500;
  text-align: right;
  font-family: var(--fb);
}
.cmp2-yes{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}
.cmp2-gold .cmp2-yes{
  background: var(--gold-soft);
  color: var(--gold);
}
.cmp2-silver .cmp2-yes{
  background: var(--silver-soft);
  color: var(--silver-tone);
}
.cmp2-no{
  color: var(--ink-4);
  font-size: 16px;
}

.cmp2-cta{
  display: block;
  width: 100%;
  margin-top: 30px;
  padding: 15px;
  border-radius: 999px;
  text-align: center;
  font-family: var(--fd);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  background: transparent;
  color: var(--ink-0);
  border: 1px solid var(--border2);
  transition: all .25s var(--ease);
}
.cmp2-cta:hover{
  background: rgba(255,255,255,0.04);
  border-color: var(--silver-tone);
}
.cmp2-cta-gold{
  background: var(--gold);
  color: #0a0a0a;
  border-color: var(--gold);
}
.cmp2-cta-gold:hover{
  background: #e3b556;
  border-color: #e3b556;
  transform: translateY(-1px);
  box-shadow: 0 14px 34px rgba(212,164,69,0.32);
}

.cmp2-foot{
  text-align: center;
  color: var(--ink-3);
  font-size: 12.5px;
  max-width: 780px;
  margin: 42px auto 0;
  line-height: 1.65;
}

@media (max-width: 760px){
  .cmp2-grid{
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .cmp2-card{ padding: 32px 26px 28px; }
  .cmp2-name{ font-size: 38px; }
  .cmp2-amount{ font-size: 34px; }
}

/* ═══════════════════════════════════════════════════════
   2 · LOYALTY / REFERRAL — 3-step no fake card
   ═══════════════════════════════════════════════════════ */
#loyalty .section-inner{
  padding: 120px 24px;
}

.loy2-wrap{
  max-width: 1040px;
  margin: 0 auto;
  text-align: center;
}

.loy2-head{ margin-bottom: 64px; }
.loy2-title{
  font-family: var(--fd);
  font-size: clamp(40px, 5.5vw, 72px);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1;
  margin: 14px 0 18px;
  color: var(--ink-0);
}
.loy2-sub{
  color: var(--ink-2);
  font-size: 16px;
  line-height: 1.7;
  max-width: 620px;
  margin: 0 auto;
}

.loy2-steps{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
  margin: 0 auto 56px;
  max-width: 900px;
}
.loy2-steps::before{
  content: '';
  position: absolute;
  top: 38px;
  left: 16%;
  right: 16%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--border2) 20%, var(--border2) 80%, transparent);
  z-index: 0;
}

.loy2-step{
  position: relative;
  z-index: 1;
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.loy2-num{
  width: 76px;
  height: 76px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--gun);
  border: 1px solid var(--border2);
  font-family: var(--fd);
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--ink-0);
  margin-bottom: 24px;
  position: relative;
  transition: all .3s var(--ease);
}
.loy2-num::before{
  content: '';
  position: absolute;
  inset: -7px;
  border-radius: 50%;
  border: 1px dashed var(--border2);
  opacity: .5;
  transition: opacity .3s var(--ease);
}
.loy2-step:hover .loy2-num{
  border-color: var(--red);
  background: var(--surface);
  color: var(--red);
  transform: scale(1.06);
  box-shadow: 0 10px 30px rgba(200,16,46,0.25);
}
.loy2-step:hover .loy2-num::before{ opacity: 1; }

.loy2-step-title{
  font-family: var(--fd);
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
  letter-spacing: -0.005em;
  color: var(--ink-0);
}
.loy2-step-desc{
  color: var(--ink-2);
  font-size: 14px;
  line-height: 1.6;
  max-width: 240px;
  margin: 0;
}

.loy2-benefits{
  display: flex;
  justify-content: center;
  gap: 42px;
  flex-wrap: wrap;
  padding: 26px 0;
  margin-bottom: 40px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.loy2-benefit{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
}
.loy2-dot{
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--red);
  display: inline-block;
}

.loy2-cta-wrap{ margin-top: 8px; }
.loy2-cta{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 18px 34px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-family: var(--fd);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .25s var(--ease);
}
.loy2-cta:hover{
  background: var(--red2);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(200,16,46,0.35);
}
.loy2-cta .cta-arrow{
  transition: transform .2s var(--ease);
}
.loy2-cta:hover .cta-arrow{ transform: translateX(4px); }

@media (max-width: 820px){
  .loy2-steps{
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .loy2-steps::before{
    top: 8%;
    bottom: 8%;
    left: 50%;
    right: auto;
    width: 1px;
    height: auto;
    background: linear-gradient(to bottom, transparent, var(--border2) 20%, var(--border2) 80%, transparent);
  }
  .loy2-benefits{
    flex-direction: column;
    gap: 14px;
    align-items: center;
  }
}

/* ═══════════════════════════════════════════════════════
   3 · FAQ — compact centered header, single column
   ═══════════════════════════════════════════════════════ */
#faq .section-inner{ padding: 120px 24px; }

.faq2-wrap{
  max-width: 880px;
  margin: 0 auto;
}

.faq2-head{
  text-align: center;
  max-width: 680px;
  margin: 0 auto 48px;
}
.faq2-title{
  font-family: var(--fd);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1;
  margin: 14px 0 14px;
  color: var(--ink-0);
}
.faq2-sub{
  color: var(--ink-2);
  font-size: 14.5px;
  line-height: 1.6;
  margin: 0;
}

.faq2-list{
  max-width: 820px;
  margin: 0 auto;
  border-top: 1px solid var(--border);
}

/* Re-style the existing .faq-item so it plays nice in the compact layout */
.faq2-list .faq-item{
  border-bottom: 1px solid var(--border);
  padding: 0;
  background: transparent;
}
.faq2-list .faq-q{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 22px 4px;
  font-family: var(--fd);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-0);
  cursor: pointer;
  list-style: none;
  letter-spacing: 0.005em;
  transition: color .2s var(--ease);
}
.faq2-list .faq-q::-webkit-details-marker{ display: none; }
.faq2-list .faq-q:hover{ color: var(--red); }

.faq2-list .faq-ic{
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--border2);
  position: relative;
  transition: all .3s var(--ease);
}
.faq2-list .faq-ic::before,
.faq2-list .faq-ic::after{
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  background: var(--ink-0);
  transition: all .3s var(--ease);
}
.faq2-list .faq-ic::before{
  width: 10px;
  height: 1.2px;
  transform: translate(-50%, -50%);
}
.faq2-list .faq-ic::after{
  width: 1.2px;
  height: 10px;
  transform: translate(-50%, -50%);
}
.faq2-list .faq-item[open] .faq-ic{
  background: var(--red);
  border-color: var(--red);
  transform: rotate(90deg);
}
.faq2-list .faq-item[open] .faq-ic::after{
  opacity: 0;
}

.faq2-list .faq-a{
  padding: 0 4px 22px;
  color: var(--ink-2);
  font-size: 14.5px;
  line-height: 1.75;
}
.faq2-list .faq-a p{ margin: 0; }
.faq2-list .faq-a b{ color: var(--ink-0); font-weight: 600; }

.faq2-foot{
  text-align: center;
  margin-top: 44px;
  color: var(--ink-3);
  font-size: 14px;
}
.faq2-foot a{
  color: var(--red);
  border-bottom: 1px solid transparent;
  text-decoration: none;
  transition: border-color .2s var(--ease);
}
.faq2-foot a:hover{ border-bottom-color: var(--red); }

@media (max-width: 600px){
  #loyalty .section-inner,
  #faq .section-inner{ padding: 80px 20px; }
  .loy2-num{ width: 66px; height: 66px; font-size: 22px; }
  .faq2-list .faq-q{ font-size: 15px; padding: 20px 2px; }
}

/* ═══════════════════════════════════════════════════════
   FOUNDER / CEO SECTION
   Portrait left, bio+stats+certifications grid right
   ═══════════════════════════════════════════════════════ */
#founder{
  background: linear-gradient(180deg, var(--carbon) 0%, #0d0d12 60%, var(--carbon) 100%);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
#founder::before{
  content: '';
  position: absolute;
  top: -10%;
  left: -5%;
  width: 40%;
  height: 60%;
  background: radial-gradient(ellipse at center, rgba(200,16,46,0.12), transparent 70%);
  pointer-events: none;
  z-index: 0;
}
#founder::after{
  content: '';
  position: absolute;
  bottom: -10%;
  right: -5%;
  width: 40%;
  height: 60%;
  background: radial-gradient(ellipse at center, rgba(200,16,46,0.08), transparent 70%);
  pointer-events: none;
  z-index: 0;
}
#founder .section-inner{
  position: relative;
  z-index: 1;
  padding: 140px 24px;
  max-width: 1280px;
  margin: 0 auto;
}

.fnd-grid{
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 64px;
  align-items: start;
}

/* ───── LEFT COLUMN ───── */
.fnd-portrait-col{
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.fnd-portrait-wrap{
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: var(--gun);
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.6),
    0 0 0 1px var(--border);
  transition: transform .4s var(--ease);
}
.fnd-portrait-wrap:hover{ transform: translateY(-4px); }

.fnd-portrait-img{
  display: block;
  width: 100%;
  height: auto;
  filter: contrast(1.05) saturate(1.05);
}

.fnd-portrait-ribbon{
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: var(--red);
  color: #fff;
  padding: 14px 18px;
  border-radius: 10px;
  display: flex;
  align-items: baseline;
  gap: 10px;
  box-shadow: 0 14px 34px rgba(200,16,46,0.5);
  backdrop-filter: blur(4px);
}
.fnd-ribbon-years{
  font-family: var(--fd);
  font-size: 38px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
}
.fnd-ribbon-label{
  font-family: var(--fd);
  font-size: 11px;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
  opacity: 0.92;
}

/* Small credibility card — Jason Rose photo */
.fnd-credit-card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .3s var(--ease);
}
.fnd-credit-card:hover{ border-color: var(--border2); }
.fnd-credit-img{
  display: block;
  width: 100%;
  height: 180px;
  object-fit: cover;
  object-position: center 30%;
}
.fnd-credit-caption{
  padding: 14px 18px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0;
  border-top: 1px solid var(--border);
}
.fnd-credit-caption strong{ color: var(--ink-0); font-weight: 600; }

/* ───── RIGHT COLUMN ───── */
.fnd-content-col{ min-width: 0; }

.fnd-header{ margin-bottom: 32px; }
.fnd-title{
  font-family: var(--fd);
  font-size: clamp(44px, 5.5vw, 72px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 14px 0 10px;
  color: var(--ink-0);
}
.fnd-role{
  font-family: var(--fb);
  font-size: 14px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
  margin: 0;
}

.fnd-bio{
  margin-bottom: 40px;
  max-width: 680px;
}
.fnd-bio p{
  color: var(--ink-1);
  font-size: 16px;
  line-height: 1.75;
  margin: 0 0 16px;
}
.fnd-bio p:last-child{ margin-bottom: 0; }
.fnd-bio strong{
  color: var(--ink-0);
  font-weight: 600;
}

/* Stats row */
.fnd-stats{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 56px;
  border: 1px solid var(--border);
}
.fnd-stat{
  background: var(--surface);
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: background .3s var(--ease);
}
.fnd-stat:hover{ background: var(--surface2); }
.fnd-stat-num{
  font-family: var(--fd);
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
  color: var(--red);
  letter-spacing: -0.02em;
}
.fnd-stat-lbl{
  font-family: var(--fd);
  font-size: 11px;
  line-height: 1.35;
  color: var(--ink-2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 500;
}

/* Certifications header */
.fnd-certs{ margin-top: 24px; }
.fnd-certs-header{
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 20px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.fnd-certs-title{
  font-family: var(--fd);
  font-size: 24px;
  font-weight: 700;
  color: var(--ink-0);
  letter-spacing: -0.01em;
  margin: 0;
}
.fnd-certs-sub{
  font-size: 13px;
  color: var(--ink-2);
  margin: 0;
}

/* Certifications grid */
.fnd-certs-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.fnd-cert{ display: block; }
.fnd-cert-link{
  display: block;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  transition: all .35s var(--ease);
  position: relative;
}
.fnd-cert-link::before{
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(200,16,46,0) 0%, rgba(200,16,46,0) 50%, rgba(200,16,46,0.15) 100%);
  opacity: 0;
  transition: opacity .35s var(--ease);
  pointer-events: none;
  z-index: 2;
}
.fnd-cert-link:hover{
  border-color: rgba(200,16,46,0.4);
  transform: translateY(-3px);
  box-shadow: 0 20px 40px -15px rgba(0,0,0,0.5);
}
.fnd-cert-link:hover::before{ opacity: 1; }

.fnd-cert-img-wrap{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #fff;
  display: grid;
  place-items: center;
}
.fnd-cert-img-wrap img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .5s var(--ease);
}
.fnd-cert-link:hover .fnd-cert-img-wrap img{
  transform: scale(1.04);
}

/* Zoom icon overlay on hover */
.fnd-cert-img-wrap::after{
  content: '⤢';
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(10,10,10,0.75);
  backdrop-filter: blur(6px);
  color: #fff;
  font-size: 15px;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: scale(.7);
  transition: all .3s var(--ease);
  z-index: 3;
  font-weight: 700;
}
.fnd-cert-link:hover .fnd-cert-img-wrap::after{
  opacity: 1;
  transform: scale(1);
}

.fnd-cert-meta{
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.fnd-cert-brand{
  font-family: var(--fd);
  font-size: 15px;
  font-weight: 700;
  color: var(--ink-0);
  letter-spacing: -0.005em;
  line-height: 1.2;
}
.fnd-cert-type{
  font-family: var(--fb);
  font-size: 11.5px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
  line-height: 1.35;
}

.fnd-certs-footer{
  text-align: center;
  margin-top: 28px;
  font-size: 12.5px;
  color: var(--ink-3);
  font-style: italic;
}

/* ───── RESPONSIVE ───── */
@media (max-width: 1040px){
  .fnd-grid{
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .fnd-portrait-col{
    position: relative;
    top: auto;
    max-width: 420px;
    margin: 0 auto;
    width: 100%;
  }
}

@media (max-width: 760px){
  #founder .section-inner{ padding: 90px 20px; }
  .fnd-stats{ grid-template-columns: repeat(2, 1fr); }
  .fnd-stat{ padding: 18px 14px; }
  .fnd-stat-num{ font-size: 28px; }
  .fnd-certs-grid{ grid-template-columns: repeat(2, 1fr); }
  .fnd-ribbon-years{ font-size: 30px; }
}

@media (max-width: 480px){
  .fnd-certs-grid{ grid-template-columns: 1fr; }
  .fnd-cert-img-wrap{ aspect-ratio: 16 / 10; }
}

/* ═══════════════════════════════════════════════════════
   CONTACT — Google Maps block + improved address
   ═══════════════════════════════════════════════════════ */

/* Enhanced address line — two-line stacked style, clickable */
.contact-address-item{ align-items: flex-start !important; }
.contact-address-item a{
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.3;
  transition: color .2s var(--ease);
}
.contact-address-item a:hover{ color: var(--red); }
.contact-address-item .addr-street{
  font-family: var(--fb);
  font-size: 14px;
  color: var(--ink-0);
  font-weight: 500;
}
.contact-address-item .addr-city{
  font-family: var(--fb);
  font-size: 12px;
  color: var(--ink-2);
  letter-spacing: 0.02em;
}

/* Map block — lives below the contact grid, full section width */
.contact-map-wrap{
  max-width: 1240px;
  margin: 80px auto 0;
  padding: 0 24px;
}

.contact-map-header{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.contact-map-label{ flex: 1; min-width: 260px; }
.contact-map-label .section-eyebrow{ margin-bottom: 10px; }
.contact-map-title{
  font-family: var(--fd);
  font-size: clamp(22px, 2.8vw, 30px);
  font-weight: 700;
  color: var(--ink-0);
  letter-spacing: -0.01em;
  margin: 0 0 6px;
  line-height: 1.1;
}
.contact-map-sub{
  font-family: var(--fb);
  font-size: 13.5px;
  color: var(--ink-2);
  margin: 0;
  letter-spacing: 0.01em;
}

.contact-map-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.map-action-btn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: 999px;
  font-family: var(--fd);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  background: var(--red);
  color: #fff;
  border: 1px solid var(--red);
  transition: all .25s var(--ease);
  white-space: nowrap;
}
.map-action-btn:hover{
  background: var(--red2);
  transform: translateY(-1px);
  box-shadow: 0 12px 30px rgba(200,16,46,0.35);
}
.map-action-btn svg{
  flex-shrink: 0;
  transition: transform .3s var(--ease);
}
.map-action-btn:hover svg{ transform: rotate(15deg); }

.map-action-ghost{
  background: transparent;
  color: var(--ink-0);
  border-color: var(--border2);
}
.map-action-ghost:hover{
  background: rgba(255,255,255,0.04);
  border-color: var(--ink-0);
  color: var(--ink-0);
  box-shadow: none;
}

/* Map frame — the actual iframe container */
.contact-map-frame{
  position: relative;
  width: 100%;
  aspect-ratio: 21 / 9;
  min-height: 380px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border2);
  background: var(--surface);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.5);
}
.contact-map-frame iframe{
  display: block;
  width: 100%;
  height: 100%;
  /* Dark-mode-ish tint — matches brand instead of bright daylight map */
  filter: grayscale(0.35) contrast(0.95) brightness(0.92);
  transition: filter .4s var(--ease);
}
.contact-map-frame:hover iframe{
  filter: grayscale(0) contrast(1) brightness(1);
}

@media (max-width: 760px){
  .contact-map-wrap{ margin-top: 56px; padding: 0 20px; }
  .contact-map-header{
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .contact-map-frame{
    aspect-ratio: 4 / 3;
    min-height: 320px;
    border-radius: 14px;
  }
  .map-action-btn{
    padding: 10px 16px;
    font-size: 11.5px;
  }
}

/* ═══════════════════════════════════════════════════════
   CONTACT — Business hours + form honeypot
   ═══════════════════════════════════════════════════════ */

/* Hours card — sits below contact-info */
.contact-hours{
  margin-top: 22px;
  padding: 20px 22px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
}

.hours-header{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.hours-title{
  font-family: var(--fd);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink-2);
}

.hours-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.hours-list li{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  font-size: 14px;
  font-family: var(--fb);
}
.hours-list .hours-day{
  color: var(--ink-0);
  font-weight: 500;
}
.hours-list .hours-time{
  color: var(--ink-1);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.hours-list .hours-closed .hours-day,
.hours-list .hours-closed .hours-time{
  color: var(--ink-3);
}

.hours-note{
  margin: 12px 0 0;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--ink-2);
  line-height: 1.5;
  font-style: italic;
}

/* Footer hours line */
.footer-hours{
  font-family: var(--fb);
  font-size: 12px;
  color: var(--ink-2);
  margin: 6px 0 0;
  letter-spacing: 0.02em;
}

/* Netlify Forms honeypot — must be visually hidden but still in the DOM */
.hp-field{
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ═══════════════════════════════════════════════════════
   INLINE GALLERY VIDEO — real video card in Galerie
   ═══════════════════════════════════════════════════════ */

/* Override the .vid-thumb static styling when it contains a real <video> */
.vid-thumb-video{
  position: relative;
  background: #000;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  min-height: 0; /* let it flex */
}

.vid-inline{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  /* Subtle brand color grading matching the site */
  filter: contrast(1.04) saturate(1.05);
  transition: transform .7s var(--ease);
}

.vid-card-live:hover .vid-inline{
  transform: scale(1.02);
}

/* "Live" pulsing badge in the corner */
.vid-live-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 8px;
  background: rgba(10,10,10,0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  font-family: var(--fd);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
  pointer-events: none;
}
.vid-live-dot{
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 0 0 rgba(200,16,46,0.7);
  animation: vidLivePulse 1.6s ease-out infinite;
}
@keyframes vidLivePulse{
  0%   { box-shadow: 0 0 0 0 rgba(200,16,46,0.7); }
  70%  { box-shadow: 0 0 0 8px rgba(200,16,46,0); }
  100% { box-shadow: 0 0 0 0 rgba(200,16,46,0); }
}

/* Enhance .vid-label so it sits on top of the video with a gradient scrim */
.vid-card-live .vid-label{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 2;
  padding: 34px 14px 14px;
  background: linear-gradient(to top, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.6) 50%, transparent 100%);
  color: #fff;
  font-family: var(--fd);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  pointer-events: none;
}

/* On small screens the card should still look great */
@media (max-width: 600px){
  .vid-thumb-video{ aspect-ratio: 9 / 16; }
  .vid-live-badge{ font-size: 9px; padding: 4px 9px 4px 7px; }
}

/* ═══════════════════════════════════════════════════════
   MOBILE FIXES — aggressive cleanups for phone viewports
   These are additive patches to ensure newer sections
   (compare, loyalty, faq, founder, map, inline videos)
   look right on narrow screens.
   ═══════════════════════════════════════════════════════ */

/* Tablet landscape — squeeze nav for the added Équipe link */
@media (max-width: 1100px){
  .nav-links{ gap: 18px; }
  .nav-link{ font-size: 13px; }
}

/* Tablet portrait */
@media (max-width: 900px){
  /* Compare cards must stack cleanly */
  .cmp2-grid{
    grid-template-columns: 1fr !important;
    gap: 24px;
    max-width: 500px;
    margin: 0 auto;
  }

  /* Founder: portrait not sticky on mobile */
  .fnd-portrait-col{
    position: static !important;
    top: auto !important;
  }

  /* Map header stacks */
  .contact-map-header{
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
  }
  .contact-map-actions{ width: 100%; }
  .map-action-btn{ flex: 1; justify-content: center; }
}

/* Phone (main target) */
@media (max-width: 640px){

  /* ---- Global padding sanity ---- */
  section .section-inner{ padding-left: 16px; padding-right: 16px; }

  /* ---- Compare cards on phone ---- */
  .cmp2-card{ padding: 28px 20px 24px; }
  .cmp2-name{ font-size: 34px; }
  .cmp2-amount{ font-size: 32px; }
  .cmp2-features li{
    padding: 11px 0;
    font-size: 13px;
    gap: 10px;
  }
  .cmp2-features li .k{ font-size: 12.5px; }
  .cmp2-header h2, .cmp2-title{ font-size: 34px !important; }
  .cmp2-sub{ font-size: 14px; padding: 0 4px; }

  /* ---- Loyalty steps — vertical stack, tighter ---- */
  .loy2-steps{
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }
  .loy2-title{ font-size: 38px !important; }
  .loy2-num{
    width: 60px !important;
    height: 60px !important;
    font-size: 22px !important;
    margin-bottom: 16px;
  }
  .loy2-benefits{
    gap: 10px !important;
    padding: 20px 0;
  }
  .loy2-benefit{ font-size: 12px; }
  .loy2-cta{ padding: 15px 26px; font-size: 12px; }

  /* ---- FAQ on phone ---- */
  .faq2-list .faq-q{
    font-size: 14.5px;
    padding: 18px 2px;
    gap: 14px;
  }
  .faq2-list .faq-a{
    font-size: 13.5px;
    padding-bottom: 18px;
  }
  .faq2-title{ font-size: 30px; }

  /* ---- Founder — all mobile ---- */
  #founder .section-inner{ padding: 70px 16px !important; }
  .fnd-title{ font-size: 40px; }
  .fnd-bio p{ font-size: 15px; line-height: 1.7; }
  .fnd-stats{ grid-template-columns: repeat(2, 1fr); }
  .fnd-stat{ padding: 16px 12px; }
  .fnd-stat-num{ font-size: 26px; }
  .fnd-stat-lbl{ font-size: 10px; }
  .fnd-certs-grid{ grid-template-columns: 1fr 1fr; gap: 12px; }
  .fnd-cert-brand{ font-size: 13px; }
  .fnd-cert-type{ font-size: 10.5px; }
  .fnd-cert-meta{ padding: 10px 12px; }
  .fnd-certs-title{ font-size: 20px; }
  .fnd-portrait-wrap{ max-width: 340px; margin: 0 auto; }
  .fnd-portrait-ribbon{
    padding: 10px 14px;
    gap: 8px;
  }
  .fnd-ribbon-years{ font-size: 26px; }
  .fnd-ribbon-label{ font-size: 9px; }

  /* ---- Contact (forms + hours + map) ---- */
  .contact-inner{
    grid-template-columns: 1fr !important;
    gap: 36px;
  }
  .contact-address-item .addr-street{ font-size: 13.5px; }
  .contact-address-item .addr-city{ font-size: 11.5px; }
  .contact-hours{ padding: 16px 18px; }
  .hours-list li{ font-size: 13px; }
  .hours-note{ font-size: 11px; }

  .contact-map-wrap{ margin-top: 40px; padding: 0 16px; }
  .contact-map-title{ font-size: 20px; }
  .contact-map-sub{ font-size: 12px; }
  .map-action-btn{
    padding: 10px 14px;
    font-size: 10.5px;
    letter-spacing: 0.08em;
  }
  .contact-map-frame{
    aspect-ratio: 3 / 4;
    min-height: 280px;
    border-radius: 12px;
  }

  /* ---- Form inputs ---- */
  .form-row{ grid-template-columns: 1fr !important; gap: 0 !important; }

  /* ---- Footer ---- */
  .footer-tagline{ font-size: 13px; padding: 0 8px; line-height: 1.5; }
  .footer-hours{ font-size: 11px; padding: 0 8px; }

  /* ---- Inline video cards in gallery ---- */
  .vid-thumb-video{ aspect-ratio: 3 / 4 !important; }
  .vid-card-live .vid-label{
    font-size: 12.5px;
    padding: 28px 12px 12px;
  }
  .vid-live-badge{
    top: 10px;
    left: 10px;
    font-size: 8.5px;
    padding: 3px 8px 3px 6px;
  }
  .vid-live-dot{ width: 6px; height: 6px; }

  /* ---- Gallery tabs — horizontal scroll instead of wrap on tiny screens ---- */
  .gtab{ font-size: 12px; padding: 8px 14px; }
}

/* Very small phones (iPhone SE etc.) */
@media (max-width: 380px){
  .cmp2-name{ font-size: 30px; }
  .cmp2-amount{ font-size: 28px; }
  .fnd-title{ font-size: 34px; }
  .fnd-certs-grid{ grid-template-columns: 1fr; }
  .fnd-stats{ grid-template-columns: repeat(2, 1fr); gap: 1px; }
  .loy2-title{ font-size: 32px !important; }
  .contact-map-frame{ aspect-ratio: 1 / 1; min-height: 260px; }
}

/* ═══════════════════════════════════════════════════════
   PRO-SHOP — Hat carousel (auto-rotating 3-angle gallery)
   ═══════════════════════════════════════════════════════ */
.shop-hat-carousel{
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #0f0f13;
  cursor: grab;
  outline: none;
}
.shop-hat-carousel:active{ cursor: grabbing; }
.shop-hat-carousel:focus-visible{
  box-shadow: inset 0 0 0 2px rgba(200,16,46,0.6);
}

.hat-img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.02);
  transition: opacity .9s var(--ease), transform 1.8s var(--ease);
  pointer-events: none;
  will-change: opacity, transform;
}
.hat-img.active{
  opacity: 1;
  transform: scale(1);
}

/* Tiny dots at the bottom */
.hat-dots{
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 3;
}
.hat-dot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.35);
  cursor: pointer;
  padding: 0;
  transition: all .3s var(--ease);
  position: relative;
}
/* Larger invisible hit target so clicks are easy */
.hat-dot::before{
  content: '';
  position: absolute;
  inset: -8px;
}
.hat-dot:hover{ background: rgba(255,255,255,0.7); transform: scale(1.15); }
.hat-dot.active{
  background: var(--red);
  width: 26px;
  border-radius: 4px;
}
.hat-dot.active:hover{ transform: none; }

/* Subtle "auto" hint — top right */
.hat-hint{
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 4px 9px;
  font-family: var(--fd);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
  pointer-events: none;
  z-index: 3;
  opacity: 0;
  transition: opacity .4s var(--ease);
}
.shop-card-hat:hover .hat-hint{ opacity: 1; }

@media (max-width: 640px){
  .hat-hint{ opacity: 1; font-size: 8.5px; }
}

/* ═══════════════════════════════════════════════════════
   MOTION: Water-drop beads on Céramique card hover
   Drops materialize + glide down, showcasing hydrophobic effect
   ═══════════════════════════════════════════════════════ */
.svc-card-ceramic{
  position: relative;
  overflow: hidden;
}
.svc-card-ceramic .bead{
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%,
      rgba(255,255,255,0.65) 0%,
      rgba(200,220,255,0.35) 35%,
      rgba(150,180,220,0.18) 65%,
      rgba(100,140,200,0.08) 100%);
  box-shadow:
    inset -1.5px -1.5px 3px rgba(30,60,100,0.3),
    inset 1.5px 1.5px 3px rgba(255,255,255,0.4),
    0 1px 3px rgba(0,0,0,0.25);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  transform: translateY(-10px) scale(0.6);
  transition: opacity .2s var(--ease);
  will-change: transform, opacity;
}

/* Positions — scattered naturally across the card */
.svc-card-ceramic .bead-1 { top: 12%;  left: 18%; width: 10px; height: 10px; }
.svc-card-ceramic .bead-2 { top: 22%;  left: 72%; width: 16px; height: 16px; }
.svc-card-ceramic .bead-3 { top: 42%;  left: 28%; width: 12px; height: 12px; }
.svc-card-ceramic .bead-4 { top: 55%;  left: 82%; width: 9px;  height: 9px;  }
.svc-card-ceramic .bead-5 { top: 18%;  left: 50%; width: 13px; height: 13px; }

/* Trigger on hover — only via explicit intent (no auto, no touch) */
@media (hover: hover) and (pointer: fine){
  .svc-card-ceramic:hover .bead{
    opacity: 1;
    animation: bead-fall 2.6s cubic-bezier(.5,.05,.8,.5) infinite;
  }
  .svc-card-ceramic:hover .bead-1 { animation-delay: 0s;    }
  .svc-card-ceramic:hover .bead-2 { animation-delay: 0.45s; }
  .svc-card-ceramic:hover .bead-3 { animation-delay: 0.9s;  }
  .svc-card-ceramic:hover .bead-4 { animation-delay: 1.3s;  }
  .svc-card-ceramic:hover .bead-5 { animation-delay: 1.75s; }
}

@keyframes bead-fall {
  0%   { opacity: 0; transform: translateY(-8px) scale(0.6); }
  10%  { opacity: 1; transform: translateY(0)    scale(1);   }
  80%  { opacity: 1; transform: translateY(110px) scale(0.95); }
  100% { opacity: 0; transform: translateY(130px) scale(0.7); }
}


/* ═══════════════════════════════════════════════════════
   MOTION: Shine sweep on Gold compare card hover
   Premium chrome-catches-light effect
   ═══════════════════════════════════════════════════════ */
.cmp2-gold{
  position: relative;
  overflow: hidden;
}
.cmp2-gold::before{
  content: '';
  position: absolute;
  top: 0;
  /* Start fully off the left edge, with enough width to sweep all the way across */
  left: -60%;
  width: 45%;
  height: 100%;
  background: linear-gradient(
    100deg,
    transparent 0%,
    transparent 35%,
    rgba(255, 215, 130, 0.06) 42%,
    rgba(255, 220, 140, 0.22) 50%,
    rgba(255, 215, 130, 0.06) 58%,
    transparent 65%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 2;
  transform: skewX(-18deg);
  transition: left 0s;
  opacity: 0;
}

@media (hover: hover) and (pointer: fine){
  .cmp2-gold:hover::before{
    opacity: 1;
    animation: shine-sweep 1.4s cubic-bezier(.35,.15,.35,1) both;
  }
}

@keyframes shine-sweep {
  0%   { left: -60%; }
  100% { left: 140%; }
}
