/* BAND SECTION */
.band { background: var(--dk); padding: 1.5rem 0; overflow: hidden; margin: 2rem 0; }
.band-track { display: flex; gap: 2rem; animation: scroll 20s linear infinite; white-space: nowrap; font-family: var(--fd); font-size: 1.2rem; font-weight: 700; color: var(--lime); letter-spacing: .1em; }
@keyframes scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.band-track:hover { animation-play-state: paused; }

/* HERO SECTION */
.hero { background: linear-gradient(135deg, var(--mid) 0%, var(--dk) 100%); padding: 4rem 0; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; top: -50%; right: -10%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(200,245,58,.08) 0%, transparent 70%); border-radius: 50%; }
.hero::after { content: 'SPRITE'; position: absolute; font-family: var(--fd); font-size: 14vw; color: rgba(200,245,58,.02); bottom: -20px; right: -20px; letter-spacing: .1em; line-height: 1; }
.hero-tag { font-size: .75rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; color: var(--lime); margin-bottom: .8rem; }
.hero-title { font-family: var(--fd); font-size: clamp(3rem, 6vw, 5.5rem); letter-spacing: .05em; color: #fff; line-height: 1.1; margin-bottom: 1rem; }
.hero-title .hl { color: var(--lime); }
.hero-sub { font-size: 1rem; line-height: 1.8; color: #a8d4b8; margin-bottom: 2rem; }
.hero-stats { display: flex; gap: 3rem; margin-top: 2rem; }
.hero-stat-num { font-family: var(--fd); font-size: 2rem; font-weight: 900; color: var(--lime); }
.hero-stat-label { font-size: .85rem; color: #8ab894; margin-top: .2rem; }
.hero-can { object-fit: contain; animation: float 3.5s ease-in-out infinite; }
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-20px); } }
.hb { position: absolute; border-radius: 50%; opacity: .08; background: radial-gradient(circle at 30% 30%, #fff, transparent); }
.hb:nth-child(1) { width: 300px; height: 300px; top: 10%; left: 10%; }
.hb:nth-child(2) { width: 200px; height: 200px; bottom: 20%; right: 15%; }
.hb:nth-child(3) { width: 150px; height: 150px; top: 40%; right: 5%; }
.hero-glow { position: absolute; width: 200px; height: 200px; background: radial-gradient(circle, rgba(0,166,81,.2) 0%, transparent 70%); border-radius: 50%; bottom: 10%; }

/* FLAVOR CARDS */
.fc { background: #fff; border-radius: 12px; overflow: hidden; border: 1.5px solid var(--br); transition: transform .3s, box-shadow .3s; }
.fc:hover { transform: translateY(-8px); box-shadow: 0 12px 36px rgba(0,166,81,.18); }
.fb { height: 160px; display: flex; align-items: center; justify-content: center; position: relative; padding: 1.5rem; }
.fb.green { background: linear-gradient(135deg, #004d24, #00a651); }
.fb.dark { background: linear-gradient(135deg, #1a1a2e, #3a3a8a); }
.fb.red { background: linear-gradient(135deg, #7b0f0f, #c0392b); }
.fb.orange { background: linear-gradient(135deg, #b94f00, #e67e22); }
.fb.pink { background: linear-gradient(135deg, #880040, #e91e8c); }
.fb.purple { background: linear-gradient(135deg, #3d1a5c, #8e44ad); }
.fcan { max-height: 120px; max-width: 80px; object-fit: contain; filter: drop-shadow(0 8px 16px rgba(0,0,0,.3)); }
.fbod { padding: 1.2rem; }
.fn { font-family: var(--fd); font-size: 1.1rem; color: var(--dk); margin-bottom: .4rem; }
.fd2 { font-size: .8rem; color: var(--mu); line-height: 1.5; margin-bottom: .8rem; }
.fl { display: inline-block; font-size: .8rem; font-weight: 700; color: var(--g); text-decoration: none; transition: gap .2s; }
.fl:hover { color: var(--gd); }

/* PRODUCT CARDS */
.pc { background: #fff; border-radius: 12px; overflow: hidden; border: 1.5px solid var(--br); transition: transform .3s, box-shadow .3s; display: flex; flex-direction: column; }
.pc:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(0,166,81,.15); }
.piw { height: 200px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.piw::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.08) 0%, transparent 60%); pointer-events: none; }
.pcan { max-height: 150px; max-width: 100px; object-fit: contain; filter: drop-shadow(0 8px 16px rgba(0,0,0,.3)); transition: transform .3s; position: relative; z-index: 2; }
.pc:hover .pcan { transform: scale(1.08) rotate(-2deg); }
.pbadge { position: absolute; top: .8rem; left: .8rem; font-size: .65rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: .25rem .7rem; border-radius: 4px; color: #fff; z-index: 3; }
.pbadge.new { background: #00a651; }
.pbadge.sale { background: #c0392b; }
.pbadge.hit { background: #f39c12; }
.pa { position: absolute; bottom: 1rem; left: 0; right: 0; display: flex; gap: .6rem; justify-content: center; opacity: 0; transform: translateY(20px); transition: opacity .3s, transform .3s; z-index: 2; }
.pc:hover .pa { opacity: 1; transform: translateY(0); }
.ba { background: var(--g); color: #fff; border: none; border-radius: 8px; padding: .6rem 1.2rem; font-size: .75rem; font-weight: 700; cursor: pointer; transition: background .2s; }
.ba:hover { background: var(--gd); }
.bw { background: transparent; border: 1.5px solid var(--br); color: var(--g); width: 40px; height: 40px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s, color .2s; }
.bw:hover { background: var(--g); color: #fff; border-color: var(--g); }
.pb { padding: 1rem; display: flex; flex-direction: column; flex: 1; }
.pbr { font-size: .7rem; color: var(--mu); text-transform: uppercase; margin-bottom: .3rem; }
.pn { font-family: var(--fd); font-size: 1.15rem; color: var(--dk); margin-bottom: .3rem; line-height: 1.2; }
.pv { font-size: .8rem; color: var(--mu); margin-bottom: .8rem; }
.stars { font-size: .9rem; color: #f39c12; }
.pp { font-size: 1.2rem; font-weight: 800; color: var(--dk); }
.pps { text-decoration: line-through; color: #999; font-weight: 400; margin-right: .5rem; }
.ppo { font-weight: 800; }

/* PROMO SECTION */
.promo { background: linear-gradient(135deg, var(--mid) 0%, var(--dk) 100%); color: #fff; position: relative; overflow: hidden; }
.plabel { font-size: .75rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; color: var(--lime); margin-bottom: .8rem; }
.ptitle { font-family: var(--fd); font-size: clamp(2.5rem, 5vw, 4rem); letter-spacing: .06em; line-height: 1.1; }
.pdesc { font-size: .95rem; line-height: 1.7; color: #a8d4b8; margin-bottom: 2rem; }
.cd { display: flex; gap: 1.5rem; margin: 2rem 0; }
.cdu { display: flex; flex-direction: column; align-items: center; background: rgba(255,255,255,.08); padding: 1rem 1.5rem; border-radius: 8px; }
.cdn { font-family: var(--fd); font-size: 2.2rem; font-weight: 900; color: var(--lime); line-height: 1; }
.cdl { font-size: .75rem; color: #a8d4b8; text-transform: uppercase; margin-top: .4rem; }
.lime { color: var(--lime); }

/* PACKS SECTION */
.pkc { background: #fff; border-radius: 12px; border: 1.5px solid var(--br); padding: 2rem; text-align: center; transition: transform .3s; position: relative; }
.pkc:hover { transform: translateY(-8px); box-shadow: 0 12px 36px rgba(0,166,81,.15); }
.pkc.feat { background: linear-gradient(135deg, var(--off) 0%, #fff 100%); border: 2px solid var(--g); }
.pktop { display: inline-block; background: var(--ld); color: var(--dk); font-size: .65rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: .4rem .8rem; border-radius: 50px; margin-bottom: 1rem; }
.pki { height: 120px; width: auto; object-fit: contain; margin-bottom: 1rem; }
.pkn { font-family: var(--fd); font-size: 1.5rem; color: var(--dk); margin-bottom: .4rem; }
.pkd { font-size: .85rem; color: var(--mu); margin-bottom: 1rem; }
.pkp { font-size: 1.8rem; font-weight: 800; color: var(--g); margin-bottom: 1.5rem; }
.pkp small { font-size: .7rem; color: var(--mu); font-weight: 400; }
.pkf { list-style: none; margin-bottom: 1.5rem; }
.pkf li { font-size: .85rem; color: var(--dk); margin-bottom: .6rem; }
.pkf i { color: var(--g); margin-right: .6rem; }

/* NEWSLETTER */
.nls { background: linear-gradient(135deg, var(--dk) 0%, var(--mid) 100%); }
.nli { background: #fff; border: none; border-radius: 8px 0 0 8px; padding: .9rem 1.5rem; flex: 1; font-size: .9rem; font-family: var(--fb); }
.nli:focus { outline: none; box-shadow: 0 0 0 3px rgba(0,166,81,.3); }
.nlb { background: var(--g); color: #fff; border: none; border-radius: 0 8px 8px 0; padding: .9rem 1.8rem; font-weight: 800; font-size: .85rem; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.nlb:hover { background: var(--gd); }

/* ADVANTAGES */
.fbox { background: #fff; border: 1.5px solid var(--br); border-radius: 12px; padding: 2rem 1.5rem; transition: transform .3s, box-shadow .3s; }
.fbox:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(0,166,81,.15); }
.ficon { display: block; font-size: 2.5rem; margin-bottom: 1rem; }
.ftit { font-family: var(--fd); font-size: 1.2rem; color: var(--dk); margin-bottom: .6rem; }
.fdesc { font-size: .85rem; color: var(--mu); line-height: 1.6; }

/* UTILITIES */
.dlime { width: 60px; height: 4px; background: var(--lime); }
.ey { font-size: .75rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; color: var(--ld); }
.st { font-family: var(--fd); font-size: clamp(2rem, 4vw, 3.5rem); letter-spacing: .06em; color: var(--dk); line-height: 1.1; }
.alt { color: var(--g); }

@media (max-width: 768px) {
  .hero-stats { flex-direction: column; gap: 1.5rem; }
  .pkc { margin-bottom: 1rem; }
  .cd { flex-direction: column; }
}
