/* NDCTees /services/dtf-transfers — DTF Transfers order page.
   Cloned from specials-v2.css with a dtf2- prefix. Uses site design tokens
   (var(--red) etc.) with fallbacks so it renders even if a token is missing. */

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

/* ── Hero ── */
.dtf2__hero { text-align: center; padding: 64px 0 40px; }
.dtf2__eyebrow { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 3px; font-size: 12px; font-weight: 700; color: var(--dtf2-red); }
.dtf2__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; }
.dtf2__accent { color: var(--dtf2-red); }
.dtf2__sub { color: var(--dtf2-mut); max-width: 660px; margin: 0 auto; font-size: 16px; line-height: 1.6; }

/* ── Generic section ── */
.dtf2-section { margin: 0 0 40px; padding: 28px; border: 1px solid var(--dtf2-line); border-radius: 14px; background: var(--dtf2-panel); position: relative; }
.dtf2-section__head { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px 16px; margin-bottom: 18px; }
.dtf2-section__eyebrow { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 2px; font-size: 11px; font-weight: 700; color: var(--dtf2-red); background: rgba(204,0,0,.12); padding: 4px 10px; border-radius: 999px; }
.dtf2-section__heading { font-family: var(--font-display, inherit); font-size: clamp(22px, 3vw, 30px); font-weight: 700; text-transform: uppercase; margin: 0; }

/* ── What / why ── */
.dtf2-what__lead { color: var(--dtf2-txt); font-size: 15.5px; line-height: 1.65; margin: 0 0 18px; max-width: 820px; }
.dtf2-chips { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 10px; }
.dtf2-chip { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border: 1px solid var(--dtf2-line); border-radius: 999px; background: var(--dtf2-panel2); font-size: 13px; font-weight: 600; transition: border-color .18s, transform .18s; }
.dtf2-chip::before { content: "\2713"; color: var(--dtf2-red); font-weight: 700; }
.dtf2-chip:hover { transform: translateY(-2px); border-color: rgba(255,255,255,.28); }

/* ── Pricing ── */
.dtf2-pricing__intro { color: var(--dtf2-mut); font-size: 15px; margin: 0 0 18px; }
.dtf2-price-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.dtf2-price-card { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 24px 16px; border: 2px solid var(--dtf2-line); border-radius: 12px; background: var(--dtf2-panel2); text-align: center; transition: border-color .18s, transform .18s; }
.dtf2-price-card:hover { transform: translateY(-3px); border-color: var(--dtf2-red); }
.dtf2-price-card__size { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 14px; font-weight: 700; color: var(--dtf2-mut); }
.dtf2-price-card__price { font-family: var(--font-display, inherit); font-size: 40px; font-weight: 800; color: #fff; line-height: 1; }
.dtf2-pricing__notes { margin: 18px 0 0; color: var(--dtf2-red); font-size: 12.5px; font-weight: 600; }

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

/* Rush checkbox row sits in a half field */
.dtf2-field--rush { justify-content: flex-start; }
.dtf2-rush { display: flex; align-items: center; gap: 8px; background: var(--dtf2-ink); border: 1px solid var(--dtf2-line); border-radius: 8px; padding: 11px 12px; font-size: 14px; color: var(--dtf2-txt); cursor: pointer; transition: border-color .15s; }
.dtf2-rush:hover { border-color: rgba(255,255,255,.28); }
.dtf2-rush input { width: 17px; height: 17px; accent-color: var(--dtf2-red); flex: 0 0 auto; }
.dtf2-rush:has(input:checked) { border-color: var(--dtf2-red); box-shadow: 0 0 0 2px rgba(204,0,0,.22); }

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

/* ── Artwork upload (single zone) ── */
.dtf2-art { margin-top: 22px; }
.dtf2-art__head { display: flex; flex-direction: column; gap: 2px; margin-bottom: 8px; }
.dtf2-art__head strong { font-family: var(--font-condensed, inherit); text-transform: uppercase; letter-spacing: 1px; font-size: 13px; }
.dtf2-art__head span { color: var(--dtf2-mut); font-size: 12.5px; }
.dtf2-art__slot { background: var(--dtf2-panel2); border: 1px solid var(--dtf2-line); border-radius: 10px; padding: 14px; min-width: 0; }
.dtf2-art__slot .rfm-cu-host { min-width: 0; max-width: 100%; }
.dtf2 .uppy-Root, .dtf2 .uppy-Dashboard, .dtf2 .uppy-Dashboard-inner { max-width: 100% !important; min-width: 0 !important; width: 100% !important; }

/* ── Submit foot ── */
.dtf2-form__foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 24px; flex-wrap: wrap; }
.dtf2-form__note { color: var(--dtf2-mut); font-size: 12.5px; margin: 0; max-width: 60%; }
.dtf2-submit { background: var(--dtf2-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, transform .18s; }
.dtf2-submit:not(:disabled):hover { background: #a30000; transform: translateY(-2px); }
.dtf2-submit:focus, .dtf2-submit:active { background: var(--dtf2-red); border-color: var(--dtf2-red); color: #fff; }
.dtf2-submit:disabled { opacity: .4; cursor: not-allowed; }
.dtf2-result { margin-top: 18px; padding: 14px 16px; border-radius: 8px; font-size: 14px; line-height: 1.5; }
.dtf2-result.is-ok { background: rgba(34,197,94,.14); border: 1px solid rgba(34,197,94,.5); color: #d6ffe2; }
.dtf2-result.is-err { background: rgba(204,0,0,.14); border: 1px solid rgba(204,0,0,.5); color: #ffd9d9; }

/* ── FAQ ── */
.dtf2-faq__list { display: flex; flex-direction: column; gap: 10px; }
.dtf2-faq__item { border: 1px solid var(--dtf2-line); border-radius: 10px; background: var(--dtf2-panel2); overflow: hidden; transition: border-color .18s; }
.dtf2-faq__item:hover { border-color: rgba(255,255,255,.28); }
.dtf2-faq__item[open] { border-color: var(--dtf2-red); }
.dtf2-faq__q { list-style: none; cursor: pointer; padding: 16px 18px; font-weight: 700; font-size: 15px; color: var(--dtf2-txt); position: relative; padding-right: 44px; }
.dtf2-faq__q::-webkit-details-marker { display: none; }
.dtf2-faq__q::after { content: "+"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--dtf2-red); font-size: 22px; line-height: 1; font-weight: 700; }
.dtf2-faq__item[open] .dtf2-faq__q::after { content: "\2212"; }
.dtf2-faq__a { padding: 0 18px 16px; color: var(--dtf2-mut); font-size: 14px; line-height: 1.6; }

/* ── Cross-link CTA ── */
.dtf2-crosslink { text-align: center; padding: 28px; border: 1px dashed var(--dtf2-line); border-radius: 14px; background: var(--dtf2-panel); }
.dtf2-crosslink p { margin: 0; font-size: 15px; color: var(--dtf2-txt); }
.dtf2-crosslink a { color: var(--dtf2-red); text-decoration: none; }
.dtf2-crosslink a:hover, .dtf2-crosslink a:focus { color: #fff; }

/* ── Kill the theme's pink (#CC3366) inside the page ── */
.dtf2 a { color: var(--dtf2-red); }
.dtf2 a:hover, .dtf2 a:focus { color: #fff; }

/* Uppy dashboard surfaces → dark panel (mirrors specials-v2) */
.dtf2 .uppy-Root, .dtf2 .uppy-Dashboard-inner, .dtf2 .uppy-Dashboard-innerWrap { background: var(--dtf2-panel2) !important; color: var(--dtf2-txt) !important; border-color: var(--dtf2-line) !important; }
.dtf2 .uppy-Dashboard-AddFiles { border-color: var(--dtf2-line) !important; }
.dtf2 .uppy-Dashboard-AddFiles-title, .dtf2 .uppy-Dashboard-dropFilesHereHint, .dtf2 .uppy-Dashboard-note, .dtf2 .uppy-StatusBar-statusPrimary, .dtf2 .uppy-Dashboard-Item-name { color: var(--dtf2-txt) !important; }
.dtf2 .uppy-Dashboard-note { color: var(--dtf2-mut) !important; }
.dtf2 .uppy-Dashboard-browse { color: var(--dtf2-red) !important; background: transparent !important; border: 1px solid var(--dtf2-line) !important; border-radius: 6px !important; padding: 4px 10px !important; }
.dtf2 .uppy-Dashboard-browse:hover, .dtf2 .uppy-Dashboard-browse:focus { color: #fff !important; background: var(--dtf2-red) !important; border-color: var(--dtf2-red) !important; }
.dtf2 .uppy-StatusBar:not(.is-complete) .uppy-StatusBar-progress, .dtf2 .uppy-StatusBar.is-complete .uppy-StatusBar-progress { background-color: var(--dtf2-red) !important; }
.dtf2 .uppy-DashboardContent-bar, .dtf2 .uppy-Dashboard-files, .dtf2 .uppy-StatusBar { background: var(--dtf2-panel) !important; color: var(--dtf2-txt) !important; border-color: var(--dtf2-line) !important; }
.dtf2 .uppy-Dashboard button:hover, .dtf2 .uppy-Dashboard button:focus, .dtf2 .uppy-c-btn:hover, .dtf2 .uppy-c-btn:focus { background-color: var(--dtf2-red) !important; color: #fff !important; border-color: var(--dtf2-red) !important; }
.dtf2 .uppy-Dashboard-Item-action--remove { color: var(--dtf2-red) !important; background: transparent !important; }
.dtf2 .uppy-Dashboard-Item-action--remove svg { fill: currentColor !important; }

/* ── Responsive ── */
@media (max-width: 900px) {
	.dtf2-price-cards { grid-template-columns: repeat(2, 1fr); }
	.dtf2-form__grid { grid-template-columns: 1fr; }
	.dtf2-field--half, .dtf2-field--full { grid-column: 1 / -1; }
	.dtf2-form__note { max-width: 100%; }
}
@media (max-width: 520px) {
	.dtf2-price-cards { grid-template-columns: 1fr; }
}
