/* Beyond Insights - Visually Stunning Beauty Brand Styles */
:root {
    --royal-purple: #7434ac;
    --heathered-gray: #b7af9b;
    --red-ribbon: #f10b25;
    --purple: #98069d;
    --rose: #eb0473;
    --fire-bush: #e4a324;
    --wisteria: #9454b0;
    --dark-bg: #1a0f2e;
    --cream: #faf8f5;
    --white: #ffffff;
    --dark-text: #2a2a2a;
    --glass: rgba(255, 255, 255, 0.1);
    --shadow-purple: rgba(116, 52, 172, 0.3);
    --shadow-fire: rgba(228, 163, 36, 0.3);
}

#beyond-insights-casestudy iframe {
  width: 100%;
  border: none;
  display: block;
  min-height: 100vh;
}

/* Smooth transition when height adjusts */
#beyond-insights-casestudy {
  transition: height 0.3s ease;
}
/* Remove excessive gap */
#beyond-insights-casestudy {
    min-height: auto !important;
    padding-bottom: 40px !important;
}

.screen.decision {
    margin-top: 40px !important; /* reduced from whatever it was */}
/* ─────────  LANEIGE CASE STUDY  ───────── */
.case-study{background:linear-gradient(to bottom,var(--white)0%,#f8f5ff 100%);
  padding:120px 20px;position:relative;overflow:hidden}
.case-study .case-header{text-align:center;margin-bottom:80px}
.case-study .case-label{display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:var(--white);padding:10px 30px;border-radius:28px;font:700 .8rem/1 'Segoe UI',sans-serif;letter-spacing:2px}
.case-study .case-subtitle{font-size:1.4rem;max-width:800px;margin:25px auto 0;color:var(--heathered-gray)}

.case-challenge{background:linear-gradient(135deg,rgba(241,11,37,.03)0%,rgba(116,52,172,.03)100%);
  border:2px solid rgba(241,11,37,.1);border-radius:28px;padding:60px;margin-bottom:90px}
.challenge-title{text-align:center;font-size:2.2rem;font-weight:300;margin-bottom:50px}
.challenge-body{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.metric-value{display:block;font-size:3.2rem;font-weight:700;color:var(--red-ribbon)}
.challenge-arrow{font-size:3rem;color:var(--red-ribbon);opacity:.5}
.challenge-risk ul{margin:8px 0 0;padding:0 0 0 18px}
.case-challenge .challenge-copy{font-size:1.2rem;max-width:900px;margin:0 auto;text-align:center;margin-top:25px}

.blueprint-reveal .blueprint-grid{display:grid;gap:45px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.insight-card{background:var(--white);border-radius:22px;padding:45px 40px;box-shadow:0 16px 50px rgba(0,0,0,.08)}
.tool-badge{display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:#fff;font:700 .75rem/1 'Segoe UI',sans-serif;padding:6px 20px;border-radius:18px;margin-bottom:18px}
.insight-card h4{font-size:1.4rem;margin:0 0 18px;color:var(--dark-text)}
.insight-card .intro{font-size:1.05rem;margin-bottom:20px}
.edge-columns{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0 30px}
.edge-columns ul{list-style:none;padding:0}
.edge-columns .title{font-weight:600;margin-bottom:6px;color:var(--royal-purple)}
.edge-conclusion{font-size:1rem;background:rgba(116,52,172,.05);padding:18px;border-radius:12px}

.migration-stats{display:flex;gap:30px;margin:25px 0}
.stat{flex:1 1 120px;border:2px solid currentColor;border-radius:18px;padding:25px;text-align:center}
.stat.curious{color:var(--fire-bush)}
.stat.recon{color:var(--royal-purple)}
.stat .percent{display:block;font-size:2.6rem;font-weight:700}
.critical{margin:20px 0;font-weight:500}
.triggers{padding-left:18px;font-size:.95rem;margin:0}
.triggers li{margin-bottom:6px}

.driver-equation{display:flex;align-items:center;justify-content:space-between;
  gap:18px;margin:25px 0 30px;flex-wrap:wrap}
.driver{flex:0 1 140px;background:#faf7ff;border:1px solid rgba(116,52,172,.2);border-radius:14px;
  padding:20px;text-align:center;font-size:.9rem;font-weight:500}
.plus,.equals{font-size:1.6rem;color:var(--royal-purple);font-weight:700}
.result{flex:0 1 100px;background:linear-gradient(135deg,var(--fire-bush),var(--rose));color:#fff;
  text-align:center;border-radius:18px;padding:18px 12px;font-weight:700}
.why{font-size:.95rem;padding-left:18px;margin:0}
.why li{margin-bottom:6px}

.strategic-actions{margin-top:100px}
.strategy-tracks .tracks-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:20px}
.strategy-tracks .tracks-head span{text-align:center;font:600 .8rem/1 'Segoe UI',sans-serif;
  padding:10px 0;border:2px solid var(--royal-purple);border-radius:22px;text-transform:uppercase}
.phase{display:grid;grid-template-columns:110px 1fr 1fr;gap:40px;background:var(--white);
  border-radius:22px;padding:45px 40px;box-shadow:0 12px 40px rgba(0,0,0,.05);margin-bottom:40px}
.phase-tag{width:90px;height:90px;border-radius:50%;border:6px solid var(--royal-purple);
  display:flex;align-items:center;justify-content:center;font-weight:700}
.phase-col h4{font-size:1.2rem;margin:0 0 10px;color:var(--dark-text)}
.phase-col ul{padding-left:18px;margin:0 0 8px;font-size:.95rem}
.phase .deliverable{font-size:.85rem;font-style:italic;margin:4px 0 0}

.summary-90{margin-top:120px;text-align:center}
.summary-title{font-size:2rem;margin-bottom:50px;font-weight:300}
.summary-steps{display:flex;justify-content:center;gap:120px;list-style:none;margin:0 0 70px;padding:0;
  position:relative}
.summary-steps li{position:relative}
.summary-steps li::before{content:'';position:absolute;left:50%;bottom:-28px;width:2px;height:28px;
  background:var(--royal-purple);transform:translateX(-50%)}
.summary-steps span{display:block;width:72px;height:72px;border:6px solid var(--royal-purple);
  border-radius:50%;line-height:60px;font-size:1.4rem;font-weight:700;margin:0 auto 15px}
.summary-cards{display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.summary-cards article{background:#fff;border-radius:22px;padding:35px 28px;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.summary-cards h4{font-size:1.1rem;margin:0 0 15px;color:var(--royal-purple)}
.summary-cards ul{padding-left:16px;font-size:.95rem;margin:0}
.summary-cards li{margin-bottom:6px}

/* Responsive tweaks */
@media(max-width:1024px){
  .challenge-body{flex-direction:column}
  .strategy-tracks .tracks-head{grid-template-columns:1fr}
  .phase{grid-template-columns:90px 1fr}
}
@media(max-width:768px){
  .case-study{padding:80px 18px}
  .phase{grid-template-columns:1fr}
  .phase-tag{margin:0 auto 20px}
  .summary-steps{gap:70px}
}

/* Base Styles */
body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', sans-serif;
    background: var(--white);
    color: var(--dark-text);
    overflow-x: hidden;
    line-height: 1.6;
}

/* Particles Background */.particles-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
}

.particle {
    position: absolute;
    width: 6px;  /* CHANGE from 4px to 6px */
    height: 6px;  /* CHANGE from 4px to 6px */
    background: var(--royal-purple);
    border-radius: 50%;
    opacity: 0.4;  /* OPTIONAL: increase from 0.3 to 0.4 for slightly more visibility */
    animation: float-particle 20s infinite linear;
}

.particle:nth-child(odd) {
    background: var(--fire-bush);
    animation-duration: 25s;
}

.particle:nth-child(1) { left: 10%; animation-delay: 0s; }
.particle:nth-child(2) { left: 20%; animation-delay: 3s; }
.particle:nth-child(3) { left: 30%; animation-delay: 6s; }
.particle:nth-child(4) { left: 40%; animation-delay: 9s; }
.particle:nth-child(5) { left: 50%; animation-delay: 12s; }
.particle:nth-child(6) { left: 60%; animation-delay: 15s; }
.particle:nth-child(7) { left: 70%; animation-delay: 18s; }
.particle:nth-child(8) { left: 80%; animation-delay: 21s; }

@keyframes float-particle {
    0% {
        transform: translateY(100vh) translateX(0) scale(0);
        opacity: 0;
    }
    10% {
        opacity: 0.3;
        transform: translateY(90vh) translateX(-10px) scale(1);
    }
    90% {
        opacity: 0.3;
        transform: translateY(10vh) translateX(10px) scale(1);
    }
    100% {
        transform: translateY(0) translateX(0) scale(0);
        opacity: 0;
    }
}

/* Navigation */
.nav {
    position: fixed;
    top: 0;
    width: 100%;
    background: rgba(26, 15, 46, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    padding: 25px 60px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav.scrolled {
    padding: 15px 60px;
    background: rgba(26, 15, 46, 0.98);
}

.nav-content {
    max-width: 1600px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    height: 50px;
    width: auto;
    filter: drop-shadow(0 2px 10px rgba(228, 163, 36, 0.3));
    transition: transform 0.3s ease;
}

.logo:hover {
    transform: scale(1.05);
}

.book-briefing {
    background: linear-gradient(135deg, var(--fire-bush), var(--rose));
    color: var(--white);
    padding: 14px 40px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.book-briefing::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
}

.book-briefing:hover::before {
    left: 100%;
}

.book-briefing:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(228, 163, 36, 0.4);
}

/* Typography */
h1 {
    font-size: clamp(3rem, 7vw, 5.5rem);
    font-weight: 200;
    letter-spacing: -2px;
    line-height: 1.1;
}

h2 {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 300;
    letter-spacing: -1px;
    line-height: 1.2;
}
/* Method name emphasis - ADD HERE */
.method-name {
    color: var(--fire-bush);
    font-weight: 600;
}
.section-title {
    text-align: center;
    margin-bottom: 60px;
    position: relative;
    z-index: 2;
}

.gradient-text {
    background: linear-gradient(135deg, var(--fire-bush), var(--royal-purple), var(--rose));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Screen Sections */
.screen {
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding: 100px 60px;
    position: relative;
}

.container {
    max-width: 1400px;
    margin: 0 auto;
    width: 100%;
    position: relative;
    z-index: 2;
}

/* HERO Section */
.hero {
    background: linear-gradient(135deg, var(--dark-bg) 0%, #2a1548 50%, #3d0a5f 100%);
    color: var(--white);
    position: relative;
    overflow: hidden;
    padding-top: 120px;
}

.gradient-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at 30% 50%, rgba(228, 163, 36, 0.1) 0%, transparent 40%),
                radial-gradient(circle at 70% 20%, rgba(235, 4, 115, 0.1) 0%, transparent 40%);
    z-index: 1;
}

.hero-bg-animation {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.hero-shape-1, .hero-shape-2, .hero-shape-3 {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.3;
}

.hero-shape-1 {
    width: 600px;
    height: 600px;
    background: var(--fire-bush);
    top: -20%;
    right: -10%;
    animation: morph 20s ease-in-out infinite;
}

.hero-shape-2 {
    width: 400px;
    height: 400px;
    background: var(--rose);
    bottom: -10%;
    left: -5%;
    animation: morph 25s ease-in-out infinite reverse;
}

.hero-shape-3 {
    width: 300px;
    height: 300px;
    background: var(--royal-purple);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: pulse 4s ease-in-out infinite;
}

@keyframes morph {
    0%, 100% { border-radius: 50%; transform: scale(1) rotate(0deg); }
    33% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; transform: scale(1.1) rotate(120deg); }
    66% { border-radius: 70% 30% 30% 70% / 70% 70% 30% 30%; transform: scale(0.9) rotate(240deg); }
}

@keyframes pulse {
    0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.3; }
    50% { transform: translate(-50%, -50%) scale(1.2); opacity: 0.5; }
}

.hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 1000px;
    margin: 0 auto;
}

.logo-hero {
    width: 300px;
    height: auto;
    margin-bottom: 50px;
    filter: drop-shadow(0 10px 30px rgba(0, 0, 0, 0.3));
    animation: float 6s ease-in-out infinite;
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-20px); }
}

.hero-title {
    margin-bottom: 30px;
}

.title-line-1, .title-line-2 {
    display: block;
    animation: fadeInUp 1s ease-out;
}

.title-line-2 {
    animation-delay: 0.2s;
    background: linear-gradient(90deg, var(--white), var(--rose));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.hero-sub {
    font-size: 1.6rem;
    font-weight: 300;
    max-width: 800px;
    margin: 0 auto 50px;
    opacity: 0.9;
    line-height: 1.5;
    animation: fadeInUp 1s ease-out 0.4s both;
}

.highlight {
    color: var(--fire-bush);
    font-weight: 600;
}

.hero-cta {
    display: inline-flex;
    align-items: center;
    gap: 15px;
    background: linear-gradient(135deg, var(--fire-bush), var(--rose));
    color: var(--white);
    padding: 20px 50px;
    border-radius: 60px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1.2rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 15px 40px rgba(228, 163, 36, 0.4);
    animation: fadeInUp 1s ease-out 0.6s both;
    position: relative;
    overflow: hidden;
}

.hero-cta::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
}

.hero-cta:hover::before {
    left: 100%;
}

.hero-cta:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 50px rgba(228, 163, 36, 0.5);
}

.cta-arrow {
    transition: transform 0.3s ease;
}

.hero-cta:hover .cta-arrow {
    transform: translateX(5px);
}

.hero-stats {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-top: 80px;
    animation: fadeInUp 1s ease-out 0.8s both;
}

.stat-item {
    text-align: center;
}

.stat-number {
    font-size: 3.5rem;
    font-weight: 700;
    background: linear-gradient(135deg, var(--fire-bush), var(--rose));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.stat-symbol {
    font-size: 2.5rem;
    font-weight: 300;
    color: var(--rose);
    margin-left: 5px;
}

.stat-label {
    display: block;
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.8);
    margin-top: 10px;
}

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

/* Why Beyond Section */
.why-beyond {
    background: linear-gradient(to bottom, var(--white) 0%, var(--cream) 100%);
    padding: 120px 60px;
}

.title-accent {
    font-size: 0.8em;
    color: var(--heathered-gray);
}

.beyond-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
    margin-top: 80px;
}

.beyond-card {
    background: var(--white);
    border-radius: 30px;
    padding: 50px 30px;
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
}

.card-glow {
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, var(--shadow-purple) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.beyond-card:hover .card-glow {
    opacity: 0.3;
}

.beyond-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 60px rgba(116, 52, 172, 0.15);
}

.beyond-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 30px;
    background: linear-gradient(135deg, var(--royal-purple), var(--wisteria));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.icon-inner {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--white);
    z-index: 2;
}

.beyond-card h3 {
    font-size: 1.5rem;
    color: var(--royal-purple);
    margin-bottom: 20px;
    font-weight: 600;
}

.beyond-card p {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--dark-text);
}

/* Meet Elaine Section */
.meet-elaine {
    background: linear-gradient(to bottom, var(--white) 0%, var(--cream) 100%);
    padding: 120px 60px;
}

.elaine-showcase {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 80px;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

.elaine-image-wrapper {
    position: relative;
}

.image-frame {
    position: relative;
    width: 300px;
    height: 300px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 50%;
    background: #2a3f47; /* matches the photo background */
}

.elaine-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 50%;
    display: block;
}

.image-accent {
    position: absolute;
    top: -20px;
    left: -20px;
    right: -20px;
    bottom: -20px;
    background: linear-gradient(135deg, var(--fire-bush), var(--royal-purple), var(--rose));
    border-radius: 50%;
    opacity: 0.2;
    animation: pulse 4s ease-in-out infinite;
}

.elaine-content {
    padding-left: 40px;
}

.elaine-name {
    font-size: 3rem;
    font-weight: 300;
    color: var(--royal-purple);
    margin-bottom: 10px;
    letter-spacing: -1px;
}

.elaine-title {
    font-size: 1.5rem;
    color: var(--fire-bush);
    margin-bottom: 40px;
    font-weight: 500;
}

.elaine-credentials {
    display: flex;
    flex-direction: column;
    gap: 25px;
    margin-bottom: 40px;
}

.credential-item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.credential-icon {
    font-size: 1.8rem;
    flex-shrink: 0;
    width: 40px;
    text-align: center;
}

.credential-item p {
    font-size: 1.15rem;
    line-height: 1.6;
    color: var(--dark-text);
    margin: 0;
}

.credential-item strong {
    color: var(--royal-purple);
}

.elaine-quote {
    font-size: 1.3rem;
    font-style: italic;
    color: var(--heathered-gray);
    padding: 30px;
    background: rgba(116, 52, 172, 0.05);
    border-left: 4px solid var(--royal-purple);
    border-radius: 10px;
    line-height: 1.6;
}

/* Responsive adjustments for Meet Elaine */
@media (max-width: 1024px) {
    .elaine-showcase {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 60px;
    }
    
    .elaine-content {
        padding-left: 0;
    }
    
    .credential-item {
        text-align: left;
        max-width: 600px;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    .meet-elaine {
        padding: 80px 20px;
    }
    
    .image-frame {
        width: 250px;
        height: 250px;
    }
    
    .elaine-name {
        font-size: 2.5rem;
    }
    
    .elaine-title {
        font-size: 1.2rem;
    }
}

/* BRUTAL Section */
.brutal {
    background: var(--white);
    position: relative;
    overflow: hidden;
}

.brutal-visual {
    text-align: center;
    margin-bottom: 60px;
}

.crisis-meter {
    width: 300px;
    height: 30px;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 15px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
}

.meter-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 85%;
    background: linear-gradient(90deg, var(--fire-bush), var(--red-ribbon));
    border-radius: 15px;
    animation: pulse-width 2s ease-in-out infinite;
}

@keyframes pulse-width {
    0%, 100% { width: 85%; }
    50% { width: 90%; }
}

.meter-label {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 700;
    color: var(--white);
    letter-spacing: 2px;
    font-size: 0.9rem;
}

.brutal-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}

.brutal-stat {
    text-align: center;
    padding: 60px 40px;
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.03) 0%, rgba(228, 163, 36, 0.03) 100%);
    border-radius: 30px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid rgba(116, 52, 172, 0.1);
    position: relative;
    overflow: hidden;
    min-height: 400px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.stat-visual {
    position: relative;
    margin-bottom: 40px;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.stat-ring {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 180px;
    height: 180px;
    border: 4px solid rgba(116, 52, 172, 0.2);
    border-radius: 50%;
    animation: rotate 20s linear infinite;
}

.stat-ring::before {
    content: '';
    position: absolute;
    top: -10px;
    left: -10px;
    right: -10px;
    bottom: -10px;
    border: 2px solid rgba(228, 163, 36, 0.1);
    border-radius: 50%;
    animation: rotate 15s linear infinite reverse;
}

@keyframes rotate {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

.brutal-number {
    font-size: 5rem;
    font-weight: 700;
    background: linear-gradient(135deg, var(--royal-purple), var(--fire-bush));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    position: relative;
    z-index: 2;
    line-height: 1;
    text-shadow: 0 10px 30px rgba(116, 52, 172, 0.2);
}

.brutal-stat:hover {
    transform: translateY(-10px);
    box-shadow: 0 30px 80px rgba(116, 52, 172, 0.15);
    background: var(--royal-purple);
}

.brutal-stat:hover .brutal-number {
    background: var(--white);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.brutal-stat:hover .brutal-label,
.brutal-stat:hover .brutal-detail {
    color: var(--white);
}

.brutal-label {
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 15px;
    color: var(--dark-text);
    transition: color 0.3s ease;
}

.brutal-detail {
    font-size: 1.1rem;
    line-height: 1.5;
    color: var(--dark-text);
    opacity: 0.8;
    transition: color 0.3s ease;
}

/* GAP Section */
.gap {
    background: linear-gradient(to bottom, var(--cream) 0%, var(--white) 100%);
    position: relative;
    overflow: hidden;
}

.gap-visual-intro {
    text-align: center;
    margin-bottom: 60px;
}

.gap-subtitle {
    font-size: 1.6rem;
    color: var(--dark-text);
}

.text-strike {
    position: relative;
}

.text-strike::after {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 100%;
    height: 3px;
    background: var(--red-ribbon);
    transform: rotate(-5deg);
}

/* For the gap comparison grid */
.gap-comparison {
    display: grid;
    grid-template-columns: 1fr 100px 1fr;
    gap: 40px;
    align-items: stretch; /* Ensure both columns have same height */
}

.gap-column {
    padding: 60px 50px;
    border-radius: 30px;
    position: relative;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}

/* Ensure OLD PLAYBOOK column matches the Blueprint column */
.old-playbook {
    display: flex;
    flex-direction: column;
    align-items: center; /* Center the content */
    justify-content: flex-start; /* Align content to top */
}

.old-playbook h3 {
    text-align: center;
    margin-bottom: 40px; /* Match the Blueprint's spacing */
}
.new-blueprint {
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.08) 0%, rgba(228, 163, 36, 0.08) 100%);
    border: 3px solid var(--royal-purple);
    box-shadow: 0 25px 80px rgba(116, 52, 172, 0.15);
    transform: scale(1.05);
}

.gap-column h3 {
    font-size: 2.2rem;
    margin-bottom: 40px;
    text-align: center;
    font-weight: 600;
    height: 60px; /* Fixed height for both titles */
    display: flex;
    align-items: center;
    justify-content: center;
}

.strike-through {
    text-decoration: line-through;
    opacity: 0.6;
}

.gap-items {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.gap-item {
    font-size: 1.15rem;
    padding: 20px 0;
    position: relative;
    transition: transform 0.3s ease;
    display: flex;
    gap: 15px;
    align-items: flex-start;
}

.item-icon {
    font-size: 1.5rem;
    font-weight: 700;
    flex-shrink: 0;
    width: 30px;
}

.item-content {
    flex: 1;
}

.old-playbook .item-icon {
    color: var(--red-ribbon);
}

.new-blueprint .item-icon {
    color: var(--royal-purple);
}

.item-title {
    font-weight: 600;
    display: block;
    margin-bottom: 5px;
}

.item-desc {
    font-size: 0.95rem;
    opacity: 0.8;
    line-height: 1.4;
    display: inline;
}

.old-playbook .gap-item {
    color: #666;
    opacity: 0.7;
}

.new-blueprint .gap-item {
    color: var(--dark-text);
}

.new-blueprint .item-title {
    color: var(--royal-purple);
}

.new-blueprint .gap-item:hover {
    transform: translateX(10px);
}

.new-blueprint .gap-item:hover .item-desc {
    opacity: 1;
    color: var(--fire-bush);
}

.gap-divider {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.divider-pulse {
    width: 4px;
    height: 100%;
    background: linear-gradient(to bottom, var(--fire-bush) 0%, var(--royal-purple) 50%, var(--rose) 100%);
    border-radius: 2px;
    position: relative;
}

.divider-pulse::before {
    content: '';
    position: absolute;
    top: 0;
    left: -10px;
    right: -10px;
    bottom: 0;
    background: inherit;
    filter: blur(10px);
    opacity: 0.5;
    animation: pulse 2s ease-in-out infinite;
}

/* SOLUTION Section */
.solution {
    background: var(--dark-bg);
    color: var(--white);
    position: relative;
    overflow: hidden;
}

.solution-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.solution-gradient-1, .solution-gradient-2 {
    position: absolute;
    width: 800px;
    height: 800px;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.2;
}

.solution-gradient-1 {
    background: var(--fire-bush);
    top: -400px;
    left: -400px;
    animation: float 20s ease-in-out infinite;
}

.solution-gradient-2 {
    background: var(--royal-purple);
    bottom: -400px;
    right: -400px;
    animation: float 25s ease-in-out infinite reverse;
}

.section-subtitle {
    text-align: center;
    font-size: 1.8rem !important;
    color: #e4a324 !important; /* gold color */
    margin-bottom: 60px;
}

.modules {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-top: 80px;
}

@media (max-width: 1400px) {
    .modules {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 900px) {
    .modules {
        grid-template-columns: 1fr;
    }
}

.module {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.1) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 2px solid rgba(255, 255, 255, 0.1);
    border-radius: 30px;
    padding: 60px 40px;
    text-align: center;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.module-glow {
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, var(--shadow-fire) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.module:hover .module-glow {
    opacity: 0.5;
}

.module:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 40px 100px rgba(228, 163, 36, 0.4);
    border-color: var(--fire-bush);
}

.module-number {
    position: absolute;
    top: 30px;
    right: 30px;
    font-size: 3rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.1);
}

.module-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 30px;
    position: relative;
}

.icon-svg {
    width: 100%;
    height: 100%;
    color: var(--fire-bush);
    transition: all 0.4s ease;
}

.module:hover .icon-svg {
    transform: scale(1.1) rotate(10deg);
    color: var(--rose);
}

.module h3 {
    font-size: 2rem;
    margin-bottom: 20px;
    background: linear-gradient(135deg, var(--fire-bush), var(--rose));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.module p {
    font-size: 1.2rem;
    line-height: 1.6;
    margin-bottom: 30px;
    opacity: 0.9;
}

.module-result {
    margin-top: 30px;
    padding-top: 30px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    font-size: 1.1rem;
    text-align: left;
}

.result-label {
    color: var(--fire-bush);
    font-weight: 600;
}

/* ─── Blueprint Stepper ───────────────────────────── */
.blueprint-stepper {
    background: linear-gradient(to bottom, var(--white) 0%, var(--cream) 100%);
    position: relative;
    overflow: hidden;
}

.blueprint-stepper::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(116, 52, 172, 0.05) 0%, transparent 70%);
    pointer-events: none;
}

.stepper {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
}

.stepper details {
    background: var(--white);
    border: 2px solid rgba(116, 52, 172, 0.1);
    border-radius: 20px;
    margin: 20px 0;
    overflow: hidden;
    transition: all 0.3s ease;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);
}

.stepper details[open] {
    border-color: var(--royal-purple);
    box-shadow: 0 20px 60px rgba(116, 52, 172, 0.15);
}

.stepper summary {
    list-style: none;
    cursor: pointer;
    padding: 30px 40px;
    display: flex;
    align-items: center;
    gap: 20px;
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--dark-text);
    position: relative;
    transition: all 0.3s ease;
}

.stepper summary::-webkit-details-marker {
    display: none;
}

.stepper summary::after {
    content: '+';
    position: absolute;
    right: 40px;
    font-size: 2rem;
    font-weight: 300;
    color: var(--royal-purple);
    transition: transform 0.3s ease;
}

.stepper details[open] summary::after {
    transform: rotate(45deg);
}

.stepper summary:hover {
    background: rgba(116, 52, 172, 0.03);
}

.step-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, var(--royal-purple), var(--wisteria));
    color: var(--white);
    border-radius: 50%;
    font-size: 1.5rem;
    font-weight: 700;
    flex-shrink: 0;
    box-shadow: 0 5px 20px rgba(116, 52, 172, 0.3);
}

.step-title {
    flex: 1;
    color: var(--royal-purple);
}

.step-duration {
    font-size: 1rem;
    color: var(--fire-bush);
    font-weight: 500;
}

.step-content {
    padding: 0 40px 40px;
    animation: fadeIn 0.3s ease;
    margin-right: 60px; 
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.step-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.step-list li {
    padding: 15px 0;
    padding-left: 40px;
    position: relative;
    font-size: 1.15rem;
    line-height: 1.6;
    color: var(--dark-text);
}

.step-list li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--fire-bush);
    font-size: 1.5rem;
    font-weight: 600;
}

.step-list strong {
    color: var(--royal-purple);
}

.step-outcome {
    margin-top: 30px;
    padding: 20px;
    background: linear-gradient(135deg, rgba(228, 163, 36, 0.05) 0%, rgba(116, 52, 172, 0.05) 100%);
    border-radius: 15px;
    border-left: 4px solid var(--fire-bush);
}

.outcome-label {
    font-weight: 600;
    color: var(--fire-bush);
}
/*═══════════════════════════════════════════════════════════════════
  CASE STUDY (Laneige) ―  full visual spec
  ‑‑‑  Add _after_ all existing styles  ‑‑‑
═══════════════════════════════════════════════════════════════════*/

/* Section wrapper */
.case-study{
  background:linear-gradient(to bottom,var(--white) 0%,#f8f5ff 100%);
  position:relative;overflow:hidden;padding:120px 20px;
}

/* ── Header ──────────────────────────────────────────*/
.case-header{text-align:center;margin-bottom:60px}
.case-label{
  display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:var(--white);padding:10px 30px;border-radius:30px;font-size:.85rem;font-weight:700;
  letter-spacing:3px;margin-bottom:30px;box-shadow:0 10px 30px rgba(116,52,172,.3);
  text-transform:uppercase;
}
.case-subtitle{
  font-size:1.6rem;color:var(--heathered-gray);margin-top:20px;font-weight:300;
  max-width:800px;margin-inline:auto;
}

/* ── Challenge card ─────────────────────────────────*/
.case-challenge{
  background:linear-gradient(135deg,rgba(241,11,37,.03) 0%,rgba(116,52,172,.03) 100%);
  border-radius:30px;padding:60px;margin-bottom:80px;border:2px solid rgba(241,11,37,.1);
}
.challenge-header{margin-bottom:40px}
.challenge-header h3{
  font-size:2.2rem;color:var(--dark-text);text-align:center;font-weight:300;line-height:1.4;
}
.challenge-visual{
  display:flex;align-items:center;justify-content:center;gap:40px;margin-bottom:40px;flex-wrap:wrap;
}
.big-stat{display:block;font-size:3rem;font-weight:700;color:var(--red-ribbon);line-height:1;margin-bottom:10px}
.stat-label{font-size:1.1rem;color:var(--dark-text);opacity:.8}
.problem-arrow{font-size:3rem;color:var(--red-ribbon);opacity:.5}
.risk-factors p{font-weight:600;margin-bottom:10px;color:var(--dark-text)}
.risk-factors ul{list-style:none;padding:0}
.risk-factors li{padding:5px 0;color:var(--dark-text);opacity:.8}
.risk-factors li::before{content:'×';color:var(--red-ribbon);font-weight:700;margin-right:10px;font-size:1.2rem}
.challenge-statement{
  font-size:1.3rem;line-height:1.8;color:var(--dark-text);text-align:center;max-width:900px;margin:0 auto;
}

/* ── Blueprint Reveal ───────────────────────────────*/
.blueprint-reveal{margin-bottom:80px}
.section-subtitle{
  font-size:2.5rem;text-align:center;margin-bottom:60px;font-weight:300;color:var(--dark-text);
}
.blueprint-insights{display:grid;gap:50px}
.insight-module{
  background:var(--white);border-radius:24px;padding:50px;box-shadow:0 20px 60px rgba(0,0,0,.1);
  border:1px solid rgba(116,52,172,.1);position:relative;overflow:hidden;
}
.module-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}
.tool-badge{
  display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:var(--white);padding:8px 24px;border-radius:20px;font-size:.85rem;font-weight:700;letter-spacing:1px;
  white-space:nowrap;
}
.module-header h4{font-size:1.8rem;color:var(--dark-text);font-weight:600}
.module-content p{font-size:1.2rem;line-height:1.8;color:var(--dark-text);margin-bottom:25px}

/*  Brand‑Edge table  */
.edge-findings{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:30px 0}
.edge-item{
  background:rgba(116,52,172,.03);padding:30px;border-radius:15px;border:1px solid rgba(116,52,172,.1);
}
.edge-item h5{font-size:1.2rem;color:var(--royal-purple);margin-bottom:15px}
.edge-item ul{list-style:none;padding:0}
.edge-item li{
  padding:8px 0;font-size:1.05rem;position:relative;padding-left:20px;
}
.edge-item li::before{content:'•';position:absolute;left:0;color:var(--fire-bush);font-weight:700}
.edge-conclusion{
  margin-top:30px;padding:20px;background:linear-gradient(135deg,rgba(228,163,36,.05) 0%,rgba(116,52,172,.05) 100%);
  border-radius:10px;font-weight:500;
}

/*  Infidelity Index  */
.migration-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px;
}
.stat-group{
  text-align:center;padding:30px;border-radius:20px;position:relative;
}
.stat-group.curious{
  background:linear-gradient(135deg,rgba(228,163,36,.1) 0%,rgba(235,4,115,.1) 100%);
  border:2px solid var(--fire-bush);
}
.stat-group.reconcilable{
  background:linear-gradient(135deg,rgba(116,52,172,.1) 0%,rgba(148,84,176,.1) 100%);
  border:2px solid var(--royal-purple);
}
.stat-group .percentage{
  display:block;font-size:3rem;font-weight:700;line-height:1;margin-bottom:10px;
}
.curious .percentage{color:var(--fire-bush)}
.reconcilable .percentage{color:var(--royal-purple)}
.stat-group .label{display:block;font-weight:600;margin-bottom:10px;font-size:1.1rem}
.stat-group .detail{font-size:.95rem;opacity:.8;margin:0}

/*  Loyalty‑Multiverse equation  */
.driver-equation{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:25px;margin:40px 0}
.driver-item{
  display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;background:rgba(116,52,172,.05);
  border-radius:15px;flex:0 1 150px;
}
.driver-icon{width:60px;height:60px}
.driver-text{font-size:.9rem;text-align:center;font-weight:500}
.operator{font-size:2rem;color:var(--royal-purple);font-weight:300}
.driver-result{
  background:linear-gradient(135deg,var(--fire-bush),var(--rose));color:var(--white);padding:25px 35px;
  border-radius:20px;text-align:center;box-shadow:0 15px 40px rgba(228,163,36,.3);
}
.result-value{display:block;font-size:2.5rem;font-weight:700;margin-bottom:5px}
.result-text{font-size:.95rem}

/* ── Strategic Actions (parallel timeline) ──────────*/
.strategic-actions{margin-bottom:80px}
.parallel-timeline{display:grid;gap:60px}
.timeline-header{display:grid;grid-template-columns:1fr 40px 1fr;align-items:center;margin-bottom:30px}
.track-label{
  font-size:.85rem;font-weight:700;padding:6px 14px;border-radius:20px;border:1px solid var(--royal-purple);
  background:var(--white);color:var(--royal-purple);letter-spacing:1px;text-transform:uppercase;
}
.timeline-connector{height:2px;background:linear-gradient(to right,var(--royal-purple),var(--fire-bush))}
.timeline-phase{
  display:grid;grid-template-columns:180px auto;gap:40px;background:var(--white);padding:40px;border-radius:20px;
  box-shadow:0 15px 50px rgba(0,0,0,.08);border-left:5px solid;
  border-image:linear-gradient(to bottom,var(--royal-purple),var(--fire-bush)) 1;
}
.phase-indicator{text-align:center}
.phase-number{display:block;font-size:2.2rem;font-weight:700;color:var(--royal-purple)}
.phase-timing{font-size:.9rem;color:var(--heathered-gray);font-weight:600}
.phase-content{display:grid;grid-template-columns:1fr 40px 1fr;gap:30px}
.phase-arrow{display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--royal-purple)}
.track-outcome{margin-top:15px;font-size:1rem;font-weight:600;color:var(--fire-bush)}
.phase-content ul{padding-left:20px;margin:0}
.phase-content li{padding:6px 0;font-size:1rem}

/*  Collaboration callout  */
.collaboration-note{
  display:flex;align-items:center;gap:20px;margin-top:40px;padding:25px;border-radius:15px;
  background:rgba(116,52,172,.05);border:1px solid rgba(116,52,172,.15);
}
.collab-icon{width:40px;height:40px;flex:0 0 40px}

/*  Impact preview  */
.transformation-results{text-align:center;margin-top:60px}
.impact-preview{display:flex;flex-wrap:wrap;justify-content:center;gap:30px;margin-top:30px}
.impact-stat{
  flex:0 1 140px;padding:25px;border-radius:15px;background:rgba(116,52,172,.05);
  border:1px solid rgba(116,52,172,.15);
}
.impact-number{display:block;font-size:1.6rem;font-weight:700;color:var(--royal-purple)}
.impact-label{font-size:.9rem;font-weight:600;color:var(--dark-text)}

/* ── Results grid ───────────────────────────────────*/
.case-results{
  background:linear-gradient(135deg,#2a1548 0%,var(--dark-bg) 100%);
  border-radius:30px;padding:80px 60px;margin-bottom:60px;position:relative;overflow:hidden;
}
.results-title{
  text-align:center;color:var(--white);font-size:2.5rem;margin-bottom:60px;font-weight:300;
}
.results-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;max-width:1000px;margin:0 auto;
}
.result-card{
  text-align:center;padding:40px 20px;background:rgba(255,255,255,.05);backdrop-filter:blur(20px);
  border-radius:20px;border:2px solid rgba(255,255,255,.1);transition:.3s;
}
.result-card:hover{transform:translateY(-5px);border-color:var(--fire-bush);background:rgba(255,255,255,.08)}
.result-number{
  display:block;font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:15px;line-height:1;
}
.result-label{color:rgba(255,255,255,.9);font-size:1rem;line-height:1.4}

/* ── Closing quote & CTA ───────────────────────────*/
.case-closing{text-align:center;margin-bottom:40px}
.case-quote{
  font-size:1.5rem;font-style:italic;color:var(--dark-text);margin:60px auto 50px;max-width:800px;
  padding:40px;background:linear-gradient(135deg,rgba(116,52,172,.03) 0%,rgba(228,163,36,.03) 100%);
  border-left:5px solid;border-image:linear-gradient(to bottom,var(--royal-purple),var(--fire-bush)) 1;
  border-radius:0 20px 20px 0;line-height:1.8;
}
.case-quote cite{
  display:block;margin-top:20px;font-size:1rem;font-style:normal;color:var(--royal-purple);font-weight:600;
}
.case-cta{margin-top:50px}
.cta-question{font-size:1.8rem;color:var(--dark-text);margin-bottom:30px}
.case-cta .cta-button{
  display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  color:var(--white);padding:18px 50px;border-radius:50px;text-decoration:none;font-weight:600;font-size:1.2rem;
  transition:.3s;box-shadow:0 15px 40px rgba(228,163,36,.3);
}
.case-cta .cta-button:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(228,163,36,.4)}
.case-footnotes{
  text-align:center;font-size:.85rem;color:var(--heathered-gray);font-style:italic;opacity:.7;margin-top:40px;
}

/* ── Responsive shims ───────────────────────────────*/
@media (max-width:1024px){
  .case-challenge{padding:40px}
  .challenge-visual{flex-direction:column;gap:30px}.problem-arrow{transform:rotate(90deg)}
  .blueprint-insights{gap:40px}.insight-module{padding:40px}
  .migration-stats{grid-template-columns:1fr}.driver-equation{flex-direction:column;gap:15px}
  .operator{transform:rotate(90deg)}.results-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .case-study{padding:80px 20px}.case-header{margin-bottom:40px}.case-subtitle{font-size:1.3rem}
  .case-challenge{padding:30px 20px;border-radius:20px}.big-stat{font-size:4rem}.challenge-statement{font-size:1.1rem}
  .section-subtitle{font-size:2rem;margin-bottom:40px}.insight-module{padding:30px 25px;border-radius:20px}
  .module-header{flex-direction:column;align-items:flex-start;gap:15px}.module-header h4{font-size:1.5rem}
  .module-content p{font-size:1.05rem}.stat-group{padding:20px}.stat-group .percentage{font-size:2.5rem}
  .driver-item{padding:15px}.driver-result{padding:20px 30px}.timeline-phase{grid-template-columns:1fr}
  .action-phase{padding:30px 25px}.results-title{font-size:2rem;margin-bottom:40px}
  .results-grid{grid-template-columns:1fr;gap:25px}.result-card{padding:30px 20px}.result-number{font-size:2.5rem}
  .case-quote{font-size:1.2rem;padding:30px 25px}.cta-question{font-size:1.5rem}
  .case-cta .cta-button{padding:15px 40px;font-size:1.1rem}
}
/* ─── WOW glow for challenge box ─────────────────────────────── */
.wow-glow{
  position:relative;
  overflow:hidden;
}
.wow-glow::before{
  content:'';
  position:absolute; inset:-2px;
  background:linear-gradient(135deg,rgba(241,11,37,.25),rgba(116,52,172,.25));
  border-radius:32px;
  z-index:-2;
  opacity:.3;
  filter:blur(35px);
}
.wow-glow::after{
  content:'';
  position:absolute; inset:0;
  background:inherit;
  border-radius:30px;
  z-index:-1;
  backdrop-filter:blur(25px);
}

/* Driver‑equation goes horizontal on wide screens */
.driver-equation.flex-row{
  display:flex; align-items:center; justify-content:center;
  flex-wrap:wrap; gap:28px; margin:45px 0;
}
.operator{font-size:2.4rem; color:var(--royal-purple); font-weight:200}

/* Replace emoji‑like icons with subtle duotone glyphs */
.driver-icon{width:60px;height:60px;background:#f8f5ff;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.05); position:relative;}
.driver-icon::after{
  content:'';width:36px;height:36px;mask-size:contain;mask-repeat:no-repeat;
  background:linear-gradient(135deg,var(--royal-purple),var(--fire-bush));
}
.icon-science::after {mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='13' y='24' width='38' height='16' rx='3'/%3E%3C/svg%3E");}
.icon-moon::after    {mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 10a14 14 0 1 0 0 28 14 14 0 0 1 0-28z'/%3E%3C/svg%3E");}
.icon-box::after     {mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='14' y='20' width='36' height='24' rx='4'/%3E%3C/svg%3E");}

/* Stylish two‑column grid on XL screens */
@media (min-width:1300px){
  .stylish-grid{grid-template-columns:1fr 1fr;}
}

/* Phase indicator – remove day text, enlarge */
.phase-indicator{
  flex:0 0 130px; text-align:center; border-right:1px solid #eee; padding-right:25px;
}
.phase-number{
  display:block; font:700 2.6rem/1 'Montserrat',sans-serif;
  color:var(--royal-purple);
}

/* remove timing row entirely */
.phase-timing{display:none!important;}

/* fix stray tiny gold dot & overflow on impact section */
.screen.case-study{overflow:visible;}

/* ── Blueprint card grid tidy‑up ───────────────────────── */
.blueprint-insights{
  /* use a real grid so every column snaps to the same width */
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  gap:48px;
  max-width:1400px;          /* keeps cards from stretching too wide   */
  margin-inline:auto;        /* centres the grid in large view‑ports    */
}
.insight-module{height:100%;}/* cards now all equal height automatically */
/* ── Loyalty Multiverse equation visual polish ─────────── */
.driver-equation{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:36px;
  margin-block:40px 20px;
}

.driver-item{
  width:120px;        /* larger click‑target / visual weight */
  height:120px;
  gap:14px;
  border:2px solid rgba(116,52,172,.08);
}

.plus,
.equals{
  font-size:2.2rem;
  font-weight:700;
  color:var(--royal-purple);
}
/* ── Phase table alignment & visual rhythm ─────────────── */
.timeline-phase{
  display:grid;
  grid-template-columns:140px 30px 1fr;
  align-items:flex-start;
  border-top:1px solid rgba(116,52,172,.08);   /* subtle zebra line */
  padding-block:38px;
}

.timeline-phase:first-of-type{border-top:none;}  /* keep the top edge clean */

/* numbered phase badge */
.phase-indicator{
  position:relative;
  width:140px;
  text-align:center;
  padding-top:4px;
}

.phase-number{
  display:inline-flex;
  align-items:center;justify-content:center;
  width:62px;height:62px;
  border:3px solid var(--royal-purple);
  border-radius:50%;
  font-size:1.75rem;
  font-weight:700;
  color:var(--royal-purple);
}

.phase-indicator::after{           /* vertical accent bar */
  content:'';
  position:absolute;
  left:0;top:10px;bottom:10px;
  width:4px;
  background:linear-gradient(var(--royal-purple),var(--fire-bush));
  border-radius:4px;
}

/* arrow column */
.phase-arrow{
  font-size:2rem;
  color:var(--royal-purple);
  line-height:1;
  margin-top:8px;
}
.nav{
    /* existing properties … */
    z-index:800;          /* ← previously 1000. All Case‑Study elements use 900 */
}
.case-study{
   position:relative;
   z-index:10;     /* above the floating particles */
   overflow:hidden;/* cuts off stray spark elements */
}


/* PROCESS Section */
.process {
    background: linear-gradient(to bottom, var(--cream) 0%, var(--white) 100%);
    position: relative;
    overflow: hidden;
}

.process-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.process-wave {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 200px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.5' d='M0,96L48,112C96,128,192,160,288,160C384,160,480,128,576,112C672,96,768,96,864,112C960,128,1056,160,1152,160C1248,160,1344,128,1392,112L1440,96L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E") no-repeat bottom;
    background-size: cover;
}

.timeline-visual {
    position: relative;
    margin: 80px 0;
}

.timeline-path {
    position: absolute;
    top: 60px;
    left: 0;
    width: 100%;
    height: 2px;
}

.path-svg {
    width: 100%;
    height: 200px;
}

.timeline-phases {
    display: flex;
    justify-content: space-between;
    position: relative;
    z-index: 2;
}

.phase {
    flex: 1;
    text-align: center;
    position: relative;
}

.phase-circle {
    width: 120px;
    height: 120px;
    background: var(--white);
    border: 4px solid var(--royal-purple);
    border-radius: 50%;
    margin: 0 auto 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 10px 40px rgba(116, 52, 172, 0.2);
    transition: all 0.3s ease;
}

.phase-number {
    font-size: 3rem;
    font-weight: 700;
    color: var(--royal-purple);
}

.phase-pulse {
    position: absolute;
    top: -20px;
    left: -20px;
    right: -20px;
    bottom: -20px;
    border: 2px solid var(--royal-purple);
    border-radius: 50%;
    opacity: 0;
    animation: pulse-ring 2s ease-in-out infinite;
}

@keyframes pulse-ring {
    0% {
        transform: scale(0.8);
        opacity: 0;
    }
    50% {
        opacity: 0.3;
    }
    100% {
        transform: scale(1.2);
        opacity: 0;
    }
}

.phase:hover .phase-circle {
    background: var(--royal-purple);
    transform: scale(1.1);
}

.phase:hover .phase-number {
    color: var(--white);
}

.phase-content h3 {
    font-size: 2rem;
    color: var(--royal-purple);
    margin-bottom: 10px;
}

.phase-duration {
    font-size: 1.2rem;
    color: var(--fire-bush);
    font-weight: 600;
    margin-bottom: 10px;
}

.phase-details {
    font-size: 1.1rem;
    color: var(--dark-text);
}

.process-details {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-top: 100px;
}

.detail-card {
    background: var(--white);
    border-radius: 30px;
    padding: 50px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
    border-top: 5px solid var(--royal-purple);
    transition: all 0.3s ease;
}

.detail-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 30px 80px rgba(116, 52, 172, 0.15);
}

.detail-icon {
    width: 120px;
    height: 120px;
    margin: 0 auto 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.05) 0%, rgba(228, 163, 36, 0.05) 100%);
    border-radius: 30px;
    padding: 25px;
    box-shadow: 0 15px 40px rgba(116, 52, 172, 0.1);
}

.detail-svg {
    width: 100%;
    height: 100%;
}

.detail-card h4 {
    font-size: 1.8rem;
    color: var(--royal-purple);
    margin-bottom: 30px;
}

.detail-card ul {
    list-style: none;
}

.detail-card li {
    padding: 12px 0;
    padding-left: 30px;
    position: relative;
    font-size: 1.1rem;
    color: var(--dark-text);
}

.detail-card li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--fire-bush);
    font-weight: 600;
}

/* Decision Section */
.decision {
    background: var(--white);
}

.decision .value-icon {
    width: 160px;
    height: 160px;
    margin: 0 auto 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.05) 0%, rgba(228, 163, 36, 0.05) 100%);
    border-radius: 50%;
    padding: 30px;
    box-shadow: 0 20px 50px rgba(116, 52, 172, 0.15);
}

.decision .value-icon .icon-svg {
    width: 100%;
    height: 100%;
}

.decision .value-card {
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.03) 0%, rgba(228, 163, 36, 0.03) 100%);
    border-radius: 30px;
    padding: 50px;
    border: 1px solid rgba(116, 52, 172, 0.1);
    transition: all 0.3s ease;
    text-align: center;
}

.decision .value-card h3 {
    font-size: 1.8rem;
    color: var(--royal-purple);
    margin-bottom: 20px;
}

.decision .value-card p {
    font-size: 1.15rem;
    line-height: 1.6;
    color: var(--dark-text);
}

.cost-comparison {
    margin: 60px 0;
}

.comparison-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 60px;
}

.cost-item {
    text-align: center;
    padding: 40px;
    border-radius: 20px;
    transition: all 0.3s ease;
    background: var(--white);
}

.cost-item.traditional {
    border: 2px solid var(--red-ribbon);
    box-shadow: 0 10px 30px rgba(241, 11, 37, 0.1);
}

.cost-item.blueprint {
    border: 2px solid var(--royal-purple);
    transform: scale(1.1);
    box-shadow: 0 15px 40px rgba(116, 52, 172, 0.15);
}

.cost-label {
    display: block;
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 15px;
    color: var(--dark-text);
}

.cost-amount {
    display: block;
    font-size: 2.5rem;
    margin-bottom: 15px;
    font-weight: 700;
}

.traditional .cost-amount {
    color: var(--red-ribbon);
}

.blueprint .cost-amount {
    color: var(--royal-purple);
}

.cost-result {
    display: block;
    font-size: 1.1rem;
    color: var(--dark-text);
    opacity: 0.8;
}

.vs-divider {
    font-size: 2rem;
    font-weight: 700;
    color: var(--heathered-gray);
}

.value-props {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin: 80px 0;
}

.value-card {
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.03) 0%, rgba(228, 163, 36, 0.03) 100%);
    border-radius: 30px;
    padding: 50px;
    border: 1px solid rgba(116, 52, 172, 0.1);
    transition: all 0.3s ease;
    text-align: center;
}

.value-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 30px 80px rgba(116, 52, 172, 0.15);
    border-color: var(--royal-purple);
}

.value-icon {
    width: 120px;
    height: 120px;
    margin: 0 auto 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(116, 52, 172, 0.05);
    border-radius: 50%;
    padding: 20px;
}

.value-icon .icon-svg {
    width: 100%;
    height: 100%;
    animation: float 4s ease-in-out infinite;
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.value-card h3 {
    font-size: 1.8rem;
    color: var(--royal-purple);
    margin-bottom: 20px;
}

.value-card p {
    font-size: 1.15rem;
    line-height: 1.6;
    color: var(--dark-text);
}

.urgency-message {
    text-align: center;
    margin: 60px 0;
    padding: 60px;
    background: linear-gradient(135deg, rgba(235, 4, 115, 0.05) 0%, rgba(116, 52, 172, 0.05) 100%);
    border-radius: 30px;
}

.urgency-text {
    font-size: 1.6rem;
    line-height: 1.8;
    color: var(--dark-text);
}

/* Closing Window Section */
.closing {
    background: linear-gradient(135deg, var(--dark-bg) 0%, #3d0000 100%);
    color: var(--white);
    position: relative;
    overflow: hidden;
}

.closing-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.warning-pulse {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(241, 11, 37, 0.3) 0%, transparent 70%);
    animation: pulse 3s ease-in-out infinite;
}

.text-white {
    color: var(--white) !important;
}

.text-red {
    color: var(--red-ribbon);
    text-shadow: 0 0 30px rgba(241, 11, 37, 0.5);
}

.closing-subtitle {
    text-align: center;
    font-size: 1.8rem;
    margin-bottom: 60px;
    opacity: 0.9;
}

.cost-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}

.cost-card {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(241, 11, 37, 0.1) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 30px;
    padding: 50px;
    text-align: center;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border: 2px solid rgba(241, 11, 37, 0.3);
    position: relative;
    overflow: hidden;
}

.cost-card:hover {
    transform: translateY(-15px) scale(1.02);
    box-shadow: 0 40px 100px rgba(241, 11, 37, 0.4);
    border-color: var(--red-ribbon);
}

.cost-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cost-svg {
    width: 100%;
    height: 100%;
}

.cost-icon.rising svg {
    animation: rise 2s ease-in-out infinite;
}

.cost-icon.falling svg {
    animation: fall 2s ease-in-out infinite;
}

.cost-icon.warning svg {
    animation: warning-flash 1s ease-in-out infinite;
}

@keyframes rise {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

@keyframes fall {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(10px); }
}

@keyframes warning-flash {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.6; transform: scale(1.1); }
}

.cost-label {
    font-size: 1.3rem;
    color: var(--white);
    line-height: 1.5;
}

/* Leadership Section */
.leadership {
    background: linear-gradient(to bottom, var(--cream) 0%, var(--white) 100%);
}

.leadership-subtitle {
    text-align: center;
    font-size: 1.5rem;
    color: var(--heathered-gray);
    margin-bottom: 60px;
}

.leadership-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.leader-card {
    background: var(--white);
    border-radius: 24px;
    padding: 40px;
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.08);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.leader-gradient {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 5px;
    background: linear-gradient(90deg, var(--fire-bush), var(--royal-purple), var(--rose));
}

.leader-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 25px 70px rgba(116, 52, 172, 0.15);
}

.leader-name {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--royal-purple);
    margin-bottom: 10px;
}

.leader-title {
    font-size: 1.1rem;
    color: var(--fire-bush);
    margin-bottom: 20px;
    font-weight: 500;
}

.leader-bio {
    font-size: 1.05rem;
    color: var(--dark-text);
    line-height: 1.6;
}

/* CTA Section */
.cta {
    background: linear-gradient(135deg, var(--royal-purple) 0%, var(--dark-bg) 100%);
    color: var(--white);
    text-align: center;
    position: relative;
    overflow: hidden;
    padding: 150px 60px;
}

.cta-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.cta-gradient-1, .cta-gradient-2 {
    position: absolute;
    width: 600px;
    height: 600px;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.3;
}

.cta-gradient-1 {
    background: var(--fire-bush);
    top: -300px;
    right: -300px;
    animation: float 15s ease-in-out infinite;
}

.cta-gradient-2 {
    background: var(--rose);
    bottom: -300px;
    left: -300px;
    animation: float 20s ease-in-out infinite reverse;
}

.cta-particles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.cta-particle {
    position: absolute;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
    animation: float-random 30s infinite linear;
}

.cta-particle:nth-child(1) {
    top: 20%;
    left: 10%;
    animation-delay: 0s;
}

.cta-particle:nth-child(2) {
    top: 60%;
    right: 15%;
    animation-delay: 10s;
}

.cta-particle:nth-child(3) {
    bottom: 20%;
    left: 50%;
    animation-delay: 20s;
}

@keyframes float-random {
    0% {
        transform: translate(0, 0) scale(1);
    }
    33% {
        transform: translate(100px, -100px) scale(1.2);
    }
    66% {
        transform: translate(-100px, 100px) scale(0.8);
    }
    100% {
        transform: translate(0, 0) scale(1);
    }
}

.cta-content {
    position: relative;
    z-index: 2;
    max-width: 1000px;
    margin: 0 auto;
}

.cta-title {
    font-size: clamp(3rem, 6vw, 5rem);
    margin-bottom: 30px;
    font-weight: 300;
    letter-spacing: -2px;
}

.word-animate {
    display: inline-block;
    opacity: 0;
    animation: word-fade 0.6s ease-out forwards;
}

.word-animate:nth-child(1) { animation-delay: 0.1s; }
.word-animate:nth-child(2) { animation-delay: 0.2s; }
.word-animate:nth-child(3) { animation-delay: 0.3s; }
.word-animate:nth-child(4) { animation-delay: 0.4s; }
.word-animate:nth-child(5) { animation-delay: 0.5s; }
.word-animate:nth-child(6) { animation-delay: 0.6s; }
.word-animate:nth-child(7) { animation-delay: 0.7s; }

@keyframes word-fade {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.cta-subtitle {
    font-size: 1.8rem;
    margin-bottom: 50px;
    opacity: 0.9;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.cta-button {
    display: inline-flex;
    align-items: center;
    gap: 15px;
    background: var(--fire-bush);
    color: var(--white);
    padding: 25px 70px;
    border-radius: 60px;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.5rem;
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 15px 50px rgba(228, 163, 36, 0.4);
}

.button-bg {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
}

.cta-button:hover .button-bg {
    left: 100%;
}

.button-text {
    position: relative;
    z-index: 2;
}

.button-arrow {
    position: relative;
    z-index: 2;
    transition: transform 0.3s ease;
}

.cta-button:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 70px rgba(228, 163, 36, 0.5);
}

.cta-button:hover .button-arrow {
    transform: translateX(5px);
}

.cta-contact {
    font-size: 1.3rem;
    margin-top: 40px;
    opacity: 0.9;
}

.email-link, .website-link {
    color: var(--fire-bush);
    text-decoration: none;
    transition: all 0.3s ease;
}

.email-link:hover, .website-link:hover {
    color: var(--rose);
    text-shadow: 0 0 20px rgba(235, 4, 115, 0.5);
}

/* Footer */
.footer {
    background: var(--dark-bg);
    color: var(--white);
    padding: 80px 60px;
    text-align: center;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-content {
    max-width: 800px;
    margin: 0 auto;
}

.footer-logo {
    height: 60px;
    margin-bottom: 20px;
    filter: brightness(1.2);
}

.footer-tagline {
    font-size: 1.2rem;
    color: var(--fire-bush);
    margin-bottom: 40px;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.social-proof {
    margin: 40px 0;
}

.social-proof p {
    font-size: 1.1rem;
    margin-bottom: 20px;
    opacity: 0.8;
}

.brand-logos {
    font-size: 1rem;
    opacity: 0.6;
    line-height: 1.8;
}

.brand-logos span {
    transition: all 0.3s ease;
}

.brand-logos span:hover:not(:nth-child(even)) {
    color: var(--fire-bush);
    opacity: 1;
}

.copyright {
    font-size: 0.95rem;
    opacity: 0.6;
    margin-top: 40px;
}

/* Sticky CTA */
.sticky-cta {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background: linear-gradient(135deg, var(--fire-bush), var(--royal-purple));
    color: var(--white);
    padding: 18px 40px;
    border-radius: 60px;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.1rem;
    box-shadow: 0 15px 50px rgba(228, 163, 36, 0.5);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 0;
    transform: translateY(100px);
    z-index: 999;
    display: flex;
    align-items: center;
    gap: 10px;
}

.sticky-cta.visible {
    opacity: 1;
    transform: translateY(0);
}

.sticky-cta:hover {
    transform: translateY(-5px) scale(1.05);
    box-shadow: 0 20px 70px rgba(228, 163, 36, 0.6);
}

.sticky-arrow {
    transition: transform 0.3s ease;
}

.sticky-cta:hover .sticky-arrow {
    transform: translateX(5px);
}

/* Animations */
.fade-in {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* AOS-like animations */
[data-aos="fade-up"] {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s ease;
}

[data-aos="fade-right"] {
    opacity: 0;
    transform: translateX(-40px);
    transition: all 0.8s ease;
}

[data-aos="fade-left"] {
    opacity: 0;
    transform: translateX(40px);
    transition: all 0.8s ease;
}

[data-aos="zoom-in"] {
    opacity: 0;
    transform: scale(0.8);
    transition: all 0.8s ease;
}

[data-aos="flip-left"] {
    opacity: 0;
    transform: perspective(2500px) rotateY(-100deg);
    transition: all 0.8s ease;
}

[data-aos="flip-up"] {
    opacity: 0;
    transform: perspective(2500px) rotateX(-100deg);
    transition: all 0.8s ease;
}

[data-aos="slide-right"] {
    opacity: 0;
    transform: translateX(-100px);
    transition: all 0.8s ease;
}

[data-aos="slide-left"] {
    opacity: 0;
    transform: translateX(100px);
    transition: all 0.8s ease;
}

.visible [data-aos] {
    opacity: 1;
    transform: none;
}

/* Mobile Responsiveness for Stepper */
@media (max-width: 768px) {
    .stepper summary {
        padding: 20px;
        flex-wrap: wrap;
        gap: 15px;
    }
    
    .step-index {
        width: 40px;
        height: 40px;
        font-size: 1.2rem;
    }
    
    .step-title {
        flex: none;  /* ADD THIS */
        width: calc(100% - 60px);  /* ADD THIS */
    }
    
    .step-duration {
        width: 100%;
        margin-left: 55px;  /* CHANGE from 60px to 55px */
        margin-right: 40px;  /* ADD THIS LINE */
        font-size: 0.9rem;
    }
    
    .step-content {
        padding: 0 20px 20px;
    }
    
    .step-list li {
        font-size: 1rem;
        padding-left: 30px;
    }
    
    .stepper summary::after {
        right: 20px;
        top: 20px;  /* ADD THIS LINE */
    }
}

/* Hero subtitle tightening on mobile */
@media (max-width: 768px) {
    .hero-sub {
        font-size: clamp(1.1rem, 3vw, 1.3rem);
        line-height: 1.4;
        padding: 0 10px;
    }
    
    .hero-sub br {
        display: none;
    }
}

/* Responsive */
@media (max-width: 1200px) {
    .beyond-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .modules {
        grid-template-columns: 1fr;
    }
    
    .results-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 1024px) {
    .screen {
        padding: 80px 40px;
    }

    .nav {
        padding: 20px 40px;
    }

    .brutal-grid,
    .value-props,
    .process-details,
    .leadership-grid {
        grid-template-columns: 1fr;
    }

    .gap-comparison {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .gap-divider {
        display: none;
    }

    .timeline-phases {
        flex-direction: column;
        gap: 60px;
    }

    .cost-grid {
        grid-template-columns: 1fr;
    }

    .comparison-visual {
        flex-direction: column;
    }

    .old-playbook {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 768px) {
    .screen {
        padding: 60px 20px;
        min-height: auto;
    }

    .nav {
        padding: 15px 20px;
    }

    h1 {
        font-size: 2.5rem;
    }

    h2 {
        font-size: 2rem;
    }

    .hero-sub {
        font-size: 1.3rem;
    }

    .hero-stats {
        flex-direction: column;
        gap: 30px;
    }

    .book-briefing {
        padding: 10px 25px;
        font-size: 0.9rem;
    }

    .sticky-cta {
        bottom: 20px;
        right: 20px;
        padding: 12px 25px;
    }

    .logo-hero {
        width: 250px;
    }

    .cta-button {
        padding: 18px 40px;
        font-size: 1.2rem;
    }

    .beyond-grid,
    .results-grid {
        grid-template-columns: 1fr;
    }
}
@media print {
    /* Force backgrounds to print */
    * {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
    }
    
    /* Fix sections not showing */
    .screen {
        page-break-inside: avoid;
        min-height: auto !important;
        height: auto !important;
        padding: 40px !important;
    }
    
    /* Hide animations */
    .particle,
    .hero-shape-1,
    .hero-shape-2,
    .hero-shape-3,
    .cta-particle {
        display: none !important;
    }
    
    /* Ensure content is visible */
    .fade-in,
    [data-aos] {
        opacity: 1 !important;
        transform: none !important;
    }
}
#pager{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:9999;
  display:flex;
  gap:8px;
  pointer-events:none;      /* let page receive clicks unless showing */
}
#pager button{
  pointer-events:auto;
  width:44px;height:44px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(6px);
  color:#fff;
  font-size:1.3rem;
  cursor:pointer;
  transition:background .25s;
}
#pager button:hover{background:rgba(255,255,255,.35);}
#pager.hidden{opacity:0;transition:opacity .3s;}
/* --- Case‑study tweaks --- */
.case-study.advisory .case-label{
  /* violet label with subtle glow */
  font-size:.75rem;font-weight:600;letter-spacing:.6px;
  color:#fff;background:#7434ac;padding:4px 10px;border-radius:4px;
  box-shadow:0 0 6px rgba(116,52,172,.6);
}
.case-study .story-point{margin:60px 0;display:flex;gap:40px}
.case-study .point-marker{flex:0 0 110px}
.case-study .point-marker.alt{order:2} /* switch side */
.case-study .point-content{flex:1;background:#faf7ff;padding:25px 30px;border-radius:10px;
  box-shadow:0 6px 18px rgba(0,0,0,.06)}
.case-study .bullet li{margin:6px 0}
.case-study .rec-actions{margin-left:20px}
.case-results .result-footnote{font-size:.75rem;color:#666;margin-top:12px}
.case-disclaimer{font-size:.7rem;color:#888;margin-top:25px;text-align:center}
.case-pager{text-align:center;margin-top:40px}
.pager-btn{background:#7434ac;color:#fff;border:none;padding:10px 20px;
  border-radius:30px;cursor:pointer;margin:0 8px;font-size:.85rem;
  transition:background .25s}
.pager-btn:hover{background:#5e2d8e}

/* ---------- Section Pager ---------- */
#section-pager{position:fixed; bottom:2rem; right:2rem; z-index:9999; display:flex; gap:.5rem;}
#section-pager button{
  width:46px; height:46px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(116,52,172,.85); color:#fff; font-size:1.8rem; line-height:1;
  box-shadow:0 4px 10px rgba(0,0,0,.2); transition:background .25s,transform .25s;
}
#section-pager button:hover{background:#eb0473; transform:scale(1.08);}
#section-pager button:disabled{opacity:.25; cursor:default; transform:none;}
/* ---------- Case Study v2 ---------- */
.story-grid      {display:grid; gap:2.5rem; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); margin-top:2.5rem;}
.story-card      {background:#fff; border-radius:12px; padding:2rem 1.6rem; position:relative; box-shadow:0 4px 12px rgba(0,0,0,.08);}
.story-card h3   {margin-top:0; font-size:1.2rem; line-height:1.3; color:#7434ac;}
.story-lede      {font-weight:600; margin:.6rem 0 1rem;}
.story-bullets   {padding-left:1.2rem; margin:0;}
.story-bullets li{margin-bottom:.5rem; font-size:.95rem;}
.segment-donut   {display:flex; flex-direction:column; align-items:center; margin-top:1.2rem;}
.segment-donut .slice{--p:50; width:120px; aspect-ratio:1; border-radius:50%; background:conic-gradient(var(--col,#7434ac) calc(var(--p)*1%),#eee 0);}
.slice1{--col:#7434ac;}
.slice2{--col:#e4a324;}
.segment-donut figcaption{font-size:.8rem; margin-top:.5rem; color:#555;}
.story-steps     {margin:.8rem 0 0 1.2rem; padding:0; counter-reset:step;}
.story-steps li  {margin-bottom:.6rem; position:relative;}
.story-steps li::before{counter-increment:step; content:counter(step) "."; position:absolute; left:-1.4rem; color:#eb0473; font-weight:700;}
.impact-metrics  {display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-top:1.4rem;}
.impact-metrics .metric{display:block; font-size:1.6rem; font-weight:700; color:#e4096f;}
.case-footnotes  {font-size:.75rem; color:#777; margin-top:1.5rem; text-align:center;}

@media (min-width:768px){
  .impact-metrics{grid-template-columns:repeat(4,1fr);}
}
/* ——— CASE STUDY (Laneige) ——— */
.case-study { padding: 4rem 0 5rem; background: #faf8ff; }
.case-study .center { text-align:center; }

.case-study .subtitle {
  display:block; margin-top:.4rem; font-size:1rem;
  font-weight:400; color:#6a6a6a;
}

.cs-grid {
  display:grid; gap:2.5rem;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  margin-top:3rem;
}

.cs-box{
  background:#fff; padding:2rem 1.8rem; border-radius:12px;
  box-shadow:0 6px 22px rgba(118,74,188,.08);
  position:relative; overflow:hidden;
}

.cs-head{ margin:0 0 1rem; font-size:1.2rem; color:#7434ac; }
.cs-body{ margin:0; padding-left:1.1em; line-height:1.55; }
.cs-body li{ margin:.6rem 0; }

.cs-impact{
  grid-column:1/-1; /* span full grid */
  background:#27123d url("cs-pattern.svg") center/cover;
  color:#fff; border-radius:14px; padding:2.5rem 2rem; text-align:center;
  position:relative; overflow:hidden;
}
.cs-impact::before{
  content:''; position:absolute; inset:0;
  backdrop-filter:blur(6px);
}
.impact-title{ margin:0 0 2rem; font-size:1.4rem; font-weight:600; position:relative; }
.impact-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:2rem; position:relative; }

.impact-card{
  flex:1 1 150px; max-width:180px; padding:1.5rem 1rem;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
}
.metric{ display:block; font-size:2rem; font-weight:700; line-height:1.2; }
.impact-card small{ display:block; margin-top:.4rem; font-size:.83rem; line-height:1.3; color:#e5e1ff; }

/* Responsive fine‑tuning */
@media (max-width:600px){
  .cs-box{ padding:1.6rem 1.4rem; }
  .cs-impact{ padding:2rem 1.4rem; }
  .impact-grid{ gap:1rem; }
}
.page-nav{
  position:fixed; bottom:2rem; right:2rem; z-index:999;
  display:flex; gap:.5rem;
}
.page-nav button{
  background:#7434ac; color:#fff; padding:.6rem 1rem;
  border:none; border-radius:4px; font-weight:600; cursor:pointer;
  transition:background .25s;
}
.page-nav button:hover{ background:#5d2d96; }

.sticky-cta {
  display: none !important;
}
/* KPI Sources */
.kpi-sources {
    background: #f5f5f5;
    padding: 40px 20px;
    border-top: 1px solid #e0e0e0;
}

.kpi-sources h4 {
    font-size: 1.2rem;
    color: var(--dark-text);
    margin-bottom: 20px;
    font-weight: 600;
}

.kpi-sources ol {
    list-style: none;
    padding: 0;
    max-width: 800px;
    margin: 0 auto;
}

.kpi-sources li {
    font-size: 0.9rem;
    color: #666;
    margin-bottom: 10px;
    line-height: 1.6;
}

.kpi-sources sup {
    font-weight: 600;
    color: var(--royal-purple);
    margin-right: 5px;
}

/* Hero KPI references */
.kpi-ref {
    text-decoration: none;
    color: inherit;
    vertical-align: super;
    font-size: 0.8em;
    font-weight: 400;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.kpi-ref:hover {
    opacity: 1;
    color: var(--fire-bush);
}
/* ─── Loyalty Multiverse layout tweaks ───────────────────────────────*/
.driver-equation{
  display:flex; align-items:center; justify-content:center;
  gap:40px; flex-wrap:wrap; margin:50px 0 35px;
}
.driver-item, .driver-result{
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.driver-item{
  background:#f9f6ff; border:1px solid rgba(116,52,172,.08);
  border-radius:14px; padding:38px 34px; width:180px;
  box-shadow:0 6px 24px rgba(116,52,172,.06);
}
.driver-svg{ width:48px; height:48px; margin-bottom:20px; }
.op{ font-size:38px; font-weight:300; color:#7434ac; }
.driver-result{
  background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  color:#fff; width:180px; padding:40px 0; border-radius:18px;
  box-shadow:0 20px 60px rgba(228,163,36,.25);
}
.result-value{ font-size:36px; font-weight:700; line-height:1; }
.result-text { font-size:14px; opacity:.9; }

/* ─── Strategy timeline refresh ─────────────────────────────────────*/
.track-tabs{display:flex;align-items:center;justify-content:center;gap:10px;margin:30px 0 40px;}
.track-label{
  padding:7px 22px;border:2px solid #7434ac;border-radius:30px;font-size:12px;
  font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#7434ac;
}
.track-label.active{background:#7434ac;color:#fff;}
.track-connector{
  width:160px;height:2px;background:#7434ac;border-radius:2px;
}
.action-timeline{display:grid;gap:60px;max-width:1080px;margin:0 auto;}
.action-phase{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:40px;
  background:#fff;border:1px solid rgba(116,52,172,.12);border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.06);padding:50px 40px;position:relative;
}
.phase-left ul,.phase-right ul{margin:18px 0 0 18px;}
.phase-marker{
  display:inline-block;background:#fff;color:#7434ac;
  border:2px solid #7434ac;border-radius:50%;width:70px;height:70px;
  text-align:center;line-height:66px;font-size:22px;font-weight:700;
  box-shadow:0 0 0 6px rgba(116,52,172,.12);margin-bottom:18px;
}
.phase-arrow{
  font-size:42px;color:#7434ac;font-weight:100;align-self:center;
}
.phase-result{margin-top:16px;font-size:14px;color:#7434ac;}

/* responsive */
@media(max-width:900px){
  .driver-equation{gap:28px;}
  .action-phase{grid-template-columns:1fr;border-left:6px solid var(--fire-bush);}
  .phase-arrow{display:none;}
  .phase-marker{margin-bottom:12px;}
}

/* ─── Case‑study polish (paste after existing CASE STUDY rules) ───────────────── */

/* 1 ░ Blueprint insights grid ░ */
.blueprint-insights{
    display:grid;
    gap:60px;
    grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
    align-items:start;
}

/* Card consistency */
.insight-module{
    min-height:100%;                     /* all same height in the grid   */
    display:flex; flex-direction:column; /* title‑area sticks to top       */
    background:var(--white);
    box-shadow:0 24px 60px rgba(116,52,172,.08);
    padding:48px 40px;
}

/* 2 ░ Loyalty Multiverse equation ░ */
.driver-equation{display:flex;align-items:center;justify-content:center;gap:32px;}
.driver-item{
    width:120px;height:120px;
    flex:0 0 auto;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    background:#f8f5ff;border-radius:20px;
}
.driver-item svg{width:48px;height:48px;margin-bottom:12px;color:#7434ac;}
.operator{font-size:2.2rem;font-weight:700;color:#7434ac;}
.driver-result{
    width:140px;height:140px;
    flex:0 0 auto;
    border-radius:22px;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    background:linear-gradient(135deg,var(--fire-bush),var(--rose));
    color:#fff;box-shadow:0 18px 50px rgba(228,163,36,.28);
}
.result-value{font-size:2.5rem;line-height:1;margin-bottom:.25rem;}
/* Mobile stack */
@media(max-width:800px){
  .driver-equation{flex-direction:column;gap:20px;}
  .operator{transform:rotate(90deg);}
}

/* 3 ░ Transformation phases layout ░ */
.parallel-timeline{
    display:grid;gap:60px;
}
@media(min-width:1200px){
  .parallel-timeline{grid-template-columns:400px 1fr;}
}
/* phase cards */
.timeline-phase{
    background:#fff;border-radius:20px;padding:50px 40px;
    box-shadow:0 24px 60px rgba(0,0,0,.08);
}
.phase-indicator{
    display:flex;align-items:center;gap:18px;margin-bottom:32px;
}
.phase-number{
    width:46px;height:46px;border-radius:50%;line-height:46px;text-align:center;
    background:#fff;border:3px solid var(--royal-purple);font:700 1.2rem/46px var(--font,inherit);
}
.phase-timing{font-weight:600;color:var(--royal-purple);}
/* arrow nicely centred */
.phase-arrow{font-size:2rem;color:#7434ac;margin:0 24px;}

/* 4 ░ Universal card padding & shadows (for all case‑study cards) ░ */
.case-study .insight-module,
.case-study .timeline-phase,
.case-study .stat-group,
.case-study .result-card{
    transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.case-study .insight-module:hover,
.case-study .timeline-phase:hover,
.case-study .result-card:hover{
    transform:translateY(-6px);
}
/*══════════  CASE STUDY  ══════════*/
.case-study{
  background:linear-gradient(to bottom,var(--white) 0%,#f8f5ff 100%);
  padding:120px 20px;position:relative;overflow:hidden
}
.case-header{text-align:center;margin-bottom:60px}
.case-label{display:inline-block;padding:8px 28px;border-radius:28px;
  background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:#fff;font-weight:700;font-size:.8rem;letter-spacing:2px;text-transform:uppercase}
.case-subtitle{max-width:780px;margin:22px auto 0;font-size:1.45rem;color:var(--heathered-gray)}

.blueprint-reveal{margin-top:80px}
.section-subtitle{font-size:2rem;text-align:center;margin-bottom:50px;font-weight:300}

.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:50px}
.insight-card{background:#fff;border:1px solid rgba(116,52,172,.12);
  border-radius:24px;padding:50px;box-shadow:0 18px 54px rgba(0,0,0,.06);position:relative}
.insight-head{display:flex;align-items:center;gap:18px;margin-bottom:25px}
.tool-badge{background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:#fff;padding:6px 20px;border-radius:18px;font-size:.8rem;font-weight:700;white-space:nowrap}

.edge-columns{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin:28px 0}
.edge-col h5{font-size:1.05rem;color:var(--royal-purple);margin-bottom:12px}
.edge-col ul{margin:0;padding:0;list-style:none}
.edge-col li{padding:6px 0;position:relative;padding-left:18px;font-size:.95rem}
.edge-col li::before{content:"•";position:absolute;left:0;color:var(--fire-bush);font-weight:700}

.edge-conclusion{margin-top:25px;padding:18px 22px;border-radius:12px;
  background:rgba(116,52,172,.04);font-size:1.05rem}

.loyalty-stats{display:flex;gap:26px;margin:30px 0}
.stat-box{flex:1;padding:26px 20px;border-radius:16px;text-align:center;border:2px solid}
.stat-box .percent{display:block;font-size:2.4rem;font-weight:700;margin-bottom:6px}
.stat-box.curious{border-color:var(--fire-bush)}
.stat-box.recon{border-color:var(--royal-purple)}
.stat-tag{font-weight:600;font-size:.95rem}
.stat-box small{display:block;font-size:.8rem;line-height:1.4;margin-top:6px}

.index-key{margin-bottom:18px;font-size:1rem;font-weight:500}
.index-triggers{margin:0 0 0 16px;font-size:.95rem;line-height:1.6}

.multiverse-equation{display:flex;align-items:center;justify-content:center;gap:20px;margin:35px 0 28px}
.mv-block{flex:0 0 150px;padding:38px 16px;border-radius:18px;text-align:center;
  background:rgba(116,52,172,.05);font-size:.9rem;font-weight:600;color:var(--dark-text)}
.mv-symbol{font-size:2rem;font-weight:300;color:var(--royal-purple)}
.mv-result{flex:0 0 140px;border-radius:18px;padding:32px 10px;text-align:center;
  background:linear-gradient(135deg,var(--fire-bush),var(--rose));color:#fff;
  box-shadow:0 12px 34px rgba(228,163,36,.3)}
.mv-lift{display:block;font-size:2.3rem;font-weight:700;margin-bottom:4px}
.why-it-works{margin-left:18px;font-size:.95rem;line-height:1.6}

.strategic-actions{margin-top:90px}
.track-labels{text-align:center;margin-bottom:20px}
.track{display:inline-block;padding:6px 18px;border-radius:18px;font-size:.78rem;font-weight:700;margin:0 4px}
.track.research{border:2px solid var(--royal-purple);color:var(--royal-purple)}
.track.marketing{border:2px solid var(--royal-purple);background:var(--royal-purple);color:#fff}

.phase-table{display:flex;flex-direction:column;gap:40px;margin-top:30px}
.phase-row{display:grid;grid-template-columns:120px 1fr 20px 1fr;gap:28px;background:#fff;
  border-radius:22px;padding:40px;border:1px solid rgba(116,52,172,.1);
  box-shadow:0 14px 40px rgba(0,0,0,.04)}
.phase-pill{display:flex;align-items:center;justify-content:center;
  width:88px;height:88px;border:2px solid var(--royal-purple);border-radius:50%;
  font-size:1.1rem;font-weight:700;color:var(--royal-purple);}
.phase-col h5{font-size:1.15rem;margin-bottom:10px;color:var(--dark-text)}
.phase-col ul{margin:0 0 10px 18px;font-size:.95rem;line-height:1.6}
.deliverable{font-size:.88rem;font-weight:600;color:var(--fire-bush)}
.arrow{display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--royal-purple)}

.collab-note{font-size:.9rem;font-style:italic;margin:35px 0;text-align:center}

.case-results{background:linear-gradient(135deg,#2a1548,var(--dark-bg));
  border-radius:26px;padding:70px 40px;margin:90px 0 60px;position:relative;color:#fff}
.results-title{text-align:center;font-size:2.2rem;font-weight:300;margin-bottom:50px}
.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;max-width:960px;margin:0 auto}
.result-card{background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.12);
  border-radius:18px;padding:36px 20px;text-align:center;transition:.25s}
.result-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.1)}
.result-num{display:block;font-size:2.6rem;font-weight:700;background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px}
.result-tag{font-size:.95rem;line-height:1.3;color:rgba(255,255,255,.92)}

.case-quote{max-width:800px;margin:0 auto 60px;font-size:1.3rem;line-height:1.8;font-style:italic;color:var(--dark-text)}
.case-quote cite{display:block;margin-top:18px;font-weight:600;color:var(--royal-purple);font-style:normal}

.case-cta{text-align:center}
.cta-question{font-size:1.5rem;margin-bottom:26px}
.cta-button{display:inline-block;padding:18px 50px;border-radius:48px;background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  color:#fff;font-weight:700;font-size:1.15rem;transition:.25s}
.cta-button:hover{transform:translateY(-3px);box-shadow:0 14px 38px rgba(228,163,36,.4)}

.case-footnotes{text-align:center;font-size:.8rem;font-style:italic;color:var(--heathered-gray);opacity:.8;margin-top:45px}

/*────  Responsive  ────*/
@media(max-width:1024px){
  .insight-card{padding:40px}
  .phase-row{grid-template-columns:90px 1fr 20px 1fr;padding:30px 28px}
  .phase-pill{width:70px;height:70px;font-size:1rem}
}
@media(max-width:680px){
  .insights-grid{grid-template-columns:1fr}
  .blueprint-reveal .section-subtitle{font-size:1.7rem}
  .multiverse-equation{flex-direction:column}
  .mv-symbol{transform:rotate(90deg)}
  .phase-table{gap:28px}
  .phase-row{grid-template-columns:1fr;padding:30px}
  .arrow{display:none}
}
/* ════════════════════════════════════════════════════════════
   LANEIGE CASE‑STUDY  (adds no side‑effects to other sections)
   ════════════════════════════════════════════════════════════ */
.case-study {background:linear-gradient(#fff 0%,#f8f6ff 100%);padding:120px 20px;}
.case-hero{text-align:center;margin-bottom:80px}
.case-pill{display:inline-block;padding:8px 22px;border-radius:20px;background:#7434ac;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:1px}
.case-title{font-size:clamp(2.3rem,4vw,3.5rem);font-weight:300;line-height:1.2;margin:20px 0}
.case-sub{max-width:700px;margin:0 auto;color:#6b6b6b;font-size:1.1rem}
/* ------------- Challenge -------------- */
.challenge{background:rgba(241,11,37,.02);border:2px solid rgba(241,11,37,.15);border-radius:28px;padding:60px;margin-bottom:90px}
.challenge-head{text-align:center;font-size:2rem;font-weight:400;margin-bottom:50px}
.challenge-flex{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:50px;margin-bottom:40px}
.challenge-metric{text-align:center}
.metric-big{display:block;font-size:4rem;font-weight:700;color:#f10b25;line-height:1}
.metric-label{font-size:1.05rem;color:#222;opacity:.8}
.arrow{font-size:3rem;color:#f10b25;opacity:.4}
.challenge-list ul{margin:0;padding-left:18px}
.challenge-list li{margin:6px 0}
.challenge-copy{max-width:860px;margin:0 auto;font-size:1.15rem;line-height:1.7;color:#222}
/* ------------- Insights grid ----------- */
.section-kicker{text-align:center;font-size:2.2rem;font-weight:400;margin-bottom:60px}
.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:50px;margin-bottom:100px}
.insight-card{background:#fff;border:1px solid rgba(116,52,172,.12);border-radius:24px;padding:45px;box-shadow:0 18px 40px rgba(0,0,0,.06)}
.badge{display:inline-block;background:#7434ac;color:#fff;padding:6px 20px;border-radius:16px;font-size:.8rem;font-weight:700;letter-spacing:.5px;margin-bottom:20px}
.insight-card h4{font-size:1.5rem;font-weight:600;margin:0 0 20px;color:#222}
.insight-card p{font-size:1.05rem;line-height:1.75;margin-bottom:25px;color:#222}
.two-col-list{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0}
.two-col-list h5{font-size:1rem;margin-bottom:8px;color:#7434ac}
.two-col-list ul{margin:0;padding-left:18px}
.callout{background:rgba(116,52,172,.05);padding:18px 22px;border-radius:12px;font-size:1rem}
.stat-pair{display:flex;gap:25px;margin:25px 0;flex-wrap:wrap}
.stat-box{flex:1 1 120px;border:2px solid;border-radius:14px;padding:22px 18px;text-align:center}
.curious{border-color:#e4a324}
.recon{border-color:#7434ac}
.stat-box .num{display:block;font-size:2.4rem;font-weight:700;margin-bottom:6px}
.stat-label{font-weight:600;font-size:1rem}
.insight-copy{font-size:1rem;margin:18px 0 24px}
.bullet-tight{padding-left:18px;margin:0}
.bullet-tight li{margin:6px 0;font-size:1rem}
.formula-row{display:flex;align-items:center;justify-content:center;gap:18px;margin:30px 0 25px;flex-wrap:wrap}
.formula-block{background:#f9f7ff;border:1px solid rgba(116,52,172,.15);border-radius:12px;padding:32px 20px;text-align:center;font-size:1rem;line-height:1.4;flex:0 1 130px}
.op{font-size:2.2rem;color:#7434ac;font-weight:300}
.formula-result{background:linear-gradient(135deg,#e4a324,#eb0473);color:#fff;border-radius:16px;padding:28px 30px;font-size:2rem;font-weight:700;text-align:center;line-height:1.2;flex:0 1 140px;box-shadow:0 6px 20px rgba(228,163,36,.35)}
.formula-result small{display:block;font-size:.75rem;font-weight:400;margin-top:4px}
/* ------------- Strategy --------------- */
.track-tags{display:flex;gap:8px;justify-content:center;margin-bottom:25px}
.track{padding:6px 16px;border:1px solid #7434ac;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.5px;color:#7434ac;text-transform:uppercase;background:#fff}
.research{border-color:#7434ac}
.marketing{border-color:#7434ac}
.phase-stack{display:flex;flex-direction:column;gap:40px;margin-bottom:40px}
.phase-card{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:25px;background:#fff;border:1px solid rgba(116,52,172,.12);border-radius:24px;padding:40px;box-shadow:0 14px 36px rgba(0,0,0,.05)}
.phase-num{grid-row:span 2;background:#fff;border:3px solid #7434ac;color:#7434ac;width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}
.phase-col h4{font-size:1.1rem;font-weight:700;margin:0 0 10px}
.phase-col ul{margin:0 0 10px 18px}
.phase-col li{margin:6px 0;font-size:.95rem}
.deliver{font-size:.9rem;color:#e4a324;font-weight:600}
.arrow-right{font-size:1.6rem;color:#7434ac;align-self:center}
.collab-note{background:#f9f7ff;border:1px solid rgba(116,52,172,.12);border-radius:16px;padding:18px 22px;font-size:.95rem;margin:20px 0 50px;text-align:center}
/* ------------- Impact bar ------------- */
.impact-bar{display:flex;justify-content:center;gap:30px;flex-wrap:wrap}
.impact-bar div{background:#f5f3ff;border-radius:16px;padding:22px 28px;text-align:center;flex:0 1 120px}
.impact-bar span{display:block;font-size:1.4rem;font-weight:700;color:#7434ac}
.impact-bar small{font-size:.75rem}
/* ------ Responsive tweaks ------ */
@media (max-width:1024px){
  .challenge{padding:40px}
  .insight-grid{gap:35px}
  .phase-card{grid-template-columns:1fr;gap:18px}
  .phase-num{margin:0 auto}
  .arrow-right{display:none}
}
@media (max-width:600px){
  .metric-big{font-size:2.8rem}
  .challenge-flex{gap:25px}
  .two-col-list{grid-template-columns:1fr}
  .phase-card{padding:30px 24px}
}
/* ═══════════════════════════════════ */

/* END of case‑study polish */
/* ─── CASE STUDY LAYOUT FIXES 2025‑07‑21 ───────────────────────────── */

/* stack the three insight modules on narrow screens & center them */
.column-stack {
  display: flex;
  flex-direction: column;
  gap: 60px;
}

/* full‑width cards look cramped at >1300 px; switch to row layout then */
@media (min-width: 1300px){
  .column-stack{
    flex-direction: row;
  }
}

/* Transformation grid: two tracks in perfect vertical alignment */
.transformation-grid{
  display: grid;
  gap: 50px;
}

.tracks-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-bottom:30px;
}

.track-title{
  display:block;
  padding:8px 22px;
  font-size:.8rem;
  font-weight:700;
  border:2px solid var(--royal-purple);
  border-radius:30px;
  text-align:center;
  text-transform:uppercase;
}

.phase-card{
  background:#fff;
  border-radius:24px;
  padding:40px 50px;
  box-shadow:0 12px 35px rgba(0,0,0,.06);
  border:1px solid rgba(116,52,172,.12);
}

.phase-badge{
  width:60px;height:60px;line-height:60px;
  text-align:center;
  font-weight:700;
  color:var(--royal-purple);
  border:3px solid var(--royal-purple);
  border-radius:50%;
  margin-bottom:25px;
}

.phase-body{
  display:grid;
  grid-template-columns:1fr 40px 1fr;
  gap:25px;
}

.phase-body::before{
  content:'→';
  grid-column:2;
  align-self:center;
  justify-self:center;
  font-size:1.6rem;
  color:var(--royal-purple);
}

.track-block h4{
  font-size:1.15rem;
  margin:0 0 10px;
  color:var(--royal-purple);
  font-weight:600;
}

.track-outcome{
  margin-top:12px;
  font-size:.9rem;
  color:var(--fire-bush);
  font-weight:600;
}

/* remove old Week 2 / Week 6 timeline */
.transformation-results,
.timeline-visual,
.results-disclaimer {display:none!important;}

/* 90‑Day arc visuals */
.ninety-title{
  text-align:center;
  font-size:2.2rem;
  font-weight:300;
  margin:100px 0 40px;
}

.ninety-arc{
  width:100%;
  max-width:900px;
  height:180px;
  display:block;
  margin:0 auto;
}

.ninety-steps{
  display:flex;
  justify-content:space-between;
  max-width:900px;
  margin:-120px auto 0;         /* pull up under the arc */
  padding:0 15px;
}

.ninety-steps .step{
  text-align:center;
}

.ninety-steps .circle{
  width:100px;height:100px;
  border:4px solid var(--royal-purple);
  border-radius:50%;
  line-height:100px;
  font-size:2rem;
  font-weight:700;
  color:var(--royal-purple);
  box-shadow:0 8px 25px rgba(116,52,172,.12);
  background:rgba(255,255,255,.9);
  margin:0 auto 15px;
}

.ninety-steps h4{margin:0;font-size:1.25rem;color:var(--royal-purple);font-weight:600}

/* footer: single gray bar; remove duplicate white slab */
.footer-sources,
.source-notes{
  background:transparent!important;
  border:none!important;
  color:rgba(255,255,255,.8);
  font-size:.8rem;
  text-align:center;
  margin-top:30px;
}
/* ─── Case‑Study Fixes & Responsive Grid ─────────────────────────── */
.insight-grid{
  display:grid;
  gap:48px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  margin-top:60px;
}

/* Insight card base */
.insight-card{
  background:#fff;
  border:1px solid rgba(116,52,172,.12);
  border-radius:20px;
  padding:40px 30px;
  box-shadow:0 15px 45px rgba(0,0,0,.06);
}
.insight-card header{margin-bottom:25px;}
.insight-card h4{font-size:1.55rem;margin:0 0 8px;color:var(--dark-text);}
.analysis-headline,.strategy-headline,.arc-headline{
  text-align:center;
  font-size:2.2rem;
  font-weight:300;
  margin:90px 0 40px;
}
.driver-equation{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:20px;
  margin:35px 0;
}
.driver-item{
  background:rgba(116,52,172,.04);
  border-radius:14px;
  padding:24px 18px;
  text-align:center;
  font-size:.95rem;
  font-weight:500;
  min-width:120px;
}
.driver-result{
  background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  color:#fff;
  border-radius:14px;
  padding:28px 22px;
  text-align:center;
}
.op{font-size:1.8rem;font-weight:700;color:var(--royal-purple);}

/* Strategy timeline */
.track-legend{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:40px;
  margin:60px 0 30px;
}
.track-label{
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.8px;
  padding:6px 18px;
  border-radius:20px;
  border:2px solid var(--royal-purple);
  text-transform:uppercase;
}
.track-label.marketing{border-color:var(--fire-bush);}
.track-connector{
  width:90px;height:2px;
  background:linear-gradient(90deg,var(--royal-purple),var(--fire-bush));
}
.strategy-phases{
  display:flex;
  flex-direction:column;
  gap:50px;
  margin-bottom:80px;
  max-width:1000px;
  margin-left:auto;
  margin-right:auto;
}
.phase{
  display:grid;
  grid-template-columns:120px 1fr 36px 1fr;
  gap:30px;
}
.phase-marker{
  width:120px;height:120px;
  border:4px solid var(--royal-purple);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;font-weight:700;color:var(--royal-purple);
  position:relative;
}
.phase-marker::after{
  content:'';position:absolute;inset:-10px;
  border:2px solid rgba(116,52,172,.15);border-radius:50%;
}
.phase-block h4{margin:0 0 8px;font-size:1.3rem;color:var(--dark-text);}
.phase-block ul{margin:0 0 12px 18px;padding:0;font-size:.95rem;line-height:1.5;}
.phase-block .deliverable{font-size:.9rem;font-style:italic;color:var(--fire-bush);}
.phase-arrow{font-size:1.8rem;line-height:1;color:var(--fire-bush);align-self:center;}

/* 90‑Day arc */
.arc-visual{margin:40px auto 0;max-width:800px;position:relative;text-align:center;}
.arc-steps{
  list-style:none;margin:0;padding:0;display:flex;justify-content:space-between;
}
.arc-steps .circle{
  width:72px;height:72px;border-radius:50%;
  border:4px solid var(--royal-purple);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.2rem;color:var(--royal-purple);
  background:#fff;position:relative;
}
.arc-steps .label{display:block;margin-top:12px;font-weight:600;color:var(--royal-purple);}
.arc-path{position:absolute;left:0;right:0;top:24px;height:96px;pointer-events:none;}
.arc-path path{stroke:url(#grad);stroke-width:3;}

/* Make sure nothing spills on small screens */
@media(max-width:768px){
  .phase{grid-template-columns:1fr;gap:20px;}
  .phase-arrow{display:none;}
  .track-legend{flex-direction:column;gap:14px;}
}

/* Footer source note – tiny & inline */
.footer .source-line{
  font-size:.7rem;opacity:.65;margin-top:18px;
  max-width:700px;margin-left:auto;margin-right:auto;
}
/* ─────────  LANEIGE CASE STUDY  ───────── */
.case-study{background:linear-gradient(to bottom,var(--white)0%,#f8f5ff 100%);
  padding:120px 20px;position:relative;overflow:hidden}
.case-study .case-header{text-align:center;margin-bottom:80px}
.case-study .case-label{display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:var(--white);padding:10px 30px;border-radius:28px;font:700 .8rem/1 'Segoe UI',sans-serif;letter-spacing:2px}
.case-study .case-subtitle{font-size:1.4rem;max-width:800px;margin:25px auto 0;color:var(--heathered-gray)}

.case-challenge{background:linear-gradient(135deg,rgba(241,11,37,.03)0%,rgba(116,52,172,.03)100%);
  border:2px solid rgba(241,11,37,.1);border-radius:28px;padding:60px;margin-bottom:90px}
.challenge-title{text-align:center;font-size:2.2rem;font-weight:300;margin-bottom:50px}
.challenge-body{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.metric-value{display:block;font-size:3.2rem;font-weight:700;color:var(--red-ribbon)}
.challenge-arrow{font-size:3rem;color:var(--red-ribbon);opacity:.5}
.challenge-risk ul{margin:8px 0 0;padding:0 0 0 18px}
.case-challenge .challenge-copy{font-size:1.2rem;max-width:900px;margin:0 auto;text-align:center;margin-top:25px}

.blueprint-reveal .blueprint-grid{display:grid;gap:45px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.insight-card{background:var(--white);border-radius:22px;padding:45px 40px;box-shadow:0 16px 50px rgba(0,0,0,.08)}
.tool-badge{display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:#fff;font:700 .75rem/1 'Segoe UI',sans-serif;padding:6px 20px;border-radius:18px;margin-bottom:18px}
.insight-card h4{font-size:1.4rem;margin:0 0 18px;color:var(--dark-text)}
.insight-card .intro{font-size:1.05rem;margin-bottom:20px}
.edge-columns{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0 30px}
.edge-columns ul{list-style:none;padding:0}
.edge-columns .title{font-weight:600;margin-bottom:6px;color:var(--royal-purple)}
.edge-conclusion{font-size:1rem;background:rgba(116,52,172,.05);padding:18px;border-radius:12px}

.migration-stats{display:flex;gap:30px;margin:25px 0}
.stat{flex:1 1 120px;border:2px solid currentColor;border-radius:18px;padding:25px;text-align:center}
.stat.curious{color:var(--fire-bush)}
.stat.recon{color:var(--royal-purple)}
.stat .percent{display:block;font-size:2.6rem;font-weight:700}
.critical{margin:20px 0;font-weight:500}
.triggers{padding-left:18px;font-size:.95rem;margin:0}
.triggers li{margin-bottom:6px}

.driver-equation{display:flex;align-items:center;justify-content:space-between;
  gap:18px;margin:25px 0 30px;flex-wrap:wrap}
.driver{flex:0 1 140px;background:#faf7ff;border:1px solid rgba(116,52,172,.2);border-radius:14px;
  padding:20px;text-align:center;font-size:.9rem;font-weight:500}
.plus,.equals{font-size:1.6rem;color:var(--royal-purple);font-weight:700}
.result{flex:0 1 100px;background:linear-gradient(135deg,var(--fire-bush),var(--rose));color:#fff;
  text-align:center;border-radius:18px;padding:18px 12px;font-weight:700}
.why{font-size:.95rem;padding-left:18px;margin:0}
.why li{margin-bottom:6px}

.strategic-actions{margin-top:100px}
.strategy-tracks .tracks-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:20px}
.strategy-tracks .tracks-head span{text-align:center;font:600 .8rem/1 'Segoe UI',sans-serif;
  padding:10px 0;border:2px solid var(--royal-purple);border-radius:22px;text-transform:uppercase}
.phase{display:grid;grid-template-columns:110px 1fr 1fr;gap:40px;background:var(--white);
  border-radius:22px;padding:45px 40px;box-shadow:0 12px 40px rgba(0,0,0,.05);margin-bottom:40px}
.phase-tag{width:90px;height:90px;border-radius:50%;border:6px solid var(--royal-purple);
  display:flex;align-items:center;justify-content:center;font-weight:700}
.phase-col h4{font-size:1.2rem;margin:0 0 10px;color:var(--dark-text)}
.phase-col ul{padding-left:18px;margin:0 0 8px;font-size:.95rem}
.phase .deliverable{font-size:.85rem;font-style:italic;margin:4px 0 0}

.summary-90{margin-top:120px;text-align:center}
.summary-title{font-size:2rem;margin-bottom:50px;font-weight:300}
.summary-steps{display:flex;justify-content:center;gap:120px;list-style:none;margin:0 0 70px;padding:0;
  position:relative}
.summary-steps li{position:relative}
.summary-steps li::before{content:'';position:absolute;left:50%;bottom:-28px;width:2px;height:28px;
  background:var(--royal-purple);transform:translateX(-50%)}
.summary-steps span{display:block;width:72px;height:72px;border:6px solid var(--royal-purple);
  border-radius:50%;line-height:60px;font-size:1.4rem;font-weight:700;margin:0 auto 15px}
.summary-cards{display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.summary-cards article{background:#fff;border-radius:22px;padding:35px 28px;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.summary-cards h4{font-size:1.1rem;margin:0 0 15px;color:var(--royal-purple)}
.summary-cards ul{padding-left:16px;font-size:.95rem;margin:0}
.summary-cards li{margin-bottom:6px}

/* Responsive tweaks */
@media(max-width:1024px){
  .challenge-body{flex-direction:column}
  .strategy-tracks .tracks-head{grid-template-columns:1fr}
  .phase{grid-template-columns:90px 1fr}
}
@media(max-width:768px){
  .case-study{padding:80px 18px}
  .phase{grid-template-columns:1fr}
  .phase-tag{margin:0 auto 20px}
  .summary-steps{gap:70px}
}
/* ─── CASE STUDY : LANEIGE ─────────────────────────────────────────── */

.case-study{
  background:linear-gradient(to bottom,var(--white) 0%,#f8f5ff 100%);
  padding:120px 20px;
}
.mini-title{
  text-align:center;
  font-size:2rem;
  font-weight:300;
  margin:90px 0 50px;
  color:var(--dark-text);
}
.insight-grid{
  display:grid;
  gap:50px;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
}
.insight-card{
  background:#fff;
  border-radius:24px;
  padding:45px 40px;
  box-shadow:0 15px 45px rgba(0,0,0,.08);
  position:relative;
}
.badge{
  display:inline-block;
  background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));
  color:#fff;font-size:.8rem;font-weight:700;
  padding:6px 18px;border-radius:15px;margin-bottom:25px;
}
.insight-card h4{font-size:1.4rem;color:var(--dark-text);margin-bottom:20px;}
.edge-table{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0;}
.edge-col h5{font-size:1rem;color:var(--royal-purple);margin-bottom:8px;}
.edge-col ul{list-style:none;padding:0;margin:0;}
.edge-col li{padding:4px 0;font-size:.95rem;}
.edge-note{
  background:rgba(116,52,172,.05);
  border-left:4px solid var(--fire-bush);
  padding:18px 20px;font-size:.95rem;border-radius:10px;margin-top:25px;
}
.loyalty-stats{display:flex;gap:20px;margin:25px 0;}
.loyalty-box{
  flex:1;border:3px solid var(--fire-bush);border-radius:15px;padding:20px;text-align:center;
}
.loyalty-box.recon{border-color:var(--royal-purple);}
.big-num{display:block;font-size:2.4rem;font-weight:700;margin-bottom:6px;}
.stat-label{font-weight:600;font-size:.9rem;}
.stat-sub{font-size:.8rem;opacity:.8;}
.insight-text{margin:20px 0;font-size:.98rem;line-height:1.6;}
.trigger-list{margin:0;padding-left:18px;font-size:.95rem;}
.trigger-list li{margin:5px 0;}
.formula-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:30px 0;}
.pill{
  background:rgba(116,52,172,.05);border:1px solid rgba(116,52,172,.15);
  border-radius:12px;padding:18px 20px;font-size:.9rem;text-align:center;
  min-width:140px;
}
.op{font-size:1.8rem;font-weight:700;color:var(--royal-purple);}
.lift-box{
  background:linear-gradient(135deg,var(--fire-bush),var(--rose));
  color:#fff;border-radius:14px;padding:22px 30px;text-align:center;
  box-shadow:0 12px 35px rgba(228,163,36,.35);
}
.lift-num{font-size:2rem;font-weight:700;line-height:1;}
.lift-txt{font-size:.8rem;opacity:.9;}
.why-works{margin:15px 0 0;padding-left:18px;font-size:.9rem;}
.why-works li{margin:6px 0;}

.tracks-header{
  display:flex;justify-content:center;gap:80px;margin-bottom:40px;margin-top:80px;
  position:relative;
}
.track-badge{
  background:#fff;border:2px solid var(--royal-purple);color:var(--royal-purple);
  padding:6px 20px;border-radius:25px;font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;
}
.track-right{border-color:var(--fire-bush);color:var(--fire-bush);}

.phase-table{display:flex;flex-direction:column;gap:60px;}
.phase-row{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.phase-left,.phase-right{background:#fff;border-radius:20px;padding:40px 35px;box-shadow:0 12px 35px rgba(0,0,0,.05);position:relative;}
.phase-circle{
  position:absolute;top:-25px;left:-25px;
  width:90px;height:90px;border-radius:50%;border:6px solid var(--royal-purple);
  display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--royal-purple);
  background:#fff;font-size:.9rem;
}
.phase-row:nth-child(2) .phase-circle{border-color:var(--wisteria);}
.phase-row:nth-child(3) .phase-circle{border-color:var(--fire-bush);}
.phase-left h5,.phase-right h5{font-size:1.2rem;color:var(--dark-text);margin-bottom:15px;}
.phase-left ul,.phase-right ul{margin:0 0 10px 0;padding-left:18px;font-size:.9rem;}
.deliver{font-size:.85rem;color:var(--heathered-gray);font-style:italic;}

.arc-timeline{
  display:flex;justify-content:center;gap:140px;margin:100px auto 0;max-width:700px;
  position:relative;padding:0;list-style:none;
}
.arc-timeline::before{
  content:'';position:absolute;bottom:34px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--fire-bush),var(--royal-purple));
  border-radius:2px;
}
.arc-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:60px;height:60px;border-radius:50%;
  border:4px solid var(--royal-purple);background:#fff;font-weight:700;color:var(--royal-purple);
  font-size:1.1rem;position:relative;z-index:2;
}
.arc-title{display:block;text-align:center;margin-top:12px;font-weight:600;color:var(--royal-purple);font-size:.95rem;}
.arc-timeline li{position:relative;}

@media(max-width:1024px){
  .insight-grid{grid-template-columns:1fr;}
  .phase-row{grid-template-columns:1fr;}
  .tracks-header{flex-direction:column;gap:20px;}
}
/* ─── CASE‑STUDY LAYOUT PATCH — 2025‑07‑21 ───────────────────────── */
.case-study {padding:120px 20px;background:#fff linear-gradient(to bottom,#fff 0%,#f8f5ff 100%);}
.case-title{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:300;text-align:center;margin:0 0 .3em;}
.case-subtitle{text-align:center;max-width:800px;margin:.3em auto 2em;color:var(--heathered-gray);font-size:1.1rem;}

.challenge-block{background:linear-gradient(135deg,rgba(241,11,37,.03),rgba(116,52,172,.03));border:2px solid rgba(241,11,37,.1);border-radius:22px;padding:50px;margin:0 auto 80px;max-width:1100px;}
.challenge-head{text-align:center;font-size:1.8rem;font-weight:400;margin-bottom:40px;}
.challenge-flex{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap;}
.big‑stat{text-align:center;}
.stat-value{display:block;font-size:3rem;font-weight:700;color:var(--red-ribbon);}
.stat-caption{font-size:1rem;color:var(--dark-text);}
.problem-arrow{font-size:2.5rem;color:var(--red-ribbon);opacity:.6;}
.risk-list ul{margin:0;padding-left:20px;}
.risk-list li{margin:6px 0;}

.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-bottom:100px;}
.insight-card{background:#fff;border:1px solid rgba(116,52,172,.1);border-radius:18px;padding:40px;box-shadow:0 12px 40px rgba(0,0,0,.05);}
.insight-card.multiverse{overflow:hidden;}

.tool-badge{display:inline-block;background:linear-gradient(135deg,var(--royal-purple),var(--wisteria));color:#fff;padding:6px 18px;border-radius:14px;font-size:.75rem;font-weight:600;letter-spacing:1px;margin-bottom:18px;}

.edge-flex{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0;}
.edge-box{background:rgba(116,52,172,.04);padding:20px;border-radius:12px;}
.edge-conclusion{margin-top:20px;padding:15px 18px;background:linear-gradient(135deg,rgba(228,163,36,.06),rgba(116,52,172,.06));border-left:4px solid var(--fire-bush);border-radius:8px;font-size:.95rem;}

.migration-grid{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:25px 0;}
.migration-box{padding:20px;border-radius:14px;text-align:center;border:3px solid}
.migration-box.curious{border-color:var(--fire-bush);}
.migration-box.reconcilable{border-color:var(--royal-purple);}
.migration-num{display:block;font-size:2.4rem;font-weight:700;margin-bottom:6px;color:inherit;}
.migration-label{display:block;font-weight:600;margin-bottom:6px;}

.driver-equation{display:flex;align-items:center;justify-content:center;gap:20px;margin:30px 0;}
.driver-box{flex:0 1 140px;background:rgba(116,52,172,.05);padding:25px;border-radius:12px;text-align:center;font-size:.86rem;font-weight:600;}
.math-symbol{font-size:2.2rem;color:var(--royal-purple);font-weight:300;}
.lift-box{flex:0 0 120px;background:linear-gradient(135deg,var(--fire-bush),var(--rose));border-radius:14px;color:#fff;padding:25px 10px;text-align:center;box-shadow:0 10px 30px rgba(228,163,36,.4);}
.lift-value{display:block;font-size:1.9rem;font-weight:700;line-height:1;}
.lift-label{font-size:.8rem;opacity:.9;}

.why-list{margin-top:20px;padding-left:20px;font-size:.9rem;}

.strategy-head{text-align:center;font-size:1.8rem;margin:0 0 40px;font-weight:400;}
.track-bar{text-align:center;margin-bottom:25px;}
.track-badge{display:inline-block;border:2px solid var(--royal-purple);border-radius:18px;padding:4px 14px;font-size:.75rem;font-weight:600;margin:0 4px;color:var(--royal-purple);}
.track-badge.dev{border-color:var(--wisteria);color:var(--wisteria);}

.phase-grid{display:flex;flex-direction:column;gap:40px;margin-bottom:80px;}
.phase-card{background:#fff;border:1px solid rgba(116,52,172,.1);border-radius:18px;padding:30px 25px;box-shadow:0 10px 35px rgba(0,0,0,.05);}
.phase-badge{width:66px;height:66px;border-radius:50%;border:4px solid var(--royal-purple);display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:15px;color:var(--royal-purple);}
.phase-columns{display:grid;grid-template-columns:1fr 1fr;gap:35px;}
.phase-card h4{font-size:1.1rem;margin:0 0 10px;font-weight:700;}
.phase-card ul{margin:0 0 10px 18px;}
.deliverable{font-size:.85rem;color:var(--fire-bush);font-style:italic;}

.roadmap-head{text-align:center;font-size:1.6rem;margin:40px 0 25px;font-weight:400;}
.roadmap-wave{position:relative;max-width:700px;margin:0 auto 20px;padding-top:20px;}
.roadmap-wave::before{content:'';position:absolute;top:44px;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--fire-bush),var(--rose));border-radius:2px;}
.wave-step{position:relative;display:inline-block;width:33.333%;text-align:center;}
.circle{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border:4px solid var(--royal-purple);border-radius:50%;background:#fff;box-shadow:0 8px 20px rgba(116,52,172,.12);font-weight:700;margin-bottom:10px;}
.wave-label{display:block;font-weight:600;color:var(--royal-purple);}

/* responsive */
@media(max-width:900px){
  .driver-equation{flex-wrap:wrap}
  .phase-columns{grid-template-columns:1fr}
}
/* ─── Case‑Study NEW Layout ───────────────────────────────────────── */
.case-study .cs-block{
    background:#fff;
    border-radius:22px;
    padding:50px 40px;
    margin-bottom:70px;
    box-shadow:0 15px 60px rgba(0,0,0,.06);
    max-width:900px;
    margin-left:auto;
    margin-right:auto;
}
.cs-badge{display:inline-block;padding:6px 18px;border-radius:14px;font-size:.75rem;
    font-weight:700;letter-spacing:.8px;color:#fff}
.cs-badge.purple{background:#7434ac}
.cs-badge.gold{background:#e4a324}
.cs-badge.magenta{background:#eb0473}
.cs-title{font-size:1.8rem;font-weight:600;margin:20px 0 25px;color:var(--dark-text)}
.cs-copy{font-size:1.1rem;line-height:1.7;margin-bottom:25px;color:var(--dark-text)}
.cs-split.two-up{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px;margin:30px 0}
.cs-sub{font-size:1rem;font-weight:600;margin-bottom:10px;color:#7434ac}
.cs-insight{border-left:6px solid var(--fire-bush);padding:18px 22px;border-radius:14px;
    font-style:italic;font-size:1.05rem;color:var(--dark-text);background:rgba(228,163,36,.05)}
.cs-insight.gold{border-color:var(--fire-bush)}
/* Stats */
.cs-stats.duo{display:flex;gap:40px;justify-content:center;margin:35px 0}
.stat{flex:1 1 180px;text-align:center;padding:35px 25px;border:4px solid;border-radius:20px}
.stat.curious{border-color:var(--fire-bush)}
.stat.recon{border-color:#7434ac}
.stat .number{display:block;font-size:2.8rem;font-weight:700;margin-bottom:6px}
/* Triggers */
.triggers ul{margin-left:1.2rem}
.triggers li{margin:.35rem 0}
/* Driver Equation */
.driver-equation{display:flex;flex-wrap:wrap;align-items:center;gap:18px;justify-content:center;margin:40px 0}
.driver-item{background:rgba(116,52,172,.05);padding:22px 30px;border-radius:16px;font-weight:600;text-align:center;min-width:150px}
.operator{font-size:2rem;font-weight:300;color:#7434ac}
.driver-result{background:linear-gradient(135deg,var(--fire-bush),var(--rose));
    color:#fff;padding:25px 40px;border-radius:20px;text-align:center;box-shadow:0 10px 35px rgba(0,0,0,.1)}
/* Why this works list */
.why-works{margin:25px 0 0 0;padding-left:1.2rem}
.why-works li{margin:.5rem 0}
/* ─── Plan Table ──────────────────────────────────────────────────── */
.cs-plan{margin-top:100px}
.cs-plan-heading{text-align:center;font-size:2rem;font-weight:300;margin-bottom:60px}
.plan-table{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:2px solid transparent}
.plan-colhead{grid-column:span 1;text-align:center;font-size:.8rem;font-weight:700;
    padding:10px 0;border-radius:40px;margin-bottom:25px;background:rgba(116,52,172,.05)}
.plan-phase{padding:35px 30px;display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(0,0,0,.05)}
.phase-chip{align-self:flex-start;border:3px solid #7434ac;color:#7434ac;border-radius:50%;
    width:54px;height:54px;display:flex;align-items:center;justify-content:center;font-weight:700}
.plan-phase h4{font-size:1.2rem;margin:6px 0 4px}
.plan-phase ul{padding-left:1.2rem;margin:0}
.plan-phase li{margin:.25rem 0;font-size:.95rem}
.deliverable{font-size:.85rem;margin-top:6px}
.deliverable span{font-weight:700;color:var(--fire-bush)}
/* 90‑Day Arc */
.timeline90{text-align:center;margin:110px auto 0;max-width:960px}
.arc{display:flex;justify-content:space-between;align-items:flex-end;position:relative;
     margin-top:50px;padding:0 10px}
.arc::before{content:'';position:absolute;left:0;right:0;top:35px;height:4px;
     background:linear-gradient(90deg,var(--fire-bush),#7434ac,var(--rose));
     border-radius:2px;z-index:0}
.arc li{position:relative;z-index:1;flex:1;text-align:center;font-size:.95rem}
.arc .circle{display:inline-flex;align-items:center;justify-content:center;
     width:56px;height:56px;border:4px solid #7434ac;border-radius:50%;font-weight:700;font-size:1.1rem;margin-bottom:12px}
/* Responsive */
@media(max-width:880px){
  .plan-table{grid-template-columns:1fr}
  .plan-colhead:nth-of-type(2){display:none}
}
/* === TRANSFORMATION STRATEGY === */
.strategic-actions {
  margin: 120px auto 100px;
  max-width: 1200px;
  padding: 0 20px;
}

.strategy-grid {
  display: grid;
  grid-template-columns: 160px 1fr 1fr;
  row-gap: 70px;
  column-gap: 60px;
  align-items: start;
  margin-top: 60px;
}

/* headers (row 1) */
.track-header {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 1px;
  text-align: center;
  padding: 10px 0;
  border-radius: 40px;
  background: rgba(116, 52, 172, 0.08);
}

.track-header.research  { background: rgba(116, 52, 172, 0.10); }
.track-header.marketing { background: rgba(241, 11, 37, 0.06); }

.spacer { /* empty cell to keep headers aligned */ }

/* phase column */
.phase-col {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-top: 4px;
}

.phase-badge {
  position: relative;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 4px solid var(--royal-purple);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-family: inherit;
}

.phase-num    { font-size: 1.6rem; font-weight: 700; line-height: 1; }
.phase-label  { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; }

/* track blocks */
.track-block {
  background: var(--white);
  border-radius: 18px;
  padding: 35px 40px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.06);
}

.track-block h4 {
  font-size: 1.25rem;
  margin-bottom: 18px;
  font-weight: 700;
}

.track-block ul {
  margin: 0 0 25px 0;
  padding-left: 18px;
}

.track-block li { margin-bottom: 6px; }

.block-foot {
  font-size: 0.9rem;
  color: var(--fire-bush);
  font-weight: 600;
}

/* responsive */
@media (max-width: 980px){
  .strategy-grid{
    grid-template-columns: 120px 1fr;
  }
  .track-header.marketing { display:none; }
  .spacer                { display:none; }
  .track-block.marketing { grid-column: 2 / -1; }
}
/* ==== HERO STAT LABELS ==== */
.hero-stats .stat-label{
  display:block;          /* put each label under its number */
  font-size:clamp(.75rem,1.2vw,.9rem);
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-top:.25rem;
  color:#ffb8ff;          /* soft lilac that stands out on the purple gradient */
}
/* ==== CASE STUDY CARDS ==== */
.blueprint-summary{
  display:grid;
  gap:2rem 3rem;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  margin-top:3rem;
}

.cs-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  padding:1.75rem 2rem;
  border-radius:12px;
  backdrop-filter:blur(6px);
}

.cs-card.span‑2{grid-column:span 2;}

.cs-title{
  font-size:1.25rem;
  margin-bottom:.75rem;
  background:linear-gradient(90deg,#ff6bd6,#ffb86c);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.cs-card.impact{
  border-color:#ff6bd6;
}
/* ==== SOURCE FOOTNOTES ==== */
.kpi-sources{
  font-size:.7rem;
  opacity:.7;
  background:transparent;
  text-align:left;
  padding:1rem 0 2rem;
}
.kpi-sources h4{font-size:.8rem;margin-bottom:.25rem;}
/* ==== CASE STUDY WRAPPER ==== */
.case-wrapper{
  max-width:1200px;
  margin:4rem auto;
  padding:0 1rem;
}
.section-head{
  text-align:center;
  font-size:1.75rem;
  margin-bottom:2.5rem;
  background:linear-gradient(90deg,#ff6bd6,#ffb86c);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ==== GRID ==== */
.case-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:2rem;
}

/* ==== CARDS ==== */
.cs-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  padding:1.75rem 2rem;
  border-radius:14px;
  backdrop-filter:blur(6px);
}
.cs-card h4{
  color:#ff6bd6;
  font-size:1.15rem;
  margin-bottom:.75rem;
}
.cs-card ul,
.cs-card ol{
  margin-left:1.25rem;
}
.cs-card.impact{
  border-color:#ff6bd6;
}
/* ==== CASE‑STUDY WRAPPER ==== */
.case-wrapper{
  max-width:1200px;
  margin:5rem auto;
  padding:0 1rem;
}

/* section heading */
.section-head{
  text-align:center;
  font-size:1.9rem;
  margin-bottom:3rem;
  background:linear-gradient(90deg,#ff6bd6 0%,#ffb86c 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* grid layout */
.case-grid{
  display:grid;
  gap:2rem;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  margin-bottom:3.5rem;
}

/* cards */
.cs-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  padding:1.75rem 2rem;
  border-radius:14px;
  backdrop-filter:blur(6px);
}
.cs-card h4{
  color:#ff6bd6;
  font-size:1.25rem;
  margin-bottom:.9rem;
}
.cs-card ul,
.cs-card ol{margin-left:1.25rem;}
.cs-card.impact{border-color:#ff6bd6;}

/* timeline */
.timeline{
  display:flex;
  flex-wrap:wrap;
  gap:1.5rem;
  justify-content:space-between;
}
.phase{
  flex:1 1 250px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  padding:1.5rem;
  text-align:center;
}
.phase h5{
  font-size:1rem;
  margin-bottom:.6rem;
  color:#ff6bd6;
}
.phase h5 span{
  display:block;
  font-weight:400;
  font-size:.8rem;
  color:#ffb86c;
}
.phase p{font-size:.85rem;line-height:1.4;}
/* ==========  BEAUTY CASE STUDY  ========== */
.beauty-case{
  --violet:#9b5de5;
  --rose:#ff6bd6;
  --peach:#ffb86c;
  --white:rgba(255,255,255,.85);

  margin:6rem auto 8rem;
  max-width:1200px;
  padding:0 1rem;
}

/* headline + subtitle */
.beauty-head{
  text-align:center;
  margin-bottom:3.5rem;
}
.beauty-head h3{
  font-size:1.9rem;
  background:linear-gradient(90deg,var(--rose) 0%,var(--peach) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.beauty-head .subtitle{
  margin-top:.75rem;
  font-size:1rem;
  color:var(--white);
}

/* grid */
.beauty-grid{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}

/* cards */
.beauty-card{
  position:relative;
  padding:2rem 2.25rem;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  animation:fadeUp .7s ease both;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:none;}
}

/* decorative focus bars */
.focus-left:before,
.focus-right:after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  width:4px;
  border-radius:4px;
  background:linear-gradient(180deg,var(--rose),var(--peach));
}
.focus-left:before{left:-4px;}
.focus-right:after{right:-4px;}

.card-tag{
  font-size:.8rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--peach);
  margin-bottom:.9rem;
}
.big-statement{
  font-size:1.1rem;
  font-weight:600;
  line-height:1.4;
  margin-bottom:1rem;
}
.insight-block{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1rem;
}
.metric{
  font-size:2.1rem;
  font-weight:700;
  background:linear-gradient(0deg,var(--peach),var(--rose));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.metric-copy{font-size:.9rem;line-height:1.4;}

.strategy-list{
  margin:1rem 0 0 1.1rem;
  font-size:.9rem;
  line-height:1.4;
}
.strategy-list li{margin-bottom:.5rem;}

.impact{
  text-align:center;
  border:2px solid var(--peach);
}
.result-line{
  font-size:1.1rem;
  font-weight:600;
  margin:.35rem 0;
}
.book-cta{
  display:inline-block;
  margin-top:1.2rem;
  padding:.65rem 1.5rem;
  border-radius:30px;
  background:linear-gradient(90deg,var(--rose),var(--peach));
  color:#1b0338;
  font-weight:600;
  text-decoration:none;
  transition:transform .25s;
}
.book-cta:hover{transform:translateY(-3px);}

/* timeline */
.roadmap{
  display:flex;
  justify-content:space-between;
  margin-top:4rem;
  gap:1rem;
}
.phase{
  flex:1 1 0;
  text-align:center;
  padding:1.2rem 1rem;
  border:1px solid rgba(255,255,255,.15);
  border-radius:12px;
  background:rgba(255,255,255,.04);
  font-size:.9rem;
}
.phase h5{
  font-size:1rem;
  color:var(--rose);
  margin-bottom:.3rem;
}
.phase span{color:var(--white);}
@media(max-width:600px){
  .roadmap{flex-direction:column;}
}
/* === Laneige Case Study width tweaks === */
.beauty-case{max-width:1150px;}          /* give section room to expand */

.beauty-grid{
  grid-template-columns:repeat(auto-fit,minmax(350px,1fr));   /* wider cards */
}
/* === Blueprint Analysis alignment === */
.panel-grid{
  display:grid;
  gap:2rem;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  margin-top:2.5rem;
}
.panel-grid article{
  background:rgba(255,255,255,.06);
  border-radius:16px;
  padding:2rem 2.25rem;
  backdrop-filter:blur(8px);
}
/* === Strategy Recommendation grid === */
.strategy-wrapper .phase-cards{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  justify-content:center;   /* center last row */
}
.strategy-wrapper .phase-card{
  background:#fff;
  border-radius:18px;
  box-shadow:0 8px 20px rgba(0,0,0,.06);
  padding:2.25rem 2.5rem;
}
/* === Sticky CTA bar === */
.sticky-cta{
  position:fixed;
  bottom:0;            /* keep at viewport bottom */
  top:auto;
  left:0; right:0;
  z-index:9999;
}
/************  BLUEPRINT PANEL  ************/
.blueprint-panel{
  max-width:1150px;
  margin:6rem auto 7rem;
  padding:0 1rem;
}
.panel-head{
  text-align:center;
  font-size:1.8rem;
  margin-bottom:3rem;
  background:linear-gradient(90deg,#ff6bd6,#ffb86c);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.panel-grid{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
}
.panel-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:2rem 2.25rem;
  backdrop-filter:blur(8px);
}
.tag{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:#ffb86c;margin-bottom:.9rem;}
.lead-copy{font-size:.95rem;margin-bottom:1rem;line-height:1.5;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin:1rem 0;}
.two-col h5{font-size:.8rem;margin-bottom:.4rem;}
.callout{background:rgba(255,255,255,.05);padding:1rem;border-left:3px solid #ff6bd6;font-size:.85rem;border-radius:10px;}
.metric-box{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:12px;padding:1rem;margin-bottom:1rem;}
.metric-num{font-size:2.2rem;font-weight:700;}
.metric-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;}
.metric-box.yellow{background:rgba(255,184,108,.1);border:1px solid #ffb86c;}
.metric-box.violet{background:rgba(155,93,229,.1);border:1px solid #9b5de5;}
.conversion-list{margin:1rem 0 1.3rem 1.1rem;font-size:.9rem;line-height:1.4;}
.lift-box{text-align:center;border:2px solid #ff6bd6;border-radius:50%;width:110px;height:110px;margin:0 auto 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.lift-num{font-size:1.6rem;font-weight:700;}
.lift-label{font-size:.75rem;text-transform:uppercase;}
.why-works{font-size:.85rem;line-height:1.5;}

/************  STRATEGY WRAPPER  ************/
.strategy-wrapper{
  max-width:1150px;
  margin:6rem auto 8rem;
  padding:0 1rem;
}
.strategy-head{
  text-align:center;
  font-size:1.8rem;
  margin-bottom:1rem;
  background:linear-gradient(90deg,#ff6bd6,#ffb86c);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.strategy-sub{text-align:center;font-size:.9rem;margin-bottom:2.5rem;color:rgba(255,255,255,.8);}
.phase-cards{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  justify-content:center;
}
.phase-card{
  background:#ffffff;
  border-radius:18px;
  box-shadow:0 8px 20px rgba(0,0,0,.06);
  padding:2.25rem 2.5rem;
}
.phase-ring{
  display:inline-block;
  width:70px;height:70px;line-height:70px;
  border:3px solid #9b5de5;border-radius:50%;
  text-align:center;font-weight:600;font-size:.9rem;margin-right:.65rem;color:#9b5de5;
}
.phase-card h4{font-size:1rem;margin-bottom:1rem;}
.phase-card ul{margin-left:1.1rem;font-size:.9rem;line-height:1.45;}
.deliver{margin-top:1.2rem;font-size:.85rem;}
/* =========  LANEIGE MODULE  ========= */

/* ----------  Shared Colors  ---------- */
:root{
  --violet:#9b5de5;
  --rose:#ff6bd6;
  --peach:#ffb86c;
  --white:rgba(255,255,255,.88);
}

/* ----------  Base Wrapper  ---------- */
.laneige-module{max-width:1200px;margin:0 auto;padding:0 1rem;}

/* ----------  HERO CASE STUDY  ---------- */
.beauty-head{
  text-align:center;
  font-size:1.9rem;
  margin:4.5rem 0 3rem;
  background:linear-gradient(90deg,var(--rose),var(--peach));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.beauty-grid{display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));}
.beauty-card{
  position:relative;padding:2rem 2.25rem;border-radius:16px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
}
.focus-left:before,.focus-right:after{
  content:"";position:absolute;top:0;bottom:0;width:4px;border-radius:4px;
  background:linear-gradient(180deg,var(--rose),var(--peach));
}
.focus-left:before{left:-4px;} .focus-right:after{right:-4px;}
.card-tag{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--peach);margin-bottom:.9rem;}
.big-statement{font-size:1.1rem;font-weight:600;line-height:1.4;margin-bottom:1rem;}
.insight-block{display:flex;align-items:center;gap:1rem;margin-bottom:.7rem;}
.metric{font-size:2.1rem;font-weight:700;background:linear-gradient(0deg,var(--peach),var(--rose));
        -webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.metric-copy{font-size:.9rem;line-height:1.45;}
.strategy-list{margin:1rem 0 0 1.1rem;font-size:.9rem;line-height:1.45;}
.impact{text-align:center;border:2px solid var(--peach);}
.result-line{font-size:1.1rem;font-weight:600;margin:.3rem 0;}
.book-cta{display:inline-block;margin-top:1rem;padding:.6rem 1.6rem;border-radius:30px;
          background:linear-gradient(90deg,var(--rose),var(--peach));color:#1b0338;font-weight:600;text-decoration:none;}
.book-cta:hover{filter:brightness(1.1);}
.roadmap{display:flex;gap:1rem;justify-content:center;margin:3.5rem 0 6rem;}
.phase{flex:1 1 0;text-align:center;padding:1rem;border:1px solid rgba(255,255,255,.15);
       border-radius:12px;background:rgba(255,255,255,.04);font-size:.9rem;}
.phase h5{font-size:1rem;color:var(--rose);margin-bottom:.25rem;}
.phase span{color:var(--white);}

/* ----------  BLUEPRINT ANALYSIS  ---------- */
.blueprint-panel{margin:5rem 0;}
.panel-head{text-align:center;font-size:1.8rem;margin-bottom:2.8rem;
             background:linear-gradient(90deg,var(--rose),var(--peach));
             -webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.panel-grid{display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));}
.panel-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
            border-radius:16px;padding:2rem 2.25rem;backdrop-filter:blur(8px);}
.tag{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--peach);margin-bottom:.9rem;}
.lead-copy{font-size:.95rem;margin-bottom:1rem;line-height:1.45;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin:1rem 0;}
.two-col h5{font-size:.8rem;margin-bottom:.3rem;}
.callout{background:rgba(255,255,255,.05);padding:1rem;border-left:3px solid var(--rose);
        border-radius:10px;font-size:.83rem;}
.metric-box{display:flex;flex-direction:column;align-items:center;justify-content:center;
           border-radius:12px;padding:1rem;margin-bottom:.9rem;}
.metric-num{font-size:2.1rem;font-weight:700;}
.metric-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;}
.metric-box.yellow{background:rgba(255,184,108,.12);border:1px solid var(--peach);}
.metric-box.violet{background:rgba(155,93,229,.12);border:1px solid var(--violet);}
.conversion-list{margin:1rem 0 1.3rem 1.1rem;font-size:.9rem;line-height:1.45;}
.lift-box{text-align:center;border:2px solid var(--rose);border-radius:50%;width:110px;height:110px;
          margin:0 auto 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.lift-num{font-size:1.6rem;font-weight:700;} .lift-label{font-size:.75rem;text-transform:uppercase;}

/* ----------  STRATEGY  ---------- */
.strategy-head{text-align:center;font-size:1.8rem;margin-bottom:.8rem;
               background:linear-gradient(90deg,var(--rose),var(--peach));
               -webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.strategy-sub{text-align:center;font-size:.9rem;margin-bottom:2.2rem;color:var(--white);}
.phase-cards{display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));}
.phase-card{background:#fff;border-radius:18px;box-shadow:0 8px 20px rgba(0,0,0,.06);
            padding:2.25rem 2.5rem;}
.phase-ring{display:inline-block;width:70px;height:70px;line-height:66px;border:3px solid var(--violet);
            border-radius:50%;text-align:center;font-weight:600;font-size:.9rem;color:var(--violet);margin-right:.6rem;}
.phase-card h4{font-size:1rem;margin-bottom:1rem;} .phase-card ul{margin-left:1.1rem;font-size:.9rem;line-height:1.45;}
.deliver{margin-top:1.2rem;font-size:.83rem;}
/* ── Laneige Overrides (match existing design language) ── */
.igniter-metric{
  text-align:center;
  margin-left:auto;margin-right:auto;
}
.igniter-number{
  font-size:4rem;font-weight:700;
  background:linear-gradient(135deg,var(--royal-purple),var(--fire-bush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  display:block;margin-top:10px;
}
.result-panel{margin:90px auto 110px;text-align:center;max-width:860px}
.result-h3{font-size:2rem;font-weight:300;margin-bottom:40px}
.kpi-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:40px;margin-bottom:50px;padding:0}
.kpi-grid li{list-style:none;font:600 1.1rem/1.3 'Segoe UI',sans-serif;color:var(--royal-purple)}
.kpi-number{display:block;font-size:2.4rem;font-weight:700;color:var(--red-ribbon)}
.cta-primary{
  display:inline-block;padding:18px 38px;border-radius:32px;
  background:linear-gradient(135deg,var(--rose),var(--fire-bush));
  color:#fff;font-weight:700;font-size:1rem;text-decoration:none;
  box-shadow:0 8px 18px rgba(0,0,0,.12);transition:box-shadow .25s,transform .25s
}
.cta-primary:hover{box-shadow:0 12px 26px rgba(0,0,0,.18);transform:translateY(-2px)}
/* tighten blueprint grid on large screens */
@media(min-width:1200px){.blueprint-grid{grid-template-columns:repeat(3,1fr);}}
/* === Laneige Case‑Study Layout (hooks into existing palette & typography) === */
.case-header.center{text-align:center;margin:60px 0 40px}
.case-label{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--rose)}
.headline-lg{font-size:2rem;background:linear-gradient(90deg,var(--rose),var(--fire-bush));
            -webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:14px 0}
.case-subtitle{font-size:.95rem;color:var(--wisteria)}

.case-challenge{display:flex;align-items:center;justify-content:space-between;
               gap:40px;margin-bottom:60px}
.challenge-col{flex:1 1 500px}
.challenge-metric{text-align:center}
.big-num{font-size:4rem;font-weight:700}
.challenge-metric figcaption{font-size:.8rem;color:var(--heathered-gray)}

.blueprint-grid{display:grid;gap:30px;margin-bottom:70px;
               grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.insight-card{background:var(--white);border-radius:22px;padding:26px 28px;
             box-shadow:0 10px 24px rgba(0,0,0,.05)}
.tool-badge{display:inline-block;font-size:.7rem;letter-spacing:.04em;padding:4px 8px;
           border-radius:20px;background:var(--royal-purple);color:#fff;margin-bottom:14px}
.tool-badge.violet{background:var(--violet)} .tool-badge.rose{background:var(--rose)}
.insight-card h4{font-size:1.1rem;margin-bottom:10px;color:var(--royal-purple)}
.insight-card p{font-size:.9rem;line-height:1.45}

.result-panel{padding:60px 40px;border-radius:28px;margin-bottom:80px}
.kpi-row{display:flex;flex-wrap:wrap;justify-content:center;gap:40px;margin:40px 0 50px;padding:0}
.kpi-row li{list-style:none;font-size:.95rem;color:var(--white);text-align:center}
.kpi-num{display:block;font-size:2rem;font-weight:700;color:var(--fire-bush)}

.btn-primary{display:inline-block;padding:18px 38px;border-radius:32px;font-weight:700;
            background:linear-gradient(90deg,var(--rose),var(--fire-bush));color:#fff;
            text-decoration:none;box-shadow:0 8px 18px rgba(0,0,0,.13);transition:.25s}
.btn-primary:hover{box-shadow:0 12px 26px rgba(0,0,0,.18);transform:translateY(-2px)}

.phase-stack{display:grid;gap:32px;margin-bottom:120px}
@media(min-width:900px){.phase-stack{grid-template-columns:1fr 1fr 1fr}}
.phase-card{background:var(--white);border-radius:22px;padding:34px 38px;
           box-shadow:0 10px 24px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:18px}
.phase-ring{display:inline-block;width:54px;height:54px;line-height:52px;border:3px solid var(--royal-purple);
           border-radius:50%;text-align:center;font-weight:700;font-size:.9rem;color:var(--royal-purple);
           margin-right:12px}
.phase-card header{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.phase-card h4{font-size:1.05rem}
.phase-card ul{margin-left:1rem;font-size:.9rem;line-height:1.5}
.phase-card footer{font-size:.8rem;color:var(--heathered-gray);margin-top:auto}
/* === Laneige wrapper matches global max‑width === */
.wrap-1100{max-width:1100px;margin:0 auto;padding:0 1rem;position:relative}

/* ---------- Blueprint grid (3 cards) ---------- */
.blueprint-grid{display:grid;gap:40px;margin:70px 0;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}

/* ---------- Insight cards ---------- */
.insight-card{background:var(--white);border-radius:22px;padding:30px 32px;
  box-shadow:0 10px 24px rgba(0,0,0,.05)}
.tool-badge{display:inline-block;font-size:.7rem;letter-spacing:.04em;padding:4px 8px;
  border-radius:20px;background:var(--royal-purple);color:#fff;margin-bottom:16px}
.tool-badge.violet{background:var(--violet)} .tool-badge.rose{background:var(--rose)}
.insight-card h4{font-size:1.15rem;margin-bottom:10px;color:var(--royal-purple)}
.insight-card p{font-size:.94rem;line-height:1.5}

/* ---------- Result panel ---------- */
.result-panel{padding:60px 40px;border-radius:28px;margin:90px 0 110px;text-align:center}
.kpi-row{display:flex;flex-wrap:wrap;justify-content:center;gap:60px;margin:45px 0 55px;padding:0}
.kpi-row li{list-style:none;font-size:.95rem;color:var(--white)}
.kpi-num{display:block;font-size:2.1rem;font-weight:700;color:var(--fire-bush)}

/* ---------- Roadmap dual‑track ---------- */
.roadmap-wrap{padding-bottom:140px} /* ensures space above sticky bar */
.track-labels{display:flex;gap:40px;justify-content:center;margin-bottom:20px;font-size:.8rem;
  letter-spacing:.05em;text-transform:uppercase;color:var(--heathered-gray)}
.track-labels .track{flex:1 1 0;text-align:center}
.phase-row{background:var(--white);border-radius:22px;padding:34px 32px;
  box-shadow:0 10px 24px rgba(0,0,0,.05);margin-bottom:38px}
.phase-row header{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.phase-ring{display:inline-block;width:56px;height:56px;line-height:52px;border:3px solid var(--royal-purple);
  border-radius:50%;text-align:center;font-weight:700;font-size:.9rem;color:var(--royal-purple)}
.phase-row h4{font-size:1.1rem}
.phase-row{display:grid;gap:32px}
@media(min-width:900px){.phase-row{grid-template-columns:200px 1fr 1fr}}
.track-card{background:rgba(255,255,255,.04);border:1px solid rgba(0,0,0,.05);
  border-radius:16px;padding:24px 28px;font-size:.92rem;line-height:1.5}
.track-card ul{margin-left:1rem}
.deliver{margin-top:14px;font-size:.8rem;color:var(--heathered-gray)}
/* == Laneige : wrapper + typography ================================== */
.laneige-wrapper{max-width:1100px;margin:0 auto;padding:0 1rem 160px;font-size:1.05rem}

/* header */
.laneige-header{text-align:center;margin:90px 0 60px}
.laneige-header .pill{font-size:.8rem;letter-spacing:.05em;background:var(--royal-purple);
  color:#fff;padding:4px 12px;border-radius:16px}
.laneige-header h2{font-size:2.1rem;margin:18px 0;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* Igniter Trap */
.igniter-card{display:flex;align-items:center;gap:40px;background:rgba(227,206,255,.12);
  border:1px solid var(--fire-bush);border-radius:20px;padding:38px 46px;margin-bottom:80px}
.igniter-copy{flex:1}.igniter-copy h3{font-size:1.3rem;margin-bottom:14px}
.igniter-stat{text-align:center}.igniter-stat span{font-size:4.4rem;font-weight:700;
  background:linear-gradient(90deg,var(--violet),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.igniter-stat figcaption{font-size:.8rem;color:var(--heathered-gray)}

/* blueprint cards */
.insight-grid{display:grid;gap:46px;margin-bottom:100px;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.insight-card{background:var(--white);border-radius:22px;padding:34px 32px;
  box-shadow:0 12px 28px rgba(0,0,0,.06);position:relative;font-size:1rem}
.badge{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;
  padding:4px 10px;border-radius:20px;color:#fff;background:var(--royal-purple);margin-bottom:14px}
.badge.violet{background:var(--violet)} .badge.rose{background:var(--rose)} .badge.brand{background:var(--wisteria)}
.insight-card h4{font-size:1.2rem;margin-bottom:12px;color:var(--royal-purple)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.two-col h5{font-size:.82rem;margin-bottom:6px}
.callout{background:rgba(255,184,108,.12);padding:12px;border-left:3px solid var(--fire-bush);
  border-radius:10px;font-size:.9rem;margin:18px 0}
.segments,.heritage{font-size:.88rem;margin-top:10px}
.fifty-fifty{display:flex;gap:12px;margin:18px 0}
.metric{flex:1 1 0;border-radius:14px;padding:14px;text-align:center}
.metric.yellow{background:rgba(255,184,108,.14);border:1px solid var(--fire-bush)}
.metric.purple{background:rgba(155,93,229,.14);border:1px solid var(--violet)}
.metric strong{font-size:1.8rem}
.trilogy{margin:14px 0 18px 1rem;font-size:.95rem;line-height:1.5}
.execution{font-size:.9rem;font-style:italic}

/* KPI bar */
.kpi-bar{background:var(--royal-purple);border-radius:24px;padding:60px 50px;
  text-align:center;box-shadow:0 12px 30px rgba(0,0,0,.2);margin-bottom:100px}
.kpi-bar ul{display:flex;flex-wrap:wrap;justify-content:center;gap:80px 40px;margin:0 0 46px;padding:0}
.kpi-bar li{list-style:none;font-size:1rem;color:#fff}
.kpi-bar .num{display:block;font-size:2.3rem;font-weight:700;color:var(--fire-bush)}
.cta-gradient{display:inline-block;padding:18px 42px;border-radius:34px;font-weight:700;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));color:#fff;text-decoration:none;
  box-shadow:0 8px 18px rgba(0,0,0,.13);transition:.25s}
.cta-gradient:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.18)}

/* roadmap */
.roadmap{margin-top:40px}
.track-labels{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:10px;font-size:.79rem;
  letter-spacing:.05em;text-transform:uppercase}
.track-labels .track{padding:10px 0;border:1px solid var(--royal-purple);border-radius:20px;
  text-align:center}
.track-labels .marketing{background:var(--royal-purple);color:#fff}
.phase{background:var(--white);border-radius:22px;padding:38px 34px;margin-bottom:42px;
  box-shadow:0 10px 26px rgba(0,0,0,.06)}
.phase header{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.ring{display:inline-block;width:60px;height:60px;line-height:56px;border:3px solid var(--royal-purple);
  border-radius:50%;text-align:center;font-weight:700;font-size:.9rem;color:var(--royal-purple)}
.phase header h4{font-size:1.15rem}
.phase header span{font-weight:400;font-size:.9rem;color:var(--heathered-gray)}
.phase{display:grid;gap:28px}
@media(min-width:900px){.phase{grid-template-columns:220px 1fr 1fr}}
.col{background:rgba(248,248,253,.5);border:1px solid rgba(0,0,0,.05);border-radius:16px;padding:26px}
.col ul{margin-left:1rem;font-size:.95rem;line-height:1.55}
.deliver{margin-top:14px;font-size:.82rem;color:var(--heathered-gray)}
/* == DARK FIRE‑ICON SECTION ========================================== */
.laneige-dark{
  --bg1:#120a31; --bg2:#1e114a;
  background:linear-gradient(135deg,var(--bg1),var(--bg2));
  color:#fff;padding:0 1.2rem 160px;max-width:1100px;margin:0 auto;position:relative;
  font-size:1.15rem;line-height:1.6;
}

/* header */
.laneige-head{text-align:center;padding:90px 0 50px}
.laneige-pill{font-size:.8rem;letter-spacing:.05em;background:var(--violet);
  padding:4px 14px;border-radius:18px}
.laneige-head h2{font-size:2.3rem;margin:18px 0;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.laneige-head p{font-size:1rem;color:rgba(255,255,255,.8)}

/* igniter trap */
.igniter-wrap{display:flex;align-items:center;justify-content:space-between;
  gap:34px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);
  border-radius:22px;padding:38px 44px;margin-bottom:80px}
.igniter-wrap h3{font-size:1.4rem;margin-bottom:12px}
.igniter-num{font-size:4.6rem;font-weight:700;
  background:linear-gradient(90deg,var(--fire-bush),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.igniter-wrap p{flex:1;color:rgba(255,255,255,.88)}

/* three‑card grid */
.tri-grid{display:grid;gap:38px;margin-bottom:90px;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.tri-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  border-radius:22px;padding:34px 32px;display:flex;flex-direction:column}
.h‑stretch{height:100%}
.tag{display:inline-block;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;font-weight:600;margin-bottom:14px}
.brand{background:var(--wisteria)}.infidelity{background:var(--violet)}.multiverse{background:var(--rose)}
.tri-card h4{font-size:1.25rem;margin-bottom:12px}
.fight-table{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:16px;font-size:.95rem}
.fight-table h5{font-size:.8rem;margin-bottom:6px;color:var(--fire-bush)}
.callout{background:rgba(255,184,108,.18);padding:10px 12px;border-radius:12px;
  border-left:3px solid var(--fire-bush);font-size:.9rem;margin:14px 0}
.segment-call,.heritage{font-size:.88rem;margin-top:8px}
.duo{display:flex;gap:12px;margin:16px 0}
.stat{flex:1 1 0;border-radius:14px;padding:14px;text-align:center;font-size:.9rem}
.stat strong{font-size:1.9rem;display:block;margin-bottom:4px}
.stat‑gold{background:rgba(255,184,108,.16);border:1px solid var(--fire-bush)}
.stat‑violet{background:rgba(155,93,229,.16);border:1px solid var(--violet)}
.trilogy{margin:14px 0 16px 1rem;font-size:.97rem;line-height:1.5}
.exec-hint{font-size:.9rem;font-style:italic}

/* KPI panel */
.kpi-panel{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.13);
  border-radius:24px;padding:60px 50px;text-align:center;margin-bottom:100px}
.kpi-panel h3{font-size:1.6rem;margin-bottom:44px}
.kpi-panel h3 span{color:var(--rose)}
.kpi-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:40px;margin-bottom:50px}
.kpi-grid div{flex:1 1 160px;border:1px solid rgba(255,255,255,.18);border-radius:16px;
  padding:26px 14px}
.kpi-grid strong{display:block;font-size:2rem;font-weight:700;
  background:linear-gradient(90deg,var(--fire-bush),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:6px}
.kpi-grid span{font-size:.85rem;color:rgba(255,255,255,.9)}
.cta-grad{display:inline-block;padding:18px 46px;border-radius:36px;font-weight:700;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));color:#fff;
  text-decoration:none;box-shadow:0 8px 18px rgba(0,0,0,.15);transition:.25s}
.cta-grad:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.22)}

/* roadmap */
.phase-table{padding-top:10px}
.track-labels{display:grid;grid-template-columns:1fr 1fr;margin-bottom:16px;font-size:.78rem;
  letter-spacing:.05em;text-transform:uppercase}
.track-labels span{text-align:center;padding:10px 0;border:1px solid var(--violet);border-radius:18px}
.track-labels span:nth-child(2){background:var(--violet);color:#fff}
.phase-row{display:grid;gap:24px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);
  border-radius:22px;padding:38px 32px;margin-bottom:46px}
@media(min-width:950px){.phase-row{grid-template-columns:230px 1fr 1fr}}
.phase-row aside{display:flex;align-items:center;gap:16px}
.ring{display:inline-block;width:62px;height:62px;line-height:58px;border:3px solid var(--rose);
  border-radius:50%;text-align:center;font-weight:700;color:var(--rose)}
.phase-row h4{font-size:1.2rem}
.phase-row h4 small{font-size:.9rem;font-weight:400;color:rgba(255,255,255,.7)}
.col{background:rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.12);
  border-radius:16px;padding:28px;font-size:.95rem}
.col ul{margin-left:1rem;line-height:1.55}
.deliver{margin-top:14px;font-size:.82rem;color:rgba(255,255,255,.75)}
/* == GLOBAL WIDTH ALIGNMENT == */
.fire-wrapper{max-width:1380px;margin:0 auto;font-size:1.1rem;line-height:1.6}

/* ---------- HERO band ---------- */
.fire-hero{text-align:center;padding:90px 0 70px}
.case-pill{font-size:.8rem;letter-spacing:.05em;background:var(--violet);padding:4px 14px;border-radius:18px;color:#fff}
.fire-hero h2{font-size:2.6rem;margin:20px 0;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:1rem;color:var(--heathered-gray)}
.vulnerability-card{max-width:980px;margin:60px auto 0;background:linear-gradient(135deg,#fff8f8,#f9f0fe);
  border-radius:22px;padding:48px 50px}
.vul-body{display:flex;justify-content:space-between;gap:30px;margin:30px 0}
.big-word{font-size:2.3rem;font-weight:700;color:#d62027;display:block;margin-bottom:4px}
.vulnerability-card ul{margin-left:1rem}
.mission{text-align:center;font-size:.95rem;margin-top:24px}

/* ---------- midnight insight band ---------- */
.insight-band{background:linear-gradient(135deg,#120a31,#1e114a);padding:100px 0;color:#fff}
.insight-grid{display:grid;gap:40px;max-width:1100px;margin:0 auto 90px;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);
  border-radius:22px;padding:34px 32px;display:flex;flex-direction:column}
.badge{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;
  border-radius:20px;font-weight:600;margin-bottom:14px}
.brand{background:var(--wisteria)}.infidelity{background:var(--violet)}.multiverse{background:var(--rose)}
.card h4{font-size:1.25rem;margin-bottom:12px}
.fight-table{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:16px;font-size:.94rem}
.fight-table h5{font-size:.8rem;margin-bottom:6px;color:var(--fire-bush)}
.segment-note,.heritage-note{font-size:.88rem;margin-top:8px}
.duo{display:flex;gap:12px;margin:16px 0}
.stat{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.18);
  border-radius:14px;padding:14px 10px;text-align:center}
.stat strong{font-size:1.9rem;display:block}
.stat.gold{border-color:var(--fire-bush)}.stat.violet{border-color:var(--violet)}
.trilogy{margin:14px 0 16px 1rem;font-size:.96rem}
.exec{font-size:.9rem;font-style:italic}

/* KPI tiles */
.kpi-panel{max-width:1100px;margin:0 auto 0;text-align:center}
.kpi-panel h3{font-size:1.6rem;margin-bottom:50px}
.kpi-panel h3 span{color:var(--rose)}
.kpi-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:36px}
.kpi-grid div{flex:1 1 200px;border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:28px 14px}
.kpi-grid strong{font-size:2.4rem;font-weight:700;background:linear-gradient(90deg,var(--fire-bush),var(--rose));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;display:block;margin-bottom:6px}
.kpi-grid span{font-size:.85rem;color:rgba(255,255,255,.9)}
.cta-grad{display:inline-block;margin-top:46px;padding:18px 48px;font-weight:700;border-radius:38px;
  background:linear-gradient(90deg,var(--rose),var(--fire-bush));color:#fff;text-decoration:none}

/* ---------- light roadmap band ---------- */
.roadmap-band{background:#faf9ff;padding:120px 0;color:#333}
.road-head{text-align:center;font-size:1.8rem;margin-bottom:50px;
  background:linear-gradient(90deg,var(--violet),var(--fire-bush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.track-labels{display:grid;grid-template-columns:1fr 1fr;max-width:800px;margin:0 auto 24px;font-size:.78rem;
  letter-spacing:.05em;text-transform:uppercase}
.track-labels span{text-align:center;padding:10px 0;border:1px solid var(--violet);border-radius:18px}
.track-labels span:nth-child(2){background:var(--violet);color:#fff}
.phase-card{max-width:1100px;margin:0 auto 46px;background:#fff;border-radius:22px;
  box-shadow:0 8px 26px rgba(0,0,0,.06);padding:38px 32px;display:grid;gap:24px}
@media(min-width:960px){.phase-card{grid-template-columns:240px 1fr 1fr}}
.phase-card aside{display:flex;align-items:center;gap:16px}
.ring{display:inline-block;width:64px;height:64px;line-height:60px;border:3px solid var(--rose);
  border-radius:50%;text-align:center;font-weight:700;color:var(--rose)}
.phase-card h4{font-size:1.2rem}
.phase-card h4 small{font-size:.9rem;font-weight:400;color:#777}
.col{background:#fafbff;border:1px solid #eceefe;border-radius:16px;padding:28px;font-size:.95rem}
.col ul{margin-left:1rem;line-height:1.55}
.deliver{margin-top:14px;font-size:.82rem;color:#555}

/* Add to your CSS */
/* Fix the small tariffs/tiktok text */
.hero-sub {
    font-size: 1.3rem !important;
    line-height: 1.9 !important;
}
/* Add to your CSS */
.blueprint-card .you-get,
.blueprint-card .it-means {
    color: #e4a324 !important; /* Gold color */
    font-weight: 600 !important;
}
/* For the white line at bottom of page, based on the HTML structure */
.hero-content {
    border-bottom: none !important;
}
/* Or if it's the last element in the footer */
footer > *:last-child {
    border-bottom: none !important;
}
/* If there's still a white line, try */
section:last-child {
    border-bottom: none !important;
}
/* For the navigation items if they're too small */
.nav a {
    font-size: 1rem !important;
}
/* Remove white line from footer */
footer.footer {
    border-top: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

/* Also try this in case there's a ::before or ::after element */
footer.footer::before,
footer.footer::after {
    display: none !important;
}

/* If it's still there, it might be on the section above */
section:last-of-type {
    border-bottom: none !important;
}

/* Or on the footer's parent container */
footer.footer-content {
    border-top: none !important;
}
footer {
    border-bottom: none !important;
}

footer::after,
footer::before {
    display: none !important;
}
.blueprint-card .you-get,
.blueprint-card .it-means {
    color: #e4a324 !important; /* Gold color */
    font-weight: 600 !important;
}
.blueprint-card strong {
    color: #e4a324 !important;
}
/* Add these to the END of your styles.css file */

/* Fix 1: Remove white line from footer - based on your HTML structure */
.footer {
    border-top: none !important;
    border-bottom: none !important;
}

/* Also check if it's the body tag causing the line */
body {
    border-bottom: none !important;
}

/* If it's a horizontal rule or divider */
hr, .divider, .line {
    display: none !important;
}

/* Fix 2: For the blueprint "You get" and "It means" text */
/* Since you're using inline styles, you need to update the HTML directly */
/* Find this in your HTML: */
/* <strong>You get:</strong> */
/* And change it to: */
/* <strong style="color: #e4a324;">You get:</strong> */

/* Or add this CSS with very specific targeting */
#beyond-insights-casestudy .blueprint-card strong {
    color: #e4a324 !important;
}

/* Alternative: Target by content (modern browsers) */
strong:contains("You get:"),
strong:contains("It means:") {
    color: #e4a324 !important;
}

/* If the above doesn't work, try this more aggressive approach */
.casestudy strong {
    color: #e4a324 !important;
}
/* Add this to the END of your styles.css file */

/* Fix for "You get:" and "It means:" labels */
.result-label {
    color: #e4a324 !important;
    font-weight: 600 !important;
}

/* More specific if needed */
.module-result .result-label {
    color: #e4a324 !important;
    font-weight: 600 !important;
}

/* Even more specific with the case study ID */
#beyond-insights-casestudy .result-label {
    color: #e4a324 !important;
    font-weight: 600 !important;
}
/* FIX FOR FLOATING LOGO AND ICONS */

/* Stop the logo from floating */
.logo {
    animation: none !important;
    position: relative !important;
    transform: none !important;
}

/* Stop all unintended floating animations */
body * {
    animation-name: none !important;
}

/* Re-enable ONLY the animations we want in the case study */
#beyond-insights-casestudy .particle {
    animation: casestudy-float 20s infinite linear;
}
.cta .cta-title {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.cta .word-animate {
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
    animation: none !important;
}
<!-- CSS STYLES FOR MEET ELAINE -->
  .meet-elaine {
    padding: 100px 20px;
    background: #fff;
  }
  
  .section-title {
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 300;
    text-align: center;
    margin: 0 0 80px;
    color: #1a0033;
  }
  
  .elaine-content {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 80px;
    max-width: 1200px;
    margin: 0 auto;
    align-items: start;
  }
  
  .elaine-image {
    text-align: center;
  }
  
  .elaine-image img {
    width: 300px;
    height: 300px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
  }
  
  .elaine-name {
    font-size: 2.5rem;
    font-weight: 300;
    color: #1a0033;
    margin: 0 0 10px;
  }
  
  .elaine-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: #7434ac;
    margin: 0 0 10px;
  }
  
  .elaine-company {
    font-size: 1.5rem;
    font-weight: 600;
    color: #e4a324;
    margin: 0 0 40px;
  }
  
  .elaine-intro {
    font-size: 1.15rem;
    line-height: 1.8;
    color: #444;
    margin-bottom: 40px;
  }
  
  .elaine-highlights {
    list-style: none;
    padding: 0;
    margin: 0 0 50px;
  }
  
  .elaine-highlights li {
    position: relative;
    padding-left: 30px;
    margin-bottom: 20px;
    font-size: 1.1rem;
    line-height: 1.6;
    color: #666;
  }
  
  .elaine-highlights li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: #e4a324;
    font-weight: 700;
    font-size: 1.3rem;
  }
  
  .elaine-quote {
    font-size: 1.3rem;
    font-style: italic;
    color: #7434ac;
    line-height: 1.6;
    padding: 30px;
    background: linear-gradient(135deg, rgba(116, 52, 172, 0.05) 0%, rgba(228, 163, 36, 0.05) 100%);
    border-left: 4px solid #7434ac;
    border-radius: 10px;
  }
  
  @media (max-width: 768px) {
    .elaine-content {
      grid-template-columns: 1fr;
      text-align: center;
    }
    
    .elaine-image {
      margin: 0 auto;
    }
    
    .elaine-highlights {
      text-align: left;
      max-width: 500px;
      margin: 0 auto 50px;
    }
  }
/* Add this to your styles.css file */

.meet-elaine .elaine-image {
    text-align: center !important;
    margin: 0 auto !important;
}

.meet-elaine .elaine-image img {
    width: 350px !important;
    height: 350px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    object-position: center 20% !important; /* Adjust this to position the image better */
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15) !important;
    display: block !important;
    margin: 0 auto !important;
    background: #2a2a3e !important; /* Dark background to match the photo */
}

/* If the white is still showing, try this container approach */
.meet-elaine .elaine-image {
    width: 350px !important;
    height: 350px !important;
    border-radius: 50% !important;
    overflow: hidden !important;
    margin: 0 auto !important;
    background: #2a2a3e !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15) !important;
}

.meet-elaine .elaine-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 20% !important;
}
/* Fix blueprint section spacing */
.screen.solution {
    padding-bottom: 150px !important;
    margin-bottom: 80px !important;
}
/* Extend the dark purple background section further */
.screen.solution {
    padding-bottom: 250px !important;  /* Increased from 150px */
    margin-bottom: 120px !important;    /* Increased from 80px */
}

/* Also ensure the background covers the full height */
#blueprint {
    min-height: 100vh !important;
    padding-bottom: 300px !important;
}
/* Add more dark purple space after the blueprint modules */
/* Reduce the dark purple space after modules */
.modules {
    margin-bottom: 80px !important;  /* Reduced from 150px */
}

/* Or adjust this instead */
.screen.solution .container {
    padding-bottom: 100px !important;  /* Reduced from 200px */
}
/* Minimal dark purple after cards */
.modules {
    margin-bottom: 20px !important;
}

/* Bigger white gap */
.screen.solution {
    margin-bottom: 80px !important;
}
/* Add white gap between button section and blueprint stepper */
.blueprint-stepper {
    margin-top: 60px !important;  /* Creates white space above */
}

/* Or if that section has a different class, try */
#blueprint + section {
    margin-top: 60px !important;  /* White gap before next section */
}

/* Alternative - add bottom margin to the button section */
.cta-band, .purple-band {  /* whatever class that purple button section has */
    margin-bottom: 60px !important;
}
/* Add white space between purple band and stepper section */
.screen.blueprint-stepper {
    margin-top: 80px !important;  /* Creates white gap above */
    padding-top: 100px !important;  /* Additional space inside */
}

/* Or try targeting the transformation band if it has a specific class */
.transformation-band, .purple-band, .blueprint-band {
    margin-bottom: 80px !important;
}

/* Alternative - add space before blueprint stepper */
.stepper {
    margin-top: 100px !important;
}
/* Add space between button and title within the same section */
.screen h2.section-title {
    margin-top: 120px !important;  /* Adds space above the title */
}

/* Or target more specifically */
.screen.solution h2,
#blueprint h2 {
    margin-top: 120px !important;
}

/* If the button has a wrapper, add bottom margin */
.cta-wrapper, .button-wrapper {
    margin-bottom: 100px !important;
}

/* Alternative - if button is absolutely positioned */
.screen a[href*="90-day"],
.screen a:contains("GET YOUR") {
    margin-bottom: 100px !important;
    display: block !important;
}
/* Add space after the gap section */
.screen.gap {
    padding-bottom: 150px !important;
}

/* Or add space before the blueprint section */
#blueprint {
    padding-top: 150px !important;
}
/* Add white space AFTER the gap section */
.screen.gap {
    margin-bottom: 100px !important;
}

/* OR add white space BEFORE the blueprint section */
.screen.solution {
    margin-top: 100px !important;
}

/* OR both for more control */
.screen.gap {
    margin-bottom: 50px !important;
}
.screen.solution {
    margin-top: 50px !important;
}
/* Remove excessive white space after case study */
#beyond-insights-casestudy {
    margin-bottom: 0 !important;
    padding-bottom: 40px !important;
}

/* Ensure the Decision section follows closely */
.screen.decision {
    margin-top: 0 !important;
    padding-top: 60px !important;
}

/* Or if there's an iframe causing the issue */
#beyond-insights-casestudy iframe {
    margin-bottom: 0 !important;
}

/* Remove any min-height that might be causing the gap */
section#beyond-insights-casestudy {
    min-height: auto !important;
    height: auto !important;
}
/* Blueprint module improvements */
.module p {
    text-align: left !important;
    line-height: 1.6 !important;
}

.module-result {
    text-align: left !important;
    background: rgba(255,255,255,0.05);
    padding: 20px;
    border-radius: 10px;
    margin-top: 20px;
}

.result-label {
    color: #e4a324 !important;
    font-weight: 700 !important;
    display: block !important;
    margin-bottom: 8px !important;
}

/* Align "You get" boxes */
.module-result {
    min-height: 120px; /* ensures consistent height */
    display: flex;
    flex-direction: column;
}

/* Footer brand centering */
footer .container {
    text-align: center;
}

footer div[style*="flex"] {
    margin: 0 auto !important;
}

/* Add back flex to make auto margin work */
.module {
  display: flex;
  flex-direction: column;
}

/* Push "You get" sections to bottom and ensure consistent height */
.module-result {
  margin-top: auto;
  padding-top: 1rem; /* Reduced from 2rem */
  min-height: 180px; /* Increased to ensure alignment */
}

/* Remove the extra margin that's doubling up */
/* DELETE this part:
.module-result > div {
  margin-top: 2rem;
}
/* Quick fix for alignment */
.module {
  display: flex;
  flex-direction: column;
}

.module-result {
  margin-top: auto;
  min-height: 180px;
}
/* Prevent the Blueprint text from wrapping */
.hero-sub strong {
    white-space: nowrap;
    display: inline-block;
}

/* Optional: If the whole subtitle is wrapping awkwardly */
.hero-sub {
    font-size: 1.3rem !important;
    line-height: 1.9 !important;
    max-width: 800px;
    margin: 0 auto;
}

/* For mobile responsiveness */
@media (max-width: 768px) {
    .hero-sub strong {
        display: block; /* Put Blueprint™ on its own line on mobile */
        margin-top: 0.5rem;
    }
}


/* Force no wrapping with higher specificity */
.hero .hero-sub strong,
.hero-content .hero-sub strong,
section.hero .hero-sub strong {
    white-space: nowrap !important;
    display: inline-block !important;
}
/* Make the hero content wider to accommodate the text */
.hero-content {
    max-width: 1200px !important;
    width: 90% !important;
    margin: 0 auto !important;
}

.hero-sub {
    max-width: 900px !important;
    margin: 0 auto !important;
    font-size: 1.2rem !important; /* Slightly smaller font */
}
/* Target button by its text content */
a[class*="cta"]:contains("Unlock"),
.hero a[href*="blueprint"] {
    margin-top: 3rem !important;
    display: inline-block !important;
}

/* Push the button down */
.hero-cta {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
}

/* Or if it has a different class name, try this */
.cta-button,
a[href="#blueprint"] {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
}

/* If you need even more space above the button */
.hero-sub {
    margin-bottom: 2.5rem !important;
}
/* Add space after the Blueprint text paragraph */
.hero-sub {
    padding-bottom: 2rem !important;
    margin-bottom: 2rem !important;
}
/* Make leadership grid show all 4 people in one row */
.leadership-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 30px;
    max-width: 1400px;
    margin: 0 auto;
}

/* On tablets, switch to 2x2 */
@media (max-width: 1200px) {
    .leadership-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* On mobile, single column */
@media (max-width: 600px) {
    .leadership-grid {
        grid-template-columns: 1fr !important;
    }
}
