/* template.css overrides
================================*/
.banner { padding-top: 41.667%; }
.banner-img {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  max-height: 300px;
  background: url(../imgs/hero.jpg) no-repeat 0 0;
  background-size: 289.722222%;
}
.header2021-logo-img > img { width: 102px !important; height: auto; }
.price { margin: 0 0 0.825em 0; }
.price-save-dollar,.price-save-label,.price-save-percent { position: relative; background: #cc4e00; color: #fff; font-weight: 700; font-size: 14px; }
.price-save-percent:after { left: 100%; border-bottom: 19px solid #cc4e00; border-right: 10px solid transparent; margin-bottom: 0; }
.price-save-label { padding: 2px 0 1px 6px; }
.price-save-dollar { padding: 2px 0 1px 2px; }
.price-save-percent { padding: 2px 6px 1px 2px; }
.price-save-label:before,.price-save-percent:after { content: ''; position: absolute; bottom: 0; width: 0; height: 0; }
.item-cell { border-bottom: none; }
.item-promo { margin-top: 1em; }
.item-promo-code { border-color: #888; }
.item-promo-title span { color: #333; }
.item-promo-info { color: #cc4e00; }
.item-promo-code { padding: 1.5em 5px 1em 5px; height: auto; color: #cc4e00; }
.item-promo-code-save { display: inline; }
li.mir { display: none; }
.instantSavings, .mir { display: block; }
.finalPrice { font-size: 1.6em; }
.instantSavings { font-size: 0.925em; }
.finalPrice, .instantSavings { color: #fff; }
.originalPrice { color: #fff7; }
.shipping { visibility: hidden; }
.mir { font-size: 1em; margin: 0; color: #76c442; }
.header .logo { width: 125px; }
.items-grid:after { background: none; }
.item-title a { font-size: 14px; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; }
.item-container:hover { opacity: 1; filter: alpha(opacity=100); transition: all 0.2s ease-in-out; }


/* CSS Custom Properties — design tokens
================================*/
:root {
  --ne-logo-blue:   #09144F;
  --ne-blue:        #002D6A;
  --ne-light-blue:  #084BA6;
  --ne-yellow:      #FA9D28;
  --ne-lt-orange:   #FF8500;
  --ne-orange:      #F06C00;
  --ne-navy:        #00283A;
  --bg-dark-1:      #0a0a0f;
  --bg-dark-2:      #0d0d14;
  --bg-dark-3:      #111118;
  --bg-light-1:     #f5f5f7;
  --bg-light-2:     #fafafa;
  --bg-light-3:     #f0f0f0;
  --surface-dark-1: #0f1a2e;
  --surface-dark-2: #0d1b33;
  --text-primary:   #f0f0f0;
  --text-secondary: #9e9e9e;
  --gray-bg:        #F2F2F2;
  --gray-line:      #E8E8E8;
  --gray-border:    #D1D1D1;
  --gray-aux-light: #6E6E6E;
  --gray-body:      #212121;
  --ngg-orange:     #FA9D28;
  --ngg-darkorange: #FF8500;
  --ngg-btn-txt:    #212121;
  --ngg-opensans:   'Open Sans', sans-serif;
  --ngg-montserrat: 'Montserrat', sans-serif;
  --sp-1:  8px;
  --sp-2:  16px;
  --sp-3:  24px;
  --sp-4:  32px;
  --sp-6:  48px;
  --sp-8:  64px;
  --sp-section:    40px;
  --sp-section-lg: 64px;

  /* 007 / NVIDIA campaign tokens */
  --c-nvidia-green:  #76b900;
  --c-nvidia-green2: #8fd400;
  --c-007-gold:      #c8a96e;
  --c-dark-surface:  #0c0c0c;
  --c-dark-card:     #161616;
  --c-dark-card2:    #1a1a1a;
  --c-border-subtle: rgba(255,255,255,0.08);
  --hero-h:          59vh;
}

/* Newegg button standards
================================*/
.btn-primary, .button.button-primary, .ngg-shopall, .ngg-buynow {
  text-transform: none;
  font-family: var(--ngg-opensans);
  border: 0;
  background-color: var(--ngg-orange);
  color: var(--ngg-btn-txt);
}
.ngg-btn { border: 0; background: none; width: 100%; margin: 3% auto; text-align: center; }
.ngg-item-btn { margin: auto; text-align: center; }
.ngg-item-btn a { border-radius: 35px; width: 100%; letter-spacing: 0; font-size: 14px; }
.ngg-shopall, .ngg-buynow { border-radius: 30px; text-align: center; transition: 0.5s; font-weight: 700; font-family: var(--ngg-opensans); }
.ngg-shopall { border-radius: 50px; background-color: var(--c-nvidia-green); color: var(--ngg-btn-txt); border: 0; padding: 10px 4%; font-weight: 700; text-transform: none; font-size: clamp(1rem, 2vw, 1.5rem); }
.ngg-buynow { padding: 10px 8%; }
.ngg-shopall:hover, .ngg-buynow:hover, .ngg-item-btn a:hover { background-color: var(--ngg-darkorange); transition: 0.35s; }
.btn-primary:hover, .btn-primary:active, .button.button-primary:hover, .button.button-primary:active { background: var(--ngg-darkorange); color: var(--ngg-btn-txt); }

/* Global base — scoped to .section-inner only
================================*/
body { background: var(--bg-dark-1); margin: 0; }
.section-inner {
  max-width: 1366px;
  margin: 0 auto;
  overflow: hidden;
  font-size: 14px;
  font-family: var(--ngg-opensans);
  color: var(--text-primary);
  background: var(--c-dark-surface);
}
.section-inner * { font-size: max(14px, inherit); }
img { max-width: 100%; display: block; }
a { text-decoration: none; }

/* Scroll reveal
================================*/
.reveal { opacity: 1; transform: none; }
.will-reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.55s ease-out, transform 0.55s ease-out; }
.will-reveal.visible { opacity: 1; transform: none; }
@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .will-reveal { opacity: 1; transform: none; }
}

/* Disclaimer
================================*/
.disclaimer {
  font-size: 12px;
  color: var(--text-secondary);
  text-align: left;
  padding: var(--sp-4) clamp(24px, 6vw, 80px) var(--sp-8);
  line-height: 1.7;
  border-top: 1px solid var(--c-border-subtle);
  max-width: 1200px;
  margin: 0 auto;
}

.ngg-disclaimer { text-align:center; font-size:12px; color: var(--text-secondary); }

/* ── PAGE-SPECIFIC STYLES ───────────────────── */

/* ─── HERO ─────────────────────────────────── */
.lp-hero {
  position: relative;
  width: 100%;
  max-height: var(--hero-h);
  overflow: hidden;
  background: #000;
}
.lp-hero-bg {
  position: relative;
  width: 100%;
  height: var(--hero-h);
  background: linear-gradient(135deg, #000 0%, #0a0a0a 40%, #111 100%);
  display: flex;
  align-items: stretch;
}
.lp-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.65) 45%, rgba(0,0,0,0.1) 70%, rgba(0,0,0,0) 100%);
  z-index: 1;
  pointer-events: none;
}
.lp-hero-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--sp-6) clamp(24px, 5vw, 72px);
  max-width: 520px;
  flex-shrink: 0;
}
.lp-hero-text {
  flex: 1;
}
.lp-hero-headline {
  font-family: var(--ngg-opensans);
  font-size: clamp(26px, 3.5vw, 46px);
  font-weight: 900;
  line-height: 1.1;
  color: #fff;
  margin: 0 0 var(--sp-2);
  letter-spacing: -0.5px;
}
.lp-hero-sub {
  font-family: var(--ngg-opensans);
  font-size: clamp(14px, 1.5vw, 17px);
  color: rgba(255,255,255,0.85);
  margin: 0 0 var(--sp-3);
  line-height: 1.5;
}
.lp-hero-sub em { font-style: italic; }
.hero-cta-btn {
  display: inline-block;
  background: var(--c-nvidia-green);
  color: #000;
  font-family: var(--ngg-opensans);
  font-weight: 700;
  font-size: 15px;
  padding: 10px 20px;
  border-radius: 4px;
  transition: background 0.25s;
  margin-bottom: var(--sp-2);
  line-height: 24px;
}
.hero-cta-btn:hover { background: var(--c-nvidia-green2); color: #000; }
.hero-fine {
  font-size: 12px !important;
  color: rgba(255,255,255,0.5);
  margin: var(--sp-1) 0 var(--sp-3);
  line-height: 1.5;
}
.hero-fine a { color: rgba(255,255,255,0.6); text-decoration: underline; font-size: 12px !important; }
.lp-hero-logos {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: auto;
}
.hero-partner-logo-wrap,
.hero-nvidia-logo-wrap {
  background: rgba(255,255,255,0.06);
  border: 0px solid rgba(255,255,255,0.15);
  border-radius: 4px;
  padding: 6px 0px;
  display: flex;
  align-items: center;
}
.hero-partner-logo { width: auto; }
.hero-nvidia-logo  { width: auto; }

.lp-hero-game-art {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 60%;
  z-index: 0;
  overflow: hidden;
}
.hero-game-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center top;
  display: block;
}

/* ─── INTRO COPY ───────────────────────────── */
.lp-intro {
  background: var(--c-dark-surface);
  padding: var(--sp-6) clamp(24px, 6vw, 80px);
  border-bottom: 1px solid var(--c-border-subtle);
}
.lp-intro-inner {
  max-width: 1020px;
  margin: 0 auto;
  text-align: center;
}
.lp-intro-inner p {
  font-size: 15px;
  line-height: 1.8;
  color: rgba(255,255,255,0.75);
  margin: 0 0 var(--sp-2);
}
.lp-intro-inner p em { font-style: italic; color: rgba(255,255,255,0.9); }
.intro-avail { font-size: 13px !important; color: var(--text-secondary) !important; }

/* ─── SHARED SECTION HEADER ─────────────────── */
.lp-section-header {
  text-align: center;
  padding: var(--sp-section) clamp(24px, 6vw, 80px) var(--sp-3);
}
.lp-section-title {
  font-family: var(--ngg-opensans);
  font-size: clamp(18px, 2.5vw, 30px);
  font-weight: 800;
  color: #fff;
  margin: 0;
  line-height: 1.2;
}
.lp-section-title em { font-style: italic; }

/* ─── VIDEO SECTION ─────────────────────────── */
.lp-video-section {
  background: #0a0a0a;
  padding: 0 clamp(24px, 8vw, 140px) var(--sp-section);
  border-bottom: 1px solid var(--c-border-subtle);
}
.video-box-wrap {
  max-width: 500px;
  margin: 0 auto;
}
.video-box {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  background: #000;
  border-radius: 4px;
}
.video-box iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: 0;
}
.video-caption {
  text-align: center;
  font-size: 1.5rem;
  color: var(--text-primary);
  margin: var(--sp-2) 0 0;
}

/* ─── FEATURE SECTIONS ──────────────────────── */
.lp-feature-section {
  background: var(--c-dark-surface);
  padding: var(--sp-section) clamp(24px, 6vw, 80px);
  border-bottom: 1px solid var(--c-border-subtle);
}
.lp-feature-alt {
  background: #0a0a0a;
}
.lp-feature-inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.lp-feature-eyebrow {
  font-family: var(--ngg-opensans);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--c-nvidia-green);
  margin: 0 0 var(--sp-1);
}
.lp-feature-headline {
  font-family: var(--ngg-opensans);
  font-size: clamp(20px, 3vw, 36px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 var(--sp-2);
  line-height: 1.15;
}
.lp-feature-body {
  font-size: 15px;
  line-height: 1.8;
  color: rgba(255,255,255,0.72);
  margin: 0 0 var(--sp-4);
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}
.lp-feature-body em { font-style: italic; color: rgba(255,255,255,0.9); }

/* Compare image */
.lp-compare-img-wrap {
  max-width: 680px;
  margin: 0 auto;
}
.lp-compare-img {
  position: relative;
  display: inline-block;
  width: 100%;
}
.lp-compare-img img {
  width: 100%;
  border-radius: 4px;
  display: block;
}
.compare-label {
  position: absolute;
  bottom: 12px;
  font-family: var(--ngg-opensans);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  background: rgba(0,0,0,0.7);
  color: #fff;
  padding: 4px 8px;
  border-radius: 3px;
  line-height: 1.3;
  text-align: center;
}
.compare-label-off { left: 12px; border-left: 3px solid #fff; }
.compare-label-on  { right: 12px; border-left: 3px solid var(--c-nvidia-green); }

/* Feature image */
.lp-feature-img-wrap { max-width: 760px; margin: 0 auto; }
.lp-feature-img-wrap img { width: 100%; border-radius: 4px; }
.img-caption {
  font-size: 12px !important;
  color: var(--text-secondary);
  text-align: center;
  margin: var(--sp-1) 0 0;
  line-height: 1.5;
}

/* ─── BUY SECTION / PRODUCT GRID ───────────── */
.lp-buy-section {
  background: var(--c-dark-surface);
  padding: var(--sp-section) clamp(16px, 4vw, 60px) var(--sp-4);
  border-bottom: 1px solid var(--c-border-subtle);
}
.items-grid-3 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3);
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1100px;
}
.items-grid-3 .item-cell {
  flex: 1 1 280px;
  max-width: 340px;
  background: var(--c-dark-card);
  border: 1px solid var(--c-border-subtle);
  border-radius: 6px;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
  padding: 0;
  margin: 0;
}
.items-grid-3 .item-cell:hover {
  border-color: var(--c-nvidia-green);
  transform: translateY(-2px);
}
.items-grid-3 .item-container {
  display: flex;
  flex-direction: column;
  height: auto;
  padding: var(--sp-3);
}
.items-grid-3 .item-img {
  display: block;
  text-align: center;
  margin-bottom: var(--sp-2);
}
.items-grid-3 .item-img img {
  max-height: 180px;
  width: auto;
  margin: 0 auto;
  object-fit: contain;
}
.items-grid-3 .item-info {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.item-brand {
  font-size: 13px;
  color: var(--text-secondary);
  margin: 0 0 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.items-grid-3 .item-title {
  margin: 0 0 var(--sp-1);
  flex: 1;
}
.items-grid-3 .item-title a {
  font-family: var(--ngg-opensans);
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.items-grid-3 .price { color: #fff; margin-bottom: 4px; }
.items-grid-3 .btn-area { margin-top: var(--sp-2); }
.items-grid-3 .btn-area a {
  display: block;
  background: var(--c-nvidia-green);
  color: #000;
  font-family: var(--ngg-opensans);
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  padding: 10px 16px;
  border-radius: 35px;
  border: 0;
  transition: background 0.25s;
  min-height: 44px;
  line-height: 24px;
}
.items-grid-3 .btn-area a:hover { background: var(--c-nvidia-green2); color: #000; }

/* ─── FOOTER LOGOS ──────────────────────────── */
.lp-footer-logos {
  background: var(--c-dark-surface);
  padding: var(--sp-4) clamp(24px, 6vw, 80px);
  border-top: 1px solid var(--c-border-subtle);
}
.lp-footer-logos-inner {
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-6);
}
.footer-ratings {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-6);
}
.footer-rating-img { height: 60px; width: auto; }
.footer-brand-logos {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  justify-content: center;
}
.footer-partner-logo-wrap,
.footer-nvidia-logo-wrap {
  /*background: rgba(255,255,255,0.06);*/
  border: 0px solid rgba(255,255,255,0.12);
  border-radius: 4px;
  padding: 8px 16px;
  display: flex;
  align-items: center;
}
.footer-partner-logo,
.footer-nvidia-logo { height: 42px; width: auto; }

/* ─── RESPONSIVE ─────────────────────────────── */
@media only screen and (max-width: 550px) {
  .lp-hero { max-height: 370px; }
  .lp-hero-bg { height: 370px; }
  .lp-hero-game-art { width: 50%; }
  .lp-hero-content { padding: var(--sp-2) var(--sp-2); max-width: 55%; }
  .lp-hero-headline { font-size: clamp(14px, 5vw, 22px); }
  
  .hero-cta-btn { font-size: 14px; padding: 8px 16px; }
  /*
  .lp-hero-sub { display: none; }
  .hero-fine { display: none; }
  .lp-hero-logos { display: none; }
*/
  .items-grid-3 { gap: var(--sp-2); }
  .items-grid-3 .item-cell { flex: 1 1 100%; max-width: 100%; }

  .footer-ratings { gap: var(--sp-2); }
  .ngg-shopall { font-size:1.5rem; }
  .ngg-btn { margin:8% auto; }
}

@media only screen and (max-width: 768px) {
  .lp-feature-section { padding: var(--sp-4) clamp(16px, 5vw, 40px); }
  .lp-intro { padding: var(--sp-4) clamp(16px, 5vw, 40px); }
  .items-grid-3 .item-cell { flex: 1 1 240px; }
}

@media only screen and (min-width: 375px) {}
@media only screen and (min-width: 481px) {}
@media only screen and (min-width: 641px) {
  .banner { padding-top: 21.96%; }
  .banner-img { background-position: 100% 0; background-size: 152.7086383601757%; }
}
@media only screen and (min-width: 769px) {
  .lp-footer-logos-inner { flex-direction: column; justify-content: space-between; }
}
@media only screen and (min-width: 1025px) {
  .items-grid-3 .item-cell { flex: 1 1 250px; }
}
@media only screen and (min-width: 1440px) {}
