/* ============================================================
   MEETS GREAT SHOTS — cream panel + teal band + ribbon
   ============================================================ */
.mgs { position: relative; background: var(--pd-cream); padding-top: clamp(10px, 1.2vw, 18px); }
.mgs-burst { filter: drop-shadow(0 1px 1px rgba(44,44,44,.12)); }

/* ---------- Cream headline panel ---------- */
.mgs__top {
  position: relative; overflow: hidden;
  background: var(--pd-cream) url('assets/section2-backdrop.webp') no-repeat 48px center / 100% 100%;
  display: grid; grid-template-columns: 1.05fr 1fr; align-items: center;
  padding: clamp(0.8rem,1.6vw,1.4rem) 0 clamp(0.8rem,1.6vw,1.4rem) clamp(92px,9.5vw,178px);
  aspect-ratio: 1505 / 532;
  min-height: 0;
  border-bottom: 12px solid var(--pd-teal);
}
.mgs__copy { position: relative; z-index: 2; max-width: 600px; padding-right: 30px; }
.mgs__eyebrow {
  position: relative; display: inline-block;
  font-family: var(--font-script); color: var(--pd-red);
  font-size: clamp(1.9rem,3.2vw,2.8rem); line-height: 1; margin-left: 4px;
}
.mgs__title {
  font-family: var(--font-display); font-weight: 800; color: var(--pd-teal-dark);
  font-size: clamp(4rem,7.8vw,6.8rem); line-height: .9; letter-spacing: .01em; margin: 2px 0 0;
}
.mgs__script {
  position: relative; display: inline-block;
  font-family: var(--font-script); color: var(--pd-teal-dark);
  font-size: clamp(3.6rem,7.2vw,6.2rem); line-height: 1; margin: 0;
  text-shadow: 3px 3px 0 var(--pd-red);
}
.mgs__p {
  font-family: var(--font-body); color: var(--pd-ink); line-height: 1.45;
  max-width: 44ch; margin: 12px 0 0; font-weight: 500; font-size: clamp(.9rem,1vw,1rem);
}
.mgs__p--2 { margin-top: 8px; margin-bottom: 14px; }
.mgs__cta {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--pd-red); color: #fff; border: none;
  font-family: var(--font-label); font-weight: 900; text-transform: uppercase; letter-spacing: .08em;
  font-size: .95rem; padding: 15px 34px; white-space: nowrap;
  box-shadow: var(--pd-shadow-sm); cursor: pointer;
  clip-path: polygon(4% 0, 96% 0, 100% 50%, 96% 100%, 4% 100%, 0 50%);
  transition: background .18s ease, transform .12s ease;
}
.mgs__cta:hover { background: var(--pd-red-dark); }
.mgs__cta:active { transform: scale(.97); }

/* ---------- Teal feature band ---------- */
.mgs__band { position: relative; background: var(--pd-teal); padding: clamp(2.2rem,4vw,3.4rem) clamp(24px,5vw,72px) 0; margin-top: clamp(14px,1.6vw,22px); }
.mgs__grain {
  position: absolute; inset: 0; pointer-events: none; z-index: 5;
  background-image: url("assets/grain.png?v=3");
  background-size: 220px 220px; background-repeat: repeat; opacity: .22;
}
.mgs__vig {
  position: absolute; inset: 0; pointer-events: none; z-index: 6;
  background: radial-gradient(110% 96% at 50% 42%, transparent 36%, rgba(0,0,0,.22) 64%, rgba(0,0,0,.6) 100%);
}
.mgs__bandinner, .mgs__ribbonwrap { position: relative; z-index: 7; }
.mgs__bandinner {
  max-width: 1500px; margin: 0 auto;
  display: grid; grid-template-columns: 0.95fr 1.7fr; gap: clamp(28px,3.5vw,56px); align-items: center;
  padding-bottom: clamp(2rem,3.5vw,3rem);
}
.mgs__interior {
  position: relative; aspect-ratio: 16/11;
  background: var(--pd-cream); border: 6px solid var(--pd-cream);
  border-radius: 18px; box-shadow: 0 22px 40px rgba(0,0,0,.4), 0 6px 14px rgba(0,0,0,.28);
}
.mgs__interior image-slot { position: absolute; inset: 0; border-radius: 12px; overflow: hidden; }
.mgs__cards { display: grid; grid-template-columns: repeat(3, 1fr); }
.mgs__card { padding: 0 clamp(14px,1.8vw,26px); text-align: center; position: relative; }
.mgs__card + .mgs__card { border-left: 1px solid var(--pd-cream-82); }
.mgs__badge {
  position: relative; width: clamp(120px,11vw,152px); height: clamp(88px,8vw,110px);
  margin: 0 auto 16px; background: var(--pd-cream); border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 22px rgba(0,0,0,.32), 0 3px 6px rgba(0,0,0,.22);
}
.mgs-ic { width: 62%; height: 62%; display: block; filter: drop-shadow(0 3px 4px rgba(0,0,0,.28)); }
.mgs__cardtitle {
  font-family: var(--font-script); color: var(--pd-cream);
  font-size: clamp(1.45rem,2.1vw,2rem); line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,.4), 0 2px 10px rgba(0,0,0,.25);
}
.mgs__cardrule { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 9px 0 12px; }
.mgs__cardrule span { width: 26px; height: 2px; background: var(--pd-red); border-radius: 2px; }
.mgs__cardbody {
  font-family: var(--font-body); color: #fff; font-weight: 600;
  font-size: .9rem; line-height: 1.5; max-width: 24ch; margin: 0 auto;
  text-shadow: 0 1px 3px rgba(0,0,0,.35);
}

/* ---------- Ribbon tagline ---------- */
.mgs__ribbonwrap { position: relative; max-width: 1460px; margin: 0 auto; padding: 0 10px clamp(1.8rem,3vw,2.8rem); }
.mgs__ribbon {
  position: relative; background: var(--pd-teal-dark); color: var(--pd-cream);
  display: flex; align-items: center; justify-content: center; gap: clamp(22px,3.4vw,54px); flex-wrap: wrap;
  padding: 18px clamp(70px,8vw,120px); border-radius: 6px;
  clip-path: polygon(0 0, 100% 0, 97% 50%, 100% 100%, 0 100%, 3% 50%);
  filter: drop-shadow(0 14px 20px rgba(0,0,0,.4)) drop-shadow(0 4px 6px rgba(0,0,0,.3));
}
.mgs__rb-caps { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; letter-spacing: .02em; font-size: clamp(1.05rem,2vw,1.65rem); }
.mgs__rb-script { font-family: var(--font-script); color: var(--pd-cream); font-size: clamp(1.3rem,2.3vw,2rem); }
.mgs__rb-script--red { color: var(--pd-red); }

/* ---------- Laser outline ---------- */
/* vectorEffect="non-scaling-stroke" on each path keeps stroke width uniform at all ribbon sizes */
.mgs__laser { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; z-index: 0; }
.mgs__laser path { fill: none; }
.mgs__laser-neon {
  stroke: var(--pd-red); stroke-width: 3px; stroke-linejoin: round;
  opacity: .85; animation: mgsNeonPulse 2.4s ease-in-out infinite;
}
.mgs__laser-edge {
  stroke: #ff8aa0; stroke-width: 1.2px; stroke-linejoin: round; opacity: .9;
}
.mgs__laser-comet {
  stroke: #fff; stroke-width: 3.4px; stroke-linecap: round;
  stroke-dasharray: 10 390; stroke-dashoffset: 0;
  animation: mgsLaserRun 2.8s linear infinite;
}
/* text spans sit above the SVG */
.mgs__ribbon > *:not(.mgs__laser) { position: relative; z-index: 1; }
@keyframes mgsLaserRun { to { stroke-dashoffset: -400; } }
@keyframes mgsNeonPulse { 0%,100% { opacity: .7; } 50% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .mgs__laser-comet, .mgs__laser-neon { animation: none; } }

.mgs__speedlines { position: absolute; left: -2px; top: 50%; transform: translateY(-50%); display: flex; flex-direction: column; gap: 5px; z-index: 4; }
.mgs__speedlines span { display: block; width: 56px; height: 4px; background: var(--pd-red); border-radius: 3px; }
.mgs__arrow { position: absolute; right: -14px; bottom: -2px; width: clamp(96px,10vw,150px); z-index: 4; }
.mgs__arrow svg { width: 100%; height: auto; display: block; filter: drop-shadow(0 10px 14px rgba(0,0,0,.4)) drop-shadow(0 3px 5px rgba(0,0,0,.3)); }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .mgs__top { grid-template-columns: 1fr; aspect-ratio: 1505 / 532; padding: 0; }
  .mgs__bandinner { grid-template-columns: 1fr; }
  .mgs__cards { grid-template-columns: 1fr; gap: 28px; }
  .mgs__card + .mgs__card { border-left: none; border-top: 1px solid var(--pd-cream-82); padding-top: 24px; }
  .mgs__arrow { width: 96px; right: -6px; }
}

/* hide entire MGS section on mobile only */
@media (max-width: 900px) {
  .mgs__top { display: none; }
  .mgs__band { display: none; }
}
