/* ============================================
   QUALITY MANAGEMENT PAGE
   ============================================ */

/* ---- Shared typography ---- */
.qm-label { display: block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: var(--font-semibold); letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--color-text-primary); margin-bottom: var(--space-4); }
.qm-heading { font-family: var(--font-heading); font-size: var(--text-section); font-weight: var(--font-semibold); line-height: var(--leading-tight); letter-spacing: -0.6px; color: var(--color-text-primary); margin: 0 0 var(--space-6); }
.qm-intro { font-family: var(--font-body); font-size: var(--text-lg); color: var(--color-text-secondary); line-height: var(--leading-normal); max-width: var(--text-max-width); margin: 0; }
.qm-body { font-family: var(--font-body); font-size: var(--text-base); color: var(--color-text-secondary); line-height: var(--leading-normal); margin: 0 0 var(--space-5); }
.qm-section-title { font-family: var(--font-heading); font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: var(--font-semibold); line-height: var(--leading-tight); letter-spacing: -0.6px; color: var(--color-text-primary); margin: 0 0 var(--space-5); }


/* ============================================
   1. HERO — Split: title left, PDCA cycle right
   ============================================ */
.qm-hero {
    position: relative;
    min-height: 100vh;
    background: #FFFFFF;
    overflow: hidden;
    display: flex;
    align-items: center;
}

/* Halftone dot field — two scales of dots + a soft radial bloom anchored on the
   PDCA cycle. Rings (.qm-hero__ripple children) ride on top, expanding outward
   to embody "Continuous Improvement". */
.qm-hero__grid-bg {
    position: absolute; inset: 0;
    background-color: #FFFFFF;
    background-image:
        radial-gradient(ellipse 60% 70% at 80% 50%, rgba(50,48,47,0.07) 0%, rgba(50,48,47,0.02) 45%, transparent 75%),
        radial-gradient(circle, rgba(50,48,47,0.18) 1.4px, transparent 1.6px),
        radial-gradient(circle, rgba(50,48,47,0.07) 0.9px, transparent 1.1px);
    background-size: cover, 96px 96px, 24px 24px;
    background-position: center, 0 0, 0 0;
    overflow: hidden;
    pointer-events: none;
}

/* Top white fade so the header sits cleanly over the dot field */
.qm-hero__grid-bg::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 220px;
    background: linear-gradient(to bottom, #FFFFFF, transparent); z-index: 3;
    pointer-events: none;
}

/* Expanding rings — children of .qm-hero__cycle, so they're always perfectly
   concentric with the PDCA ring regardless of layout. */
.qm-hero__ripple {
    position: absolute;
    top: 50%; left: 50%;
    width: 100%; height: 100%;
    border-radius: 50%;
    border: 1.5px solid rgba(50,48,47,0.22);
    transform: translate(-50%, -50%) scale(0.25);
    opacity: 0;
    animation: qmRipple 7s cubic-bezier(0.22, 1, 0.36, 1) infinite;
    pointer-events: none;
    z-index: 0;
}

.qm-hero__ripple:nth-child(1) { animation-delay: 0s; }
.qm-hero__ripple:nth-child(2) { animation-delay: 1.75s; }
.qm-hero__ripple:nth-child(3) { animation-delay: 3.5s; }
.qm-hero__ripple:nth-child(4) { animation-delay: 5.25s; }

@keyframes qmRipple {
    0%   { transform: translate(-50%, -50%) scale(0.25); opacity: 0;    border-width: 2px; }
    8%   { opacity: 0.85; }
    100% { transform: translate(-50%, -50%) scale(3.6);  opacity: 0;    border-width: 0.5px; }
}

@media (prefers-reduced-motion: reduce) {
    .qm-hero__ripple { animation: none; opacity: 0.25; transform: translate(-50%, -50%) scale(1.2); }
    .qm-hero__ripple:nth-child(2) { transform: translate(-50%, -50%) scale(1.8); opacity: 0.18; }
    .qm-hero__ripple:nth-child(3) { transform: translate(-50%, -50%) scale(2.5); opacity: 0.12; }
    .qm-hero__ripple:nth-child(4) { transform: translate(-50%, -50%) scale(3.2); opacity: 0.07; }
}

.qm-hero__inner {
    position: relative; z-index: 2;
    display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--space-12);
    max-width: 1600px; margin: 0 auto;
    padding: 160px var(--container-padding) clamp(60px, 8vw, 100px);
    align-items: center; min-height: 100vh;
}

.qm-hero__left { position: relative; display: flex; flex-direction: column; gap: var(--space-6); }

.qm-hero__ghost {
    position: absolute; top: -0.35em; left: -0.05em;
    font-family: var(--font-heading); font-size: clamp(6rem, 14vw, 14rem); font-weight: 800;
    color: rgba(50,48,47,0.04); line-height: 0.85; letter-spacing: -0.04em;
    white-space: nowrap; pointer-events: none; user-select: none;
}

.qm-hero__eyebrow { font-family: var(--font-body); font-size: 0.7rem; font-weight: var(--font-semibold); letter-spacing: 0.3em; text-transform: uppercase; color: var(--color-text-secondary); }

.qm-hero__title { display: flex; flex-direction: column; margin: 0; }

.qm-hero__line--display { font-family: var(--font-display); font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 600; line-height: 1.05; letter-spacing: -2px; color: var(--color-text-primary); }

.qm-hero__line--script {
    font-family: 'Dancing Script', cursive; font-size: clamp(2.6rem, 6.5vw, 6rem); font-weight: 700;
    line-height: 1; color: var(--color-text-primary); display: block; position: relative; padding-bottom: 0.2em;
}

.qm-hero__line--script::after {
    content: ''; position: absolute; left: 0; bottom: 0; width: 55%; height: 0.18em;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 16' preserveAspectRatio='none'%3E%3Cpath d='M 4,8 C 50,3 130,2 200,6 C 270,10 350,8 396,5 C 350,11 270,15 200,12 C 130,9 50,12 4,13 Z' fill='%23FF1A0F' opacity='0.92'/%3E%3C/svg%3E");
    background-size: 100% 100%; background-repeat: no-repeat;
}

.qm-hero__lead { font-family: var(--font-body); font-size: var(--text-lg); color: var(--color-text-secondary); line-height: var(--leading-normal); max-width: 460px; }

/* ---- Right: Quality check mark — mirrors .sv-reno__diagram-icon scaled up ---- */
.qm-hero__right { display: flex; justify-content: center; }

.qm-hero__mark {
    position: relative;
    width: clamp(360px, 36vw, 520px);
    height: clamp(360px, 36vw, 520px);
    display: flex; align-items: center; justify-content: center;
}

.qm-hero__mark-badge {
    width: 100%; height: 100%;
    border-radius: 50%;
    background: #FFFFFF;
    border: 1.5px solid var(--color-text-primary);
    display: flex; align-items: center; justify-content: center;
    position: relative; z-index: 1;
}

.qm-hero__mark-badge i {
    font-size: clamp(8rem, 13vw, 14rem);
    color: var(--color-text-primary);
    line-height: 1;
}

/* Outer thin marker ring — same minimalist hint of structure the cycle had */
.qm-hero__mark::before {
    content: '';
    position: absolute;
    inset: -20px;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    pointer-events: none;
}

@media (max-width: 1024px) {
    .qm-hero__inner { grid-template-columns: 1fr; padding-top: 130px; min-height: auto; }
    .qm-hero__ghost { font-size: clamp(4rem, 18vw, 8rem); }
    .qm-hero__mark { width: clamp(280px, 70vw, 360px); height: clamp(280px, 70vw, 360px); }
    .qm-hero__mark-badge i { font-size: clamp(6rem, 28vw, 10rem); }
    /* Reposition the bloom under the title where the PDCA cycle now lives.
       Ripples are already children of the cycle, so they follow it automatically. */
    .qm-hero__grid-bg {
        background-image:
            radial-gradient(ellipse 90% 50% at 50% 78%, rgba(50,48,47,0.07) 0%, rgba(50,48,47,0.02) 45%, transparent 75%),
            radial-gradient(circle, rgba(50,48,47,0.16) 1.3px, transparent 1.5px),
            radial-gradient(circle, rgba(50,48,47,0.06) 0.8px, transparent 1px);
    }
}


/* ============================================
   2. APPROACH — Mirrors .sc-house from subcontractor page
   (header → framed feature image → 3-stat grid)
   ============================================ */
.qm-approach {
    padding: clamp(80px, 10vw, 140px) 0;
    background: #fafaf8;
}

.qm-approach__inner {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 clamp(24px, 4vw, 80px);
}

.qm-approach__header {
    max-width: 880px;
    margin-bottom: clamp(40px, 5vw, 64px);
}

.qm-approach__heading {
    font-family: var(--font-heading);
    font-size: clamp(3.5rem, 7vw, 6rem);
    font-weight: 400;
    line-height: 1.05;
    color: var(--color-text-primary);
    letter-spacing: -1.5px;
    margin-bottom: var(--space-5);
}

.qm-approach__lead,
.qm-approach__body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: 1.65;
    color: var(--color-text-secondary);
    max-width: 720px;
    margin-bottom: var(--space-4);
}
.qm-approach__body:last-child { margin-bottom: 0; }

.qm-approach__feature {
    position: relative;
    border-radius: clamp(16px, 2vw, 28px);
    overflow: hidden;
    aspect-ratio: 16 / 8;
    margin: 0 0 clamp(56px, 7vw, 96px);
}

.qm-approach__feature-img {
    width: 100%; height: 100%;
    object-fit: cover;
}

.qm-approach__feature-frame { position: absolute; inset: 0; pointer-events: none; }
.qm-approach__feature-corner {
    position: absolute;
    width: 40px; height: 40px;
}
.qm-approach__feature-corner::before,
.qm-approach__feature-corner::after {
    content: ''; position: absolute;
    background: rgba(255, 255, 255, 0.5);
}
.qm-approach__feature-corner::before { width: 1px; height: 100%; }
.qm-approach__feature-corner::after { width: 100%; height: 1px; }
.qm-approach__feature-corner--tl { top: 20px; left: 20px; }
.qm-approach__feature-corner--tl::before { left: 0; }
.qm-approach__feature-corner--tl::after { top: 0; }
.qm-approach__feature-corner--br { bottom: 20px; right: 20px; }
.qm-approach__feature-corner--br::before { right: 0; }
.qm-approach__feature-corner--br::after { bottom: 0; }

.qm-approach__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(24px, 3vw, 56px);
}

.qm-approach__stat {
    padding-top: clamp(28px, 3.5vw, 44px);
    border-top: 3px solid rgba(0, 0, 0, 0.12);
}

.qm-approach__stat-num {
    display: block;
    font-family: var(--font-heading);
    font-size: var(--text-xs);
    font-weight: 500;
    color: var(--color-text-secondary);
    letter-spacing: 0.18em;
    margin-bottom: var(--space-4);
}

.qm-approach__stat-title {
    font-family: var(--font-heading);
    font-size: clamp(3rem, 5.5vw, 4.5rem);
    font-weight: var(--font-bold);
    line-height: 1;
    color: var(--color-text-primary);
    letter-spacing: -0.04em;
    margin-bottom: clamp(12px, 1.5vw, 20px);
}

.qm-approach__stat-body {
    font-family: var(--font-body);
    font-size: clamp(1rem, 1.4vw, 1.25rem);
    font-weight: var(--font-regular);
    line-height: 1.4;
    color: var(--color-text-secondary);
}

@media (max-width: 900px) {
    .qm-approach__stats {
        grid-template-columns: 1fr;
        gap: 0;
    }
    .qm-approach__stat + .qm-approach__stat {
        margin-top: var(--space-6);
    }
}


/* ============================================
   3. QMS PILLARS — Numbered list (light theme)
   ============================================ */
.qm-pillars {
    background: transparent; padding: var(--section-padding) 0;
    position: relative; overflow: hidden;
}

.qm-pillars__inner { position: relative; z-index: 1; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); }

.qm-pillars__header { position: relative; margin-bottom: var(--space-12); }

.qm-pillars__ghost {
    font-family: var(--font-heading); font-size: clamp(5rem, 12vw, 10rem); font-weight: 800;
    color: rgba(50,48,47,0.04); line-height: 0.85; display: block; margin-bottom: var(--space-2);
    pointer-events: none; user-select: none;
}

.qm-pillars__header .qm-section-title { color: var(--color-text-primary); }

.qm-pillars__header p {
    font-family: var(--font-body); font-size: var(--text-base);
    color: var(--color-text-secondary); line-height: var(--leading-normal); max-width: 600px; margin: 0;
}

.qm-pillars__ripples { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; height: 100%; pointer-events: none; z-index: 0; }
.qm-pillars__circle { position: absolute; top: 50%; left: 50%; border-radius: 50%; border: 1px solid rgba(0,0,0,0.06); transform: translate(-50%, -50%); animation: qmPillarsRipple 9s ease-in-out infinite; }
.qm-pillars__circle--1 { width: 28vw; height: 28vw; }
.qm-pillars__circle--2 { width: 50vw; height: 50vw; animation-delay: 0.6s; }
.qm-pillars__circle--3 { width: 75vw; height: 75vw; animation-delay: 1.2s; }
.qm-pillars__circle--4 { width: 105vw; height: 105vw; animation-delay: 1.8s; }
@keyframes qmPillarsRipple { 0%, 100% { opacity: 0.5; transform: translate(-50%, -50%) scale(1); } 50% { opacity: 1; transform: translate(-50%, -50%) scale(1.04); } }

.qm-pillars__list { position: relative; display: flex; flex-direction: column; isolation: isolate; }
.qm-pillars__indicator { position: absolute; left: 0; right: 0; top: 0; height: 0; background: rgba(0,0,0,0.04); border-left: 3px solid var(--color-text-primary); z-index: 0; pointer-events: none; transition: transform 520ms cubic-bezier(0.4, 0, 0.1, 1), height 520ms cubic-bezier(0.4, 0, 0.1, 1); }

.qm-pillars__item {
    position: relative; z-index: 1;
    display: flex; align-items: center; gap: var(--space-6);
    padding: var(--space-6); border-bottom: 1px solid rgba(0,0,0,0.08);
    cursor: default; outline: none;
}
.qm-pillars__item:last-child { border-bottom: none; }

.qm-pillars__item-num {
    font-family: var(--font-heading); font-size: var(--text-3xl); font-weight: 700;
    color: var(--color-gray-300); flex-shrink: 0; min-width: 60px; line-height: 1;
    transition: color 280ms ease;
}
.qm-pillars__item:hover .qm-pillars__item-num,
.qm-pillars__item:focus .qm-pillars__item-num { color: var(--color-text-primary); }

.qm-pillars__item-text {
    font-family: var(--font-heading); font-size: clamp(1.1rem, 2vw, 1.5rem); font-weight: var(--font-semibold);
    color: var(--color-text-secondary); letter-spacing: -0.6px; line-height: var(--leading-snug); margin: 0;
    transition: color 280ms ease;
}
.qm-pillars__item:hover .qm-pillars__item-text,
.qm-pillars__item:focus .qm-pillars__item-text { color: var(--color-text-primary); }


/* ============================================
   4. STANDARDS — Three certification cards
   Blueprint sheet style
   ============================================ */
.qm-standards {
    background: transparent; padding: var(--section-padding) 0;
}

.qm-standards__inner { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); }

.qm-standards__header { margin-bottom: var(--space-12); max-width: 600px; }

.qm-standards__cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }

.qm-standards__card {
    background: var(--color-pure-white); border: 0.5px solid #d8d8d4;
    border-radius: 18px;
    position: relative; overflow: hidden;
    box-shadow: 0 22px 50px -28px rgba(0,0,0,0.22), 0 2px 6px rgba(0,0,0,0.04);
    transition: transform 520ms cubic-bezier(0.4, 0, 0.1, 1), box-shadow 520ms cubic-bezier(0.4, 0, 0.1, 1);
}

.qm-standards__card:hover {
    transform: translateY(-3px);
    box-shadow: 0 30px 60px -30px rgba(0,0,0,0.28), 0 4px 10px rgba(0,0,0,0.05);
}

.qm-standards__card-bar {
    display: flex; justify-content: space-between;
    padding: var(--space-2) var(--space-5); border-bottom: 0.5px solid #e4e4e0;
    font-family: 'Courier New', monospace; font-size: 0.55rem; font-weight: 700;
    letter-spacing: 0.2em; text-transform: uppercase; color: #b8b8b4;
    position: relative; z-index: 2;
}
.qm-standards__card-body { position: relative; z-index: 2; }

.qm-standards__card-body { padding: var(--space-6) var(--space-5); }

.qm-standards__card-title {
    font-family: var(--font-heading); font-size: var(--text-base); font-weight: var(--font-semibold);
    color: var(--color-text-primary); letter-spacing: -0.4px; margin: 0 0 var(--space-3);
}

.qm-standards__card-desc {
    font-family: var(--font-body); font-size: var(--text-sm); color: var(--color-text-secondary);
    line-height: var(--leading-normal); margin: 0;
}

@media (max-width: 768px) { .qm-standards__cards { grid-template-columns: 1fr; } }


/* ============================================
   5. QUOTE — Blueprint drawing sheet
   ============================================ */
.qm-quote { background: transparent; padding: var(--section-padding) 0; }

.qm-quote__inner { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); }

.qm-quote__sheet {
    background: var(--color-pure-white); border: 0.5px solid #d8d8d4;
    border-radius: 18px;
    position: relative; overflow: hidden;
    box-shadow: 0 22px 50px -28px rgba(0,0,0,0.22), 0 2px 6px rgba(0,0,0,0.04);
    transition: transform 520ms cubic-bezier(0.4, 0, 0.1, 1), box-shadow 520ms cubic-bezier(0.4, 0, 0.1, 1);
}

.qm-quote__sheet:hover {
    transform: translateY(-3px);
    box-shadow: 0 32px 70px -32px rgba(0,0,0,0.28), 0 4px 12px rgba(0,0,0,0.05);
}

.qm-quote__sheet::after {
    content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0.35;
    background:
        repeating-linear-gradient(90deg, #d0d0cc 0px, #d0d0cc 1px, transparent 1px, transparent 36px) 0 0 / 100% 6px no-repeat,
        repeating-linear-gradient(90deg, #d0d0cc 0px, #d0d0cc 1px, transparent 1px, transparent 36px) 0 100% / 100% 6px no-repeat,
        repeating-linear-gradient(180deg, #d0d0cc 0px, #d0d0cc 1px, transparent 1px, transparent 36px) 0 0 / 6px 100% no-repeat,
        repeating-linear-gradient(180deg, #d0d0cc 0px, #d0d0cc 1px, transparent 1px, transparent 36px) 100% 0 / 6px 100% no-repeat;
}

.qm-quote__sheet-bar {
    display: flex; justify-content: space-between;
    padding: var(--space-3) var(--space-6); border-bottom: 0.5px solid #e4e4e0;
    font-family: 'Courier New', monospace; font-size: 0.6rem; font-weight: 700;
    letter-spacing: 0.2em; text-transform: uppercase; color: #b8b8b4;
    position: relative; z-index: 2;
}
.qm-quote__sheet-body { position: relative; z-index: 2; }

.qm-quote__sheet-body {
    padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 5vw, 5rem);
    text-align: center; position: relative;
}

.qm-quote__mark {
    font-family: var(--font-heading); font-size: clamp(6rem, 12vw, 10rem); font-weight: 800;
    color: rgba(50,48,47,0.04); line-height: 0.5; display: block; margin-bottom: var(--space-4); pointer-events: none;
}

.qm-quote__text {
    font-family: var(--font-heading); font-size: clamp(1.4rem, 3vw, 2.2rem); font-weight: var(--font-regular);
    color: var(--color-text-primary); line-height: var(--leading-snug); letter-spacing: -0.6px;
    margin: 0 auto; font-style: italic; max-width: 720px;
}


/* ============================================
   6. CLIENT SATISFACTION — Horizontal flow
   ============================================ */
.qm-satisfaction { background: transparent; padding: var(--section-padding) 0; }

.qm-satisfaction__inner { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); }

.qm-satisfaction__header { margin-bottom: var(--space-12); max-width: 600px; }

.qm-satisfaction__flow {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.qm-satisfaction__step {
    padding-top: var(--space-8);
    border-top: 2px solid var(--color-text-primary);
    display: flex; flex-direction: column; gap: var(--space-4);
}

.qm-satisfaction__step-num {
    font-family: var(--font-body); font-size: 0.7rem; font-weight: 700;
    letter-spacing: 0.18em; color: var(--color-text-secondary); line-height: 1;
}

.qm-satisfaction__step-title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 2.8vw, 2.4rem);
    font-weight: var(--font-regular);
    color: var(--color-text-primary); letter-spacing: -0.8px;
    line-height: 1.1; margin: 0;
}

.qm-satisfaction__step-desc {
    font-family: var(--font-body); font-size: var(--text-base); color: var(--color-text-primary);
    line-height: var(--leading-normal); margin: 0;
}

.qm-satisfaction__connector { display: none; }

@media (max-width: 900px) {
    .qm-satisfaction__flow { grid-template-columns: 1fr; gap: var(--space-8); }
}


/* ============================================
   7. SUPPLY CHAIN — Clean text section
   ============================================ */
.qm-supply { background: transparent; padding: var(--section-padding) 0; }

.qm-supply__inner {
    max-width: 800px; margin: 0 auto; padding: 0 var(--container-padding);
}


/* ============================================
   8. CTA
   ============================================ */
.qm-cta { position: relative; background: transparent; padding: clamp(6rem, 12vw, 10rem) 0; overflow: hidden; isolation: isolate; }
.qm-cta__bg { display: none; }
.qm-cta__overlay { display: none; }

.qm-cta__inner { position: relative; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); text-align: center; }

.qm-cta__heading {
    font-family: var(--font-heading); font-size: var(--text-section); font-weight: var(--font-semibold);
    line-height: var(--leading-tight); letter-spacing: -0.6px; color: var(--color-text-primary); margin: 0 0 var(--space-8);
}

.qm-cta__btn {
    display: inline-flex; align-items: center; gap: var(--space-3);
    padding: 18px 44px; font-family: var(--font-body); font-size: var(--text-base); font-weight: var(--font-semibold);
    color: #FFFFFF; background: var(--color-text-primary); border-radius: var(--radius-pill);
    text-decoration: none; transition: background var(--duration-base) var(--ease-out), gap var(--duration-base) var(--ease-out);
}

.qm-cta__btn:hover { background: #000000; gap: var(--space-4); }
.qm-cta__btn i { font-size: 1.1rem; }


/* ============================================
   Reusable cinematic photo banner
   ============================================ */
.qm-cinema { position: relative; width: calc(100% - 2 * var(--container-padding)); max-width: var(--container-max); margin: clamp(2.5rem, 5vw, 4rem) auto; aspect-ratio: 21 / 9; max-height: 560px; overflow: hidden; border-radius: 18px; box-shadow: 0 30px 80px -40px rgba(0,0,0,0.5), 0 4px 12px rgba(0,0,0,0.05); }

/* Cinema figures inside the explore panels — wider + taller on mobile.
   Desktop holds them at 21:9 inside container-padded width which on a
   375px phone renders ~311×133px (almost invisible). Below 700px the
   figure pulls in to a 12px side margin (~351px wide on a 375px
   viewport) and switches to 4:3 aspect so it renders ~351×263px —
   visibly bigger in both directions. Applies to both .qm-cinema
   variants (Standards "Aligned, Audited, Accountable" + Client
   Satisfaction "Precision, Verified"). */
@media (max-width: 700px) {
    .qm-cinema {
        width: calc(100% - 24px);
        margin-left: 12px;
        margin-right: 12px;
        aspect-ratio: 4 / 3;
        max-height: none;
        border-radius: 14px;
    }
}
.qm-cinema__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.4s cubic-bezier(0.16, 1, 0.3, 1); }
.qm-cinema:hover .qm-cinema__img { transform: scale(1.03); }
.qm-cinema::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,20,18,0.65) 0%, rgba(20,20,18,0.2) 50%, rgba(20,20,18,0) 100%); pointer-events: none; }
.qm-cinema--right::after { background: linear-gradient(270deg, rgba(20,20,18,0.65) 0%, rgba(20,20,18,0.2) 50%, rgba(20,20,18,0) 100%); }
.qm-cinema__caption { position: absolute; left: clamp(1.5rem, 5vw, 4rem); bottom: clamp(1.5rem, 4vw, 3rem); max-width: 540px; color: #FFFFFF; z-index: 1; }
.qm-cinema--right .qm-cinema__caption { left: auto; right: clamp(1.5rem, 5vw, 4rem); text-align: right; }
.qm-cinema__eyebrow { display: block; font-family: var(--font-body); font-size: 0.7rem; font-weight: 600; letter-spacing: var(--tracking-wider); text-transform: uppercase; color: rgba(255,255,255,0.75); margin-bottom: var(--space-3); }
.qm-cinema__text { display: block; font-family: var(--font-heading); font-size: clamp(1.4rem, 2.8vw, 2.2rem); font-weight: var(--font-semibold); line-height: 1.15; letter-spacing: -0.5px; color: #FFFFFF; }


/* ============================================
   EXPLORE — Merged section (mirrors .ec-merged from ethics & .in-explore from
   innovation). Sidebar nav + active panel container that wraps the original
   qm-pillars / qm-standards / qm-quote / qm-satisfaction / qm-cta / qm-supply
   sections so the visitor clicks through them instead of scrolling past.
   ============================================ */
.qm-explore {
    position: relative;
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    max-width: 1600px;
    margin: 0 auto;
    padding: var(--section-padding) clamp(24px, 4vw, 80px);
}

/* ---- Left nav (sticky) — homepage page-explorer aesthetic ---- */
.qm-explore__nav {
    position: sticky;
    top: 120px;
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 0;
    background: var(--color-accent, #FF3B30);
    border-radius: 16px;
    padding: clamp(1.5rem, 2.5vw, 2rem) 0;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

.qm-explore__nav::-webkit-scrollbar {
    width: 4px;
}

.qm-explore__nav::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.3);
    border-radius: 4px;
}

.qm-explore__navbox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(0.6rem, 1vw, 1rem);
    padding: clamp(0.55rem, 0.9vw, 0.75rem) clamp(1.2rem, 2vw, 1.8rem);
    background: none;
    border: none;
    border-radius: 0;
    text-align: left;
    cursor: pointer;
    width: 100%;
    position: relative;
    transition: background 0.2s, opacity 0.2s;
    box-shadow: none;
}

.qm-explore__navbox:hover {
    background: rgba(255, 255, 255, 0.08);
    transform: none;
    box-shadow: none;
    border: none;
}

.qm-explore__navbox.is-active {
    background: rgba(255, 255, 255, 0.06);
    border: none;
    box-shadow: none;
}

.qm-explore__navbox.is-active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 20px;
    background: #fff;
    border-radius: 0 2px 2px 0;
}

.qm-explore__navbox-num {
    font-family: var(--font-body, 'Urbanist', sans-serif);
    font-size: 0.75rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.5);
    min-width: 24px;
    letter-spacing: 0.02em;
    opacity: 1;
}

.qm-explore__navbox.is-active .qm-explore__navbox-num {
    color: rgba(255, 255, 255, 0.8);
}

.qm-explore__navbox-title {
    font-family: var(--font-body, 'Urbanist', sans-serif);
    font-size: clamp(0.9rem, 1.1vw, 1.05rem);
    font-weight: 400;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 0.01em;
    transition: color 0.2s, font-size 0.2s, font-weight 0.2s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.qm-explore__navbox.is-active .qm-explore__navbox-title {
    color: #fff;
    font-size: clamp(1.1rem, 1.4vw, 1.35rem);
    font-weight: 600;
}

/* ---- Right content + panels ---- */
.qm-explore__content {
    min-width: 0;
}

.qm-explore__panels {
    position: relative;
}

.qm-explore__panel {
    display: none;
}

.qm-explore__panel.is-active {
    display: block;
    animation: qmExploreFade 0.35s var(--ease-out, cubic-bezier(0.16, 1, 0.3, 1));
}

@keyframes qmExploreFade {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Reset section-level padding so panels render flush inside the grid. */
.qm-explore__panel > section {
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
}

/* Each panel's inner container fills the column rather than being capped
   by the original section's container-max constraint. */
.qm-explore__panel > section > [class$="__inner"] {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
}

/* ---- Responsive: stack vertically below 1024px ---- */
/* Mobile stepper — hidden on desktop, replaces the red sidebar nav
   below 1024px. */
.qm-explore__mobile-nav { display: none; }

@media (max-width: 1023px) {
    .qm-explore {
        grid-template-columns: 1fr;
    }

    /* Hide the desktop red sidebar (and the mobile horizontal-scroll
       variant). The hidden nav still owns the active state — JS click-
       cycles its buttons — but the visible UI is the stepper. */
    .qm-explore__nav { display: none; }

    /* Stepper — red pill matching the page accent. Same pattern as
       ethics and innovation steppers. */
    /* Styled to match the homepage .page-explorer__pager. */
    .qm-explore__mobile-nav {
        display: flex;
        align-items: stretch;
        gap: 0.5rem;
        padding: 0.55rem;
        background: var(--color-accent, #FF3B30);
        color: #FFFFFF;
        border-radius: 14px;
        box-shadow: 0 10px 28px -10px rgba(0, 0, 0, 0.35);
        margin-bottom: var(--space-4);
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        position: sticky;
        top: 0;
        z-index: 20;
    }
    .qm-explore__mobile-btn {
        flex-shrink: 0;
        width: 56px;
        height: 56px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        border: none;
        border-radius: 10px;
        background: rgba(255, 255, 255, 0.16);
        color: #fff;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
        transition: background 0.15s ease, transform 0.15s ease;
    }
    .qm-explore__mobile-btn:active {
        background: rgba(255, 255, 255, 0.3);
        transform: scale(0.94);
    }
    .qm-explore__mobile-current {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 0.15rem;
        padding: 0 0.25rem;
        text-align: center;
    }
    .qm-explore__mobile-num {
        font-family: var(--font-body, "Urbanist", sans-serif);
        font-size: 0.58rem;
        font-weight: 700;
        letter-spacing: 0.16em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.7);
    }
    .qm-explore__mobile-label {
        font-family: var(--font-body, "Urbanist", sans-serif);
        font-size: 0.95rem;
        font-weight: 700;
        line-height: 1.15;
        color: #fff;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}
