/*
Theme Name: Flatsome Child Custom
Theme URI: https://example.com/
Description: Child theme tu�?chỉnh giao diện cho Flatsome.
Author: Local Dev
Template: flatsome
Version: 1.0.0
Text Domain: flatsome-child-custom
*/

/* ===== Brand tokens ===== */
:root {
  --brand-primary: #e70584;
  --brand-primary-dark: #cc0474;
  --brand-accent: #f26cb5;
  --text-main: #0f172a;
  --text-soft: #475569;
  --line-soft: #e2e8f0;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --radius-md: 12px;
  --radius-lg: 16px;
  --shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.08);
}

/* ===== Base typography ===== */
body {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text-main);
  font-size: 16px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Noto Serif", Georgia, "Times New Roman", serif;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.25;
}

.nav > li > a,
.button,
button,
input,
textarea,
select {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

.material-symbols-outlined {
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
  font-style: normal;
  line-height: 1;
  display: inline-block;
  white-space: nowrap;
}

/* Force global font mapping to avoid Flatsome override */
html body,
body,
body p,
body li,
body span,
body a:not(.star-1):not(.star-2):not(.star-3):not(.star-4):not(.star-5),
body button,
body input,
body textarea,
body select,
.nav > li > a,
.button {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
}

/*
 * .star-rating (WooCommerce): mặc định dùng font .woff với content "s"/"S" — dễ thành ô/khối khi fallback.
 * Phần tử cha/con chỉ cần layout; nội dung sao chuyển sang Unicode ★ (block bên dưới).
 */
.star-rating,
.star-rating span {
  letter-spacing: 0 !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
}

/* Sao ★ Unicode — không phụ thuộc font WooCommerce, giữ cơ chế cắt width của WC */
.star-rating::before {
  content: "\2605\2605\2605\2605\2605" !important;
  font-family: "Segoe UI Symbol", "Noto Sans Symbols", "Apple Color Emoji", "Segoe UI Emoji", sans-serif !important;
  color: #d1d5db !important;
  letter-spacing: 0.08em !important;
  white-space: nowrap !important;
}

.star-rating span::before {
  content: "\2605\2605\2605\2605\2605" !important;
  font-family: "Segoe UI Symbol", "Noto Sans Symbols", "Apple Color Emoji", "Segoe UI Emoji", sans-serif !important;
  color: #e70584 !important;
  letter-spacing: 0.08em !important;
  white-space: nowrap !important;
}

/* Không ép Noto Serif lên tiêu đề sản phẩm Woo (h1.product_title) — sẽ tách style riêng bên dưới */
body h1:not(.product_title):not(.product-title),
body h2,
body h3,
body h4,
body h5,
body h6,
.banner h1,
.banner h2,
.fsc-home-head__title,
.fsc-hero-slide__title {
  font-family: "Noto Serif", Georgia, "Times New Roman", serif !important;
}

/* Tailwind-like utility classes for your HTML blocks */
.font-headline {
  font-family: "Noto Serif", Georgia, "Times New Roman", serif !important;
}

.font-body,
.font-label {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
}

/* ===== Atelier shared utilities (moved from HTML block) ===== */
:root {
  --on-background: #1a1c1a;
  --surface-container: #efeeeb;
  --primary: #e70584;
  --primary-container: #cc0474;
}

.material-symbols-outlined {
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.editorial-gradient {
  background: linear-gradient(135deg, #e70584 0%, #cc0474 100%);
}

.glass-nav {
  background: rgba(250, 249, 246, 0.8);
  backdrop-filter: blur(20px);
}

.atelier-section * {
  box-sizing: border-box;
}

.no-scrollbar::-webkit-scrollbar {
  display: none;
}

.no-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

/* Lightweight color/font utility classes used by blocks */
.text-on-background {
  color: var(--on-background);
}

.bg-surface-container {
  background-color: var(--surface-container);
}

.text-primary {
  color: var(--primary);
}

.bg-primary-container {
  background-color: var(--primary-container);
}

p,
li,
span {
  color: inherit;
}

a {
  color: var(--brand-primary);
  transition: all 0.2s ease;
}

a:hover {
  color: var(--brand-primary-dark);
}

/* ===== Header & navigation ===== */
#header {
  box-shadow: 0 2px 12px rgba(15,23,42,0.07);
}

#header .container,
#header .header-inner,
#header .header-inner.container,
.header-wrapper .header-main .header-inner.container {
  max-width: min(1180px, calc(100% - 32px)) !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.header-main {
  background: #fff !important;
  border-bottom: 1px solid rgba(231,5,132,0.08);
}

/* Nav links — spacing + clean hover */
.nav > li > a {
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.04em;
  color: #2a1520;
  padding: 6px 14px !important;
  transition: color 0.2s ease;
}

.nav > li.active > a,
.nav > li > a:hover {
  color: var(--brand-primary) !important;
}

/* Simple underline on active */
.nav > li.active > a {
  border-bottom: 2px solid var(--brand-primary);
  padding-bottom: 4px !important;
}

/* Dropdown — clean card look */
.nav-dropdown,
ul.nav-dropdown,
.nav li ul.nav-dropdown {
  background: #fff !important;
  border: 1px solid rgba(231,5,132,0.1) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 36px rgba(15,23,42,0.1), 0 2px 8px rgba(231,5,132,0.06) !important;
  padding: 12px 0 !important;
  margin-top: 4px !important;
}

/* Dropdown column headings */
.nav-dropdown .nav-column h4,
.mega-menu .nav-dropdown h4 {
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--brand-primary) !important;
  padding: 4px 20px 10px !important;
  border-bottom: 1px solid rgba(231,5,132,0.08) !important;
  margin-bottom: 4px !important;
}

/* Dropdown items */
.nav-dropdown li a,
.nav li ul.nav-dropdown li a {
  font-size: 14.5px !important;
  font-weight: 500 !important;
  color: #2a1520 !important;
  padding: 8px 20px !important;
  transition: color 0.15s ease, background 0.15s ease;
}

/* Phân cấp rõ ràng trong dropdown (cha/con/cháu) */
.nav-dropdown > li > a,
.nav-dropdown .nav-column > ul > li > a {
  font-size: 15px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  color: #23121a !important;
  display: block !important;
  background: rgba(231, 5, 132, 0.05) !important;
  border-left: 2px solid rgba(231, 5, 132, 0.2) !important;
  padding: 8px 14px !important;
  margin: 0 10px 4px !important;
  white-space: nowrap !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

.nav-dropdown > li.menu-item-has-children > a,
.nav-dropdown .nav-column > ul > li.menu-item-has-children > a {
  border-left-color: rgba(231, 5, 132, 0.45) !important;
}

.nav-dropdown li li > a {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #5d3d4c !important;
  padding: 7px 20px 7px 30px !important;
}

.nav-dropdown li li li > a {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #7b5a68 !important;
  padding: 6px 20px 6px 42px !important;
}

.nav-dropdown li a:hover,
.nav li ul.nav-dropdown li a:hover {
  color: var(--brand-primary) !important;
  background: rgba(231,5,132,0.04) !important;
}

.nav-dropdown .nav-column + .nav-column {
  border-left: 1px solid rgba(231,5,132,0.07) !important;
}

/* Mobile menu: làm rõ item cùng cấp */
@media (max-width: 849px) {
  .off-canvas .nav-vertical > li > a,
  .mfp-content .nav-vertical > li > a,
  .nav-sidebar .nav-vertical > li > a {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #23121a !important;
    letter-spacing: 0.01em !important;
  }

  .off-canvas .nav-vertical > li > ul.children > li > a,
  .off-canvas .nav-vertical > li > ul.sub-menu > li > a,
  .mfp-content .nav-vertical > li > ul.children > li > a,
  .mfp-content .nav-vertical > li > ul.sub-menu > li > a,
  .nav-sidebar .nav-vertical > li > ul.children > li > a,
  .nav-sidebar .nav-vertical > li > ul.sub-menu > li > a {
    font-size: 17px !important;
    font-weight: 500 !important;
    color: #5d3d4c !important;
    padding-left: 14px !important;
  }
}

/* ── Fix: Mega menu luôn hiển thị ngang bất kể trang nào ─── */
/* Flatsome sticky header làm mega menu bị đổ dọc — override lại */
#header .nav-dropdown.nav-mega-menu,
.is-sticky .nav-dropdown.nav-mega-menu,
.header-scrolled .nav-dropdown.nav-mega-menu,
.nav-dropdown[class*="columns-"],
ul.nav-dropdown.columns-4,
ul.nav-dropdown.columns-3,
ul.nav-dropdown.columns-2 {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
}

/* Mỗi cột chiếm không gian đều nhau */
#header .nav-dropdown .nav-column,
.is-sticky .nav-dropdown .nav-column,
.nav-dropdown .nav-column {
  flex: 1 1 0 !important;
  min-width: 140px !important;
}

/* Mục cấp 1 không có menu con vẫn thành 1 cột độc lập (vd: Virgin hair) */
#header .nav-dropdown.nav-mega-menu > li,
.is-sticky .nav-dropdown.nav-mega-menu > li,
.header-scrolled .nav-dropdown.nav-mega-menu > li {
  flex: 1 1 160px !important;
  min-width: 160px !important;
}



/* ===== Buttons ===== */
.button,
button,
input[type="submit"],
input[type="button"],
.woocommerce a.button,
.woocommerce button.button {
  border-radius: 999px;
  font-weight: 700;
  border: 0;
  box-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.button.primary,
.button.is-primary,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #respond input#submit.alt {
  background-color: var(--brand-primary);
}

.button.primary:hover,
.button.is-primary:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #respond input#submit.alt:hover {
  background-color: var(--brand-primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.28);
}

/* ===== Cards & boxes ===== */
.box,
.product-small.box,
.blog-post-inner,
.post-item .box {
  border-radius: var(--radius-lg);
  border: 1px solid var(--line-soft);
  overflow: hidden;
  box-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.box:hover,
.product-small.box:hover,
.post-item .box:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
}

/* ===== WooCommerce polish ===== */
.woocommerce ul.products li.product .box-image,
.woocommerce div.product div.images img {
  border-radius: var(--radius-md);
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price {
  color: var(--brand-primary-dark);
  font-weight: 700;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: var(--radius-md);
}

/* ===== Forms ===== */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="search"],
textarea,
select {
  border-radius: 10px;
  border: 1px solid #cbd5e1;
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--brand-accent);
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

/* ===== Footer ===== */
#footer {
  background: #0b1220;
  color: #dbeafe;
}

#footer a {
  color: #bfdbfe;
}

#footer a:hover {
  color: #ffffff;
}

.absolute-footer {
  background-color: #070d19;
  color: #cbd5e1;
}

/* ===== Utility spacing ===== */
.section {
  padding-top: clamp(36px, 6vw, 72px);
  padding-bottom: clamp(36px, 6vw, 72px);
}

/* ===== Mobile ===== */
@media (max-width: 849px) {
  .nav-size-large > li > a {
    font-size: 14px;
  }

  .section {
    padding-top: 32px;
    padding-bottom: 32px;
  }
}

/* ===== Product pages optimization (shop + single) ===== */
body.post-type-archive-product #main,
body.tax-product_cat #main,
body.tax-product_tag #main,
body.single-product #main {
  background: linear-gradient(180deg, #faf9f6 0%, #fff7fb 100%);
}

/* ===== Shop Page Top Bar Redesign (Mobile & Desktop) ===== */
.shop-page-title {
  background: transparent !important;
  border-bottom: 0 !important;
  padding: 15px 0 !important;
}

.shop-page-title .page-title-inner {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px;
}

/* ── Cột trái: Breadcrumbs ── */
.shop-page-title .flex-col.flex-grow,
.shop-page-title .flex-col.flex-grow .breadcrumbs {
  text-align: left !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}

.shop-page-title .breadcrumbs {
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  color: #2a1520;
}
.shop-page-title .breadcrumbs a {
  color: var(--brand-primary);
  display: inline-block;
}
.shop-page-title .breadcrumbs .divider {
  margin: 0 6px;
  color: #ccc;
  display: inline-block;
}

/* ── Cột phải: Khung Lọc & Sắp xếp ── */
.shop-page-title .flex-col:not(.flex-grow) {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin: 0 !important;
  width: auto !important;
}

/* Nút Filter */
.shop-page-title .category-filtering {
  margin: 0 !important;
}
.shop-page-title .filter-button {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  background: #fff;
  border: 1px solid rgba(231,5,132,0.2) !important;
  border-radius: 99px;
  padding: 8px 16px !important;
  font-size: 12.5px !important;
  font-weight: 700 !important;
  color: var(--brand-primary) !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  box-shadow: 0 4px 10px rgba(231,5,132,0.04);
  line-height: 1 !important;
}

.shop-page-title .filter-button i {
  display: inline-block !important;
  font-size: 14px !important;
  margin-right: 6px !important;
  margin-bottom: 0 !important;
  line-height: 1 !important;
}
.shop-page-title .filter-button strong {
  font-weight: 700 !important;
  line-height: 1 !important;
}

/* Dòng Sắp xếp (Sorting) */
.shop-page-title .woocommerce-ordering {
  margin: 0 !important;
}
.shop-page-title .woocommerce-ordering select {
  margin: 0 !important;
  background: #fff !important;
  border: 1px solid rgba(231,5,132,0.2) !important;
  border-radius: 99px !important;
  padding: 6px 30px 6px 16px !important;
  height: 34px !important;
  font-size: 13.5px !important;
  color: #2a1520;
  box-shadow: 0 4px 10px rgba(231,5,132,0.04);
}

/* Ẩn bớt số lượng kết quả trên Mobile cho đỡ rối */
@media (max-width: 549px) {
  .shop-page-title .woocommerce-result-count {
    display: none !important;
  }
}


.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  display: flex;
  flex-direction: column;
}

.woocommerce ul.products li.product .col-inner,
.woocommerce-page ul.products li.product .col-inner {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
}

.woocommerce ul.products li.product .box,
.woocommerce-page ul.products li.product .box {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 100%;
  border: 1px solid rgba(231, 5, 132, 0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(231, 5, 132, 0.08);
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.woocommerce ul.products li.product .box:hover,
.woocommerce-page ul.products li.product .box:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 34px rgba(231, 5, 132, 0.15);
}

.woocommerce ul.products li.product .box-image,
.woocommerce-page ul.products li.product .box-image {
  flex-shrink: 0;
}

.woocommerce ul.products li.product .box-image img,
.woocommerce-page ul.products li.product .box-image img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.product-small .box-text,
.woocommerce ul.products li.product .box-text,
.woocommerce-page ul.products li.product .box-text {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  padding: 14px 16px 16px !important;
}

.woocommerce ul.products li.product .title-wrapper,
.woocommerce-page ul.products li.product .title-wrapper {
  flex: 1 1 auto;
  min-height: 0;
}

.woocommerce ul.products li.product .price-wrapper,
.woocommerce-page ul.products li.product .price-wrapper {
  flex-shrink: 0;
  margin-top: auto;
  padding-top: 10px;
}

.woocommerce ul.products li.product .name,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product p.name.product-title,
.woocommerce-page ul.products li.product .name,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product p.name.product-title {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.45;
  margin-bottom: 0;
  color: #1a1a2e;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Flatsome: loop thật tế là div.products > div.product — 2 dòng cố định + ellipsis (giá thẳng hàng) */
.woocommerce .products .product.product-small .title-wrapper,
.woocommerce-page .products .product.product-small .title-wrapper {
  flex-shrink: 0;
  overflow: visible;
}

.woocommerce .products .product.product-small .box-text p.name.product-title,
.woocommerce .products .product.product-small .box-text p.woocommerce-loop-product__title,
.woocommerce-page .products .product.product-small .box-text p.name.product-title,
.woocommerce-page .products .product.product-small .box-text p.woocommerce-loop-product__title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 15px;
  line-height: 1.45;
  height: calc(1.45em * 2);
  min-height: calc(1.45em * 2);
  max-height: calc(1.45em * 2);
  box-sizing: border-box;
}

.woocommerce .products .product.product-small .box-text p.name.product-title a,
.woocommerce .products .product.product-small .box-text p.woocommerce-loop-product__title a,
.woocommerce-page .products .product.product-small .box-text p.name.product-title a,
.woocommerce-page .products .product.product-small .box-text p.woocommerce-loop-product__title a {
  display: inline;
  color: inherit;
}

/* Thẻ SP: SP không có sao vẫn chừa đúng một dòng — giá thẳng hàng với SP có đánh giá */
.woocommerce .product-small .box-text:not(:has(.star-rating)) .title-wrapper {
  padding-bottom: 22px;
}

.woocommerce .product-small .box-text .star-rating {
  margin: 6px 0 4px;
  flex-shrink: 0;
  float: none !important;
  display: inline-block !important;
  vertical-align: top;
}

.woocommerce ul.products li.product .name a,
.woocommerce ul.products li.product p.name a,
.woocommerce-page ul.products li.product .name a,
.woocommerce-page ul.products li.product p.name a {
  color: #1a1a2e;
}

.woocommerce ul.products li.product .name a:hover,
.woocommerce-page ul.products li.product .name a:hover {
  color: #e70584;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  color: #e70584;
  font-weight: 700;
  font-size: 15px;
}

.woocommerce span.onsale {
  border: 0;
  border-radius: 999px;
  min-height: 30px;
  line-height: 30px;
  padding: 0 12px;
  background: linear-gradient(135deg, #e70584 0%, #cc0474 100%);
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
  border-radius: 999px;
  border-color: #e70584;
  color: #e70584;
  font-weight: 700;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
  background: #e70584;
  color: #fff;
}

/* Shop filters/order bar */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering select {
  color: #5f4a55;
}

.woocommerce .woocommerce-ordering select {
  border-radius: 10px;
  border-color: rgba(231,5,132,0.2);
  background: #fff;
}

/* Single product layout */
body.single-product .product-main {
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(231, 5, 132, 0.1);
  padding: clamp(12px, 2.6vw, 26px);
}

/*
 * Tiêu đề sản phẩm CHỈ trên h1 (Flatsome: product_title + product-title).
 * Không dùng div.product .product-title — class đó cũng có ở thẻ p trong Related.
 * Layout Gallery Wide không có .product-main → bắt buộc có h1.product_title.
 */
body.single-product div.product h1.product_title,
body.single-product div.product h1.product-title {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
  font-size: clamp(26px, 3.2vw, 40px) !important;
  font-weight: 700 !important;
  line-height: 1.22 !important;
  letter-spacing: -0.02em !important;
  color: #1a1a2e !important;
  margin: 0 0 12px !important;
}

/* Chỉ giá khối sản phẩm chính — không dùng div.product span.price (trúng luôn Related) */
body.single-product div.product .product-main p.price,
body.single-product div.product .product-main span.price,
body.single-product div.product .entry-summary p.price,
body.single-product div.product .entry-summary span.price,
body.single-product div.product .add-to-cart-wrapper p.price,
body.single-product div.product .add-to-cart-wrapper span.price {
  color: #e70584;
  font-weight: 800;
  font-size: clamp(24px, 2.8vw, 36px);
}

body.single-product div.product .woocommerce-product-details__short-description {
  color: #5b4953;
  font-size: 15px;
  line-height: 1.76;
}

body.single-product .quantity .qty {
  border-radius: 999px;
  border: 1px solid rgba(231,5,132,0.25);
  height: 42px;
}

body.single-product div.product form.cart .button.single_add_to_cart_button {
  border-radius: 999px;
  min-height: 42px;
  padding: 0 20px;
  background: linear-gradient(135deg, #e70584 0%, #cc0474 100%);
  border: 0;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.02em;
}

body.single-product div.product .woocommerce-product-gallery {
  border-radius: 12px;
  overflow: hidden;
}

/* Product tabs — không bọc khung ngoài (chỉ nội dung, tránh “hộp” hồng) */
body.single-product .woocommerce-tabs {
  margin-top: 18px;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

body.single-product .woocommerce-tabs ul.tabs li a {
  font-weight: 700;
}

body.single-product .woocommerce-Tabs-panel {
  color: #5d4a55;
  line-height: 1.75;
}

body.single-product .woocommerce-tabs .woocommerce-Tabs-panel,
body.single-product .woocommerce-tabs .panel,
body.single-product #tab-reviews {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

/* Related products */
body.single-product .related,
body.single-product .upsells {
  margin-top: 20px;
  padding: 18px 14px;
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(231, 5, 132, 0.07);
  width: min(1240px, 92%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

body.single-product .related > h2,
body.single-product .upsells > h2 {
  font-size: clamp(30px, 3.5vw, 48px);
  margin-bottom: 12px;
}

/* Single product — contact CTAs (replaces Add to cart) */
.fsc-product-contact-cta {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
  margin-bottom: 4px;
}

.fsc-product-contact-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 20px;
  border-radius: 999px;
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  border: 0;
  line-height: 1.3;
}

.fsc-product-contact-cta__btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
}

.fsc-product-contact-cta__btn--whatsapp {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
  color: #fff !important;
}

.fsc-product-contact-cta__btn--whatsapp:hover {
  color: #fff !important;
}

.fsc-product-contact-cta__btn--instagram {
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 45%, #8134af 100%);
  color: #fff !important;
}

.fsc-product-contact-cta__btn--instagram:hover {
  color: #fff !important;
}

.fsc-product-contact-cta__icon {
  display: flex;
  flex-shrink: 0;
}

@media (min-width: 550px) {
  .fsc-product-contact-cta {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

/* Breadcrumbs */
.woocommerce .woocommerce-breadcrumb,
.woocommerce-page .woocommerce-breadcrumb {
  color: #6b5560;
}

.woocommerce .woocommerce-breadcrumb a,
.woocommerce-page .woocommerce-breadcrumb a {
  color: #e70584;
}

/* ===== Homepage hero slider (movie style) ===== */
.fsc-hero-slider {
  position: relative;
  width: 100%;
  min-height: clamp(560px, 82vh, 920px);
  border-radius: 0;
  overflow: hidden;
  background: #020617;
  margin-bottom: 24px;
}

.fsc-hero-slider__track {
  position: relative;
  min-height: inherit;
}

.fsc-hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: scale(1.02);
  transition: opacity 0.45s ease, transform 0.6s ease;
  background-size: cover;
  background-position: center;
}

.fsc-hero-slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: scale(1);
}

.fsc-hero-slide__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(36, 14, 26, 0.88) 0%, rgba(36, 14, 26, 0.68) 35%, rgba(36, 14, 26, 0.3) 60%, rgba(36, 14, 26, 0.7) 100%),
    linear-gradient(0deg, rgba(36, 14, 26, 0.84) 0%, rgba(36, 14, 26, 0) 45%);
}

.fsc-hero-slide__content {
  position: relative;
  z-index: 1;
  max-width: 560px;
  padding: clamp(28px, 6vw, 72px);
  color: #fff1f6;
}

.fsc-hero-slide__subtitle {
  display: inline-block;
  margin-bottom: 8px;
  opacity: 1;
  color: #ffd7e5;
  font-size: 14px;
}

.fsc-hero-slide__title {
  color: #fff;
  font-size: clamp(30px, 5vw, 52px);
  margin: 0 0 8px;
}

.fsc-hero-slide__meta {
  font-size: 13px;
  color: #ffe4ee;
  margin-bottom: 14px;
}

.fsc-hero-slide__description {
  color: #ffdbe8;
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 20px;
}

.fsc-hero-slide__actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.fsc-hero-slide__btn {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 0;
  cursor: pointer;
}

.fsc-hero-slide__btn--play {
  width: auto;
  min-width: 130px;
  padding: 0 18px;
  background: linear-gradient(135deg, #f26cb5 0%, #e70584 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 8px 30px rgba(231, 5, 132, 0.35);
}

.fsc-hero-slide__btn--ghost {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.fsc-hero-slider__nav {
  position: absolute;
  right: 20px;
  bottom: 18px;
  z-index: 3;
  display: flex;
  gap: 8px;
  max-width: min(56vw, 460px);
  overflow-x: auto;
  padding: 4px;
}

.fsc-hero-slider__thumb {
  border: 2px solid transparent;
  background: rgba(15, 23, 42, 0.55);
  border-radius: 9px;
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  flex: 0 0 auto;
  width: 64px;
  height: 38px;
}

.fsc-hero-slider__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fsc-hero-slider__thumb.is-active {
  border-color: #f8fafc;
}

@media (max-width: 849px) {
  .fsc-hero-slider {
    border-radius: 0;
    min-height: 72vh;
  }

  .fsc-hero-slide__content {
    max-width: 100%;
    padding: 22px 18px 92px;
  }

  .fsc-hero-slide__title {
    font-size: clamp(25px, 7vw, 35px);
  }

  .fsc-hero-slider__nav {
    left: 14px;
    right: 14px;
    bottom: 10px;
    max-width: none;
  }
}

/* ===== Homepage sections: USP + quick categories ===== */
.fsc-home-usp,
.fsc-home-cats {
  padding: clamp(30px, 5vw, 56px) 0;
}

.fsc-home-wrap {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}

.fsc-home-usp {
  position: relative;
}

.fsc-home-usp::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(1240px, 100%);
  height: 100%;
  border-radius: 26px;
  background:
    radial-gradient(circle at 10% 15%, rgba(231, 5, 132, 0.32) 0%, rgba(231, 5, 132, 0) 34%),
    radial-gradient(circle at 88% 8%, rgba(231, 5, 132, 0.26) 0%, rgba(231, 5, 132, 0) 38%),
    linear-gradient(180deg, #fff9fc 0%, #fff4f8 100%);
  border: 1px solid rgba(231,5,132,0.25);
  box-shadow: 0 20px 45px rgba(231, 5, 132, 0.08);
  pointer-events: none;
}

.fsc-home-usp .fsc-home-wrap {
  position: relative;
  z-index: 1;
  padding: 26px 18px;
}

.fsc-home-head {
  margin-bottom: 18px;
}

.fsc-home-usp__top {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 16px;
  align-items: stretch;
  margin-bottom: 16px;
}

.fsc-home-usp__visual {
  position: relative;
  min-height: 190px;
  border-radius: 16px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(231,5,132,0.25);
  box-shadow: 0 14px 34px rgba(231, 5, 132, 0.15);
}

.fsc-home-usp__visual-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(130deg, rgba(52, 17, 34, 0.78) 12%, rgba(52, 17, 34, 0.24) 78%);
}

.fsc-home-usp__visual-content {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  z-index: 1;
  color: #fff3f8;
}

.fsc-home-usp__visual-content span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.9;
  margin-bottom: 6px;
}

.fsc-home-usp__visual-content strong {
  font-size: 20px;
  line-height: 1.45;
}

.fsc-home-head__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(231,5,132,0.12);
  color: #e70584;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.fsc-home-head__title {
  margin: 10px 0 0;
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #1e1b2f;
}

.fsc-usp-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.fsc-usp-card {
  position: relative;
  background: linear-gradient(180deg, #ffffff 0%, #fff8fb 100%);
  border: 1px solid rgba(231,5,132,0.2);
  border-radius: 14px;
  padding: 18px 16px 16px;
  box-shadow: 0 12px 26px rgba(231, 5, 132, 0.1);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.fsc-usp-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #f26cb5 0%, #e70584 100%);
    opacity: 1;
    border-radius: 13px 13px 0 0;
}

.fsc-usp-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 32px rgba(231, 5, 132, 0.16);
}

.fsc-usp-card__icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f26cb5 0%, #e70584 100%);
  color: #fff;
  font-size: 16px;
}

.fsc-usp-card__stat {
  display: inline-flex;
  margin-left: 8px;
  transform: translateY(-8px);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 999px;
  background: #e70584;
  color: #ffffff;
}

.fsc-usp-card__title {
  margin: 12px 0 6px;
  font-size: 18px;
  color: #271524;
}

.fsc-home-cats {
  position: relative;
}

.fsc-home-cats::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: min(1240px, 100%);
  height: calc(100% - 12px);
  border-radius: 24px;
  background: linear-gradient(180deg, #fff5f9 0%, #fff 100%);
  border: 1px solid #f7d6e4;
  pointer-events: none;
}

.fsc-home-cats .fsc-home-wrap {
  position: relative;
  z-index: 1;
  padding: 24px 18px 28px;
}

.fsc-usp-card__desc {
  margin: 0;
  color: #6a4460;
  font-size: 14px;
  line-height: 1.6;
}

.fsc-cat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.fsc-cat-card {
  position: relative;
  overflow: hidden;
  min-height: 250px;
  border-radius: 18px;
  border: 1px solid #f3bfd3;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(231, 5, 132, 0.16);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.2s ease;
}

.fsc-cat-card:hover {
  transform: translateY(-6px);
  border-color: #f59ab7;
  box-shadow: 0 18px 36px rgba(231, 5, 132, 0.2);
}

.fsc-cat-card__media {
  position: absolute;
  inset: 0;
}

.fsc-cat-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform 0.5s ease;
}

.fsc-cat-card:hover .fsc-cat-card__media img {
  transform: scale(1.08);
}

.fsc-cat-card__shine {
  position: absolute;
  inset: -2px;
  background: linear-gradient(115deg, rgba(255, 255, 255, 0) 40%, rgba(255, 255, 255, 0.55) 50%, rgba(255, 255, 255, 0) 60%);
  transform: translateX(-130%);
  transition: transform 0.7s ease;
}

.fsc-cat-card:hover .fsc-cat-card__shine {
  transform: translateX(130%);
}

.fsc-cat-card__content {
  position: relative;
  z-index: 1;
  height: 100%;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(0deg, rgba(36, 14, 26, 0.82) 0%, rgba(36, 14, 26, 0.14) 66%);
}

.fsc-cat-card__tag {
  display: inline-flex;
  align-self: flex-start;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(231, 5, 132, 0.85);
  border: 1px solid rgba(255, 220, 233, 0.65);
  padding: 5px 9px;
  border-radius: 999px;
}

.fsc-cat-card__title {
  margin: 0 0 8px;
  color: #fff7fb;
  font-size: clamp(20px, 2.2vw, 28px);
}

.fsc-cat-card__desc {
  margin: 0 0 12px;
  color: #ffe4ef;
  font-size: 14px;
}

.fsc-cat-card__cta {
  font-size: 13px;
  font-weight: 700;
  color: #ffd1e2;
}

.fsc-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
  transition-delay: var(--reveal-delay, 0ms);
}

.fsc-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===== Homepage section: Our Heritage ===== */
.fsc-home-heritage {
  position: relative;
  padding: clamp(40px, 6vw, 86px) 0;
  background-color: #ffffff;
  /* Subtle wave pattern using inline SVG */
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C240,110 480,10 720,60 C960,110 1200,10 1440,60 L1440,0 L0,0 Z' fill='rgba(231,5,132,0.035)'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath d='M0,40 C360,90 720,0 1080,50 C1260,75 1380,30 1440,40 L1440,120 L0,120 Z' fill='rgba(231,5,132,0.025)'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 80' preserveAspectRatio='none'%3E%3Cpath d='M0,40 C180,10 360,70 540,40 C720,10 900,70 1080,40 C1260,10 1380,60 1440,40' stroke='rgba(231,5,132,0.08)' stroke-width='1.5' fill='none'/%3E%3Cpath d='M0,55 C200,25 400,80 600,55 C800,30 1000,80 1200,55 C1350,38 1410,65 1440,55' stroke='rgba(231,5,132,0.05)' stroke-width='1' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat, repeat-x;
  background-size: 100% 140px, 100% 140px, 180px 80px;
  background-position: top center, bottom center, center center;
  overflow: hidden;
}

.fsc-home-heritage::before {
  content: "";
  position: absolute;
  inset: 10px 0 0;
  width: min(1240px, 100%);
  margin: 0 auto;
  border-radius: 24px;
  border: 1px solid rgba(231,5,132,0.1);
  background: transparent;
  pointer-events: none;
}

.fsc-home-heritage__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(20px, 4vw, 62px);
  align-items: center;
  padding: clamp(18px, 2.6vw, 36px);
}

.fsc-home-heritage__media {
  position: relative;
}

.fsc-home-heritage__image-wrap {
  position: relative;
  z-index: 1;
  aspect-ratio: 4 / 5;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 22px 48px rgba(231, 5, 132, 0.2);
}

.fsc-home-heritage__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fsc-home-heritage__shape {
  position: absolute;
  width: min(62%, 240px);
  aspect-ratio: 1;
  right: -28px;
  bottom: -24px;
  background: linear-gradient(135deg, rgba(231, 5, 132, 0.3) 0%, rgba(174, 46, 95, 0.24) 100%);
  border-radius: 14px;
  z-index: 0;
}

.fsc-home-heritage__title {
  margin: 14px 0 18px;
  font-size: clamp(30px, 4.1vw, 54px);
  line-height: 1.1;
  color: #221a21;
}

.fsc-home-heritage__title i {
  font-style: italic;
  font-weight: 500;
}

.fsc-home-heritage__text {
  display: grid;
  gap: 14px;
  color: #5c4953;
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.75;
}

.fsc-home-heritage__text p {
  margin: 0;
}

.fsc-home-heritage__cta {
  margin-top: 28px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 16px;
  font-weight: 700;
  color: #e70584;
  text-decoration: none;
}

.fsc-home-heritage__cta span {
  width: 52px;
  height: 1px;
  background: #e70584;
  transition: width 0.2s ease;
}

.fsc-home-heritage__cta:hover span {
  width: 68px;
}

/* ===== Homepage section: Gallery ===== */
.fsc-home-gallery {
  padding: clamp(50px, 7vw, 96px) 0;
  position: relative;
  overflow: hidden;
  background-color: #fff;
  background-image:
    linear-gradient(180deg, rgba(251,228,240,0.6) 0%, rgba(255,255,255,0) 22%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 720 100'%3E%3Cpath d='M0,30 C120,10 240,50 360,30 C480,10 600,50 720,30' stroke='rgba(231,5,132,0.09)' stroke-width='1.5' fill='none'/%3E%3Cpath d='M0,70 C120,50 240,90 360,70 C480,50 600,90 720,70' stroke='rgba(231,5,132,0.05)' stroke-width='1' fill='none'/%3E%3C/svg%3E");
  background-size: 100% 100%, 720px 100px;
  background-position: top, 0 0;
  background-repeat: no-repeat, repeat;
}

/* Decorative wave accent at top */
.fsc-home-gallery::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 22px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 22' preserveAspectRatio='none'%3E%3Cdefs%3E%3ClinearGradient id='wg' x1='0%25' y1='0%25' x2='100%25' y2='0%25'%3E%3Cstop offset='0%25' stop-color='%23e70584' stop-opacity='0'/%3E%3Cstop offset='25%25' stop-color='%23e70584' stop-opacity='0.7'/%3E%3Cstop offset='50%25' stop-color='%23f26cb5' stop-opacity='0.85'/%3E%3Cstop offset='75%25' stop-color='%23e70584' stop-opacity='0.7'/%3E%3Cstop offset='100%25' stop-color='%23e70584' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cpath d='M0,11 C120,3 240,19 360,11 C480,3 600,19 720,11 C840,3 960,19 1080,11 C1200,3 1320,19 1440,11 L1440,0 L0,0 Z' fill='url(%23wg)'/%3E%3C/svg%3E");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
}

/* Decorative circle blob — top right */
.fsc-home-gallery::after {
  content: "";
  position: absolute;
  top: -80px; right: -80px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(231,5,132,0.08) 0%, transparent 70%);
  pointer-events: none;
}

.fsc-home-gallery__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: clamp(18px, 3vw, 34px);
}

.fsc-home-gallery__title {
  margin: 0 0 6px;
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.12;
  color: #1a0f17;
  letter-spacing: -0.025em;
}

.fsc-home-gallery__subtitle {
  margin: 0;
  color: #8a6070;
  font-size: 15px;
  font-style: italic;
  letter-spacing: 0.01em;
}

.fsc-home-gallery__social {
  color: #e70584;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  padding: 7px 18px;
  border-radius: 999px;
  border: 1.5px solid rgba(231,5,132,0.35);
  background: rgba(231,5,132,0.04);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  white-space: nowrap;
}

.fsc-home-gallery__social:hover {
  background: #e70584;
  border-color: #e70584;
  color: #fff;
}

.fsc-home-gallery__scroll {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 16px 16px 20px;
  scrollbar-width: thin;
  scrollbar-color: rgba(231,5,132,0.35) rgba(231,5,132,0.06);
}

.fsc-home-gallery__scroll::-webkit-scrollbar {
  height: 5px;
}

.fsc-home-gallery__scroll::-webkit-scrollbar-track {
  background: rgba(231,5,132,0.06);
  border-radius: 999px;
}

.fsc-home-gallery__scroll::-webkit-scrollbar-thumb {
  background: rgba(231,5,132,0.35);
  border-radius: 999px;
}

.fsc-home-gallery__scroll::-webkit-scrollbar-thumb:hover {
  background: #e70584;
}

/* Ẩn thanh cuộn ngang khi hàng ảnh đã khít (không tràn) — class do JS gắn */
.fsc-home-gallery__scroll.is-fsc-gallery-no-overflow {
  overflow-x: hidden;
  scrollbar-width: none;
}

.fsc-home-gallery__scroll.is-fsc-gallery-no-overflow::-webkit-scrollbar {
  display: none;
  height: 0;
}

.fsc-home-gallery__scroll.is-custom-gallery {
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  justify-content: flex-start;
  scroll-snap-type: x proximity;
}

/* Khi có cả hai class: .is-custom-gallery đặt overflow-x:auto sau rule no-overflow — cần ghi đè lại khi đã khít */
.fsc-home-gallery__scroll.is-custom-gallery.is-fsc-gallery-no-overflow {
  overflow-x: hidden;
  scrollbar-width: none;
}

.fsc-home-gallery__scroll.is-custom-gallery.is-fsc-gallery-no-overflow::-webkit-scrollbar {
  display: none;
  height: 0;
}

.fsc-home-gallery__card {
  min-width: 260px;
  width: 260px;
  height: 420px;
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid rgba(231,5,132,0.12);
  background: #f8f4f6;
  box-shadow:
    0 8px 24px rgba(231,5,132,0.1),
    0 2px 6px rgba(231,5,132,0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.fsc-home-gallery__card.is-offset {
  margin-top: 40px;
}

.fsc-home-gallery__scroll.is-custom-gallery .fsc-home-gallery__card.is-offset {
  margin-top: 40px;
}

.fsc-home-gallery__scroll.is-custom-gallery .fsc-home-gallery__card {
  scroll-snap-align: start;
}

.fsc-home-gallery__card:hover {
  transform: translateY(-8px) scale(1.015);
  box-shadow:
    0 24px 48px rgba(231,5,132,0.22),
    0 6px 16px rgba(231,5,132,0.1);
  border-color: rgba(231,5,132,0.3);
}

.fsc-home-gallery__card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.fsc-home-gallery__card:hover img {
  transform: scale(1.04);
}

@media (max-width: 1000px) {
  .fsc-home-usp::before,
  .fsc-home-cats::before,
  .fsc-home-heritage::before {
    border-radius: 16px;
  }

  .fsc-home-usp__top {
    grid-template-columns: 1fr;
  }

  .fsc-usp-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fsc-cat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fsc-home-heritage__grid {
    grid-template-columns: 1fr;
  }

  .fsc-home-gallery__card {
    min-width: 270px;
    width: 270px;
    height: 410px;
  }
}

@media (max-width: 767px) {
  .fsc-home-wrap {
    width: calc(100% - 22px);
  }

  .fsc-home-usp .fsc-home-wrap,
  .fsc-home-cats .fsc-home-wrap {
    padding: 16px 10px 18px;
  }

  .fsc-home-heritage__grid {
    padding: 14px 10px;
  }

  .fsc-home-heritage__shape {
    right: -6px;
    bottom: -6px;
  }

  .fsc-home-gallery__scroll {
    gap: 12px;
    padding: 10px 12px 10px;
  }

  .fsc-home-gallery__card {
    min-width: 235px;
    width: 235px;
    height: 340px;
    border-radius: 10px;
  }

  .fsc-home-gallery__card.is-offset {
    margin-top: 18px;
  }

  .fsc-usp-grid,
  .fsc-cat-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .fsc-cat-card {
    min-height: 200px;
    border-radius: 14px;
  }
}

/* ===== Homepage section: Newsletter ===== */
.fsc-home-newsletter {
  padding: clamp(34px, 5vw, 72px) 0 clamp(44px, 6vw, 96px);
  background: #faf9f6;
}

.fsc-home-newsletter__gradient {
  background: linear-gradient(135deg, #e70584 0%, #cc0474 100%);
  padding: 4px;
  border-radius: 16px;
  overflow: hidden;
}

.fsc-home-newsletter__inner {
  border-radius: 12px;
  background: #faf9f6;
  padding: clamp(28px, 5vw, 72px) clamp(16px, 5vw, 58px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.fsc-home-newsletter__icon {
  color: #e70584;
  font-size: 42px;
  margin-bottom: 16px;
}

.fsc-home-newsletter__title {
  margin: 0 0 10px;
  font-size: clamp(30px, 4.2vw, 54px);
  line-height: 1.1;
  color: #221c23;
}

.fsc-home-newsletter__title i {
  font-style: italic;
  font-weight: 400;
}

.fsc-home-newsletter__subtitle {
  margin: 0;
  max-width: 720px;
  color: #5b4a54;
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.75;
}

.fsc-home-newsletter__form {
  margin-top: 24px;
  width: min(100%, 640px);
  display: flex;
  gap: 12px;
}

.fsc-home-newsletter__input {
  flex: 1;
  border: 1px solid #ecd2dd;
  background: #f4f3f1;
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 15px;
  color: #1a1c1a;
}

.fsc-home-newsletter__input:focus {
  border-color: #cc0474;
  box-shadow: 0 0 0 3px rgba(174, 46, 95, 0.15);
  outline: none;
}

.fsc-home-newsletter__button {
  border: 0;
  background: #e70584;
  color: #fff;
  border-radius: 10px;
  padding: 14px 26px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.fsc-home-newsletter__button:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}

.fsc-home-newsletter__notice {
  margin: 14px 0 0;
  font-size: 14px;
  font-weight: 600;
}

.fsc-home-newsletter__notice.is-success {
  color: #0b7a43;
}

.fsc-home-newsletter__notice.is-info {
  color: #6a5176;
}

.fsc-home-newsletter__notice.is-error {
  color: #ba1a1a;
}

.fsc-home-newsletter__policy {
  margin: 14px 0 0;
  color: #6f5964;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

@media (max-width: 767px) {
  .fsc-home-newsletter__form {
    flex-direction: column;
  }

  .fsc-home-newsletter__button {
    width: 100%;
  }
}

/* ===== Contact page ===== */
.fsc-contact-page {
  padding: clamp(34px, 5vw, 72px) 0 clamp(48px, 6vw, 92px);
  background: linear-gradient(180deg, #faf9f6 0%, #fff7fb 100%);
}

.fsc-contact-page__hero {
  text-align: center;
  max-width: 880px;
  margin: 0 auto 28px;
}

.fsc-contact-page__title {
  margin: 12px 0;
  font-size: clamp(34px, 4.6vw, 60px);
  line-height: 1.12;
  color: #221c23;
}

.fsc-contact-page__subtitle {
  margin: 0;
  color: #5b4a54;
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.72;
}

.fsc-contact-page__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 18px;
}

.fsc-contact-page__info {
  display: grid;
  gap: 12px;
}

.fsc-contact-card,
.fsc-contact-page__form-wrap {
  border: 1px solid #efd6e1;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 14px 28px rgba(231, 5, 132, 0.08);
}

.fsc-contact-card {
  padding: 16px 16px 14px;
}

.fsc-contact-card h3 {
  margin: 0 0 6px;
  font-size: 20px;
  color: #321d2a;
}

.fsc-contact-card p {
  margin: 0;
  color: #634f5b;
  font-size: 14px;
}

.fsc-contact-card a {
  color: #e70584;
  text-decoration: none;
}

.fsc-contact-page__form-wrap {
  padding: clamp(18px, 3vw, 28px);
}

.fsc-contact-page__form-wrap h2 {
  margin: 0 0 14px;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.1;
}

.fsc-contact-form {
  display: grid;
  gap: 12px;
}

.fsc-contact-form__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.fsc-contact-form input,
.fsc-contact-form textarea {
  width: 100%;
  border: 1px solid rgba(231,5,132,0.2);
  border-radius: 10px;
  background: #faf7f9;
  color: #1a1c1a;
  font-size: 14px;
  padding: 13px 14px;
}

.fsc-contact-form input:focus,
.fsc-contact-form textarea:focus {
  border-color: #cc0474;
  box-shadow: 0 0 0 3px rgba(174, 46, 95, 0.15);
  outline: none;
}

.fsc-contact-form button {
  justify-self: start;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #e70584 0%, #cc0474 100%);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 13px 22px;
  cursor: pointer;
}

.fsc-contact-page__notice {
  margin: 10px 0 0;
  font-size: 14px;
  font-weight: 600;
}

.fsc-contact-page__notice.is-success {
  color: #0b7a43;
}

.fsc-contact-page__notice.is-error {
  color: #ba1a1a;
}

@media (max-width: 1000px) {
  .fsc-contact-page__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .fsc-contact-form__row {
    grid-template-columns: 1fr;
  }

  .fsc-contact-form button {
    width: 100%;
    justify-self: stretch;
  }
}

/* ===== About Us page ===== */
.fsc-about-page {
  padding: clamp(34px, 5vw, 74px) 0 clamp(52px, 7vw, 110px);
  background: linear-gradient(180deg, #faf9f6 0%, #fff4f8 100%);
}

.fsc-about-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(18px, 3vw, 32px);
  align-items: stretch;
  margin-bottom: clamp(24px, 4vw, 40px);
}

.fsc-about-hero__content,
.fsc-about-hero__image-wrap,
.fsc-about-story,
.fsc-about-values,
.fsc-about-process,
.fsc-about-cta {
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(231, 5, 132, 0.09);
}

.fsc-about-hero__content {
  padding: clamp(18px, 3vw, 30px);
}

.fsc-about-hero__title {
  margin: 12px 0 12px;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: 1.08;
  color: #221b22;
}

.fsc-about-hero__subtitle {
  margin: 0;
  color: #5f4a55;
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.76;
}

.fsc-about-hero__stats {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.fsc-about-hero__stats div {
  border: 1px solid #f2d9e4;
  border-radius: 11px;
  padding: 10px;
  background: #fff7fb;
}

.fsc-about-hero__stats strong {
  display: block;
  font-size: 22px;
  color: #e70584;
  line-height: 1.1;
}

.fsc-about-hero__stats span {
  font-size: 12px;
  color: #6c5560;
}

.fsc-about-hero__image-wrap {
  overflow: hidden;
  min-height: 460px;
}

.fsc-about-hero__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fsc-about-story {
  margin-bottom: 18px;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 16px;
  padding: 16px;
}

.fsc-about-story__image {
  border-radius: 12px;
  overflow: hidden;
  min-height: 320px;
}

.fsc-about-story__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fsc-about-story__content {
  align-self: center;
}

.fsc-about-story__content h2 {
  margin: 0 0 10px;
  font-size: clamp(32px, 4vw, 50px);
  line-height: 1.12;
}

.fsc-about-story__content p {
  margin: 0 0 12px;
  color: #5d4a55;
  font-size: 15px;
  line-height: 1.75;
}

.fsc-about-values,
.fsc-about-process {
  padding: 20px 18px;
  margin-bottom: 18px;
}

.fsc-about-values__grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.fsc-about-value-card {
  border: 1px solid #f0d9e4;
  border-radius: 12px;
  padding: 15px 14px;
  background: linear-gradient(180deg, #fff 0%, #fff7fb 100%);
}

.fsc-about-value-card h3 {
  margin: 0 0 6px;
  font-size: 22px;
  color: #2b1d2a;
}

.fsc-about-value-card p {
  margin: 0;
  color: #614d58;
  font-size: 14px;
  line-height: 1.68;
}

.fsc-about-process__timeline {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.fsc-about-step {
  border: 1px solid #f0d9e4;
  border-radius: 12px;
  padding: 14px 12px;
  background: #fff;
}

.fsc-about-step span {
  display: inline-flex;
  margin-bottom: 8px;
  color: #e70584;
  font-weight: 800;
  letter-spacing: 0.08em;
  font-size: 12px;
}

.fsc-about-step h3 {
  margin: 0 0 6px;
  font-size: 20px;
  color: #2f1f2d;
}

.fsc-about-step p {
  margin: 0;
  color: #64505b;
  font-size: 14px;
  line-height: 1.65;
}

.fsc-about-cta {
  text-align: center;
  padding: clamp(20px, 4vw, 42px) clamp(14px, 4vw, 40px);
  background: linear-gradient(145deg, #fff 0%, #fff4fa 90%);
}

.fsc-about-cta h2 {
  margin: 0 0 8px;
  font-size: clamp(32px, 4.5vw, 58px);
  line-height: 1.12;
}

.fsc-about-cta p {
  margin: 0 auto;
  max-width: 760px;
  color: #614d58;
  font-size: 16px;
  line-height: 1.72;
}

.fsc-about-cta__actions {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fsc-about-cta__actions a {
  border-radius: 999px;
  text-decoration: none;
  border: 1px solid #e70584;
  background: #e70584;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 18px;
}

.fsc-about-cta__actions a.is-outline {
  background: transparent;
  color: #e70584;
}

@media (max-width: 1100px) {
  .fsc-about-hero,
  .fsc-about-story {
    grid-template-columns: 1fr;
  }

  .fsc-about-process__timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .fsc-about-hero__stats,
  .fsc-about-values__grid,
  .fsc-about-process__timeline {
    grid-template-columns: 1fr;
  }

  .fsc-about-hero__image-wrap {
    min-height: 320px;
  }
}

/* ===== Blog optimization (archive + single) ===== */
body.blog #content.blog-wrapper,
body.archive #content.blog-wrapper,
body.single-post #content.blog-wrapper {
  background: linear-gradient(180deg, #faf9f6 0%, #fff7fb 100%);
}

/* Archive cards */
body.blog .blog-wrapper .post,
body.archive.category .blog-wrapper .post,
body.archive.tag .blog-wrapper .post,
body.search .blog-wrapper .post {
  margin-bottom: 24px;
}

body.blog .blog-wrapper .article-inner,
body.archive .blog-wrapper .article-inner,
body.search .blog-wrapper .article-inner {
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(231, 5, 132, 0.08);
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

body.blog .blog-wrapper .article-inner:hover,
body.archive .blog-wrapper .article-inner:hover,
body.search .blog-wrapper .article-inner:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(231, 5, 132, 0.14);
}

body.blog .blog-wrapper .entry-header-text,
body.archive .blog-wrapper .entry-header-text,
body.search .blog-wrapper .entry-header-text {
  padding: 18px 18px 0;
}

body.blog .blog-wrapper .entry-image,
body.archive .blog-wrapper .entry-image,
body.search .blog-wrapper .entry-image {
  border-radius: 0;
}

body.blog .blog-wrapper .entry-image img,
body.archive .blog-wrapper .entry-image img,
body.search .blog-wrapper .entry-image img {
  aspect-ratio: 16/9;
  object-fit: cover;
}

body.blog .blog-wrapper h2.entry-title,
body.archive .blog-wrapper h2.entry-title,
body.search .blog-wrapper h2.entry-title {
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.15;
  margin-bottom: 8px;
}

body.blog .blog-wrapper .entry-content,
body.archive .blog-wrapper .entry-content,
body.search .blog-wrapper .entry-content {
  padding: 16px 18px 18px;
}

body.blog .blog-wrapper .entry-summary,
body.archive .blog-wrapper .entry-summary,
body.search .blog-wrapper .entry-summary {
  color: #624e58;
  font-size: 15px;
  line-height: 1.72;
}

body.blog .blog-wrapper .more-link.button,
body.archive .blog-wrapper .more-link.button,
body.search .blog-wrapper .more-link.button {
  border-radius: 999px;
  border-color: #e70584;
  color: #e70584;
  font-weight: 700;
  letter-spacing: 0.02em;
}

body.blog .blog-wrapper .more-link.button:hover,
body.archive .blog-wrapper .more-link.button:hover,
body.search .blog-wrapper .more-link.button:hover {
  background: #e70584;
  color: #fff;
}

/* Sidebar widgets */
.blog-wrapper .widget,
.blog-wrapper .widget_search,
.blog-wrapper .widget_recent_entries,
.blog-wrapper .widget_categories,
.blog-wrapper .widget_tag_cloud {
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(231, 5, 132, 0.06);
  padding: 14px;
  margin-bottom: 14px;
}

.blog-wrapper .widget-title {
  margin-bottom: 10px;
  font-size: 24px;
  line-height: 1.2;
}

/* Pagination */
.blog-wrapper .nav-pagination > li > a,
.blog-wrapper .nav-pagination > li > span {
  border-radius: 999px;
  border-color: #e8ceda;
  min-width: 38px;
  height: 38px;
  line-height: 36px;
}

.blog-wrapper .nav-pagination > li > .current,
.blog-wrapper .nav-pagination > li > span.current {
  background: #e70584;
  border-color: #e70584;
  color: #fff;
}

/* Single post */
body.single-post .blog-single .article-inner {
  border: 1px solid rgba(231,5,132,0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(231, 5, 132, 0.09);
  overflow: hidden;
}

body.single-post .blog-single .entry-header-text {
  padding: 24px 24px 6px;
}

body.single-post .blog-single h1.entry-title {
  font-size: clamp(34px, 4.4vw, 64px);
  line-height: 1.08;
}

body.single-post .blog-single .entry-content.single-page {
  padding: 22px 24px 26px;
  color: #43333d;
}

body.single-post .blog-single .entry-content.single-page p {
  font-size: 17px;
  line-height: 1.86;
  color: #5a4953;
}

body.single-post .blog-single .entry-content.single-page h2,
body.single-post .blog-single .entry-content.single-page h3 {
  margin-top: 1.4em;
  margin-bottom: 0.5em;
}

body.single-post .blog-single blockquote {
  border-left: 3px solid #cc0474;
  background: #fff6fa;
  border-radius: 10px;
  padding: 16px 18px;
}

body.single-post .blog-single .entry-author.author-box {
  border-top: 1px solid #f0dce5;
  margin: 0 24px 20px;
  padding-top: 20px;
}

body.single-post .blog-single .blog-share {
  margin-top: 26px;
}

body.single-post .blog-single .nav-next-prev {
  padding: 0 24px 24px;
}

@media (max-width: 849px) {
  body.single-post .blog-single .entry-header-text,
  body.single-post .blog-single .entry-content.single-page {
    padding-left: 14px;
    padding-right: 14px;
  }

  body.blog .blog-wrapper .entry-header-text,
  body.archive .blog-wrapper .entry-header-text,
  body.blog .blog-wrapper .entry-content,
  body.archive .blog-wrapper .entry-content {
    padding-left: 14px;
    padding-right: 14px;
  }
}

/* ===== Sale Team Member Section ===== */
.fsc-home-team {
  padding: clamp(40px, 6vw, 72px) 0;
  background: linear-gradient(180deg, #fff9fc 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

.fsc-home-team::before {
  content: "";
  position: absolute;
  top: -60px;
  left: -60px;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(231,5,132,0.07) 0%, rgba(231,5,132,0) 70%);
  pointer-events: none;
}

.fsc-home-team::after {
  content: "";
  position: absolute;
  bottom: -80px;
  right: -40px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(231,5,132,0.06) 0%, rgba(231,5,132,0) 70%);
  pointer-events: none;
}

.fsc-home-team .fsc-home-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 36px;
}

.fsc-home-team__subtitle {
  margin: 10px auto 0;
  max-width: 520px;
  color: var(--text-soft);
  font-size: 15px;
  line-height: 1.65;
}

/* Slider wrapper */
.fsc-team-slider-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
}

.fsc-team-track {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 16px 4px 8px;
  flex: 1;
}

/* Scrollbar hidden already via .no-scrollbar */

/* Card */
.fsc-team-card {
  flex: 0 0 calc(25% - 15px);
  min-width: 200px;
  scroll-snap-align: start;
  background: #ffffff;
  border: 1px solid rgba(231,5,132,0.15);
  border-radius: 20px;
  box-shadow: 0 8px 28px rgba(231,5,132,0.08);
  padding: 28px 20px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.fsc-team-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(231,5,132,0.16);
}

/* Avatar */
.fsc-team-card__avatar-wrap {
  position: relative;
  width: 100px;
  height: 100px;
  margin-bottom: 6px;
}

.fsc-team-card__avatar-ring {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: conic-gradient(from 180deg, #f26cb5 0%, #e70584 40%, #ffd6ec 70%, #f26cb5 100%);
  animation: fsc-team-ring-spin 5s linear infinite;
}

@keyframes fsc-team-ring-spin {
  to { transform: rotate(360deg); }
}

.fsc-team-card__avatar {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(135deg, #fce8f3 0%, #ffd6ed 100%);
  border: 3px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fsc-team-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fsc-team-card__initial {
  font-size: 36px;
  font-weight: 800;
  color: var(--brand-primary);
  font-family: "Noto Serif", serif;
  line-height: 1;
}

.fsc-team-card__online-dot {
  position: absolute;
  bottom: 4px;
  right: 4px;
  z-index: 2;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #22c55e;
  border: 2.5px solid #fff;
  box-shadow: 0 0 0 0 rgba(34,197,94,0.5);
  animation: fsc-team-pulse 2s ease-in-out infinite;
}

@keyframes fsc-team-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0.4); }
  50%        { box-shadow: 0 0 0 6px rgba(34,197,94,0); }
}

/* Card text */
.fsc-team-card__name {
  font-size: 18px;
  font-weight: 700;
  color: var(--brand-primary);
  margin: 6px 0 0;
  font-family: "Manrope", sans-serif !important;
}

.fsc-team-card__role {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-soft);
}

.fsc-team-card__phone {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-main);
  text-decoration: none;
  margin-top: 2px;
}

.fsc-team-card__phone:hover {
  color: var(--brand-primary);
}


/* ── Team card action buttons ────────────────────────────── */
.fsc-team-card__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
  width: 100%;
}

/* Shared base for both CTA btns */
.fsc-team-card__whatsapp,
.fsc-team-card__instagram {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  color: #fff !important;
  border: 0;
  width: 100%;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease, filter 0.22s ease;
}

/* Shimmer overlay */
.fsc-team-card__whatsapp::after,
.fsc-team-card__instagram::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%);
  background-size: 200% 100%;
  background-position: -100% 0;
  transition: background-position 0.55s ease;
  border-radius: inherit;
}

.fsc-team-card__whatsapp:hover::after,
.fsc-team-card__instagram:hover::after {
  background-position: 200% 0;
}

/* WhatsApp */
.fsc-team-card__whatsapp {
  background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
  box-shadow: 0 5px 18px rgba(37,211,102,0.38);
}

.fsc-team-card__whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(37,211,102,0.55);
  color: #fff !important;
}

/* Instagram */
.fsc-team-card__instagram {
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #8134af 100%);
  box-shadow: 0 5px 18px rgba(221,42,123,0.38);
}

.fsc-team-card__instagram:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(221,42,123,0.55);
  color: #fff !important;
}

/* Icon inside buttons — force white + consistent size */
.fsc-team-card__whatsapp svg,
.fsc-team-card__instagram svg {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  fill: #fff;
  color: #fff;
  position: relative;
  z-index: 1;
}

/* Button label text above svg z-index */
.fsc-team-card__whatsapp span,
.fsc-team-card__instagram span {
  position: relative;
  z-index: 1;
}


/* Nav arrows */
.fsc-team-nav {
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid rgba(231,5,132,0.2);
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(231,5,132,0.12);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  z-index: 2;
  position: relative;
}

.fsc-team-nav svg {
  width: 18px;
  height: 18px;
}

.fsc-team-nav:hover {
  background: var(--brand-primary);
  color: #fff;
  transform: scale(1.1);
  box-shadow: 0 8px 22px rgba(231,5,132,0.3);
}

.fsc-team-nav--prev { margin-right: 10px; }
.fsc-team-nav--next { margin-left:  10px; }

/* Dots */
.fsc-team-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
}

.fsc-team-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(231,5,132,0.2);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background 0.2s ease, width 0.25s ease;
}

.fsc-team-dot.is-active {
  background: var(--brand-primary);
  width: 24px;
  border-radius: 999px;
}

/* Responsive */
@media (max-width: 1024px) {
  .fsc-team-card {
    flex: 0 0 calc(33.33% - 14px);
  }
}

@media (max-width: 767px) {
  .fsc-team-card {
    flex: 0 0 calc(50% - 10px);
  }

  .fsc-team-nav {
    width: 34px;
    height: 34px;
  }

  .fsc-team-nav--prev { margin-right: 6px; }
  .fsc-team-nav--next { margin-left:  6px; }
}

@media (max-width: 479px) {
  .fsc-team-card {
    flex: 0 0 calc(100% - 4px);
  }
}

/* ═══════════════════════════════════════════════════
   CUSTOM SITE FOOTER — fsc-footer
═══════════════════════════════════════════════════ */
.fsc-footer {
  background: #0b1220;
  color: #c8d8f0;
  font-family: "Manrope", sans-serif;
}

/* ── CTA Banner — floating overlap effect ─────── */
.fsc-footer-cta-wrap {
  /* Split: top half = last section bg, bottom half = dark footer */
  background: linear-gradient(to bottom, #faf9f6 50%, #141b2b 50%);
  padding: clamp(40px, 5.5vw, 64px) clamp(16px, 4vw, 40px);
  position: relative;
  z-index: 2;
}

.fsc-footer-cta {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 0;
  background: linear-gradient(130deg, #1a0d28 0%, #2a0b3a 40%, #141b2b 100%);
  border-radius: 22px;
  border: 1px solid rgba(231, 5, 132, 0.3);
  box-shadow:
    0 0 0 1px rgba(231, 5, 132, 0.1),
    0 32px 80px rgba(0, 0, 0, 0.55),
    0 8px 24px rgba(231, 5, 132, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  overflow: hidden;
  position: relative;
  z-index: 3;
}


/* LEFT card with shapes */
.fsc-footer-cta__card {
  position: relative;
  background: linear-gradient(145deg, #e70584 0%, #e30b86 45%, #e30b86 100%);
  overflow: hidden;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fsc-footer-cta__shapes {
  position: absolute;
  inset: 0;
}

/* SVG shape positioning */
.fsc-shape { position: absolute; }

.fsc-shape--arc {
  width: 220px;
  height: 220px;
  bottom: -30px;
  left: -30px;
}

.fsc-shape--ring {
  width: 90px;
  height: 90px;
  top: 18px;
  right: 18px;
  animation: fsc-footer-ring-spin 12s linear infinite;
}

@keyframes fsc-footer-ring-spin {
  to { transform: rotate(360deg); }
}

.fsc-shape--chevrons {
  width: 60px;
  top: 30%;
  left: 24px;
}

.fsc-shape--star {
  width: 26px;
  height: 26px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.fsc-shape--circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  bottom: 32px;
  right: 32px;
}

/* RIGHT content */
.fsc-footer-cta__content {
  padding: clamp(32px, 4vw, 52px) clamp(28px, 3.5vw, 56px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}

.fsc-footer-cta__eyebrow {
  display: inline-flex;
  width: fit-content;
  padding: 5px 14px;
  border-radius: 999px;
  background: rgba(231, 5, 132, 0.18);
  border: 1px solid rgba(231, 5, 132, 0.3);
  color: #f26cb5;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.fsc-footer-cta__title {
  font-family: "Noto Serif", Georgia, serif !important;
  font-size: clamp(26px, 3.2vw, 42px);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.fsc-footer-cta__desc {
  font-size: 15px;
  line-height: 1.65;
  color: #b0c4de;
  max-width: 480px;
  margin: 0;
}

.fsc-footer-cta__actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.fsc-footer-cta__btn {
  display: inline-flex;
  align-items: center;
  padding: 12px 26px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
  white-space: nowrap;
}

.fsc-footer-cta__btn--primary {
  background: linear-gradient(135deg, #f26cb5 0%, #e70584 100%);
  color: #fff !important;
  box-shadow: 0 8px 24px rgba(231, 5, 132, 0.4);
}

.fsc-footer-cta__btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(231, 5, 132, 0.55);
  color: #fff !important;
}

.fsc-footer-cta__btn--ghost {
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.25);
  color: #e2e8f0 !important;
}

.fsc-footer-cta__btn--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.45);
  color: #fff !important;
  transform: translateY(-2px);
}

/* ── Links Grid ───────────────────────────────── */
.fsc-footer-links-wrap {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  background: #141b2b;
  padding: clamp(40px, 5.5vw, 64px) clamp(16px, 4vw, 40px);
}

.fsc-footer-links-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr);
  gap: 32px 40px;
}

/* Brand column */
.fsc-footer-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  margin-bottom: 14px;
}

.fsc-footer-brand__logo {
  width: auto;
  max-height: 48px;
  display: block;
}

@media (max-width: 768px) {
  .fsc-footer-brand__logo {
    max-height: 40px;
  }
}

.fsc-footer-brand__text {
  font-family: "Noto Serif", Georgia, serif;
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: -0.01em;
}

.fsc-footer-brand:hover .fsc-footer-brand__text {
  color: #f26cb5;
}

.fsc-footer-brand__tagline {
  font-size: 13.5px;
  line-height: 1.65;
  color: #ffff;
  max-width: 280px;
  margin: 0 0 20px;
}

/* Social icons */
.fsc-footer-social {
  display: flex;
  align-items: center;
  gap: 10px;
}

.fsc-footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #8aa0bd !important;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.fsc-footer-social__link svg {
  width: 15px;
  height: 15px;
}

.fsc-footer-social__link:hover {
  background: rgba(231, 5, 132, 0.2);
  border-color: rgba(231, 5, 132, 0.35);
  color: #f26cb5 !important;
  box-shadow: 0 4px 16px rgba(231, 5, 132, 0.25);
  transform: translateY(-2px);
}

/* Link columns */
.fsc-footer-col__heading {
  font-family: "Manrope", sans-serif !important;
  font-size: 15px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #ffffff;
  margin: 0 0 16px;
}

.fsc-footer-col__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fsc-footer-col__list a {
  font-size: 14px;
  color: #ffff !important;
  text-decoration: none;
  transition: color 0.18s ease, padding-left 0.18s ease;
  display: inline-block;
}

.fsc-footer-col__list a:hover {
  color: #f26cb5 !important;
  padding-left: 4px;
}

/* ── Bottom Bar ───────────────────────────────── */
.fsc-footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  background: #070d18;
  padding: 18px clamp(16px, 4vw, 40px);
}

.fsc-footer-bottom__inner {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.fsc-footer-bottom__copy {
  font-size: 13px;
  color: #4a607a;
  margin: 0;
}

.fsc-footer-bottom__copy a {
  color: #6d84a0 !important;
  text-decoration: none;
}

.fsc-footer-bottom__copy a:hover {
  color: #f26cb5 !important;
}

.fsc-footer-bottom__legal {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fsc-footer-bottom__legal a {
  font-size: 13px;
  color: #4a607a !important;
  text-decoration: none;
  transition: color 0.18s ease;
}

.fsc-footer-bottom__legal a:hover {
  color: #f26cb5 !important;
}

.fsc-footer-bottom__legal span {
  color: #2a3a50;
  font-size: 12px;
}

/* ── Responsive ───────────────────────────────── */
@media (max-width: 1024px) {
  .fsc-footer-cta {
    grid-template-columns: 260px 1fr;
  }

  .fsc-footer-links-inner {
    grid-template-columns: 1fr 1fr;
    gap: 28px 32px;
  }

  .fsc-footer-col--brand {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 0 24px;
  }

  .fsc-footer-brand {
    grid-row: 1;
    grid-column: 1;
    align-self: start;
  }

  .fsc-footer-brand__tagline {
    grid-row: 1;
    grid-column: 2;
    max-width: 100%;
    align-self: center;
  }

  .fsc-footer-social {
    grid-row: 2;
    grid-column: 1 / -1;
    margin-top: 8px;
  }
}

@media (max-width: 768px) {
  .fsc-footer-cta {
    grid-template-columns: 1fr;
  }

  .fsc-footer-cta__card {
    min-height: 160px;
  }

  .fsc-footer-links-inner {
    grid-template-columns: 1fr 1fr;
  }

  .fsc-footer-col--brand {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 10px;
  }

  .fsc-footer-brand {
    grid-row: 1;
    grid-column: 1;
  }

  .fsc-footer-brand__tagline,
  .fsc-footer-social {
    grid-column: 1;
  }

  .fsc-footer-brand__tagline {
    grid-row: 2;
    margin: 0 0 8px;
  }

  .fsc-footer-social {
    grid-row: 3;
    margin-top: 0;
  }

  .fsc-footer-bottom__inner {
    flex-direction: column;
    text-align: center;
  }
}

@media (max-width: 479px) {
  .fsc-footer-links-inner {
    grid-template-columns: 1fr;
  }

  .fsc-footer-cta__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .fsc-footer-cta__btn {
    width: 100%;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════
   ABOUT PAGE — Find Us Here section
═══════════════════════════════════════════════════ */
.fsc-about-findus {
  padding: clamp(48px, 6vw, 72px) 0 clamp(32px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.fsc-about-findus .fsc-home-head {
  margin-bottom: 0;
}

/* ── Contact cards grid ────────────────────────── */
.fsc-findus-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.fsc-findus-card {
  background: #ffffff;
  border: 1px solid #f3e8f0;
  border-radius: 18px;
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 2px 16px rgba(231, 5, 132, 0.05);
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.fsc-findus-card:hover {
  box-shadow: 0 8px 32px rgba(231, 5, 132, 0.12);
  transform: translateY(-3px);
}

/* Icon circle */
.fsc-findus-card__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fce8f3 0%, #ffd6ed 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fsc-findus-card__icon svg {
  width: 22px;
  height: 22px;
  stroke: #e70584;
}

/* Card title */
.fsc-findus-card__title {
  font-family: "Noto Serif", Georgia, serif;
  font-size: 17px;
  font-weight: 700;
  color: #1a1a2e;
  margin: 0;
}

/* Info list */
.fsc-findus-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fsc-findus-card__list li {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.fsc-findus-card__label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #e70584;
}

.fsc-findus-card__list a,
.fsc-findus-card__list span:not(.fsc-findus-card__label) {
  font-size: 14px;
  color: #4b5563;
  line-height: 1.5;
  text-decoration: none;
  transition: color 0.18s ease;
}

.fsc-findus-card__list a:hover {
  color: #e70584;
}

/* ── Google Map ────────────────────────────────── */
.fsc-findus-map {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  border: 1px solid #f3e8f0;
}

.fsc-findus-map iframe {
  border-radius: 16px;
}

/* ── Responsive ────────────────────────────────── */
@media (max-width: 768px) {
  .fsc-findus-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 480px) and (max-width: 768px) {
  .fsc-findus-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── Disable Quick View button on product cards ── */
.quick-view-button,
.quick-view-icon,
.box-image .quick-view,
.product-image .quick-view,
.is-product-quick-view,
span.quick-view-button {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════
   PRODUCT REVIEWS — redesign to match brand palette
═══════════════════════════════════════════════════════ */

/* ── Tab label ──────────────────────────────────────── */
.woocommerce-tabs .reviews_tab a,
#tab-reviews h2.woocommerce-Reviews-title {
  font-family: "Noto Serif", Georgia, serif !important;
}

/* Section wrapper — cân lề, tránh form lệch một bên */
#reviews {
  padding: 0;
}

/* Đồng nhất container với phần thông tin/related trên single product */
body.single-product .woocommerce-tabs,
body.single-product #reviews {
  width: min(1240px, 92%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

#reviews.woocommerce-Reviews.row {
  justify-content: center;
}

/* Cột danh sách bình luận — ẩn khi chưa có review (template child không in nội dung) */
#reviews #comments.fsc-reviews-no-list {
  display: none !important;
}

/* Fallback nếu cache/plugin vẫn in .woocommerce-noreviews */
#reviews #comments .woocommerce-noreviews,
.woocommerce-Reviews .woocommerce-noreviews {
  display: none !important;
}

/* ── Review form wrapper — không thêm khung/thẻ (chỉ căn lề nội dung) ─ */
#review_form_wrapper {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 8px 0 0;
  box-shadow: none;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  box-sizing: border-box;
}

/* Cụm chọn sao — thoáng, căn trái rõ ràng */
#respond .comment-form-rating {
  margin-bottom: 20px;
}

#respond .comment-form-rating .stars,
#respond p.stars {
  display: block;
  margin: 10px 0 0;
  line-height: 1;
}

#respond .comment-form-rating .stars span,
#respond p.stars span {
  display: inline-block;
  vertical-align: middle;
}

#review_form_wrapper #respond,
#review_form_wrapper #review_form,
#review_form_wrapper .comment-respond {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Form title */
#review_form #reply-title,
#review_form_wrapper h3 {
  font-family: inherit !important;
  font-size: clamp(17px, 1.8vw, 19px);
  font-weight: 700;
  color: #1a1a2e;
  margin: 0 0 20px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Star rating ─────────────────────────────────────── */
#respond .comment-form-rating label {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #6b7280;
  margin-bottom: 8px;
  display: block;
}

/* Form chọn sao (p.stars) — hover/active (màu link, không ảnh hưởng ::before) */
.comment-form-rating .stars:hover a,
.comment-form-rating .stars.selected a.active,
.comment-form-rating .stars.selected a:not(.active) {
  color: #e70584 !important;
}

/*
 * Sao chọn điểm (p.stars a::before): WC dùng font + \e021 — dễ “mất” sao (chỉ vạch).
 * Thay bằng Unicode ☆/★ + màu cố định, giữ logic hover/selected của WooCommerce.
 */
.woocommerce #respond p.stars a,
#respond p.stars a {
  position: relative !important;
  display: inline-block !important;
  width: 1.35em !important;
  height: 1.35em !important;
  min-width: 1.35em !important;
  text-indent: -9999px !important;
  overflow: visible !important;
  vertical-align: middle !important;
}

.woocommerce #respond p.stars a::before,
#respond p.stars a::before {
  content: "\2606" !important;
  font-family: "Segoe UI Symbol", "Noto Sans Symbols", "Segoe UI Emoji", sans-serif !important;
  color: #9ca3af !important;
  font-size: 1.35rem !important;
  font-weight: 400 !important;
  line-height: 1.35em !important;
  text-align: center !important;
  text-indent: 0 !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

.woocommerce #respond p.stars:hover a::before,
#respond p.stars:hover a::before {
  content: "\2605" !important;
  color: #f472b6 !important;
}

.woocommerce #respond p.stars a:hover ~ a::before,
#respond p.stars a:hover ~ a::before {
  content: "\2606" !important;
  color: #d1d5db !important;
}

.woocommerce #respond p.stars.selected a.active::before,
#respond p.stars.selected a.active::before {
  content: "\2605" !important;
  color: #e70584 !important;
}

.woocommerce #respond p.stars.selected a:not(.active)::before,
#respond p.stars.selected a:not(.active)::before {
  content: "\2605" !important;
  color: #e70584 !important;
}

.woocommerce #respond p.stars.selected a.active ~ a::before,
#respond p.stars.selected a.active ~ a::before {
  content: "\2606" !important;
  color: #d1d5db !important;
}

/* ── Form labels ─────────────────────────────────────── */
#respond p label,
#respond .comment-form-comment label {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #6b7280;
  display: block;
  margin-bottom: 8px;
}

/* ── Textarea & inputs ───────────────────────────────── */
#respond textarea,
#respond input[type="text"],
#respond input[type="email"] {
  width: 100%;
  border: 1.5px solid #e5e7eb;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 14px;
  font-family: "Manrope", sans-serif;
  color: #1a1a2e;
  background: #fafafa;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  resize: vertical;
  box-sizing: border-box;
}

#respond textarea:focus,
#respond input[type="text"]:focus,
#respond input[type="email"]:focus {
  border-color: #e70584;
  box-shadow: 0 0 0 3px rgba(231, 5, 132, 0.08);
  background: #ffffff;
}

#respond textarea {
  min-height: 120px;
  margin-bottom: 16px;
}

/* Author / email fields inline on desktop */
#respond .comment-form-author,
#respond .comment-form-email {
  display: inline-block;
  width: 48%;
  margin-right: 2%;
  vertical-align: top;
}

#respond .comment-form-email {
  margin-right: 0;
}

/* ── Submit button ───────────────────────────────────── */
#respond .form-submit {
  text-align: center;
  margin-top: 8px;
}

#respond .form-submit #submit,
#respond input[type="submit"] {
  background: linear-gradient(135deg, #e70584 0%, #b8046a 100%) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 14px 40px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  cursor: pointer !important;
  transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
  box-shadow: 0 4px 16px rgba(231, 5, 132, 0.3) !important;
  min-width: min(100%, 260px) !important;
}

#respond input[type="submit"]:hover {
  opacity: 0.9 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 24px rgba(231, 5, 132, 0.4) !important;
}

/* Mobile: tránh form reviews sát mép màn hình */
@media (max-width: 767px) {
  body.single-product #tab-reviews,
  body.single-product .woocommerce-tabs .woocommerce-Tabs-panel#tab-reviews {
    padding-left: 16px !important;
    padding-right: 16px !important;
    box-sizing: border-box;
  }

  body.single-product #tab-reviews #review_form_wrapper {
    max-width: 100%;
    padding: 8px 0 0;
  }

  body.single-product .woocommerce-tabs {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* ── Existing review comments ────────────────────────── */
#reviews #comments ol.commentlist {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}

#reviews #comments ol.commentlist li.review {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 20px 0;
  margin-bottom: 0;
  border-bottom: 1px solid #ece8ee;
  display: flex;
  gap: 16px;
}

#reviews #comments ol.commentlist li.review img.avatar {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  border: 2px solid #f0c4de !important;
  flex-shrink: 0;
  object-fit: cover;
}

#reviews #comments ol.commentlist li.review .comment-text {
  flex: 1;
}

#reviews #comments ol.commentlist li.review .meta strong {
  font-size: 15px;
  font-weight: 700;
  color: #1a1a2e;
}

#reviews #comments ol.commentlist li.review .meta time {
  font-size: 12px;
  color: #9ca3af;
  margin-left: 8px;
}

#reviews #comments ol.commentlist li.review .star-rating {
  margin: 4px 0 8px;
  float: none !important;
  display: inline-block !important;
}

#reviews #comments ol.commentlist li.review:last-child {
  border-bottom: none;
}

/* Màu sao đầy: đã set ở block Unicode .star-rating span::before */

#reviews #comments ol.commentlist li.review .description p {
  font-size: 14px;
  color: #4b5563;
  line-height: 1.65;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE REDESIGN
═══════════════════════════════════════════════════════ */

/* Tiêu đề chính: dùng rule phía trên (clamp). Không set .product-title chung ở đây. */

/* Tóm tắt SP: căn chỉnh khối sao (nội dung sao = Unicode ở block trên) */
body.single-product .woocommerce-product-rating .star-rating,
body.single-product .product-info .woocommerce-product-rating .star-rating {
  float: none !important;
  display: inline-block !important;
  vertical-align: middle;
  margin: 0.2em 0 0.4em !important;
  position: relative !important;
  overflow: hidden !important;
  height: 1em !important;
  line-height: 1 !important;
  width: 5.4em !important;
  font-size: 1em !important;
}

body.single-product .woocommerce-product-rating .star-rating span {
  overflow: hidden !important;
  padding-top: 1.5em !important;
}

/* ── Product Price ──────────────────────────────────── */
.product-info .price-wrapper .price,
.product-info p.price {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: #e70584 !important;
  margin-bottom: 24px !important;
  display: block;
}
.product-info .price-wrapper .price del,
.product-info p.price del {
  font-size: 18px !important;
  color: #9ca3af !important;
  font-weight: 400 !important;
  margin-right: 8px;
}

/* ── Short Description ──────────────────────────────── */
.product-info .product-short-description {
  font-size: 15px !important;
  color: #4b5563 !important;
  line-height: 1.65 !important;
  margin-bottom: 28px !important;
}

.product-info .product-short-description strong {
  color: #1a1a2e;
}

/* ── Add to Cart Form & Button ─────────────────────── */
.product-info form.cart {
  margin-bottom: 32px !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.product-info form.cart button.button.single_add_to_cart_button {
  background: linear-gradient(135deg, #e70584 0%, #b8046a 100%) !important;
  color: #ffffff !important;
  border-radius: 50px !important;
  padding: 14px 36px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  border: none !important;
  box-shadow: 0 4px 16px rgba(231, 5, 132, 0.3) !important;
  transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
  height: auto !important;
  line-height: normal !important;
  flex: 1;
  min-width: 200px;
}

.product-info form.cart button.button.single_add_to_cart_button:hover {
  opacity: 0.9 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(231, 5, 132, 0.4) !important;
}

/* ── Quantity Input ────────────────────────────────── */
.product-info .quantity {
  margin: 0 !important;
}

.product-info .quantity input.qty {
  border-radius: 10px !important;
  border: 1.5px solid #e5e7eb !important;
  height: 50px !important;
  width: 65px !important;
  background: #fafafa !important;
  font-weight: 600 !important;
  color: #1a1a2e !important;
}

/* ── Product Images / Gallery ───────────────────────── */
.product-gallery-slider .product-image,
.product-gallery-slider img,
.product-gallery img {
  border-radius: 16px !important;
  overflow: hidden;
}

/* Ảnh chính trang chi tiết: bớt cao/dài, giữ layout cân đối */
@media (min-width: 1024px) {
  body.single-product .product-gallery-slider .product-image {
    aspect-ratio: 5 / 4;
    max-height: 500px;
  }

  body.single-product .product-gallery-slider .product-image img,
  body.single-product .woocommerce-product-gallery__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Flatsome/Flickity hay set height inline nên cần chặn để ảnh không bị quá cao */
  body.single-product .product-gallery-slider .flickity-viewport,
  body.single-product .woocommerce-product-gallery .flickity-viewport {
    max-height: 500px !important;
  }
}

.product-gallery {
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}

.product-thumbnails .col img {
  border-radius: 8px !important;
  border: 0 !important;
}

/* Thumbnail: đồng nhất kích thước khung ảnh */
body.single-product .product-thumbnails .col {
  flex: 0 0 120px !important;
  width: 120px !important;
  max-width: 120px !important;
}

body.single-product .product-thumbnails .col a {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 8px;
  border: 2px solid transparent;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.single-product .product-thumbnails .col img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

@media (max-width: 767px) {
  body.single-product .product-thumbnails .col {
    flex: 0 0 86px !important;
    width: 86px !important;
    max-width: 86px !important;
  }
}

body.single-product .product-thumbnails .col.is-nav-selected a {
  border-color: #e70584 !important;
  box-shadow: 0 2px 8px rgba(231,5,132,0.15);
}

/* ── Container Width Expansion ─────────────────────── */
.single-product .product-container > .product-main > .row {
  max-width: 1240px !important;
  width: 92% !important;
}

/* Giảm nhẹ kích thước khối ảnh ở desktop để cân với phần thông tin */
@media (min-width: 1024px) {
  body.single-product .product-main .woocommerce-product-gallery,
  body.single-product .product-main .product-gallery {
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ═══════════════════════════════════════════════════════
   SINGLE PRODUCT — Tab Reviews: form frame (sao p.stars → block Unicode phía trên)
═══════════════════════════════════════════════════════ */

/* Khung trong Flatsome (.has-border) — gỡ viền; template child đã bỏ class, giữ override cho cache cũ */
body.single-product #review_form .review-form-inner,
body.single-product #review_form .review-form-inner.has-border {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ═══════════════════════════════════════════════════════
   SINGLE PRODUCT — Related / Upsells: titles + slider
═══════════════════════════════════════════════════════ */

body.single-product .related .product-section-title,
body.single-product .upsells .product-section-title {
  font-family: "Noto Serif", Georgia, serif !important;
  font-size: clamp(20px, 2.4vw, 28px) !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  color: #5b4953 !important;
  text-align: center;
  margin-bottom: 20px !important;
}

/* (Cũ ul.products — giữ chỗ; clamp thật nằm ở block Flatsome div.product bên dưới file) */

/* Card cùng chiều cao trong slider Related */
body.single-product .related .slider.row-slider .flickity-slider > .col,
body.single-product .related .slider.row-slider .flickity-slider > li.product,
body.single-product .upsells .slider.row-slider .flickity-slider > .col,
body.single-product .upsells .slider.row-slider .flickity-slider > li.product {
  display: flex !important;
  align-items: stretch !important;
}

body.single-product .related .slider .col .col-inner,
body.single-product .upsells .slider .col .col-inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  width: 100% !important;
}

body.single-product .related .slider .col .box,
body.single-product .upsells .slider .col .box {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
}

body.single-product .related .slider .col .box-text,
body.single-product .upsells .slider .col .box-text {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}

body.single-product .related .slider .col .price-wrapper,
body.single-product .upsells .slider .col .price-wrapper {
  margin-top: auto !important;
}

body.single-product .related ul.products li.product .name strong,
body.single-product .related ul.products li.product .name a strong,
body.single-product .upsells ul.products li.product .name strong {
  color: inherit !important;
  font-weight: 700 !important;
}

body.single-product .related ul.products li.product .price,
body.single-product .related ul.products li.product .price .woocommerce-Price-amount,
body.single-product .upsells ul.products li.product .price,
body.single-product .upsells ul.products li.product .price .woocommerce-Price-amount {
  font-size: 15px !important;
  font-weight: 700 !important;
  margin-top: 0 !important;
  color: #e70584 !important;
}

body.single-product .related .product-label > span,
body.single-product .related .badge,
body.single-product .upsells .product-label > span {
  font-size: 10px !important;
  letter-spacing: 0.1em !important;
  font-weight: 800 !important;
}

/* Flickity arrows — related / upsells slider */
body.single-product .related .slider .flickity-prev-next-button,
body.single-product .upsells .slider .flickity-prev-next-button {
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.98) !important;
  box-shadow: 0 2px 14px rgba(15, 23, 42, 0.12) !important;
  border: 1px solid rgba(231, 5, 132, 0.22) !important;
  color: #8a185f !important;
  opacity: 1 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

body.single-product .related .slider .flickity-prev-next-button:hover,
body.single-product .upsells .slider .flickity-prev-next-button:hover {
  background: #ffffff !important;
  box-shadow: 0 4px 18px rgba(231, 5, 132, 0.2) !important;
  color: #e70584 !important;
}

body.single-product .related .slider .flickity-prev-next-button .flickity-button-icon,
body.single-product .upsells .slider .flickity-prev-next-button .flickity-button-icon,
body.single-product .related .slider .flickity-prev-next-button svg,
body.single-product .upsells .slider .flickity-prev-next-button svg,
body.single-product .related .slider .flickity-prev-next-button svg path,
body.single-product .upsells .slider .flickity-prev-next-button svg path,
body.single-product .related .slider .flickity-prev-next-button .arrow,
body.single-product .upsells .slider .flickity-prev-next-button .arrow {
  opacity: 0 !important;
}

/* Vẽ mũi tên thủ công để luôn nhìn rõ trên mọi bản Flatsome/Flickity */
body.single-product .related .slider .flickity-prev-next-button::before,
body.single-product .upsells .slider .flickity-prev-next-button::before {
  content: "›";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -52%);
  font-size: 30px;
  line-height: 1;
  font-weight: 700;
  color: #8a185f;
  opacity: 1 !important;
  pointer-events: none;
}

body.single-product .related .slider .flickity-prev-next-button.previous::before,
body.single-product .upsells .slider .flickity-prev-next-button.previous::before {
  content: "‹";
}

body.single-product .related .slider .flickity-prev-next-button:disabled::before,
body.single-product .upsells .slider .flickity-prev-next-button:disabled::before {
  opacity: 0.45 !important;
}

/* ═══════════════════════════════════════════════════════
   CUSTOM STYLES — Decrease Product Title & Equalize Cards Fix
═══════════════════════════════════════════════════════ */

/* Make Main Product Title Smaller */
body.single-product .product-info h1.product-title {
  font-size: clamp(20px, 2.5vw, 24px) !important;
  line-height: 1.35 !important;
  margin-bottom: 16px !important;
}

/* Force Related Products Cards to have Square Images for Equal Card Height */
body.single-product .related ul.products li.product .box-image,
body.single-product .related .slider .col .box-image,
body.single-product .upsells ul.products li.product .box-image,
body.single-product .upsells .slider .col .box-image {
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
  width: 100% !important;
  position: relative !important;
  overflow: hidden !important;
  padding-top: 0 !important;
}

body.single-product .related ul.products li.product .box-image .image-cover,
body.single-product .upsells ul.products li.product .box-image .image-cover {
  padding-top: 0 !important;
}

body.single-product .related ul.products li.product .box-image img,
body.single-product .related .slider .col .box-image img,
body.single-product .upsells ul.products li.product .box-image img,
body.single-product .upsells .slider .col .box-image img {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* ═══════════════════════════════════════════════════════
   FLATSOME RELATED / UPSELLS — đúng DOM (KHÔNG có ul.products)
   Row: .related > .row.slider > .product.product-small (div)
═══════════════════════════════════════════════════════ */

body.single-product .related .product.product-small .title-wrapper,
body.single-product .upsells .product.product-small .title-wrapper {
  flex-shrink: 0 !important;
  overflow: visible !important;
}

body.single-product .related .product.product-small p.woocommerce-loop-product__title,
body.single-product .upsells .product.product-small p.woocommerce-loop-product__title {
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
  font-weight: 600 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #1a1a2e !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  height: calc(1.4em * 2) !important;
  min-height: calc(1.4em * 2) !important;
  max-height: calc(1.4em * 2) !important;
  box-sizing: border-box !important;
}

body.single-product .related .product.product-small p.woocommerce-loop-product__title a,
body.single-product .upsells .product.product-small p.woocommerce-loop-product__title a {
  display: inline !important;
  color: inherit !important;
  text-decoration: none !important;
  font-weight: inherit !important;
}

body.single-product .related .slider .flickity-slider > .col,
body.single-product .upsells .slider .flickity-slider > .col {
  display: flex !important;
  align-items: stretch !important;
}

/* Desktop: canh giữa dãy card trong track (tránh dồn trái khi ít sản phẩm) */
@media (min-width: 1024px) {
  body.single-product .related .slider .flickity-slider,
  body.single-product .upsells .slider .flickity-slider {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    left: 0 !important;
  }
}

body.single-product .related .slider .col .col-inner,
body.single-product .upsells .slider .col .col-inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  width: 100% !important;
}

body.single-product .related .slider .product-small.box,
body.single-product .upsells .slider .product-small.box {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
}

body.single-product .related .slider .box-text,
body.single-product .upsells .slider .box-text {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  text-align: left !important;
  align-items: flex-start !important;
}

body.single-product .related .slider .price-wrapper,
body.single-product .upsells .slider .price-wrapper {
  margin-top: auto !important;
  justify-content: flex-start !important;
  text-align: left !important;
  width: 100% !important;
}

body.single-product .related .slider .product-small .name,
body.single-product .related .slider .product-small .woocommerce-loop-product__title,
body.single-product .upsells .slider .product-small .name,
body.single-product .upsells .slider .product-small .woocommerce-loop-product__title,
body.single-product .related .slider .product-small .price,
body.single-product .upsells .slider .product-small .price {
  text-align: left !important;
}

/* Cùng layout khi Related là grid (row) không có .slider */
body.single-product .related.related-products-wrapper .row:not(.slider) .col .col-inner,
body.single-product .upsells .row:not(.slider) .col .col-inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

body.single-product .related.related-products-wrapper .row:not(.slider) .price-wrapper,
body.single-product .upsells .row:not(.slider) .price-wrapper {
  margin-top: auto !important;
}

/* ═══════════════════════════════════════════════════════
   STRATEGIC PLAN PAGE — [fsc_strategic_plan]
═══════════════════════════════════════════════════════ */

.fsc-strategic-plan {
  --fsc-sp-blue: #6ec4e8;
  --fsc-sp-blue-deep: #4aa8d8;
  --fsc-sp-green: #9ccc3c;
  --fsc-sp-green-deep: #7cb518;
  --fsc-sp-purple: #b39ddb;
  --fsc-sp-purple-deep: #9575cd;
  --fsc-sp-text: #1a1a2e;
  --fsc-sp-muted: #64748b;
  --fsc-sp-surface: #f8fafc;
  padding: clamp(32px, 5vw, 72px) 16px 80px;
  background: #ffffff;
  border: none;
  box-shadow: none;
}

.fsc-strategic-plan .fsc-home-wrap {
  max-width: 920px;
  margin: 0 auto;
}

.fsc-strategic-plan__hero {
  text-align: center;
  margin-bottom: clamp(40px, 6vw, 72px);
}

.fsc-strategic-plan__title {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--fsc-sp-text);
  margin: 0 0 20px;
  line-height: 1.15;
}

.fsc-strategic-plan__lead {
  font-family: "Manrope", sans-serif;
  font-size: clamp(1rem, 1.35vw, 1.125rem);
  line-height: 1.75;
  color: var(--fsc-sp-muted);
  margin: 0 auto;
  max-width: 52ch;
}

.fsc-strategic-plan__block {
  margin-bottom: clamp(48px, 7vw, 80px);
}

.fsc-strategic-plan__subtitle {
  font-family: "Noto Serif", Georgia, serif;
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  font-style: italic;
  font-weight: 600;
  color: var(--fsc-sp-text);
  text-align: center;
  margin: 0 0 28px;
  letter-spacing: 0.01em;
}

.fsc-strategic-plan__purpose {
  font-family: "Manrope", sans-serif;
  font-size: clamp(1.125rem, 1.8vw, 1.35rem);
  line-height: 1.65;
  text-align: center;
  color: var(--fsc-sp-text);
  margin: 0 auto;
  max-width: 42em;
  font-weight: 500;
}

/* Focus — 3 cards */
.fsc-strategic-plan__focus-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 3vw, 28px);
  align-items: stretch;
}

@media (max-width: 900px) {
  .fsc-strategic-plan__focus-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin: 0 auto;
  }
}

.fsc-strategic-plan__focus-card {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  min-height: 140px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--fsc-sp-surface);
}

.fsc-strategic-plan__focus-num {
  flex: 0 0 4.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Manrope", sans-serif;
  font-size: clamp(2.5rem, 5vw, 3.25rem);
  font-weight: 800;
  line-height: 1;
  color: #ffffff;
}

.fsc-strategic-plan__focus-card.is-blue .fsc-strategic-plan__focus-num {
  background: linear-gradient(160deg, var(--fsc-sp-blue) 0%, var(--fsc-sp-blue-deep) 100%);
}

.fsc-strategic-plan__focus-card.is-green .fsc-strategic-plan__focus-num {
  background: linear-gradient(160deg, var(--fsc-sp-green) 0%, var(--fsc-sp-green-deep) 100%);
}

.fsc-strategic-plan__focus-card.is-purple .fsc-strategic-plan__focus-num {
  background: linear-gradient(160deg, var(--fsc-sp-purple) 0%, var(--fsc-sp-purple-deep) 100%);
}

.fsc-strategic-plan__focus-panel {
  flex: 1;
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
  border-right: 5px solid;
  background: #f1f5f9;
}

.fsc-strategic-plan__focus-card.is-blue .fsc-strategic-plan__focus-panel {
  border-right-color: var(--fsc-sp-blue-deep);
}

.fsc-strategic-plan__focus-card.is-green .fsc-strategic-plan__focus-panel {
  border-right-color: var(--fsc-sp-green-deep);
}

.fsc-strategic-plan__focus-card.is-purple .fsc-strategic-plan__focus-panel {
  border-right-color: var(--fsc-sp-purple-deep);
}

.fsc-strategic-plan__focus-label {
  font-family: "Manrope", sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--fsc-sp-text);
  margin: 0;
  line-height: 1.35;
}

.fsc-strategic-plan__focus-icon {
  color: var(--fsc-sp-muted);
  opacity: 0.92;
}

.fsc-strategic-plan__focus-icon svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Values bar */
.fsc-strategic-plan__values-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: center;
  gap: 16px;
  padding: 18px 24px;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  border-radius: 12px;
  border: 1px solid #e2e8f0;
}

.fsc-strategic-plan__values-bar span {
  font-family: "Manrope", sans-serif;
  font-size: clamp(0.95rem, 1.2vw, 1.05rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fsc-sp-text);
}

/* Priorities list */
.fsc-strategic-plan__priorities-intro {
  font-family: "Manrope", sans-serif;
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--fsc-sp-muted);
  text-align: center;
  max-width: 48em;
  margin: 0 auto 40px;
}

.fsc-strategic-plan__priority-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.fsc-strategic-plan__priority-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 0;
}

.fsc-strategic-plan__priority-num {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Manrope", sans-serif;
  font-size: 1.65rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
}

.fsc-strategic-plan__priority-item.is-blue .fsc-strategic-plan__priority-num {
  background: linear-gradient(145deg, var(--fsc-sp-blue), var(--fsc-sp-blue-deep));
}

.fsc-strategic-plan__priority-item.is-green .fsc-strategic-plan__priority-num {
  background: linear-gradient(145deg, var(--fsc-sp-green), var(--fsc-sp-green-deep));
}

.fsc-strategic-plan__priority-item.is-purple .fsc-strategic-plan__priority-num {
  background: linear-gradient(145deg, var(--fsc-sp-purple), var(--fsc-sp-purple-deep));
}

.fsc-strategic-plan__priority-body {
  flex: 1;
  padding-top: 2px;
}

.fsc-strategic-plan__priority-title {
  font-family: "Manrope", sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--fsc-sp-text);
  margin: 0 0 10px;
  line-height: 1.3;
}

.fsc-strategic-plan__priority-body p {
  font-family: "Manrope", sans-serif;
  font-size: 0.98rem;
  line-height: 1.7;
  color: var(--fsc-sp-muted);
  margin: 0;
}

@media (max-width: 600px) {
  .fsc-strategic-plan__priority-item {
    flex-direction: column;
    gap: 12px;
  }

  .fsc-strategic-plan__values-bar {
    flex-direction: column;
    text-align: center;
  }
}

/* ═══════════════════════════════════════════════════════
   MEMBERSHIP REQUIREMENTS — [fsc_membership_requirements]
═══════════════════════════════════════════════════════ */

.fsc-membership-req {
  --fsc-mr-accent: #e70584;
  --fsc-mr-text: #1a1a2e;
  --fsc-mr-muted: #475569;
  --fsc-mr-line: #e2e8f0;
  --fsc-mr-soft: #f8fafc;
  padding: clamp(32px, 5vw, 72px) 16px 80px;
  background: #ffffff;
}

.fsc-membership-req .fsc-home-wrap {
  max-width: 800px;
  margin: 0 auto;
}

.fsc-membership-req__hero {
  margin-bottom: clamp(40px, 6vw, 56px);
  padding-bottom: clamp(28px, 4vw, 40px);
  border-bottom: 1px solid var(--fsc-mr-line);
}

.fsc-membership-req__title {
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.85rem, 3.5vw, 2.35rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--fsc-mr-text);
  margin: 0 0 24px;
  line-height: 1.2;
}

.fsc-membership-req__intro p,
.fsc-membership-req__prose p {
  font-family: "Manrope", sans-serif;
  font-size: 1.02rem;
  line-height: 1.78;
  color: var(--fsc-mr-muted);
  margin: 0 0 1.15em;
}

.fsc-membership-req__intro p:last-child {
  margin-bottom: 0;
}

.fsc-membership-req__tiers {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: clamp(40px, 5vw, 56px);
}

.fsc-membership-req__card {
  border-radius: 14px;
  overflow: hidden;
  background: var(--fsc-mr-soft);
  border: 1px solid var(--fsc-mr-line);
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.04);
}

.fsc-membership-req__card-title {
  font-family: "Noto Serif", Georgia, serif;
  font-size: 1.2rem;
  font-weight: 700;
  font-style: italic;
  margin: 0;
  padding: 16px 22px 12px;
  color: #fff;
  letter-spacing: 0.02em;
}

.fsc-membership-req__card--affiliate .fsc-membership-req__card-title {
  background: linear-gradient(135deg, #64748b 0%, #475569 100%);
}

.fsc-membership-req__card--associate .fsc-membership-req__card-title {
  background: linear-gradient(135deg, #6ec4e8 0%, #38a0d6 100%);
}

.fsc-membership-req__card--cera .fsc-membership-req__card-title {
  background: linear-gradient(135deg, #b39ddb 0%, #9575cd 100%);
}

.fsc-membership-req__card--fellow .fsc-membership-req__card-title {
  background: linear-gradient(135deg, #e70584 0%, #b8046a 100%);
}

.fsc-membership-req__card-body {
  padding: 20px 22px 22px;
}

.fsc-membership-req__card-body p {
  font-family: "Manrope", sans-serif;
  font-size: 0.98rem;
  line-height: 1.78;
  color: var(--fsc-mr-text);
  margin: 0;
}

.fsc-membership-req__section {
  margin-bottom: clamp(36px, 5vw, 48px);
}

.fsc-membership-req__section-title {
  font-family: "Noto Serif", Georgia, serif;
  font-size: clamp(1.25rem, 2vw, 1.45rem);
  font-weight: 700;
  font-style: italic;
  color: var(--fsc-mr-text);
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid rgba(231, 5, 132, 0.25);
}

.fsc-membership-req__prose p:last-child {
  margin-bottom: 0;
}

.fsc-membership-req__section--benefits {
  padding: 28px 24px 32px;
  background: linear-gradient(180deg, #fdf5fa 0%, #ffffff 55%);
  border-radius: 16px;
  border: 1px solid #fce7f3;
}

.fsc-membership-req__benefits-lead {
  font-family: "Manrope", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--fsc-mr-text);
  margin: 0 0 18px;
}

.fsc-membership-req__benefits-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.fsc-membership-req__benefits-list li {
  font-family: "Manrope", sans-serif;
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--fsc-mr-muted);
  padding: 14px 0 14px 2rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  position: relative;
}

.fsc-membership-req__benefits-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.fsc-membership-req__benefits-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.15rem;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #e70584, #f472b6);
  box-shadow: 0 0 0 3px rgba(231, 5, 132, 0.15);
}

.fsc-membership-req__footer {
  margin-top: 40px;
  padding: 22px 24px;
  text-align: center;
  background: var(--fsc-mr-soft);
  border-radius: 12px;
  border: 1px solid var(--fsc-mr-line);
}

.fsc-membership-req__footer p {
  font-family: "Manrope", sans-serif;
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--fsc-mr-muted);
  margin: 0;
}

.fsc-membership-req__footer a {
  color: var(--fsc-mr-accent);
  font-weight: 700;
  text-decoration: none;
}

.fsc-membership-req__footer a:hover {
  text-decoration: underline;
}

/* ===== Dark Theme Footer (#313731) ===== */
#footer,
#footer .footer-wrapper,
#footer .footer-1,
#footer .footer-2,
#footer .footer-widgets,
#footer .section,
.absolute-footer {
  background-color: #313731 !important;
  background-image: none !important;
  color: #e0e0e0 !important;
}

#footer > .bg,
#footer .bg {
  background-color: transparent !important;
  background-image: none !important;
}

#footer {
  border-top: 1px solid rgba(255,255,255,0.05) !important;
}

.absolute-footer {
  background-color: #2b302b !important; /* Slightly darker than main footer */
  border-top: 1px solid rgba(255,255,255,0.05) !important;
  color: #ccc !important;
}

/* Footer text & links */
#footer p, #footer li, #footer div, #footer span,
.absolute-footer p, .absolute-footer div, .absolute-footer span {
  color: #e0e0e0 !important;
}

#footer a,
.absolute-footer a {
  color: #fff !important;
  transition: color 0.2s ease;
}

#footer a:hover,
.absolute-footer a:hover {
  color: var(--brand-primary) !important;
}

/* Footer headings */
#footer .widget-title,
#footer h1, #footer h2, #footer h3, #footer h4, #footer h5, #footer h6 {
  color: #fff !important;
  font-weight: 700 !important;
}

/* Fix social icons in footer */
#footer .social-icons a,
.absolute-footer .social-icons a {
  color: #fff !important;
  border-color: rgba(255,255,255,0.2) !important;
}
#footer .social-icons a:hover,
.absolute-footer .social-icons a:hover {
  background-color: var(--brand-primary) !important;
  color: #fff !important;
  border-color: var(--brand-primary) !important;
}

/* ═══════════════════════════════════════════════════════
   VIDEO PAGE — [fsc_video_page]
═══════════════════════════════════════════════════════ */
.fsc-video-page {
  padding: clamp(36px, 5vw, 72px) 16px;
  background:
    radial-gradient(900px 360px at 100% 0%, rgba(231, 5, 132, 0.08), transparent 70%),
    linear-gradient(180deg, #fffafe 0%, #ffffff 100%);
}

.fsc-video-page .fsc-home-wrap {
  max-width: 1180px;
  margin: 0 auto;
}

.fsc-home-head--center {
  text-align: center;
  align-items: center;
  margin-bottom: clamp(24px, 4vw, 40px);
}

.fsc-video-page__lead {
  margin: 10px auto 0;
  max-width: 620px;
  color: #6b7280;
  font-size: 15px;
  line-height: 1.7;
}

.fsc-video-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 24px);
}

.fsc-video-card {
  background: #fff;
  border: 1px solid rgba(231, 5, 132, 0.18);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08), 0 2px 8px rgba(231, 5, 132, 0.06);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.fsc-video-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.12), 0 4px 12px rgba(231, 5, 132, 0.12);
}

.fsc-video-card__frame {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #0f0f14;
  overflow: hidden;
}

.fsc-video-card__frame iframe,
.fsc-video-card__frame video,
.fsc-video-card__frame embed,
.fsc-video-card__frame object {
  width: 100% !important;
  height: 100% !important;
  border: 0;
  display: block;
}

.fsc-video-card__body {
  padding: 14px 14px 16px;
}

.fsc-video-card__label {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-primary);
  background: rgba(231, 5, 132, 0.08);
  border: 1px solid rgba(231, 5, 132, 0.15);
  border-radius: 99px;
  padding: 4px 9px;
  margin-bottom: 8px;
}

.fsc-video-card__title {
  margin: 0 0 6px;
  font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.35;
  color: #23121a;
}

.fsc-video-card__text {
  margin: 0;
  color: #6b7280;
  font-size: 14px;
  line-height: 1.65;
}

.fsc-video-empty {
  margin: 0 auto;
  max-width: 620px;
  text-align: center;
  border: 1px dashed rgba(231, 5, 132, 0.35);
  border-radius: 14px;
  padding: 22px 16px;
  background: #fff;
  color: #6b7280;
}

@media (max-width: 1024px) {
  .fsc-video-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .fsc-video-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .fsc-video-card__title {
    font-size: 17px;
  }
}
