/* NDCTees /specials-v2 — interactive bundle builder.
   Uses site design tokens (var(--red) etc.) with fallbacks so it renders
   correctly even if a token is missing on this page. */

.sv2 {
	--sv2-red: var(--red, #cc0000);
	--sv2-ink: #0e0e0e;
	--sv2-panel: #161616;
	--sv2-panel2: #1e1e1e;
	--sv2-line: rgba(255,255,255,.12);
	--sv2-txt: #f5f5f5;
	--sv2-mut: var(--gray-300, #b3b3b3);
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 20px 120px;
	color: var(--sv2-txt);
	font-family: var(--font-body, inherit);
}

/* ── Hero ── */
.sv2__hero { text-align: center; padding: 64px 0 40px; }
.sv2__eyebrow { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 3px; font-size: 12px; font-weight: 700; color: var(--sv2-red); }
.sv2__title { font-family: var(--font-display, inherit); font-size: clamp(34px, 6vw, 60px); font-weight: 800; text-transform: uppercase; margin: 10px 0 12px; line-height: 1.02; }
.sv2__accent { color: var(--sv2-red); }
.sv2__sub { color: var(--sv2-mut); max-width: 620px; margin: 0 auto; font-size: 16px; line-height: 1.6; }

/* ── Step ── */
.sv2-step { margin: 0 0 40px; padding: 28px; border: 1px solid var(--sv2-line); border-radius: 14px; background: var(--sv2-panel); transition: opacity .25s; position: relative; }
.sv2-step.is-locked { opacity: .4; pointer-events: none; filter: saturate(.4); }
.sv2-step.is-locked::after { content: "Complete the step above to unlock"; position: absolute; top: 14px; right: 18px; font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: var(--sv2-mut); }
.sv2-step__head { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px 16px; margin-bottom: 22px; }
.sv2-step__eyebrow { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 2px; font-size: 11px; font-weight: 700; color: var(--sv2-red); background: rgba(204,0,0,.12); padding: 4px 10px; border-radius: 999px; }
.sv2-step__heading { font-family: var(--font-display, inherit); font-size: clamp(22px, 3vw, 30px); font-weight: 700; text-transform: uppercase; margin: 0; }
.sv2-skip { margin-left: auto; background: none; border: 1px solid transparent; color: var(--sv2-mut); font-size: 13px; cursor: pointer; text-decoration: underline; padding: 6px 12px; border-radius: 8px; transition: background .15s, color .15s, border-color .15s; }
/* Hover never goes pink — it goes red with white text (defeats the theme's
   reset.css `button:hover { background:#CC3366 }`; class+pseudo outranks it). */
.sv2-skip:hover, .sv2-skip:focus { background: var(--sv2-red); border-color: var(--sv2-red); color: #fff; text-decoration: none; }

/* ── Bundle cards ── */
.sv2-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.sv2-card { position: relative; display: flex; flex-direction: column; gap: 6px; padding: 22px 20px 64px; border: 2px solid var(--sv2-line); border-radius: 12px; background: var(--sv2-panel2); cursor: pointer; transition: border-color .18s, transform .18s; }
.sv2-card:hover { transform: translateY(-3px); border-color: rgba(255,255,255,.28); }
.sv2-card.is-featured { border-color: var(--sv2-red); }
.sv2-card.is-selected { border-color: var(--sv2-red); box-shadow: 0 0 0 3px rgba(204,0,0,.25); }
.sv2-card__input { position: absolute; opacity: 0; pointer-events: none; }
.sv2-card__badge { position: absolute; top: -11px; left: 20px; background: var(--sv2-red); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; }
.sv2-card__name { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 13px; font-weight: 700; color: var(--sv2-mut); }
.sv2-card__price { font-family: var(--font-display, inherit); font-size: 38px; font-weight: 800; color: #fff; line-height: 1; }
.sv2-card__desc { font-size: 13px; color: var(--sv2-mut); margin-bottom: 6px; }
.sv2-card__features { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.sv2-card__features li { position: relative; padding-left: 22px; font-size: 13px; line-height: 1.45; color: var(--sv2-txt); }
.sv2-card__features li::before { content: "\2713"; position: absolute; left: 0; top: 0; color: var(--sv2-red); font-weight: 700; }
.sv2-card__pick { position: absolute; left: 20px; right: 20px; bottom: 18px; text-align: center; padding: 10px; border-radius: 8px; border: 1px solid var(--sv2-line); font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 13px; font-weight: 700; transition: background .15s, border-color .15s, color .15s; }
/* SELECT turns red on card hover and when selected (never pink). */
.sv2-card:hover .sv2-card__pick, .sv2-card.is-selected .sv2-card__pick { background: var(--sv2-red); border-color: var(--sv2-red); color: #fff; }
.sv2-card.is-selected .sv2-card__pick::after { content: " \2713"; }

/* ── Add-ons ── */
.sv2-addons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.sv2-addon { display: flex; gap: 12px; padding: 16px; border: 2px solid var(--sv2-line); border-radius: 10px; background: var(--sv2-panel2); cursor: pointer; transition: border-color .18s; }
.sv2-addon:hover { border-color: rgba(255,255,255,.28); }
.sv2-addon.is-selected { border-color: var(--sv2-red); box-shadow: 0 0 0 2px rgba(204,0,0,.22); }
.sv2-addon__input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--sv2-red); flex: 0 0 auto; }
.sv2-addon__body { display: flex; flex-direction: column; gap: 3px; }
.sv2-addon__name { font-weight: 700; font-size: 14px; }
.sv2-addon__price { color: var(--sv2-red); font-weight: 700; font-size: 14px; }
.sv2-addon__desc { color: var(--sv2-mut); font-size: 12.5px; line-height: 1.45; }

/* ── Submit form ──
   6-col grid so a row can be 2-up (50% = span 3) or 3-up (33% = span 2). */
.sv2-form__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.sv2-field { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--sv2-mut); }
.sv2-field--half { grid-column: span 3; }   /* 50% on desktop */
.sv2-field--third { grid-column: span 2; }  /* 33% on desktop */
.sv2-field--full { grid-column: 1 / -1; }
.sv2-field--spaced { margin-top: 16px; }
/* Invalid-on-submit highlight (red label + red field outline). */
.sv2-field.sv2-invalid > span { color: var(--sv2-red); }
.sv2-field.sv2-invalid input, .sv2-field.sv2-invalid textarea { border-color: var(--sv2-red); box-shadow: 0 0 0 2px rgba(204,0,0,.25); }
.sv2-field.sv2-invalid .sv2-radio { border-color: var(--sv2-red); }
.sv2-field input, .sv2-field textarea { background: var(--sv2-ink); border: 1px solid var(--sv2-line); border-radius: 8px; color: var(--sv2-txt); padding: 11px 12px; font-size: 14px; font-family: inherit; }
.sv2-field input:focus, .sv2-field textarea:focus { outline: none; border-color: var(--sv2-red); }

/* Shipping radios (Pickup / Ship) */
.sv2-radio-row { display: flex; gap: 10px; flex-wrap: wrap; }
.sv2-radio { display: flex; align-items: center; gap: 8px; flex: 1 1 0; min-width: 160px; background: var(--sv2-ink); border: 1px solid var(--sv2-line); border-radius: 8px; padding: 11px 12px; font-size: 14px; color: var(--sv2-txt); cursor: pointer; transition: border-color .15s; }
.sv2-radio:hover { border-color: rgba(255,255,255,.28); }
.sv2-radio input { width: 17px; height: 17px; accent-color: var(--sv2-red); flex: 0 0 auto; }
.sv2-radio:has(input:checked) { border-color: var(--sv2-red); box-shadow: 0 0 0 2px rgba(204,0,0,.22); }

/* Updates / Newsletter opt-in checkboxes */
.sv2-optins { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.sv2-checkbox { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--sv2-mut); line-height: 1.45; cursor: pointer; }
.sv2-checkbox input { width: 17px; height: 17px; margin-top: 1px; accent-color: var(--sv2-red); flex: 0 0 auto; }
.sv2-checkbox strong { color: var(--sv2-txt); font-weight: 700; }

/* ── Artwork slots (two columns / 50% each on desktop) ── */
.sv2-art { margin-top: 22px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; align-items: start; }
.sv2-art__head { grid-column: 1 / -1; display: flex; flex-direction: column; gap: 2px; margin-bottom: 4px; }
.sv2-art__head strong { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 13px; }
.sv2-art__head span { color: var(--sv2-mut); font-size: 12.5px; }
.sv2-art__row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 10px 14px; background: var(--sv2-panel2); border: 1px solid var(--sv2-line); border-radius: 8px; flex-wrap: wrap; }
.sv2-art__label { font-size: 14px; font-weight: 600; }
.sv2-art__label em { color: var(--sv2-mut); font-style: normal; font-weight: 400; font-size: 12px; margin-left: 6px; }
.sv2-art__row input[type=file] { font-size: 12.5px; color: var(--sv2-mut); max-width: 60%; }

.sv2-art__checklist { list-style: none; margin: 8px 0 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px 18px; }
.sv2-art__checklist li { position: relative; padding-left: 18px; font-size: 13px; color: var(--sv2-txt); }
.sv2-art__checklist li::before { content: "\2022"; position: absolute; left: 0; color: var(--sv2-red); font-weight: 700; }
.sv2-art__checklist li em { color: var(--sv2-mut); font-style: normal; font-size: 11px; margin-left: 6px; }
.sv2-uploader { margin-top: 18px; }
.sv2-uploader__label { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 12px; color: var(--sv2-mut); margin-bottom: 8px; }

/* ── Submit foot ── */
.sv2-form__foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 24px; flex-wrap: wrap; }
.sv2-form__note { color: var(--sv2-mut); font-size: 12.5px; margin: 0; max-width: 60%; }
.sv2-addons__note { flex-basis: 100%; width: 100%; margin: 0; color: var(--sv2-red); font-size: 12.5px; font-weight: 600; }
.sv2-submit { background: var(--sv2-red); color: #fff; border: none; border-radius: 8px; padding: 14px 26px; font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 15px; font-weight: 700; cursor: pointer; transition: background .18s, opacity .18s; }
.sv2-submit:not(:disabled):hover { background: #a30000; }
.sv2-submit:disabled { opacity: .4; cursor: not-allowed; }
.sv2-result { margin-top: 18px; padding: 14px 16px; border-radius: 8px; font-size: 14px; line-height: 1.5; }
.sv2-result.is-ok { background: rgba(34,197,94,.14); border: 1px solid rgba(34,197,94,.5); color: #d6ffe2; }
.sv2-result.is-err { background: rgba(204,0,0,.14); border: 1px solid rgba(204,0,0,.5); color: #ffd9d9; }

/* ── Running summary (sticky widget) ── */
.sv2-summary { position: fixed; right: 22px; bottom: 22px; width: 290px; background: var(--sv2-ink); border: 1px solid var(--sv2-red); border-radius: 14px; padding: 18px; box-shadow: 0 18px 50px rgba(0,0,0,.5); z-index: 60; }
.sv2-summary__title { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 2px; font-size: 12px; font-weight: 700; color: var(--sv2-red); margin-bottom: 10px; }
.sv2-summary__list { list-style: none; margin: 0 0 12px; padding: 0; display: flex; flex-direction: column; gap: 7px; max-height: 200px; overflow: auto; }
.sv2-summary__list li { display: flex; justify-content: space-between; gap: 10px; font-size: 13px; }
.sv2-summary__list li span { color: var(--sv2-mut); }
.sv2-summary__total { display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--sv2-line); padding-top: 12px; margin-bottom: 12px; }
.sv2-summary__total span { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--sv2-mut); }
.sv2-summary__total strong { font-family: var(--font-display, inherit); font-size: 26px; color: #fff; }
.sv2-summary__cta { width: 100%; background: var(--sv2-red); color: #fff; border: none; border-radius: 8px; padding: 11px; font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 13px; font-weight: 700; cursor: pointer; transition: background .18s; }
.sv2-summary__cta:hover { background: #a30000; color: #fff; }

/* Hide the site's floating Get-a-Quote button on this page only (desktop) so
   the running-total widget owns the bottom-right corner. */
body:has(#sv2-app) .float-cta { display: none !important; }

/* ── Summary subtotal / sales-tax rows ── */
.sv2-summary__rows { border-top: 1px solid var(--sv2-line); margin-top: 4px; padding-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.sv2-summary__rows .sv2-summary__row { display: flex; justify-content: space-between; gap: 10px; font-size: 13px; }
.sv2-summary__rows .sv2-summary__row span:first-child { color: var(--sv2-mut); }
.sv2-summary__rows .sv2-summary__row span:last-child { color: var(--sv2-txt); }
/* total row no longer needs its own top border now the rows block has one */
.sv2-summary__total { border-top: 1px solid var(--sv2-line); padding-top: 10px; margin-top: 4px; }

/* ── Per-product upload slots ── */
/* min-width:0 lets each grid track shrink below the Uppy dashboard's intrinsic
   width (grid/flex items default to min-width:auto = min-content, which was
   forcing ~780px tracks and overflowing the viewport). */
.sv2-art__slot { background: var(--sv2-panel2); border: 1px solid var(--sv2-line); border-radius: 10px; padding: 14px 14px 6px; min-width: 0; }
.sv2-art__slot .rfm-cu-host { min-width: 0; max-width: 100%; }
.sv2 .uppy-Root, .sv2 .uppy-Dashboard, .sv2 .uppy-Dashboard-inner { max-width: 100% !important; min-width: 0 !important; width: 100% !important; }
.sv2-art__slot-label { display: flex; align-items: baseline; gap: 8px; margin-bottom: 8px; }
.sv2-art__slot-label span { font-size: 14px; font-weight: 700; color: var(--sv2-txt); }
.sv2-art__slot-label em { color: var(--sv2-mut); font-style: normal; font-weight: 400; font-size: 12px; }
/* "Use same artwork as the tees" — only shown on non-tees slots when a tees
   slot exists in the selection. Checking it hides that slot's uploader. */
.sv2-art__same { display: none; align-items: center; gap: 8px; font-size: 12.5px; color: var(--sv2-mut); margin: -2px 0 10px; cursor: pointer; }
.sv2-art--has-tees .sv2-art__slot:not(.is-tees) .sv2-art__same { display: flex; }
.sv2-art__same-input { width: 16px; height: 16px; accent-color: var(--sv2-red); flex: 0 0 auto; }
.sv2-art__slot.use-tees .rfm-cu-host { display: none; }
.sv2-art__slot.use-tees .sv2-art__same { color: var(--sv2-txt); }

/* ── Kill the theme's pink (#CC3366) inside the builder ─────────────────
   The site's reset.css paints every <a>/<button> pink with a pink hover
   fill. Scope-override so nothing here is ever pink; links go red, and the
   Uppy uploader is dark-themed to match the panels. */
.sv2 a { color: var(--sv2-red); }
.sv2 a:hover, .sv2 a:focus { color: #fff; }

/* The theme also pinks buttons on :focus and :active (not just :hover) — that's
   why "Continue to submit" went pink after a click. Pin our buttons red on
   focus/active; keep the darker-red hover. (class+pseudo outranks the theme.) */
.sv2-submit:focus, .sv2-submit:active,
.sv2-summary__cta:focus, .sv2-summary__cta:active { background: var(--sv2-red); border-color: var(--sv2-red); color: #fff; }
.sv2-submit:not(:disabled):hover, .sv2-summary__cta:hover { background: #a30000; color: #fff; }
/* Remove (×) buttons in the sticky cart — never pink */
.sv2-summary__remove { background: none; border: none; color: var(--sv2-mut); font-size: 17px; line-height: 1; cursor: pointer; padding: 0 2px; transition: color .15s; }
.sv2-summary__remove:hover, .sv2-summary__remove:focus, .sv2-summary__remove:active { color: var(--sv2-red); background: none; }
.sv2-summary__li-right { display: inline-flex; align-items: center; gap: 8px; }

/* Uppy dashboard surfaces → dark panel */
.sv2 .uppy-Root, .sv2 .uppy-Dashboard-inner, .sv2 .uppy-Dashboard-innerWrap { background: var(--sv2-panel2) !important; color: var(--sv2-txt) !important; border-color: var(--sv2-line) !important; }
.sv2 .uppy-Dashboard-AddFiles { border-color: var(--sv2-line) !important; }
.sv2 .uppy-Dashboard-AddFiles-title, .sv2 .uppy-Dashboard-dropFilesHereHint, .sv2 .uppy-Dashboard-note, .sv2 .uppy-StatusBar-statusPrimary, .sv2 .uppy-Dashboard-Item-name { color: var(--sv2-txt) !important; }
.sv2 .uppy-Dashboard-note { color: var(--sv2-mut) !important; }
/* "browse files" — was pink; make it red, and red-fill/white-text on hover */
.sv2 .uppy-Dashboard-browse { color: var(--sv2-red) !important; background: transparent !important; border: 1px solid var(--sv2-line) !important; border-radius: 6px !important; padding: 4px 10px !important; }
.sv2 .uppy-Dashboard-browse:hover, .sv2 .uppy-Dashboard-browse:focus { color: #fff !important; background: var(--sv2-red) !important; border-color: var(--sv2-red) !important; }
/* status / progress accents */
.sv2 .uppy-StatusBar:not(.is-complete) .uppy-StatusBar-progress, .sv2 .uppy-StatusBar.is-complete .uppy-StatusBar-progress { background-color: var(--sv2-red) !important; }
.sv2 .uppy-DashboardContent-bar, .sv2 .uppy-Dashboard-files, .sv2 .uppy-StatusBar { background: var(--sv2-panel) !important; color: var(--sv2-txt) !important; border-color: var(--sv2-line) !important; }
/* every other Uppy button: never pink — transparent, red-fill on hover */
.sv2 .uppy-Dashboard button:hover, .sv2 .uppy-Dashboard button:focus, .sv2 .uppy-c-btn:hover, .sv2 .uppy-c-btn:focus { background-color: var(--sv2-red) !important; color: #fff !important; border-color: var(--sv2-red) !important; }
.sv2 .uppy-Dashboard-Item-action--remove { color: var(--sv2-red) !important; background: transparent !important; }
.sv2 .uppy-Dashboard-Item-action--remove svg { fill: currentColor !important; }

/* ── Responsive ── */
@media (max-width: 900px) {
	.sv2-cards, .sv2-addons { grid-template-columns: 1fr; }
	.sv2-art { grid-template-columns: 1fr; }
	.sv2-form__grid { grid-template-columns: 1fr; }
	/* Every field spans the single column = 100% width, one per row. */
	.sv2-field--half, .sv2-field--third, .sv2-field--full { grid-column: 1 / -1; }
	.sv2-form__note { max-width: 100%; }
	/* sit above the theme's 58px .mobile-cta sticky bar */
	.sv2-summary { left: 12px; right: 12px; bottom: 70px; width: auto; }
	.sv2-summary__list { max-height: 120px; }
}
