/* CSS spécifique pour /sonorisation-evenementiel - extrait depuis la version live */

/* Bloc #1 */
:root {
        --transition-normal: 0.3s ease;
      }
      
    .section_hero {
      position: relative;
      min-height: 100vh;
      width: 100%;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      overflow: hidden;
      background-color: var(--primary-dark);
      padding: 0 var(--spacing-md);
      z-index: 1;
    }
    
    .hero-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-image: url("/images/noise-pattern.png");
      background-size: 200px;
      background-repeat: repeat;
      opacity: 0.05;
      z-index: -1;
    }
    
    .hero-diagonal {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 15vw;
      background-color: var(--primary-dark);
      transform: skewY(-3deg);
      transform-origin: bottom left;
      z-index: -1;
      border-top: 1px solid rgba(118, 228, 155, 0.1);
    }
    
    .hero-content {
      max-width: 1200px;
      width: 100%;
      z-index: 2;
      padding: var(--spacing-lg) 0;
      position: relative;
    }
    
    .hero-subtitle {
      font-family: 'Schibsted Grotesk', sans-serif;
      font-size: 1.1rem;
      color: var(--accent-green);
      text-transform: uppercase;
      letter-spacing: 3px;
      margin-bottom: var(--spacing-sm);
      font-weight: 400;
      opacity: 0;
      transform: translateY(20px);
      animation: fadeUp 0.8s ease forwards 0.2s;
    }
    
    .hero-title {
      font-family: 'Broad Sans', sans-serif;
      font-size: 4.5rem;
      line-height: 1.1;
      margin-bottom: var(--spacing-md);
      font-weight: 700;
      max-width: 800px;
      text-transform: uppercase;
      color: var(--text-light);
      position: relative;
      opacity: 0;
      transform: translateY(30px);
      animation: fadeUp 0.8s ease forwards 0.4s;
    }
    
    .hero-title span {
      color: var(--accent-green);
    }
    
    .hero-description {
      font-family: 'Schibsted Grotesk', sans-serif;
      font-size: 1.2rem;
      line-height: 1.8;
      margin-bottom: var(--spacing-lg);
      color: var(--text-secondary);
      max-width: 650px;
      opacity: 0;
      transform: translateY(30px);
      animation: fadeUp 0.8s ease forwards 0.6s;
    }
    
    .hero-description span {
      color: var(--accent-green);
      font-weight: 600;
      transition: all var(--transition-normal);
    }
    
    .hero-description span:hover {
      color: var(--accent-purple);
    }
    
    .hero-location {
      color: var(--accent-green);
      font-weight: 600;
      transition: all var(--transition-normal);
    }
    
    .hero-location:hover {
      color: var(--accent-purple);
    }
    
    .hero-cta-container {
      display: flex;
      gap: var(--spacing-md);
      margin-top: var(--spacing-md);
      opacity: 0;
      transform: translateY(30px);
      animation: fadeUp 0.8s ease forwards 0.8s;
    }
    
    .hero-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 15px 35px;
      background: var(--accent-green);
      color: var(--primary-dark);
      border: none;
      border-radius: var(--border-radius);
      font-family: 'Broad Sans', sans-serif;
      font-weight: 600;
      text-transform: uppercase;
      font-size: 1rem;
      letter-spacing: 1px;
      cursor: pointer;
      transition: all var(--transition-normal);
      text-decoration: none;
    }
    
    .hero-cta:hover {
      background: var(--accent-purple);
      transform: translateY(-5px);
      box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
    }
    
    .hero-cta.secondary {
      background: transparent;
      border: 2px solid var(--accent-green);
      color: var(--text-light);
    }
    
    .hero-cta.secondary:hover {
      background: rgba(118, 228, 155, 0.1);
      border-color: var(--accent-purple);
      color: var(--text-light);
    }
    
    /* Régie-specific background icons */
    .regie-icons {
      position: absolute;
      width: 100%;
      height: 100%;
      z-index: -1;
      opacity: 0.1;
    }
    
    .regie-icon {
      position: absolute;
      width: 60px;
      height: 60px;
      background-repeat: no-repeat;
      background-position: center;
      background-size: contain;
      opacity: 0.7;
    }
    
    .icon-light {
      top: 15%;
      left: 20%;
      fill: var(--accent-green);
      animation: float 15s ease-in-out infinite;
    }
    
    .icon-sound {
      top: 25%;
      right: 15%;
      fill: var(--accent-green);
      animation: float 18s ease-in-out infinite 1s;
    }
    
    .icon-video {
      bottom: 20%;
      left: 25%;
      fill: var(--accent-green);
      animation: float 20s ease-in-out infinite 2s;
    }
    
    .icon-security {
      bottom: 15%;
      right: 20%;
      fill: var(--accent-green);
      animation: float 17s ease-in-out infinite;
    }
    
    .icon-gear {
      top: 60%;
      left: 10%;
      fill: var(--accent-green);
      animation: rotate 20s linear infinite;
    }
    
    /* Régie grid background */
    .regie-grid {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-image: linear-gradient(rgba(118, 228, 155, 0.03) 1px, transparent 1px),
                         linear-gradient(90deg, rgba(118, 228, 155, 0.03) 1px, transparent 1px);
      background-size: 50px 50px;
      z-index: -1;
      opacity: 0.5;
    }
    
    /* Abstract shapes */
    .shape {
      position: absolute;
      z-index: -1;
    }
    
    .shape-circle {
      width: 300px;
      height: 300px;
      border-radius: 50%;
      background: linear-gradient(135deg, rgba(118, 228, 155, 0.1), rgba(66, 58, 187, 0.1));
      top: 20%;
      right: 10%;
      animation: float 20s infinite ease-in-out alternate;
    }
    
    .shape-square {
      width: 200px;
      height: 200px;
      background: rgba(118, 228, 155, 0.05);
      transform: rotate(45deg);
      bottom: 10%;
      left: 5%;
      animation: float 25s infinite ease-in-out alternate-reverse;
    }
    
    .scroll-indicator {
      position: absolute;
      bottom: 60px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      cursor: pointer;
      opacity: 0;
      animation: fadeIn 0.8s ease forwards 1.5s;
      z-index: 10;
    }
    
    .scroll-text {
      font-size: 0.9rem;
      text-transform: uppercase;
      letter-spacing: 2px;
      margin-bottom: var(--spacing-xs);
      color: var(--text-secondary);
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    .scroll-icon {
      width: 30px;
      height: 50px;
      border: 2px solid var(--accent-green);
      border-radius: 15px;
      position: relative;
      overflow: hidden;
    }
    
    .scroll-icon::before {
      content: '';
      position: absolute;
      top: 5px;
      left: 50%;
      width: 6px;
      height: 6px;
      background: var(--accent-green);
      border-radius: 50%;
      transform: translateX(-50%);
      animation: scrollDown 2s infinite;
    }
    
    /* Animations */
    @keyframes fadeUp {
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    @keyframes fadeIn {
      to {
        opacity: 1;
      }
    }
    
    @keyframes scrollDown {
      0% {
        top: 5px;
        opacity: 1;
      }
      50% {
        top: 25px;
        opacity: 0.5;
      }
      100% {
        top: 5px;
        opacity: 1;
      }
    }
    
    @keyframes float {
      0% {
        transform: translate(0, 0);
      }
      50% {
        transform: translate(30px, 20px);
      }
      100% {
        transform: translate(0, 0);
      }
    }
    
    @keyframes rotate {
      from {
        transform: rotate(0deg);
      }
      to {
        transform: rotate(360deg);
      }
    }
    
    /* Media Queries */
    @media (max-width: 992px) {
      .hero-content {
        text-align: center;
      }
      
      .hero-title, .hero-description {
        max-width: 100%;
      }
      
      .hero-cta-container {
        justify-content: center;
      }
    }
    
    @media (max-width: 768px) {
      .hero-title {
        font-size: 3rem;
      }
      
      .hero-cta-container {
        flex-direction: column;
        width: 100%;
        max-width: 400px;
        margin-left: auto;
        margin-right: auto;
      }
      
      .hero-cta {
        width: 100%;
      }
    }
    
    @media (max-width: 576px) {
      .hero-title {
        font-size: 2.5rem;
      }
      
      .hero-subtitle {
        font-size: 1rem;
      }
      
      .hero-description {
        font-size: 1rem;
      }
    }

/* Bloc #2 */
.section_definition {
      position: relative;
      overflow: hidden;
      z-index: 1;
    }
    
    .definition-diagonal-top {
      position: absolute;
      top: -15vw;
      left: 0;
      width: 100%;
      height: 15vw;
      background-color: var(--primary-dark);
      transform: skewY(-3deg);
      transform-origin: top left;
      z-index: -1;
      border-bottom: 1px solid rgba(118, 228, 155, 0.1);
    }
    
    .definition-diagonal-bottom {
      position: absolute;
      bottom: -15vw;
      left: 0;
      width: 100%;
      height: 15vw;
      background-color: var(--primary-dark);
      transform: skewY(3deg);
      transform-origin: bottom right;
      z-index: 0;
      border-top: 1px solid rgba(118, 228, 155, 0.1);
    }
    
    .definition-container {
      margin: 0 auto;
      position: relative;
      z-index: 2;
    }
    
    .definition-title-wrap {
      text-align: center;
      margin-bottom: var(--spacing-lg);
    }
    
    .definition-title {
      font-family: 'Broad Sans', sans-serif;
      font-size: 3rem;
      font-weight: 700;
      margin-bottom: var(--spacing-md);
      text-transform: uppercase;
      color: var(--text-light);
      position: relative;
      display: inline-block;
    }
    
    .definition-title::after {
      content: '';
      position: absolute;
      bottom: -10px;
      left: 50%;
      transform: translateX(-50%);
      width: 60px;
      height: 4px;
      background: linear-gradient(to right, var(--accent-green), var(--accent-purple));
      border-radius: 2px;
    }
    
    .definition-subtitle {
      color: var(--text-secondary);
      font-family: 'Schibsted Grotesk', sans-serif;
      font-size: 1.1rem;
      max-width: 800px;
      margin: 0 auto;
      line-height: 1.6;
    }
    
    /* Grid layout for intro section */
    .definition-intro {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--spacing-lg);
      margin-bottom: var(--spacing-xl);
      align-items: center;
    }
    
    .intro-visual {
      position: relative;
      min-height: 350px;
      border-radius: var(--border-radius);
      overflow: hidden;
      background: rgba(19, 21, 33, 0.4);
      border: 1px solid rgba(118, 228, 155, 0.1);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all var(--transition-normal);
      opacity: 0;
      transform: translateX(-30px);
    }
    
    .intro-visual.fade-in-left {
      opacity: 1;
      transform: translateX(0);
      animation: fadeLeft 1s ease forwards;
    }
    
    .intro-visual:hover {
      transform: translateY(-10px);
      border-color: var(--accent-green);
      box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
    }
    
    .conductor-visual {
      position: relative;
      width: 100%;
      height: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      padding: var(--spacing-md);
    }
    
    .conductor-elements {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      opacity: 0.1;
    }
    
    .conductor-element {
      position: absolute;
      width: 40px;
      height: 40px;
      border-radius: 50%;
      background: var(--accent-green);
      opacity: 0.3;
    }
    
    .conductor-element-1 {
      top: 20%;
      left: 20%;
      animation: float 20s infinite ease-in-out;
    }
    
    .conductor-element-2 {
      top: 70%;
      left: 30%;
      width: 30px;
      height: 30px;
      animation: float 15s infinite ease-in-out reverse;
    }
    
    .conductor-element-3 {
      top: 40%;
      left: 70%;
      width: 35px;
      height: 35px;
      animation: float 18s infinite ease-in-out 2s;
    }
    
    .conductor-element-4 {
      top: 80%;
      left: 80%;
      animation: float 22s infinite ease-in-out 1s;
    }
    
    .conductor-element-5 {
      top: 20%;
      left: 60%;
      width: 25px;
      height: 25px;
      animation: float 17s infinite ease-in-out 3s;
    }
    
    .conductor-lines {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
    }
    
    .conductor-line {
      position: absolute;
      height: 1px;
      background: var(--accent-green);
      opacity: 0.2;
      transform-origin: center;
    }
    
    .conductor-line-1 {
      width: 80%;
      top: 30%;
      left: 10%;
    }
    
    .conductor-line-2 {
      width: 60%;
      top: 50%;
      left: 20%;
    }
    
    .conductor-line-3 {
      width: 70%;
      top: 70%;
      left: 15%;
    }
    
    .conductor-icon {
      width: 100px;
      height: 100px;
      background: rgba(118, 228, 155, 0.08);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: var(--spacing-md);
      border: 2px solid rgba(118, 228, 155, 0.15);
      position: relative;
      z-index: 2;
    }
    
    .conductor-icon svg {
      width: 50px;
      height: 50px;
      fill: var(--accent-green);
    }
    
    .conductor-title {
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--accent-green);
      margin-bottom: var(--spacing-sm);
      font-family: 'Broad Sans', sans-serif;
      position: relative;
      z-index: 2;
    }
    
    .conductor-desc {
      font-size: 1.1rem;
      text-align: center;
      color: var(--text-light);
      position: relative;
      z-index: 2;
      font-family: 'Schibsted Grotesk', sans-serif;
      font-style: italic;
    }
    
    .intro-content {
      opacity: 0;
      transform: translateX(30px);
    }
    
    .intro-content.fade-in-right {
      opacity: 1;
      transform: translateX(0);
      animation: fadeRight 1s ease forwards;
    }
    
    .intro-subtitle {
      font-size: 1.3rem;
      color: var(--accent-green);
      margin-bottom: var(--spacing-sm);
      font-weight: 600;
      font-family: 'Broad Sans', sans-serif;
    }
    
    .intro-text {
      color: var(--text-secondary);
      margin-bottom: var(--spacing-md);
      line-height: 1.8;
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    .intro-features {
      margin-top: var(--spacing-md);
    }
    
    .intro-feature {
      display: flex;
      align-items: flex-start;
      margin-bottom: var(--spacing-sm);
      transform: translateY(20px);
      opacity: 0;
      transition: all var(--transition-normal);
    }
    
    .intro-feature.visible {
      transform: translateY(0);
      opacity: 1;
    }
    
    .feature-bullet {
      width: 24px;
      height: 24px;
      min-width: 24px;
      background: rgba(118, 228, 155, 0.1);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-right: var(--spacing-sm);
      margin-top: 5px;
    }
    
    .feature-bullet svg {
      width: 14px;
      height: 14px;
      fill: var(--accent-green);
    }
    
    .feature-text {
      flex: 1;
      color: var(--text-secondary);
      line-height: 1.6;
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    .feature-highlight {
      color: var(--text-light);
      font-weight: 600;
    }
    
    /* Definition Types */
    .definition-types {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: var(--spacing-md);
      margin: var(--spacing-lg) 0;
    }
    
    .definition-type {
      flex: 1;
      min-width: 280px;
      max-width: 500px;
      background: rgba(19, 21, 33, 0.6);
      border: 1px solid rgba(118, 228, 155, 0.1);
      border-radius: var(--border-radius);
      padding: var(--spacing-lg);
      text-align: center;
      transition: all var(--transition-normal);
      position: relative;
      overflow: hidden;
      opacity: 0;
      transform: translateY(30px);
    }
    
    .definition-type.visible {
      opacity: 1;
      transform: translateY(0);
    }
    
    .definition-type:hover {
      transform: translateY(-10px);
      border-color: var(--accent-green);
      box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
    }
    
    .definition-type::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 4px;
      background: var(--accent-green);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform var(--transition-normal);
    }
    
    .definition-type:hover::before {
      transform: scaleX(1);
    }
    
    .type-icon {
      width: 80px;
      height: 80px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto var(--spacing-sm);
      border-radius: 15px;
      background: rgba(118, 228, 155, 0.1);
      transition: all var(--transition-normal);
      border: 2px solid rgba(118, 228, 155, 0.1);
    }
    
    .definition-type:hover .type-icon {
      background: rgba(118, 228, 155, 0.15);
      border-color: var(--accent-green);
      transform: rotate(5deg) scale(1.05);
    }
    
    .type-icon svg {
      width: 40px;
      height: 40px;
      fill: var(--accent-green);
    }
    
    .type-title {
      font-size: 1.6rem;
      font-weight: 600;
      margin-bottom: var(--spacing-sm);
      color: var(--accent-green);
      font-family: 'Broad Sans', sans-serif;
    }
    
    .type-desc {
      color: var(--text-secondary);
      line-height: 1.7;
      margin-bottom: var(--spacing-sm);
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    /* Creative Connection Section */
    .connection-section {
      position: relative;
      margin: var(--spacing-xl) 0;
      padding: var(--spacing-lg) 0;
      overflow: hidden;
    }
    
    .connection-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: rgba(19, 21, 33, 0.4);
      border-radius: var(--border-radius);
      border: 1px solid rgba(118, 228, 155, 0.1);
      overflow: hidden;
    }
    
    .connection-wave {
      position: absolute;
      bottom: -20px;
      left: 0;
      width: 100%;
      height: 40px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath fill='rgba(118, 228, 155, 0.1)' d='M0,0V46.29c47.79,22.2,103.59,32.17,158,28,70.36-5.37,136.33-33.31,206.8-37.5C438.64,32.43,512.34,53.67,583,72.05c69.27,18,138.3,24.88,209.4,13.08,36.15-6,69.85-17.84,104.45-29.34C989.49,25,1113-14.29,1200,52.47V0Z' opacity='.25'%3E%3C/path%3E%3Cpath fill='rgba(118, 228, 155, 0.1)' d='M0,0V15.81C13,36.92,27.64,56.86,47.69,72.05,99.41,111.27,165,111,224.58,91.58c31.15-10.15,60.09-26.07,89.67-39.8,40.92-19,84.73-46,130.83-49.67,36.26-2.85,70.9,9.42,98.6,31.56,31.77,25.39,62.32,62,103.63,73,40.44,10.79,81.35-6.69,119.13-24.28s75.16-39,116.92-43.05c59.73-5.85,113.28,22.88,168.9,38.84,30.2,8.66,59,6.17,87.09-7.5,22.43-10.89,48-26.93,60.65-49.24V0Z' opacity='.5'%3E%3C/path%3E%3Cpath fill='rgba(118, 228, 155, 0.1)' d='M0,0V5.63C149.93,59,314.09,71.32,475.83,42.57c43-7.64,84.23-20.12,127.61-26.46,59-8.63,112.48,12.24,165.56,35.4C827.93,77.22,886,95.24,951.2,90c86.53-7,172.46-45.71,248.8-84.81V0Z'%3E%3C/path%3E%3C/svg%3E");
      background-size: cover;
      background-position: center;
      opacity: 0.5;
    }
    
    .conductor-quote {
      position: relative;
      padding: 0 var(--spacing-lg);
      text-align: center;
      z-index: 2;
      opacity: 0;
      transform: translateY(30px);
      transition: all var(--transition-normal);
    }
    
    .conductor-quote.visible {
      opacity: 1;
      transform: translateY(0);
    }
    
    .quote-icon {
      width: 60px;
      height: 60px;
      margin: 0 auto var(--spacing-md);
      opacity: 0.3;
    }
    
    .quote-icon svg {
      width: 100%;
      height: 100%;
      fill: var(--accent-green);
    }
    
    .quote-text {
      font-size: 1.5rem;
      line-height: 1.8;
      color: var(--text-light);
      margin-bottom: var(--spacing-md);
      font-family: 'Schibsted Grotesk', sans-serif;
      font-weight: 300;
      position: relative;
    }
    
    .quote-text::before,
    .quote-text::after {
      content: '"';
      color: var(--accent-green);
      font-size: 2rem;
      font-weight: 700;
    }
    
    .quote-author {
      font-size: 1.1rem;
      color: var(--accent-green);
      font-weight: 600;
      font-family: 'Broad Sans', sans-serif;
    }
    
    /* Phases Tab System */
    .phases-container {
      margin-top: var(--spacing-xl);
    }
    
    .phases-tabs {
      display: flex;
      justify-content: center;
      gap: var(--spacing-sm);
      margin-bottom: var(--spacing-lg);
      position: relative;
      z-index: 2;
      flex-wrap: wrap;
    }
    
    .phase-tab {
      padding: 15px 25px;
      background: transparent;
      border: 2px solid rgba(118, 228, 155, 0.2);
      border-radius: var(--border-radius);
      color: var(--text-light);
      font-family: 'Broad Sans', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      text-transform: uppercase;
      cursor: pointer;
      transition: all var(--transition-normal);
      min-width: 200px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    
    .phase-tab::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: var(--accent-green);
      opacity: 0;
      transition: opacity var(--transition-normal);
      z-index: -1;
    }
    
    .phase-tab:hover {
      border-color: var(--accent-green);
      color: var(--text-light);
      transform: translateY(-3px);
    }
    
    .phase-tab:hover::before {
      opacity: 0.1;
    }
    
    .phase-tab.active {
      background: var(--accent-green);
      border-color: var(--accent-green);
      color: var(--primary-dark);
    }
    
    .phase-tab.active::before {
      opacity: 1;
    }
    
    .phases-content-wrap {
      position: relative;
    }
    
    .phase-content {
      opacity: 0;
      visibility: hidden;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      transition: opacity 0.5s ease, visibility 0.5s ease;
    }
    
    .phase-content.active {
      opacity: 1;
      visibility: visible;
      position: relative;
    }
    
    .phase-header {
      background: rgba(19, 21, 33, 0.6);
      border: 1px solid rgba(118, 228, 155, 0.1);
      border-radius: var(--border-radius);
      padding: var(--spacing-md) var(--spacing-lg);
      margin-bottom: var(--spacing-lg);
      transition: all var(--transition-normal);
    }
    
    .phase-header:hover {
      border-color: var(--accent-green);
      transform: translateY(-5px);
      box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
    }
    
    .phase-title {
      font-family: 'Broad Sans', sans-serif;
      font-size: 2rem;
      font-weight: 700;
      margin-bottom: var(--spacing-sm);
      color: var(--text-light);
      position: relative;
      display: inline-block;
    }
    
    .phase-title::after {
      content: '';
      position: absolute;
      bottom: -5px;
      left: 0;
      width: 40px;
      height: 3px;
      background: var(--accent-green);
    }
    
    .phase-desc {
      color: var(--text-secondary);
      line-height: 1.6;
      font-family: 'Schibsted Grotesk', sans-serif;
      margin-bottom: 0;
    }
    
    .phase-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: var(--spacing-md);
      margin-bottom: var(--spacing-lg);
    }
    
    .phase-item {
      background: rgba(19, 21, 33, 0.4);
      border: 1px solid rgba(118, 228, 155, 0.1);
      border-radius: var(--border-radius);
      padding: var(--spacing-md);
      transition: all var(--transition-normal);
      opacity: 0;
      transform: translateY(20px);
    }
    
    .phase-item.visible {
      opacity: 1;
      transform: translateY(0);
    }
    
    .phase-item:hover {
      border-color: var(--accent-green);
      transform: translateY(-5px);
      box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    }
    
    .phase-item-title {
      display: flex;
      align-items: center;
      margin-bottom: var(--spacing-sm);
      font-family: 'Broad Sans', sans-serif;
    }
    
    .phase-item-icon {
      width: 40px;
      height: 40px;
      background: rgba(118, 228, 155, 0.1);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-right: var(--spacing-sm);
      flex-shrink: 0;
      transition: all var(--transition-normal);
    }
    
    .phase-item:hover .phase-item-icon {
      background: rgba(118, 228, 155, 0.2);
      transform: rotate(5deg);
    }
    
    .phase-item-icon svg {
      width: 22px;
      height: 22px;
      fill: var(--accent-green);
    }
    
    .phase-item-name {
      font-size: 1.2rem;
      font-weight: 600;
      color: var(--text-light);
    }
    
    .phase-item-desc {
      color: var(--text-secondary);
      line-height: 1.6;
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    /* Service links styling */
    .service-link {
      color: var(--accent-green);
      text-decoration: none;
      font-weight: 600;
      position: relative;
      transition: all var(--transition-normal);
    }
    
    .service-link:hover {
      color: var(--accent-purple);
    }
    
    .service-link::after {
      content: '';
      position: absolute;
      bottom: -2px;
      left: 0;
      width: 100%;
      height: 1px;
      background: var(--accent-green);
      transform: scaleX(0);
      transform-origin: right;
      transition: transform var(--transition-normal);
    }
    
    .service-link:hover::after {
      transform: scaleX(1);
      transform-origin: left;
      background: var(--accent-purple);
    }
    
    /* Expertise Cards */
    .expertise-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: var(--spacing-md);
      margin-top: var(--spacing-xl);
    }
    
    .expertise-card {
      background: rgba(19, 21, 33, 0.4);
      border: 1px solid rgba(118, 228, 155, 0.1);
      border-radius: var(--border-radius);
      padding: var(--spacing-md);
      transition: all var(--transition-normal);
      opacity: 0;
      transform: translateY(20px);
      overflow: hidden;
      position: relative;
    }
    
    .expertise-card.visible {
      opacity: 1;
      transform: translateY(0);
    }
    
    .expertise-card:hover {
      border-color: var(--accent-green);
      transform: translateY(-5px);
      box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    }
    
    .expertise-card::before {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 2px;
      background: var(--accent-green);
      transform: scaleX(0);
      transform-origin: right;
      transition: transform var(--transition-normal);
    }
    
    .expertise-card:hover::before {
      transform: scaleX(1);
      transform-origin: left;
    }
    
    .expertise-icon {
      width: 50px;
      height: 50px;
      background: rgba(118, 228, 155, 0.1);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: var(--spacing-sm);
      transition: all var(--transition-normal);
    }
    
    .expertise-card:hover .expertise-icon {
      background: rgba(118, 228, 155, 0.2);
      transform: rotate(5deg);
    }
    
    .expertise-icon svg {
      width: 25px;
      height: 25px;
      fill: var(--accent-green);
    }
    
    .expertise-title {
      font-size: 1.2rem;
      font-weight: 600;
      margin-bottom: var(--spacing-sm);
      color: var(--text-light);
      font-family: 'Broad Sans', sans-serif;
    }
    
    .expertise-desc {
      color: var(--text-secondary);
      line-height: 1.6;
      font-family: 'Schibsted Grotesk', sans-serif;
      font-size: 0.95rem;
    }
    
    /* Background elements */
    .def-bg-element {
      position: absolute;
      z-index: -1;
    }
    
    .def-wave {
      width: 400px;
      height: 400px;
      background-color: var(--accent-green);
      border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      opacity: 0.03;
      top: 20%;
      right: -200px;
      animation: morphWave 15s infinite alternate ease-in-out;
    }
    
    @keyframes morphWave {
      0% {
        border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      }
      50% {
        border-radius: 35% 65% 35% 65% / 65% 35% 65% 35%;
      }
      100% {
        border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      }
    }
    
    .def-dots {
      width: 300px;
      height: 300px;
      background-image: radial-gradient(var(--accent-green) 1px, transparent 1px);
      background-size: 20px 20px;
      opacity: 0.05;
      bottom: 15%;
      left: 5%;
    }
    
    /* Animations */
    @keyframes fadeIn {
      to {
        opacity: 1;
      }
    }
    
    @keyframes fadeUp {
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    @keyframes fadeLeft {
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    
    @keyframes fadeRight {
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    
    @keyframes float {
      0% {
        transform: translate(0, 0);
      }
      50% {
        transform: translate(15px, 15px);
      }
      100% {
        transform: translate(0, 0);
      }
    }
    
    /* Responsive Styles */
    @media (max-width: 1200px) {
      .expertise-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }
    
    @media (max-width: 992px) {
      .definition-intro {
        grid-template-columns: 1fr;
      }
      
      .intro-visual {
        order: -1;
        min-height: 300px;
        margin-bottom: var(--spacing-md);
      }
      
      .phase-grid {
        grid-template-columns: 1fr;
      }
      
      .definition-title {
        font-size: 2.5rem;
      }
      
      .phase-tab {
        min-width: 150px;
      }
      
      .quote-text {
        font-size: 1.3rem;
      }
    }
    
    @media (max-width: 768px) {
      .expertise-grid {
        grid-template-columns: 1fr;
      }
      
      .phase-tab {
        min-width: 120px;
        padding: 12px 15px;
        font-size: 0.9rem;
      }
      
      .definition-title {
        font-size: 2rem;
      }
      
      .phase-title {
        font-size: 1.8rem;
      }
      
      .quote-text {
        font-size: 1.2rem;
      }
    }
    
    @media (max-width: 576px) {
      .phases-tabs {
        flex-direction: column;
        gap: 10px;
      }
      
      .phase-tab {
        width: 100%;
      }
      
      .phase-header {
        padding: var(--spacing-md);
      }
      
      .phase-title {
        font-size: 1.5rem;
      }
      
      .definition-type {
        min-width: 100%;
      }
      
      .quote-text {
        font-size: 1.1rem;
      }
    }

/* Bloc #3 */
html.wf-design-mode .intro-feature,
html.wf-design-mode .conductor-quote,
html.wf-design-mode .definition-type,
html.wf-design-mode .expertise-card,
html.wf-design-mode .phase-content,
html.wf-design-mode .phase-item,
html.wf-design-mode .phase-tab {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  display: block !important;
  pointer-events: auto !important;
  transition: none !important;
}

html.wf-design-mode .phase-content {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
  position: relative !important;
}

html.wf-design-mode .phase-tab {
  background: var(--accent-green) !important;
  border-color: var(--accent-green) !important;
  color: var(--primary-dark) !important;
}

/* Bloc #4 */
html.wf-design-mode .faq-item,
    html.wf-design-mode .faq-answer {
      opacity: 1 !important;
      transform: none !important;
      max-height: none !important;
    }
     :root {
      --transition-normal: 0.3s ease;
    }
    .section_faq {
      position: relative;
      background: linear-gradient(135deg, rgba(19, 21, 33, 0.98) 0%, var(--primary-dark) 100%);
      overflow: hidden;
      z-index: 1;
    }
    
    .faq-diagonal-top {
      position: absolute;
      top: -15vw;
      left: 0;
      width: 100%;
      height: 15vw;
      background-color: var(--primary-dark);
      transform: skewY(3deg);
      transform-origin: top right;
      z-index: 0;
      border-bottom: 1px solid rgba(118, 228, 155, 0.1);
    }
    
    .faq-diagonal-bottom {
      position: absolute;
      bottom: -15vw;
      left: 0;
      width: 100%;
      height: 15vw;
      background-color: var(--primary-dark);
      transform: skewY(-3deg);
      transform-origin: bottom left;
      z-index: 0;
      border-top: 1px solid rgba(118, 228, 155, 0.1);
    }
    
    .faq-bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2376E49B' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
      opacity: 0.05;
      z-index: 0;
    }
    
    .faq-container {
      max-width: 1000px;
      margin: 0 auto;
      position: relative;
      z-index: 2;
    }
    
    .faq-header {
      text-align: center;
      margin-bottom: var(--spacing-lg);
      opacity: 0;
      transform: translateY(30px);
      animation: fadeUp 0.8s ease forwards 0.1s;
    }
    
    .faq-title {
      font-family: 'Broad Sans', sans-serif;
      font-size: 3rem;
      font-weight: 700;
      margin-bottom: var(--spacing-md);
      text-transform: uppercase;
      color: var(--text-light);
      position: relative;
      display: inline-block;
    }
    
    .faq-title .highlight {
      color: var(--accent-green);
    }
    
    .faq-title::after {
      content: '';
      position: absolute;
      bottom: -10px;
      left: 50%;
      transform: translateX(-50%);
      width: 60px;
      height: 4px;
      background: linear-gradient(to right, var(--accent-green), var(--accent-purple));
      border-radius: 2px;
    }
    
    .faq-subtitle {
      color: var(--text-secondary);
      font-family: 'Schibsted Grotesk', sans-serif;
      font-size: 1.1rem;
      max-width: 700px;
      margin: 0 auto;
      line-height: 1.6;
    }
    
    .faq-items {
      display: flex;
      flex-direction: column;
      gap: var(--spacing-md);
      margin-bottom: var(--spacing-xl);
    }
    
    .faq-item {
      background: rgba(19, 21, 33, 0.5);
      border: 1px solid rgba(118, 228, 155, 0.1);
      border-radius: var(--border-radius);
      overflow: hidden;
      transition: all var(--transition-normal);
      opacity: 0;
      transform: translateY(20px);
    }
    
    .faq-item:nth-child(1) { animation: fadeUp 0.8s ease forwards 0.2s; }
    .faq-item:nth-child(2) { animation: fadeUp 0.8s ease forwards 0.3s; }
    .faq-item:nth-child(3) { animation: fadeUp 0.8s ease forwards 0.4s; }
    .faq-item:nth-child(4) { animation: fadeUp 0.8s ease forwards 0.5s; }
    .faq-item:nth-child(5) { animation: fadeUp 0.8s ease forwards 0.6s; }
    .faq-item:nth-child(6) { animation: fadeUp 0.8s ease forwards 0.7s; }
    .faq-item:nth-child(7) { animation: fadeUp 0.8s ease forwards 0.8s; }
    
    .faq-item:hover {
      border-color: rgba(118, 228, 155, 0.3);
      box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
      transform: translateY(-5px);
    }
    
    .faq-question {
      padding: var(--spacing-md);
      cursor: pointer;
      position: relative;
      display: flex;
      align-items: center;
      justify-content: space-between;
      user-select: none;
    }
    
    .faq-question-text {
      font-family: 'Broad Sans', sans-serif;
      font-weight: 600;
      font-size: 1.2rem;
      color: var(--text-light);
      padding-right: var(--spacing-md);
    }
    
    .faq-icon {
      position: relative;
      width: 24px;
      height: 24px;
      flex-shrink: 0;
    }
    
    .faq-icon::before,
    .faq-icon::after {
      content: '';
      position: absolute;
      background-color: var(--accent-green);
      transition: all var(--transition-normal);
    }
    
    .faq-icon::before {
      top: 11px;
      left: 0;
      width: 24px;
      height: 2px;
    }
    
    .faq-icon::after {
      top: 0;
      left: 11px;
      width: 2px;
      height: 24px;
    }
    
    .faq-item.active .faq-icon::after {
      transform: rotate(90deg);
      opacity: 0;
    }
    
    .faq-answer {
      max-height: 0;
      transition: max-height 0.3s ease, padding 0.3s ease;
    }
    
    .faq-item.active .faq-answer {
      max-height: 1000px;
    }
    
    .faq-answer-content {
      padding: 0 var(--spacing-md) var(--spacing-md);
      color: var(--text-secondary);
      line-height: 1.6;
      font-family: 'Schibsted Grotesk', sans-serif;
    }
    
    .faq-answer-content p:last-child {
      margin-bottom: 0;
    }
    
    .faq-answer-content strong {
      color: var(--text-light);
      font-weight: 600;
    }
    
    .faq-answer-content .highlight {
      color: var(--accent-green);
      font-weight: 600;
    }
    
    .faq-answer-list {
      list-style: none;
      padding: 0;
      margin: var(--spacing-sm) 0;
    }
    
    .faq-answer-list li {
      display: flex;
      align-items: flex-start;
      margin-bottom: var(--spacing-xs);
      color: var(--text-secondary);
    }
    
    .faq-answer-list li::before {
      content: '▸';
      color: var(--accent-green);
      font-weight: bold;
      margin-right: var(--spacing-xs);
      margin-top: 2px;
    }
    
    /* Background elements */
    .faq-bg-element {
      position: absolute;
      z-index: 0;
    }
    
    .faq-wave {
      width: 400px;
      height: 400px;
      background-color: var(--accent-green);
      border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      opacity: 0.03;
      top: 20%;
      right: -200px;
      animation: morphWave 15s infinite alternate ease-in-out;
    }
    
    @keyframes morphWave {
      0% {
        border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      }
      50% {
        border-radius: 35% 65% 35% 65% / 65% 35% 65% 35%;
      }
      100% {
        border-radius: 65% 35% 65% 35% / 35% 65% 35% 65%;
      }
    }
    
    .faq-dots {
      width: 300px;
      height: 300px;
      background-image: radial-gradient(var(--accent-green) 1px, transparent 1px);
      background-size: 20px 20px;
      opacity: 0.05;
      bottom: 15%;
      left: 5%;
    }
    
    /* Animations */
    @keyframes fadeUp {
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    /* Media Queries */
    @media (max-width: 992px) {
      .faq-title {
        font-size: 2.5rem;
      }
    }
    
    @media (max-width: 768px) {
      .faq-title {
        font-size: 2.2rem;
      }
      
      .faq-question-text {
        font-size: 1.1rem;
      }
    }
    
    @media (max-width: 576px) {
      .faq-title {
        font-size: 2rem;
      }
      
      .faq-question {
        padding: var(--spacing-sm) var(--spacing-md);
      }
      
      .faq-question-text {
        font-size: 1rem;
      }
      
      .faq-answer-content {
        padding: 0 var(--spacing-md) var(--spacing-md);
        font-size: 0.95rem;
      }
    }
