/**
 * OEM/ODM Services V6 — Design from V3 HTML, namespaced under .oem-odm-v6
 * Typography: DM Serif Display (headings) + DM Sans (body)
 */

.oem-odm-v6 {
  --ink:      #18181b;
  --ink-2:    #3f3f46;
  --ink-3:    #52525b;
  --ink-4:    #71717a;
  --rule:     #c0bfc4;
  --rule-lt:  #dddde0;
  --surface:  #f7f7f8;
  --surface-2:#efeff0;
  --pink:     #E91E8C;
  --pink-dk:  #B8176F;
  --pink-lt:  #fdf0f7;
  --pink-bd:  #f0a8d0;
  --white:    #ffffff;
  --serif: 'DM Serif Display', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;
  --r: 12px;
  --max: 1440px;
}

.oem-odm-v6,
.oem-odm-v6 *,
.oem-odm-v6 *::before,
.oem-odm-v6 *::after { box-sizing: border-box; }

.oem-odm-v6 {
  font-family: var(--sans);
  background: var(--white);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── WRAP & SECTION ── */
.oem-odm-v6 .wrap { max-width: var(--max); margin: 0 auto; padding: 0 2.5rem; }
.oem-odm-v6 .section { padding: 5rem 0; border-bottom: 1.5px solid var(--rule-lt); }
.oem-odm-v6 .section:last-child { border-bottom: none; }
.oem-odm-v6 .sec-eye { font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--pink); margin-bottom: 10px; }
.oem-odm-v6 .sec-title { font-family: var(--serif); font-size: 36px; letter-spacing: -.02em; margin-bottom: 12px; line-height: 1.15; color: var(--ink); }
.oem-odm-v6 .sec-intro { font-size: 14px; color: var(--ink-3); line-height: 1.75; max-width: 580px; margin-bottom: 2.5rem; }

/* ── HERO ── */
.oem-odm-v6 .hero { padding: calc(5rem + 20px) 0 4.5rem; border-bottom: 1.5px solid var(--rule-lt); }
.oem-odm-v6 .hero-eye { font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--pink); margin-bottom: 16px; }
.oem-odm-v6 .hero h1 { font-family: var(--serif); font-size: 56px; line-height: 1.06; letter-spacing: -.03em; margin-bottom: 14px; color: var(--ink); }
.oem-odm-v6 .hero h1 em { font-style: italic; color: var(--ink-4); }
.oem-odm-v6 .hero-body { font-size: 15px; color: var(--ink-3); line-height: 1.75; max-width: 460px; }
.oem-odm-v6 .hero-inner { display: grid; grid-template-columns: 1fr 650px; gap: 0; align-items: center; }
.oem-odm-v6 .hero-img-single { height: 450px; border-radius: 0; overflow: hidden; border: none; }
.oem-odm-v6 .hero-img-single img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* hero stat strip */
.oem-odm-v6 .hero-stat-strip { display: flex; align-items: center; gap: 0; margin-top: 24px; border: 1.5px solid var(--rule-lt); border-radius: 9px; overflow: hidden; background: var(--surface); }
.oem-odm-v6 .hss-item { flex: 1; padding: 12px 16px; text-align: center; }
.oem-odm-v6 .hss-num { font-family: var(--serif); font-size: 24px; line-height: 1; color: var(--ink); margin-bottom: 3px; }
.oem-odm-v6 .hss-lbl { font-size: 11px; color: var(--ink-4); line-height: 1.3; }
.oem-odm-v6 .hss-pink .hss-num { color: var(--pink-dk); }
.oem-odm-v6 .hss-pink .hss-lbl { color: var(--pink-dk); opacity: .75; }
.oem-odm-v6 .hss-div { width: 1.5px; height: 36px; background: var(--rule-lt); flex-shrink: 0; }

/* ── BUTTONS ── */
.oem-odm-v6 .btn-primary { background: var(--ink); color: var(--white); font-family: var(--sans); font-size: 14px; font-weight: 500; padding: 13px 26px; border-radius: 7px; text-decoration: none; transition: background .15s; border: none; cursor: pointer; display: inline-block; }
.oem-odm-v6 .btn-primary:hover { background: var(--pink-dk); }
.oem-odm-v6 .btn-pink { background: var(--pink); color: var(--white); font-family: var(--sans); font-size: 13px; font-weight: 500; padding: 13px 28px; border-radius: 7px; text-decoration: none; transition: background .15s; white-space: nowrap; text-align: center; display: inline-block; }
.oem-odm-v6 .btn-pink:hover { background: var(--pink-dk); }

/* ── OEM VS ODM ── */
.oem-odm-v6 .two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5px; background: var(--rule-lt); border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .service-col { background: var(--white); padding: 36px 32px; }
.oem-odm-v6 .service-col.featured { background: var(--surface); }
.oem-odm-v6 .svc-tag { font-size: 11px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--pink); margin-bottom: 14px; }
.oem-odm-v6 .svc-title { font-family: var(--serif); font-size: 26px; margin-bottom: 8px; color: var(--ink); }
.oem-odm-v6 .svc-sub { font-size: 13px; color: var(--ink-4); font-style: italic; margin-bottom: 18px; }
.oem-odm-v6 .svc-body { font-size: 13px; color: var(--ink-3); line-height: 1.7; margin-bottom: 20px; }
.oem-odm-v6 .svc-list { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.oem-odm-v6 .svc-list li { font-size: 13px; color: var(--ink-2); display: flex; gap: 9px; align-items: flex-start; line-height: 1.5; }
.oem-odm-v6 .svc-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--pink); flex-shrink: 0; margin-top: 7px; }

/* ── MOQ TIERS ── */
.oem-odm-v6 .moq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5px; background: var(--rule-lt); border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .moq-col { background: var(--white); padding: 32px 28px; position: relative; }
.oem-odm-v6 .moq-col.feat { background: var(--ink); }
.oem-odm-v6 .moq-pop { position: absolute; top: 18px; right: 18px; background: var(--pink); color: var(--white); font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; padding: 3px 10px; border-radius: 20px; }
.oem-odm-v6 .moq-tier-tag { font-size: 11px; font-weight: 500; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 18px; }
.oem-odm-v6 .moq-col.feat .moq-tier-tag { color: rgba(255,255,255,.4); }
.oem-odm-v6 .moq-big { font-family: var(--serif); font-size: 62px; line-height: 1; color: var(--ink); }
.oem-odm-v6 .moq-col.feat .moq-big { color: var(--white); }
.oem-odm-v6 .moq-sub { font-size: 12px; color: var(--ink-4); margin-top: 5px; margin-bottom: 24px; }
.oem-odm-v6 .moq-col.feat .moq-sub { color: rgba(255,255,255,.38); }
.oem-odm-v6 .moq-rule { border: none; border-top: 1.5px solid var(--rule-lt); margin-bottom: 20px; }
.oem-odm-v6 .moq-col.feat .moq-rule { border-color: rgba(255,255,255,.14); }
.oem-odm-v6 .moq-list { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.oem-odm-v6 .moq-list li { font-size: 13px; color: var(--ink-2); display: flex; gap: 9px; align-items: flex-start; line-height: 1.5; }
.oem-odm-v6 .moq-col.feat .moq-list li { color: rgba(255,255,255,.72); }
.oem-odm-v6 .moq-chk { width: 16px; height: 16px; border-radius: 50%; background: var(--pink-lt); border: 1.5px solid var(--pink-bd); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.oem-odm-v6 .moq-col.feat .moq-chk { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.22); }
.oem-odm-v6 .moq-chk::after { content: '\2713'; font-size: 9px; color: var(--pink); font-weight: 700; }
.oem-odm-v6 .moq-col.feat .moq-chk::after { color: rgba(255,255,255,.85); }

/* ── CUSTOMIZATION with images ── */
.oem-odm-v6 .custom-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5px; background: var(--rule-lt); border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .custom-cell { background: var(--white); display: flex; flex-direction: column; }
.oem-odm-v6 .cc-img { aspect-ratio: 4/3; background: var(--surface); border-bottom: 1.5px solid var(--rule-lt); overflow: hidden; position: relative; flex-shrink: 0; }
.oem-odm-v6 .cc-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.oem-odm-v6 .cc-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.oem-odm-v6 .cc-ph span { font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--rule); }
.oem-odm-v6 .cc-body-wrap { padding: 20px 22px; flex: 1; display: flex; flex-direction: column; }
.oem-odm-v6 .cc-num { font-family: var(--serif); font-size: 28px; color: var(--rule-lt); line-height: 1; margin-bottom: 10px; }
.oem-odm-v6 .cc-title { font-size: 15px; font-weight: 500; color: var(--ink); margin-bottom: 6px; }
.oem-odm-v6 .cc-body { font-size: 13px; color: var(--ink-3); line-height: 1.6; margin-bottom: 12px; flex: 1; }
.oem-odm-v6 .cc-tags { display: flex; gap: 5px; flex-wrap: wrap; }
.oem-odm-v6 .cc-tag { font-size: 11px; background: var(--surface); color: var(--ink-3); border: 1.5px solid var(--rule-lt); padding: 2px 9px; border-radius: 20px; }
.oem-odm-v6 .cc-tag.pink { background: var(--pink-lt); color: var(--pink-dk); border-color: var(--pink-bd); }

/* ── PROCESS with image cards ── */
.oem-odm-v6 .proc-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.oem-odm-v6 .proc-card { background: var(--white); display: flex; flex-direction: column; border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .proc-img { aspect-ratio: 3/2; background: var(--surface); border-bottom: 1.5px solid var(--rule-lt); overflow: hidden; position: relative; flex-shrink: 0; }
.oem-odm-v6 .proc-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.oem-odm-v6 .proc-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.oem-odm-v6 .proc-ph span { font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--rule); }
.oem-odm-v6 .hl-img { background: var(--ink); }
.oem-odm-v6 .proc-card-body { padding: 20px 18px; flex: 1; }
.oem-odm-v6 .hl-body { background: var(--white); }
.oem-odm-v6 .proc-day { font-size: 22px; font-weight: 300; line-height: 1; color: var(--ink-4); margin-bottom: 6px; }
.oem-odm-v6 .proc-stage { font-size: 13px; font-weight: 500; color: var(--ink); margin-bottom: 3px; }
.oem-odm-v6 .proc-desc { font-size: 11px; color: var(--ink-4); line-height: 1.5; }
.oem-odm-v6 .proc-foot { background: var(--surface); border: 1.5px solid var(--rule-lt); border-top: none; border-radius: 0 0 var(--r) var(--r); padding: 11px 20px; font-size: 12px; color: var(--ink-4); display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.oem-odm-v6 .proc-foot strong { color: var(--ink); font-weight: 500; }

/* ── CERTIFICATIONS with images ── */
.oem-odm-v6 .cert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
.oem-odm-v6 .cert-card { border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; display: flex; flex-direction: column; }
.oem-odm-v6 .cert-img { aspect-ratio: 3/2; background: var(--surface); border-bottom: 1.5px solid var(--rule-lt); overflow: hidden; position: relative; flex-shrink: 0; }
.oem-odm-v6 .cert-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.oem-odm-v6 .cert-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.oem-odm-v6 .cert-ph span { font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--rule); }
.oem-odm-v6 .cert-card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.oem-odm-v6 .cert-badge { width: 36px; height: 36px; border-radius: 7px; background: var(--pink-lt); border: 1.5px solid var(--pink-bd); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: var(--pink-dk); margin-bottom: 10px; letter-spacing: .02em; flex-shrink: 0; }
.oem-odm-v6 .cert-name { font-size: 13px; font-weight: 500; margin-bottom: 4px; color: var(--ink); }
.oem-odm-v6 .cert-desc { font-size: 12px; color: var(--ink-3); line-height: 1.55; flex: 1; }
.oem-odm-v6 .cert-status { font-size: 10px; color: var(--pink); font-weight: 500; margin-top: 8px; letter-spacing: .04em; display: block; }

/* ── QC STEPS with images ── */
.oem-odm-v6 .qc-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.oem-odm-v6 .qc-step { background: var(--white); display: flex; flex-direction: column; border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .qc-step-img { aspect-ratio: 3/2; background: var(--surface); border-bottom: 1.5px solid var(--rule-lt); overflow: hidden; position: relative; flex-shrink: 0; }
.oem-odm-v6 .qc-step-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.oem-odm-v6 .qc-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.oem-odm-v6 .qc-ph span { font-size: 9px; font-weight: 500; letter-spacing: .05em; text-transform: uppercase; color: var(--rule); text-align: center; padding: 0 6px; }
.oem-odm-v6 .qc-step-body { padding: 18px 16px; }
.oem-odm-v6 .qc-step-num { font-family: var(--serif); font-size: 18px; color: var(--pink-bd); line-height: 1; margin-bottom: 6px; }
.oem-odm-v6 .qc-step-name { font-size: 12px; font-weight: 500; color: var(--ink); margin-bottom: 3px; }
.oem-odm-v6 .qc-step-desc { font-size: 11px; color: var(--ink-4); line-height: 1.4; }

/* ── FAQ ── */
.oem-odm-v6 .faq-list { border: 1.5px solid var(--rule-lt); border-radius: var(--r); overflow: hidden; }
.oem-odm-v6 .faq-item { border-bottom: 1.5px solid var(--rule-lt); }
.oem-odm-v6 .faq-item:last-child { border-bottom: none; }
.oem-odm-v6 .faq-q {
  width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  font-family: var(--sans); font-size: 14px; font-weight: 500; color: var(--ink);
  padding: 20px 26px; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.oem-odm-v6 .faq-q:hover { background: var(--surface); }
.oem-odm-v6 .faq-icon {
  width: 24px; height: 24px; border-radius: 50%; background: var(--surface-2); border: 1.5px solid var(--rule-lt);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  font-size: 15px; color: var(--ink-4); transition: transform .2s, background .15s, color .15s, border-color .15s;
}
.oem-odm-v6 .faq-item.open .faq-icon { transform: rotate(45deg); background: var(--pink); color: var(--white); border-color: var(--pink); }
.oem-odm-v6 .faq-a { font-size: 13px; color: var(--ink-3); line-height: 1.8; padding: 0 26px 22px; display: none; max-width: 760px; }
.oem-odm-v6 .faq-item.open .faq-a { display: block; }

/* ── CONTACT SECTION ── */
.oem-odm-v6 .contact-section {
  background: var(--ink); border-radius: 16px;
  margin: 4rem auto; padding: 3rem 3.5rem; max-width: var(--max);
  display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: flex-start;
}
.oem-odm-v6 .contact-eye { font-size: 11px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--pink); margin-bottom: 10px; }
.oem-odm-v6 .contact-section h2 { font-family: var(--serif); font-size: 32px; color: var(--white); line-height: 1.2; margin-bottom: 10px; letter-spacing: -.02em; }
.oem-odm-v6 .contact-section p { font-size: 14px; color: rgba(255,255,255,.55) !important; line-height: 1.7; max-width: 480px; }
.oem-odm-v6 .contact-methods { margin-top: 1.5rem; display: flex; flex-direction: column; gap: 8px; }
.oem-odm-v6 .contact-method {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px; padding: 11px 16px;
  text-decoration: none; transition: background .15s;
}
.oem-odm-v6 .contact-method:hover { background: rgba(255,255,255,.1); color: var(--white); }
.oem-odm-v6 .contact-method__icon { width: 16px; height: 16px; flex-shrink: 0; }

/* WPForms overrides inside contact section */
.oem-odm-v6 .contact-section .wpforms-container { color: #fff; }
.oem-odm-v6 .contact-section .wpforms-container .wpforms-field label,
.oem-odm-v6 .contact-section .wpforms-container label.wpforms-field-label { color: #fff !important; }
.oem-odm-v6 .contact-section .wpforms-container input,
.oem-odm-v6 .contact-section .wpforms-container textarea {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  color: var(--white); border-radius: 7px; padding: 12px 14px; font-size: 14px;
  width: 100%;
}
.oem-odm-v6 .contact-section .wpforms-container input::placeholder,
.oem-odm-v6 .contact-section .wpforms-container textarea::placeholder { color: rgba(255,255,255,.35); }
.oem-odm-v6 .contact-section .wpforms-container input:focus,
.oem-odm-v6 .contact-section .wpforms-container textarea:focus {
  border-color: var(--pink); outline: none; background: rgba(255,255,255,.12);
}
.oem-odm-v6 .contact-section .wpforms-container button[type="submit"],
.oem-odm-v6 .contact-section .wpforms-container .wpforms-submit {
  background: var(--pink) !important; color: var(--white) !important;
  border: none; border-radius: 7px; padding: 13px 28px;
  font-size: 14px; font-weight: 500; cursor: pointer; transition: background .15s;
}
.oem-odm-v6 .contact-section .wpforms-container button[type="submit"]:hover,
.oem-odm-v6 .contact-section .wpforms-container .wpforms-submit:hover {
  background: var(--pink-dk) !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .oem-odm-v6 .hero-inner { grid-template-columns: 1fr; gap: 3rem; }
  .oem-odm-v6 .hero h1 { font-size: 40px; }
  .oem-odm-v6 .two-col,
  .oem-odm-v6 .moq-grid { grid-template-columns: 1fr; }
  .oem-odm-v6 .cert-grid { grid-template-columns: repeat(2, 1fr); }
  .oem-odm-v6 .proc-grid { grid-template-columns: repeat(3, 1fr); }
  .oem-odm-v6 .qc-steps { grid-template-columns: repeat(2, 1fr); }
  .oem-odm-v6 .custom-grid { grid-template-columns: 1fr 1fr; }
  .oem-odm-v6 .contact-section { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .oem-odm-v6 .custom-grid { grid-template-columns: 1fr; }
  .oem-odm-v6 .proc-grid { grid-template-columns: 1fr 1fr; }
  .oem-odm-v6 .qc-steps { grid-template-columns: 1fr 1fr; }
  .oem-odm-v6 .hero-stat-strip { flex-wrap: wrap; }
  .oem-odm-v6 .hss-div { display: none; }
  .oem-odm-v6 .hss-item { flex: 1 0 40%; }
  .oem-odm-v6 .contact-section { padding: 2rem 1.5rem; margin: 2rem 1rem; }
}
