.elementor-865 .elementor-element.elementor-element-655210d{--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;}/* Start custom CSS *//* =========================
   OZTVAPES ARTICLE MODULE
   Desktop + Mobile Ready
   Keep existing HTML class names
========================= */

.oz-grape-ice-page{
  --bg:#f4f7fc;
  --card:#ffffff;
  --ink:#142033;
  --text:#56627a;
  --muted:#72809a;
  --line:#dce5f2;
  --line-strong:#c9d6ea;
  --blue:#2563eb;
  --blue-dark:#1849b9;
  --blue-soft:#edf4ff;
  --hero-a:#eef5ff;
  --hero-b:#ffffff;
  --cta-a:#1f5eff;
  --cta-b:#3b82f6;
  --shadow:0 14px 34px rgba(20,32,51,.07);
  --shadow-soft:0 8px 22px rgba(20,32,51,.05);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:18px;
  --radius-sm:14px;

  max-width: 1120px;
  margin: 0 auto;
  padding: 0 20px;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.75;
}

.oz-grape-ice-page *,
.oz-grape-ice-page *::before,
.oz-grape-ice-page *::after{
  box-sizing: border-box;
}

.oz-grape-ice-page a{
  color: var(--blue);
  text-decoration: none;
  font-weight: 700;
  transition: all .2s ease;
}

.oz-grape-ice-page a:hover{
  color: var(--blue-dark);
  text-decoration: underline;
}

.oz-grape-ice-page p{
  margin: 0 0 14px;
  color: var(--text);
}

.oz-grape-ice-page p:last-child{
  margin-bottom: 0;
}

/* =========================
   HERO
========================= */
.oz-grape-ice-hero{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(37,99,235,.12), transparent 34%),
    linear-gradient(135deg, var(--hero-a) 0%, #f8fbff 52%, var(--hero-b) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: 40px 34px 34px !important;
  margin: 0 0 24px;
}

.oz-grape-ice-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #dfeafe;
  color: #2455c3;
  border: 1px solid #cddcff;
  border-radius: 999px;
  padding: 8px 14px !important;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .2px;
  margin-bottom: 16px;
}

.oz-grape-ice-hero h1{
  margin: 0 0 16px;
  color: #10192b;
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.08;
  letter-spacing: -.03em;
}

.oz-grape-ice-hero p{
  max-width: 920px;
  font-size: 17px;
  color: #526178;
}

/* =========================
   GRID
========================= */
.oz-grape-ice-grid{
  display: grid;
  grid-template-columns: repeat(12, minmax(0,1fr));
  gap: 20px;
  margin: 0 0 24px;
}

.oz-span-12{grid-column: span 12;}
.oz-span-8{grid-column: span 8;}
.oz-span-6{grid-column: span 6;}
.oz-span-4{grid-column: span 4;}

/* =========================
   COMMON CARD
========================= */
.oz-grape-ice-card{
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: 28px 28px 24px !important;
  margin-bottom: 24px;
}

.oz-grape-ice-card h2{
  margin: 0 0 14px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.15;
  letter-spacing: -.025em;
  color: #10182b;
}

.oz-grape-ice-card h3{
  margin: 0 0 10px;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.28;
  color: #14213a;
}

.oz-lead{
  font-size: 17px;
  color: var(--text);
}

/* =========================
   LIST
========================= */
.oz-points{
  margin: 14px 0 0;
  padding-left: 22px !important;
}

.oz-points li{
  margin: 8px 0;
  color: var(--text);
}

.oz-points strong{
  color: #162237;
}

/* =========================
   QUICK PICKS
========================= */
.oz-quick-picks{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
  margin-top: 18px;
}

.oz-pick{
  background: linear-gradient(180deg,#ffffff 0%,#f9fbff 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: 0 6px 18px rgba(20,32,51,.04);
  padding: 20px 20px 18px !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.oz-pick:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(20,32,51,.08);
  border-color: #c7d6ed;
}

.oz-pick h3{
  font-size: 21px;
  line-height: 1.3;
}

.oz-pick p{
  font-size: 15px;
  color: var(--muted);
}

.oz-tag{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--blue-soft);
  color: #2157c5;
  border: 1px solid #d4e3ff;
  border-radius: 999px;
  padding: 7px 12px !important;
  font-size: 12px;
  font-weight: 700;
  margin: 0 8px 10px 0;
  line-height: 1;
}

/* =========================
   TABLE
========================= */
.oz-compare-table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  margin-top: 8px;
}

.oz-compare-table th,
.oz-compare-table td{
  text-align: left;
  vertical-align: top;
  padding: 16px 14px !important;
  border-bottom: 1px solid var(--line);
}

.oz-compare-table th:first-child,
.oz-compare-table td:first-child{
  padding-left: 24px !important;
}

.oz-compare-table th{
  background: #f3f7ff;
  color: #1a3767;
  font-size: 14px;
  font-weight: 700;
}

.oz-compare-table td{
  background: #fff;
  color: #44516b;
  font-size: 15px;
}

.oz-compare-table tr:last-child td{
  border-bottom: none;
}

.oz-note{
  margin-top: 14px;
  background: #f7faff;
  border: 1px dashed #c5d6f0;
  border-radius: var(--radius-sm);
  padding: 14px 16px !important;
  color: #60718d;
  font-size: 14px;
}

/* =========================
   SMALL FLAVOUR BOX
========================= */
.oz-flavour-box{
  height: 100%;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 20px 20px 18px !important;
  box-shadow: 0 5px 15px rgba(20,32,51,.03);
}

.oz-flavour-box h3{
  font-size: 22px;
}

.oz-flavour-box p{
  color: var(--muted);
}

/* =========================
   FAQ
========================= */
.oz-faq-item{
  padding: 18px 0 !important;
  border-bottom: 1px solid var(--line);
}

.oz-faq-item:last-child{
  border-bottom: none;
}

.oz-faq-item h3{
  margin-bottom: 8px;
  font-size: 22px;
  line-height: 1.35;
}

/* =========================
   RELATED LINKS
========================= */
.oz-related-links{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 16px;
  padding-left: 10px !important;
}

.oz-related-links a{
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  background: #f4f8ff;
  border: 1px solid #d7e3f8;
  border-radius: 999px;
  padding: 10px 16px 10px 18px !important;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
}

.oz-related-links a:hover{
  background: #edf4ff;
  text-decoration: none;
}

/* =========================
   CTA
========================= */
.oz-bottom-cta{
  background: linear-gradient(135deg, var(--cta-a) 0%, var(--cta-b) 100%);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: 30px 28px 26px !important;
  margin: 0 0 10px;
  color: #fff;
}

.oz-bottom-cta h2{
  margin: 0 0 12px;
  color: #fff;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.14;
  letter-spacing: -.02em;
}

.oz-bottom-cta p{
  color: rgba(255,255,255,.92);
  margin-bottom: 16px;
}

.oz-bottom-cta a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  background: #fff;
  color: #1d57d1;
  border-radius: 999px;
  padding: 12px 18px !important;
  font-weight: 700;
  text-decoration: none;
}

.oz-bottom-cta a:hover{
  color: #1548b3;
  text-decoration: none;
}

/* =========================
   SECTION SPACING FIX
========================= */
.oz-grape-ice-page > section:last-child{
  margin-bottom: 0;
}

/* =========================
   TABLET
========================= */
@media (max-width: 991px){
  .oz-grape-ice-page{
    max-width: 900px;
    padding: 0 16px;
  }

  .oz-span-8,
  .oz-span-6,
  .oz-span-4{
    grid-column: span 12;
  }

  .oz-quick-picks{
    grid-template-columns: 1fr;
  }

  .oz-grape-ice-hero{
    padding: 30px 24px 24px !important;
  }

  .oz-grape-ice-card{
    padding: 24px 22px 20px !important;
  }

  .oz-bottom-cta{
    padding: 24px 22px 22px !important;
  }
}

/* =========================
   MOBILE
========================= */
@media (max-width: 640px){
  .oz-grape-ice-page{
    padding: 0 12px;
    font-size: 15px;
    line-height: 1.7;
  }

  .oz-grape-ice-grid{
    gap: 16px;
    margin-bottom: 18px;
  }

  .oz-grape-ice-hero{
    border-radius: 20px;
    padding: 24px 16px 18px !important;
    margin-bottom: 18px;
  }

  .oz-grape-ice-eyebrow{
    font-size: 11px;
    padding: 7px 12px !important;
    margin-bottom: 12px;
  }

  .oz-grape-ice-hero h1{
    font-size: 29px;
    line-height: 1.15;
    margin-bottom: 12px;
  }

  .oz-grape-ice-hero p{
    font-size: 15px;
  }

  .oz-grape-ice-card{
    border-radius: 18px;
    padding: 18px 16px 16px !important;
    margin-bottom: 18px;
  }

  .oz-grape-ice-card h2{
    font-size: 26px;
    line-height: 1.2;
    margin-bottom: 12px;
  }

  .oz-grape-ice-card h3,
  .oz-faq-item h3,
  .oz-flavour-box h3{
    font-size: 19px;
    line-height: 1.3;
  }

  .oz-lead{
    font-size: 15px;
  }

  .oz-points{
    padding-left: 18px !important;
  }

  .oz-pick{
    padding: 16px 14px 14px !important;
    border-radius: 16px;
  }

  .oz-pick h3{
    font-size: 18px;
  }

  .oz-tag{
    font-size: 11px;
    padding: 6px 10px !important;
  }

  .oz-compare-table{
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 14px;
  }

  .oz-compare-table th,
  .oz-compare-table td{
    font-size: 13px;
    padding: 12px 10px !important;
    min-width: 150px;
  }

  .oz-compare-table th:first-child,
  .oz-compare-table td:first-child{
    padding-left: 14px !important;
  }

  .oz-note{
    padding: 12px 12px !important;
    font-size: 13px;
  }

  .oz-flavour-box{
    border-radius: 16px;
    padding: 16px 14px 14px !important;
  }

  .oz-faq-item{
    padding: 14px 0 !important;
  }

  .oz-related-links{
    gap: 10px;
    padding-left: 4px !important;
  }

  .oz-related-links a{
    font-size: 13px;
    min-height: 38px;
    padding: 9px 12px 9px 14px !important;
  }

  .oz-bottom-cta{
    border-radius: 20px;
    padding: 20px 16px 18px !important;
  }

  .oz-bottom-cta h2{
    font-size: 25px;
    line-height: 1.18;
  }

  .oz-bottom-cta p{
    font-size: 14px;
  }

  .oz-bottom-cta a{
    width: 100%;
    justify-content: center;
    padding: 12px 16px !important;
    min-height: 44px;
  }
}/* End custom CSS */