/* ==============================================
   CALIHASH PRODUCT CSS
   Brand layer for CaliHash client site.
   Built on the AiPhlo template base.
   
   Prefix: ch-
   Brand tokens: --gold, --cream, --green, --black, --white
   Fonts: Bebas Neue (display), Inter (body)
   
   DO NOT mix with accurate.css / pages.css.
   This file is calihash-specific only.
   ============================================== */

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --black: #0a0a0a;
      --white: #ffffff;
      --cream: #f5f0e8;
      --gold: #c9a84c;
      --green: #2d4a2d;
      --gray: #888;
      --font-display: 'Bebas Neue', sans-serif;
      --font-body: 'Inter', sans-serif;
    }

    html { scroll-behavior: smooth; }
    body { background: var(--black); color: var(--white); font-family: var(--font-body); overflow-x: hidden; }

    /* ============ PHANTOM NAV TRIGGER ============ */
    #ch-nav-trigger {
      position: fixed;
      top: 22px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 99999;
      cursor: pointer;
      text-align: center;
      transition: transform 0.3s ease;
    }

    #ch-nav-trigger img {
      height: 84px;
      width: auto;
      max-width: 100px;
      display: block;
      margin: 0 auto 4px;
      object-fit: contain;
      transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), filter 0.25s ease;
      filter: drop-shadow(0 2px 8px rgba(201, 168, 76, 0));
    }

    #ch-nav-trigger:hover img,
    #ch-nav-trigger.ch-active img {
      transform: scale(1.08);
      filter: drop-shadow(0 4px 16px rgba(201, 168, 76, 0.5));
    }

    #ch-nav-trigger span {
      color: var(--gold);
      font-family: var(--font-body);
      font-size: 8px;
      font-weight: 600;
      letter-spacing: 3.5px;
      text-transform: uppercase;
      display: inline-block;
      opacity: 0.7;
      transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.2s;
    }

    #ch-nav-trigger:hover span,
    #ch-nav-trigger.ch-active span {
      opacity: 1;
      transform: translateY(2px);
    }

    /* ============ PHANTOM NAV DROPDOWN ============ */
    #ch-nav-dropdown {
      position: fixed;
      top: 148px;
      left: 50%;
      transform: translateX(-50%) translateY(-14px);
      z-index: 999999;
      background: #0d0d0d;
      border: 1px solid rgba(201, 168, 76, 0.2);
      padding: 20px 36px 18px;
      min-width: 150px;
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      transition: opacity 0.25s ease, transform 0.5s cubic-bezier(0.16, 0.84, 0.44, 1), box-shadow 0.4s ease;
      box-shadow: 0 24px 60px rgba(0, 0, 0, 0.7);
    }

    #ch-nav-dropdown.ch-visible {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
      transform: translateX(-50%) translateY(0);
      box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6), 0 0 32px rgba(201, 168, 76, 0.07);
    }

    .ch-dropdown-arrow {
      position: absolute;
      top: -16px;
      left: 50%;
      transform: translateX(-50%) translateY(18px);
      width: 0;
      height: 0;
      border-left: 9px solid transparent;
      border-right: 9px solid transparent;
      border-bottom: 9px solid rgba(201, 168, 76, 0.25);
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.3s ease 0.35s, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) 0.35s;
    }

    .ch-dropdown-arrow::after {
      content: '';
      position: absolute;
      top: 2px;
      left: -9px;
      width: 0;
      height: 0;
      border-left: 9px solid transparent;
      border-right: 9px solid transparent;
      border-bottom: 9px solid #0d0d0d;
    }

    #ch-nav-dropdown.ch-visible .ch-dropdown-arrow {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }

    #ch-nav-dropdown a {
      display: block;
      padding: 9px 0;
      color: rgba(255, 255, 255, 0.75);
      text-decoration: none;
      font-family: var(--font-body);
      font-size: 11px;
      font-weight: 400;
      letter-spacing: 3px;
      text-transform: uppercase;
      border-bottom: 1px solid rgba(201, 168, 76, 0.1);
      transition: color 0.2s ease, transform 0.2s ease, letter-spacing 0.2s ease;
      white-space: nowrap;
    }

    #ch-nav-dropdown a:last-child { border-bottom: none; padding-bottom: 4px; }

    #ch-nav-dropdown a:hover {
      color: var(--gold);
      transform: translateX(4px);
      letter-spacing: 4px;
    }

    /* ============ HERO ============ */
    .ch-hero {
      position: relative;
      width: 100%;
      height: 100vh;
      height: 100dvh; /* dynamic viewport — fixes Safari address bar jank */
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .ch-hero-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    .ch-hero-fallback {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
    }

    @keyframes kenBurns {
      from { transform: scale(1.0); }
      to   { transform: scale(1.08); }
    }

    .ch-hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.3) 0%,
        rgba(0,0,0,0.15) 40%,
        rgba(0,0,0,0.6) 100%
      );
      z-index: 1;
    }

    .ch-hero-content {
      position: relative;
      z-index: 2;
      text-align: center;
      padding: 0 24px;
    }

    .ch-hero-title {
      font-family: var(--font-display);
      font-size: clamp(80px, 15vw, 180px);
      letter-spacing: 8px;
      line-height: 0.9;
      color: var(--white);
      text-shadow: 0 2px 40px rgba(0,0,0,0.4);
    }

    #ch-hero-particle-canvas {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      pointer-events: none;
      z-index: 10;
    }

    .ch-hero-tagline {
      font-size: 12px;
      letter-spacing: 6px;
      text-transform: uppercase;
      color: var(--cream);
      margin-top: 20px;
      opacity: 0.9;
    }

    .ch-hero-scroll {
      position: absolute;
      bottom: 40px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 2;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      cursor: pointer;
    }

    .ch-hero-scroll span {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.6);
    }

    .ch-scroll-line {
      width: 1px;
      height: 40px;
      background: rgba(255,255,255,0.4);
      animation: scrollPulse 2s ease-in-out infinite;
    }

    @keyframes scrollPulse {
      0%, 100% { opacity: 0.4; transform: scaleY(1); }
      50% { opacity: 1; transform: scaleY(0.6); }
    }

    /* ============ SOUND TOGGLE ============ */
    .ch-sound-toggle {
      background: none;
      border: none;
      cursor: pointer;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 5px;
      padding: 6px 14px;
      margin: 20px auto 0;
      border-radius: 20px;
      opacity: 0.5;
      transition: opacity 0.3s ease;
    }
    .ch-sound-toggle:hover { opacity: 1; }
    .ch-sound-toggle svg {
      width: 22px;
      height: 16px;
      display: block;
    }
    .ch-sound-toggle svg rect {
      fill: var(--cream);
      transition: fill 0.3s ease;
    }
    .ch-sound-toggle .ch-sound-label {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.55);
      transition: color 0.3s ease;
    }
    .ch-sound-toggle.active { opacity: 0.85; }
    .ch-sound-toggle.active svg rect { fill: var(--gold); }
    .ch-sound-toggle.active .ch-sound-label { color: var(--gold); }
    .ch-sound-toggle.active .bar1 { animation: soundBar 0.9s ease-in-out infinite; }
    .ch-sound-toggle.active .bar2 { animation: soundBar 0.9s ease-in-out 0.15s infinite; }
    .ch-sound-toggle.active .bar3 { animation: soundBar 0.9s ease-in-out 0.05s infinite; }
    .ch-sound-toggle.active .bar4 { animation: soundBar 0.9s ease-in-out 0.22s infinite; }
    .ch-sound-toggle.active .bar5 { animation: soundBar 0.9s ease-in-out 0.10s infinite; }
    @keyframes soundBar {
      0%, 100% { transform: scaleY(0.4); }
      50%       { transform: scaleY(1.0); }
    }

    /* ============ MARQUEE ============ */
    .ch-marquee {
      position: relative;
      padding: 15px 0;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      min-height: 48px;
    }

    /* Two gradient layers — crossfade between them */
    .ch-marquee::before,
    .ch-marquee::after {
      content: '';
      position: absolute;
      inset: 0;
      z-index: 0;
      transition: opacity 3s ease;
      pointer-events: none;
    }
    .ch-marquee::before {
      background: linear-gradient(90deg, #4b2d7a 0%, #5b9dc9 40%, #4b2d7a 70%, #5b9dc9 100%);
      opacity: 1;
    }
    .ch-marquee::after {
      background: linear-gradient(90deg, #8c1a1a 0%, #e8321a 28%, #f5820a 55%, #c9a84c 80%, #e8321a 100%);
      opacity: 0;
    }
    .ch-marquee.ch-warm::before { opacity: 0; }
    .ch-marquee.ch-warm::after  { opacity: 1; }

    /* True 3-column layout: [left group] [CENTER] [right group] */
    .ch-marquee-row {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      width: 100%;
      padding: 0 40px;
    }

    .ch-mp-left,
    .ch-mp-right {
      flex: 1;
      display: flex;
      align-items: center;
      gap: 44px;
    }
    .ch-mp-left  { justify-content: flex-end;   padding-right: 56px; }
    .ch-mp-right { justify-content: flex-start;  padding-left:  56px; }

    .ch-mp {
      font-family: var(--font-body);
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 3px;
      text-transform: uppercase;
      white-space: nowrap;
      opacity: 0;
      transform: translateY(5px);
      transition: opacity 0.45s ease, transform 0.45s ease;
      color: rgba(255, 255, 255, 0.82);
      flex-shrink: 0;
    }

    .ch-mp--center {
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 5px;
      color: #ffffff;
      flex-shrink: 0;
    }

    .ch-mp.ch-visible        { opacity: 0.82; transform: translateY(0); }
    .ch-mp--center.ch-visible { opacity: 1;    transform: translateY(0); }

    /* Mobile sub-text slot — hidden on desktop */
    .ch-mp--sub {
      display: none;
      font-size: 9px;
      font-weight: 500;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.7);
      opacity: 0;
      transform: translateY(4px);
      transition: opacity 0.45s ease, transform 0.45s ease;
    }

    @media (max-width: 768px) {
      .ch-marquee { padding: 22px 0; min-height: 72px; }
      .ch-marquee-row { flex-direction: column; gap: 8px; padding: 0 24px; }
      .ch-mp-left, .ch-mp-right { display: none; }
      .ch-mp--sub { display: block; }
      .ch-mp--sub.ch-visible { opacity: 0.75; transform: translateY(0); }
    }

    /* ============ INTRO ============ */
    .ch-intro {
      padding: 120px 48px;
      max-width: 800px;
      margin: 0 auto;
      text-align: center;
    }

    .ch-intro h2 {
      font-family: var(--font-display);
      font-size: clamp(36px, 5vw, 64px);
      letter-spacing: 2px;
      line-height: 1.1;
      color: var(--white);
      margin-bottom: 24px;
    }

    .ch-intro p {
      font-size: 16px;
      line-height: 1.8;
      color: var(--gray);
      font-weight: 300;
    }

    /* ============ PRODUCTS ============ */
    .ch-products {
      padding: 80px 48px;
    }

    .ch-products-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 2px;
      max-width: 1200px;
      margin: 0 auto;
    }

    .ch-product-card {
      position: relative;
      aspect-ratio: 1;
      overflow: hidden;
      cursor: pointer;
    }

    .ch-product-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.6s ease;
    }

    .ch-product-card:hover img {
      transform: scale(1.05);
    }

    .ch-product-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 60%);
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 28px;
    }

    .ch-product-name {
      font-family: var(--font-display);
      font-size: 28px;
      letter-spacing: 2px;
      color: var(--white);
      margin-bottom: 8px;
    }

    .ch-product-desc {
      font-size: 13px;
      color: rgba(255,255,255,0.7);
      line-height: 1.5;
      font-weight: 300;
    }

    /* ============ FEATURED PRODUCT ============ */
    .ch-featured {
      padding: 100px 48px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
      max-width: 1200px;
      margin: 0 auto;
    }

    .ch-featured-label {
      font-size: 11px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 16px;
    }

    .ch-featured-name {
      font-family: var(--font-display);
      font-size: clamp(64px, 10vw, 120px);
      letter-spacing: 4px;
      line-height: 0.9;
      margin-bottom: 24px;
    }

    .ch-featured-desc {
      font-size: 15px;
      line-height: 1.8;
      color: var(--gray);
      font-weight: 300;
      margin-bottom: 32px;
    }

    .ch-featured-cta {
      display: inline-block;
      padding: 14px 36px;
      border: 1px solid var(--white);
      color: var(--white);
      text-decoration: none;
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      transition: background 0.2s, color 0.2s;
    }

    .ch-featured-cta:hover { background: var(--white); color: var(--black); }

    .ch-featured-carousel {
      position: relative;
      aspect-ratio: 4/5;
      overflow: hidden;
    }

    .ch-featured-carousel img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0;
      transition: opacity 0.8s ease;
    }

    .ch-featured-carousel img.active { opacity: 1; }

    .ch-carousel-dots {
      display: flex;
      gap: 8px;
      margin-top: 16px;
      justify-content: center;
    }

    .ch-carousel-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: #333;
      cursor: pointer;
      transition: background 0.2s;
    }

    .ch-carousel-dot.active { background: var(--white); }

    .ch-carousel-arrow {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      z-index: 10;
      background: rgba(0,0,0,0.5);
      border: 1px solid rgba(255,255,255,0.2);
      color: var(--white);
      width: 44px;
      height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      font-size: 18px;
      transition: background 0.2s;
      user-select: none;
    }
    .ch-carousel-arrow:hover { background: rgba(0,0,0,0.85); }
    .ch-carousel-arrow.prev { left: 12px; }
    .ch-carousel-arrow.next { right: 12px; }

    /* ============ PRODUCT SECTIONS ============ */
    .ch-product-section {
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-height: 600px;
      border-top: 1px solid rgba(201, 168, 76, 0.15);
    }

    .ch-product-section.reverse { direction: rtl; }
    .ch-product-section.reverse > * { direction: ltr; }

    /* ============ PRODUCT SQUARE ROW ============ */
    .ch-product-row-outer {
      position: relative;
      border-top: 1px solid rgba(201, 168, 76, 0.15);
      background: #fff;
    }

    .ch-product-row-wrap {
      position: relative;
      background: #fff;
      padding: 48px 80px 56px;
      cursor: grab;
      user-select: none;
      overflow: hidden;
    }

    .ch-product-row-wrap.is-dragging { cursor: grabbing; }

    /* Large centered overlay arrows */
    .ch-row-nav {
      position: absolute;
      top: 0; bottom: 0;
      width: 80px;
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 10;
      cursor: pointer;
      opacity: 0;
      transition: opacity 0.25s ease;
    }

    .ch-row-nav:hover { opacity: 1; }
    .ch-row-nav--prev { left: 0; }
    .ch-row-nav--next { right: 0; }

    .ch-row-nav-btn {
      width: 52px;
      height: 52px;
      background: #fff;
      border: 1px solid #ddd;
      box-shadow: 0 4px 20px rgba(0,0,0,0.1);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 20px;
      color: #222;
      transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
    }

    .ch-row-nav:hover .ch-row-nav-btn {
      border-color: #1a5fa8;
      box-shadow: 0 6px 28px rgba(26,95,168,0.18);
      transform: scale(1.08);
    }

    .ch-product-row {
      display: flex;
      gap: 20px;
      will-change: transform;
    }

    .ch-product-square {
      flex: 0 0 calc(25% - 15px);
      min-width: 0;
      border: 1px solid #e8e8e8;
      overflow: hidden;
      transition: box-shadow 0.3s ease;
    }

    .ch-product-square:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.08); }

    .ch-product-square-media {
      position: relative;
      width: 100%;
      aspect-ratio: 1 / 1;
      overflow: hidden;
    }

    .ch-product-square-media img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0;
      transition: opacity 0.8s ease, transform 0.6s ease;
    }

    .ch-product-square-media img.active { opacity: 1; }
    .ch-product-square:hover .ch-product-square-media img.active { transform: scale(1.04); }

    .ch-product-square-info {
      padding: 24px 28px 32px;
      background: #fff;
    }

    .ch-product-square-nav {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 14px;
    }

    .ch-product-square-arrow {
      width: 22px;
      height: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 1px solid #ccc;
      font-size: 11px;
      cursor: pointer;
      color: #111;
      transition: border-color 0.2s, background 0.2s;
      user-select: none;
    }

    .ch-product-square-arrow:hover { border-color: #111; background: rgba(0,0,0,0.05); }

    .ch-product-square-counter {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 2px;
      color: #aaa;
    }

    /* Row-level swipe arrows */
    /* Row arrows removed — drag/touch only */

    /* ============ SPEED CONTROL BAR ============ */
    .ch-speed-bar {
      background: #fff;
      border-top: 1px solid #efefef;
      padding: 18px 40px 22px;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 14px;
    }

    .ch-speed-nav {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    .ch-speed-nav-btn {
      width: 48px;
      height: 48px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 22px;
      font-weight: 700;
      color: #e8321a;
      cursor: pointer;
      border: 2px solid #e8321a;
      transition: background 0.2s, color 0.2s, transform 0.15s;
      user-select: none;
    }

    .ch-speed-nav-btn:hover {
      background: #e8321a;
      color: #fff;
      transform: scale(1.08);
    }

    .ch-speed-steps {
      display: flex;
      gap: 6px;
      align-items: center;
    }

    .ch-speed-step {
      font-family: var(--font-body);
      font-size: 8px;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: #ccc;
      cursor: pointer;
      padding: 5px 14px;
      border: 1px solid #e8e8e8;
      transition: color 0.2s, border-color 0.2s, background 0.2s;
    }

    .ch-speed-step.active { color: #e8321a; border-color: #e8321a; }
    .ch-speed-step:hover  { color: #e8321a; border-color: rgba(232,50,26,0.4); }

    /* WPFF special — orange/red brand card */
    .ch-product-square--special {
      background: #111;
      border-color: rgba(232, 50, 26, 0.4) !important;
      position: relative;
    }
    .ch-product-square--special::before {
      content: 'Limited';
      position: absolute;
      top: 12px;
      right: 14px;
      font-family: var(--font-body);
      font-size: 7px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: #e8321a;
      opacity: 0.8;
      z-index: 2;
      pointer-events: none;
    }
    .ch-product-square--special .ch-product-square-info {
      background: #111;
    }
    .ch-product-square--special .ch-product-square-arrow {
      border-color: rgba(232,50,26,0.3);
      color: #f5820a;
    }
    .ch-product-square--special .ch-product-square-arrow:hover {
      border-color: #e8321a;
      background: rgba(232,50,26,0.08);
    }
    .ch-product-square--special .ch-product-square-counter { color: #444; }

    @media (max-width: 768px) {
      .ch-product-square { flex: 0 0 100%; border-right: none; }
    }

    .ch-product-media {
      position: relative;
      overflow: hidden;
    }

    .ch-product-media img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0;
      transition: opacity 0.8s ease;
    }

    .ch-product-media img.active { opacity: 1; }

    .ch-product-info {
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 80px 64px;
      background: #0d0d0d;
    }

    .ch-product-tagline {
      font-size: 10px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 16px;
    }

    .ch-product-title {
      font-family: var(--font-display);
      font-size: clamp(40px, 5vw, 72px);
      letter-spacing: 3px;
      line-height: 1;
      margin-bottom: 24px;
    }

    .ch-product-body {
      font-size: 14px;
      line-height: 1.9;
      color: var(--gray);
      font-weight: 300;
      margin-bottom: 36px;
    }

    .ch-product-nav {
      display: flex;
      align-items: center;
      gap: 20px;
    }

    .ch-product-arrow {
      width: 40px;
      height: 40px;
      border: 1px solid #333;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      font-size: 16px;
      color: var(--white);
      transition: border-color 0.2s, background 0.2s;
      user-select: none;
    }
    .ch-product-arrow:hover { border-color: var(--white); background: rgba(255,255,255,0.05); }

    .ch-product-counter {
      font-size: 11px;
      letter-spacing: 2px;
      color: #555;
    }

    .ch-product-shop {
      display: inline-block;
      margin-top: 32px;
      padding: 13px 32px;
      border: 1px solid #333;
      color: var(--white);
      text-decoration: none;
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      transition: border-color 0.2s, background 0.2s;
      align-self: flex-start;
    }
    .ch-product-shop:hover { border-color: var(--white); background: rgba(255,255,255,0.05); }

    /* ============ COA SECTION ============ */
    .ch-coa {
      background: #0d0d0d;
      border-top: 1px solid rgba(201, 168, 76, 0.15);
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-height: 560px;
    }

    /* Left — lab data panel */
    .ch-coa-data {
      padding: 72px 64px;
      border-right: 1px solid rgba(201, 168, 76, 0.12);
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .ch-coa-eyebrow {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
    }

    .ch-coa-heading {
      font-family: var(--font-display);
      font-size: 38px;
      letter-spacing: 2px;
      line-height: 1.1;
      margin-bottom: 8px;
    }

    .ch-coa-subhead {
      font-family: var(--font-body);
      font-size: 12px;
      letter-spacing: 1.5px;
      color: #888;
      text-transform: uppercase;
      margin-bottom: 40px;
    }

    .ch-coa-stats {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 0;
      border: 1px solid rgba(201, 168, 76, 0.18);
      margin-bottom: 40px;
    }

    .ch-coa-stat {
      padding: 20px 18px;
      border-right: 1px solid rgba(201, 168, 76, 0.18);
      text-align: center;
    }

    .ch-coa-stat:last-child { border-right: none; }

    .ch-coa-stat-val {
      font-family: var(--font-display);
      font-size: 28px;
      letter-spacing: 1px;
      color: var(--gold);
      display: block;
    }

    .ch-coa-stat-label {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #666;
      display: block;
      margin-top: 4px;
    }

    .ch-coa-terpenes {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 36px;
    }

    .ch-coa-terpene {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.6);
      border: 1px solid rgba(201, 168, 76, 0.2);
      padding: 5px 12px;
    }

    .ch-coa-terpene span {
      color: var(--gold);
      margin-left: 6px;
    }

    .ch-coa-meta {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px 32px;
    }

    .ch-coa-meta-row {
      font-family: var(--font-body);
      font-size: 10px;
      letter-spacing: 1px;
      color: #666;
      display: flex;
      justify-content: space-between;
      border-bottom: 1px solid rgba(255,255,255,0.06);
      padding-bottom: 6px;
    }

    .ch-coa-meta-row strong {
      color: rgba(255,255,255,0.75);
      font-weight: 500;
    }

    /* Right — QR + compliance panel */
    .ch-coa-verify {
      padding: 72px 64px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
    }

    .ch-coa-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      border: 1px solid rgba(201, 168, 76, 0.3);
      padding: 6px 16px;
      margin-bottom: 40px;
      font-family: var(--font-body);
      font-size: 8px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
    }

    .ch-coa-badge::before {
      content: '';
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--gold);
      flex-shrink: 0;
    }

    .ch-coa-qr {
      width: 160px;
      height: 160px;
      border: 1px solid rgba(201, 168, 76, 0.25);
      padding: 12px;
      margin-bottom: 24px;
      background: #fff;
      position: relative;
    }

    /* Generated QR pattern — purely CSS art approximation */
    .ch-coa-qr svg {
      width: 100%;
      height: 100%;
    }

    .ch-coa-qr-label {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #555;
      margin-bottom: 32px;
    }

    .ch-coa-compliance {
      font-family: var(--font-body);
      font-size: 9px;
      line-height: 1.8;
      letter-spacing: 0.5px;
      color: #444;
      max-width: 280px;
      text-align: center;
      border-top: 1px solid rgba(255,255,255,0.06);
      padding-top: 24px;
    }

    .ch-coa-compliance strong {
      color: #666;
      letter-spacing: 2px;
      text-transform: uppercase;
      font-size: 8px;
    }

    /* Cannabinoid profile table */
    .ch-coa-cannabinoids {
      margin-bottom: 28px;
    }
    .ch-coa-cannabinoids-label {
      font-size: 8px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 10px;
      opacity: 0.7;
    }
    .ch-coa-cannabinoid-row {
      display: grid;
      grid-template-columns: 80px 1fr 52px;
      align-items: center;
      gap: 10px;
      padding: 5px 0;
      border-bottom: 1px solid rgba(255,255,255,0.04);
      font-size: 9px;
      letter-spacing: 1.5px;
    }
    .ch-coa-cannabinoid-row:last-child { border-bottom: none; }
    .ch-coa-cannabinoid-name {
      color: rgba(255,255,255,0.45);
      text-transform: uppercase;
    }
    .ch-coa-cannabinoid-bar-wrap {
      height: 2px;
      background: rgba(255,255,255,0.06);
      border-radius: 1px;
      overflow: hidden;
    }
    .ch-coa-cannabinoid-bar-fill {
      height: 100%;
      background: linear-gradient(90deg, rgba(201,168,76,0.5), var(--gold));
      border-radius: 1px;
    }
    .ch-coa-cannabinoid-val {
      color: rgba(255,255,255,0.7);
      text-align: right;
      font-weight: 500;
    }

    /* Right panel — purity statement */
    .ch-coa-verify-heading {
      font-family: var(--font-display);
      font-size: clamp(32px, 3.5vw, 48px);
      letter-spacing: 3px;
      line-height: 1;
      color: var(--white);
      margin-bottom: 20px;
      text-align: center;
    }
    .ch-coa-verify-body {
      font-size: 12px;
      line-height: 1.85;
      color: rgba(255,255,255,0.38);
      font-weight: 300;
      max-width: 300px;
      text-align: center;
      margin-bottom: 32px;
    }
    .ch-coa-standards {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px 24px;
      margin-bottom: 36px;
      width: 100%;
      max-width: 320px;
    }
    .ch-coa-standard-item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 9px;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.45);
    }
    .ch-coa-standard-item::before {
      content: '';
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: var(--gold);
      flex-shrink: 0;
      opacity: 0.6;
    }

    @media (max-width: 768px) {
      .ch-coa { grid-template-columns: 1fr; }
      .ch-coa-data { padding: 48px 24px; border-right: none; border-bottom: 1px solid rgba(201,168,76,0.12); }
      .ch-coa-verify { padding: 48px 24px; }
      .ch-coa-stats { grid-template-columns: 1fr 1fr 1fr; }
      .ch-coa-standards { grid-template-columns: 1fr 1fr; }
    }

    /* ============ PRESS ============ */
    .ch-press {
      background: var(--white);
      padding: 0 0 64px;
    }

    .ch-press-header {
      display: flex;
      align-items: center;
      gap: 32px;
      padding: 64px 64px 0;
    }

    .ch-press-header-line {
      flex: 1;
      height: 1px;
      background: #ddd;
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.3s;
    }

    .ch-press-header-line.right {
      transform-origin: right;
    }

    .ch-press-header.animated .ch-press-header-line {
      transform: scaleX(1);
    }

    .ch-press-heading {
      font-family: var(--font-display);
      font-size: 32px;
      letter-spacing: 8px;
      text-transform: uppercase;
      color: #111;
      white-space: nowrap;
      flex-shrink: 0;
      display: flex;
      gap: 4px;
    }

    /* ── Universal CaliHash phantom letter style ── */
    .ch-animated-heading .letter {
      display: inline-block;
      opacity: 0;
      position: relative;
      transition: color 0.35s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
      cursor: default;
      will-change: transform, color, opacity;
    }

    /* Soft lift — no glow blast */
    .ch-animated-heading .letter:hover {
      transform: scale(1.08) translateY(-3px) !important;
    }
    .ch-animated-heading--cinematic .letter:hover {
      transform: scale(1.12) translateY(-4px) !important;
      text-shadow:
        0 0 12px currentColor,
        0 0 32px currentColor,
        0 0 70px currentColor,
        0 0 140px currentColor;
    }

    /* Particle cloud canvas that floats over each letter */
    .ch-letter-particles {
      position: fixed;
      pointer-events: none;
      z-index: 99998;
      opacity: 0;
      transition: opacity 0.18s ease;
    }
    .ch-letter-particles.visible { opacity: 1; }

    @keyframes letterIn {
      from { opacity: 0; transform: translateY(18px) scale(0.8); filter: blur(10px); }
      to   { opacity: 1; transform: translateY(0)   scale(1);   filter: blur(0); }
    }

    .ch-press-featured {
      border-top: 1px solid rgba(201, 168, 76, 0.22);
      border-bottom: 1px solid rgba(201, 168, 76, 0.22);
      margin-top: 48px;
    }

    .ch-press-featured .ch-press-logo-cell {
      aspect-ratio: 8 / 1;
      border-right: none;
      border-bottom: none;
    }

    .ch-press-logos {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      border-top: none;
    }

    .ch-press-logo-cell {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 12px;
      border-right: 1px solid rgba(201, 168, 76, 0.18);
      border-bottom: 1px solid rgba(201, 168, 76, 0.18);
      position: relative;
      overflow: hidden;
      aspect-ratio: 3 / 1;
    }

    .ch-press-logo-cell::after {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--black);
      transform: scaleY(0);
      transform-origin: bottom;
      transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
      z-index: 0;
    }

    .ch-press-logo-cell:hover::after { transform: scaleY(1); }

    .ch-press-logo-cell:nth-child(4n) { border-right: none; }
    .ch-press-logo-cell:nth-last-child(-n+4) { border-bottom: none; }

    .ch-press-logo-name {
      font-family: var(--font-display);
      font-size: 21px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #111;
      position: relative;
      z-index: 1;
      opacity: 1;
      text-align: center;
      padding: 0 8px;
      transition: opacity 0.25s ease, color 0.25s ease;
    }

    .ch-press-logo-cell:not(.text-only):hover .ch-press-logo-name {
      opacity: 0;
    }

    .ch-press-logo-cell.text-only:hover .ch-press-logo-name {
      color: #fff;
    }

    .ch-press-logo-cell img {
      width: calc(100% - 24px);
      height: calc(100% - 24px);
      object-fit: contain;
      filter: invert(1);
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 2;
      opacity: 0;
      transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .ch-press-logo-cell:hover img {
      opacity: 1;
    }

    .ch-press-logo-cell img.no-invert {
      filter: none;
    }

    /* ============ SERVICES / B2B ============ */
    .ch-services {
      position: relative;
      padding: 0 80px;
    }
    .ch-services::before,
    .ch-services::after {
      content: '';
      position: absolute;
      inset: 0;
      pointer-events: none;
      transition: opacity 2.5s ease;
    }
    .ch-services::before {
      background: linear-gradient(90deg, #4b2d7a 0%, #5b9dc9 40%, #4b2d7a 70%, #5b9dc9 100%);
      opacity: 1;
    }
    .ch-services::after {
      background: linear-gradient(90deg, #8c1a1a 0%, #e8321a 28%, #f5820a 55%, #c9a84c 80%, #e8321a 100%);
      opacity: 0;
    }
    .ch-services.ch-warm::before { opacity: 0; }
    .ch-services.ch-warm::after  { opacity: 1; }
    .ch-services-row {
      display: flex;
      position: relative;
      z-index: 1;
    }
    .ch-service-card {
      flex: 1;
      border-right: 1px solid rgba(201,168,76,0.12);
      position: relative;
    }
    .ch-service-card:last-child { border-right: none; }
    .ch-service-trigger {
      padding: 28px 24px 24px;
      cursor: pointer;
      text-align: center;
    }
    .ch-service-heading {
      font-family: var(--font-display);
      font-size: clamp(18px, 2vw, 26px);
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.9);
      transition: color 0.2s ease;
      white-space: nowrap;
      line-height: 1;
    }
    .ch-service-card:hover .ch-service-heading,
    .ch-service-card.open .ch-service-heading { color: #fff; }
    .ch-service-dot {
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: rgba(201,168,76,0.3);
      margin: 8px auto 0;
      transition: background 0.2s ease, transform 0.2s ease;
    }
    .ch-service-card:hover .ch-service-dot,
    .ch-service-card.open .ch-service-dot {
      background: var(--gold);
      transform: scale(1.5);
    }
    /* Dropdown panel — full width, positioned below the row */
    .ch-service-panel {
      position: absolute;
      top: 100%;
      left: -80px;
      right: -80px;
      background: #fff;
      border-top: none;
      border-bottom: none;
      z-index: 100;
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.4s cubic-bezier(0.16,0.84,0.44,1);
      pointer-events: none;
    }
    .ch-service-card.open .ch-service-panel {
      grid-template-rows: 1fr;
      pointer-events: auto;
    }
    .ch-service-panel-inner { overflow: hidden; }
    .ch-service-panel-content {
      padding: 40px 80px;
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 80px;
    }
    .ch-service-panel-left { flex: 1; }
    .ch-service-panel-label {
      font-size: 9px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 12px;
    }
    .ch-service-panel-heading {
      font-family: var(--font-display);
      font-size: clamp(28px, 3vw, 40px);
      letter-spacing: 2px;
      color: var(--black);
      line-height: 1;
      margin-bottom: 16px;
    }
    .ch-service-panel-detail {
      font-size: 13px;
      line-height: 1.8;
      color: rgba(0,0,0,0.55);
      font-weight: 300;
      max-width: 480px;
    }
    .ch-service-cta {
      display: inline-block;
      margin-top: 24px;
      padding: 12px 32px;
      border: 1px solid rgba(201,168,76,0.6);
      font-size: 9px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--black);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
      flex-shrink: 0;
      align-self: center;
    }
    .ch-service-cta:hover { border-color: var(--gold); background: rgba(201,168,76,0.12); color: var(--gold); }

    @media (max-width: 768px) {
      .ch-services { padding: 0 24px; }
      .ch-services-row { flex-direction: column; }
      .ch-service-card { border-right: none; border-bottom: 1px solid rgba(201,168,76,0.12); }
      .ch-service-card:last-child { border-bottom: none; }
      .ch-service-trigger { text-align: left; padding: 20px 0; }
      .ch-service-dot { margin: 6px 0 0; }
      .ch-service-panel { position: static; left: auto; right: auto; }
      .ch-service-panel-content { flex-direction: column; gap: 20px; padding: 20px 0 32px; }
    }

    /* Menu page services — text-only, contained, compact */
    .ch-menu-services::before,
    .ch-menu-services::after { display: none; }
    .ch-menu-services {
      background: var(--black);
      padding: 48px 18vw 0;
      border-top: 1px solid rgba(201,168,76,0.08);
    }
    .ch-menu-services .ch-services-row {
      border: 1px solid rgba(201,168,76,0.1);
    }
    .ch-menu-services .ch-service-trigger {
      padding: 16px 16px 12px;
    }
    .ch-menu-services .ch-service-heading {
      background: linear-gradient(90deg, #c9a84c 0%, #f5820a 50%, #c9a84c 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      font-size: clamp(11px, 1.1vw, 15px);
      letter-spacing: 2px;
    }
    .ch-menu-services .ch-service-dot { margin-top: 5px; }
    .ch-menu-services .ch-service-card {
      border-right-color: rgba(201,168,76,0.1);
    }
    .ch-menu-services .ch-service-panel {
      left: 0;
      right: 0;
      background: #fff;
    }
    @media (max-width: 768px) {
      .ch-menu-services { padding: 36px 24px 0; }
      .ch-menu-services .ch-service-trigger { padding: 14px 0 10px; }
    }

    /* ============ NEWSLETTER ============ */
    .ch-newsletter {
      padding: 72px 48px 80px;
      text-align: center;
      border-top: 1px solid rgba(201, 168, 76, 0.2);
      background: #0a0a0a;
    }

    .ch-newsletter-eyebrow {
      font-family: var(--font-body);
      font-size: 10px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 14px;
      opacity: 0.85;
    }

    .ch-newsletter h3 {
      font-family: var(--font-display);
      font-size: 32px;
      letter-spacing: 3px;
      margin-bottom: 10px;
    }

    .ch-newsletter-sub {
      font-family: var(--font-body);
      font-size: 13px;
      letter-spacing: 1px;
      color: #888;
      margin-bottom: 32px;
    }

    .ch-newsletter-form {
      display: flex;
      gap: 0;
      max-width: 420px;
      margin: 0 auto;
      border: 1px solid rgba(201, 168, 76, 0.3);
    }

    .ch-newsletter-form input {
      flex: 1;
      padding: 14px 20px;
      background: transparent;
      border: none;
      color: var(--white);
      font-family: var(--font-body);
      font-size: 13px;
      outline: none;
    }

    .ch-newsletter-form input::placeholder { color: #444; }

    .ch-newsletter-form button {
      padding: 14px 24px;
      background: var(--gold);
      color: var(--black);
      border: none;
      font-family: var(--font-body);
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      cursor: pointer;
      transition: background 0.2s, color 0.2s;
      white-space: nowrap;
    }

    .ch-newsletter-form button:hover { background: var(--cream); }

    /* ============ FOOTER ============ */
    /* ============ FOOTER ============ */
    .ch-footer {
      position: relative;
      overflow: hidden;
      background: var(--black);
      border-top: 1px solid rgba(201, 168, 76, 0.18);
      padding: 100px 80px 0;
    }

    /* Ghost logo — large, right side */
    .ch-footer-bg-logo {
      position: absolute;
      right: -60px;
      top: 50%;
      transform: translateY(-58%);
      width: 420px;
      opacity: 0.04;
      filter: brightness(0) invert(1);
      pointer-events: none;
    }

    /* Main content grid */
    .ch-footer-main {
      position: relative;
      display: grid;
      grid-template-columns: 1.4fr 1fr 1fr;
      gap: 80px;
      padding-bottom: 80px;
      z-index: 1;
    }

    /* Brand column */
    .ch-footer-brand-logo {
      margin-bottom: 28px;
    }

    .ch-footer-brand-logo img {
      height: 52px;
      filter: brightness(0) invert(1);
    }

    .ch-footer-brand-tagline {
      font-family: var(--font-display);
      font-size: 22px;
      letter-spacing: 4px;
      color: var(--gold);
      margin-bottom: 12px;
    }

    .ch-footer-brand-sub {
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #444;
      line-height: 2;
    }

    /* Nav columns */
    .ch-footer-col-label {
      font-size: 10px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: #555;
      margin-bottom: 28px;
    }

    .ch-footer-nav-links {
      list-style: none;
    }

    .ch-footer-nav-links li {
      margin-bottom: 14px;
    }

    .ch-footer-nav-links a {
      font-size: 13px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: #777;
      text-decoration: none;
      transition: color 0.25s ease, letter-spacing 0.25s ease;
    }

    .ch-footer-nav-links a:hover {
      color: var(--white);
      letter-spacing: 3px;
    }

    /* Connect column */
    .ch-footer-ig-handle {
      display: block;
      font-family: var(--font-display);
      font-size: 28px;
      letter-spacing: 3px;
      color: var(--white);
      text-decoration: none;
      margin-bottom: 20px;
      transition: color 0.25s ease, letter-spacing 0.25s ease;
    }

    .ch-footer-ig-handle:hover {
      color: var(--gold);
      letter-spacing: 4px;
    }

    .ch-footer-ig-sub {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #444;
    }

    /* Gold divider */
    .ch-footer-divider {
      position: relative;
      z-index: 1;
      height: 1px;
      background: linear-gradient(to right, transparent, var(--gold), transparent);
      opacity: 0.4;
    }

    /* Bottom bar */
    .ch-footer-bottom {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 28px 0 36px;
    }

    .ch-footer-bottom-logo img {
      height: 24px;
      filter: brightness(0) invert(1);
      opacity: 0.25;
    }

    .ch-footer-copy {
      font-size: 11px;
      color: #333;
      letter-spacing: 2px;
    }

    .ch-footer-made {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: #333;
    }

    /* ============ RESPONSIVE ============ */
    @media (max-width: 768px) {

      #ch-nav-trigger img { height: 64px; }
      #ch-nav-dropdown { top: 140px; min-width: 130px; padding: 16px 28px 14px; }
.ch-featured { grid-template-columns: 1fr; gap: 40px; padding: 60px 24px; }
      .ch-product-section { grid-template-columns: 1fr; min-height: auto; }
      .ch-product-section.reverse { direction: ltr; }
      .ch-product-media { height: 70vw; }
      .ch-product-info { padding: 48px 24px; }
      .ch-coa { grid-template-columns: 1fr; }
      .ch-intro, .ch-press, .ch-newsletter { padding: 60px 24px; }
      .ch-footer { padding: 60px 24px 0; }
      .ch-footer-bg-logo { display: none; }
      .ch-footer-main { grid-template-columns: 1fr; gap: 40px; padding-bottom: 48px; text-align: center; }
      .ch-footer-brand-logo { margin-bottom: 16px; }
      .ch-footer-bottom { flex-direction: column; gap: 8px; text-align: center; padding: 20px 0; }

      /* Press — Forbes full width, then 2-per-row */
      .ch-press-featured .ch-press-logo-cell { aspect-ratio: 4 / 1; }
      .ch-press-logos { grid-template-columns: repeat(2, 1fr); }
      .ch-press-logo-cell:nth-child(4n) { border-right: 1px solid rgba(201,168,76,0.15); }
      .ch-press-logo-cell:nth-last-child(-n+4) { border-bottom: 1px solid rgba(201,168,76,0.15); }
      .ch-press-logo-cell:nth-child(2n) { border-right: none; }
      .ch-press-logo-cell:nth-last-child(-n+2) { border-bottom: none; }
    }

    /* ============================================================
       SUB-PAGE SYSTEM
       Homepage content hides; #ch-subpage shows per route.
    ============================================================ */

    #ch-subpage { display: none; }
    #ch-subpage.ch-visible { display: block; }
    #ch-home-content.ch-hidden { display: none; }

    /* ============ ABOUT PAGE ============ */
    .ch-about-hero {
      position: relative;
      width: 100%;
      height: 80vh;
      overflow: hidden;
    }
    .ch-about-hero img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      animation: kenBurns 20s ease-in-out infinite alternate;
    }
    .ch-about-hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.72) 100%);
      display: flex;
      align-items: flex-end;
      padding: 80px 10%;
    }
    .ch-about-hero-heading {
      font-family: var(--font-display);
      font-size: clamp(52px, 9vw, 130px);
      letter-spacing: 4px;
      line-height: 0.95;
      color: var(--white);
    }
    .ch-about-body {
      max-width: 800px;
      margin: 0 auto;
      padding: 100px 48px;
    }
    .ch-about-body h2 {
      font-family: var(--font-display);
      font-size: clamp(32px, 4vw, 56px);
      letter-spacing: 2px;
      color: var(--white);
      margin-bottom: 32px;
    }
    .ch-about-body p {
      font-size: 16px;
      line-height: 1.9;
      color: var(--gray);
      font-weight: 300;
      margin-bottom: 24px;
    }
    .ch-about-philosophy {
      border-left: 2px solid var(--gold);
      padding-left: 32px;
      margin: 48px 0;
    }
    .ch-about-image {
      width: 100%;
      height: 60vh;
      object-fit: cover;
      display: block;
    }

    /* ============ SHOP PAGE ============ */
    .ch-shop-header {
      padding: 160px 48px 60px;
      text-align: center;
    }
    .ch-shop-header h1 {
      font-family: var(--font-display);
      font-size: clamp(64px, 12vw, 160px);
      letter-spacing: 4px;
      color: var(--white);
      margin-bottom: 16px;
      line-height: 0.9;
    }
    .ch-shop-note {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(201,168,76,0.3);
      display: inline-block;
      padding: 10px 24px;
      margin-top: 24px;
    }
    .ch-shop-category {
      padding: 0 48px 80px;
      max-width: 1400px;
      margin: 0 auto;
    }
    .ch-shop-category-label {
      font-size: 10px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.35);
      margin-bottom: 32px;
      padding-bottom: 16px;
      border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    .ch-shop-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
      gap: 2px;
    }
    .ch-shop-card {
      background: #111;
      cursor: pointer;
      overflow: hidden;
    }
    .ch-shop-card-img {
      width: 100%;
      aspect-ratio: 1;
      object-fit: cover;
      display: block;
      transition: transform 0.6s ease;
    }
    .ch-shop-card:hover .ch-shop-card-img { transform: scale(1.04); }
    .ch-shop-card-info { padding: 20px 24px 28px; }
    .ch-shop-card-name {
      font-family: var(--font-display);
      font-size: 24px;
      letter-spacing: 1.5px;
      color: var(--white);
      margin-bottom: 4px;
    }
    .ch-shop-card-variant {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.35);
      margin-bottom: 14px;
    }
    .ch-shop-card-price {
      font-size: 14px;
      color: var(--gold);
      letter-spacing: 1px;
    }

    /* ============ STORES PAGE ============ */
    .ch-stores-header {
      padding: 160px 48px 80px;
      text-align: center;
    }
    .ch-stores-header h1 {
      font-family: var(--font-display);
      font-size: clamp(64px, 12vw, 160px);
      letter-spacing: 4px;
      color: var(--white);
      line-height: 0.9;
      margin-bottom: 16px;
    }
    .ch-stores-sub {
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.35);
    }
    .ch-stores-list {
      padding: 0 48px 120px;
      max-width: 960px;
      margin: 0 auto;
    }
    .ch-store-item {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 28px 0;
      border-bottom: 1px solid rgba(255,255,255,0.07);
      gap: 24px;
    }
    .ch-store-item:first-child { border-top: 1px solid rgba(255,255,255,0.07); }
    .ch-store-logo {
      width: 60px;
      height: 60px;
      object-fit: contain;
      border-radius: 8px;
      flex-shrink: 0;
      filter: brightness(0) invert(1);
      opacity: 0.85;
    }
    .ch-store-name {
      font-family: var(--font-display);
      font-size: 22px;
      letter-spacing: 1.5px;
      color: var(--white);
    }
    .ch-store-address {
      font-size: 11px;
      letter-spacing: 1.5px;
      color: rgba(255,255,255,0.4);
      text-transform: uppercase;
      margin-top: 4px;
    }
    .ch-store-state {
      font-size: 10px;
      letter-spacing: 3px;
      color: var(--gold);
      text-transform: uppercase;
      flex-shrink: 0;
    }
    .ch-store-map {
      font-size: 10px;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.45);
      text-decoration: none;
      border: 1px solid rgba(255,255,255,0.12);
      padding: 9px 20px;
      transition: color 0.2s ease, border-color 0.2s ease;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .ch-store-map:hover { color: var(--gold); border-color: rgba(201,168,76,0.5); }

    /* ============ CONTACT PAGE ============ */
    /* Smoke hero */
    .ch-contact-smoke {
      height: 56vh;
      min-height: 320px;
      max-height: 520px;
      position: relative;
      background: var(--black);
      overflow: hidden;
    }
    #ch-smoke-canvas {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
    }
    @media (max-width: 768px) {
      .ch-contact-smoke { height: 40vh; min-height: 220px; }
    }

    /* Form type tabs */
    .ch-contact-tabs {
      display: flex;
      justify-content: center;
      gap: 0;
      border-bottom: 1px solid rgba(201,168,76,0.12);
      margin-bottom: 0;
      padding: 0 48px;
    }
    .ch-contact-tab {
      font-family: var(--font-body);
      font-size: 9px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.3);
      padding: 16px 32px;
      cursor: pointer;
      border-bottom: 1px solid transparent;
      margin-bottom: -1px;
      transition: color 0.2s ease, border-color 0.2s ease;
      background: none;
      border-top: none;
      border-left: none;
      border-right: none;
    }
    .ch-contact-tab:hover { color: rgba(255,255,255,0.7); }
    .ch-contact-tab.active {
      color: var(--gold);
      border-bottom-color: var(--gold);
    }

    /* Form panels */
    .ch-contact-panel { display: none; }
    .ch-contact-panel.active { display: block; }

    .ch-contact-panel-header {
      max-width: 560px;
      margin: 0 auto;
      padding: 52px 0 40px;
      text-align: center;
    }
    .ch-contact-panel-heading {
      font-family: var(--font-display);
      font-size: clamp(32px, 4vw, 52px);
      letter-spacing: 3px;
      color: var(--white);
      line-height: 1;
      margin-bottom: 12px;
    }
    .ch-contact-panel-sub {
      font-size: 12px;
      color: rgba(255,255,255,0.35);
      line-height: 1.7;
      font-weight: 300;
      letter-spacing: 0.5px;
    }

    .ch-contact-form-wrap {
      max-width: 560px;
      margin: 0 auto;
      padding: 0 48px 100px;
    }
    .ch-contact-input,
    .ch-contact-textarea,
    .ch-contact-select {
      width: 100%;
      background: transparent;
      border: none;
      border-bottom: 1px solid rgba(255,255,255,0.15);
      color: var(--white);
      font-family: var(--font-body);
      font-size: 14px;
      letter-spacing: 1px;
      padding: 16px 0;
      margin-bottom: 36px;
      outline: none;
      display: block;
      transition: border-color 0.25s ease;
      -webkit-appearance: none;
      appearance: none;
    }
    .ch-contact-select {
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(201,168,76,0.5)'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 4px center;
      cursor: pointer;
    }
    .ch-contact-select option { background: #111; color: var(--white); }
    .ch-contact-input::placeholder,
    .ch-contact-textarea::placeholder {
      color: rgba(255,255,255,0.25);
      letter-spacing: 2px;
      text-transform: uppercase;
      font-size: 11px;
    }
    .ch-contact-input:focus,
    .ch-contact-textarea:focus,
    .ch-contact-select:focus { border-bottom-color: var(--gold); outline: none; }
    .ch-contact-textarea { resize: none; height: 120px; }
    .ch-contact-submit {
      font-family: var(--font-body);
      font-size: 10px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--white);
      background: transparent;
      border: 1px solid rgba(255,255,255,0.25);
      padding: 16px 52px;
      cursor: pointer;
      transition: border-color 0.2s ease, color 0.2s ease;
      display: block;
      margin: 0 auto;
    }
    .ch-contact-submit:hover { border-color: var(--gold); color: var(--gold); }
    .ch-contact-submit:disabled { opacity: 0.4; cursor: not-allowed; }
    .ch-contact-status {
      text-align: center;
      font-size: 11px;
      letter-spacing: 2px;
      text-transform: uppercase;
      margin-top: 24px;
      min-height: 20px;
    }
    .ch-contact-status.success { color: var(--gold); }
    .ch-contact-status.error { color: #c44; }

    @media (max-width: 768px) {
      .ch-contact-tabs { padding: 0 24px; gap: 0; }
      .ch-contact-tab { padding: 14px 16px; font-size: 8px; letter-spacing: 3px; }
      .ch-contact-form-wrap { padding: 0 0 80px; }
    }

    /* ============ MENU PAGE ============ */
    .ch-menu-header {
      padding: 160px 48px 48px;
      text-align: center;
      background: var(--black);
    }
    .ch-menu-header h1 {
      font-family: var(--font-display);
      font-size: clamp(64px, 10vw, 140px);
      letter-spacing: 4px;
      color: var(--white);
      line-height: 0.9;
      margin-bottom: 20px;
    }
    .ch-menu-subheading {
      font-size: 11px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      opacity: 0.8;
    }

    /* Card grid */
    .ch-menu-list {
      background: var(--black);
      padding: 80px 48px 80px;
    }
    .ch-menu-grid {
      max-width: 1200px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      gap: 2px;
    }
    .ch-menu-row {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      column-gap: 2px;
      row-gap: 0;
    }

    /* Portrait card */
    .ch-menu-card {
      position: relative;
      aspect-ratio: 3/4;
      overflow: hidden;
      cursor: pointer;
      background: #111;
    }
    .ch-menu-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.7s ease, filter 0.4s ease;
      filter: brightness(0.72);
    }
    .ch-menu-card:hover img,
    .ch-menu-card.open img {
      transform: scale(1.06);
      filter: brightness(1);
    }
    .ch-menu-card-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, transparent 60%);
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 24px;
      pointer-events: none;
    }
    .ch-menu-card-name {
      font-family: var(--font-display);
      font-size: clamp(22px, 2.2vw, 34px);
      letter-spacing: 2px;
      color: var(--white);
      line-height: 1;
      margin-bottom: 7px;
      transition: color 0.2s ease;
    }
    .ch-menu-card:hover .ch-menu-card-name,
    .ch-menu-card.open .ch-menu-card-name { color: var(--gold); }
    .ch-menu-card-tagline {
      font-size: 8px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.45);
    }
    @media (min-width: 769px) {
      .ch-menu-card-tagline {
        background: linear-gradient(90deg, #c9a84c 0%, #f5820a 50%, #c9a84c 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
      }
    }
    .ch-menu-card-plus {
      position: absolute;
      top: 16px;
      right: 16px;
      width: 28px;
      height: 28px;
      border: 1px solid rgba(201,168,76,0.35);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--gold);
      font-size: 13px;
      transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1), border-color 0.2s, background 0.2s;
    }
    .ch-menu-card.open .ch-menu-card-plus {
      transform: rotate(45deg);
      border-color: var(--gold);
      background: rgba(201,168,76,0.1);
    }

    /* Full-width expand panel — spans all columns in its row */
    .ch-menu-expand {
      grid-column: 1 / -1;
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.55s cubic-bezier(0.16,0.84,0.44,1);
      background: #0d0d0d;
    }
    .ch-menu-expand.open { grid-template-rows: 1fr; }
    .ch-menu-expand-inner { overflow: hidden; }
    .ch-menu-expand-content {
      display: grid;
      grid-template-columns: 320px 1fr 260px;
      gap: 0;
      border-top: 1px solid rgba(201,168,76,0.12);
    }
    .ch-menu-expand-img { overflow: hidden; }
    .ch-menu-expand-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      min-height: 300px;
      display: block;
    }
    .ch-menu-expand-name {
      font-family: var(--font-display);
      font-size: clamp(36px, 4vw, 56px);
      letter-spacing: 4px;
      color: var(--white);
      line-height: 0.9;
    }
    .ch-menu-info {
      display: flex;
      flex-direction: column;
      gap: 20px;
      padding: 40px 48px;
      border-left: 1px solid rgba(201,168,76,0.08);
      border-right: 1px solid rgba(201,168,76,0.08);
    }
    .ch-menu-description {
      font-size: 14px;
      line-height: 1.9;
      color: rgba(255,255,255,0.6);
      font-weight: 300;
    }
    .ch-menu-process-label {
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 6px;
    }
    .ch-menu-process {
      font-size: 12px;
      line-height: 1.7;
      color: rgba(255,255,255,0.35);
      font-weight: 300;
    }
    .ch-menu-inquire {
      display: inline-block;
      margin-top: 8px;
      padding: 12px 32px;
      border: 1px solid rgba(201,168,76,0.35);
      font-size: 9px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      transition: border-color 0.2s ease, background 0.2s ease;
      align-self: flex-start;
    }
    .ch-menu-inquire:hover { border-color: var(--gold); background: rgba(201,168,76,0.07); }

    /* Specs column */
    .ch-menu-specs {
      padding: 40px 32px;
      display: flex;
      flex-direction: column;
      gap: 16px;
    }
    .ch-menu-variants {
      border-bottom: 1px solid rgba(201,168,76,0.1);
      padding-bottom: 16px;
      margin-bottom: 4px;
    }
    .ch-menu-variants-label {
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 10px;
    }
    .ch-menu-variant-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 8px 0;
      border-bottom: 1px solid rgba(255,255,255,0.04);
      font-size: 12px;
    }
    .ch-menu-variant-row:last-child { border-bottom: none; }
    .ch-menu-variant-name { color: rgba(255,255,255,0.8); letter-spacing: 1px; }
    .ch-menu-variant-type {
      font-size: 8px;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.3);
      border: 1px solid rgba(255,255,255,0.08);
      padding: 2px 6px;
    }
    .ch-menu-variant-price { color: var(--gold); font-weight: 500; }
    .ch-menu-pricing {
      font-size: 11px;
      letter-spacing: 2px;
      color: rgba(255,255,255,0.35);
      font-style: italic;
    }
    .ch-menu-details { display: flex; flex-direction: column; gap: 6px; }
    .ch-menu-detail-row {
      display: flex;
      justify-content: space-between;
      font-size: 10px;
      letter-spacing: 1px;
      padding: 4px 0;
      border-bottom: 1px solid rgba(255,255,255,0.04);
    }
    .ch-menu-detail-row:last-child { border-bottom: none; }
    .ch-menu-detail-label { color: rgba(255,255,255,0.3); text-transform: uppercase; letter-spacing: 2px; }
    .ch-menu-detail-value { color: rgba(255,255,255,0.65); text-align: right; }

    /* COA inside menu expand */
    .ch-menu-coa {
      border-top: 1px solid rgba(201,168,76,0.1);
    }

    @media (max-width: 768px) {
      .ch-menu-list { padding: 32px 8px 60px; }
      .ch-menu-row { grid-template-columns: repeat(2, 1fr); }
      .ch-menu-expand-content { grid-template-columns: 1fr; }
      .ch-menu-expand-img { min-height: 200px; }
      .ch-menu-info { padding: 24px; border-left: none; border-right: none; }
      .ch-menu-specs { display: none; }
    }

    /* Wholesale strip */
    .ch-menu-wholesale {
      background: #0d0d0d;
      border-top: 1px solid rgba(201,168,76,0.15);
      padding: 80px 48px;
      text-align: center;
    }
    .ch-menu-wholesale h2 {
      font-family: var(--font-display);
      font-size: clamp(36px, 5vw, 64px);
      letter-spacing: 3px;
      color: var(--white);
      margin-bottom: 20px;
    }
    .ch-menu-wholesale p {
      font-size: 14px;
      line-height: 1.8;
      color: rgba(255,255,255,0.5);
      max-width: 560px;
      margin: 0 auto 32px;
    }

    /* Sub-page mobile */
    @media (max-width: 768px) {
      .ch-about-body,
      .ch-shop-header,
      .ch-shop-category,
      .ch-stores-header,
      .ch-stores-list,
      .ch-contact-header,
      .ch-contact-form-wrap,
      .ch-menu-header,
      .ch-menu-wholesale { padding-left: 24px; padding-right: 24px; }
      .ch-about-hero-overlay { padding: 48px 24px; }
      .ch-store-item { flex-direction: column; align-items: flex-start; gap: 16px; }
      .ch-store-state { display: none; }
    }
    /* ============ BLOG ============ */
    .ch-blog-page { padding: 0 5%; background: var(--black); }
    .ch-blog-header {
      padding: 150px 0 56px;
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      border-bottom: 1px solid rgba(201,168,76,0.15);
      gap: 40px;
    }
    .ch-blog-header-left h1 {
      font-family: var(--font-display);
      font-size: clamp(52px, 7vw, 100px);
      letter-spacing: 3px;
      color: var(--white);
      line-height: 0.9;
    }
    .ch-blog-header-left p {
      font-size: 10px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: rgba(245,240,232,0.35);
      margin-top: 14px;
    }
    .ch-blog-controls {
      display: flex;
      align-items: center;
      gap: 16px;
      flex-shrink: 0;
    }
    .ch-blog-search {
      background: transparent;
      border: 1px solid rgba(201,168,76,0.2);
      color: var(--white);
      font-family: var(--font-body);
      font-size: 11px;
      letter-spacing: 2px;
      padding: 10px 16px;
      outline: none;
      width: 220px;
      transition: border-color 0.3s;
    }
    .ch-blog-search::placeholder { color: rgba(255,255,255,0.2); }
    .ch-blog-search:focus { border-color: rgba(201,168,76,0.55); }
    .ch-blog-sort {
      background: transparent;
      border: 1px solid rgba(201,168,76,0.2);
      color: rgba(255,255,255,0.6);
      font-family: var(--font-body);
      font-size: 10px;
      letter-spacing: 2px;
      padding: 10px 14px;
      outline: none;
      cursor: pointer;
      transition: border-color 0.3s;
      appearance: none;
    }
    .ch-blog-sort:focus { border-color: rgba(201,168,76,0.55); }

    /* Featured post — full width hero card */
    .ch-blog-featured {
      margin: 48px 0 0;
      position: relative;
      cursor: pointer;
      overflow: hidden;
      height: 420px;
      border: 1px solid rgba(201,168,76,0.1);
    }
    .ch-blog-featured img {
      width: 100%; height: 100%;
      object-fit: cover;
      filter: brightness(0.45);
      transition: filter 0.5s ease, transform 0.7s ease;
      display: block;
    }
    .ch-blog-featured:hover img { filter: brightness(0.35); transform: scale(1.02); }
    .ch-blog-featured.ch-active img { filter: brightness(0.25); }
    .ch-blog-featured-overlay {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 48px 56px;
      background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.15) 60%, transparent 100%);
    }
    .ch-blog-featured-badge {
      font-size: 8px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(201,168,76,0.35);
      padding: 5px 12px;
      display: inline-block;
      margin-bottom: 16px;
      width: fit-content;
    }
    .ch-blog-featured h2 {
      font-family: var(--font-display);
      font-size: clamp(32px, 4vw, 64px);
      letter-spacing: 2px;
      color: var(--white);
      line-height: 0.95;
      max-width: 680px;
      margin-bottom: 14px;
    }
    .ch-blog-featured-meta {
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.35);
    }
    .ch-blog-featured.ch-active::after {
      content: '';
      position: absolute;
      bottom: 0; left: 0; right: 0;
      height: 2px;
      background: var(--gold);
    }

    /* 5-tile grid for remaining posts */
    .ch-blog-grid {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      border: 1px solid rgba(201,168,76,0.1);
      border-top: none;
      margin-bottom: 0;
    }
    .ch-blog-card {
      position: relative;
      cursor: pointer;
      overflow: hidden;
      aspect-ratio: 3/4;
      border-right: 1px solid rgba(201,168,76,0.08);
      user-select: none;
    }
    .ch-blog-card:last-child { border-right: none; }
    .ch-blog-card-img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
      filter: brightness(0.55);
      transition: filter 0.4s ease, transform 0.6s ease;
    }
    .ch-blog-card:hover .ch-blog-card-img { filter: brightness(0.4); transform: scale(1.05); }
    .ch-blog-card.ch-active .ch-blog-card-img { filter: brightness(0.3); transform: scale(1.05); }
    .ch-blog-card-overlay {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 20px 18px;
      background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.05) 55%, transparent 100%);
    }
    .ch-blog-card-cat {
      font-size: 7px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 6px;
      display: block;
    }
    .ch-blog-card h2 {
      font-family: var(--font-display);
      font-size: clamp(12px, 1.2vw, 18px);
      letter-spacing: 0.5px;
      color: var(--white);
      line-height: 1.05;
      margin: 0;
    }
    .ch-blog-card.ch-active::after {
      content: '';
      position: absolute;
      bottom: 0; left: 0; right: 0;
      height: 2px;
      background: var(--gold);
    }

    /* Accordion expansion panel */
    .ch-blog-expand {
      overflow: hidden;
      max-height: 0;
      transition: max-height 0.65s ease;
    }
    .ch-blog-expand.ch-open { max-height: 5000px; }
    .ch-blog-expand-inner {
      padding: 72px 0 0;
      border-top: 1px solid rgba(201,168,76,0.15);
      position: relative;
    }
    .ch-expand-topbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 48px;
    }
    .ch-expand-nav {
      display: flex;
      align-items: center;
      gap: 32px;
    }
    .ch-expand-nav-btn {
      background: none;
      border: 1px solid rgba(201,168,76,0.2);
      color: rgba(255,255,255,0.4);
      font-family: var(--font-body);
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      padding: 10px 20px;
      cursor: pointer;
      transition: border-color 0.3s, color 0.3s;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .ch-expand-nav-btn:hover { border-color: var(--gold); color: var(--gold); }
    .ch-expand-nav-btn:disabled { opacity: 0.2; cursor: default; pointer-events: none; }
    .ch-expand-close {
      font-size: 8px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.25);
      background: none;
      border: none;
      cursor: pointer;
      padding: 0;
      transition: color 0.3s;
    }
    .ch-expand-close:hover { color: var(--gold); }
    .ch-expand-cat {
      font-size: 8px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      display: block;
      margin-bottom: 14px;
    }
    .ch-expand-title {
      font-family: var(--font-display);
      font-size: clamp(36px, 5vw, 82px);
      letter-spacing: 2px;
      color: var(--white);
      line-height: 0.95;
      margin: 0 0 20px;
    }
    .ch-expand-meta {
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.3);
      padding-bottom: 44px;
      border-bottom: 1px solid rgba(201,168,76,0.12);
      margin-bottom: 52px;
    }
    .ch-expand-bottombar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 40px 0 72px;
      border-top: 1px solid rgba(201,168,76,0.1);
      margin-top: 60px;
    }
    /* Blog post (direct URL) */
    .ch-post-hero {
      position: relative;
      width: 100%;
      height: 55vh;
      overflow: hidden;
    }
    .ch-post-hero img {
      width: 100%; height: 100%;
      object-fit: cover;
      filter: brightness(0.5);
    }
    .ch-post-hero-content {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 60px 10%;
    }
    .ch-post-cat {
      font-size: 9px;
      letter-spacing: 5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 16px;
    }
    .ch-post-title {
      font-family: var(--font-display);
      font-size: clamp(36px, 6vw, 90px);
      letter-spacing: 2px;
      line-height: 0.95;
      color: var(--white);
    }
    .ch-post-meta {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.4);
      margin-top: 20px;
    }
    .ch-post-body {
      max-width: 740px;
      margin: 0 auto;
      padding: 80px 48px 120px;
    }
    .ch-post-section { margin-bottom: 52px; }
    .ch-post-section h2 {
      font-family: var(--font-display);
      font-size: clamp(26px, 3vw, 42px);
      letter-spacing: 2px;
      color: var(--white);
      margin-bottom: 20px;
    }
    .ch-post-section p {
      font-size: 16px;
      line-height: 1.85;
      color: rgba(245,240,232,0.78);
    }
    .ch-post-section p + p { margin-top: 18px; }
    .ch-post-section strong { color: var(--gold); font-weight: 600; }
    .ch-post-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 60px;
      padding-top: 40px;
      border-top: 1px solid rgba(201,168,76,0.15);
    }
    .ch-post-tag {
      font-size: 9px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(201,168,76,0.35);
      padding: 6px 14px;
      border-radius: 20px;
    }
    .ch-post-back {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.45);
      text-decoration: none;
      margin-bottom: 48px;
      transition: color 0.3s ease;
    }
    .ch-post-back:hover { color: var(--gold); }
    /* Blog schema JSON-LD injected per post via JS */
    @media (max-width: 768px) {
      .ch-blog-page { padding: 0 4%; }
      .ch-blog-header { flex-direction: column; align-items: flex-start; padding-top: 120px; }
      .ch-blog-controls { width: 100%; }
      .ch-blog-search { width: 100%; }
      .ch-blog-featured { height: 280px; }
      .ch-blog-featured-overlay { padding: 28px 24px; }
      .ch-blog-grid { grid-template-columns: repeat(2, 1fr); }
      .ch-expand-topbar { flex-direction: column; align-items: flex-start; gap: 20px; }
      .ch-post-body { padding: 48px 24px 80px; }
      .ch-post-hero-content { padding: 40px 24px; }
    }