
    /* HERO */
    .page-hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; background: var(--navy); overflow: hidden; }
    .page-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 40%; opacity: .3; }
    .page-hero::before { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(160deg, oklch(11% 0.08 282 / .97) 0%, oklch(11% 0.08 282 / .65) 60%, oklch(11% 0.08 282 / .3) 100%); }
    .page-hero::after { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; background-image: linear-gradient(oklch(99% 0.005 88 / .018) 1px, transparent 1px), linear-gradient(90deg, oklch(99% 0.005 88 / .018) 1px, transparent 1px); background-size: 80px 80px; }
    .page-hero-inner { position: relative; z-index: 2; padding: clamp(110px, 13vw, 168px) 0 clamp(64px, 8vw, 96px); display: flex; flex-direction: column; gap: 20px; }
    .page-hero-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--orange); display: flex; align-items: center; gap: 12px; }
    .page-hero-eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--orange); flex-shrink: 0; }
    .page-hero-h { font-family: var(--ff-d); font-weight: 900; font-size: clamp(38px, 6.5vw, 88px); letter-spacing: -0.04em; line-height: 0.94; color: var(--ink); }
    .page-hero-h em { font-style: normal; color: var(--orange); }
    .page-hero-sub { font-size: clamp(14px, 1.5vw, 17px); color: oklch(99% 0.005 88 / .55); line-height: 1.65; max-width: 52ch; }
    .page-hero-breadcrumb { position: absolute; bottom: 32px; right: clamp(20px, 4vw, 40px); z-index: 2; display: flex; align-items: center; gap: 10px; font-size: 11px; color: oklch(99% 0.005 88 / .35); letter-spacing: .04em; }
    .page-hero-breadcrumb a { color: oklch(99% 0.005 88 / .45); transition: color .2s; }
    .page-hero-breadcrumb a:hover { color: var(--orange); }
    .page-hero-breadcrumb > span { color: var(--orange); font-weight: 600; }

    .hero-stats { display: flex; flex-wrap: wrap; margin-top: 12px; }
    .hs-cell { padding: 16px 32px 16px 0; margin-right: 32px; border-right: 1px solid oklch(99% 0.005 88 / .12); }
    .hs-cell:last-child { border-right: none; margin-right: 0; }
    .hs-n { font-family: var(--ff-d); font-weight: 900; font-size: clamp(28px, 3.5vw, 44px); letter-spacing: -0.04em; line-height: 1; color: var(--ink); }
    .hs-n sup { font-size: .5em; vertical-align: .3em; }
    .hs-n.c-orange { color: var(--orange); }
    .hs-n.c-lime   { color: var(--lime); }
    .hs-l { font-size: 10px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: oklch(99% 0.005 88 / .45); margin-top: 4px; }

    /* OVERVIEW */
    .overview { background: var(--cream); }
    .overview-inner { padding: clamp(72px, 9vw, 108px) 0; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
    .overview-txt .lbl { color: var(--orange); margin-bottom: 20px; }
    .overview-txt h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(28px, 3.5vw, 48px); letter-spacing: -0.03em; color: var(--forest); line-height: 1.08; margin-bottom: 20px; }
    .overview-txt h2 em { font-style: normal; color: var(--orange); }
    .overview-txt p { font-size: 15px; line-height: 1.75; color: var(--muted); margin-bottom: 16px; }
    .overview-feats { display: flex; flex-direction: column; gap: 12px; margin-top: 28px; }
    .ov-feat { display: flex; align-items: flex-start; gap: 14px; padding: 16px 20px; background: var(--ink); border-radius: 6px; border: 1px solid oklch(22% 0.093 282 / .07); }
    .ov-feat-ico { width: 36px; height: 36px; border-radius: 6px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: oklch(74.9% 0.166 61 / .1); color: var(--orange); }
    .ov-feat-body strong { font-size: 13px; font-weight: 700; color: var(--forest); display: block; margin-bottom: 3px; }
    .ov-feat-body span { font-size: 12px; color: var(--muted); line-height: 1.5; }
    .overview-visual { position: relative; }
    .overview-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 8px; box-shadow: 0 24px 64px oklch(22% 0.093 282 / .16); }
    .overview-360 {
      position: relative; width: 100%; aspect-ratio: 340/470;
      border-radius: 8px; overflow: hidden;
      background: linear-gradient(180deg, #b9e4f5 0%, #d5ecf2 55%, #b8d99c 100%);
      box-shadow: 0 24px 64px oklch(22% 0.093 282 / .16);
      cursor: grab; touch-action: none; user-select: none;
    }
    .overview-360.dragging { cursor: grabbing; }
    .overview-360 img {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: contain;
      user-select: none; pointer-events: none;
      -webkit-user-drag: none;
    }
    .overview-360-tag {
      position: absolute; top: 14px; left: 14px;
      display: inline-flex; align-items: center; gap: 6px;
      padding: 6px 11px;
      background: oklch(22% 0.093 282 / .82);
      backdrop-filter: blur(8px);
      border-radius: 4px;
      color: var(--ink); font-size: 10px; font-weight: 700;
      letter-spacing: .14em; text-transform: uppercase;
      pointer-events: none;
    }
    .overview-360-tag::before {
      content: ''; width: 6px; height: 6px; border-radius: 50%;
      background: var(--orange);
      box-shadow: 0 0 0 3px oklch(74.9% 0.166 61 / .25);
      animation: ov360pulse 1.6s ease-in-out infinite;
    }
    @keyframes ov360pulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
    .overview-360-hint {
      position: absolute; bottom: 16px; left: 50%;
      transform: translateX(-50%);
      display: inline-flex; align-items: center; gap: 8px;
      padding: 8px 14px;
      background: oklch(22% 0.093 282 / .72);
      backdrop-filter: blur(8px);
      border-radius: 999px;
      color: var(--ink);
      font-size: 11px; font-weight: 600;
      letter-spacing: .08em; text-transform: uppercase;
      pointer-events: none; white-space: nowrap;
      transition: opacity .5s ease, transform .5s ease;
    }
    .overview-360.interacted .overview-360-hint { opacity: 0; transform: translateX(-50%) translateY(6px); }
    .overview-360-hint svg { animation: ov360swipe 2s ease-in-out infinite; }
    @keyframes ov360swipe { 0%, 100% { transform: translateX(-3px); } 50% { transform: translateX(3px); } }
    .overview-badge { position: absolute; bottom: -20px; left: -20px; background: var(--navy); color: var(--ink); padding: 20px 24px; border-radius: 8px; box-shadow: 0 12px 36px oklch(22% 0.093 282 / .28); z-index: 2; }
    .overview-badge strong { font-size: 32px; font-weight: 900; letter-spacing: -0.04em; color: var(--orange); display: block; line-height: 1; }
    .overview-badge span { font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: oklch(99% 0.005 88 / .5); }

    /* WHY VIDEOTRON */
    .why-vt { background: var(--navy); position: relative; overflow: hidden; }
    .why-vt::after { content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none; background-image: linear-gradient(oklch(99% 0.005 88 / .016) 1px, transparent 1px), linear-gradient(90deg, oklch(99% 0.005 88 / .016) 1px, transparent 1px); background-size: 80px 80px; }
    .why-vt .wrap { position: relative; z-index: 1; }
    .why-vt-inner { padding: clamp(72px, 9vw, 108px) 0; }
    .why-vt-hdr { margin-bottom: 56px; }
    .why-vt-hdr .lbl { color: var(--orange); margin-bottom: 20px; }
    .why-vt-hdr h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(26px, 3.5vw, 48px); letter-spacing: -0.03em; color: var(--ink); line-height: 1.08; }
    .why-vt-hdr h2 em { font-style: normal; color: var(--orange); }
    .why-vt-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
    .why-vt-item { background: oklch(99% 0.005 88 / .04); padding: 40px 32px; border: 1px solid oklch(99% 0.005 88 / .07); transition: background .25s; }
    .why-vt-item:hover { background: oklch(99% 0.005 88 / .08); }
    .why-vt-ico { width: 48px; height: 48px; border-radius: 8px; margin-bottom: 24px; display: flex; align-items: center; justify-content: center; background: oklch(74.9% 0.166 61 / .12); color: var(--orange); border: 1px solid oklch(74.9% 0.166 61 / .2); }
    .why-vt-ico.lime { background: oklch(81.3% 0.173 121 / .1); color: var(--lime); border-color: oklch(81.3% 0.173 121 / .2); }
    .why-vt-num { font-family: var(--ff-d); font-weight: 900; font-size: clamp(38px, 4vw, 56px); letter-spacing: -0.05em; color: oklch(99% 0.005 88 / .05); line-height: 1; margin-bottom: 12px; }
    .why-vt-title { font-family: var(--ff-d); font-size: 16px; font-weight: 700; color: var(--ink); margin-bottom: 10px; }
    .why-vt-txt { font-size: 13px; line-height: 1.7; color: oklch(99% 0.005 88 / .52); }

    /* COVERAGE */
    .coverage { background: var(--ink); }
    .coverage-inner { padding: clamp(72px, 9vw, 108px) 0; }
    .coverage-hdr { margin-bottom: 56px; }
    .coverage-hdr .lbl { color: var(--orange); margin-bottom: 20px; }
    .coverage-hdr h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(26px, 3.5vw, 48px); letter-spacing: -0.03em; color: var(--forest); line-height: 1.08; }
    .coverage-hdr h2 em { font-style: normal; color: var(--orange); }
    .coverage-hdr p { font-size: 15px; color: var(--muted); margin-top: 12px; max-width: 52ch; line-height: 1.7; }
    .coverage-regions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
    .cov-region h3 { font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--orange); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid oklch(22% 0.093 282 / .1); }
    .cov-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
    .cov-list li { display: flex; flex-direction: column; gap: 2px; padding: 10px 14px; border-radius: 4px; background: var(--cream); border: 1px solid oklch(22% 0.093 282 / .07); }
    .cov-list li strong { font-size: 13px; font-weight: 600; color: var(--forest); }
    .cov-list li span { font-size: 11px; color: var(--muted); }
    .cov-more { font-size: 12px; color: var(--muted); text-align: center; margin-top: 40px; }
    .cov-more strong { color: var(--orange); }

    /* TECH SPECS */
    .techspec { background: var(--cream); }
    .techspec-inner { padding: clamp(72px, 9vw, 108px) 0; }
    .techspec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
    .techspec-txt .lbl { color: var(--orange); margin-bottom: 20px; }
    .techspec-txt h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(26px, 3vw, 44px); letter-spacing: -0.03em; color: var(--forest); line-height: 1.08; margin-bottom: 20px; }
    .techspec-txt h2 em { font-style: normal; color: var(--orange); }
    .techspec-txt p { font-size: 14px; line-height: 1.75; color: var(--muted); }
    .spec-row { display: flex; justify-content: space-between; align-items: flex-start; padding: 14px 0; border-bottom: 1px solid oklch(22% 0.093 282 / .08); gap: 24px; }
    .spec-row:last-child { border-bottom: none; }
    .spec-key { font-size: 12px; font-weight: 600; color: var(--muted); flex-shrink: 0; width: 160px; }
    .spec-val { font-size: 13px; font-weight: 600; color: var(--forest); text-align: right; }

    /* RELATED */
    .related { background: var(--ink); }
    .related-inner { padding: clamp(72px, 9vw, 108px) 0; }
    .related-hdr { margin-bottom: 48px; }
    .related-hdr .lbl { color: var(--orange); margin-bottom: 16px; }
    .related-hdr h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(24px, 3vw, 40px); letter-spacing: -0.03em; color: var(--forest); line-height: 1.08; }
    .related-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

    .prod-card { background: var(--cream); border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .3s, transform .3s; }
    .prod-card:hover { box-shadow: 0 16px 48px oklch(22% 0.093 282 / .14); transform: translateY(-4px); }
    .prod-card-img { position: relative; aspect-ratio: 3/2; overflow: hidden; }
    .prod-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
    .prod-card:hover .prod-card-img img { transform: scale(1.05); }
    .prod-card-img-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, oklch(9% 0.08 282 / .72) 0%, oklch(9% 0.08 282 / .15) 55%, transparent 100%); }
    .prod-tag { position: absolute; top: 16px; left: 16px; z-index: 2; font-size: 9px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; padding: 5px 10px; border-radius: 3px; }
    .prod-tag-transit { background: var(--lime); color: oklch(22% 0.093 282); }
    .prod-tag-captive { background: oklch(99% 0.005 88 / .15); color: var(--ink); border: 1px solid oklch(99% 0.005 88 / .3); backdrop-filter: blur(8px); }
    .prod-card-body { padding: 28px 28px 32px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
    .prod-card-name { font-family: var(--ff-d); font-weight: 700; font-size: clamp(22px, 2.2vw, 28px); letter-spacing: -0.025em; color: var(--forest); line-height: 1.1; }
    .prod-card-desc { font-size: 14px; line-height: 1.75; color: var(--muted); flex: 1; }
    .prod-specs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
    .prod-spec { display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 4px; font-size: 11px; font-weight: 600; background: var(--ink); color: var(--muted); border: 1px solid oklch(22% 0.093 282 / .1); }
    .prod-spec strong { color: var(--forest); }
    .prod-card-cta { margin-top: 8px; }

    /* GALLERY */
    .gallery { background: oklch(14% 0.07 282); }
    .gallery-inner { padding: clamp(72px, 9vw, 108px) 0; }
    .gallery-hdr { margin-bottom: 40px; display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
    .gallery-hdr-txt .lbl { color: var(--orange); margin-bottom: 16px; }
    .gallery-hdr-txt h2 { font-family: var(--ff-d); font-weight: 700; font-size: clamp(24px, 3vw, 44px); letter-spacing: -0.03em; color: var(--ink); line-height: 1.08; }
    .gallery-hdr-txt h2 em { font-style: normal; color: var(--orange); }
    .gallery-hdr-meta { font-size: 12px; color: oklch(99% 0.005 88 / .35); letter-spacing: .04em; flex-shrink: 0; }

    .gallery-mosaic {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      grid-template-rows: 320px 240px;
      gap: 6px;
    }
    .gm-item { overflow: hidden; border-radius: 4px; position: relative; cursor: zoom-in; }
    .gm-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .65s cubic-bezier(.25,.46,.45,.94); display: block; }
    .gm-item:hover img { transform: scale(1.05); }
    .gm-item::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(0deg, oklch(8% 0.07 282 / .55) 0%, transparent 55%);
      opacity: 0; transition: opacity .35s;
    }
    .gm-item:hover::after { opacity: 1; }
    .gm-wide { grid-column: 1 / 3; }

    /* Lightbox */
    .lb { position: fixed; inset: 0; z-index: 9999; background: oklch(5% 0.04 282 / .96); display: flex; flex-direction: column; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity .25s; padding: 64px 24px 48px; }
    .lb.open { opacity: 1; pointer-events: all; }
    .lb-row { display: flex; align-items: center; justify-content: center; width: 100%; }
    .lb img { max-width: min(80vw, 1100px); max-height: 80vh; object-fit: contain; border-radius: 4px; box-shadow: 0 32px 96px oklch(0% 0 0 / .6); }
    .lb-close { position: absolute; top: 20px; right: 24px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: oklch(99% 0.005 88 / .1); border: 1px solid oklch(99% 0.005 88 / .2); border-radius: 50%; color: var(--ink); cursor: pointer; transition: background .2s; font-size: 20px; line-height: 1; }
    .lb-close:hover { background: oklch(99% 0.005 88 / .2); }
    .lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: oklch(99% 0.005 88 / .08); border: 1px solid oklch(99% 0.005 88 / .18); border-radius: 50%; color: var(--ink); cursor: pointer; transition: background .2s; }
    .lb-prev { left: 16px; }
    .lb-next { right: 16px; }
    .lb-nav:hover { background: oklch(99% 0.005 88 / .2); }
    .lb-counter { margin-top: 16px; font-size: 11px; color: oklch(99% 0.005 88 / .4); letter-spacing: .1em; }

 
    @media (max-width: 1024px) {
      .gallery-mosaic { grid-template-rows: 260px 200px; }
    }
    @media (max-width: 768px) {
      .gallery-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
      .gm-wide { grid-column: 1 / 3; }
    }
    @media (max-width: 480px) {
      .gallery-mosaic { grid-template-columns: 1fr; grid-template-rows: auto; }
      .gm-item { height: 220px; }
      .gm-wide { grid-column: auto; }
    }
