/* =====================================================
   FI Courses – Variables
===================================================== */

:root {
  --fic-text: rgba(255, 255, 255, 0.92);
  --fic-muted: rgba(255, 255, 255, 0.68);
  --fic-soft: rgba(255, 255, 255, 0.52);
  --fic-line: rgba(255, 255, 255, 0.10);
  --fic-line-strong: rgba(255, 255, 255, 0.16);
  --fic-accent: #b31230;
  --fic-accent-hover: #c51636;
  --fic-bg-soft: rgba(255, 255, 255, 0.03);
  --fic-radius: 18px;
  --fic-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
}

/* =====================================================
   SINGLE COURSE
===================================================== */

.ficourse-single {
  max-width: 980px;
  margin: 100px auto 120px;
  padding: 0 28px;
  color: var(--fic-text);
}

.ficourse-header {
  margin-bottom: 64px;
}

.ficourse-header h1 {
  margin: 0 0 18px;
  font-size: clamp(2.5rem, 5vw, 4.4rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
  font-weight: 700;
  color: #fff;
  text-wrap: balance;
}

.ficourse-header > p {
  margin: 0 0 18px;
  font-size: clamp(1.12rem, 1.6vw, 1.4rem);
  line-height: 1.6;
  color: var(--fic-muted);
  max-width: 760px;
}

.ficourse-header > p:last-child {
  margin-top: 10px;
  font-size: 0.98rem;
  color: var(--fic-soft);
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.ficourse-header strong {
  color: #fff;
  font-weight: 600;
}

.ficourse-header__subtitle {
  margin: 0 0 18px;
  font-size: clamp(1.12rem, 1.6vw, 1.4rem);
  line-height: 1.6;
  color: var(--fic-muted);
  max-width: 760px;
}

.ficourse-header__subtitle.fi-course-hook {
  max-width: 760px;
  color: var(--fic-muted);
}

.ficourse-header__subtitle.fi-course-hook p {
  font-size: clamp(1.12rem, 1.6vw, 1.4rem);
  line-height: 1.6;
}

.ficourse-header img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  margin-top: 34px;
  box-shadow: var(--fic-shadow);
}

.ficourse-header__image {
  margin-top: 34px;
}

/* =====================================================
   CONTENT SECTIONS
===================================================== */

.ficourse-single section,
.ficourse-section {
  margin: 0 0 42px;
  padding: 0;
}

.ficourse-single section h2,
.ficourse-enroll-box__content h2 {
  margin: 0 0 18px;
  font-size: clamp(1.8rem, 2.6vw, 2.5rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 500;
  color: #fff;
}

.ficourse-enroll-box__content h2 {
  margin: 0 0 10px;
}

.ficourse-single section p,
.ficourse-content p {
  margin: 0 0 18px;
  font-size: 1.12rem;
  line-height: 1.8;
  color: var(--fic-text);
  max-width: 760px;
}

.ficourse-single section p br + br {
  content: "";
  display: block;
  margin-top: 10px;
}

.ficourse-content {
  margin-bottom: 34px;
}

.ficourse-content > *:last-child {
  margin-bottom: 0;
}

.ficourse-text-block,
.fi-course-curriculum-wrap {
  max-width: 760px;
}

/* =====================================================
   OFFER / CTA
===================================================== */

.ficourse-single section:last-of-type + section,
.ficourse-single .fi-course-offer,
.ficourse-single .ficourse-enroll-box {
  margin-top: 56px;
}

.fi-course-offer,
.ficourse-enroll-box {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  padding: 28px 32px;
  border: 1px solid var(--fic-line);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.035) 0%,
    rgba(255, 255, 255, 0.015) 100%
  );
  border-radius: 22px;
  box-shadow: var(--fic-shadow);
}

.fi-course-offer {
  margin-top: 24px;
}

.fi-course-offer__price,
.fi-course-price {
  font-size: 1.45rem;
  font-weight: 600;
  color: #fff;
}

.fi-course-price del {
  opacity: 0.55;
}

.fi-course-offer__button,
.fi-course-buy-button,
.ficourse-single a.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 14px 24px;
  border-radius: 12px;
  background: var(--fic-accent);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: transform 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
  box-shadow: 0 14px 40px rgba(179, 18, 48, 0.22);
}

.fi-course-offer__button:hover,
.fi-course-buy-button:hover,
.ficourse-single a.button:hover {
  background: var(--fic-accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 18px 46px rgba(179, 18, 48, 0.28);
}

.ficourse-enroll-box__action {
  display: flex;
  align-items: center;
}

/* =====================================================
   COURSE META / TEXT BLOCKS
===================================================== */

.fi-course-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 10px 0 0;
  font-size: 0.98rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fic-soft);
}

.fi-course-learn,
.fi-course-audience {
  max-width: 760px;
}

.fi-course-hook p,
.fi-course-card__subtitle p,
.fi-course-learn p,
.fi-course-audience p,
.fi-course-problem p,
.fi-course-outcomes p,
.fi-course-teacher p {
  margin: 0 0 16px;
}

.fi-course-card__subtitle p:last-child,
.fi-course-hook p:last-child,
.fi-course-learn p:last-child,
.fi-course-audience p:last-child,
.fi-course-problem p:last-child,
.fi-course-outcomes p:last-child,
.fi-course-teacher p:last-child {
  margin-bottom: 0;
}

/* =====================================================
   CURRICULUM
===================================================== */

.fi-course-curriculum {
  margin: 0;
  padding: 0;
  list-style: none;
  max-width: 760px;
  border-top: 1px solid var(--fic-line);
}

.fi-course-curriculum li {
  position: relative;
  margin: 0;
  padding: 18px 0 18px 30px;
  border-bottom: 1px solid var(--fic-line);
  font-size: 1.06rem;
  line-height: 1.65;
  color: var(--fic-text);
}

.fi-course-curriculum li::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 29px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--fic-accent);
  box-shadow: 0 0 0 6px rgba(179, 18, 48, 0.10);
}

/* =====================================================
   COURSES GRID
===================================================== */

.fi-courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 28px;
}

.fi-course-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  height: 100%;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 22px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03) 0%,
    rgba(255, 255, 255, 0.015) 100%
  );
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.18);
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.fi-course-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.24);
  border-color: rgba(255, 255, 255, 0.14);
}

.fi-course-card__image {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: 22px 22px 0 0;
  background: #0f0f0f;
}

.fi-course-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform 0.45s ease;
}

.fi-course-card:hover .fi-course-card__image img {
  transform: scale(1.04);
}

.fi-course-card__badge {
  position: absolute;
  top: 14px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: #fff;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  z-index: 2;
}

.fi-course-card__badge--inline {
  position: static;
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: none;
  color: rgba(255, 255, 255, 0.92);
}

.fi-course-card__content {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px 22px 24px;
}

.fi-course-card__topline {
  margin-bottom: -4px;
}

.fi-course-card__title {
  margin: 0;
  font-size: 1.55rem;
  line-height: 1.08;
  letter-spacing: -0.03em;
  font-weight: 700;
}

.fi-course-card__title a {
  color: #fff;
  text-decoration: none;
}

.fi-course-card__title a:hover {
  color: #fff;
  opacity: 0.92;
}

.fi-course-card__subtitle {
  color: rgba(255, 255, 255, 0.72);
  font-size: 1rem;
  line-height: 1.65;
}

.fi-course-card__meta {
  margin: 0;
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.fi-course-card__excerpt {
  margin: 0;
  color: var(--fic-text);
  font-size: 1rem;
  line-height: 1.7;
  opacity: 0.88;
}

.fi-course-card__link {
  margin: 6px 0 0;
}

.fi-course-card__link a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  background: #8f1029;
  color: #fff;
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: 0 14px 30px rgba(143, 16, 41, 0.22);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.fi-course-card__link a:hover {
  background: #a81331;
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(143, 16, 41, 0.28);
  color: #fff;
}

/* =====================================================
   ARCHIVE COURSES
===================================================== */

.ficourses-archive {
  max-width: 1180px;
  margin: 90px auto 110px;
  padding: 0 28px;
  color: var(--fic-text);
}

.ficourses-archive__header {
  margin-bottom: 42px;
}

.ficourses-archive__header h1 {
  margin: 0;
  font-size: clamp(2.3rem, 4vw, 4rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: #fff;
}

.ficourses-archive__empty {
  font-size: 1.08rem;
  color: var(--fic-muted);
}

/* =====================================================
   BUSINESS TOGGLE
===================================================== */

.fi-business-toggle-row {
  margin-top: 8px;
  margin-bottom: 8px;
}

.fi-business-toggle-row label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
}

.fi-business-field {
  transition: all 0.2s ease;
}

/* =====================================================
   RESPONSIVE
===================================================== */

@media (max-width: 1100px) {
  .ficourse-single {
    max-width: 900px;
    padding: 0 24px;
  }

  .fi-courses-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .ficourse-single {
    margin: 70px auto 90px;
    padding: 0 20px;
  }

  .ficourse-header {
    margin-bottom: 46px;
  }

  .ficourse-single section,
  .ficourse-section {
    margin-bottom: 34px;
  }

  .ficourse-single section p,
  .ficourse-content p {
    font-size: 1.04rem;
    line-height: 1.75;
  }

  .fi-courses-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .fi-course-offer,
  .ficourse-enroll-box {
    padding: 22px;
    border-radius: 18px;
  }

  .fi-course-offer__button,
  .fi-course-buy-button,
  .ficourse-single a.button {
    width: 100%;
  }

  .ficourses-archive {
    margin: 70px auto 90px;
    padding: 0 20px;
  }

  .ficourses-archive__header {
    margin-bottom: 30px;
  }
}

@media (max-width: 680px) {
  .fi-courses-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .fi-course-card__content {
    padding: 20px;
  }

  .fi-course-card__title {
    font-size: 1.35rem;
  }
}

/* =====================================================
   WooCommerce Account / Login / Lost Password
===================================================== */

/* Wrapper general */
.woocommerce-account .woocommerce,
.woocommerce-lost-password .woocommerce {
  max-width: 1180px;
  margin: 0 auto;
  padding: 10px 0 80px;
  color: rgba(255,255,255,.92);
}

/* =========================
   ACCOUNT LOGGED-IN
========================= */

.woocommerce-account .woocommerce.ct-woo-account {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}

.woocommerce-account .woocommerce.ct-woo-account .ct-acount-nav {
  position: sticky;
  top: 30px;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation {
  float: none;
  width: 100%;
  margin: 0;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation ul {
  margin: 0;
  padding: 12px;
  list-style: none;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.015) 100%);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation li {
  margin: 0;
  padding: 0;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation li + li {
  margin-top: 6px;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation a {
  display: flex;
  align-items: center;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 14px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  font-weight: 500;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation a:hover {
  background: rgba(255,255,255,.04);
  color: #fff;
  transform: translateX(2px);
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation li.is-active a {
  background: rgba(143,16,41,.18);
  color: #fff;
  border: 1px solid rgba(179,18,48,.28);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content {
  float: none;
  width: 100%;
  min-width: 0;
  padding: 28px 30px 34px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.015) 100%);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content p,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content li,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content address {
  color: rgba(255,255,255,.84);
  line-height: 1.7;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content a {
  color: #fff;
  text-decoration: none;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content a:hover {
  opacity: .88;
}

/* tablas dentro de account */
.woocommerce-account .woocommerce.ct-woo-account table.shop_table,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.015);
}

.woocommerce-account .woocommerce.ct-woo-account table.shop_table th,
.woocommerce-account .woocommerce.ct-woo-account table.shop_table td,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-table th,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-table td {
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  text-align: left;
  color: rgba(255,255,255,.88);
}

.woocommerce-account .woocommerce.ct-woo-account table.shop_table th,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-table th {
  color: rgba(255,255,255,.68);
  font-size: .9rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 600;
  background: rgba(255,255,255,.02);
}

.woocommerce-account .woocommerce.ct-woo-account table.shop_table tr:last-child td,
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-table tr:last-child td {
  border-bottom: 0;
}

/* cajas de addresses */
.woocommerce-account .woocommerce.ct-woo-account .woocommerce-Addresses {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-Address {
  padding: 24px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.02);
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-Address-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-Address-title h3 {
  margin: 0;
}

.woocommerce-account .woocommerce.ct-woo-account .woocommerce-Address-title .edit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  color: #fff;
  text-decoration: none;
}

/* forms dentro de account */
.woocommerce-account .woocommerce.ct-woo-account form .form-row,
.woocommerce-lost-password .woocommerce form .form-row,
.woocommerce-account .woocommerce form .form-row {
  margin: 0 0 18px;
  padding: 0;
}

.woocommerce-account .woocommerce.ct-woo-account form .form-row label,
.woocommerce-lost-password .woocommerce form .form-row label,
.woocommerce-account .woocommerce form .form-row label {
  display: block;
  margin: 0 0 8px;
  color: rgba(255,255,255,.92);
  font-weight: 500;
}

.woocommerce-account .woocommerce.ct-woo-account form .input-text,
.woocommerce-account .woocommerce.ct-woo-account form input[type="text"],
.woocommerce-account .woocommerce.ct-woo-account form input[type="email"],
.woocommerce-account .woocommerce.ct-woo-account form input[type="password"],
.woocommerce-account .woocommerce.ct-woo-account form input[type="tel"],
.woocommerce-account .woocommerce.ct-woo-account form textarea,
.woocommerce-account .woocommerce.ct-woo-account form select,
.woocommerce-account .woocommerce form .input-text,
.woocommerce-account .woocommerce form input[type="text"],
.woocommerce-account .woocommerce form input[type="email"],
.woocommerce-account .woocommerce form input[type="password"],
.woocommerce-account .woocommerce form input[type="tel"],
.woocommerce-account .woocommerce form textarea,
.woocommerce-account .woocommerce form select,
.woocommerce-lost-password .woocommerce form .input-text,
.woocommerce-lost-password .woocommerce form input[type="text"],
.woocommerce-lost-password .woocommerce form input[type="email"],
.woocommerce-lost-password .woocommerce form input[type="password"] {
  min-height: 54px;
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.02);
  color: #fff;
  padding: 0 16px;
  box-shadow: none;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.woocommerce-account .woocommerce.ct-woo-account form textarea,
.woocommerce-account .woocommerce form textarea,
.woocommerce-lost-password .woocommerce form textarea {
  min-height: 130px;
  padding: 14px 16px;
}

.woocommerce-account .woocommerce.ct-woo-account form .input-text:focus,
.woocommerce-account .woocommerce.ct-woo-account form textarea:focus,
.woocommerce-account .woocommerce.ct-woo-account form select:focus,
.woocommerce-account .woocommerce form .input-text:focus,
.woocommerce-account .woocommerce form textarea:focus,
.woocommerce-account .woocommerce form select:focus,
.woocommerce-lost-password .woocommerce form .input-text:focus,
.woocommerce-lost-password .woocommerce form textarea:focus,
.woocommerce-lost-password .woocommerce form select:focus {
  border-color: rgba(179,18,48,.85);
  box-shadow: 0 0 0 4px rgba(179,18,48,.12);
  background: rgba(255,255,255,.03);
  outline: none;
}

/* botones */
.woocommerce-account .woocommerce .button,
.woocommerce-account .woocommerce button.button,
.woocommerce-account .woocommerce .woocommerce-button,
.woocommerce-account .woocommerce input.button,
.woocommerce-lost-password .woocommerce .button,
.woocommerce-lost-password .woocommerce button.button,
.woocommerce-lost-password .woocommerce input.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border: 0;
  border-radius: 12px;
  background: #8f1029;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: .02em;
  box-shadow: 0 14px 30px rgba(143,16,41,.22);
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.woocommerce-account .woocommerce .button:hover,
.woocommerce-account .woocommerce button.button:hover,
.woocommerce-account .woocommerce .woocommerce-button:hover,
.woocommerce-account .woocommerce input.button:hover,
.woocommerce-lost-password .woocommerce .button:hover,
.woocommerce-lost-password .woocommerce button.button:hover,
.woocommerce-lost-password .woocommerce input.button:hover {
  background: #a81331;
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(143,16,41,.28);
  color: #fff;
}

/* notices */
.woocommerce-account .woocommerce .woocommerce-message,
.woocommerce-account .woocommerce .woocommerce-info,
.woocommerce-account .woocommerce .woocommerce-error,
.woocommerce-lost-password .woocommerce .woocommerce-message,
.woocommerce-lost-password .woocommerce .woocommerce-info,
.woocommerce-lost-password .woocommerce .woocommerce-error {
  margin: 0 0 22px;
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.92);
}

/* =========================
   LOGIN / REGISTER NO LOGADO
========================= */

.woocommerce-account .woocommerce:not(.ct-woo-account) .u-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(320px, 1fr));
  gap: 28px;
  align-items: start;
}

.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column1,
.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column2 {
  width: 100%;
  float: none;
  margin: 0;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.015) 100%);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column1 h2,
.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column2 h2 {
  margin: 0 0 18px;
  font-size: clamp(1.7rem, 2.5vw, 2.2rem);
  line-height: 1.08;
  letter-spacing: -.02em;
  color: #fff;
}

.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column1 p,
.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column2 p,
.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column1 label,
.woocommerce-account .woocommerce:not(.ct-woo-account) .u-column2 label {
  color: rgba(255,255,255,.88);
  line-height: 1.7;
}

/* lost password */
.woocommerce-lost-password .woocommerce {
  max-width: 760px;
}

.woocommerce-lost-password .woocommerce form.lost_reset_password,
.woocommerce-lost-password .woocommerce form.woocommerce-ResetPassword {
  padding: 30px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.015) 100%);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 980px) {
  .woocommerce-account .woocommerce.ct-woo-account {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .woocommerce-account .woocommerce.ct-woo-account .ct-acount-nav {
    position: static;
  }

  .woocommerce-account .woocommerce.ct-woo-account .woocommerce-Addresses,
  .woocommerce-account .woocommerce:not(.ct-woo-account) .u-columns {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .woocommerce-account .woocommerce,
  .woocommerce-lost-password .woocommerce {
    padding: 0 0 56px;
  }

  .woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-content,
  .woocommerce-account .woocommerce:not(.ct-woo-account) .u-column1,
  .woocommerce-account .woocommerce:not(.ct-woo-account) .u-column2,
  .woocommerce-lost-password .woocommerce form.lost_reset_password,
  .woocommerce-lost-password .woocommerce form.woocommerce-ResetPassword {
    padding: 22px 20px 26px;
    border-radius: 18px;
  }

  .woocommerce-account .woocommerce.ct-woo-account .woocommerce-MyAccount-navigation ul {
    padding: 10px;
    border-radius: 18px;
  }
}


:is(.woocommerce-info, .woocommerce-error, .woocommerce-message, .woocommerce-thankyou-order-received)::before { top:  -20px !important; left:  -20px !important; }

/* Login prompt above checkout */
body.fi-premium-checkout .woocommerce-form-login-toggle {
  margin: 0 0 26px;
}

body.fi-premium-checkout .woocommerce-form-login-toggle .woocommerce-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.78);
  box-shadow: none;
}

body.fi-premium-checkout .woocommerce-form-login-toggle .woocommerce-info::before {
  color: rgba(255,255,255,.65);
}

body.fi-premium-checkout .woocommerce-form-login-toggle .woocommerce-info a {
  color: #fff;
  font-weight: 600;
  text-decoration: none;
}

body.fi-premium-checkout .woocommerce-form-login-toggle .woocommerce-info a:hover {
  opacity: .86;
}

/* Login form shown when clicking "Click here to login" */
body.fi-premium-checkout form.woocommerce-form-login {
  margin: 0 0 28px;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.02);
}

/* Coupon toggle if it appears */
body.fi-premium-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.78);
}

body.fi-premium-checkout .woocommerce-form-coupon-toggle .woocommerce-info a {
  color: #fff;
  font-weight: 600;
  text-decoration: none;
}

body.fi-premium-checkout .woocommerce-form-login-toggle {
  display: none;
}