/* 🔒 GLOBAL MOBILE OVERFLOW FIX */
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

:root{
  --bg:#05010f;
  --bg-alt:#070017;
  --text:#e5e7eb;
  --muted:#9ca3af;

  --primary:#a855f7;
  --accent:#ec4899;
  --accent2:#6366f1;

  --border:rgba(255,255,255,.10);
  --card-bg:rgba(10,4,28,.66);
  --shadow-soft:0 18px 60px rgba(0,0,0,.72);
}

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

html,body{ margin:0; padding:0; }
body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:0 1.25rem;
}

/* Background particles */
#bg-particles{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0;
  pointer-events:none;
  opacity:.55;
}
.promo-bar,.site-header,main,footer{ position:relative; z-index:1; }

/* =========================================================
   PROMO BAR
   ========================================================= */
.promo-bar{
  background:linear-gradient(90deg, rgba(168,85,247,.22), rgba(236,72,153,.16), rgba(99,102,241,.14));
  border-bottom:1px solid rgba(255,255,255,.08);
}
.promo-inner{
  max-width:1120px; margin:0 auto;
  padding:.55rem 1.25rem;
  display:flex; align-items:center; gap:1rem;
}
.promo-label{
  font-size:.72rem;
  letter-spacing:.08em;
  font-weight:800;
  padding:.22rem .55rem;
  border-radius:999px;
  background:rgba(2,6,23,.6);
  border:1px solid rgba(255,255,255,.12);
}
.promo-marquee{
  overflow:hidden; flex:1;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 10%, #000 90%, transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 10%, #000 90%, transparent 100%);
}
.promo-track{
  display:inline-flex;
  gap:2rem;
  white-space:nowrap;
  will-change:transform;
  animation:marquee 18s linear infinite;
}
.promo-track span{
  font-size:.86rem;
  color:rgba(229,231,235,.9);
}
@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky; top:0;
  background:rgba(5,1,15,.72);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 0; gap:1rem;
}
.logo{ display:flex; align-items:center; gap:.75rem; min-width:220px; }
.logo-title{ font-weight:800; font-size:1rem; }
.logo-sub{
  display:block;
  font-size:.75rem;
  color:rgba(229,231,235,.65);
  margin-top:2px;
}
.main-nav{ display:flex; gap:1rem; flex-wrap:wrap; }
.main-nav a{
  color:rgba(229,231,235,.82);
  font-size:.92rem;
  padding:.35rem .4rem;
  border-radius:.65rem;
}
.main-nav a:hover{
  background:rgba(255,255,255,.06);
  color:#fff;
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px;
  padding:.55rem 1.1rem;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:var(--text);
  font-weight:750;
  font-size:.92rem;
  cursor:pointer;
  white-space:nowrap;
  transition:transform 150ms ease, box-shadow 150ms ease, filter 150ms ease, border-color 150ms ease, background 150ms ease;
}
.btn-primary{
  background-image:linear-gradient(135deg, var(--primary), var(--accent), var(--accent2));
  color:#0b1120;
  box-shadow:0 16px 35px rgba(168,85,247,.22);
}
.btn-outline{
  background:transparent;
  border-color:rgba(148,163,184,.25);
}
.btn-ghost{
  background:transparent;
  border-color:transparent;
  color:var(--muted);
}
.btn-sm{ padding:.35rem .75rem; font-size:.82rem; }

.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 22px 45px rgba(236,72,153,.28);
  filter:brightness(1.05);
}
.btn-outline:hover{ border-color:var(--primary); }
.btn-ghost:hover{ color:var(--text); }

/* =========================================================
   SECTIONS
   ========================================================= */
.section{ padding:64px 0; }
.section-header{ margin-bottom:1.2rem; }
.section-header h2{ margin:0; font-size:1.6rem; }
.section-header p{ margin:.45rem 0 0; color:rgba(229,231,235,.72); }
.section-header-row{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:1.5rem; flex-wrap:wrap;
}
.muted{ color:var(--muted); font-size:.9rem; }
.small-note{ margin-top:8px; }

/* =========================================================
   HERO
   ========================================================= */
.hero-premium{
  position:relative;
  padding:96px 0 70px;
  background:
    radial-gradient(circle at 12% 18%, rgba(168,85,247,.30), rgba(5,1,15,0) 45%),
    radial-gradient(circle at 82% 12%, rgba(236,72,153,.22), rgba(5,1,15,0) 50%),
    radial-gradient(circle at 55% 75%, rgba(99,102,241,.18), rgba(5,1,15,0) 60%),
    var(--bg);
}
.hero-premium-bg{
  position:absolute; inset:-20%;
  background:
    radial-gradient(circle at 20% 20%, rgba(168,85,247,.22), transparent 55%),
    radial-gradient(circle at 85% 15%, rgba(236,72,153,.18), transparent 60%),
    radial-gradient(circle at 60% 85%, rgba(99,102,241,.14), transparent 62%);
  pointer-events:none;
  filter:blur(2px);
}

.hero-premium-inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:42px;
  align-items:stretch;
}
.hero-premium-left{ align-self:center; }
.hero-premium-right{ align-self:stretch; width:100%; max-width:none; }

.hero-premium-pill{
  display:inline-block;
  padding:7px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.9);
  font-size:13px;
}

.hero-premium-title{
  margin:18px 0 0;
  font-size:52px;
  line-height:1.08;
  letter-spacing:-.02em;
}
.hero-premium-highlight{ color:var(--accent); }

.hero-premium-sub{
  margin:18px 0 0;
  max-width:54ch;
  color:rgba(229,231,235,.86);
}
.hero-premium-chips{
  margin-top:16px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.hero-premium-chips .chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  font-size:13px;
  color:rgba(255,255,255,.88);
}
.hero-premium-actions{
  margin-top:22px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* HERO RIGHT CARD + LOGO MARQUEE */
.hero-logos-card{
  height:100%;
  border-radius:26px;
  padding:22px;
  background:
    radial-gradient(circle at 20% 20%, rgba(168,85,247,.18), transparent 55%),
    radial-gradient(circle at 90% 0%, rgba(236,72,153,.14), transparent 52%),
    rgba(10,4,28,.60);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 28px 80px rgba(0,0,0,.75);
  backdrop-filter:blur(16px);
}
.hero-logos-card--big{ min-height:360px; }

.hero-logos-kicker{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(229,231,235,.78);
}
.hero-logos-title{ margin:10px 0 0; font-size:20px; font-weight:850; }
.hero-logos-sub{ margin:8px 0 0; color:rgba(229,231,235,.78); font-size:13px; }

.logo-marquee{
  margin-top:16px;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(2,6,23,.35);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.logo-track{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px;
  width:max-content;
  will-change:transform;
  animation:logoScroll 22s linear infinite;
}
@keyframes logoScroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
.logo-item{
  display:flex; align-items:center; justify-content:center;
  height:54px;
  min-width:128px;
  padding:10px 14px;
  border-radius:14px;
  background:rgba(5,1,15,.55);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 10px 24px rgba(0,0,0,.45);
}
.logo-item img{
  height:26px;
  width:auto;
  display:block;
  opacity:.96;
}
.logo-pill{
  font-weight:800;
  font-size:13px;
  letter-spacing:.01em;
  color:rgba(229,231,235,.92);
  background:linear-gradient(135deg, rgba(168,85,247,.22), rgba(236,72,153,.16));
  border-color:rgba(168,85,247,.30);
}
.hero-logos-badges{ margin-top:16px; display:flex; flex-wrap:wrap; gap:10px; }
.mini-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:13px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:rgba(229,231,235,.90);
}
@media (prefers-reduced-motion: reduce){
  .promo-track{ animation:none !important; }
  .logo-track{ animation:none !important; }
}

/* =========================================================
   TRUST (FULL RESTORE)
   ========================================================= */
.trust-pro{
  padding:54px 0 30px;
  background:
    radial-gradient(circle at 15% 15%, rgba(168,85,247,.20), transparent 60%),
    radial-gradient(circle at 85% 15%, rgba(236,72,153,.14), transparent 60%),
    rgba(5,1,15,.2);
}
.trust-pro-wrap{
  border-radius:26px;
  padding:22px;
  background:rgba(10,4,28,.55);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 26px 85px rgba(0,0,0,.55);
  backdrop-filter:blur(14px);
}
.trust-pro-header h2{ margin:0; font-size:1.5rem; font-weight:900; }
.trust-pro-header p{ margin:.45rem 0 0; color:rgba(229,231,235,.75); }

.trust-pro-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
  align-items:stretch;
}
.trust-pro-card{
  border-radius:22px;
  padding:16px;
  background:
    radial-gradient(circle at 20% 20%, rgba(168,85,247,.16), transparent 60%),
    rgba(2,6,23,.45);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 45px rgba(0,0,0,.55);
}
.trust-icon{
  width:40px; height:40px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, rgba(168,85,247,.22), rgba(236,72,153,.14));
  border:1px solid rgba(168,85,247,.28);
  margin-bottom:10px;
}
.trust-pro-value{
  font-size:28px;
  font-weight:900;
  letter-spacing:-.02em;
}
.trust-pro-label{ margin-top:2px; font-weight:800; }
.trust-pro-sub{ margin-top:4px; color:rgba(229,231,235,.70); font-size:13px; }

.trust-pro-strip{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* ✅ BASE strip pill (used everywhere: trust/footer/contact/etc) */
.strip-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(229,231,235,.86);
  font-size:13px;
}

/* =========================================================
   PRODUCTS
   ========================================================= */
.products-controls-row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.search-input{
  width:min(340px, 90vw);
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(2,6,23,.55);
  color:var(--text);
  outline:none;
}
.search-input:focus{
  border-color:rgba(168,85,247,.55);
  box-shadow:0 0 0 4px rgba(168,85,247,.16);
}

/* nicer dropdown */
.select-wrap{ position:relative; display:inline-flex; align-items:center; }
.sort-select{
  appearance:none;
  padding:12px 44px 12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 20% 20%, rgba(168,85,247,.14), transparent 60%),
    rgba(2,6,23,.55);
  color:var(--text);
  font-weight:750;
  outline:none;
  cursor:pointer;
}
.sort-select:focus{
  border-color:rgba(236,72,153,.55);
  box-shadow:0 0 0 4px rgba(236,72,153,.14);
}
.select-caret{
  position:absolute;
  right:14px;
  pointer-events:none;
  color:rgba(229,231,235,.75);
  font-size:14px;
}

/* categories */
.category-list{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-bottom:1rem;
}
.category-pill{
  border-radius:999px;
  padding:.50rem 1rem;
  font-size:.85rem;
  background:rgba(2,6,23,.55);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(229,231,235,.88);
  cursor:pointer;
  transition:transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
}
.category-pill:hover{
  transform:translateY(-2px);
  border-color:rgba(168,85,247,.55);
  box-shadow:0 12px 34px rgba(0,0,0,.55);
}
.category-pill.active{
  background:linear-gradient(135deg, rgba(168,85,247,.85), rgba(236,72,153,.70));
  border-color:transparent;
  color:#0b1120;
  font-weight:900;
}

/* product cards */
.product-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1rem;
}

.product-card{
  border-radius:22px;
  overflow:hidden;
  background:
    radial-gradient(circle at 0 0, rgba(168,85,247,.16), transparent 55%),
    radial-gradient(circle at 100% 0, rgba(236,72,153,.12), transparent 55%),
    rgba(10,4,28,.66);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow-soft);
  display:flex;
  flex-direction:column;
  min-height:100%;
  transition:transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, filter 180ms ease;
}
.product-card:hover{
  transform:translateY(-8px);
  border-color:rgba(168,85,247,.35);
  box-shadow:0 32px 90px rgba(0,0,0,.88);
  filter:saturate(1.05);
}

/* IMPORTANT: do not tint/fade images */
.product-media{ position:relative; }
.product-media img{
  width:100%;
  height:210px;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
  filter:none !important;
}
.product-media::after{ content:none !important; }

.product-badge{
  position:absolute;
  top:.6rem; left:.6rem;
  font-size:.75rem;
  padding:.25rem .55rem;
  border-radius:999px;
  background:rgba(5,1,15,.55);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  color:rgba(229,231,235,.92);
  z-index:2;
}
.product-ribbon{
  position:absolute;
  top:10px;
  right:10px;
  padding:7px 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.01em;
  color:#0b1120;
  background-image:linear-gradient(135deg, rgba(168,85,247,.95), rgba(236,72,153,.85));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 14px 35px rgba(0,0,0,.55);
  z-index:2;
}

/* body uses flex to pin buttons */
.product-body{
  padding:14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
  min-height:0;
}
.product-title{ font-size:1.02rem; line-height:1.2; font-weight:850; }
.product-category{ font-size:.8rem; color:rgba(229,231,235,.70); }
.product-desc{
  color:rgba(229,231,235,.70);
  font-size:.86rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* tags */
.product-tags{ display:flex; flex-wrap:wrap; gap:8px; }
.tag{
  font-size:12px;
  font-weight:800;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(229,231,235,.86);
}
.tag.hot{
  background:linear-gradient(135deg, rgba(168,85,247,.22), rgba(236,72,153,.16));
  border-color:rgba(168,85,247,.25);
}

/* meta */
.product-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.product-price{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(168,85,247,.24), rgba(236,72,153,.18));
  border:1px solid rgba(168,85,247,.30);
  font-weight:900;
}
.product-duration{ font-size:.78rem; color:rgba(229,231,235,.68); }

/* FIX: buttons always aligned at bottom */
.product-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:auto; /* pin to bottom */
  padding-top:6px;
}
.product-actions .btn{
  width:100%;
  min-height:44px; /* consistent height */
}

/* =========================================================
   HOW IT WORKS + CONTACT
   ========================================================= */
.steps-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:1rem; }
.step-card{
  border-radius:1rem;
  background:rgba(10,4,28,.55);
  border:1px solid rgba(255,255,255,.10);
  padding:.95rem;
  box-shadow:0 8px 24px rgba(0,0,0,.55);
}
.step-number{
  display:inline-flex;
  width:28px; height:28px;
  margin-bottom:.4rem;
  border-radius:999px;
  align-items:center; justify-content:center;
  background:rgba(168,85,247,.18);
  font-size:.85rem;
}

.contact-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:1rem; }
.contact-card{
  border-radius:1rem;
  background:rgba(10,4,28,.55);
  border:1px solid rgba(255,255,255,.10);
  padding:.95rem;
  box-shadow:0 8px 24px rgba(0,0,0,.5);
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:var(--bg-alt);
  padding:1.1rem 0;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.footer-inner h3{ margin:0 0 .2rem; font-size:1rem; }
.footer-inner p{ margin:0; }
.empty-state{ text-align:center; padding-top:1rem; color:var(--muted); }

/* =========================================================
   RESPONSIVE (Phone / Tablet / iPad / PC / TV)
   ========================================================= */
@media (max-width: 980px){
  .hero-premium-inner{ grid-template-columns:1fr; }
  .hero-premium-title{ font-size:42px; }
  .hero-logos-card--big{ min-height:auto; }
  .product-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px){
  .product-grid{ grid-template-columns:1fr; }
  .trust-pro-grid{ grid-template-columns:1fr; }
  .steps-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .product-actions{ grid-template-columns:1fr; }
}
@media (min-width: 1400px){
  /* nicer spacing for very large screens / TVs */
  .container{ max-width:1280px; }
  .hero-premium-title{ font-size:58px; }
}

/* =========================================================
   FLOATING WHATSAPP BUTTON
   ========================================================= */
.whatsapp-float{
  position:fixed;
  left:18px;
  bottom:18px;
  width:58px;
  height:58px;
  border-radius:50%;
  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:99999;
  box-shadow:
    0 0 0 0 rgba(37,211,102,.55),
    0 18px 45px rgba(0,0,0,.65);
  animation:whatsapp-pulse 2.2s infinite;
  transition:transform 150ms ease, box-shadow 150ms ease, opacity 200ms ease;
}
.whatsapp-float img{ width:30px; height:30px; filter:brightness(1.1); }
.whatsapp-float:hover{
  transform:scale(1.08);
  box-shadow:
    0 0 0 12px rgba(37,211,102,0),
    0 22px 55px rgba(0,0,0,.75);
}
.whatsapp-online{
  position:absolute;
  top:6px;
  right:6px;
  width:13px;
  height:13px;
  border-radius:50%;
  border:2px solid #fff;
  transition:background 200ms ease, box-shadow 200ms ease, opacity 200ms ease;
}
.whatsapp-online.online{
  background:#25D366;
  box-shadow:
    0 0 0 2px rgba(37,211,102,.35),
    0 0 10px rgba(37,211,102,.95);
}
.whatsapp-online.offline{
  background:#9ca3af;
  box-shadow:none;
  opacity:.85;
}
.whatsapp-tooltip{
  position:absolute;
  left:70px;
  background:rgba(10,4,28,.9);
  color:#fff;
  padding:6px 12px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
  opacity:0;
  transform:translateX(-6px);
  pointer-events:none;
  border:1px solid rgba(255,255,255,.12);
  transition:all 180ms ease;
}
.whatsapp-float:hover .whatsapp-tooltip{
  opacity:1;
  transform:translateX(0);
}
@keyframes whatsapp-pulse{
  0%{
    box-shadow:
      0 0 0 0 rgba(37,211,102,.55),
      0 18px 45px rgba(0,0,0,.65);
  }
  70%{
    box-shadow:
      0 0 0 18px rgba(37,211,102,0),
      0 18px 45px rgba(0,0,0,.65);
  }
  100%{
    box-shadow:
      0 0 0 0 rgba(37,211,102,0),
      0 18px 45px rgba(0,0,0,.65);
  }
}

/* =========================================================
   FAKE ORDER TOAST (bottom-right)
   ========================================================= */
.order-toast{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:99997;
  width:min(360px, calc(100vw - 36px));
  border-radius:18px;
  padding:12px 12px;
  background:
    radial-gradient(circle at 15% 20%, rgba(168,85,247,.20), transparent 60%),
    radial-gradient(circle at 85% 0%, rgba(236,72,153,.16), transparent 60%),
    rgba(10,4,28,.72);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 22px 70px rgba(0,0,0,.70);
  backdrop-filter:blur(14px);
  color:rgba(229,231,235,.92);

  transform:translateY(18px);
  opacity:0;
  pointer-events:none;
  transition:transform 240ms ease, opacity 240ms ease;
}

.order-toast.show{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}

.order-toast-inner{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.order-toast-img{
  width:46px;
  height:46px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(2,6,23,.45);
  flex:0 0 auto;
}
.order-toast-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.order-toast-body{ flex:1; min-width:0; }
.order-toast-title{
  font-weight:900;
  font-size:13px;
  line-height:1.25;
  margin:0;
  color:#fff;
}
.order-toast-sub{
  margin:4px 0 0;
  font-size:12px;
  color:rgba(229,231,235,.78);
}
.order-toast-meta{
  margin-top:8px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.order-toast-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:850;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(229,231,235,.86);
}

.order-toast-close{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:rgba(229,231,235,.9);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex:0 0 auto;
  transition:transform 160ms ease, filter 160ms ease, border-color 160ms ease;
}
.order-toast-close:hover{
  transform:translateY(-1px);
  border-color:rgba(168,85,247,.45);
  filter:brightness(1.05);
}

/* keep it above whatsapp button on small screens */
@media (max-width:560px){
  .order-toast{ right:12px; bottom:88px; width:min(360px, calc(100vw - 24px)); }
}

/* =========================================================
   FAKE ORDER TOAST – SMALL VERSION (OVERRIDE)
   ========================================================= */
.order-toast{
  width: min(300px, calc(100vw - 36px));
  padding:10px;
  border-radius:14px;
}

.order-toast-inner{
  gap:10px;
}

.order-toast-img{
  width:38px;
  height:38px;
  border-radius:10px;
}

.order-toast-title{
  font-size:12.5px;
  line-height:1.25;
}

.order-toast-sub{
  font-size:11.5px;
}

.order-toast-meta{
  margin-top:6px;
  gap:6px;
}

.order-toast-pill{
  padding:4px 8px;
  font-size:11px;
}

.order-toast-close{
  width:28px;
  height:28px;
  font-size:13px;
}

/* mobile: even tighter */
@media (max-width:560px){
  .order-toast{
    width: min(280px, calc(100vw - 24px));
    bottom:86px; /* still above WhatsApp */
  }
}

/* ===============================
   HERO LOGO IMAGE PERFECT FIT
   =============================== */
.hero-logos-card .logo-item{
  width: 110px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-logos-card .logo-item img{
  width: 100%;
  height: 100%;
  object-fit: contain; /* keeps logo clean, no crop */
  display: block;
}

/* Optional: slightly bigger on desktop */
@media (min-width: 1024px){
  .hero-logos-card .logo-item{
    width: 120px;
    height: 70px;
  }
}

/* ===============================
   HERO BANNER LOGOS: FULL FIT FIX
   (only affects the hero marquee)
   =============================== */

/* remove the extra inner space that makes logos look small */
.hero-logos-card .logo-track .logo-item{
  padding: 0 !important;              /* key fix */
  min-width: 140px !important;        /* a bit wider */
  height: 62px !important;            /* a bit taller */
  overflow: hidden !important;
}

/* make images truly fill the box */
.hero-logos-card .logo-track .logo-item img{
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;       /* fills the box */
  object-position: center !important;
  display: block !important;
}

/* responsive sizes */
@media (max-width: 560px){
  .hero-logos-card .logo-track .logo-item{
    min-width: 130px !important;
    height: 58px !important;
  }
}

.lux-btn {
  display: inline-block;
  padding: 14px 36px;
  background: linear-gradient(135deg, #b11226, #e10600);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  border-radius: 50px;
  text-decoration: none;
  box-shadow: 0 10px 30px rgba(225, 6, 0, 0.35);
  transition: all 0.35s ease;
  position: relative;
  overflow: hidden;
}

/* Shine effect */
.lux-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: rgba(255, 255, 255, 0.25);
  transform: skewX(-25deg);
  transition: all 0.6s ease;
}

.lux-btn:hover::before {
  left: 130%;
}

/* Hover animation */
.lux-btn:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 18px 40px rgba(225, 6, 0, 0.55);
}

/* Click effect */
.lux-btn:active {
  transform: scale(0.96);
}

/* ✅ MOBILE FIX: remove right-side extra space (horizontal overflow) */
html, body {
  width: 100%;
  overflow-x: hidden !important;
}

/* common overflow sources */
.promo-bar,
.promo-inner,
.promo-marquee,
.logo-marquee,
.hero,
.hero-premium,
.hero-premium-inner,
.site-header {
  overflow-x: hidden;
}

/* ensure marquee tracks never create page width */
.promo-track,
.logo-track {
  will-change: transform;
}

/* ===============================
   MOBILE OVERFLOW FIX (IMPORTANT)
   =============================== */
html, body { overflow-x: hidden !important; width: 100%; }

/* Hero background can create overflow because it's inset:-20% */
.hero-premium { overflow: hidden; }

/* Make sure absolute glow layer doesn't expand page width */
.hero-premium-bg { left: 0; right: 0; }

/* Safety: any media shouldn't exceed screen */
img, video, canvas { max-width: 100%; height: auto; }

/* Marquee tracks can cause overflow on some browsers */
.promo-marquee, .logo-marquee { overflow: hidden; }

/* ===============================
   MOBILE MENU (Hamburger)
   =============================== */
.menu-btn{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(10,4,28,.55);
  color:rgba(229,231,235,.92);
  font-size:20px;
  font-weight:900;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}

@media (max-width: 900px){
  .menu-btn{ display:inline-flex; }
  .site-header{ position:sticky; }
  .header-inner{ position:relative; }

  /* hide nav until menu opened */
  .main-nav{
    display:none;
    position:absolute;
    top:100%;
    left:0; right:0;
    padding:12px;
    background:rgba(5,1,15,.92);
    border-bottom:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(16px);
    flex-direction:column;
    gap:8px;
    z-index:99999;
  }

  .site-header.nav-open .main-nav{ display:flex; }

  .main-nav a{
    padding:12px 12px;
    border-radius:14px;
    background:rgba(255,255,255,.04);
  }
}
