.elementor-21141 .elementor-element.elementor-element-c4a6edb{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0%;--padding-bottom:0%;--padding-left:4%;--padding-right:4%;}.elementor-21141 .elementor-element.elementor-element-c4a6edb.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-21141 .elementor-element.elementor-element-bcb6331{--display:flex;}@media(min-width:768px){.elementor-21141 .elementor-element.elementor-element-c4a6edb{--width:87.1%;}}/* Start custom CSS for html, class: .elementor-element-e0390e8 *//* =======================================================
   PDP BASE
   ======================================================= */
.pdp {
  --ink: #0f172a;
  --muted: #667085;
  --border: #e5e7eb;
  --bg: #fff;
  --primary: #0b1222;
  --radius: 16px;

  color: var(--ink);
  font-family: "Inter Tight", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
.pdp * { box-sizing: border-box; }

/* =======================================================
   LAYOUT
   ======================================================= */
.pdp-wrap {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 32px;
  align-items: start;
}

@media (max-width: 900px) {
  .pdp-wrap { grid-template-columns: 1fr; }
}

/* =======================================================
   BREADCRUMB
   ======================================================= */
.bs-breadcrumb {
  margin: 35px 0;
  font: inherit;
}
.bs-bc-list {
  display: flex; align-items: center;
  gap: 0; margin: 0; padding: 0; list-style: none;
}
.bs-bc-item { display: flex; align-items: center; }

/* separators */
.bs-bc-item + .bs-bc-item::before {
  content: "›";
  margin: 0 10px;
  color: #94a3b8;
  line-height: 1;
}

/* links */
.bs-bc-link {
  text-decoration: none;
  color: #101828;
  font-weight: 500;
  font-size: 18px;
}
.bs-bc-link:hover { text-decoration: underline; }

/* current page */
.bs-bc-current {
  color: #667085;
  font-weight: 500;
  font-size: 18px;
}

/* home icon + a11y text */
.bs-bc-home { display: inline-flex; align-items: center; }
.bs-sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 1px, 1px); white-space: nowrap; border: 0;
}

/* =======================================================
   MEDIA (GALLERY)
   ======================================================= */
.pdp-hero {
  border-radius: 7px;
  overflow: hidden;
  background: #fff;
  border: 2px solid #efeded;
}
.pdp-hero img {
  width: 100%;
  height: 620px;
  display: block;
  object-fit: contain;
  /*padding-top: 25px;*/
}

.pdp-thumbs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  margin-top: 16px;
}
.pdp-thumbs button {
  padding: 0; border: 0; background: none;
  cursor: pointer;
  border-radius: 6px;
  overflow: hidden;
  outline: 2px solid #efeded;
  transition: outline-color .2s ease;
}
.pdp-thumbs button.is-active { outline-color: #cbd5e1; }
.pdp-thumbs img {
  width: 100%;
  height: 150px;
  display: block;
  object-fit: contain;
}

@media (max-width: 600px) {
  .pdp-thumbs { grid-template-columns: repeat(3, 1fr); gap: 10px; }
}

/* =======================================================
   INFO PANEL
   ======================================================= */
.pdp-info { max-width: 590px; width: 100%; }

.pdp-brand {
  color: var(--muted);
  font-size: 19px;
  margin-top: 4px;
}
.pdp-title {
  font-size: 30px;
  line-height: 1.2;
  margin: 6px 0 8px;
  font-weight: 500;
}
.pdp-from {
  color: #667085;
  margin-bottom: 16px;
  font-size: 20px;
}
.pdp-from strong { color: #101828; font-weight: 600; }

@media (max-width: 600px) {
  .pdp-title { font-size: 24px; }
}

/* Colors / Swatches */
.pdp-colors { margin: 16px 0 12px; }
.pdp-label {
  font-weight: 500;
  margin-bottom: 15px;
  color: #667085;
  font-size: 20px;
}
.pdp-swatches { display: flex; gap: 15px; margin-top: 8px; }

.pdp .pdp-swatches .swatch {
  width: 36px; height: 36px;
  background: var(--c) !important; /* lock color */
  border: 1px solid rgba(0,0,0,.08);
  cursor: pointer;
  outline: 2px solid transparent;
  outline-offset: 2px;
  border-radius: 0; /* square per your style */
  padding: 0;
}
.pdp .pdp-swatches .swatch:hover,
.pdp .pdp-swatches .swatch:active {
  background: var(--c) !important;
  box-shadow: none !important;
  filter: none !important;
  transform: none !important;
  outline: none !important;
}
.pdp .pdp-swatches .swatch.is-active {
  outline: 2px solid #6d28d9;
  outline-offset: 2px;
  border-radius: 0;
}

/* CTA */
.pdp-cta {
  margin: 35px 0 16px;
  width: 100%; height: 54px;
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;

  border: 0; border-radius: 6px;
  background: var(--primary);
  color: #fff;

  font-size: 18px; font-weight: 600;
  cursor: pointer;
  transition: filter .2s ease;
}
.pdp-cta:hover { filter: brightness(0.98); }

/* Expert card */
.pdp-expert {
    display: flex;
    gap: 14px;
    flex-direction: column;
    align-items: start;
    padding: 25px;
    border-radius: 14px;
    border: 1px solid #eef2ff;
    background: url(https://blinkswag.com/wp-content/uploads/2025/09/bg-expert.png) center / cover no-repeat #fff;
}
.expert-title {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 6px;
  font-weight: 600; font-size: 22px;
}
.expert-title img { width: 75px; }
.expert-text p { margin: 20px 0; font-size: 22px; color: #101828; line-height: 30px; }

.expert-btn {
  display: flex; align-items: center; gap: 7px;
  height: 52px; padding: 0 14px;

  border: 0; border-radius: 7px;
  background: #101828; color: #fff;

  font-size: 18px; font-weight: 600;
  cursor: pointer;
}

/* Tabs */
.pdp-tabs { display: flex; gap: 10px; margin: 50px 0 10px; }
.pdp-tabs .tab {
  height: 48px; padding: 0 20px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;

  font: 500 16px/1 "Inter Tight", sans-serif;
  color: #667085;
  transition: color .2s ease, border-color .2s ease, background .2s ease;
}
.pdp-tabs .tab:hover {
  border-radius: 7px;
  background: none;
  color: #000;
}
.pdp-tabs .tab.is-active {
  background: none;
  border: 1px solid #101828;
  color: #101828;
}

.pdp-tabcontent { display: none; color: #374151; }
.pdp-tabcontent.is-active { display: block; }

.pdp-tabcontent p {
  color: #475467;
  font-size: 15px;
  margin: 10px 0;
  font-family: "Inter Tight", sans-serif;
}

pre.description_p {
  background: none;
  padding: 15px 0;
  font-size: 15px;
  font-family: "Inter Tight", sans-serif !important;
  font-style: normal;
}

/* Technique buttons */
button.technique-btns {
  background-color: #fbfbfb;
  border-radius: 10px;
  color: #667085;
  border: 1px solid #EAECF0;
  padding: 8px 12px;
  cursor: pointer;
  transition: background-color .2s ease, color .2s ease;
}
button.technique-btns:hover {
  background-color: #f5f5f5;
  color: #464646;
}

/* =======================================================
   QTY CARD
   ======================================================= */
.qty-card {
  --border: #e6e8ec;
  --accent: #6935D3;

  max-width: 660px;
  margin-top: 35px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 16px 16px;
  color: var(--ink);
}

.qty-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.qty-title {
  font-size: 20px; font-weight: 500; color: #101828; letter-spacing: 0;
  font-family: "Inter Tight", sans-serif;
}
.qty-title .muted { color: var(--muted); font-weight: 400; margin-left: 2px; font-size: 16px; }

.qty-box {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--accent);
  border-radius: 12px;
  font-family: "Inter Tight", sans-serif;
}

.qty-left { display: flex; align-items: baseline; gap: 0; min-width: 0; }

.select-wrap { position: relative; display: inline-flex; align-items: center; }
.select-wrap select {
  appearance: none;
  border: 0; background: transparent;
  padding: 8px 20px 8px 10px;
  font-weight: 600; font-size: 19px; color: #1D2939;
  border-radius: 8px; outline: none;
  font-family: "Inter Tight", sans-serif;
}
.select-wrap .chev {
  position: absolute; right: 6px; top: 50%;
  transform: translateY(-50%);
  width: 16px; height: 16px; color: #8b5cf6; pointer-events: none;
}

.per-piece { color: var(--muted); font-size: 14px; white-space: nowrap; }

.qty-total {
  font-weight: 500; font-size: 19px;
  color: #1D2939; white-space: nowrap; padding-right: 4px;
}

/* Small screens */
@media (max-width: 480px) {
  .qty-title { font-size: 18px; }
  .qty-box { grid-template-columns: 1fr; gap: 8px; }
  .qty-total { justify-self: end; }
}

/* =======================================================
   MODAL
   ======================================================= */
.modal {
  position: fixed; inset: 0;
  display: none;
  align-items: center; justify-content: center;
  z-index: 1000;
  font-family: "Inter Tight", sans-serif;
}
.modal.is-open {
  display: flex !important;
  align-items: center; justify-content: center;
}
.modal[aria-hidden="true"] { display: none !important; }

.modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(16,24,40,.6);
  backdrop-filter: blur(2px);
}
.modal__panel {
  position: relative;
  width: min(960px, 96vw);
  max-height: min(92vh, 900px);
  background: #fff; border-radius: 24px; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  outline: 0;
   max-height: 90vh;      /* Or 100vh if you want full height */
  overflow-y: auto;      /* Enable vertical scroll inside popup */
}

.modal__panel .popup {
  max-height: 90vh;
  overflow-y: auto;
}
.modal__close {
  position: absolute; left: 30px; top: 14px;
  width: 28px; border: none; background: none; padding: 0;
  color: #111827; font-size: 22px; cursor: pointer; z-index: 2;
}

/* Modal layout */
.popup {
  display: grid; grid-template-columns: 360px 1fr; min-height: 540px;
  overflow-y: scroll;
}
@media (max-width: 880px) {
  .popup { grid-template-columns: 1fr; }
  .modal__panel { width: min(560px, 96vw); }
}

/* LEFT: product */
.popup__left { padding: 56px 28px 28px; background: #fff; }
.product {
  background: #f2f4f7; border-radius: 16px; overflow: hidden;
  aspect-ratio: 1/1;
  display: flex; align-items: center; justify-content: center;
}
.product__img { width: 100%; height: 100%; object-fit: cover; }
.product__meta { margin-top: 16px; }
.product__brand { color: #475467; font-size: 12px; }
.product__title {
  margin: 6px 0 8px;
  font-size: 23px; color: #111827; font-weight: 400;
}
.product__price { font-weight: 500; font-size: 24px; color: #1D2939; }
.product__note {
  margin-top: 5px; padding: 0; font-size: 14px; color: #475467;
}

button.modal__close:hover {
    background: none;
    border: none;
}

button.btn-register-module:hover {
    border-radius: 6px;
}
button.technique-btns:hover {
    border-radius: 8px;
}
.pdp-tabs .tab:focus {
    border-radius: 6px;
}
/* RIGHT: signup */
.popup__right {
  padding: 30px 40px;
  background-image: url(https://blinkswag.com/wp-content/uploads/2025/09/bg-signup.jpg);
  background-size: cover; background-repeat: no-repeat; background-position: center;
}
.su__headline {
  margin: 0 0 20px;
  font-size: 28px; line-height: 1.25;
  color: #101828; font-weight: 500; text-align: center;
}

/* Buttons */
.btn {
  height: 44px; border-radius: 10px; border: 1px solid #e5e7eb;
  padding: 0 14px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 10px;
  cursor: pointer; background: #fff;
}
.btn--google {
  width: 100%; justify-content: center;
  border: none !important; border-radius: 7px !important;
  background: #fff !important; color: #101828 !important;

  font-weight: 400 !important; font-size: 16px !important;
  padding: 25px 0 !important;
  transition: background-color .3s ease, color .3s ease;
}
.btn--google:hover { background: #101828 !important; color: #fff !important; }

.btn--primary {
  width: 100%; height: 48px;
  border: none; border-radius: 12px;
  font-weight: 700; color: #fff; background: #0b1220;
}
.btn--primary:hover { filter: brightness(1.05); }

/* Register CTA in modal */
button.btn-register-module {
  display: flex; justify-content: center; align-items: center; gap: 6px;
  margin-top: 15px; padding: 0 16px; height: 48px;

  background: #101828; color: #fff;
  border: none; border-radius: 6px;
  font-size: 19px; font-weight: 400;
  transition: background-color .3s ease;
  width: 100%;
}
button.btn-register-module:hover { background: #6935d3; }
button.btn-register-module img { width: 22px; }

button.btn-register-module:focus {
    border-radius: 6px;
}

/* Form */
.form { margin-top: 18px; display: grid; gap: 14px; }
.form__row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 520px) { .form__row--two { grid-template-columns: 1fr; } }

.field { display: grid; gap: 6px; position: relative; }
.field__label { font-size: 15px; color: #101828; margin-top: 10px; }
label.field img {
  position: absolute; top: 54px; left: 13px; width: 20px;
}
.req { color: #ef4444; margin-left: 2px; }

.field input {
  height: 44px; padding: 0 40px;
  border: 1px solid #e5e7eb; border-radius: 10px;
  font-size: 14px; color: #0b1220; background: #fff;
}
.field input::placeholder { color: #9aa4b2; }
.field input:focus {
  border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99,102,241,.15); outline: none;
}

/* Optional: lock body scroll when modal open */
.body-lock { overflow: hidden; }

/* =======================================================
   SKELETON SYSTEM (no-flicker)
   ======================================================= */

/* Look */
.skeleton {
  position: relative;
  overflow: hidden;
  background: #e5e7eb;
  border-radius: 12px;
}
.skeleton::after {
  content: "";
  position: absolute; inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.45), transparent);
  animation: skel 1.2s infinite;
}
@keyframes skel { 100% { transform: translateX(100%); } }

/* --- No-flicker visibility control (scoped to PDP) --- */
.pdp .hide-while-loading { display: none; }
.pdp [data-skel] { display: none; }

/* While loading: show skeletons, hide real */
.pdp.is-loading [data-skel] { display: block; }
.pdp.is-loading .hide-while-loading { display: none; }

/* After loading: hide skeletons, show real */
.pdp:not(.is-loading) [data-skel] { display: none; }
.pdp:not(.is-loading) .hide-while-loading { display: block; }

/* Sized blocks */
/* Breadcrumb */
.s-bc-home { width: 20px; height: 20px; border-radius: 6px; display: inline-block; vertical-align: middle; margin-right: 6px; }
.s-bc-line { width: 120px; height: 16px; border-radius: 8px; display: inline-block; margin-right: 10px; }

/* Gallery */
.s-hero     { width: 100%; aspect-ratio: 4/3; }
.s-thumbrow { width: 100%; height: 76px; border-radius: 10px; margin-top: 10px; }

/* Info */
.s-brand    { width: 120px; height: 14px; margin: 8px 0; }
.s-title    { width: 70%;  height: 22px; margin: 8px 0; }
.s-price    { width: 160px; height: 18px; margin: 8px 0; }
.s-colorbar { width: 100%; height: 44px; margin: 8px 0; border-radius: 12px; }
.s-qty      { width: 100%; height: 100px; margin: 8px 0; border-radius: 12px; }
.s-btn      { width: 220px; height: 48px; margin: 12px 0; border-radius: 12px; }
.s-expert   { width: 100%; height: 84px; margin: 10px 0; border-radius: 16px; }
.s-desc     { width: 100%; height: 140px; margin-top: 8px; border-radius: 12px; }

/* Modal */
.s-modal-img   { width: 100%; aspect-ratio: 1/1; border-radius: 12px; }
.s-modal-brand { width: 120px; height: 14px; margin-top: 10px; }
.s-modal-title { width: 75%;  height: 20px; margin-top: 8px; }
.s-modal-price { width: 90px;  height: 16px; margin-top: 8px; }



button.pdp-cta {
    background: #101828;
    transition: 0.3s ease all;
    border: none;
}
button.pdp-cta:hover {
    background: #282828;
}

button.expert-btn {
    background: #101828;
    transition: 0.3s ease all;
    border: none;
}
button.expert-btn:hover {
    background: #282828;
}

.pdp-thumbs button:hover {
    border-radius: 6px;
    background: none;
}
.pdp-thumbs button:focus {
    border-radius: 6px;
    background: none;
}

button.modal__close {
    background: none;
    padding: 0px;
}
button.modal__close img {
    width: 22px;
}



/* =========================================================
   MOBILE FIX PACK — KEEP DESKTOP UNCHANGED
   (applies at ≤ 900px; desktop stays exactly as you designed)
   ========================================================= */
@media (max-width: 900px){

  /* 1) One-column layout & sane spacing */
  body .pdp-wrap{
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* 2) PDP hero image: truly responsive (ignore fixed 620px) */
  body .pdp-hero{ width: 100% !important; }
  body .pdp-hero img,
  body .pdp-hero img[width],
  body .pdp-hero img[height]{
    width: 100% !important;
    height: auto !important;          /* drop hard height */
    max-height: 70vh !important;      /* keep it visible on small phones */
    object-fit: contain !important;
    padding-top: 0 !important;
    display: block !important;
  }

  /* 3) Thumbnail strip: responsive grid, images contained */
  body .pdp-thumbs{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-top: 12px !important;
  }
  @media (max-width: 420px){
    /* tiny phones: easy horizontal scroll instead of wrapping */
    body .pdp-thumbs{
      grid-auto-flow: column !important;
      grid-auto-columns: minmax(86px, 1fr) !important;
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch;
    }
  }
  body .pdp-thumbs button{
    display: grid !important;
    place-items: center !important;
    aspect-ratio: 1 / 1 !important;   /* square cells */
    outline-width: 1px;               /* keep your outline but lighter on mobile */
  }
  body .pdp-thumbs img,
  body .pdp-thumbs img[width],
  body .pdp-thumbs img[height]{
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  /* 4) Tabs: don’t stretch; allow swipe if crowded */
  body .pdp-tabs{
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 8px !important;
    -webkit-overflow-scrolling: touch;
  }
  body .pdp-tabs .tab{
    flex: 0 0 auto !important;        /* no stretching */
    min-width: 120px !important;
    height: 42px !important;
    font-size: 14px !important;
  }

  /* 5) CTA & buttons: tidy height only (width remains your design) */
  body .pdp-cta{
    height: 48px !important;
    font-size: 16px !important;
    border-radius: 8px !important;
  }

  /* 6) Swatches wrap nicely */
  body .pdp-swatches{
    flex-wrap: wrap !important;
    row-gap: 10px !important;
    column-gap: 12px !important;
  }
  body .pdp .pdp-swatches .swatch{
    width: 32px !important;
    height: 32px !important;
  }

  /* 7) Qty card stacks on small screens */
  body .qty-box{
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  body .qty-total{ justify-self: end !important; }

  /* 8) Safety: kill horizontal scroll if any container overflows */
  html, body{ overflow-x: hidden; }
}

/* Optional: slightly larger mobile breakpoint support (tablets) */
@media (max-width: 600px){
  body .pdp-title{ font-size: 22px !important; }
  body .expert-text p{ font-size: 16px !important; line-height: 24px !important; }
}

/* Fix <pre class="description_p"> causing horizontal scroll */
.pdp pre.description_p{
  white-space: pre-wrap !important;  /* keep line breaks, allow wrapping */
  overflow-wrap: anywhere !important;/* break long tokens like oz./yd.² */
  word-break: break-word;            /* fallback */
  max-width: 100%;
  width: 100%;
}

/* (Optional) tighten on small screens only */
@media (max-width: 900px){
  .pdp pre.description_p{
    font-size: 15px;       /* your original size; adjust if needed */
    padding: 12px 0;
  }
}


@media (max-width: 767px) {
  .popup__left {
    display: none;
  }
  
  .bs-bc-link {
    font-size: 14px;
}

.bs-bc-current {
    font-size: 14px;
}
}






/* ------------------------------------------
   MATCHING SELECT (based on your input style)
   ------------------------------------------ */
.field select {
  height: 44px;
  width: 100%;
  margin-bottom: 12px;
  padding: 0 15px;                  /* matches input padding */
  border: 1px solid #e5e7eb;        /* same border as input */
  border-radius: 10px;              /* SAME rounding */
  background: #fff;
  color: #0b1220;                   /* same ink color */
  font-size: 14px;
  font-family: "Inter Tight", sans-serif;

  appearance: none;                 /* remove browser arrow */
  -webkit-appearance: none;
  -moz-appearance: none;

  cursor: pointer;
  transition: border-color .2s ease,
              box-shadow .2s ease;
}

/* Focus matches your input focus */
.field select:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
  outline: none;
}

/* Optional placeholder style */
.field select:invalid {
  color: #9aa4b2;
}

/* ------------------------------------------
   SELECT ICON (matches input icon positioning)
   ------------------------------------------ */
.field select + img {
  position: absolute;
  top: 45px;               /* identical to your input icon position */
  left: 13px;
  width: 20px;
  pointer-events: none;
  opacity: 0.9;
}

/* Optional: subtle arrow overlay (your theme) */
.field.select-arrow::after {
  content: "▾";
  position: absolute;
  right: 14px;
  top: 45px;               /* aligned vertically with input */
  font-size: 14px;
  color: #667085;
  pointer-events: none;
}

 .input-error {
    border-color: #e74c3c !important;
  }
  
  .input-success {
    border-color: #2ecc71 !important;
  }/* End custom CSS */