
    /* ===== sec_ncc – reset & base ===== */
    .sec_ncc *, .sec_ncc *::before, .sec_ncc *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }
 
    /* ===== sec_ncc – section wrapper ===== */
    .sec_ncc {
      background-color: #ffffff;
      padding: 80px 24px;
    }
 
    .sec_ncc__container {
      margin: 0 auto;
    }
 
    /* ===== sec_ncc – header ===== */
    .sec_ncc__header {
      text-align: center;
      margin-bottom: 48px;
    }
 
    .sec_ncc__eyebrow {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      margin-bottom: 20px;
    }
 
    .sec_ncc__eyebrow-line {
      display: block;
      height: 1px;
      width: 40px;
      background-color: #c9a84c;
    }
 
    .sec_ncc__eyebrow-text {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.3em;
      color: #c9a84c;
      text-transform: uppercase;
    }
 
    .sec_ncc__title {
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 700;
      letter-spacing: -0.01em;
      color: #1a1a1a;
      line-height: 1.1;
    }
 
    .sec_ncc__subtitle {
      margin-top: 20px;
      font-size: 15px;
      color: #7a7060;
      max-width: 640px;
      margin-left: auto;
      margin-right: auto;
      line-height: 1.7;
    }
 
    /* ===== sec_ncc – brands wrapper ===== */
    .sec_ncc__brands-wrap {
      position: relative;
      display: flex;
      align-items: center;
      gap: 12px;
    }
 
    /* ===== sec_ncc – brand grid ===== */
    .sec_ncc__brand-grid {
      flex: 1;
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
      padding-bottom: 16px;
      overflow: visible;
    }
 
    @media (min-width: 640px) {
      .sec_ncc__brand-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }
 
    @media (min-width: 1024px) {
      .sec_ncc__brand-grid {
        grid-template-columns: repeat(6, 1fr);
      }
    }
 
    /* ===== sec_ncc – brand card 2-line label ===== */
    .sec_ncc__brand-name {
      font-size: 16px;
      font-weight: 700;
      letter-spacing: 0.1em;
      color: #3a2510;
      text-align: center;
      line-height: 1.2;
    }
 
    .sec_ncc__brand-country {
      font-size: 15px;
      letter-spacing: 0.05em;
      color: #7a7060;
      margin-top: 6px;
      text-align: center;
      line-height: 0;
    }
 
    /* active overrides */
    .sec_ncc__brand-card--active .sec_ncc__brand-name,
    .sec_ncc__brand-card--active .sec_ncc__brand-country {
      color: #ffffff !important;
    }
 
    /* ===== sec_ncc – brand card ===== */
    .sec_ncc__brand-card {
      position: relative;
      height: 128px;
      border-radius: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 12px;
      border: none;
      cursor: pointer;
      transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
      background: #ffffff;
      box-shadow: 0 2px 12px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.05);
    }
 
    .sec_ncc__brand-card:hover {
      transform: translateY(-2px);
    }
 
    /* hidden card (index >= 6) */
    .sec_ncc__brand-card--hidden {
      display: none;
    }
 
    /* active card */
    .sec_ncc__brand-card--active {
      background: #5c3d1e;
      color: #ffffff;
      box-shadow: 0 8px 24px rgba(92,61,30,0.35);
      transform: translateY(-4px);
    }
 
    .sec_ncc__brand-card--active *,
    .sec_ncc__brand-card--active span,
    .sec_ncc__brand-card--active div {
      color: #ffffff !important;
    }
 
    .sec_ncc__brand-card--active::after {
      content: '';
      position: absolute;
      bottom: -8px;
      left: 50%;
      transform: translateX(-50%) rotate(45deg);
      width: 16px;
      height: 16px;
      background: #5c3d1e;
    }
 
    .sec_ncc__brand-card--active::before {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: 16px;
      /* box-shadow: inset 0 0 0 1px rgba(201,168,76,0.4); */
      pointer-events: none;
    }
    .add-to-cart-button a {
        color: #fff;
    }
    /* ===== sec_ncc – nav buttons ===== */
    .sec_ncc__nav-btn {
      display: none;
      flex-shrink: 0;
      height: 48px;
      width: 48px;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: #ffffff;
      box-shadow: 0 2px 12px rgba(0,0,0,0.1);
      border: none;
      cursor: pointer;
      color: #5c3d1e;
      transition: background 0.2s ease, opacity 0.2s ease;
      padding: 0;
    }
 
    .sec_ncc__nav-btn:hover {
      background: #f5efe6;
    }
 
    .sec_ncc__nav-btn:disabled {
      opacity: 0.3;
      cursor: default;
    }
 
    /* hiện nút khi cần (có >6 items) */
    .sec_ncc__brands-wrap.sec_ncc--has-more .sec_ncc__nav-btn {
      display: flex;
    }
 
    /* ===== sec_ncc – brand inner layouts ===== */
    .sec_ncc__brand-inner {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0px;
    }
 
    /* Drago */
    .sec_ncc__brand-drago-name {
      font-size: 20px;
      letter-spacing: 0.1em;
      color: #5c3d1e;
    }
    .sec_ncc__brand-drago-sub {
      font-size: 8px;
      letter-spacing: 0.25em;
      color: rgba(92,61,30,0.7);
      text-transform: uppercase;
      margin-top: 2px;
      text-align: center;
    }
 
    /* Huddersfield */
    .sec_ncc__brand-hud-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #7a1f1f;
    }
    .sec_ncc__brand-hud-icon { font-size: 26px; }
    .sec_ncc__brand-hud-name {
      font-size: 9px;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      margin-top: 4px;
      text-align: center;
    }
 
    /* Cerruti */
    .sec_ncc__brand-cerruti-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #5c3d1e;
    }
    .sec_ncc__brand-cerruti-crown { font-size: 18px; }
    .sec_ncc__brand-cerruti-label {
      font-size: 7px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      margin-top: 2px;
    }
    .sec_ncc__brand-cerruti-name {
      font-size: 13px;
      letter-spacing: 0.1em;
    }
    .sec_ncc__brand-cerruti-year {
      font-size: 7px;
      letter-spacing: 0.2em;
    }
 
    /* Holland & Sherry */
    .sec_ncc__brand-hs-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #5c3d1e;
    }
    .sec_ncc__brand-hs-name {
      font-size: 11px;
      letter-spacing: 0.08em;
      text-align: center;
    }
    .sec_ncc__brand-hs-sub {
      font-size: 7px;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      margin-top: 4px;
      text-align: center;
    }
 
    /* Scabal */
    .sec_ncc__brand-scabal-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #1a2a5a;
    }
    .sec_ncc__brand-scabal-crown { font-size: 18px; }
    .sec_ncc__brand-scabal-name {
      font-size: 17px;
      font-weight: 700;
      letter-spacing: 0.2em;
      margin-top: 4px;
    }
    .sec_ncc__brand-scabal-sub {
      font-size: 7px;
      letter-spacing: 0.25em;
      text-transform: uppercase;
    }
 
    /* VBC */
    .sec_ncc__brand-vbc-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 6px;
    }
    .sec_ncc__brand-vbc-inner {
      display: flex;
      flex-direction: column;
      align-items: center;
    }
    .sec_ncc__brand-vbc-star { font-size: 11px; color: #ffffff; }
    .sec_ncc__brand-vbc-full {
      font-size: 8px;
      letter-spacing: 0.1em;
      margin-top: 2px;
      color: #ffffff;
      text-align: center;
    }
    .sec_ncc__brand-vbc-year {
      font-size: 10px;
      letter-spacing: 0.3em;
      color: #ffffff;
    }
    .sec_ncc__brand-vbc-short {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.2em;
      color: #ffffff;
    }
 
    /* Loro Piana */
    .sec_ncc__brand-lp-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #2c2c2c;
    }
    .sec_ncc__brand-lp-icon { font-size: 16px; }
    .sec_ncc__brand-lp-name {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      margin-top: 4px;
      text-align: center;
    }
    .sec_ncc__brand-lp-sub {
      font-size: 7px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      margin-top: 3px;
      color: rgba(44,44,44,0.6);
    }
 
    /* Dormeuil */
    .sec_ncc__brand-dm-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #1c3a5e;
    }
    .sec_ncc__brand-dm-icon { font-size: 18px; }
    .sec_ncc__brand-dm-name {
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.15em;
      margin-top: 4px;
    }
    .sec_ncc__brand-dm-sub {
      font-size: 7px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      margin-top: 3px;
      color: rgba(28,58,94,0.65);
    }
 
    /* ===== sec_ncc – featured block ===== */
    .sec_ncc__featured {
      margin-top: 48px;
      border-radius: 24px;
      background: rgba(245,239,230,0.7);
      padding: 32px;
      box-shadow: 0 2px 12px rgba(0,0,0,0.08);
      transition: opacity 0.25s ease;
    }
 
    .sec_ncc__featured.sec_ncc--fading {
      opacity: 0;
    }
 
    @media (min-width: 768px) {
      .sec_ncc__featured { padding: 48px; }
    }
 
    .sec_ncc__featured-grid {
      display: grid;
      gap: 40px;
      align-items: center;
    }
 
    @media (min-width: 1024px) {
      .sec_ncc__featured-grid {
        grid-template-columns: 1fr 1fr;
      }
    }
 
    /* ===== sec_ncc – featured text ===== */
    .sec_ncc__feat-eyebrow {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: #c9a84c;
    }
 
    .sec_ncc__feat-title {
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 700;
      color: #1a1a1a;
      margin-top: 0px;
    }
 
    .sec_ncc__feat-origin {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 14px;
      font-weight: 700;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: #1a1a1a;
      margin-top: 16px;
    }
 
    .sec_ncc__feat-origin-flag { font-size: 18px; }
 
    .sec_ncc__feat-desc {
      font-size: 15px;
      color: #7a7060;
      line-height: 1.7;
      max-width: 400px;
      margin-top: 24px;
    }
 
    .sec_ncc__feat-items {
      display: flex;
      flex-wrap: wrap;
      gap: 24px;
      margin-top: 32px;
    }
 
    .sec_ncc__feat-item {
      display: flex;
      align-items: center;
      gap: 12px;
    }
 
    .sec_ncc__feat-icon {
      height: 44px;
      width: 44px;
      border-radius: 50%;
      background: rgba(201,168,76,0.15);
      display: flex;
      align-items: center;
      justify-content: center;
      color: #c9a84c;
      flex-shrink: 0;
    }
 
    .sec_ncc__feat-icon svg { width: 20px; height: 20px; }
 
    .sec_ncc__feat-item-title {
      font-size: 16px;
      font-weight: 600;
      color: #1a1a1a;
    }
 
    .sec_ncc__feat-item-sub {
      font-size: 12px;
      color: #7a7060;
      margin-top: 2px;
    }
 
    /* ===== sec_ncc – CTA ===== */
    .sec_ncc__cta {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      border-radius: 12px;
      background: #1a1a1a;
      padding: 16px 24px;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: #ffffff;
      border: none;
      cursor: pointer;
      transition: opacity 0.2s ease;
      margin-top: 40px;
      text-decoration: none;
    }
 
    .sec_ncc__cta:hover { opacity: 0.88; }
    .sec_ncc__cta svg { width: 16px; height: 16px; }
 
    /* ===== sec_ncc – featured visual ===== */
    .sec_ncc__feat-visual {
      position: relative;
      aspect-ratio: 4 / 3;
      border-radius: 16px;
      background: #2e1a0e;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      /* box-shadow: 0 8px 24px rgba(46,26,14,0.35); */
      overflow: hidden;
    }
 
    /* ảnh nền thương hiệu */
    .sec_ncc__feat-visual-img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      transition: opacity 0.4s ease;
    }
 
    /* lớp tối phủ lên ảnh để chữ dễ đọc */
    .sec_ncc__feat-visual-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.15) 0%,
        rgba(0,0,0,0.45) 60%,
        rgba(0,0,0,0.70) 100%
      );
      z-index: 1;
    }
 
    .sec_ncc__feat-visual-content {
      position: relative;
      z-index: 2;
      display: flex;
      flex-direction: column;
      align-items: center;
      color: #ffffff;
    }
 
    .sec_ncc__feat-visual-star { font-size: 22px; }
 
    .sec_ncc__feat-visual-name {
      font-size: 20px;
      letter-spacing: 0.1em;
      margin-top: 8px;
    }
 
    .sec_ncc__feat-visual-year {
      font-size: 17px;
      letter-spacing: 0.4em;
      margin-top: 8px;
    }
 
    .sec_ncc__feat-visual-caption {
      position: absolute;
      bottom: 32px;
      right: 40px;
      z-index: 2;
      font-style: italic;
      font-size: 13px;
      color: rgba(255,255,255,0.8);
    }