/** Shopify CDN: Minification failed

Line 27:158 Expected ")" to end URL token

**/

.mg-product__gallery { position: sticky; top: 100px; }
.mg-product__main { aspect-ratio: 1; background: var(--mg-black); overflow: hidden; margin-bottom: 10px; }
.mg-product__main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mg-product__thumbs { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; }
.mg-product__thumb { aspect-ratio: 1; background: var(--mg-border); overflow: hidden; cursor: pointer; opacity: 0.55; transition: opacity var(--mg-ease); border: 1px solid transparent; }
.mg-product__thumb:hover,.mg-product__thumb.is-active { opacity: 1; border-color: var(--mg-black); }
.mg-product__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mg-product__info { padding-top: 4px; }
.mg-product__vendor { font-size: 10px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--mg-gray-light); margin: 0 0 10px; display: block; }
.mg-product__title { font-size: clamp(26px,3vw,40px); font-weight: 700; letter-spacing: -0.025em; line-height: 1.1; margin: 0 0 16px; }
.mg-product__stars { display: flex; align-items: center; gap: 8px; margin: 0 0 24px; font-size: 13px; }
.mg-product__stars-val { color: var(--mg-gold); letter-spacing: 2px; font-size: 15px; }
.mg-product__stars-text { color: var(--mg-gray); }
.mg-product__price { font-size: clamp(22px,2.5vw,34px); font-weight: 700; letter-spacing: -0.02em; margin: 0 0 6px; }
.mg-product__price-note { font-size: 13px; color: var(--mg-gray); margin: 0 0 28px; }
.mg-product__desc { font-size: 15px; line-height: 1.7; color: var(--mg-gray); margin: 0 0 28px; padding-bottom: 28px; border-bottom: 1px solid var(--mg-border); }
.mg-product__includes { margin: 0 0 28px; }
.mg-product__includes-label { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mg-dark); margin: 0 0 12px; display: block; }
.mg-product__includes-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.mg-product__includes-list li { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--mg-dark); }
.mg-product__includes-list li::before { content: ''; width: 16px; height: 16px; border-radius: 50%; background: var(--mg-black) url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.5l2.5 2.5 4.5-5' stroke='%23fff' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E) center/10px no-repeat; flex-shrink: 0; }
.mg-product__form { margin-top: 4px; }
.mg-product__form .mg-btn { width: 100%; margin-bottom: 12px; }
.mg-product__guarantee { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--mg-gray); justify-content: center; }

@media (max-width: 900px) {
  .mg-product__inner { grid-template-columns: 1fr; gap: 48px; }
  .mg-product__gallery { position: static; }
}

/* S8: COMPARISON */
.mg-compare { background: var(--mg-black); color: var(--mg-white); }
.mg-compare__header { text-align: center; max-width: 560px; margin: 0 auto 56px; }
.mg-compare__header p { color: var(--mg-gray-light); margin: 0; }
.mg-compare__scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.mg-compare__table { width: 100%; border-collapse: collapse; min-width: 600px; }
.mg-compare__table thead th { padding: 0 24px 28px; text-align: center; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; vertical-align: bottom; }
.mg-compare__table thead th:first-child { text-align: left; width: 40%; }
.mg-compare__col-hero { background: var(--mg-charcoal); border-radius: 2px 2px 0 0; }
.mg-compare__badge { display: inline-block; background: var(--mg-white); color: var(--mg-black); font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; margin-bottom: 10px; }
.mg-compare__table tbody td { padding: 18px 24px; text-align: center; border-bottom: 1px solid var(--mg-border-dark); font-size: 14px; color: var(--mg-gray-light); vertical-align: middle; }
.mg-compare__table tbody td:first-child { text-align: left; font-size: 14px; font-weight: 500; color: var(--mg-white); }
.mg-compare__col-hero td { background: var(--mg-charcoal); }
.mg-check { color: var(--mg-green); font-size: 17px; font-weight: 700; }
.mg-x { color: #555; font-size: 17px; }

/* S9: REVIEWS */
.mg-reviews { background: var(--mg-white); color: var(--mg-black); }
.mg-reviews__header { text-align: center; max-width: 540px; margin: 0 auto 16px; }
.mg-reviews__agg { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 56px; flex-wrap: wrap; }
.mg-reviews__agg-stars { color: var(--mg-gold); font-size: 18px; letter-spacing: 2px; }
.mg-reviews__agg-score { font-size: 17px; font-weight: 700; }
.mg-reviews__agg-count { font-size: 13px; color: var(--mg-gray); }
.mg-reviews__agg-divider { width: 1px; height: 16px; background: var(--mg-border); }
.mg-reviews__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.mg-reviews__card { border: 1px solid var(--mg-border); padding: 28px 24px; display: flex; flex-direction: column; gap: 14px; }
.mg-reviews__card-header { display: flex; align-items: center; gap: 12px; }
.mg-reviews__avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--mg-off-white); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 700; color: var(--mg-dark); border: 1px solid var(--mg-border); }
.mg-reviews__name { font-size: 14px; font-weight: 700; color: var(--mg-black); margin: 0 0 2px; display: block; }
.mg-reviews__verified { font-size: 11px; color: var(--mg-gray); display: flex; align-items: center; gap: 4px; }
.mg-reviews__verified::before { content: '✓'; color: var(--mg-green); font-weight: 700; }
.mg-reviews__stars { color: var(--mg-gold); font-size: 12px; letter-spacing: 1px; }
.mg-reviews__title { font-size: 14px; font-weight: 700; color: var(--mg-black); margin: 0; }
.mg-reviews__text { font-size: 14px; line-height: 1.65; color: var(--mg-gray); margin: 0; flex: 1; }
.mg-reviews__cta { text-align: center; margin-top: 48px; }
@media (max-width: 900px) { .mg-reviews__grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px) { .mg-reviews__grid { grid-template-columns: 1fr; } }

/* S10: APPEARANCE ANGLE */
.mg-appear { background: var(--mg-black); color: var(--mg-white); }
.mg-appear__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; max-width: var(--mg-max); margin: 0 auto; padding: var(--mg-pad) var(--mg-gutter); }
.mg-appear__text { max-width: 520px; }
.mg-appear__heading { color: var(--mg-white); }
.mg-appear__copy { color: var(--mg-gray-light); font-size: clamp(15px,1.3vw,17px); line-height: 1.75; margin: 0 0 32px; }
.mg-appear__list { list-style: none; padding: 0; margin: 0 0 40px; display: flex; flex-direction: column; gap: 12px; }
.mg-appear__list li { display: flex; align-items: center; gap: 14px; font-size: 14px; color: var(--mg-gray-light); }
.mg-appear__list li::before { content: ''; width: 20px; height: 1px; background: rgba(255,255,255,0.4); flex-shrink: 0; }
.mg-appear__visual { position: relative; background: var(--mg-charcoal); overflow: hidden; aspect-ratio: 4/5; }
.mg-appear__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mg-appear__visual-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: var(--mg-charcoal); }
.mg-appear__stat { position: absolute; bottom: 28px; left: 28px; background: rgba(0,0,0,0.88); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid var(--mg-border-dark); padding: 18px 22px; }
.mg-appear__stat-num { font-size: 36px; font-weight: 700; letter-spacing: -0.03em; line-height: 1; color: var(--mg-white); display: block; margin-bottom: 4px; }
.mg-appear__stat-label { font-size: 11px; color: var(--mg-gray-light); letter-spacing: 0.05em; margin: 0; }
@media (max-width: 900px) { .mg-appear__inner { grid-template-columns: 1fr; gap: 48px; } .mg-appear__visual { aspect-ratio: 16/9; } }

/* S11: FAQ */
.mg-faq { background: var(--mg-off-white); color: var(--mg-black); }
.mg-faq__header { text-align: center; max-width: 520px; margin: 0 auto 56px; }
.mg-faq__header p { color: var(--mg-gray); margin: 0; }
.mg-faq__list { max-width: 740px; margin: 0 auto; border-top: 1px solid var(--mg-border); }
.mg-faq__item { border-bottom: 1px solid var(--mg-border); }
.mg-faq__q { display: flex; align-items: center; justify-content: space-between; padding: 22px 0; cursor: pointer; gap: 16px; list-style: none; font-size: 15px; font-weight: 600; color: var(--mg-black); user-select: none; transition: color var(--mg-ease); }
.mg-faq__q::-webkit-details-marker { display: none; }
.mg-faq__q:hover { color: var(--mg-charcoal); }
.mg-faq__icon { width: 18px; height: 18px; flex-shrink: 0; position: relative; }
.mg-faq__icon::before,.mg-faq__icon::after { content: ''; position: absolute; background: currentColor; top: 50%; left: 50%; transform: translate(-50%,-50%); transition: transform var(--mg-ease), opacity var(--mg-ease); }
.mg-faq__icon::before { width: 12px; height: 1.5px; }
.mg-faq__icon::after  { width: 1.5px; height: 12px; }
.mg-faq__item[open] .mg-faq__icon::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }
.mg-faq__a { padding: 0 0 22px; font-size: 14px; line-height: 1.75; color: var(--mg-gray); max-width: 640px; }

/* S12: FINAL CTA */
.mg-final-cta { background: var(--mg-black); color: var(--mg-white); text-align: center; }
.mg-final-cta__inner { max-width: 600px; margin: 0 auto; padding: var(--mg-pad) var(--mg-gutter); }
.mg-final-cta__heading { margin-bottom: 14px; }
.mg-final-cta__sub { color: var(--mg-gray-light); font-size: clamp(15px,1.4vw,17px); line-height: 1.65; margin: 0 0 40px; }
.mg-final-cta__ctas { display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap; }
.mg-final-cta__trust { margin-top: 36px; display: flex; align-items: center; justify-content: center; gap: 28px; flex-wrap: wrap; }
.mg-final-cta__trust-item { font-size: 11px; color: var(--mg-gray-light); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 6px; }