/* ──────────────────────────────────────────────
   ORIGINAL NEWEGG BASE.CSS (preserved)
   ────────────────────────────────────────────── */

/* template.css overrides -- use only when absolutely necessary
================================*/
.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:13px;}
.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:1.2rem}
.finalPrice, .instantSavings{color:#000;}
.shipping{visibility:hidden;}
.mir{font-size:1em;margin:0;color:#016B04}
.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);
	-webkit-transition: all 0.2s ease-in-out;
	   -moz-transition: all 0.2s ease-in-out;
		 -o-transition: all 0.2s ease-in-out;
			transition: all 0.2s ease-in-out;
}
/* No Orange Bar for Custom LPs with Black Background
.price-save-dollar,.price-save-label,.price-save-percent{position:relative;background:none;color:#fff;font-weight:700;font-size:13px;}
.price-save-percent:after{left: 100%;border-bottom:none;border-right: 10px solid transparent;margin-bottom:0;}
================================*/

/* custom CSS
================================*/
body { background-color: #000; }
:root {
	--ngg-darkblue:#09144f;
	--ngg-blue:#084BA6;
	--ngg-orange:#fa9d28;
	--ngg-darkorange: #ff8500;
	--ngg-footgry: #333;
	--ngg-opensans:'Open Sans', sans-serif;
	--ngg-btn-txt:#212121;
  }

.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:clamp(14px, 1.5vw, 1rem); }
.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; text-align:center; background-color:#fa9d28; color:#212121; border:0; padding:10px 4%; transition:0.5s; font-weight:700; text-transform:none; font-family:'Open Sans' !important; font-size:clamp(1.5rem, 2vw, 2.2rem); }
.ngg-buynow { padding:10px 8%; }
.ngg-shopall:hover, .ngg-buynow:hover, .ngg-item-btn a:hover { background-color:var(--ngg-darkorange); transition:0.35s; }


/* responsive CSS
================================*/
@media only screen and (max-width: 768px) {
  /* insert responsive CSS for tablet screens below 768px */
}

@media only screen and (max-width: 550px) {
	/* insert responsive CSS for mobile screens below 550px */
  .items-grid .item-cell { width:90%; text-align:center; border-bottom:1px solid #333; padding-bottom:8%; }
  .item-img > img { max-width:300px; }
	.items-grid .item-title { height:auto; }
}

@media only screen and (min-width: 375px) {
	/* insert responsive CSS for screens above 375px */
}
@media only screen and (min-width: 481px) {
	/* insert responsive CSS for screens above 481px */
}
@media only screen and (min-width: 641px) {
	/* insert responsive CSS for screens above 641px */
	.banner { padding-top: 21.96%; }
	.banner-img {
		background-position:100% 0;
		background-size: 152.7086383601757%;
	}

	.items-grid .item-cell { width:24%; margin:0; }
}

@media only screen and (min-width: 769px) {
	/* insert responsive CSS for screens above 769px */
}

@media only screen and (min-width: 1025px) {
	/* insert responsive CSS for screens above 1025px */
}

/* ──────────────────────────────────────────────
   PRAGMATA x GeForce RTX 50 — Landing Page
   Built on Newegg Design System tokens.
   ────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,600;0,700;0,800;1,400;1,600;1,700;1,800&display=swap');

:root {
  /* Newegg tokens we use */
  --ne-white: #FFFFFF;
  --ne-black: #000000;
  --ne-gy1:  #F7F7F7;
  --ne-gy3:  #E8E8E8;
  --ne-gy4:  #D1D1D1;
  --ne-gy6:  #ADADAD;
  --ne-gy7:  #949494;
  --ne-gy9:  #6E6E6E;
  --ne-gy12: #424242;
  --ne-gy15: #212121;
  --ne-gyd:  #121212;
  --ne-navy: #00283A;
  --ne-yellow: #FA9D28;

  /* Page specific (PRAGMATA promo = dark theme + NVIDIA green accent) */
  --bg-page:    #000000;
  --bg-surface: #0A0A0A;
  --fg-on-dark: #FFFFFF;
  --fg-muted:   #BFBFBF;
  --fg-faint:   #858585;
  --nv-green:   #76B900;    /* NVIDIA brand green — CTAs in mockup */
  --nv-green-hover: #8CD400;
  --nv-green-active: #5F9400;
  --partner-magenta: #CC1FD5;
  --divider: #2A2A2A;

  --content-max: 1200px;
  --hero-max: 1200px;

  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
}

.section-inner, .section-inner * { box-sizing: border-box; }

.section-inner {
  background: var(--bg-page);
  color: var(--fg-on-dark);
  font-family: 'Open Sans', Arial, system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: block;
  width: 100%;
}

.section-inner img, .section-inner svg { display: block; max-width: 100%; }

.section-inner button {
  font-family: inherit;
  cursor: pointer;
  border: 0;
  padding: 0;
  background: none;
  color: inherit;
}

.section-inner a { text-decoration: none; }
.section-inner h1, .section-inner h2, .section-inner h3,
.section-inner h4, .section-inner p { margin: 0; color: inherit; }

/* ═══════════════════════════════════════════════
   Shared building blocks
   ═══════════════════════════════════════════════ */

.wrap {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 24px;
}

.ngg-bg-white { background-color:white; padding:3% 0; }
.ngg-bg-grey { background-color: #111;}

.section {
  padding: 72px 0;
}

.section--tight {
  padding: 48px 0;
}

.divider {
  height: 1px;
  background: var(--divider);
  width: 100%;
}

.section-inner .section-title {
  display: block;
  font-weight: 700;
  font-size: 32px;
  line-height: 1.2;
  margin: 0 auto;
  text-align: center;
  max-width: 900px;
}

.section-inner .section-title em {
  font-style: italic;
  font-weight: 700;
}

.section-inner .section-copy {
  display: block;
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-muted);
  max-width: 760px;
  margin: 18px auto 0;
  text-align: center;
}

.section-inner .section-copy em {
  font-style: italic;
}

.section-inner .eyebrow {
  display: block;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--fg-on-dark);
  margin: 0 0 10px;
  text-align: center;
}

.section-inner .feature__heading { text-align: center; }
.section-inner .feature__caption { display: block; text-align: center; }
.section-inner .intro__inner { text-align: center; }
.section-inner .products__title { display: block; text-align: center; }

/* ═══════════════════════════════════════════════
   Buttons
   ═══════════════════════════════════════════════ */

.btn1 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  font-size: 15px;
  line-height: 1;
  padding: 12px 22px;
  transition: background-color 120ms ease, color 120ms ease;
  white-space: nowrap;
  margin:30px 0;
  border-radius: 0;
  text-transform: none;
  letter-spacing: 0;
}

.btn--primary {
  background: var(--nv-green);
  color: #0A1A00;
}
.btn--primary:hover { background: var(--nv-green-hover); }
.btn--primary:active { background: var(--nv-green-active); }

/* ═══════════════════════════════════════════════
   Hero
   ═══════════════════════════════════════════════ */

.hero {
  padding: 56px 0 40px;
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  align-items: flex-start;
}

.hero__copy {
  padding-left: 24px;
}

.hero__headline {
  font-size: 44px;
  line-height: 1.08;
  font-weight: 700;
  margin: 0 0 24px;
  letter-spacing: -0.01em;
}

.hero__sub {
  font-size: 17px;
  line-height: 1.4;
  font-weight: 700;
  margin: 0 24px;
  max-width: 480px;
}

p.hero__sub, p.hero__sub_details { padding:1% 0 2%; }


.hero__sub em {
  font-style: italic;
  font-weight: 700;
}

.hero__cta { margin-bottom: 32px; }

.hero__legal {
  font-size: 11px;
  line-height: 1.6;
  color: var(--fg-faint);
  margin: 0 0 40px;
}

.hero__legal p { margin: 0; }

.hero__logos {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* Hero logo row (images) */
.hero__logo { height: 40px; width: auto; display: block; }
.hero__logo--partner { height: 40px; }
.hero__logo--geforce { height: 40px; }

/* Hero artwork — the image already has the character + wordmark baked in */
.hero__art {
  position: relative;
  aspect-ratio: 16 / 11;
  background: #ffffff;
  /*border-radius: var(--radius-md);*/
  overflow: hidden;
  border-left: 4px solid var(--nv-green);
}

.hero__art-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* ═══════════════════════════════════════════════
   Intro / Description section
   ═══════════════════════════════════════════════ */

.intro {
  padding: 40px 0 56px;
}
.intro__inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.intro p {
  font-size: 14px;
  line-height: 1.75;
  color: var(--fg-muted);
  margin: 0 0 16px;
}
.intro p:last-child { margin-bottom: 0; }
.intro em { font-style: italic; }

/* ═══════════════════════════════════════════════
   Feature blocks (video + screenshot showcases)
   ═══════════════════════════════════════════════ */

.feature {
  padding: 80px 0;
}
.feature--alt { background: var(--bg-surface); }

.feature__heading {
  text-align: center;
  margin-bottom: 40px;
}

.media-frame {
  position: relative;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  /*aspect-ratio: 16 / 9;*/
  background: #000;
  border-radius: var(--radius-md);
  overflow: hidden;
  text-align: center;
}
.media-frame iframe { width:100%; max-width:560px; aspect-ratio: 16 / 9;}

.media-frame__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.play-btn {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 82px; height: 82px;
  border-radius: 50%;
  border: 3px solid #fff;
  background: rgba(0,0,0,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 120ms ease, transform 120ms ease;
}
.play-btn:hover { background: rgba(0,0,0,0.4); transform: translate(-50%, -50%) scale(1.04); }
.play-btn::after {
  content: '';
  display: block;
  width: 0; height: 0;
  border-style: solid;
  border-width: 14px 0 14px 22px;
  border-color: transparent transparent transparent #fff;
  margin-left: 6px;
}

/* RTX chip — used only on the video frame now */
.rtx-chip {
  position: absolute;
  right: 14px;
  bottom: 14px;
  background: var(--nv-green);
  color: #0A1A00;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.1;
  border-radius: 2px;
}
.rtx-chip span { display: block; }

/* Path-tracing comparison — the image already contains the split + chips */
.split-compare {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  background: #000;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.split-compare__img {
  width: 100%;
  height: auto;
  display: block;
}

/* DLSS frame — image already contains the FPS card overlay */
.dlss-frame {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  background: #000;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.dlss-frame__img {
  width: 100%;
  height: auto;
  display: block;
}

.feature__caption {
  font-size: 11px;
  color: var(--fg-faint);
  text-align: center;
  margin: 20px auto 0;
  max-width: 900px;
  line-height: 1.6;
  font-style: italic;
}

/* ═══════════════════════════════════════════════
   Product grid — Buy GeForce RTX
   ═══════════════════════════════════════════════ */

.products {
  padding: 80px 0 72px;
  color:#212121;
}

.products__title {
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  margin: 0 0 48px;
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  max-width: 960px;
  margin: 0 auto;
}

.product-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  text-align: center;
}

.product-card__art {
  width: 100%;
  aspect-ratio: 2 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6E6E6E;
}

.product-card__name {
  font-size: 17px;
  font-weight: 700;
  margin: 0;
  color: #fff;
}
.product-card__model {
  font-size: 17px;
  font-weight: 700;
  margin: 4px 0 6px;
  color: #fff;
}

.product-card .btn { padding: 10px 24px; }

/* ═══════════════════════════════════════════════
   Footer
   ═══════════════════════════════════════════════ */

.foot {
  padding: 24px 0 48px;
}

.foot__divider {
  height: 1px;
  background: #2F2F2F;
  margin-bottom: 48px;
}

.foot__partners {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 56px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}

/* Footer logos (images) */
.foot__logo { display: block; height: auto; }
.foot__logo--capcom { height: 37px; }
.foot__logo--esrb   { height: 72px; }
.foot__logo--partner { height: 44px; }
.foot__logo--geforce { height: 50px; }

.foot__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.foot__legal {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
  color: var(--fg-faint);
  font-size: 11px;
  line-height: 1.7;
}
.foot__legal p { margin: 0 0 10px; }
.foot__legal p:last-child { margin-bottom: 0; }

/* ═══════════════════════════════════════════════
   Responsive — tablet (≤960px)
   ═══════════════════════════════════════════════ */

@media (max-width: 960px) {
  .hero { padding: 40px 0 24px; }
  .hero__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hero__copy { padding-left: 0; order: 1; }
  .hero__art  { order: 2; aspect-ratio: 4 / 3; }
  .hero__headline { font-size: 38px; }

  .section { padding: 56px 0; }
  .feature { padding: 56px 0; }
  .section-title { font-size: 26px; }

  .product-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
    max-width: 640px;
  }

  .foot__partners { gap: 40px; }
}

/* ═══════════════════════════════════════════════
   Responsive — phone (≤580px)
   ═══════════════════════════════════════════════ */

@media (max-width: 580px) {
  .wrap { padding: 0 18px; }

  .hero { padding: 32px 0 16px; }
  .hero__headline { font-size: 32px; line-height: 1.1; }
  .hero__sub { font-size: 15px; }
  .hero__art { aspect-ratio: 4 / 3; border-left-width: 3px; }

  .intro { padding: 24px 0 40px; }
  .intro p { font-size: 13px; line-height: 1.7; }

  .feature { padding: 48px 0; }
  .section-title { font-size: 22px; }
  .section-copy { font-size: 14px; margin-top: 14px; }
  .eyebrow { font-size: 12px; }

  .play-btn { width: 60px; height: 60px; border-width: 2px; }
  .play-btn::after { border-width: 10px 0 10px 16px; margin-left: 4px; }

  .rtx-chip { padding: 5px 8px; font-size: 10px; }

  .products { padding: 56px 0 48px; }
  .products__title { font-size: 22px; margin-bottom: 32px; }
  .product-grid {
    grid-template-columns: 1fr;
    max-width: 320px;
    gap: 40px;
  }

  .foot__partners { gap: 32px; }
  .foot__logo--capcom { height: 44px; }
  .foot__logo--esrb   { height: 54px; }

  .foot__logos { gap: 24px; }
  .foot__logo--partner { height: 38px; }
  .foot__logo--geforce { height: 38px; }

  .hero__logos { gap: 12px; }
}
