:root {
    --primary: #ff9760;
    --primary-dark: #ff7a3d;
    --secondary: #1e2334;
    --bg: #fafbfc;
    --text: #4a5568;
    --text-light: #718096;
    --text-dark: #2d3748;
    --gradient: linear-gradient(135deg, #ff9760, #ff7a3d);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', sans-serif;
    background: var(--bg);
    color: var(--text);
    overflow-x: hidden;
}

/* Navigation Ultra-Premium */
.navbar {
    position: fixed;
    top: 0;
    width: 100%;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(30px);
    z-index: 10000;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
}

.navbar.scrolled {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
}

.nav-container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 85px;
}

.logo-img {
    height: 48px;
    transition: transform 0.3s ease;
}

.logo-img:hover {
    transform: scale(1.05);
}

.nav-menu {
    display: flex;
    gap: 8px;
    align-items: center;
    list-style: none;
}

.nav-item {
    position: relative;
}

.nav-link {
    padding: 12px 20px;
    color: var(--text-dark);
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    border-radius: 10px;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 6px;
}

.nav-link:hover {
    background: rgba(255, 151, 96, 0.08);
    color: var(--primary);
}

.nav-cta {
    display: flex;
    gap: 12px;
    align-items: center;
}

.btn {
    padding: 14px 32px;
    border-radius: 12px;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    border: none;
    cursor: pointer;
    display: inline-block;
}

.btn-secondary {
    background: transparent;
    color: var(--text-dark);
    border: 2px solid rgba(0, 0, 0, 0.08);
}

.btn-secondary:hover {
    border-color: var(--primary);
    color: var(--primary);
    transform: translateY(-2px);
}

.btn-primary {
    background: var(--gradient);
    color: white;
    box-shadow: 0 10px 40px rgba(255, 151, 96, 0.35);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.5);
}

/* ===== MEGA MENU - BEAUTIFUL MOSAIC STYLE ===== */
.nav-item.has-mega-menu {
    position: static;
}

.mega-menu-trigger .nav-chevron {
    margin-left: 4px;
    transition: transform 0.3s ease;
}

.nav-item.has-mega-menu:hover .nav-chevron,
.nav-item.has-mega-menu.active .nav-chevron {
    transform: rotate(180deg);
}

.mega-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: white;
    border-radius: 20px;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.15), 0 10px 30px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(0, 0, 0, 0.06);
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: 9999;
    overflow: hidden;
}

.nav-item.has-mega-menu:hover .mega-menu,
.nav-item.has-mega-menu.active .mega-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.mega-menu-inner {
    display: flex;
}

/* Section visuelle gauche */
.mega-menu-visual {
    width: 260px;
    background: var(--gradient);
    padding: 32px 28px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.mega-visual-content {
    position: relative;
    z-index: 2;
}

.mega-visual-badge {
    display: inline-block;
    padding: 5px 12px;
    background: rgba(255, 255, 255, 0.2);
    color: white;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 16px;
    backdrop-filter: blur(10px);
}

.mega-menu-visual h3 {
    font-size: 22px;
    font-weight: 800;
    color: white;
    line-height: 1.25;
    margin-bottom: 12px;
}

.mega-menu-visual h3 span {
    color: rgba(255, 255, 255, 0.85);
}

.mega-menu-visual p {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.5;
    margin-bottom: 20px;
}

.mega-visual-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: white;
    color: var(--primary-dark);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
    border-radius: 10px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.mega-visual-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.mega-visual-cta svg {
    transition: transform 0.3s ease;
}

.mega-visual-cta:hover svg {
    transform: translateX(3px);
}

.mega-visual-decoration {
    position: absolute;
    bottom: -30px;
    right: -30px;
    width: 140px;
    height: 140px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
}

.mega-visual-decoration::before {
    content: '';
    position: absolute;
    top: -40px;
    left: -40px;
    width: 80px;
    height: 80px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 50%;
}

/* Section modules droite */
.mega-menu-modules {
    flex: 1;
    padding: 24px 28px;
}

.mega-modules-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
}

.mega-modules-header h4 {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.mega-see-all {
    font-size: 13px;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.mega-see-all:hover {
    color: var(--primary-dark);
}

/* Grille de modules mosaïque */
.mega-modules-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.mega-module-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: #f8f9fa;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
    border: 2px solid transparent;
}

.mega-module-card:hover {
    background: white;
    border-color: var(--primary);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255, 151, 96, 0.15);
}

.mega-module-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.mega-module-icon img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

.mega-module-card:hover .mega-module-icon {
    transform: scale(1.08);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
}

.mega-module-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.mega-module-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}

.mega-module-count {
    font-size: 11px;
    color: var(--text-light);
    font-weight: 500;
}

/* ===== MOBILE MENU BUTTON ===== */
.mobile-menu-btn {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    border-radius: 8px;
    transition: background 0.2s ease;
}

.mobile-menu-btn:hover {
    background: rgba(0, 0, 0, 0.05);
}

.mobile-menu-btn span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--text-dark);
    border-radius: 2px;
    transition: all 0.3s ease;
}

.mobile-menu-btn.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.mobile-menu-btn.active span:nth-child(2) {
    opacity: 0;
}

.mobile-menu-btn.active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* ===== MOBILE MENU OVERLAY ===== */
.mobile-menu-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 10001;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.mobile-menu-overlay.open {
    opacity: 1;
    visibility: visible;
}

.mobile-menu-panel {
    position: absolute;
    top: 0;
    right: 0;
    width: 85%;
    max-width: 350px;
    height: 100%;
    background: white;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    overflow-y: auto;
}

.mobile-menu-overlay.open .mobile-menu-panel {
    transform: translateX(0);
}

.mobile-menu-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.mobile-menu-header span {
    font-weight: 700;
    font-size: 16px;
    color: var(--text-dark);
}

.mobile-menu-close {
    width: 36px;
    height: 36px;
    border: none;
    background: none;
    font-size: 28px;
    color: var(--text);
    cursor: pointer;
    border-radius: 8px;
    transition: background 0.2s ease;
}

.mobile-menu-close:hover {
    background: rgba(0, 0, 0, 0.05);
}

.mobile-menu-content {
    padding: 16px 0;
}

.mobile-menu-accordion {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 14px 20px;
    background: none;
    border: none;
    font-size: 15px;
    font-weight: 600;
    color: var(--text-dark);
    cursor: pointer;
    text-align: left;
}

.mobile-menu-accordion svg {
    transition: transform 0.3s ease;
}

.mobile-menu-accordion.active svg {
    transform: rotate(180deg);
}

.mobile-menu-accordion-content {
    display: none;
    padding: 0 20px 16px;
    background: rgba(0, 0, 0, 0.02);
}

.mobile-menu-accordion-content.open {
    display: block;
}

/* Mobile Modules List - Simple Links */
.mobile-modules-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 8px 0;
}

.mobile-module-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: white;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.mobile-module-link:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(255, 151, 96, 0.15);
    transform: translateX(4px);
}

.mobile-module-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.mobile-module-icon img {
    width: 24px;
    height: 24px;
    object-fit: contain;
}

.mobile-module-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.mobile-module-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mobile-module-count {
    font-size: 12px;
    color: var(--text-light);
    font-weight: 500;
}

.mobile-module-arrow {
    color: var(--text-light);
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.mobile-module-link:hover .mobile-module-arrow {
    color: var(--primary);
    transform: translateX(3px);
}

.mobile-menu-link {
    display: block;
    padding: 14px 20px;
    color: var(--text-dark);
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    transition: background 0.2s ease;
}

.mobile-menu-link:hover {
    background: rgba(0, 0, 0, 0.03);
}

.mobile-menu-cta {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px;
    margin-top: 16px;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.mobile-menu-cta .btn {
    text-align: center;
}

/* ===== MEGA MENU RESPONSIVE ===== */
@media (max-width: 1100px) {
    .mega-menu {
        min-width: 600px;
    }
    .mega-col {
        padding: 0 12px;
    }
    .mega-col-links a {
        font-size: 12px;
        padding: 5px 6px;
    }
}

@media (max-width: 768px) {
    .mega-menu {
        display: none;
    }
    .nav-chevron {
        display: none;
    }
    .mobile-menu-btn {
        display: flex;
    }
    .mobile-menu-overlay {
        display: block;
    }
}

/* Hero Section Ultra-Premium */
.hero {
    padding: 180px 60px 120px;
    background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.08) 0%, transparent 70%);
    border-radius: 50%;
    animation: float 20s ease-in-out infinite;
}

.hero::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(255, 122, 61, 0.06) 0%, transparent 70%);
    border-radius: 50%;
    animation: float 15s ease-in-out infinite reverse;
}

.hero-container {
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.hero-content {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: white;
    padding: 10px 24px;
    border-radius: 100px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    margin-bottom: 30px;
    animation: slideDown 0.8s ease-out;
}

.hero-badge-dot {
    width: 8px;
    height: 8px;
    background: var(--gradient);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}

.hero-badge span {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
}

.hero h1 {
    font-size: 72px;
    font-weight: 900;
    color: var(--text-dark);
    line-height: 1.1;
    letter-spacing: -3px;
    margin-bottom: 30px;
    animation: slideUp 0.8s ease-out 0.2s both;
}

.gradient-text {
    background: var(--gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero p {
    font-size: 22px;
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 40px;
    animation: slideUp 0.8s ease-out 0.4s both;
}

.hero-cta {
    display: flex;
    gap: 16px;
    justify-content: center;
    animation: slideUp 0.8s ease-out 0.6s both;
}

.btn-hero {
    padding: 18px 40px;
    font-size: 16px;
    border-radius: 14px;
}

.hero-stats {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-top: 80px;
    animation: slideUp 0.8s ease-out 0.8s both;
}

.stat-item {
    text-align: center;
}

.stat-number {
    font-size: 48px;
    font-weight: 900;
    background: var(--gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 8px;
}

.stat-label {
    font-size: 15px;
    color: var(--text-light);
    font-weight: 600;
}

/* ===== KEY FEATURES SECTION ===== */
.key-features-section {
    padding: 120px 60px;
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%);
}

.key-features-container {
    max-width: 1400px;
    margin: 0 auto;
}

.key-features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 60px;
}

.key-feature-card {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.key-feature-card:hover {
    transform: translateY(-8px);
}

.key-feature-card-inner {
    position: relative;
    z-index: 2;
    padding: 40px;
    background: white;
    border-radius: 24px;
    border: 1px solid rgba(0, 0, 0, 0.06);
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all 0.4s ease;
}

.key-feature-card:hover .key-feature-card-inner {
    border-color: var(--primary);
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.2);
}

.key-feature-card-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--gradient);
    opacity: 0;
    transition: opacity 0.4s ease;
    border-radius: 24px;
}

.key-feature-card:hover .key-feature-card-bg {
    opacity: 0.05;
}

.key-feature-icon {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.15) 100%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    transition: all 0.4s ease;
}

.key-feature-card:hover .key-feature-icon {
    background: var(--gradient);
    transform: scale(1.1) rotate(-5deg);
}

.key-feature-icon span {
    font-size: 32px;
    transition: all 0.4s ease;
}

.key-feature-card:hover .key-feature-icon span {
    transform: scale(1.2);
    filter: brightness(1.2);
}

.key-feature-image {
    width: 70px;
    height: 70px;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.key-feature-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.key-feature-card h3 {
    font-size: 22px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 12px 0;
    line-height: 1.3;
}

.key-feature-card p {
    font-size: 15px;
    color: var(--text);
    line-height: 1.7;
    margin: 0 0 20px 0;
    flex: 1;
}

.key-feature-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 700;
    color: var(--primary);
    text-decoration: none;
    transition: all 0.3s ease;
}

.key-feature-link:hover {
    gap: 12px;
    color: var(--primary-dark);
}

.key-feature-link svg {
    transition: transform 0.3s ease;
}

.key-feature-link:hover svg {
    transform: translateX(4px);
}

/* Key Features Responsive */
@media (max-width: 1024px) {
    .key-features-section {
        padding: 80px 40px;
    }

    .key-features-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }
}

@media (max-width: 768px) {
    .key-features-section {
        padding: 60px 20px;
    }

    .key-features-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .key-feature-card-inner {
        padding: 28px;
    }

    .key-feature-icon {
        width: 60px;
        height: 60px;
        margin-bottom: 20px;
    }

    .key-feature-icon span {
        font-size: 28px;
    }

    .key-feature-card h3 {
        font-size: 20px;
    }
}

/* Hero Screenshot */
.hero-screenshot {
    margin-top: 80px;
    animation: slideUp 0.8s ease-out 1s both;
}

.hero-screenshot-link {
    display: block;
    text-decoration: none;
}

.hero-screenshot-wrapper {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 40px 100px rgba(0, 0, 0, 0.2), 0 10px 40px rgba(0, 0, 0, 0.1);
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.hero-screenshot-wrapper:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 60px 120px rgba(0, 0, 0, 0.25), 0 20px 60px rgba(0, 0, 0, 0.15);
}

.hero-screenshot-wrapper img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.5s ease;
}

.hero-screenshot-wrapper:hover img {
    transform: scale(1.02);
}

.hero-screenshot-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
    padding: 60px 30px 30px;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.hero-screenshot-wrapper:hover .hero-screenshot-overlay {
    opacity: 1;
}

.hero-screenshot-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px;
    background: var(--gradient);
    color: white;
    font-size: 15px;
    font-weight: 700;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(255, 151, 96, 0.4);
}

.hero-screenshot-cta svg {
    animation: bounce 2s infinite;
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateY(0);
    }
    40% {
        transform: translateY(5px);
    }
    60% {
        transform: translateY(3px);
    }
}

@media (max-width: 768px) {
    .hero-screenshot {
        margin-top: 50px;
    }

    .hero-screenshot-wrapper {
        border-radius: 16px;
    }

    .hero-screenshot-overlay {
        opacity: 1;
        padding: 40px 20px 20px;
    }

    .hero-screenshot-cta {
        font-size: 13px;
        padding: 12px 18px;
    }
}

/* Section Modules - Innovative Interactive Widget */
.modules-section {
    padding: 60px 60px 100px;
    background: white;
    min-height: auto;
}

.modules-container {
    max-width: 1800px;
    margin: 0 auto;
}

.section-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 80px;
}

.section-badge {
    display: inline-block;
    padding: 8px 20px;
    background: rgba(255, 151, 96, 0.1);
    color: var(--primary-dark);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 20px;
}

.section-header h2 {
    font-size: 56px;
    font-weight: 900;
    color: var(--text-dark);
    letter-spacing: -2px;
    margin-bottom: 20px;
}

.section-header p {
    font-size: 20px;
    color: var(--text);
    line-height: 1.6;
}

/* NEW: Modules Explorer Revolutionary Experience */
.modules-explorer-new {
    width: 100%;
}

/* Modules Tabs */
.modules-tabs-wrapper {
    position: relative;
    display: flex;
    align-items: stretch;
    gap: 12px;
}

.modules-tabs-wrapper::before,
.modules-tabs-wrapper::after {
    content: "";
    position: absolute;
    top: 10px;
    bottom: 10px;
    width: 28px;
    pointer-events: none;
    z-index: 1;
    transition: opacity 0.3s ease;
}

.modules-tabs-wrapper::before {
    left: 20px;
    background: linear-gradient(90deg, rgba(250, 251, 252, 1) 0%, rgba(250, 251, 252, 0) 100%);
    opacity: 0;
}

.modules-tabs-wrapper::after {
    right: 20px;
    background: linear-gradient(270deg, rgba(250, 251, 252, 1) 0%, rgba(250, 251, 252, 0) 100%);
    opacity: 0;
}

.modules-tabs {
    position: relative;
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 20px;
    background: linear-gradient(135deg, #fafbfc 0%, #ffffff 100%);
    border-radius: 20px;
    margin-bottom: 40px;
    scrollbar-width: none;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scroll-padding: 24px;
    overscroll-behavior-x: contain;
    touch-action: pan-x;
}

.modules-tabs::-webkit-scrollbar {
    display: none;
}

.modules-tab {
    scroll-snap-align: center;
}

.modules-tab-nav {
    display: none;
    border: none;
    background: white;
    color: var(--text-dark);
    border-radius: 50%;
    width: 44px;
    height: 44px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    align-self: center;
    flex-shrink: 0;
    font-size: 24px;
    line-height: 1;
}

.modules-tab-nav:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.16);
}

.modules-tab-nav:disabled {
    opacity: 0.4;
    cursor: default;
    box-shadow: none;
    transform: none;
}

.modules-tabs-wrapper.show-left::before {
    opacity: 0;
}
/* test opacity: 1; */
.modules-tabs-wrapper.show-right::after {
    opacity: 0;
}

@media (max-width: 1200px) {
    .modules-tab {
        min-width: 160px;
    }
}

@media (max-width: 1024px) {
    .modules-tabs-wrapper {
        gap: 0;
    }

    .modules-tab-nav {
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .modules-tabs {
        margin-bottom: 20px;
        padding: 16px;
    }

    .modules-tabs-wrapper::before {
        left: 64px;
    }

    .modules-tabs-wrapper::after {
        right: 64px;
    }
}

@media (max-width: 768px) {
    .modules-tab-nav {
        width: 40px;
        height: 40px;
        font-size: 20px;
        box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
    }

    .modules-tabs {
        padding: 14px;
        gap: 10px;
    }

    .modules-tabs-wrapper::before,
    .modules-tabs-wrapper::after {
        top: 6px;
        bottom: 6px;
    }
}

.module-tab {
    min-width: 180px;
    padding: 20px 24px;
    background: white;
    border: 2px solid rgba(0, 0, 0, 0.06);
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
}

.module-tab:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    border-color: var(--primary);
}

.module-tab.active {
    background: var(--gradient);
    border-color: var(--primary);
    box-shadow: 0 10px 40px rgba(255, 151, 96, 0.3);
    transform: translateY(-4px);
}

.module-tab.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 4px;
    background: white;
    border-radius: 2px 2px 0 0;
}

.tab-icon {
    font-size: 32px;
    flex-shrink: 0;
    transition: transform 0.3s ease;
    line-height: 1;
}

.module-tab.active .tab-icon {
    transform: scale(1.15);
}

/* Tab Image Styles (for module images) */
.tab-image {
    width: 60px;
    height: 60px;
    flex-shrink: 0;
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.tab-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.module-tab:hover .tab-image img {
    transform: scale(1.05);
}

.module-tab.active .tab-image {
    transform: scale(1.1);
    box-shadow: 0 6px 20px rgba(255, 255, 255, 0.4);
}

.module-tab.active .tab-image img {
    transform: scale(1.1);
}

.tab-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.tab-content h4 {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-dark);
    transition: color 0.3s ease;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.module-tab.active .tab-content h4 {
    color: white;
}

.tab-content span {
    font-size: 12px;
    color: var(--text-light);
    font-weight: 600;
    transition: color 0.3s ease;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.module-tab.active .tab-content span {
    color: rgba(255, 255, 255, 0.9);
}

/* Features Showcase */
.features-showcase {
    position: relative;
    min-height: 600px;
}

.module-showcase {
    display: none;
    animation: fadeInModule 0.5s ease-out;
}

.module-showcase.active {
    display: block;
}

@keyframes fadeInModule {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Features Grid Visual */
.features-grid-visual {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 24px;
}

.feature-visual-card {
    background: white;
    border-radius: 20px;
    text-align: center;
    overflow: hidden;
    border: 2px solid rgba(0, 0, 0, 0.04);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    cursor: pointer;
    position: relative;
}

.feature-visual-card.large {
    grid-column: span 2;
}

.feature-visual-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
    border-color: var(--primary);
}

.feature-visual-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--gradient);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.feature-visual-card:hover::after {
    transform: scaleX(1);
}

.feature-visual-image {
    height: 240px;
    background: linear-gradient(135deg, #fafbfc 0%, #f0f1f3 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.feature-visual-image::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.05) 0%, transparent 70%);
    animation: float 15s ease-in-out infinite;
}

.screenshot-placeholder {
    text-align: center;
    z-index: 1;
    position: relative;
}

.screenshot-icon {
    font-size: 80px;
    margin-bottom: 12px;
    filter: drop-shadow(0 10px 30px rgba(255, 151, 96, 0.3));
    animation: floatIcon 3s ease-in-out infinite;
}

@keyframes floatIcon {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}

.screenshot-placeholder span {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    opacity: 0.6;
}

.feature-visual-content {
    padding: 24px;
    background: white;
}

.feature-visual-content h4 {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-dark);
    margin-bottom: 8px;
    line-height: 1.3;
}

.feature-visual-content p {
    font-size: 14px;
    color: var(--text);
    line-height: 1.6;
    margin-bottom: 16px;
}

.feature-tags-mini {
    /* display: flex; */
    flex-wrap: wrap;
    gap: 8px; text-align: center;
}

.feature-tags-mini span {
    padding: 4px 12px;
    background: rgba(255, 151, 96, 0.1);
    color: var(--primary-dark);
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    transition: all 0.2s ease;
}

.feature-visual-card:hover .feature-tags-mini span {
    background: var(--gradient);
    color: white;
}

/* Feature Detail Modal */
.feature-detail-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 40px;
}

.feature-detail-modal.active {
    display: flex;
}

.modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(10px);
    animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.modal-content {
    position: relative;
    background: white;
    border-radius: 24px;
    max-width: 1200px;
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    animation: slideUpModal 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 40px 120px rgba(0, 0, 0, 0.3);
}

@keyframes slideUpModal {
    from {
        opacity: 0;
        transform: translateY(50px) scale(0.95);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.modal-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 48px;
    height: 48px;
    background: white;
    border: none;
    border-radius: 50%;
    font-size: 28px;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    transition: all 0.3s ease;
    color: var(--text-dark);
}

.modal-close:hover {
    transform: scale(1.1) rotate(90deg);
    background: var(--gradient);
    color: white;
}

.modal-body {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    max-height: 90vh;
    overflow-y: auto;
}

.modal-screenshot {
    background: linear-gradient(135deg, #fafbfc 0%, #f0f1f3 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px;
    position: relative;
    min-height: 500px;
}

.modal-screenshot::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.08) 0%, transparent 70%);
    animation: float 20s ease-in-out infinite;
}

.modal-screenshot-placeholder {
    text-align: center;
    z-index: 1;
}

.screenshot-icon-large {
    font-size: 120px;
    margin-bottom: 20px;
    filter: drop-shadow(0 20px 40px rgba(255, 151, 96, 0.4));
    animation: floatIcon 4s ease-in-out infinite;
}

.modal-screenshot-placeholder p {
    font-size: 16px;
    color: var(--text);
    font-weight: 600;
    opacity: 0.8;
}

.modal-info {
    padding: 60px 50px;
    background: white;
}

.modal-icon {
    font-size: 56px;
    margin-bottom: 20px;
    display: inline-block;
}

.modal-title {
    font-size: 36px;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 16px;
    letter-spacing: -1px;
    line-height: 1.2;
}

.modal-description {
    font-size: 18px;
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 32px;
}

.modal-features {
    margin-bottom: 32px;
}

.modal-features h4 {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.modal-features ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.modal-features li {
    padding: 10px 0;
    padding-left: 28px;
    position: relative;
    font-size: 15px;
    color: var(--text);
    line-height: 1.6;
}

.modal-features li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--primary);
    font-weight: 900;
    font-size: 18px;
}

.modal-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 32px;
}

.modal-tags span {
    padding: 8px 16px;
    background: rgba(255, 151, 96, 0.1);
    color: var(--primary-dark);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 700;
    transition: all 0.3s ease;
}

.modal-tags span:hover {
    background: var(--gradient);
    color: white;
    transform: translateY(-2px);
}

.btn-modal {
    width: 100%;
    padding: 18px;
    font-size: 16px;
}

/* OLD: Modules Explorer (à supprimer ou ignorer) */
.modules-explorer {
    display: flex;
    flex-direction: column;
    gap: 60px;
    align-items: center;
}

/* Circular Navigation */
.modules-nav-circle {
    position: relative;
    width: 600px;
    height: 600px;
    margin: 0 auto;
}

.circle-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 200px;
    height: 200px;
    background: var(--gradient);
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.4);
    z-index: 10;
}

.center-logo {
    width: 140px;
    height: auto;
    margin-bottom: 10px;
    filter: brightness(0) invert(1);
}

.center-text {
    color: white;
    font-size: 13px;
    font-weight: 600;
    text-align: center;
    opacity: 0.9;
}

.module-nav-item {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 50%;
    height: 50%;
    transform-origin: 0% 0%;
    transform: rotate(var(--angle));
    transition: all 0.4s ease;
}

.module-nav-btn {
    position: absolute;
    top: 0;
    right: 0;
    width: 140px;
    height: 140px;
    background: white;
    border: 3px solid rgba(0, 0, 0, 0.06);
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    transform: rotate(calc(-1 * var(--angle)));
}

.module-nav-btn:hover {
    transform: rotate(calc(-1 * var(--angle))) scale(1.1);
    border-color: var(--primary);
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.3);
}

.module-nav-item.active .module-nav-btn {
    background: var(--gradient);
    border-color: var(--primary);
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.5);
    transform: rotate(calc(-1 * var(--angle))) scale(1.15);
}

.module-nav-icon {
    font-size: 48px;
    transition: transform 0.3s ease;
}

.module-nav-item.active .module-nav-icon {
    transform: scale(1.2);
}

.module-nav-label {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-dark);
    text-align: center;
    transition: color 0.3s ease;
}

.module-nav-item.active .module-nav-label {
    color: white;
}

/* Features Panel */
.features-panel {
    width: 100%;
    min-height: 600px;
    position: relative;
}

.panel-placeholder {
    text-align: center;
    padding: 80px 40px;
    opacity: 1;
    transition: opacity 0.3s ease;
}

.features-panel.has-content .panel-placeholder {
    display: none;
}

.placeholder-icon {
    font-size: 64px;
    margin-bottom: 20px;
    animation: bounce 2s ease-in-out infinite;
}

@keyframes bounce {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-20px);
    }
}

.panel-placeholder h3 {
    font-size: 28px;
    font-weight: 800;
    color: var(--text-dark);
    margin-bottom: 12px;
}

.panel-placeholder p {
    font-size: 16px;
    color: var(--text-light);
}

/* Module Content */
.module-content {
    display: none;
    animation: fadeInUp 0.5s ease-out;
}

.module-content.active {
    display: block;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.module-content-header {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 30px 40px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.05) 0%, rgba(255, 122, 61, 0.05) 100%);
    border-radius: 20px;
    margin-bottom: 40px;
    border: 2px solid rgba(255, 151, 96, 0.1);
}

.module-content-icon {
    font-size: 56px;
    filter: drop-shadow(0 8px 20px rgba(255, 151, 96, 0.3));
}

.module-content-header h3 {
    font-size: 32px;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 6px;
}

.module-content-header p {
    font-size: 16px;
    color: var(--text);
    font-weight: 600;
}

/* Features Detail Layout */
.features-detail-layout {
    display: grid;
    grid-template-columns: 400px 1fr;
    gap: 40px;
    min-height: 500px;
}

/* Features List */
.features-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.feature-item {
    background: white;
    border: 2px solid rgba(0, 0, 0, 0.06);
    border-radius: 16px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}

.feature-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--gradient);
    transform: scaleY(0);
    transition: transform 0.3s ease;
}

.feature-item:hover {
    border-color: var(--primary);
    transform: translateX(8px);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
}

.feature-item.active {
    border-color: var(--primary);
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.03) 0%, rgba(255, 122, 61, 0.03) 100%);
    box-shadow: 0 10px 40px rgba(255, 151, 96, 0.2);
    transform: translateX(8px);
}

.feature-item.active::before {
    transform: scaleY(1);
}

.feature-item-icon {
    font-size: 36px;
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

.feature-item.active .feature-item-icon {
    transform: scale(1.15);
}

.feature-item-content {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.feature-item-content h4 {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-dark);
}

.feature-arrow {
    font-size: 20px;
    color: var(--primary);
    opacity: 0;
    transition: all 0.3s ease;
}

.feature-item:hover .feature-arrow,
.feature-item.active .feature-arrow {
    opacity: 1;
    transform: translateX(4px);
}

/* Feature Detail Panel */
.feature-detail {
    background: linear-gradient(135deg, #fafbfc 0%, #ffffff 100%);
    border-radius: 20px;
    border: 2px solid rgba(0, 0, 0, 0.04);
    padding: 50px;
    position: relative;
    min-height: 500px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.detail-placeholder {
    text-align: center;
    opacity: 1;
    transition: opacity 0.3s ease;
}

.feature-detail.has-content .detail-placeholder {
    display: none;
}

.detail-placeholder-icon {
    font-size: 56px;
    margin-bottom: 16px;
    opacity: 0.3;
    animation: pulse 2s ease-in-out infinite;
}

.detail-placeholder p {
    font-size: 16px;
    color: var(--text-light);
    font-weight: 600;
}

.detail-content {
    display: none;
    animation: fadeInRight 0.5s ease-out;
}

.detail-content.active {
    display: block;
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.detail-visual {
    font-size: 80px;
    text-align: center;
    margin-bottom: 30px;
    filter: drop-shadow(0 10px 30px rgba(255, 151, 96, 0.3));
}

.detail-content h4 {
    font-size: 32px;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 20px;
    letter-spacing: -1px;
}

.detail-content p {
    font-size: 18px;
    color: var(--text);
    line-height: 1.8;
    margin-bottom: 30px;
}

.detail-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.detail-tag {
    padding: 8px 16px;
    background: white;
    border: 2px solid rgba(255, 151, 96, 0.2);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 700;
    color: var(--primary-dark);
    transition: all 0.3s ease;
}

.detail-tag:hover {
    background: var(--gradient);
    color: white;
    border-color: var(--primary);
    transform: translateY(-2px);
}

/* Video Demo Section */
.video-demo-section {
    padding: 120px 60px;
    background: white;
    position: relative;
    overflow: hidden;
}

.video-demo-container {
    max-width: 1400px;
    margin: 0 auto;
}

.video-wrapper {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 40px 120px rgba(0, 0, 0, 0.15);
    margin-top: 60px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
    aspect-ratio: 16/9;
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: white;
    cursor: pointer;
    transition: all 0.3s ease;
}

.video-placeholder:hover {
    transform: scale(1.02);
}

.play-button {
    width: 100px;
    height: 100px;
    background: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}

.play-button:hover {
    transform: scale(1.1);
}

.play-button::after {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 15px 0 15px 25px;
    border-color: transparent transparent transparent var(--primary);
    margin-left: 5px;
}

.video-placeholder h3 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 8px;
}

.video-placeholder p {
    font-size: 16px;
    opacity: 0.9;
}

/* Integration Section */
.integration-section {
    padding: 120px 60px;
    background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
}

.integration-grid {
    max-width: 1200px;
    margin: 60px auto 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}

.integration-card {
    background: white;
    border-radius: 20px;
    padding: 40px 30px;
    text-align: center;
    border: 2px solid rgba(0, 0, 0, 0.04);
    transition: all 0.3s ease;
}

.integration-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
    border-color: var(--primary);
}

.integration-icon {
    font-size: 48px;
    margin-bottom: 16px;
}

.integration-card h4 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 8px;
}

.integration-card p {
    font-size: 14px;
    color: var(--text-light);
}

/* Pricing Section */
.pricing-section {
    padding: 120px 60px;
    background: white;
}

.pricing-grid {
    max-width: 1200px;
    margin: 60px auto 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.pricing-card {
    background: white;
    border-radius: 24px;
    padding: 50px 40px;
    border: 2px solid rgba(0, 0, 0, 0.06);
    transition: all 0.4s ease;
    position: relative;
}

.pricing-card.featured {
    border-color: var(--primary);
    box-shadow: 0 30px 80px rgba(255, 151, 96, 0.2);
    transform: scale(1.05);
}

.pricing-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.1);
}

.pricing-card.featured:hover {
    transform: scale(1.05) translateY(-8px);
}

.pricing-badge {
    position: absolute;
    top: -12px;
    right: 30px;
    background: var(--gradient);
    color: white;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.pricing-card h3 {
    font-size: 24px;
    font-weight: 800;
    color: var(--text-dark);
    margin-bottom: 12px;
}

.pricing-card .price {
    font-size: 56px;
    font-weight: 900;
    color: var(--text-dark);
    margin-bottom: 8px;
}

.pricing-card .price span {
    font-size: 20px;
    color: var(--text-light);
    font-weight: 600;
}

.pricing-description {
    font-size: 15px;
    color: var(--text);
    margin-bottom: 32px;
    padding-bottom: 32px;
    border-bottom: 2px solid rgba(0, 0, 0, 0.05);
}

.pricing-features {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 32px;
}

.pricing-feature {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    color: var(--text);
}

.pricing-feature::before {
    content: '✓';
    color: var(--primary);
    font-weight: 900;
    font-size: 18px;
}

.pricing-cta {
    width: 100%;
    padding: 16px;
    text-align: center;
}

/* FAQ Section */
.faq-section {
    padding: 120px 60px;
    background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
}

.faq-container {
    max-width: 900px;
    margin: 60px auto 0;
}

.faq-item {
    background: white;
    border-radius: 16px;
    padding: 32px;
    margin-bottom: 20px;
    border: 2px solid rgba(0, 0, 0, 0.04);
    cursor: pointer;
    transition: all 0.3s ease;
}

.faq-item:hover {
    border-color: var(--primary);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
}

.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark);
}

.faq-icon {
    font-size: 24px;
    color: var(--primary);
    transition: transform 0.3s ease;
}

.faq-item.active .faq-icon {
    transform: rotate(45deg);
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    color: var(--text);
    line-height: 1.7;
    font-size: 15px;
}

.faq-item.active .faq-answer {
    max-height: 500px;
    margin-top: 20px;
}

/* Social Proof Section */
.social-proof {
    padding: 120px 60px;
    background: var(--secondary);
    color: white;
    position: relative;
    overflow: hidden;
}

.social-proof::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.social-proof-container {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 60px;
}

.testimonial-card {
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(20px);
    border-radius: 20px;
    padding: 40px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.testimonial-card:hover {
    transform: translateY(-8px);
    background: rgba(255, 255, 255, 0.08);
}

.testimonial-stars {
    color: #ffd700;
    font-size: 20px;
    margin-bottom: 20px;
}

.testimonial-text {
    font-size: 16px;
    line-height: 1.7;
    margin-bottom: 24px;
    opacity: 0.9;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: 12px;
}

.testimonial-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 18px;
}

.testimonial-info h4 {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 4px;
}

.testimonial-info p {
    font-size: 13px;
    opacity: 0.7;
}

/* Features Grid Section */
.features-grid-section {
    padding: 120px 60px;
    background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
}

.features-grid {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin-top: 60px;
}

.feature-card {
    background: white;
    border-radius: 24px;
    padding: 50px;
    border: 2px solid rgba(0, 0, 0, 0.04);
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.feature-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.05) 0%, transparent 70%);
    border-radius: 50%;
    transform: translate(50%, -50%);
}

.feature-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.1);
    border-color: var(--primary);
}

.feature-card-icon {
    font-size: 56px;
    margin-bottom: 24px;
    display: inline-block;
    filter: drop-shadow(0 8px 20px rgba(255, 151, 96, 0.3));
}

.feature-card h3 {
    font-size: 28px;
    font-weight: 800;
    color: var(--text-dark);
    margin-bottom: 16px;
}

.feature-card p {
    font-size: 16px;
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 24px;
}

.feature-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.feature-list-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    color: var(--text);
}

.feature-list-item::before {
    content: '✓';
    color: var(--primary);
    font-weight: 900;
    font-size: 18px;
}

/* CTA Section */
.cta-section {
    padding: 150px 60px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
    position: relative;
    overflow: hidden;
}

.cta-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 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='%23ffffff' fill-opacity='0.05'%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");
}

.cta-container {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1;
}

.cta-section h2 {
    font-size: 56px;
    font-weight: 900;
    color: white;
    margin-bottom: 24px;
    letter-spacing: -2px;
}

.cta-section p {
    font-size: 20px;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 40px;
    line-height: 1.6;
}

.cta-buttons {
    display: flex;
    gap: 16px;
    justify-content: center;
}

.btn-white {
    background: white;
    color: var(--primary);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.btn-white:hover {
    transform: translateY(-4px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.3);
}

.btn-outline-white {
    background: transparent;
    color: white;
    border: 2px solid white;
}

.btn-outline-white:hover {
    background: white;
    color: var(--primary);
}

/* Footer */
.footer {
    background: var(--secondary);
    color: white;
    padding: 80px 60px 40px;
}

.footer-container {
    max-width: 1400px;
    margin: 0 auto;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
    gap: 60px;
    margin-bottom: 60px;
}

.footer-brand h3 {
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 16px;
}

.footer-brand p {
    font-size: 15px;
    line-height: 1.7;
    opacity: 0.8;
    margin-bottom: 24px;
}

.footer-column h4 {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 20px;
    opacity: 0.6;
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-link {
    color: white;
    text-decoration: none;
    font-size: 15px;
    opacity: 0.8;
    transition: all 0.2s ease;
}

.footer-link:hover {
    opacity: 1;
    color: var(--primary);
    transform: translateX(4px);
}

.footer-bottom {
    padding-top: 40px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer-bottom p {
    font-size: 14px;
    opacity: 0.6;
}

.footer-bottom-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.footer-social {
    display: flex;
    gap: 12px;
}

.footer-social-link {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    color: rgba(255, 255, 255, 0.7);
    transition: all 0.3s ease;
}

.footer-social-link:hover {
    background: var(--primary);
    color: #fff;
    transform: translateY(-3px);
}

/* ===== BREADCRUMB ===== */
.loop-breadcrumb {
    background: white;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    padding: 0 60px;
    margin-top: 85px;
}

.loop-breadcrumb-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 0;
    flex-wrap: wrap;
}

.breadcrumb-item {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-light);
    text-decoration: none;
    transition: color 0.2s ease;
}

.breadcrumb-item:hover {
    color: var(--primary);
}

.breadcrumb-home {
    display: flex;
    align-items: center;
}

.breadcrumb-home svg {
    color: var(--text-light);
    transition: color 0.2s ease;
}

.breadcrumb-home:hover svg {
    color: var(--primary);
}

.breadcrumb-sep {
    display: flex;
    align-items: center;
    color: var(--text-light);
    opacity: 0.5;
}

.breadcrumb-current {
    color: var(--text-dark);
    font-weight: 600;
}

@media (max-width: 768px) {
    .loop-breadcrumb {
        padding: 0 20px;
    }

    .breadcrumb-item {
        font-size: 12px;
    }
}

/* ===== SINGLE MODULE PAGE - PREMIUM DESIGN ===== */

/* Immersive Hero Section */
.mod-hero-immersive {
    position: relative;
    min-height: 85vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.mod-hero-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.mod-hero-bg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: blur(2px);
    transform: scale(1.05);
}

.mod-hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(26, 26, 46, 0.92) 0%, rgba(22, 33, 62, 0.88) 100%);
}

.mod-hero-gradient {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
}

/* Decorative Floating Shapes */
.mod-hero-shapes {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    overflow: hidden;
}

.mod-shape {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.15) 0%, rgba(255, 122, 61, 0.1) 100%);
    filter: blur(1px);
}

.mod-shape-1 {
    width: 400px;
    height: 400px;
    top: -100px;
    right: -100px;
    animation: float-slow 20s ease-in-out infinite;
}

.mod-shape-2 {
    width: 250px;
    height: 250px;
    bottom: 10%;
    left: 5%;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.05) 100%);
    animation: float-medium 15s ease-in-out infinite reverse;
}

.mod-shape-3 {
    width: 150px;
    height: 150px;
    top: 40%;
    right: 15%;
    background: linear-gradient(135deg, rgba(255, 200, 150, 0.12) 0%, rgba(255, 151, 96, 0.08) 100%);
    animation: float-fast 12s ease-in-out infinite;
}

.mod-shape-ring {
    width: 500px;
    height: 500px;
    bottom: -200px;
    right: 20%;
    background: transparent;
    border: 2px solid rgba(255, 151, 96, 0.08);
    animation: rotate-slow 30s linear infinite;
}

@keyframes float-slow {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-30px) rotate(5deg); }
}

@keyframes float-medium {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-20px) scale(1.05); }
}

@keyframes float-fast {
    0%, 100% { transform: translateY(0) translateX(0); }
    50% { transform: translateY(-15px) translateX(10px); }
}

@keyframes rotate-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Hero Content */
.mod-hero-content {
    position: relative;
    z-index: 10;
    width: 100%;
    padding: 60px;
}

.mod-hero-inner {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.mod-hero-context {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 100px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    margin-bottom: 24px;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}

.mod-hero-context:hover {
    background: rgba(255, 255, 255, 0.2);
    color: white;
}

.mod-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.2) 0%, rgba(255, 122, 61, 0.15) 100%);
    border: 1px solid rgba(255, 151, 96, 0.3);
    border-radius: 100px;
    color: #ffb088;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 24px;
    backdrop-filter: blur(10px);
}

.mod-hero-badge svg {
    color: var(--primary);
}

.mod-hero-inner h1 {
    font-size: 64px;
    font-weight: 900;
    color: white;
    line-height: 1.1;
    margin: 0 0 24px 0;
    text-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
}

.mod-hero-excerpt {
    font-size: 20px;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.7;
    margin: 0 0 40px 0;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

/* Hero Stats */
.mod-hero-stats {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 40px;
}

.mod-hero-stat {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 24px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 16px;
    backdrop-filter: blur(10px);
}

.mod-stat-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 12px;
    color: white;
}

.mod-stat-content {
    display: flex;
    flex-direction: column;
}

.mod-stat-number {
    font-size: 24px;
    font-weight: 800;
    color: white;
    line-height: 1;
}

.mod-stat-label {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 4px;
}

/* Hero Actions */
.mod-hero-actions {
    display: flex;
    justify-content: center;
    gap: 16px;
}

.mod-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 28px;
    border-radius: 100px;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.mod-action-primary {
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    color: white;
    box-shadow: 0 8px 30px rgba(255, 122, 61, 0.4);
}

.mod-action-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(255, 122, 61, 0.5);
}

.mod-action-secondary {
    background: rgba(255, 255, 255, 0.1);
    border: 2px solid rgba(255, 255, 255, 0.3);
    color: white;
    backdrop-filter: blur(10px);
}

.mod-action-secondary:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.5);
}

/* Quick Navigation Pills */
.mod-quick-nav {
    background: white;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    padding: 0;
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

.mod-quick-nav-inner {
    max-width: 100%;
    overflow: hidden;
}

.mod-quick-nav-scroll {
    display: flex;
    gap: 8px;
    padding: 16px 60px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.mod-quick-nav-scroll::-webkit-scrollbar {
    display: none;
}

.mod-quick-pill {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background: #f8f9fa;
    border-radius: 100px;
    text-decoration: none;
    white-space: nowrap;
    scroll-snap-align: start;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.mod-quick-pill:hover {
    background: #f0f1f3;
}

.mod-quick-pill.active {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.05) 100%);
    border-color: var(--primary);
}

.mod-pill-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--pill-color, var(--primary));
    box-shadow: 0 2px 8px rgba(255, 122, 61, 0.3);
}

.mod-quick-pill.active .mod-pill-dot {
    box-shadow: 0 0 0 4px rgba(255, 151, 96, 0.2);
}

.mod-pill-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
}

/* Content Magazine Layout */
.mod-content-magazine {
    padding: 80px 60px;
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%);
}

.mod-content-layout {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 60px;
}

/* Sidebar */
.mod-sidebar {
    position: relative;
}

.mod-sidebar-sticky {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* TOC */
.mod-toc {
    background: white;
    border-radius: 20px;
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.mod-toc h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 16px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.mod-toc h4 svg {
    color: var(--primary);
}

.mod-toc-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mod-toc-item {
    display: block;
    padding: 10px 14px;
    font-size: 14px;
    color: var(--text);
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.2s ease;
    border-left: 3px solid transparent;
}

.mod-toc-item:hover {
    background: #f8f9fa;
    color: var(--text-dark);
}

.mod-toc-item.active {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.05) 100%);
    color: var(--primary);
    border-left-color: var(--primary);
    font-weight: 600;
}

.mod-toc-sub {
    padding-left: 24px;
    font-size: 13px;
}

.mod-toc-empty {
    font-size: 13px;
    color: var(--text-light);
    font-style: italic;
}

/* Sidebar Features */
.mod-sidebar-features {
    background: white;
    border-radius: 20px;
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.mod-sidebar-features h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 16px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.mod-sidebar-features h4 svg {
    color: var(--primary);
}

.mod-sidebar-features-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.mod-sidebar-feature {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    font-size: 13px;
    color: var(--text);
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.2s ease;
}

.mod-sidebar-feature:hover {
    background: #f8f9fa;
    color: var(--primary);
}

.mod-sidebar-feature svg {
    color: var(--primary);
    opacity: 0;
    transform: translateX(-4px);
    transition: all 0.2s ease;
}

.mod-sidebar-feature:hover svg {
    opacity: 1;
    transform: translateX(0);
}

.mod-sidebar-more {
    display: inline-block;
    margin-top: 8px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.05) 100%);
    border-radius: 100px;
    transition: all 0.2s ease;
}

.mod-sidebar-more:hover {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.2) 0%, rgba(255, 122, 61, 0.1) 100%);
}

/* Sidebar CTA */
.mod-sidebar-cta {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 20px;
    padding: 28px 24px;
    text-align: center;
}

.mod-sidebar-cta-icon {
    font-size: 36px;
    display: block;
    margin-bottom: 12px;
}

.mod-sidebar-cta h5 {
    font-size: 18px;
    font-weight: 800;
    color: white;
    margin: 0 0 8px 0;
}

.mod-sidebar-cta p {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 20px 0;
    line-height: 1.5;
}

.mod-sidebar-cta-btn {
    display: inline-block;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    color: white;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 100px;
    transition: all 0.3s ease;
}

.mod-sidebar-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255, 122, 61, 0.4);
}

/* Sidebar Users (Qui utilise ce module) */
.mod-sidebar-users {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 16px;
    padding: 20px;
    margin-top: 20px;
}

.mod-sidebar-users h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: white;
    margin: 0 0 16px 0;
}

.mod-sidebar-users h4 svg {
    color: var(--primary);
}

.mod-sidebar-users-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mod-sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    text-decoration: none;
    transition: all 0.3s ease;
    border-left: 3px solid transparent;
}

.mod-sidebar-user:hover {
    background: rgba(255, 255, 255, 0.15);
    border-left-color: var(--user-from);
    transform: translateX(4px);
}

.mod-sidebar-user-icon {
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, var(--user-from) 0%, var(--user-to) 100%);
    border-radius: 8px;
}

.mod-sidebar-user-name {
    font-size: 13px;
    font-weight: 600;
    color: white;
}

/* Feature Sidebar Users - Same style as module */
.feature-sidebar-users {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 16px;
    padding: 20px;
    margin-top: 20px;
}

.feature-sidebar-users h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: white;
    margin: 0 0 16px 0;
}

.feature-sidebar-users h4 svg {
    color: var(--primary);
}

.feature-sidebar-users-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.feature-sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    text-decoration: none;
    transition: all 0.3s ease;
    border-left: 3px solid transparent;
}

.feature-sidebar-user:hover {
    background: rgba(255, 255, 255, 0.15);
    border-left-color: var(--user-from);
    transform: translateX(4px);
}

.feature-sidebar-user-icon {
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, var(--user-from) 0%, var(--user-to) 100%);
    border-radius: 8px;
}

.feature-sidebar-user-name {
    font-size: 13px;
    font-weight: 600;
    color: white;
}

/* Main Content Area */
.mod-main-content {
    min-width: 0;
}

.mod-article-content,
.kf-description {
    background: white;
    border-radius: 24px;
    padding: 48px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.06);
}

/* ===== MODULE DESCRIPTION HTML STRUCTURE ===== */
/* User's specific HTML classes for rich content */

/* Module Intro Section */
.mod-article-content .module-intro {
    margin-bottom: 48px;
    padding-bottom: 48px;
    border-bottom: 2px solid #f0f1f3;
}

.mod-article-content .lead-paragraph {
    font-size: 20px;
    line-height: 1.8;
    color: var(--text-dark);
    font-weight: 500;
    margin: 0;
    position: relative;
    padding-left: 24px;
    border-left: 4px solid var(--primary);
}

/* Module Sections */
.mod-article-content .module-section {
    margin-bottom: 48px;
    padding: 32px;
    background: linear-gradient(135deg, #fafbfc 0%, #f5f6f8 100%);
    border-radius: 20px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.mod-article-content .module-section:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.mod-article-content .module-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 4px 0 0 4px;
}

/* Section Title */
.mod-article-content .section-title {
    font-size: 22px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 20px 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.mod-article-content .section-title::before {
    content: '◆';
    color: var(--primary);
    font-size: 14px;
}

/* Section Content & Detail */
.mod-article-content .section-content {
    font-size: 16px;
    line-height: 1.8;
    color: var(--text);
    margin: 0 0 16px 0;
}

.mod-article-content .section-detail {
    font-size: 15px;
    line-height: 1.7;
    color: var(--text-light);
    margin: 0;
    padding: 16px 20px;
    background: rgba(255, 255, 255, 0.7);
    border-radius: 12px;
    border-left: 3px solid rgba(255, 151, 96, 0.3);
}

/* Feature Links */
.mod-article-content .feature-link {
    color: var(--primary);
    text-decoration: none;
    font-weight: 600;
    position: relative;
    padding-bottom: 2px;
    transition: all 0.2s ease;
}

.mod-article-content .feature-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, var(--primary), #ff7a3d);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.3s ease;
}

.mod-article-content .feature-link:hover {
    color: #ff7a3d;
}

.mod-article-content .feature-link:hover::after {
    transform: scaleX(1);
    transform-origin: left;
}

/* Module Links */
.mod-article-content .module-link {
    color: #1a1a2e;
    text-decoration: none;
    font-weight: 700;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.15) 0%, rgba(255, 122, 61, 0.1) 100%);
    padding: 4px 12px;
    border-radius: 6px;
    transition: all 0.2s ease;
}

.mod-article-content .module-link:hover {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.25) 0%, rgba(255, 122, 61, 0.2) 100%);
    color: var(--primary);
}

/* Module Connections Section */
.mod-article-content .module-connections {
    margin-top: 48px;
    padding: 36px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 24px;
    position: relative;
    overflow: hidden;
}

.mod-article-content .module-connections::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.15) 0%, transparent 70%);
    border-radius: 50%;
}

.mod-article-content .module-connections::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: -10%;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(255, 122, 61, 0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.mod-article-content .connections-title {
    position: relative;
    z-index: 1;
    font-size: 20px;
    font-weight: 800;
    color: white;
    margin: 0 0 16px 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.mod-article-content .connections-title::before {
    content: '🔗';
    font-size: 24px;
}

.mod-article-content .connections-content {
    position: relative;
    z-index: 1;
    font-size: 16px;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.85);
    margin: 0;
}

.mod-article-content .connections-content .module-link {
    background: rgba(255, 255, 255, 0.15);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.mod-article-content .connections-content .module-link:hover {
    background: rgba(255, 255, 255, 0.25);
    color: #ffb088;
}

/* Section Variants with unique accents */
.mod-article-content .section-catalogues::before { background: linear-gradient(180deg, #ff9760 0%, #ff7a3d 100%); }
.mod-article-content .section-inscription-ligne::before { background: linear-gradient(180deg, #4CAF50 0%, #2E7D32 100%); }
.mod-article-content .section-pipeline::before { background: linear-gradient(180deg, #2196F3 0%, #1565C0 100%); }
.mod-article-content .section-devis::before { background: linear-gradient(180deg, #9C27B0 0%, #6A1B9A 100%); }
.mod-article-content .section-marque-blanche::before { background: linear-gradient(180deg, #607D8B 0%, #37474F 100%); }
.mod-article-content .section-commissions::before { background: linear-gradient(180deg, #FF5722 0%, #D84315 100%); }

/* ===== KF-DESCRIPTION STRUCTURE (Key Features & User Spaces) ===== */
/* Same style as mod-article-content but for .kf-description content */

.kf-description .kf-intro,
.kf-description > p:first-child {
    font-size: 18px;
    line-height: 1.8;
    color: var(--text-dark);
    font-weight: 500;
    margin: 0 0 32px 0;
    padding-left: 20px;
    border-left: 4px solid var(--primary);
}

.kf-description .kf-section {
    margin-bottom: 32px;
    padding: 28px;
    background: linear-gradient(135deg, #fafbfc 0%, #f5f6f8 100%);
    border-radius: 16px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.kf-description .kf-section:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
}

.kf-description .kf-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 4px 0 0 4px;
}

.kf-description .kf-section-title,
.kf-description .kf-section h3 {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 16px 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.kf-description .kf-section-title::before,
.kf-description .kf-section h3::before {
    content: '◆';
    color: var(--primary);
    font-size: 12px;
}

.kf-description .kf-section p {
    font-size: 15px;
    line-height: 1.8;
    color: var(--text);
    margin: 0 0 12px 0;
}

.kf-description .kf-section p:last-child {
    margin-bottom: 0;
}

.kf-description .kf-list {
    list-style: none;
    padding: 0;
    margin: 16px 0 0 0;
}

.kf-description .kf-list li {
    position: relative;
    padding-left: 28px;
    margin-bottom: 10px;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text);
}

.kf-description .kf-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    width: 8px;
    height: 8px;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 50%;
}

.kf-description .kf-list li:last-child {
    margin-bottom: 0;
}

/* Remove nested kf-description box styling */
.kf-description .kf-description {
    background: transparent;
    padding: 0;
    box-shadow: none;
    border-radius: 0;
}

/* ===== FEATURED FEATURES SHOWCASE ===== */
.mod-features-showcase {
    padding: 80px 60px;
    background: linear-gradient(180deg, #fff8f5 0%, #ffffff 100%);
}

.mod-features-showcase-inner {
    max-width: 1400px;
    margin: 0 auto;
}

.mod-section-header {
    text-align: center;
    margin-bottom: 48px;
}

.mod-section-header-content {
    max-width: 600px;
    margin: 0 auto;
}

.mod-section-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.15) 0%, rgba(255, 122, 61, 0.1) 100%);
    border: 1px solid rgba(255, 151, 96, 0.2);
    border-radius: 100px;
    color: var(--primary);
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 20px;
}

.mod-section-header h2 {
    font-size: 40px;
    font-weight: 900;
    color: var(--text-dark);
    margin: 0 0 16px 0;
    line-height: 1.2;
}

.mod-section-header p {
    font-size: 18px;
    color: var(--text);
    margin: 0;
    line-height: 1.6;
}

.mod-section-header-compact {
    text-align: left;
    margin-bottom: 32px;
}

.mod-section-header-compact h2 {
    font-size: 32px;
}

/* Bento Grid for Featured Features */
.mod-features-bento {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.mod-feature-card {
    background: white;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.mod-feature-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.2);
}

.mod-feature-large {
    grid-column: span 2;
    grid-row: span 2;
}

.mod-feature-card-link {
    display: block;
    text-decoration: none;
    height: 100%;
}

.mod-feature-card-media {
    position: relative;
    height: 200px;
    overflow: hidden;
}

.mod-feature-large .mod-feature-card-media {
    height: 320px;
}

.mod-feature-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.mod-feature-card:hover .mod-feature-card-media img {
    transform: scale(1.1);
}

.mod-feature-card-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.6) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.mod-feature-card:hover .mod-feature-card-overlay {
    opacity: 1;
}

.mod-feature-card-badge {
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 8px 16px;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    color: white;
    font-size: 12px;
    font-weight: 700;
    border-radius: 100px;
    box-shadow: 0 4px 15px rgba(255, 122, 61, 0.4);
}

.mod-feature-card-body {
    padding: 24px;
}

.mod-feature-large .mod-feature-card-body {
    padding: 32px;
}

.mod-feature-card-body h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 12px 0;
    line-height: 1.4;
}

.mod-feature-large .mod-feature-card-body h3 {
    font-size: 24px;
}

.mod-feature-card-body p {
    font-size: 14px;
    color: var(--text);
    line-height: 1.6;
    margin: 0 0 16px 0;
}

.mod-feature-large .mod-feature-card-body p {
    font-size: 16px;
}

.mod-feature-card-action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--primary);
    transition: gap 0.3s ease;
}

.mod-feature-card:hover .mod-feature-card-action {
    gap: 12px;
}

/* ===== OTHER FEATURES GRID ===== */
.mod-other-features {
    padding: 80px 60px;
    background: #f8f9fa;
}

.mod-other-features-inner {
    max-width: 1400px;
    margin: 0 auto;
}

.mod-features-masonry {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.mod-feature-tile {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: white;
    border-radius: 16px;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.mod-feature-tile:hover {
    border-color: rgba(255, 151, 96, 0.3);
    transform: translateX(6px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
}

.mod-feature-tile-image {
    width: 72px;
    height: 72px;
    border-radius: 14px;
    overflow: hidden;
    flex-shrink: 0;
}

.mod-feature-tile-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.mod-feature-tile:hover .mod-feature-tile-image img {
    transform: scale(1.1);
}

.mod-feature-tile-content {
    flex: 1;
    min-width: 0;
}

.mod-feature-tile-content h4 {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 6px 0;
    line-height: 1.3;
}

.mod-feature-tile-content p {
    font-size: 13px;
    color: var(--text);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mod-feature-tile-arrow {
    color: var(--primary);
    opacity: 0;
    transform: translateX(-8px);
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.mod-feature-tile:hover .mod-feature-tile-arrow {
    opacity: 1;
    transform: translateX(0);
}

/* ===== NAVIGATION SECTION ===== */
.mod-navigation-section {
    padding: 80px 60px;
    background: white;
}

.mod-navigation-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.mod-nav-header {
    text-align: center;
    margin-bottom: 48px;
}

.mod-nav-header h3 {
    font-size: 32px;
    font-weight: 900;
    color: var(--text-dark);
    margin: 0 0 12px 0;
}

.mod-nav-header p {
    font-size: 16px;
    color: var(--text);
    margin: 0;
}

.mod-nav-cards {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 24px;
    align-items: center;
}

.mod-nav-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 20px;
    background: #f8f9fa;
    border-radius: 20px;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all 0.3s ease;
    overflow: hidden;
}

.mod-nav-card:hover {
    background: white;
    border-color: var(--card-color, var(--primary));
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

.mod-nav-card-image {
    width: 80px;
    height: 80px;
    border-radius: 14px;
    overflow: hidden;
    flex-shrink: 0;
}

.mod-nav-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mod-nav-card-content {
    flex: 1;
    min-width: 0;
}

.mod-nav-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.mod-nav-label svg {
    color: var(--primary);
}

.mod-nav-card h4 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0;
    line-height: 1.3;
}

.mod-nav-prev {
    flex-direction: row;
}

.mod-nav-next {
    flex-direction: row-reverse;
    text-align: right;
}

.mod-nav-next .mod-nav-label {
    justify-content: flex-end;
}

.mod-nav-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 120px;
    background: #f0f1f3;
    color: var(--text-light);
    font-size: 14px;
}

.mod-nav-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 24px 32px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.05) 100%);
    border: 2px solid rgba(255, 151, 96, 0.2);
    border-radius: 20px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.mod-nav-center:hover {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.15) 0%, rgba(255, 122, 61, 0.1) 100%);
    border-color: var(--primary);
    transform: scale(1.05);
}

.mod-nav-center-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 16px;
    color: white;
}

.mod-nav-center span {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
}

/* ===== CTA SECTION ===== */
.mod-cta-section {
    padding: 100px 60px;
    background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%);
}

.mod-cta-inner {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
    padding: 60px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 32px;
    text-align: center;
    overflow: hidden;
}

.mod-cta-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.mod-cta-pattern {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: radial-gradient(rgba(255, 151, 96, 0.1) 1px, transparent 1px);
    background-size: 20px 20px;
}

.mod-cta-glow {
    position: absolute;
    top: -50%;
    right: -20%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.2) 0%, transparent 70%);
    border-radius: 50%;
}

.mod-cta-content {
    position: relative;
    z-index: 1;
    margin-bottom: 32px;
}

.mod-cta-badge {
    display: inline-block;
    padding: 10px 20px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 100px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 20px;
}

.mod-cta-content h3 {
    font-size: 36px;
    font-weight: 900;
    color: white;
    margin: 0 0 16px 0;
    line-height: 1.3;
}

.mod-cta-content p {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
    line-height: 1.6;
}

.mod-cta-actions {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: center;
    gap: 16px;
}

.mod-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 32px;
    border-radius: 100px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.mod-cta-btn-primary {
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    color: white;
    box-shadow: 0 8px 30px rgba(255, 122, 61, 0.4);
}

.mod-cta-btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(255, 122, 61, 0.5);
}

.mod-cta-btn-secondary {
    background: rgba(255, 255, 255, 0.1);
    border: 2px solid rgba(255, 255, 255, 0.3);
    color: white;
}

.mod-cta-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.5);
}

/* ===== MODULE PAGE RESPONSIVE ===== */
@media (max-width: 1200px) {
    .mod-content-layout {
        grid-template-columns: 280px 1fr;
        gap: 40px;
    }

    .mod-features-bento {
        grid-template-columns: repeat(2, 1fr);
    }

    .mod-feature-large {
        grid-column: span 2;
        grid-row: span 1;
    }

    .mod-features-masonry {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 1024px) {
    .mod-hero-inner h1 {
        font-size: 52px;
    }

    .mod-hero-stats {
        gap: 24px;
    }

    .mod-content-layout {
        grid-template-columns: 1fr;
    }

    .mod-sidebar {
        order: 2;
    }

    .mod-sidebar-sticky {
        position: relative;
        top: 0;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 16px;
    }

    .mod-toc,
    .mod-sidebar-features,
    .mod-sidebar-cta {
        flex: 1;
        min-width: 280px;
    }

    .mod-nav-cards {
        grid-template-columns: 1fr 1fr;
    }

    .mod-nav-center {
        grid-column: span 2;
        order: -1;
        flex-direction: row;
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .mod-hero-immersive {
        min-height: 100vh;
    }

    .mod-hero-content {
        padding: 40px 20px;
    }

    .mod-hero-inner h1 {
        font-size: 36px;
    }

    .mod-hero-excerpt {
        font-size: 16px;
    }

    .mod-hero-stats {
        flex-direction: column;
        gap: 12px;
    }

    .mod-hero-stat {
        justify-content: center;
    }

    .mod-hero-actions {
        flex-direction: column;
    }

    .mod-action-btn {
        justify-content: center;
    }

    .mod-quick-nav-scroll {
        padding: 12px 20px;
    }

    .mod-quick-pill {
        padding: 10px 16px;
    }

    .mod-pill-title {
        font-size: 13px;
    }

    .mod-content-magazine {
        padding: 40px 20px;
    }

    .mod-article-content {
        padding: 28px 20px;
    }

    .mod-article-content .module-section {
        padding: 24px 20px;
        margin-bottom: 32px;
    }

    .mod-article-content .section-title {
        font-size: 18px;
    }

    .mod-article-content .lead-paragraph {
        font-size: 17px;
        padding-left: 16px;
    }

    .mod-article-content .module-connections {
        padding: 28px 20px;
    }

    .mod-features-showcase,
    .mod-other-features,
    .mod-navigation-section {
        padding: 60px 20px;
    }

    .mod-section-header h2 {
        font-size: 28px;
    }

    .mod-features-bento {
        grid-template-columns: 1fr;
    }

    .mod-feature-large {
        grid-column: span 1;
    }

    .mod-feature-card-media {
        height: 180px;
    }

    .mod-feature-large .mod-feature-card-media {
        height: 200px;
    }

    .mod-features-masonry {
        grid-template-columns: 1fr;
    }

    .mod-nav-cards {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .mod-nav-center {
        grid-column: span 1;
    }

    .mod-nav-card {
        padding: 16px;
    }

    .mod-nav-card-image {
        width: 60px;
        height: 60px;
    }

    .mod-nav-card h4 {
        font-size: 16px;
    }

    .mod-nav-next {
        flex-direction: row;
        text-align: left;
    }

    .mod-nav-next .mod-nav-label {
        justify-content: flex-start;
    }

    .mod-cta-section {
        padding: 60px 20px;
    }

    .mod-cta-inner {
        padding: 40px 24px;
    }

    .mod-cta-content h3 {
        font-size: 26px;
    }

    .mod-cta-content p {
        font-size: 16px;
    }

    .mod-cta-actions {
        flex-direction: column;
    }

    .mod-cta-btn {
        justify-content: center;
    }

    /* Sidebar mobile */
    .mod-sidebar-sticky {
        flex-direction: column;
    }

    .mod-toc,
    .mod-sidebar-features,
    .mod-sidebar-cta {
        min-width: 100%;
    }

    /* Hero shapes mobile */
    .mod-shape-1 {
        width: 200px;
        height: 200px;
    }

    .mod-shape-2 {
        width: 150px;
        height: 150px;
    }

    .mod-shape-3 {
        width: 100px;
        height: 100px;
    }

    .mod-shape-ring {
        width: 300px;
        height: 300px;
    }
}



/* ===== SINGLE FEATURE PAGE ===== */
.feature-hero {
    padding: 40px 60px 60px;
    background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%);
}

.feature-hero-inner {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.feature-hero-breadcrumb {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: white;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
    margin-bottom: 24px;
    transition: all 0.3s ease;
}

.feature-hero-breadcrumb:hover {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

.feature-hero h1 {
    font-size: 48px;
    font-weight: 900;
    color: var(--text-dark);
    line-height: 1.2;
    margin-bottom: 20px;
}

.feature-hero-excerpt {
    font-size: 20px;
    color: var(--text);
    line-height: 1.6;
    margin-bottom: 24px;
}

.feature-hero-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
}

.feature-hero-tags span {
    padding: 8px 16px;
    background: rgba(255, 151, 96, 0.1);
    color: var(--primary);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
}

/* Feature Detail Section */
.feature-detail-section {
    padding: 60px;
    background: white;
}

.feature-detail-container {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 500px 1fr;
    gap: 60px;
}

/* Side Navigation */
.feature-side-nav {
    position: sticky;
    top: 120px;
    height: fit-content;
    max-height: calc(100vh - 140px);
    overflow-y: auto;
    background: #f8f9fa;
    border-radius: 20px;
    padding: 24px;
}

.feature-side-nav-header {
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.feature-side-nav-header h4 {
    font-size: 18px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 4px 0;
}

.feature-side-nav-header span {
    font-size: 13px;
    color: var(--text-light);
}

.feature-side-nav-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.feature-side-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: white;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.feature-side-nav-item:hover {
    border-color: var(--primary);
    transform: translateX(4px);
}

.feature-side-nav-item.active {
    background: var(--gradient);
    border-color: transparent;
}

.feature-side-nav-item.active .feature-side-nav-title {
    color: white;
}

.feature-side-nav-img {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}

.feature-side-nav-title {
    flex: 1;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.feature-side-nav-current {
    font-size: 10px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.8);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Main Content */
.feature-main-content {
    max-width: 800px;
}

.feature-main-image {
    margin-bottom: 40px;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}

.feature-main-image img {
    width: 100%;
    height: auto;
    display: block;
}

.feature-content-body {
    font-size: 18px;
    line-height: 1.8;
    color: var(--text);
    margin-bottom: 40px;
}

.feature-content-body p {
    margin-bottom: 20px;
}

.feature-content-body h2,
.feature-content-body h3,
.feature-content-body h4 {
    color: var(--text-dark);
    margin: 40px 0 20px;
}

.feature-details-box {
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 20px;
    padding: 32px;
    margin-bottom: 40px;
}

.feature-details-box h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 20px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 24px 0;
}

.feature-details-box h4 svg {
    color: var(--primary);
}

.feature-details-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.feature-details-box li {
    position: relative;
    padding-left: 28px;
    font-size: 16px;
    color: var(--text);
    line-height: 1.6;
}

.feature-details-box li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #10b981;
    font-weight: bold;
}

.feature-screenshot-section {
    margin-bottom: 40px;
}

.feature-screenshot-section h4 {
    font-size: 24px;
    font-weight: 800;
    color: var(--text-dark);
    margin-bottom: 24px;
}

.feature-screenshot-wrapper {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}

.feature-screenshot-wrapper img {
    width: 100%;
    height: auto;
    display: block;
}

.feature-cta-box {
    background: var(--gradient);
    border-radius: 24px;
    padding: 48px;
    text-align: center;
    margin-top: 60px;
}

.feature-cta-box h3 {
    font-size: 28px;
    font-weight: 900;
    color: white;
    margin: 0 0 12px 0;
}

.feature-cta-box p {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 28px 0;
}

.feature-cta-buttons {
    display: flex;
    gap: 16px;
    justify-content: center;
}

.feature-cta-box .btn-primary {
    background: white;
    color: var(--primary-dark);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.feature-cta-box .btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.25);
}

.feature-cta-box .btn-secondary {
    background: rgba(255, 255, 255, 0.2);
    color: white;
    border-color: rgba(255, 255, 255, 0.3);
}

.feature-cta-box .btn-secondary:hover {
    background: rgba(255, 255, 255, 0.3);
    border-color: white;
}

/* Mobile Features Carousel */
.feature-more-mobile {
    display: none;
    padding: 40px 20px;
    background: #f8f9fa;
}

.feature-more-mobile-inner {
    max-width: 100%;
}

.feature-more-mobile h3 {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 20px 0;
}

.feature-more-scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 12px;
    -webkit-overflow-scrolling: touch;
}

.feature-more-scroll::-webkit-scrollbar {
    height: 4px;
}

.feature-more-scroll::-webkit-scrollbar-thumb {
    background: var(--primary);
    border-radius: 4px;
}

.feature-more-card {
    flex: 0 0 auto;
    width: 140px;
    background: white;
    border-radius: 12px;
    padding: 12px;
    text-decoration: none;
    text-align: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

.feature-more-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.feature-more-card img {
    width: 60px;
    height: 60px;
    border-radius: 10px;
    object-fit: cover;
    margin-bottom: 10px;
}

.feature-more-card span {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-dark);
    line-height: 1.3;
}

/* Single Feature Responsive */
@media (max-width: 1200px) {
    .feature-detail-container {
        grid-template-columns: 350px 1fr;
        gap: 40px;
    }
}

@media (max-width: 1024px) {
    .feature-detail-container {
        grid-template-columns: 280px 1fr;
        gap: 30px;
    }

    .feature-hero h1 {
        font-size: 40px;
    }
}

@media (max-width: 768px) {
    .feature-hero {
        padding: 30px 20px 40px;
    }

    .feature-hero h1 {
        font-size: 32px;
    }

    .feature-hero-excerpt {
        font-size: 16px;
    }

    .feature-detail-section {
        padding: 40px 20px;
    }

    .feature-detail-container {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .feature-side-nav {
        display: none;
    }

    .feature-more-mobile {
        display: block;
    }

    .feature-main-content {
        max-width: 100%;
    }

    .feature-content-body {
        font-size: 16px;
    }

    .feature-details-box {
        padding: 24px;
    }

    .feature-cta-box {
        padding: 32px 24px;
    }

    .feature-cta-box h3 {
        font-size: 22px;
    }

    .feature-cta-buttons {
        flex-direction: column;
    }
}

/* Animations */
@keyframes float {

    0%,
    100% {
        transform: translate(0, 0) rotate(0deg);
    }

    33% {
        transform: translate(30px, -30px) rotate(5deg);
    }

    66% {
        transform: translate(-20px, 20px) rotate(-5deg);
    }
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.5;
        transform: scale(1.2);
    }
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive */
@media (max-width: 1200px) {
    .features-grid {
        grid-template-columns: 1fr;
    }

    .modules-nav-circle {
        width: 500px;
        height: 500px;
    }

    .circle-center {
        width: 160px;
        height: 160px;
    }

    .center-logo {
        width: 110px;
    }

    .module-nav-btn {
        width: 110px;
        height: 110px;
    }

    .module-nav-icon {
        font-size: 36px;
    }

    .module-nav-label {
        font-size: 11px;
    }

    .features-detail-layout {
        grid-template-columns: 350px 1fr;
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .nav-menu {
        display: none;
    }

    .hero h1 {
        font-size: 42px;
    }

    .hero-stats {
        flex-direction: column;
        gap: 30px;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    /* Mobile Modules */
    .modules-nav-circle {
        width: 100%;
        height: auto;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
        padding: 20px;
    }

    .circle-center {
        display: none;
    }

    .module-nav-item {
        position: static;
        width: 100%;
        height: auto;
        transform: none !important;
    }

    .module-nav-btn {
        position: static;
        width: 100%;
        height: 120px;
        transform: none !important;
    }

    .module-nav-btn:hover {
        transform: scale(1.05) !important;
    }

    .module-nav-item.active .module-nav-btn {
        transform: scale(1.05) !important;
    }

    .features-detail-layout {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .feature-detail {
        padding: 30px;
    }

    .detail-visual {
        font-size: 60px;
    }

    .detail-content h4 {
        font-size: 24px;
    }

    .detail-content p {
        font-size: 16px;
    }

    .section-header h2 {
        font-size: 36px;
    }

    .section-header p {
        font-size: 16px;
    }

    .cta-section h2 {
        font-size: 36px;
    }

    .cta-buttons {
        flex-direction: column;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
    }
}

    /* ===== AMÉLIORATIONS GÉNÉRALES ===== */

    /* Empêcher le scroll horizontal */
    html,
    body {
overflow-x: hidden;
max-width: 100vw;
    }

    /* Améliorer les grilles responsive */
    .features-grid-visual,
    .features-grid,
    .integration-grid,
    .pricing-grid,
    .testimonials-grid {
width: 100%;
    }

    /* ===== TABLET (1024px et moins) ===== */
    @media (max-width: 1024px) {

/* Navigation */
.nav-container {
    padding: 0 40px;
}

/* Hero */
.hero {
    padding: 160px 40px 100px;
}

.hero h1 {
    font-size: 56px;
    letter-spacing: -2px;
}

.hero p {
    font-size: 18px;
}

.hero-stats {
    gap: 40px;
}

/* Sections générales */
.modules-section,
.features-grid-section,
.video-demo-section,
.integration-section,
.pricing-section,
.faq-section,
.social-proof,
.cta-section {
    padding: 80px 40px;
}

/* Titres sections */
.section-header h2 {
    font-size: 42px;
}

.section-header p {
    font-size: 18px;
}

/* Modules - supprimer span 2 colonnes sur tablet */
.feature-visual-card.large {
    grid-column: span 1;
}

/* Modal */
.modal-body {
    grid-template-columns: 1fr;
}

.modal-screenshot {
    min-height: 400px;
    padding: 40px;
}

.modal-info {
    padding: 40px;
}

/* CTA */
.cta-section {
    padding: 100px 40px;
}

.cta-section h2 {
    font-size: 42px;
}

/* Footer */
.footer {
    padding: 60px 40px 30px;
}
    }

    /* ===== MOBILE OPTIMIZATIONS FOR MODULE TABS ===== */
@media (max-width: 768px) {
    /* Tabs container optimizations */
    .modules-tabs-wrapper {
        gap: 8px;
        margin-bottom: 30px;
    }

    .modules-tabs {
        padding: 12px;
        gap: 8px;
        border-radius: 16px;
        /* Améliorer le scroll tactile */
        -webkit-overflow-scrolling: touch;
        /* Scrollbar visible mais stylisée sur mobile */
        scrollbar-width: thin;
        scrollbar-color: rgba(255, 151, 96, 0.3) rgba(0, 0, 0, 0.05);
    }

    .modules-tabs::-webkit-scrollbar {
        display: block;
        height: 4px;
    }

    .modules-tabs::-webkit-scrollbar-track {
        background: rgba(0, 0, 0, 0.03);
        border-radius: 4px;
    }

    .modules-tabs::-webkit-scrollbar-thumb {
        background: rgba(255, 151, 96, 0.4);
        border-radius: 4px;
    }

    .modules-tabs::-webkit-scrollbar-thumb:hover {
        background: rgba(255, 151, 96, 0.6);
    }

    /* Module tabs - Version mobile compacte */
    .module-tab {
        min-width: auto;
        width: auto;
        padding: 14px 16px;
        gap: 10px;
        border-radius: 12px;
        flex-shrink: 0;
        /* Améliorer le tap sur mobile */
        -webkit-tap-highlight-color: transparent;
    }

    .module-tab:hover {
        transform: translateY(-2px);
    }

    .module-tab.active {
        transform: translateY(-2px);
        /* Ombre plus prononcée pour feedback visuel clair */
        box-shadow: 0 8px 30px rgba(255, 151, 96, 0.4);
    }

    /* Icon plus petit sur mobile */
    .tab-icon {
        font-size: 26px;
    }

    .module-tab.active .tab-icon {
        transform: scale(1.1);
        filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3));
    }

    /* Image plus petite sur mobile */
    .tab-image {
        width: 50px;
        height: 50px;
        border-radius: 8px;
    }

    .module-tab.active .tab-image {
        transform: scale(1.05);
    }

    /* Content text plus compact */
    .tab-content h4 {
        font-size: 13px;
        font-weight: 700;
        line-height: 1.2;
        max-width: 120px;
    }

    .tab-content span {
        font-size: 10px;
        opacity: 0.9;
    }

    /* Réduire l'indicateur actif */
    .module-tab.active::after {
        width: 30px;
        height: 3px;
    }

    /* Améliorer le contraste des boutons de navigation */
    .modules-tab-nav {
        background: rgba(255, 255, 255, 0.95);
        backdrop-filter: blur(8px);
    }
}

/* ===== VERSION EXTRA COMPACTE (< 480px) ===== */
@media (max-width: 480px) {
    .modules-tabs {
        padding: 10px;
        gap: 6px;
    }

    /* Mode ultra-compact: icône centrée + titre en dessous */
    .module-tab {
        min-width: 90px;
        max-width: 110px;
        padding: 12px 10px;
        gap: 8px;
        flex-direction: column;
        text-align: center;
        justify-content: center;
    }

    .tab-icon {
        font-size: 28px;
        margin-bottom: 2px;
    }

    /* Image ultra-compacte sur très petit écran */
    .tab-image {
        width: 45px;
        height: 45px;
        border-radius: 8px;
        margin-bottom: 2px;
    }

    .tab-content {
        width: 100%;
        align-items: center;
    }

    .tab-content h4 {
        font-size: 11px;
        text-align: center;
        max-width: 100%;
        line-height: 1.3;
        /* Permettre 2 lignes maximum sur très petit écran */
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* Cacher le sous-titre sur très petit écran */
    .tab-content span {
        display: none;
    }

    .module-tab.active::after {
        width: 24px;
        height: 3px;
        bottom: 2px;
    }
}

/* ===== TABLET OPTIMIZATIONS (481px - 1024px) ===== */
@media (min-width: 481px) and (max-width: 1024px) {
    .module-tab {
        min-width: 150px;
        padding: 16px 20px;
        gap: 12px;
    }

    .tab-icon {
        font-size: 28px;
    }

    /* Image taille tablette */
    .tab-image {
        width: 55px;
        height: 55px;
        border-radius: 9px;
    }

    .tab-content h4 {
        font-size: 14px;
        max-width: 160px;
    }

    .tab-content span {
        font-size: 11px;
    }
}

/* ===== MOBILE (768px et moins) ===== */
    @media (max-width: 768px) {

/* ===== NAVIGATION ===== */
.nav-container {
    padding: 0 20px;
    height: 70px;
}

.logo-img {
    height: 36px;
}

.nav-menu {
    display: none;
}

.nav-cta {
    gap: 8px;
}

.btn {
    padding: 10px 20px;
    font-size: 13px;
}

/* Cacher le bouton secondaire sur mobile */
.nav-cta .btn-secondary {
    display: none;
}

/* ===== HERO ===== */
.hero {
    padding: 130px 20px 60px;
}

.hero h1 {
    font-size: 32px;
    letter-spacing: -1px;
    margin-bottom: 20px;
}

.hero p {
    font-size: 16px;
    margin-bottom: 30px;
}

.hero-badge {
    padding: 8px 16px;
    margin-bottom: 20px;
    font-size: 12px;
}

.hero-badge span {
    font-size: 11px;
}

.hero-cta {
    flex-direction: column;
    width: 100%;
    gap: 12px;
}

.btn-hero {
    width: 100%;
    text-align: center;
    padding: 16px 32px;
    font-size: 15px;
}

.hero-stats {
    flex-direction: column;
    gap: 30px;
    margin-top: 50px;
}

.stat-number {
    font-size: 36px;
}

.stat-label {
    font-size: 14px;
}

/* ===== SECTIONS GÉNÉRALES ===== */
.modules-section,
.features-grid-section,
.video-demo-section,
.integration-section,
.pricing-section,
.faq-section,
.social-proof,
.cta-section {
    padding: 60px 20px;
}

.section-header {
    margin-bottom: 40px;
}

.section-badge {
    font-size: 11px;
    padding: 6px 16px;
}

.section-header h2 {
    font-size: 32px;
    letter-spacing: -1px;
}

.section-header p {
    font-size: 16px;
}

/* ===== MODULES SECTION ===== */
.modules-section {
    min-height: auto;
}

/* Tabs - Règles déplacées vers la section responsive optimisée ci-dessus */

/* Features showcase */
.features-showcase {
    min-height: 300px;
}

/* Grille des features - 1 colonne sur mobile */
.features-grid-visual {
    grid-template-columns: 1fr !important;
    gap: 20px;
}

.feature-visual-card.large {
    grid-column: span 1;
}

.feature-visual-image {
    height: 200px;
}

.screenshot-icon {
    font-size: 60px;
    margin-bottom: 8px;
}

.screenshot-placeholder span {
    font-size: 12px;
}

.feature-visual-content {
    padding: 20px;
}

.feature-visual-content h4 {
    font-size: 18px;
}

.feature-visual-content p {
    font-size: 13px;
    margin-bottom: 12px;
}

.feature-tags-mini {
    gap: 6px;
}

.feature-tags-mini span {
    font-size: 10px;
    padding: 4px 10px;
}

/* ===== MODAL ===== */
.feature-detail-modal {
    padding: 20px;
}

.modal-content {
    border-radius: 16px;
    max-height: 95vh;
}

.modal-close {
    width: 40px;
    height: 40px;
    top: 10px;
    right: 10px;
    font-size: 24px;
}

.modal-body {
    grid-template-columns: 1fr;
}

.modal-screenshot {
    min-height: 250px;
    padding: 30px 20px;
}

.screenshot-icon-large {
    font-size: 80px;
    margin-bottom: 16px;
}

.modal-screenshot-placeholder p {
    font-size: 14px;
}

.modal-info {
    padding: 30px 20px;
}

.modal-icon {
    font-size: 40px;
    margin-bottom: 16px;
}

.modal-title {
    font-size: 24px;
    margin-bottom: 12px;
}

.modal-description {
    font-size: 15px;
    margin-bottom: 24px;
}

.modal-features {
    margin-bottom: 24px;
}

.modal-features h4 {
    font-size: 14px;
    margin-bottom: 12px;
}

.modal-features li {
    font-size: 14px;
    padding: 8px 0;
    padding-left: 24px;
}

.modal-features li::before {
    font-size: 16px;
}

.modal-tags {
    gap: 8px;
    margin-bottom: 24px;
}

.modal-tags span {
    font-size: 11px;
    padding: 6px 12px;
}

.btn-modal {
    padding: 16px;
    font-size: 15px;
}

/* ===== FEATURES GRID SECTION ===== */
.features-grid {
    grid-template-columns: 1fr !important;
    gap: 24px;
}

.feature-card {
    padding: 30px;
}

.feature-card-icon {
    font-size: 48px;
    margin-bottom: 20px;
}

.feature-card h3 {
    font-size: 22px;
    margin-bottom: 12px;
}

.feature-card p {
    font-size: 15px;
    margin-bottom: 20px;
}

.feature-list {
    gap: 8px;
}

.feature-list-item {
    font-size: 14px;
}

.feature-list-item::before {
    font-size: 16px;
}

/* ===== VIDEO SECTION ===== */
.video-wrapper {
    border-radius: 16px;
    margin-top: 40px;
}

.play-button {
    width: 70px;
    height: 70px;
    margin-bottom: 16px;
}

.play-button::after {
    border-width: 12px 0 12px 20px;
}

.video-placeholder h3 {
    font-size: 18px;
}

.video-placeholder p {
    font-size: 14px;
    padding: 0 20px;
}

/* ===== INTEGRATION SECTION ===== */
.integration-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px;
}

.integration-card {
    padding: 30px 20px;
}

.integration-icon {
    font-size: 40px;
    margin-bottom: 12px;
}

.integration-card h4 {
    font-size: 16px;
    margin-bottom: 6px;
}

.integration-card p {
    font-size: 12px;
}

/* ===== PRICING SECTION ===== */
.pricing-grid {
    grid-template-columns: 1fr !important;
    gap: 24px;
}

.pricing-card {
    padding: 40px 30px;
}

/* Annuler le scale sur mobile pour la carte featured */
.pricing-card.featured {
    transform: none;
    box-shadow: 0 20px 60px rgba(255, 151, 96, 0.2);
}

.pricing-card.featured:hover {
    transform: translateY(-8px);
}

.pricing-badge {
    top: -10px;
    right: 20px;
    font-size: 10px;
    padding: 5px 12px;
}

.pricing-card h3 {
    font-size: 20px;
}

.pricing-card .price {
    font-size: 42px;
}

.pricing-card .price span {
    font-size: 18px;
}

.pricing-description {
    font-size: 14px;
    margin-bottom: 24px;
    padding-bottom: 24px;
}

.pricing-features {
    gap: 12px;
    margin-bottom: 24px;
}

.pricing-feature {
    font-size: 14px;
    gap: 10px;
}

.pricing-feature::before {
    font-size: 16px;
}

.pricing-cta {
    padding: 14px;
    font-size: 14px;
}

/* ===== FAQ SECTION ===== */
.faq-item {
    padding: 24px;
    margin-bottom: 16px;
}

.faq-question {
    font-size: 16px;
    gap: 16px;
}

.faq-question span:first-child {
    flex: 1;
}

.faq-icon {
    font-size: 20px;
    flex-shrink: 0;
}

.faq-answer {
    font-size: 14px;
    line-height: 1.6;
}

.faq-item.active .faq-answer {
    margin-top: 16px;
}

/* ===== TESTIMONIALS SECTION ===== */
.testimonials-grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
}

.testimonial-card {
    padding: 30px;
}

.testimonial-stars {
    font-size: 18px;
    margin-bottom: 16px;
}

.testimonial-text {
    font-size: 15px;
    margin-bottom: 20px;
}

.testimonial-avatar {
    width: 40px;
    height: 40px;
    font-size: 16px;
}

.testimonial-info h4 {
    font-size: 14px;
}

.testimonial-info p {
    font-size: 12px;
}

/* ===== CTA SECTION ===== */
.cta-section {
    padding: 80px 20px;
}

.cta-section h2 {
    font-size: 32px;
    letter-spacing: -1px;
    margin-bottom: 20px;
}

.cta-section p {
    font-size: 16px;
    margin-bottom: 32px;
}

.cta-buttons {
    flex-direction: column;
    width: 100%;
}

.btn-white,
.btn-outline-white {
    width: 100%;
    padding: 16px 32px;
}

/* ===== FOOTER ===== */
.footer {
    padding: 50px 20px 30px;
}

.footer-grid {
    grid-template-columns: 1fr !important;
    gap: 30px;
    margin-bottom: 40px;
}

.footer-brand {
    grid-column: 1;
}

.footer-brand img {
    height: 32px !important;
}

.footer-brand p {
    max-width: 100%;
    font-size: 14px;
}

.footer-column h4 {
    font-size: 13px;
    margin-bottom: 16px;
}

.footer-links {
    gap: 10px;
}

.footer-link {
    font-size: 14px;
}

.footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: 12px;
}

.footer-bottom p {
    font-size: 13px;
}
    }

    /* ===== EXTRA SMALL MOBILE (480px et moins) ===== */
    @media (max-width: 480px) {
.hero h1 {
    font-size: 28px;
}

.hero p {
    font-size: 15px;
}

.section-header h2 {
    font-size: 28px;
}

.section-header p {
    font-size: 15px;
}

/* Module tabs - Règles déplacées vers la section responsive optimisée ci-dessus */

/* Intégrations en 1 colonne sur très petit écran */
.integration-grid {
    grid-template-columns: 1fr !important;
}

.cta-section h2 {
    font-size: 28px;
}

.cta-section p {
    font-size: 15px;
}
    }

    /* ===== CORRECTIONS SPÉCIFIQUES ===== */

    /* Éviter les débordements d'images */
    img {
max-width: 100%;
height: auto;
    }

    /* S'assurer que les cartes ne dépassent pas */
    .feature-visual-card,
    .feature-card,
    .integration-card,
    .pricing-card,
    .testimonial-card,
    .faq-item {
max-width: 100%;
    }

    /* Améliorer les performances des animations sur mobile */
    @media (max-width: 768px) {
* {
    animation-duration: 0.3s !important;
}

.hero::before,
.hero::after,
.modal-screenshot::before,
.feature-visual-image::before {
    animation: none;
}
    }

    /* Fix pour les gaps qui peuvent causer des problèmes */
    @media (max-width: 768px) {

.modules-tabs,
.features-grid-visual,
.features-grid,
.integration-grid,
.pricing-grid,
.testimonials-grid {
    gap: 20px;
}
    }

    /* Améliorer la lisibilité des textes sur mobile */
    @media (max-width: 768px) {
body {
    font-size: 15px;
    line-height: 1.6;
}

p {
    line-height: 1.6;
}
    }

    @media (min-width: 769px) {
section {
    zoom: 0.8;
}
    }

/* ===== MOBILE MODULES SECTION IMPROVEMENTS ===== */
@media (max-width: 768px) {
    /* 1. Modules list max-height avec scroll */
    .modules-sidebar .modules-list {
        max-height: 300px;
        overflow-y: auto;
        padding-right: 8px;
        scrollbar-width: thin;
        scrollbar-color: var(--primary) rgba(0, 0, 0, 0.05);
    }

    .modules-sidebar .modules-list::-webkit-scrollbar {
        width: 4px;
    }

    .modules-sidebar .modules-list::-webkit-scrollbar-track {
        background: rgba(0, 0, 0, 0.03);
        border-radius: 4px;
    }

    .modules-sidebar .modules-list::-webkit-scrollbar-thumb {
        background: var(--primary);
        border-radius: 4px;
    }

    /* 2. Retirer margin-top de features-grid pour plus de compacité */
    .features-display {
        margin-top: 0 !important;
    }

    .features-content-header {
        margin-bottom: 16px;
        padding-bottom: 12px;
    }

    /* 3. Features grid - afficher 5 max avec "voir plus" */
    .features-grid {
        position: relative;
    }

    .features-grid .feature-card {
        display: none;
    }

    .features-grid .feature-card:nth-child(-n+5) {
        display: block;
    }

    .features-grid.show-all .feature-card {
        display: block;
    }

    /* Hider gradient overlay */
    .features-grid-hider {
        display: block;
        position: relative;
        margin-top: -60px;
        padding-top: 80px;
        background: linear-gradient(to bottom, transparent 0%, white 60%);
        text-align: center;
        padding-bottom: 20px;
    }

    .features-grid.show-all + .features-grid-hider {
        display: none;
    }

    .features-show-more-btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 12px 24px;
        background: var(--gradient);
        color: white;
        border: none;
        border-radius: 10px;
        font-size: 14px;
        font-weight: 600;
        cursor: pointer;
        box-shadow: 0 8px 25px rgba(255, 151, 96, 0.3);
        transition: all 0.3s ease;
    }

    .features-show-more-btn:hover {
        transform: translateY(-2px);
        box-shadow: 0 12px 35px rgba(255, 151, 96, 0.4);
    }

    .features-show-more-btn svg {
        transition: transform 0.3s ease;
    }

    .features-show-more-btn:hover svg {
        transform: translateY(2px);
    }

    /* 4. Module switcher fixed button */
    .mobile-module-switcher {
        position: fixed;
        bottom: 20px;
        left: 50%;
        z-index: 9998;
        background: var(--secondary);
        color: white;
        padding: 14px 24px;
        border-radius: 50px;
        border: none;
        font-size: 14px;
        font-weight: 600;
        cursor: pointer;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
        display: flex;
        align-items: center;
        gap: 10px;
        /* Note: transform, opacity, visibility controlled via JS for show/hide */
    }

    .mobile-module-switcher:hover {
        box-shadow: 0 15px 50px rgba(0, 0, 0, 0.4);
    }

    .mobile-module-switcher svg {
        flex-shrink: 0;
    }

    .mobile-module-switcher-text {
        max-width: 150px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* Module switcher modal */
    .module-switcher-modal {
        display: none;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 10002;
        background: white;
        border-radius: 24px 24px 0 0;
        box-shadow: 0 -10px 50px rgba(0, 0, 0, 0.2);
        max-height: 70vh;
        transform: translateY(100%);
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .module-switcher-modal.open {
        display: block;
        transform: translateY(0);
    }

    .module-switcher-modal-backdrop {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 10001;
        opacity: 0;
        transition: opacity 0.3s ease;
    }

    .module-switcher-modal-backdrop.open {
        display: block;
        opacity: 1;
    }

    .module-switcher-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 20px 24px;
        border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    }

    .module-switcher-header h4 {
        font-size: 18px;
        font-weight: 700;
        color: var(--text-dark);
    }

    .module-switcher-close {
        width: 36px;
        height: 36px;
        border: none;
        background: rgba(0, 0, 0, 0.05);
        border-radius: 50%;
        font-size: 20px;
        color: var(--text);
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background 0.2s ease;
    }

    .module-switcher-close:hover {
        background: rgba(0, 0, 0, 0.1);
    }

    .module-switcher-list {
        padding: 16px;
        max-height: calc(70vh - 80px);
        overflow-y: auto;
    }

    .module-switcher-item {
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 14px 16px;
        border-radius: 12px;
        cursor: pointer;
        transition: all 0.2s ease;
        margin-bottom: 8px;
    }

    .module-switcher-item:hover {
        background: rgba(0, 0, 0, 0.03);
    }

    .module-switcher-item.active {
        background: rgba(255, 151, 96, 0.1);
        border: 2px solid var(--primary);
    }

    .module-switcher-item-icon {
        width: 44px;
        height: 44px;
        border-radius: 10px;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 22px;
    }

    .module-switcher-item-icon img {
        width: 24px;
        height: 24px;
        object-fit: contain;
    }

    .module-switcher-item-info h5 {
        font-size: 15px;
        font-weight: 600;
        color: var(--text-dark);
        margin-bottom: 2px;
    }

    .module-switcher-item-info span {
        font-size: 12px;
        color: var(--text-light);
    }

    .module-switcher-item-check {
        margin-left: auto;
        width: 24px;
        height: 24px;
        background: var(--primary);
        border-radius: 50%;
        display: none;
        align-items: center;
        justify-content: center;
        color: white;
    }

    .module-switcher-item.active .module-switcher-item-check {
        display: flex;
    }

    /* Module switcher: hidden by default on mobile, shown via JS when on modules section */
    .mobile-module-switcher {
        visibility: hidden;
        opacity: 0;
        transform: translateX(-50%) translateY(100px);
        transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
    }

    /* Calendly badge visibility is controlled via JS based on module switcher state */
}

/* Hide mobile-only elements on desktop */
@media (min-width: 769px) {
    .mobile-module-switcher,
    .module-switcher-modal,
    .module-switcher-modal-backdrop,
    .features-grid-hider {
        display: none !important;
    }
}

/* ============================================
   HERO SPLIT LAYOUT - NEW DESIGN
   ============================================ */

.hero-split {
    padding: 160px 0 80px;
    background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
    position: relative;
    overflow: hidden;
    min-height: 90vh;
    display: flex;
    align-items: center;
}

.hero-split-container {
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 60px;
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 80px;
    align-items: center;
    position: relative;
    z-index: 2;
}

/* Left Content */
.hero-split-content {
    max-width: 600px;
}

.hero-badge-new {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: white;
    padding: 10px 22px;
    border-radius: 100px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
    margin-bottom: 28px;
    border: 1px solid rgba(255, 151, 96, 0.15);
    animation: slideInLeft 0.8s ease-out;
}

.hero-badge-pulse {
    width: 10px;
    height: 10px;
    background: var(--gradient);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
    box-shadow: 0 0 0 0 rgba(255, 151, 96, 0.5);
}

@keyframes pulse {
    0% { box-shadow: 0 0 0 0 rgba(255, 151, 96, 0.5); }
    70% { box-shadow: 0 0 0 12px rgba(255, 151, 96, 0); }
    100% { box-shadow: 0 0 0 0 rgba(255, 151, 96, 0); }
}

.hero-badge-new span {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-dark);
    letter-spacing: 0.02em;
}

.hero-split-content h1 {
    font-size: 4rem;
    font-weight: 900;
    color: var(--secondary);
    line-height: 1.08;
    letter-spacing: -0.03em;
    margin-bottom: 24px;
    animation: slideInLeft 0.8s ease-out 0.1s both;
}

.hero-gradient-text {
    background: var(--gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero-split-desc {
    font-size: 1.2rem;
    color: var(--text);
    line-height: 1.75;
    margin-bottom: 36px;
    animation: slideInLeft 0.8s ease-out 0.2s both;
}

.hero-split-cta {
    display: flex;
    gap: 16px;
    margin-bottom: 48px;
    animation: slideInLeft 0.8s ease-out 0.3s both;
}

.btn-lg {
    padding: 18px 32px;
    font-size: 16px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.btn-ghost {
    background: transparent;
    color: var(--text-dark);
    border: 2px solid rgba(0, 0, 0, 0.1);
}

.btn-ghost:hover {
    background: rgba(0, 0, 0, 0.03);
    border-color: rgba(0, 0, 0, 0.15);
}

.hero-split-stats {
    display: flex;
    align-items: center;
    gap: 32px;
    animation: slideInLeft 0.8s ease-out 0.4s both;
}

.hero-stat-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.hero-stat-num {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--secondary);
    letter-spacing: -0.02em;
}

.hero-stat-label {
    font-size: 0.85rem;
    color: var(--text-light);
    font-weight: 500;
}

.hero-stat-divider {
    width: 1px;
    height: 40px;
    background: rgba(0, 0, 0, 0.1);
}

/* Right Visual */
.hero-split-visual {
    position: relative;
    animation: slideInRight 1s ease-out 0.3s both;
}

.hero-screenshot-float {
    position: relative;
}

.hero-screenshot-float > a {
    display: block;
    position: relative;
}

.hero-screenshot-float img {
    width: 100%;
    height: auto;
    border-radius: 20px;
    box-shadow: 0 50px 100px rgba(0, 0, 0, 0.15),
                0 20px 40px rgba(0, 0, 0, 0.1);
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.hero-screenshot-float img:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 60px 120px rgba(0, 0, 0, 0.2),
                0 25px 50px rgba(0, 0, 0, 0.12);
}

.hero-screenshot-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 120%;
    height: 120%;
    background: radial-gradient(ellipse at center, rgba(255, 151, 96, 0.2) 0%, transparent 60%);
    z-index: -1;
    filter: blur(80px);
}

/* Floating Cards */
.hero-float-card {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    background: white;
    border-radius: 16px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.12);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
    z-index: 10;
    animation: float 6s ease-in-out infinite;
}

.hero-float-icon {
    width: 36px;
    height: 36px;
    background: rgba(0, 0, 0, 0.04);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dark);
}

.hero-float-icon-success {
    background: rgba(16, 185, 129, 0.12);
    color: #10b981;
}

.hero-float-icon-primary {
    background: rgba(255, 151, 96, 0.12);
    color: var(--primary);
}

.hero-float-1 {
    top: 10%;
    right: -30px;
    animation-delay: 0s;
}

.hero-float-2 {
    bottom: 25%;
    left: -40px;
    animation-delay: -2s;
}

.hero-float-3 {
    bottom: 5%;
    right: 10%;
    animation-delay: -4s;
}

@keyframes float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-15px); }
}

@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(50px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Background Decorations */
.hero-split-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.hero-bg-circle {
    position: absolute;
    border-radius: 50%;
}

.hero-bg-1 {
    top: -20%;
    right: -10%;
    width: 700px;
    height: 700px;
    background: radial-gradient(circle, rgba(255, 151, 96, 0.08) 0%, transparent 70%);
}

.hero-bg-2 {
    bottom: -30%;
    left: -15%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(255, 122, 61, 0.06) 0%, transparent 70%);
}

.hero-bg-grid {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    background-image:
        linear-gradient(rgba(0, 0, 0, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 0, 0, 0.02) 1px, transparent 1px);
    background-size: 60px 60px;
    mask-image: linear-gradient(to left, rgba(0,0,0,0.3) 0%, transparent 70%);
    -webkit-mask-image: linear-gradient(to left, rgba(0,0,0,0.3) 0%, transparent 70%);
}

/* ============================================
   HERO CARTOUCHE - KEY FEATURES BANNER
   ============================================ */

.hero-cartouche {
    background: white;
    padding: 0;
    margin-top: -40px;
    position: relative;
    z-index: 10;
}

.hero-cartouche-inner {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    padding: 0 60px;
}

.hero-cartouche-content {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    background: white;
    padding: 20px 32px;
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08),
                0 8px 25px rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.04);
}

.hero-cartouche-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background: var(--bg);
    border-radius: 100px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.hero-cartouche-item:hover {
    background: rgba(255, 151, 96, 0.08);
    border-color: var(--primary);
    transform: translateY(-2px);
}

.hero-cartouche-icon {
    font-size: 1.3rem;
}

.hero-cartouche-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-dark);
    white-space: nowrap;
}

/* Hero Split Responsive */
@media (max-width: 1200px) {
    .hero-split-container {
        gap: 50px;
    }

    .hero-split-content h1 {
        font-size: 3.2rem;
    }

    .hero-float-1 { right: 0; }
    .hero-float-2 { left: -20px; }
}

@media (max-width: 1024px) {
    .hero-split {
        padding: 140px 0 60px;
        min-height: auto;
    }

    .hero-split-container {
        grid-template-columns: 1fr;
        gap: 50px;
        padding: 0 40px;
    }

    .hero-split-content {
        max-width: 100%;
        text-align: center;
    }

    .hero-split-content h1 {
        font-size: 2.8rem;
    }

    .hero-split-cta {
        justify-content: center;
    }

    .hero-split-stats {
        justify-content: center;
    }

    .hero-split-visual {
        max-width: 600px;
        margin: 0 auto;
    }

    .hero-float-card {
        display: none;
    }

    .hero-cartouche-inner {
        padding: 0 40px;
    }

    .hero-cartouche-content {
        padding: 16px 24px;
    }
}

@media (max-width: 768px) {
    .hero-split {
        padding: 120px 0 50px;
    }

    .hero-split-container {
        padding: 0 20px;
        gap: 40px;
    }

    .hero-split-content h1 {
        font-size: 2.2rem;
    }

    .hero-split-desc {
        font-size: 1.05rem;
    }

    .hero-split-cta {
        flex-direction: column;
    }

    .hero-split-cta .btn {
        width: 100%;
        justify-content: center;
    }

    .hero-split-stats {
        flex-wrap: wrap;
        gap: 20px;
    }

    .hero-stat-divider {
        display: none;
    }

    .hero-stat-item {
        flex: 1;
        min-width: 100px;
        text-align: center;
    }

    .hero-cartouche {
        display: none;
    }
}

/* ============================================
   KEY FEATURES INFINITE SLIDER
   ============================================ */

.kf-slider-section {
    padding: 100px 0 80px;
    background: var(--bg);
    overflow: hidden;
}

.kf-slider-header {
    padding: 0 60px;
    margin-bottom: 50px;
}

.kf-slider-header-inner {
    max-width: 700px;
    margin: 0 auto;
    text-align: center;
}

.kf-slider-header h2 {
    font-size: 2.8rem;
    font-weight: 800;
    color: var(--secondary);
    margin-bottom: 16px;
    letter-spacing: -0.02em;
}

.kf-slider-header p {
    font-size: 1.15rem;
    color: var(--text);
    line-height: 1.7;
}

.kf-slider-wrapper {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: 20px 0;
}

.kf-slider-wrapper::before,
.kf-slider-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 150px;
    z-index: 10;
    pointer-events: none;
}

.kf-slider-wrapper::before {
    left: 0;
    background: linear-gradient(to right, var(--bg) 0%, transparent 100%);
}

.kf-slider-wrapper::after {
    right: 0;
    background: linear-gradient(to left, var(--bg) 0%, transparent 100%);
}

.kf-slider-track {
    display: flex;
    gap: 24px;
    width: max-content;
    will-change: transform;
}

.kf-slider-card {
    flex-shrink: 0;
    width: 320px;
    background: white;
    border-radius: 20px;
    overflow: hidden;
    text-decoration: none;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.04);
}

.kf-slider-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.12);
}

.kf-slider-card-image {
    position: relative;
    height: 180px;
    overflow: hidden;
    background: #1a1a2e;
}

/* Blurred background image */
.kf-slider-card-blur {
    position: absolute;
    inset: -20px;
    background-size: cover;
    background-position: center;
    filter: blur(15px);
    opacity: 0.7;
    transform: scale(1.1);
}

.kf-slider-card-image img {
    position: relative;
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform 0.5s ease;
    z-index: 1;
}

.kf-slider-card:hover .kf-slider-card-image img {
    transform: scale(1.05);
}

.kf-slider-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.3) 100%);
    opacity: 0.5;
    z-index: 2;
}

.kf-slider-card-icon {
    position: absolute;
    top: 16px;
    left: 16px;
    width: 48px;
    height: 48px;
    background: white;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
    z-index: 3;
}

.kf-slider-card-content {
    padding: 24px;
}

.kf-slider-card-content h4 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 10px;
    line-height: 1.3;
}

.kf-slider-card-content p {
    font-size: 0.92rem;
    color: var(--text-light);
    line-height: 1.6;
    margin-bottom: 16px;
    min-height: 44px;
}

.kf-slider-card-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--primary);
    transition: all 0.3s ease;
}

.kf-slider-card:hover .kf-slider-card-link {
    gap: 10px;
}

.kf-slider-card-link svg {
    transition: transform 0.3s ease;
}

.kf-slider-card:hover .kf-slider-card-link svg {
    transform: translateX(4px);
}

.kf-slider-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 32px;
    font-size: 0.85rem;
    color: var(--text-light);
    opacity: 0.7;
}

.kf-slider-hint svg {
    opacity: 0.5;
}

/* Slider Responsive */
@media (max-width: 1024px) {
    .kf-slider-section {
        padding: 70px 0 60px;
    }

    .kf-slider-header {
        padding: 0 40px;
        margin-bottom: 40px;
    }

    .kf-slider-header h2 {
        font-size: 2.2rem;
    }

    .kf-slider-card {
        width: 280px;
    }

    .kf-slider-card-image {
        height: 150px;
    }

    .kf-slider-wrapper::before,
    .kf-slider-wrapper::after {
        width: 80px;
    }
}

@media (max-width: 768px) {
    .kf-slider-section {
        padding: 60px 0 50px;
    }

    .kf-slider-header {
        padding: 0 20px;
        margin-bottom: 30px;
    }

    .kf-slider-header h2 {
        font-size: 1.8rem;
    }

    .kf-slider-header p {
        font-size: 1rem;
    }

    .kf-slider-track {
        gap: 16px;
    }

    .kf-slider-card {
        width: 260px;
    }

    .kf-slider-card-image {
        height: 140px;
    }

    .kf-slider-card-icon {
        width: 40px;
        height: 40px;
        font-size: 20px;
        border-radius: 12px;
    }

    .kf-slider-card-content {
        padding: 18px;
    }

    .kf-slider-card-content h4 {
        font-size: 1.05rem;
    }

    .kf-slider-card-content p {
        font-size: 0.85rem;
        min-height: 38px;
    }

    .kf-slider-wrapper::before,
    .kf-slider-wrapper::after {
        width: 40px;
    }

    .kf-slider-hint {
        display: none;
    }
}

/* ============================================
   SINGLE KEY FEATURE PAGE
   ============================================ */

.kf-single-hero {
    padding: 40px 0 80px;
    background: linear-gradient(180deg, #fff 0%, var(--bg) 100%);
}

.kf-single-hero-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 60px;
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 80px;
    align-items: center;
}

.kf-single-icon {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, rgba(255,151,96,0.15) 0%, rgba(255,122,61,0.1) 100%);
    border-radius: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    margin-bottom: 24px;
    box-shadow: 0 8px 32px rgba(255,151,96,0.15);
}

.kf-single-hero-content h1 {
    font-size: 3.2rem;
    font-weight: 800;
    color: var(--secondary);
    line-height: 1.15;
    margin-bottom: 20px;
    letter-spacing: -0.02em;
}

.kf-single-excerpt {
    font-size: 1.25rem;
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 24px;
}

.kf-single-meta {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.kf-meta-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--text-light);
    background: rgba(0,0,0,0.03);
    padding: 8px 16px;
    border-radius: 100px;
}

.kf-meta-item svg {
    color: var(--primary);
}

.kf-single-hero-image {
    position: relative;
}

.kf-image-wrapper {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,0.15);
}

.kf-image-wrapper img {
    width: 100%;
    height: auto;
    display: block;
}

.kf-image-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    height: 80%;
    background: radial-gradient(ellipse at center, rgba(255,151,96,0.3) 0%, transparent 70%);
    z-index: -1;
    filter: blur(60px);
}

/* Content Section */
.kf-single-content-section {
    padding: 80px 0;
    background: #fff;
}

.kf-single-content-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 60px;
}

.kf-single-body {
    margin-bottom: 80px;
}

.kf-content-wrapper {
    font-size: 1.1rem;
    line-height: 1.85;
    color: var(--text);
}

.kf-content-wrapper h2 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--secondary);
    margin: 40px 0 20px;
}

.kf-content-wrapper h3 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--secondary);
    margin: 32px 0 16px;
}

.kf-content-wrapper p {
    margin-bottom: 20px;
}

.kf-content-wrapper ul,
.kf-content-wrapper ol {
    margin: 20px 0;
    padding-left: 24px;
}

.kf-content-wrapper li {
    margin-bottom: 12px;
}

/* Linked Modules */
.kf-linked-modules h2 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 32px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.kf-section-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

.kf-modules-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}

.kf-module-card {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 16px;
    background: var(--bg);
    border-radius: 20px;
    text-decoration: none;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    border: 2px solid transparent;
}

.kf-module-card:hover {
    background: #fff;
    border-color: var(--module-color, var(--primary));
    box-shadow: 0 20px 50px rgba(0,0,0,0.1);
    transform: translateY(-4px);
}

.kf-module-image {
    width: 80px;
    height: 80px;
    border-radius: 16px;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
}

.kf-module-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kf-module-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--module-color, var(--primary)), transparent);
    opacity: 0.2;
}

.kf-module-content {
    flex: 1;
    min-width: 0;
}

.kf-module-content h4 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 4px;
}

.kf-module-content p {
    font-size: 0.9rem;
    color: var(--text-light);
    margin-bottom: 6px;
    line-height: 1.5;
}

.kf-module-meta {
    font-size: 0.8rem;
    color: var(--primary);
    font-weight: 600;
}

.kf-module-arrow {
    width: 40px;
    height: 40px;
    background: rgba(255,151,96,0.1);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.kf-module-card:hover .kf-module-arrow {
    background: var(--primary);
    color: white;
    transform: translateX(4px);
}

/* Navigation */
.kf-single-nav {
    padding: 60px 0;
    background: var(--bg);
}

.kf-single-nav-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 60px;
}

.kf-single-nav-inner h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--secondary);
    text-align: center;
    margin-bottom: 32px;
}

.kf-nav-cards {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
}

.kf-nav-card {
    flex: 1;
    padding: 24px;
    background: #fff;
    border-radius: 16px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.kf-nav-card:hover {
    border-color: var(--primary);
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.kf-nav-empty {
    background: transparent;
    border: 2px dashed rgba(0,0,0,0.1);
}

.kf-nav-direction {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    color: var(--text-light);
    margin-bottom: 8px;
}

.kf-nav-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--secondary);
}

.kf-nav-icon {
    font-size: 1.5rem;
}

.kf-nav-prev {
    text-align: left;
}

.kf-nav-next {
    text-align: right;
}

.kf-nav-next .kf-nav-direction {
    justify-content: flex-end;
}

.kf-nav-next .kf-nav-title {
    justify-content: flex-end;
}

.kf-nav-home {
    width: 56px;
    height: 56px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dark);
    text-decoration: none;
    transition: all 0.3s ease;
    flex-shrink: 0;
    box-shadow: 0 4px 15px rgba(0,0,0,0.06);
}

.kf-nav-home:hover {
    background: var(--primary);
    color: white;
    transform: scale(1.1);
}

/* All Features Strip */
.kf-all-strip {
    padding: 32px 0;
    background: #fff;
    border-top: 1px solid rgba(0,0,0,0.05);
    border-bottom: 1px solid rgba(0,0,0,0.05);
    overflow-x: auto;
}

.kf-all-strip-inner {
    display: flex;
    gap: 12px;
    padding: 0 60px;
    min-width: max-content;
}

.kf-strip-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: var(--bg);
    border-radius: 100px;
    text-decoration: none;
    white-space: nowrap;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.kf-strip-item:hover {
    background: rgba(255,151,96,0.1);
    border-color: var(--primary);
}

.kf-strip-item.active {
    background: var(--primary);
    color: white;
}

.kf-strip-icon {
    font-size: 1.1rem;
}

.kf-strip-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-dark);
}

.kf-strip-item.active .kf-strip-title {
    color: white;
}

/* CTA */
.kf-single-cta {
    padding: 80px 0;
    background: linear-gradient(135deg, var(--secondary) 0%, #2d3a52 100%);
}

.kf-single-cta-inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
}

.kf-cta-content h3 {
    font-size: 2rem;
    font-weight: 700;
    color: white;
    margin-bottom: 12px;
}

.kf-cta-content p {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.7);
}

.kf-cta-buttons {
    display: flex;
    gap: 16px;
    flex-shrink: 0;
}

/* Responsive */
@media (max-width: 1024px) {
    .kf-single-hero-inner {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 0 40px;
    }

    .kf-single-hero-content h1 {
        font-size: 2.5rem;
    }

    .kf-single-content-inner,
    .kf-single-nav-inner {
        padding: 0 40px;
    }

    .kf-single-cta-inner {
        flex-direction: column;
        text-align: center;
        padding: 0 40px;
    }
}

@media (max-width: 768px) {
    .kf-single-hero {
        padding: 20px 0 50px;
    }

    .kf-single-hero-inner {
        padding: 0 20px;
    }

    .kf-single-icon {
        width: 64px;
        height: 64px;
        font-size: 32px;
        border-radius: 18px;
    }

    .kf-single-hero-content h1 {
        font-size: 2rem;
    }

    .kf-single-excerpt {
        font-size: 1.1rem;
    }

    .kf-single-content-section {
        padding: 50px 0;
    }

    .kf-single-content-inner,
    .kf-single-nav-inner {
        padding: 0 20px;
    }

    .kf-modules-grid {
        grid-template-columns: 1fr;
    }

    .kf-nav-cards {
        flex-direction: column;
    }

    .kf-nav-card {
        width: 100%;
    }

    .kf-nav-home {
        order: -1;
    }

    .kf-nav-next,
    .kf-nav-next .kf-nav-direction,
    .kf-nav-next .kf-nav-title {
        text-align: left;
        justify-content: flex-start;
    }

    .kf-all-strip-inner {
        padding: 0 20px;
    }

    .kf-single-cta-inner {
        padding: 0 20px;
    }

    .kf-cta-content h3 {
        font-size: 1.5rem;
    }

    .kf-cta-buttons {
        flex-direction: column;
        width: 100%;
    }

    .kf-cta-buttons .btn {
        width: 100%;
        text-align: center;
    }
}

/* ============================================
   CONTEXTUAL NAVIGATION - MODULES & FEATURES
   ============================================ */

/* Module Context Banner */
.module-context-banner {
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.08) 0%, rgba(255, 122, 61, 0.05) 100%);
    border-bottom: 1px solid rgba(255, 151, 96, 0.15);
    padding: 16px 0;
}

.module-context-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}

.module-context-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: white;
    border-radius: 100px;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--primary);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

.module-context-back:hover {
    transform: translateX(-4px);
    box-shadow: 0 6px 20px rgba(255, 151, 96, 0.2);
}

.module-context-related {
    display: flex;
    align-items: center;
    gap: 12px;
}

.module-context-related > span {
    font-size: 0.85rem;
    color: var(--text-light);
    font-weight: 500;
}

.module-context-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.module-context-pill {
    display: inline-block;
    padding: 8px 16px;
    background: white;
    border-radius: 100px;
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-dark);
    border: 1px solid rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

.module-context-pill:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.module-context-pill.module-context-more {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

/* Module Other Section */
.module-other-section {
    padding: 80px 0;
    background: var(--bg);
}

.module-other-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 60px;
}

.module-other-inner h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 32px;
    text-align: center;
}

.module-other-scroll {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    padding: 10px 0;
    scrollbar-width: none;
}

.module-other-scroll::-webkit-scrollbar {
    display: none;
}

.module-other-card {
    flex: 0 0 280px;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: white;
    border-radius: 16px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.module-other-card:hover {
    border-color: var(--module-color, var(--primary));
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.module-other-image {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}

.module-other-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.module-other-content h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 4px;
}

.module-other-content span {
    font-size: 0.85rem;
    color: var(--text-light);
}

/* Feature Context Bar */
.feature-context-bar {
    background: white;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    padding: 12px 0;
    position: sticky;
    top: 85px;
    z-index: 90;
}

.feature-context-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.feature-context-back {
    display: flex;
    align-items: center;
    gap: 12px;
}

.feature-back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}

.feature-back-link:hover {
    color: var(--primary);
}

.feature-back-link svg {
    color: var(--text-light);
    transition: all 0.2s ease;
}

.feature-back-link:hover svg {
    color: var(--primary);
    transform: translateX(-2px);
}

.feature-back-kf {
    color: var(--primary);
}

.feature-context-sep {
    color: var(--text-light);
    font-size: 0.8rem;
}

.feature-context-counter {
    font-size: 0.85rem;
    color: var(--text-light);
}

.feature-context-counter span {
    font-weight: 700;
    color: var(--text-dark);
}

.feature-context-nav {
    display: flex;
    gap: 8px;
}

.feature-nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: var(--bg);
    border-radius: 10px;
    color: var(--text-dark);
    text-decoration: none;
    transition: all 0.2s ease;
}

.feature-nav-btn:hover {
    background: var(--primary);
    color: white;
}

.feature-nav-btn.disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/* Responsive */
@media (max-width: 768px) {
    .module-context-inner {
        padding: 0 20px;
        flex-direction: column;
        align-items: flex-start;
    }

    .module-context-related {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .module-other-inner {
        padding: 0 20px;
    }

    .module-other-card {
        flex: 0 0 240px;
    }

    .feature-context-bar {
        top: 70px;
    }

    .feature-context-inner {
        padding: 0 20px;
        flex-wrap: wrap;
    }

    .feature-context-back {
        flex-wrap: wrap;
    }
}

/* ============================================
   GLOBAL SEARCH OVERLAY
   ============================================ */

/* Search Button in Nav */
.nav-search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: var(--bg);
    border: none;
    border-radius: 12px;
    color: var(--text);
    cursor: pointer;
    transition: all 0.3s ease;
    margin-right: 12px;
}

.nav-search-btn:hover {
    background: rgba(255, 151, 96, 0.1);
    color: var(--primary);
}

/* Search Overlay */
.global-search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 99999;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.global-search-overlay.open {
    visibility: visible;
    opacity: 1;
}

.global-search-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
}

.global-search-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.95);
    width: 100%;
    max-width: 680px;
    max-height: 80vh;
    background: white;
    border-radius: 24px;
    box-shadow: 0 30px 100px rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    opacity: 0;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease;
}

.global-search-overlay.open .global-search-modal {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
}

body.search-open {
    overflow: hidden;
}

/* Search Header */
.global-search-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.global-search-input-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 16px;
    background: var(--bg);
    border-radius: 14px;
    height: 52px;
}

.global-search-input-wrapper .search-icon {
    color: var(--text-light);
    flex-shrink: 0;
}

.global-search-input-wrapper input {
    flex: 1;
    border: none;
    background: none;
    font-size: 1.1rem;
    color: var(--text-dark);
    outline: none;
}

.global-search-input-wrapper input::placeholder {
    color: var(--text-light);
}

.global-search-clear {
    display: none;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: rgba(0, 0, 0, 0.08);
    border: none;
    border-radius: 50%;
    color: var(--text);
    cursor: pointer;
    transition: all 0.2s ease;
}

.global-search-clear:hover {
    background: var(--primary);
    color: white;
}

.global-search-close {
    background: none;
    border: none;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-light);
    cursor: pointer;
    padding: 10px 16px;
    border-radius: 10px;
    transition: all 0.2s ease;
}

.global-search-close:hover {
    background: var(--bg);
    color: var(--text-dark);
}

/* Search Body */
.global-search-body {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
}

/* Quick Links */
.global-search-quick {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
}

.search-quick-section h4 {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 16px;
}

.search-quick-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.search-quick-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--bg);
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.search-quick-item:hover {
    background: rgba(255, 151, 96, 0.1);
    transform: translateX(4px);
}

.search-quick-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.search-quick-icon img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}

.search-quick-item span:last-child {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-dark);
}

/* Search Results */
.search-results-loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    gap: 16px;
}

.search-results-loader .loader-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(255, 151, 96, 0.2);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.search-results-loader span {
    font-size: 0.9rem;
    color: var(--text-light);
}

.search-results-section {
    margin-bottom: 28px;
}

.search-results-section:last-child {
    margin-bottom: 0;
}

.search-results-section h5 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.search-results-section h5 svg {
    color: var(--primary);
}

.search-results-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.search-result-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--bg);
    border-radius: 14px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.search-result-item:hover {
    background: rgba(255, 151, 96, 0.12);
    transform: translateX(4px);
}

.search-result-icon {
    font-size: 1.5rem;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.search-result-img {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}

.search-result-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.search-result-content {
    flex: 1;
    min-width: 0;
}

.search-result-title {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-result-excerpt {
    display: block;
    font-size: 0.85rem;
    color: var(--text-light);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}

.search-result-meta {
    display: block;
    font-size: 0.8rem;
    color: var(--primary);
    font-weight: 500;
    margin-top: 2px;
}

.search-result-arrow {
    color: var(--text-light);
    flex-shrink: 0;
    transition: all 0.2s ease;
}

.search-result-item:hover .search-result-arrow {
    color: var(--primary);
    transform: translateX(4px);
}

/* Mixed Results with Type Badges */
.search-results-mixed .search-results-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.search-result-header {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.search-result-type-badge {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 3px 8px;
    border-radius: 6px;
    flex-shrink: 0;
}

.search-badge-key_feature {
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    color: #92400e;
}

.search-badge-module {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
    color: #1e40af;
}

.search-badge-feature {
    background: linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%);
    color: #166534;
}

.search-result-type-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    flex-shrink: 0;
}

.search-result-type-key_feature {
    color: #f59e0b;
}

.search-result-type-module {
    color: #3b82f6;
}

.search-result-type-feature {
    color: #22c55e;
}

/* No Results */
.search-no-results {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    text-align: center;
}

.search-no-results svg {
    color: var(--text-light);
    opacity: 0.4;
    margin-bottom: 16px;
}

.search-no-results p {
    font-size: 1rem;
    color: var(--text-light);
}

.search-error {
    text-align: center;
    padding: 40px 20px;
    color: #ef4444;
    font-size: 0.95rem;
}

/* Search Footer */
.global-search-footer {
    padding: 16px 24px;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    background: var(--bg);
}

.search-shortcuts {
    display: flex;
    justify-content: center;
    gap: 24px;
}

.search-shortcuts span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: var(--text-light);
}

.search-shortcuts kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 6px;
    background: white;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text);
    font-family: inherit;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* Responsive */
@media (max-width: 768px) {
    .nav-search-btn {
        width: 40px;
        height: 40px;
        margin-right: 8px;
    }

    .global-search-modal {
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        transform: translate(0, 0);
        max-width: 100%;
        max-height: 100%;
        border-radius: 0;
    }

    .global-search-overlay.open .global-search-modal {
        transform: translate(0, 0);
    }

    .global-search-header {
        padding: 16px;
    }

    .global-search-input-wrapper {
        height: 48px;
    }

    .global-search-input-wrapper input {
        font-size: 1rem;
    }

    .global-search-body {
        padding: 16px;
    }

    .global-search-quick {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .global-search-footer {
        padding: 12px 16px;
    }

    .search-shortcuts {
        gap: 12px;
        flex-wrap: wrap;
        justify-content: center;
    }

    .search-shortcuts span {
        font-size: 0.75rem;
    }
}

/* ===== PROMOTIONAL BANNERS ===== */
.loop-banner {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    margin: 40px auto;
    max-width: 1200px;
}

.loop-banner-inner {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 32px;
    padding: 32px 40px;
}

.loop-banner-image {
    width: 160px;
    height: 120px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}

.loop-banner-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.loop-banner-content {
    flex: 1;
}

.loop-banner-title {
    font-size: 24px;
    font-weight: 800;
    margin: 0 0 8px 0;
    line-height: 1.3;
}

.loop-banner-description {
    font-size: 15px;
    margin: 0 0 16px 0;
    opacity: 0.9;
    line-height: 1.6;
}

.loop-banner-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: 100px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.loop-banner-btn svg {
    transition: transform 0.3s ease;
}

.loop-banner-btn:hover svg {
    transform: translateX(4px);
}

/* Pattern overlays */
.loop-banner-pattern-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    opacity: 0.1;
    pointer-events: none;
}

.loop-banner-pattern-dots .loop-banner-pattern-overlay {
    background-image: radial-gradient(circle, currentColor 1px, transparent 1px);
    background-size: 20px 20px;
}

.loop-banner-pattern-waves .loop-banner-pattern-overlay {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 20'%3E%3Cpath d='M0 10 Q25 0 50 10 T100 10' fill='none' stroke='white' stroke-width='2'/%3E%3C/svg%3E");
    background-size: 100px 20px;
}

.loop-banner-pattern-grid .loop-banner-pattern-overlay {
    background-image: linear-gradient(currentColor 1px, transparent 1px),
                      linear-gradient(90deg, currentColor 1px, transparent 1px);
    background-size: 30px 30px;
}

.loop-banner-pattern-circles .loop-banner-pattern-overlay {
    background-image: radial-gradient(circle, currentColor 10px, transparent 10px);
    background-size: 60px 60px;
}

.loop-banner-pattern-diagonal .loop-banner-pattern-overlay {
    background: repeating-linear-gradient(45deg, currentColor, currentColor 1px, transparent 1px, transparent 20px);
}

/* Style: Gradient */
.loop-banner-gradient {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    color: white;
}

.loop-banner-gradient .loop-banner-btn {
    background: white;
    color: #ff7a3d;
}

.loop-banner-gradient .loop-banner-btn:hover {
    background: rgba(255,255,255,0.9);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
}

/* Style: Solid */
.loop-banner-solid {
    background: #ff7a3d;
    color: white;
}

.loop-banner-solid .loop-banner-btn {
    background: rgba(255,255,255,0.2);
    color: white;
    border: 2px solid white;
}

.loop-banner-solid .loop-banner-btn:hover {
    background: white;
    color: #ff7a3d;
}

/* Style: Dark */
.loop-banner-dark {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    color: white;
}

.loop-banner-dark .loop-banner-btn {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    color: white;
}

.loop-banner-dark .loop-banner-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(255,122,61,0.4);
}

/* Style: Light */
.loop-banner-light {
    background: linear-gradient(135deg, #fff8f5 0%, #fff 100%);
    color: var(--text-dark);
    border: 2px solid rgba(255,151,96,0.2);
}

.loop-banner-light .loop-banner-btn {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    color: white;
}

/* Style: Glass */
.loop-banner-glass {
    background: rgba(255,151,96,0.1);
    backdrop-filter: blur(20px);
    color: var(--text-dark);
    border: 1px solid rgba(255,151,96,0.3);
}

.loop-banner-glass .loop-banner-btn {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    color: white;
}

/* Style: Outline */
.loop-banner-outline {
    background: transparent;
    color: var(--text-dark);
    border: 3px solid #ff7a3d;
}

.loop-banner-outline .loop-banner-btn {
    background: #ff7a3d;
    color: white;
}

/* Format: Vertical */
.loop-banner-vertical .loop-banner-inner {
    flex-direction: column;
    text-align: center;
    padding: 40px;
}

.loop-banner-vertical .loop-banner-image {
    width: 200px;
    height: 150px;
}

/* Format: Compact */
.loop-banner-compact {
    margin: 20px auto;
}

.loop-banner-compact .loop-banner-inner {
    padding: 16px 24px;
    gap: 20px;
}

.loop-banner-compact .loop-banner-title {
    font-size: 16px;
    margin-bottom: 4px;
}

.loop-banner-compact .loop-banner-description {
    font-size: 13px;
    margin-bottom: 0;
}

.loop-banner-compact .loop-banner-btn {
    padding: 8px 16px;
    font-size: 13px;
    white-space: nowrap;
}

.loop-banner-compact .loop-banner-content {
    display: flex;
    align-items: center;
    gap: 16px;
}

/* Format: Hero */
.loop-banner-hero {
    border-radius: 0;
    max-width: none;
    margin: 0;
}

.loop-banner-hero .loop-banner-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 40px;
    justify-content: center;
    text-align: center;
    flex-direction: column;
}

.loop-banner-hero .loop-banner-title {
    font-size: 32px;
}

.loop-banner-hero .loop-banner-description {
    font-size: 18px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* Format: Floating */
.loop-banner-floating {
    position: fixed;
    bottom: 24px;
    right: 24px;
    max-width: 360px;
    margin: 0;
    z-index: 1000;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    animation: slideInBanner 0.5s ease;
}

@keyframes slideInBanner {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

.loop-banner-floating .loop-banner-inner {
    padding: 20px;
    flex-direction: column;
    gap: 12px;
}

.loop-banner-floating .loop-banner-title {
    font-size: 16px;
}

.loop-banner-floating .loop-banner-description {
    font-size: 13px;
}

.loop-banner-floating .loop-banner-image {
    display: none;
}

/* Banner Responsive */
@media (max-width: 768px) {
    .loop-banner {
        margin: 24px 16px;
        border-radius: 16px;
    }

    .loop-banner-inner {
        flex-direction: column;
        padding: 24px;
        gap: 20px;
        text-align: center;
    }

    .loop-banner-image {
        width: 100%;
        height: 140px;
    }

    .loop-banner-title {
        font-size: 20px;
    }

    .loop-banner-compact .loop-banner-inner {
        flex-direction: column;
    }

    .loop-banner-compact .loop-banner-content {
        flex-direction: column;
        gap: 12px;
    }

    .loop-banner-hero .loop-banner-inner {
        padding: 40px 20px;
    }

    .loop-banner-hero .loop-banner-title {
        font-size: 24px;
    }

    .loop-banner-floating {
        bottom: 16px;
        right: 16px;
        left: 16px;
        max-width: none;
    }
}

/* ============================================================================
   USER SPACES - VISUAL COMPONENTS
   ============================================================================ */

/* ===== USER SPACES STRIP - Minimal Floating Icons ===== */
@keyframes usFloatSlow {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@keyframes usFloatMedium {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-12px); }
}

@keyframes usFloatFast {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

.us-strip-section {
    padding: 32px 20px;
    background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%);
    overflow: visible;
}

.us-strip-header {
    text-align: center;
    margin-bottom: 24px;
}

.us-strip-header h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 4px 0;
}

.us-strip-header p {
    font-size: 14px;
    color: var(--text-light);
    margin: 0;
}

.us-strip-track {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
    max-width: 900px;
    margin: 0 auto;
}

.us-strip-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    padding: 16px;
    border-radius: 16px;
    transition: all 0.3s ease;
    animation: usFloatSlow 3s ease-in-out infinite;
}

.us-strip-card:nth-child(2) { animation: usFloatMedium 3.5s ease-in-out infinite 0.3s; }
.us-strip-card:nth-child(3) { animation: usFloatFast 2.8s ease-in-out infinite 0.6s; }
.us-strip-card:nth-child(4) { animation: usFloatSlow 3.2s ease-in-out infinite 0.9s; }
.us-strip-card:nth-child(5) { animation: usFloatMedium 3s ease-in-out infinite 1.2s; }

.us-strip-card:hover {
    animation-play-state: paused;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
    transform: translateY(-4px) scale(1.05);
}

.us-strip-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    font-size: 32px;
    background: linear-gradient(135deg, var(--us-from) 0%, var(--us-to) 100%);
    border-radius: 20px;
    margin-bottom: 10px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
    transition: all 0.3s ease;
}

.us-strip-card:hover .us-strip-icon {
    transform: scale(1.1);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
}

.us-strip-card h4 {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0;
    text-align: center;
    white-space: nowrap;
}

/* Hide scroll and extra elements in minimal mode */
.us-strip-scroll {
    display: none;
}

.us-strip-card-glow,
.us-strip-card-content,
.us-strip-card p,
.us-strip-cta {
    display: none;
}

/* ===== USER SPACES SHOWCASE - Tabs + Screenshots Gallery ===== */
.us-showcase-section {
    padding: 80px 40px;
    background: linear-gradient(180deg, #1a1a2e 0%, #16213e 100%);
    position: relative;
    overflow: hidden;
}

.us-showcase-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: radial-gradient(rgba(255, 151, 96, 0.03) 1px, transparent 1px);
    background-size: 30px 30px;
}

.us-showcase-inner {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.us-showcase-header {
    text-align: center;
    margin-bottom: 40px;
}

.us-showcase-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 100px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 20px;
    backdrop-filter: blur(10px);
}

.us-showcase-header h2 {
    font-size: 36px;
    font-weight: 900;
    color: white;
    margin: 0 0 12px 0;
    line-height: 1.2;
}

.us-showcase-header p {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.7);
    margin: 0 auto;
    max-width: 600px;
    line-height: 1.6;
}

/* Tabs */
.us-showcase-tabs {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.us-showcase-tab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.us-showcase-tab:hover {
    background: rgba(255, 255, 255, 0.12);
    color: white;
}

.us-showcase-tab.active {
    background: linear-gradient(135deg, var(--tab-from) 0%, var(--tab-to) 100%);
    border-color: transparent;
    color: white;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.us-tab-icon {
    font-size: 18px;
}

.us-tab-title {
    display: none;
}

@media (min-width: 768px) {
    .us-tab-title {
        display: inline;
    }
}

/* Gallery Panels */
.us-showcase-gallery {
    position: relative;
}

.us-showcase-panel {
    display: none;
}

.us-showcase-panel.active {
    display: block;
    animation: usFadeIn 0.4s ease;
}

@keyframes usFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.us-panel-content {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 32px;
    align-items: start;
}

/* Panel Info */
.us-panel-info {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 20px;
    padding: 28px;
    backdrop-filter: blur(10px);
}

.us-panel-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    background: linear-gradient(135deg, var(--panel-from) 0%, var(--panel-to) 100%);
    border-radius: 16px;
    margin-bottom: 16px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

.us-panel-info h3 {
    font-size: 20px;
    font-weight: 800;
    color: white;
    margin: 0 0 10px 0;
}

.us-panel-info p {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.6;
    margin: 0 0 16px 0;
}

.us-panel-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}

.us-panel-stats span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
}

.us-panel-stats svg {
    opacity: 0.7;
}

.us-panel-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: linear-gradient(135deg, var(--panel-from) 0%, var(--panel-to) 100%);
    border-radius: 10px;
    color: white;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.3s ease;
}

.us-panel-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

/* Screenshots Carousel */
.us-panel-screenshots {
    position: relative;
    min-height: 400px;
}

.us-screenshots-carousel {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    background: rgba(0, 0, 0, 0.2);
}

.us-carousel-track {
    display: flex;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.us-carousel-slide {
    flex: 0 0 100%;
    padding: 16px;
}

.us-screenshot-frame {
    background: #1a1a2e;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.4);
}

.us-frame-header {
    display: flex;
    gap: 6px;
    padding: 10px 14px;
    background: rgba(0, 0, 0, 0.3);
}

.us-frame-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
}

.us-frame-dot:first-child { background: #ff5f57; }
.us-frame-dot:nth-child(2) { background: #ffbd2e; }
.us-frame-dot:nth-child(3) { background: #28ca42; }

.us-screenshot-frame img {
    display: block;
    width: 100%;
    height: auto;
}

/* Carousel Navigation */
.us-carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.15);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    z-index: 2;
}

.us-carousel-nav:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: translateY(-50%) scale(1.1);
}

.us-carousel-prev { left: 24px; }
.us-carousel-next { right: 24px; }

.us-carousel-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 16px 0;
}

.us-carousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
}

.us-carousel-dot.active {
    background: white;
    transform: scale(1.2);
}

.us-carousel-dot:hover {
    background: rgba(255, 255, 255, 0.6);
}

/* Placeholder when no screenshots */
.us-screenshots-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    background: rgba(255, 255, 255, 0.04);
    border: 2px dashed rgba(255, 255, 255, 0.1);
    border-radius: 16px;
}

.us-placeholder-icon {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    border-radius: 20px;
    margin-bottom: 16px;
    opacity: 0.7;
}

.us-screenshots-placeholder p {
    color: rgba(255, 255, 255, 0.5);
    font-size: 14px;
    margin: 0;
}

/* Responsive */
@media (max-width: 900px) {
    .us-panel-content {
        grid-template-columns: 1fr;
    }

    .us-panel-info {
        order: 2;
    }

    .us-panel-screenshots {
        order: 1;
        min-height: 280px;
    }
}

/* ===== USER SPACES CONTEXTUAL BANNER ===== */
.us-contextual {
    background: white;
    border-radius: 20px;
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.us-contextual-header h4 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 16px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.us-contextual-header svg {
    color: var(--primary);
}

.us-contextual-cards {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.us-contextual-horizontal .us-contextual-cards {
    flex-direction: row;
    gap: 12px;
}

.us-contextual-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: linear-gradient(135deg, rgba(var(--us-from), 0.08), rgba(var(--us-to), 0.05));
    border: 2px solid transparent;
    border-radius: 14px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.us-contextual-card:hover {
    background: white;
    border-color: var(--us-from);
    transform: translateX(4px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.us-contextual-icon {
    font-size: 28px;
}

.us-contextual-title {
    flex: 1;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
}

.us-contextual-card svg {
    color: var(--us-from);
    opacity: 0;
    transform: translateX(-4px);
    transition: all 0.3s ease;
}

.us-contextual-card:hover svg {
    opacity: 1;
    transform: translateX(0);
}

/* ===== USER SPACES WIDGET ===== */
.us-widget {
    background: white;
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.us-widget-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.us-widget-icon {
    font-size: 24px;
}

.us-widget-header h5 {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0;
}

.us-widget-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.us-widget-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.us-widget-item:hover {
    background: #f8f9fa;
}

.us-widget-item-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 18px;
    color: white;
}

.us-widget-item-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-dark);
}

/* ============================================================================
   SINGLE USER SPACE PAGE
   ============================================================================ */

/* Hero */
.usp-hero {
    position: relative;
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.usp-hero-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.usp-hero-gradient {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--usp-from) 0%, var(--usp-to) 100%);
}

.usp-hero-pattern {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: radial-gradient(rgba(255, 255, 255, 0.1) 1px, transparent 1px);
    background-size: 24px 24px;
}

/* Floating Shapes */
.usp-hero-shapes {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.usp-shape {
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
}

.usp-shape-1 {
    width: 400px;
    height: 400px;
    top: -100px;
    right: -100px;
    animation: usp-float 20s ease-in-out infinite;
}

.usp-shape-2 {
    width: 300px;
    height: 300px;
    bottom: 10%;
    left: -80px;
    animation: usp-float 15s ease-in-out infinite reverse;
}

.usp-shape-3 {
    width: 200px;
    height: 200px;
    top: 30%;
    right: 15%;
    background: rgba(255, 255, 255, 0.08);
    animation: usp-float 18s ease-in-out infinite;
}

.usp-shape-4 {
    width: 150px;
    height: 150px;
    bottom: 20%;
    right: 30%;
    background: rgba(255, 255, 255, 0.05);
    animation: usp-float 12s ease-in-out infinite reverse;
}

.usp-shape-ring {
    width: 600px;
    height: 600px;
    bottom: -200px;
    left: 20%;
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.08);
    animation: usp-rotate 40s linear infinite;
}

@keyframes usp-float {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-30px) scale(1.05); }
}

@keyframes usp-rotate {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.usp-hero-content {
    position: relative;
    z-index: 10;
    width: 100%;
    padding: 60px;
    padding-bottom: 120px;
}

.usp-hero-inner {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

/* Floating Icon */
.usp-hero-icon-wrap {
    position: relative;
    display: inline-block;
    margin-bottom: 32px;
}

.usp-hero-icon-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 150px;
    height: 150px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.3), transparent 70%);
    animation: usp-glow 3s ease-in-out infinite;
}

@keyframes usp-glow {
    0%, 100% { opacity: 0.5; transform: translate(-50%, -50%) scale(1); }
    50% { opacity: 1; transform: translate(-50%, -50%) scale(1.2); }
}

.usp-hero-icon {
    position: relative;
    font-size: 80px;
    display: block;
    filter: drop-shadow(0 10px 30px rgba(0, 0, 0, 0.2));
}

.usp-hero h1 {
    font-size: 56px;
    font-weight: 900;
    color: white;
    margin: 0 0 20px 0;
    text-shadow: 0 4px 30px rgba(0, 0, 0, 0.2);
}

.usp-hero-subtitle {
    font-size: 22px;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.6;
    margin: 0 0 40px 0;
}

/* Stats */
.usp-hero-stats {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
    margin-bottom: 40px;
}

.usp-stat {
    text-align: center;
}

.usp-stat-value {
    display: block;
    font-size: 36px;
    font-weight: 900;
    color: white;
}

.usp-stat-label {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.8);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.usp-stat-divider {
    width: 1px;
    height: 50px;
    background: rgba(255, 255, 255, 0.3);
}

/* Actions */
.usp-hero-actions {
    display: flex;
    justify-content: center;
    gap: 16px;
}

.usp-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 32px;
    border-radius: 100px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.usp-action-primary {
    background: white;
    color: var(--usp-from);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.usp-action-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

.usp-action-secondary {
    background: rgba(255, 255, 255, 0.15);
    border: 2px solid rgba(255, 255, 255, 0.4);
    color: white;
    backdrop-filter: blur(10px);
}

.usp-action-secondary:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* Wave */
.usp-hero-wave {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 5;
}

.usp-hero-wave svg {
    display: block;
    width: 100%;
    height: 80px;
}

/* Quick Nav */
.usp-quick-nav {
    padding: 0 60px;
    margin-top: -40px;
    position: relative;
    z-index: 20;
}

.usp-quick-nav-inner {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 24px 32px;
    background: white;
    border-radius: 24px;
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.1);
    max-width: 900px;
    margin: 0 auto;
}

.usp-quick-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background: #f8f9fa;
    border-radius: 100px;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.usp-quick-item:hover {
    background: white;
    border-color: var(--item-from);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.usp-quick-item.active {
    background: linear-gradient(135deg, var(--item-from) 0%, var(--item-to) 100%);
    color: white;
}

.usp-quick-icon {
    font-size: 20px;
}

.usp-quick-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-dark);
}

.usp-quick-item.active .usp-quick-title {
    color: white;
}

/* Content Section */
.usp-content-section {
    padding: 80px 60px;
    background: #f8f9fa;
}

.usp-content-inner {
    max-width: 900px;
    margin: 0 auto;
}

.usp-content-card {
    background: white;
    border-radius: 24px;
    padding: 48px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.06);
}

.usp-content-header {
    margin-bottom: 32px;
}

.usp-content-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: linear-gradient(135deg, var(--badge-from) 0%, var(--badge-to) 100%);
    border-radius: 100px;
    font-size: 14px;
    font-weight: 600;
    color: white;
    margin-bottom: 16px;
}

.usp-content-header h2 {
    font-size: 32px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0;
}

/* Remove box styling from kf-description inside content card */
.usp-content-body .kf-description {
    background: transparent;
    padding: 0;
    box-shadow: none;
    border-radius: 0;
}

/* Modules Section */
.usp-modules-section {
    padding: 100px 60px;
    background: white;
}

.usp-modules-inner {
    max-width: 1400px;
    margin: 0 auto;
}

.usp-modules-header {
    text-align: center;
    margin-bottom: 60px;
}

.usp-modules-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1), rgba(255, 122, 61, 0.05));
    border-radius: 100px;
    color: var(--primary);
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 20px;
}

.usp-modules-header h2 {
    font-size: 40px;
    font-weight: 900;
    color: var(--text-dark);
    margin: 0 0 16px 0;
}

.usp-modules-header p {
    font-size: 18px;
    color: var(--text);
    margin: 0;
}

.usp-modules-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 320px;
    gap: 24px;
}

.usp-module-card {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: #f8f9fa;
}

.usp-module-featured {
    grid-column: span 2;
    grid-row: span 2;
}

.usp-module-link {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
}

.usp-module-image {
    position: relative;
    height: 180px;
    overflow: hidden;
}

.usp-module-featured .usp-module-image {
    height: 350px;
}

.usp-module-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.usp-module-card:hover .usp-module-image img {
    transform: scale(1.08);
}

.usp-module-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.7) 100%);
}

.usp-module-number {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 8px 14px;
    background: var(--mod-color);
    color: white;
    font-size: 13px;
    font-weight: 800;
    border-radius: 100px;
}

.usp-module-content {
    padding: 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.usp-module-featured .usp-module-content {
    padding: 32px;
}

.usp-module-subtitle {
    font-size: 12px;
    font-weight: 600;
    color: var(--mod-color);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
}

.usp-module-content h3 {
    font-size: 18px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 10px 0;
}

.usp-module-featured h3 {
    font-size: 26px;
}

.usp-module-content p {
    font-size: 14px;
    color: var(--text);
    line-height: 1.6;
    margin: 0 0 auto 0;
}

.usp-module-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    font-size: 14px;
    font-weight: 600;
    color: var(--mod-color);
}

.usp-module-cta svg {
    transition: transform 0.3s ease;
}

.usp-module-card:hover .usp-module-cta svg {
    transform: translateX(4px);
}

/* Others Section */
.usp-others-section {
    padding: 80px 60px;
    background: #f8f9fa;
}

.usp-others-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.usp-others-header {
    text-align: center;
    margin-bottom: 40px;
}

.usp-others-header h3 {
    font-size: 28px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 8px 0;
}

.usp-others-header p {
    font-size: 16px;
    color: var(--text);
    margin: 0;
}

.usp-others-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.usp-other-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: white;
    border-radius: 20px;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.usp-other-card:hover {
    border-color: var(--other-from);
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

.usp-other-icon-wrap {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--other-from) 0%, var(--other-to) 100%);
    border-radius: 16px;
    flex-shrink: 0;
}

.usp-other-icon {
    font-size: 28px;
}

.usp-other-content {
    flex: 1;
    min-width: 0;
}

.usp-other-content h4 {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 4px 0;
}

.usp-other-content p {
    font-size: 13px;
    color: var(--text);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.usp-other-arrow {
    color: var(--other-from);
    opacity: 0;
    transform: translateX(-8px);
    transition: all 0.3s ease;
}

.usp-other-card:hover .usp-other-arrow {
    opacity: 1;
    transform: translateX(0);
}

/* CTA Section */
.usp-cta-section {
    padding: 100px 60px;
}

.usp-cta-inner {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
    padding: 60px;
    border-radius: 32px;
    text-align: center;
    overflow: hidden;
}

.usp-cta-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--cta-from) 0%, var(--cta-to) 100%);
}

.usp-cta-pattern {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: radial-gradient(rgba(255, 255, 255, 0.15) 1px, transparent 1px);
    background-size: 20px 20px;
}

.usp-cta-glow {
    position: absolute;
    top: -50%;
    right: -20%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.2), transparent 70%);
    border-radius: 50%;
}

.usp-cta-content {
    position: relative;
    z-index: 1;
}

.usp-cta-icon {
    font-size: 56px;
    display: block;
    margin-bottom: 20px;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.2));
}

.usp-cta-content h3 {
    font-size: 32px;
    font-weight: 900;
    color: white;
    margin: 0 0 16px 0;
}

.usp-cta-content p {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.9);
    margin: 0 0 32px 0;
    line-height: 1.6;
}

.usp-cta-actions {
    display: flex;
    justify-content: center;
    gap: 16px;
}

.usp-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 32px;
    border-radius: 100px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
}

.usp-cta-primary {
    background: white;
    color: var(--cta-from);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.usp-cta-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

.usp-cta-secondary {
    background: rgba(255, 255, 255, 0.15);
    border: 2px solid rgba(255, 255, 255, 0.4);
    color: white;
}

.usp-cta-secondary:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* ===== USER SPACES RESPONSIVE ===== */
@media (max-width: 1200px) {
    .us-showcase-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .us-showcase-featured {
        grid-column: span 2;
        grid-row: span 1;
    }

    .usp-modules-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .usp-module-featured {
        grid-column: span 2;
        grid-row: span 1;
    }

    .usp-others-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .us-strip-header {
        padding: 0 20px;
    }

    .us-strip-track {
        padding: 0 20px;
    }

    .us-strip-card {
        width: 260px;
        min-width: 260px;
    }

    .us-showcase-section {
        padding: 60px 20px;
    }

    .us-showcase-header h2 {
        font-size: 32px;
    }

    .us-showcase-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: 280px;
    }

    .us-showcase-featured {
        grid-column: span 1;
    }

    .usp-hero h1 {
        font-size: 36px;
    }

    .usp-hero-icon {
        font-size: 56px;
    }

    .usp-hero-subtitle {
        font-size: 18px;
    }

    .usp-hero-content {
        padding: 40px 20px 100px;
    }

    .usp-hero-stats {
        flex-direction: column;
        gap: 20px;
    }

    .usp-stat-divider {
        width: 80px;
        height: 1px;
    }

    .usp-hero-actions {
        flex-direction: column;
    }

    .usp-quick-nav {
        padding: 0 20px;
        margin-top: -30px;
    }

    .usp-quick-nav-inner {
        padding: 16px;
    }

    .usp-quick-item {
        padding: 10px 16px;
    }

    .usp-quick-title {
        font-size: 12px;
    }

    .usp-content-section,
    .usp-modules-section,
    .usp-others-section,
    .usp-cta-section {
        padding: 60px 20px;
    }

    .usp-content-card {
        padding: 28px 20px;
    }

    .usp-modules-header h2 {
        font-size: 28px;
    }

    .usp-modules-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
    }

    .usp-module-featured {
        grid-column: span 1;
        grid-row: span 1;
    }

    .usp-module-featured .usp-module-image {
        height: 200px;
    }

    .usp-others-grid {
        grid-template-columns: 1fr;
    }

    .usp-cta-inner {
        padding: 40px 24px;
    }

    .usp-cta-content h3 {
        font-size: 24px;
    }

    .usp-cta-actions {
        flex-direction: column;
    }

    /* Reduce shapes on mobile */
    .usp-shape-1, .usp-shape-3, .usp-shape-4 {
        display: none;
    }

    .usp-shape-2 {
        width: 200px;
        height: 200px;
    }

    .usp-shape-ring {
        width: 300px;
        height: 300px;
    }
}

/* ==========================================================================
   User Space Screenshots Showcase - Prominent Display
   ========================================================================== */

.usp-screenshots-showcase {
    padding: 60px 20px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.usp-screenshots-showcase-inner {
    max-width: 1100px;
    margin: 0 auto;
}

.usp-showcase-header {
    text-align: center;
    margin-bottom: 32px;
}

.usp-showcase-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: linear-gradient(135deg, var(--usp-from) 0%, var(--usp-to) 100%);
    color: white;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 16px;
}

.usp-showcase-header h2 {
    font-size: 28px;
    font-weight: 800;
    margin: 0;
    color: #0f172a;
}

/* Main Screenshot Frame */
.usp-showcase-main {
    margin-bottom: 20px;
}

.usp-main-frame {
    border-radius: 16px;
    overflow: hidden;
    background: #1a1a2e;
    box-shadow: 0 30px 60px -15px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(0, 0, 0, 0.1);
}

.usp-frame-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 20px;
    background: linear-gradient(to bottom, #2a2a4a, #1a1a2e);
}

.usp-control-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.usp-control-dot.red { background: #ff5f57; }
.usp-control-dot.yellow { background: #ffbd2e; }
.usp-control-dot.green { background: #28ca42; }

.usp-frame-title {
    margin-left: 16px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.6);
    font-weight: 500;
}

.usp-main-image-wrap {
    position: relative;
}

.usp-main-image {
    display: block;
    width: 100%;
    height: auto;
    transition: transform 0.4s ease;
}

.usp-main-image:hover {
    transform: scale(1.01);
}

.usp-fullscreen-btn {
    position: absolute;
    bottom: 20px;
    right: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    border: none;
    border-radius: 12px;
    color: #1a1a2e;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.usp-fullscreen-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
}

/* Thumbnails Strip */
.usp-thumbnails-strip {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    padding: 0 20px;
}

.usp-thumbnail {
    position: relative;
    width: 120px;
    height: 80px;
    border-radius: 10px;
    overflow: hidden;
    border: 3px solid transparent;
    background: #e2e8f0;
    cursor: pointer;
    transition: all 0.3s ease;
}

.usp-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.usp-thumbnail:hover {
    border-color: rgba(0, 0, 0, 0.2);
    transform: translateY(-4px);
}

.usp-thumbnail.active {
    border-color: var(--usp-from);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.usp-thumb-number {
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    font-size: 11px;
    font-weight: 700;
    border-radius: 6px;
}

/* Responsive */
@media (max-width: 768px) {
    .usp-screenshots-showcase {
        padding: 40px 16px;
    }

    .usp-showcase-header h2 {
        font-size: 22px;
    }

    .usp-fullscreen-btn {
        padding: 10px 16px;
        font-size: 12px;
    }

    .usp-thumbnail {
        width: 80px;
        height: 55px;
    }

    .usp-thumb-number {
        width: 18px;
        height: 18px;
        font-size: 10px;
    }
}

/* ==========================================================================
   User Space Screenshots Gallery (Legacy - kept for compatibility)
   ========================================================================== */

.usp-screenshots-section {
    padding: 80px 0;
    background: #f8fafc;
}

.usp-screenshots-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 40px;
}

.usp-screenshots-header {
    text-align: center;
    margin-bottom: 50px;
}

.usp-screenshots-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    background: linear-gradient(135deg, var(--badge-from) 0%, var(--badge-to) 100%);
    color: white;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 20px;
}

.usp-screenshots-header h2 {
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 12px 0;
    color: #0f172a;
}

.usp-screenshots-header p {
    font-size: 18px;
    color: #64748b;
    margin: 0;
}

/* Screenshots Grid */
.usp-screenshots-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.usp-screenshots-grid.single {
    grid-template-columns: 1fr;
    max-width: 900px;
    margin: 0 auto;
}

.usp-screenshots-grid.duo {
    grid-template-columns: repeat(2, 1fr);
    max-width: 1100px;
    margin: 0 auto;
}

.usp-screenshot-item {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.usp-screenshot-item.featured {
    grid-column: span 2;
    grid-row: span 2;
}

.usp-screenshots-grid.single .usp-screenshot-item.featured,
.usp-screenshots-grid.duo .usp-screenshot-item.featured {
    grid-column: span 1;
    grid-row: span 1;
}

/* Screenshot Frame - Browser mockup */
.usp-screenshot-frame {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    background: white;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    transition: all 0.4s ease;
}

.usp-screenshot-item:hover .usp-screenshot-frame {
    transform: translateY(-8px);
    box-shadow: 0 35px 60px -15px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(0, 0, 0, 0.05);
}

.usp-screenshot-browser {
    display: flex;
    gap: 6px;
    padding: 12px 16px;
    background: linear-gradient(to bottom, #f8fafc, #f1f5f9);
    border-bottom: 1px solid #e2e8f0;
}

.usp-browser-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #e2e8f0;
}

.usp-browser-dot:first-child {
    background: #fca5a5;
}

.usp-browser-dot:nth-child(2) {
    background: #fcd34d;
}

.usp-browser-dot:nth-child(3) {
    background: #86efac;
}

.usp-screenshot-img {
    width: 100%;
    height: auto;
    display: block;
    cursor: zoom-in;
    transition: transform 0.4s ease;
}

.usp-screenshot-item:hover .usp-screenshot-img {
    transform: scale(1.02);
}

.usp-screenshot-zoom {
    position: absolute;
    bottom: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(8px);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.3s ease;
    color: #334155;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.usp-screenshot-item:hover .usp-screenshot-zoom {
    opacity: 1;
    transform: translateY(0);
}

.usp-screenshot-zoom:hover {
    background: #ff9760;
    color: white;
}

.usp-screenshot-caption {
    font-size: 13px;
    color: #64748b;
    text-align: center;
    font-weight: 500;
}

/* Lightbox */
.usp-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.usp-lightbox.active {
    opacity: 1;
    visibility: visible;
}

.usp-lightbox-content {
    max-width: 90vw;
    max-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.usp-lightbox-content img {
    max-width: 100%;
    max-height: 85vh;
    object-fit: contain;
    border-radius: 12px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

.usp-lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    border: 2px solid rgba(255, 255, 255, 0.2);
    color: white;
    font-size: 28px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.usp-lightbox-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

.usp-lightbox-prev,
.usp-lightbox-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    border: 2px solid rgba(255, 255, 255, 0.2);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.usp-lightbox-prev {
    left: 30px;
}

.usp-lightbox-next {
    right: 30px;
}

.usp-lightbox-prev:hover,
.usp-lightbox-next:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-50%) scale(1.1);
}

.usp-lightbox-counter {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 24px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50px;
    backdrop-filter: blur(8px);
}

/* Screenshots Responsive */
@media (max-width: 1024px) {
    .usp-screenshots-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .usp-screenshot-item.featured {
        grid-column: span 2;
        grid-row: span 1;
    }
}

@media (max-width: 768px) {
    .usp-screenshots-section {
        padding: 60px 20px;
    }

    .usp-screenshots-header h2 {
        font-size: 28px;
    }

    .usp-screenshots-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .usp-screenshot-item.featured {
        grid-column: span 1;
    }

    .usp-lightbox-prev,
    .usp-lightbox-next {
        width: 44px;
        height: 44px;
    }

    .usp-lightbox-prev {
        left: 15px;
    }

    .usp-lightbox-next {
        right: 15px;
    }

    .usp-lightbox-close {
        top: 15px;
        right: 15px;
        width: 44px;
        height: 44px;
        font-size: 24px;
    }
}

/* ======================================
   SHARED SCREENSHOT BROWSER COMPONENT
   Reusable browser-style screenshot viewer
   ====================================== */

.loop-screenshots-browser {
    padding: 60px 20px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.loop-browser-inner {
    max-width: 1100px;
    margin: 0 auto;
}

.loop-browser-header {
    text-align: center;
    margin-bottom: 32px;
}

.loop-browser-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, var(--browser-from, #ff9760) 0%, var(--browser-to, #ff7a3d) 100%);
    color: white;
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 16px;
}

.loop-browser-badge svg {
    width: 16px;
    height: 16px;
}

.loop-browser-header h2 {
    font-size: 28px;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0;
}

/* Browser Frame */
.loop-browser-frame {
    background: #1a1a2e;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2),
                0 8px 24px rgba(0, 0, 0, 0.1);
}

.loop-browser-toolbar {
    display: flex;
    align-items: center;
    padding: 14px 18px;
    background: linear-gradient(180deg, #2d2d44 0%, #252538 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.loop-browser-controls {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.loop-browser-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.loop-dot-red {
    background: #ff5f57;
}

.loop-dot-yellow {
    background: #febc2e;
}

.loop-dot-green {
    background: #28c840;
}

.loop-browser-logo {
    margin-left: 20px;
    flex-shrink: 0;
}

.loop-browser-logo img {
    height: 24px;
    width: auto;
    display: block;
    filter: brightness(0) invert(1);
    opacity: 0.9;
}

.loop-browser-title {
    flex: 1;
    text-align: center;
    margin: 0 20px;
}

.loop-browser-title span {
    color: rgba(255, 255, 255, 0.7);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.3px;
}

.loop-browser-viewport {
    position: relative;
    background: #f0f0f0;
    overflow: hidden;
}

.loop-browser-main-image {
    width: 100%;
    height: auto;
    display: block;
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='14' fill='%23ff9760' stroke='%23fff' stroke-width='2'/%3E%3Cpath d='M11 16h10M16 11v10' stroke='%23fff' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E"), zoom-in;
    transition: transform 0.3s ease;
}

.loop-browser-viewport:hover .loop-browser-main-image {
    transform: scale(1.01);
}

.loop-browser-fullscreen {
    position: absolute;
    bottom: 20px;
    right: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(26, 26, 46, 0.9);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: white;
    padding: 10px 18px;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.loop-browser-fullscreen:hover {
    background: linear-gradient(135deg, var(--browser-from, #ff9760) 0%, var(--browser-to, #ff7a3d) 100%);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 151, 96, 0.4);
}

.loop-browser-fullscreen svg {
    width: 18px;
    height: 18px;
}

/* Thumbnails */
.loop-browser-thumbnails {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

.loop-browser-thumb {
    position: relative;
    width: 100px;
    height: 70px;
    border-radius: 10px;
    overflow: hidden;
    border: 3px solid transparent;
    background: #e0e0e0;
    cursor: pointer;
    transition: all 0.3s ease;
}

.loop-browser-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.loop-browser-thumb:hover {
    border-color: rgba(255, 151, 96, 0.5);
    transform: translateY(-3px);
}

.loop-browser-thumb.active {
    border-color: var(--browser-from, #ff9760);
    box-shadow: 0 4px 15px rgba(255, 151, 96, 0.3);
}

.loop-thumb-number {
    position: absolute;
    bottom: 4px;
    right: 4px;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 6px;
}

/* Lightbox */
.loop-browser-lightbox {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.95);
    z-index: 99999;
    justify-content: center;
    align-items: center;
}

.loop-browser-lightbox.active {
    display: flex;
}

.loop-lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: white;
    font-size: 28px;
    cursor: pointer;
    transition: all 0.3s ease;
    z-index: 10;
}

.loop-lightbox-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

.loop-lightbox-content {
    max-width: 90%;
    max-height: 85vh;
}

.loop-lightbox-image {
    max-width: 100%;
    max-height: 85vh;
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.loop-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 54px;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.loop-lightbox-nav:hover {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    transform: translateY(-50%) scale(1.1);
}

.loop-lightbox-prev {
    left: 30px;
}

.loop-lightbox-next {
    right: 30px;
}

.loop-lightbox-counter {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(10px);
    color: white;
    padding: 10px 20px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
}

/* Custom Cursor for screenshots */
.loop-browser-viewport,
.loop-browser-thumb,
.usp-main-image-wrap,
.usp-thumbnail img,
.feature-screenshot-wrapper,
.mod-screenshot-viewport {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='14' fill='%23ff9760' stroke='%23fff' stroke-width='2'/%3E%3Cpath d='M11 16h10M16 11v10' stroke='%23fff' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E"), zoom-in;
}

/* Responsive */
@media (max-width: 768px) {
    .loop-screenshots-browser {
        padding: 40px 16px;
    }

    .loop-browser-header h2 {
        font-size: 22px;
    }

    .loop-browser-frame {
        border-radius: 12px;
    }

    .loop-browser-toolbar {
        padding: 10px 14px;
    }

    .loop-browser-dot {
        width: 10px;
        height: 10px;
    }

    .loop-browser-logo {
        display: none;
    }

    .loop-browser-fullscreen span {
        display: none;
    }

    .loop-browser-fullscreen {
        padding: 10px;
        border-radius: 50%;
    }

    .loop-browser-thumbnails {
        gap: 8px;
    }

    .loop-browser-thumb {
        width: 70px;
        height: 50px;
        border-width: 2px;
    }

    .loop-lightbox-nav {
        width: 44px;
        height: 44px;
    }

    .loop-lightbox-prev {
        left: 15px;
    }

    .loop-lightbox-next {
        right: 15px;
    }
}

/* ============================================================================
   CONTACT PAGE STYLES
   ============================================================================ */

.contact-page {
    padding-top: 85px;
}

.contact-hero {
    padding: 80px 0 60px;
    text-align: center;
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.contact-hero .container {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 24px;
}

.contact-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.1) 100%);
    border: 1px solid rgba(255, 122, 61, 0.2);
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--primary-dark);
    margin-bottom: 24px;
}

.contact-hero h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 800;
    color: var(--secondary);
    margin-bottom: 20px;
    line-height: 1.2;
}

.contact-hero-subtitle {
    font-size: 1.1rem;
    color: var(--text-light);
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto;
}

.contact-content {
    padding: 60px 0 100px;
}

.contact-content .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 60px;
    align-items: start;
}

/* Contact Form Section */
.contact-form-section {
    background: #fff;
    border-radius: 24px;
    padding: 40px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    border: 1px solid rgba(0,0,0,0.05);
}

/* Contact Sidebar */
.contact-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact-info-card {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    border: 1px solid rgba(0,0,0,0.05);
}

.contact-info-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.15) 100%);
    border-radius: 12px;
    color: var(--primary-dark);
    margin-bottom: 16px;
}

.contact-info-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 8px;
}

.contact-info-card p {
    color: var(--text);
    font-size: 0.95rem;
    margin-bottom: 0;
}

.contact-info-card a {
    color: var(--primary-dark);
    text-decoration: none;
    font-weight: 600;
}

.contact-info-card a:hover {
    text-decoration: underline;
}

.contact-hours {
    display: block;
    font-size: 0.8rem;
    color: var(--text-light);
    margin-top: 4px;
}

.contact-info-demo {
    background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
    border-color: rgba(255, 122, 61, 0.3);
    color: #fff;
}

.contact-info-demo h3 {
    color: #fff;
}

.contact-info-demo p {
    color: rgba(255,255,255,0.9);
}

.contact-info-demo .contact-info-icon {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.contact-info-demo .btn {
    margin-top: 16px;
    width: 100%;
    justify-content: center;
    background: #fff;
    color: var(--primary-dark);
}

.contact-info-demo .btn:hover {
    background: rgba(255,255,255,0.9);
}

.contact-info-webinar {
    background: linear-gradient(135deg, #1e2334 0%, #2a3042 100%);
    color: #fff;
}

.contact-info-webinar h3 {
    color: #fff;
    font-size: 1.1rem;
}

.contact-info-webinar p {
    color: rgba(255,255,255,0.8);
}

.contact-webinar-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: rgba(34, 197, 94, 0.2);
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #22c55e;
    margin-bottom: 12px;
}

.contact-webinar-badge .pulse {
    width: 8px;
    height: 8px;
    background: #22c55e;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.contact-webinar-date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    margin-top: 8px;
}

.contact-info-webinar .btn-outline {
    margin-top: 16px;
    width: 100%;
    justify-content: center;
    background: transparent;
    border: 2px solid rgba(255,255,255,0.3);
    color: #fff;
}

.contact-info-webinar .btn-outline:hover {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.5);
}

/* Video Presentation Card */
.contact-info-video {
    background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
    border-color: rgba(59, 130, 246, 0.3);
    color: #fff;
}

.contact-info-video h3 {
    color: #fff;
}

.contact-info-video p {
    color: rgba(255,255,255,0.9);
    font-size: 0.9rem;
    margin-bottom: 16px;
}

.contact-info-video .contact-info-icon {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.contact-info-video .btn-outline {
    width: 100%;
    justify-content: center;
    background: transparent;
    border: 2px solid rgba(255,255,255,0.4);
    color: #fff;
    display: flex;
    align-items: center;
}

.contact-info-video .btn-outline:hover {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.6);
}

/* ============================================================================
   CONTACT FORM STYLES
   ============================================================================ */

.loop-contact-form {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-group-full {
    grid-column: 1 / -1;
}

.form-group label {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--secondary);
}

.form-group label .required {
    color: #ef4444;
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: 14px 16px;
    border: 2px solid #e2e8f0;
    border-radius: 12px;
    font-size: 0.95rem;
    font-family: inherit;
    color: var(--secondary);
    background: #fff;
    transition: all 0.2s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(255, 122, 61, 0.1);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #94a3b8;
}

.form-group textarea {
    resize: vertical;
    min-height: 140px;
}

/* Predefined Messages */
.predefined-messages {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.predefined-label {
    font-size: 0.8rem;
    color: var(--text-light);
    width: 100%;
    margin-bottom: 4px;
}

.predefined-msg-btn {
    padding: 6px 12px;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: 0.8rem;
    color: var(--text);
    cursor: pointer;
    transition: all 0.2s;
}

.predefined-msg-btn:hover {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

/* Form Consent */
.form-consent {
    background: #f8fafc;
    padding: 16px;
    border-radius: 12px;
}

.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text);
    line-height: 1.5;
}

.checkbox-label input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin: 0;
    accent-color: var(--primary);
    flex-shrink: 0;
}

.checkbox-label a {
    color: var(--primary-dark);
}

/* Form Actions */
.form-actions {
    display: flex;
    justify-content: flex-end;
}

.form-actions .btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 32px;
    font-size: 1rem;
}

.form-actions .btn .btn-loading {
    display: none;
}

.form-actions .btn.loading .btn-text,
.form-actions .btn.loading .btn-arrow {
    display: none;
}

.form-actions .btn.loading .btn-loading {
    display: flex;
    align-items: center;
    gap: 8px;
}

.form-actions .btn .spinner {
    width: 20px;
    height: 20px;
}

/* Form Messages */
.form-message {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 20px;
    border-radius: 12px;
    animation: slideUp 0.3s ease;
}

.form-success {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(34, 197, 94, 0.05) 100%);
    border: 1px solid rgba(34, 197, 94, 0.2);
}

.form-success strong {
    color: #166534;
}

.form-success p {
    color: #15803d;
    margin: 4px 0 0;
    font-size: 0.9rem;
}

.form-error {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.1) 0%, rgba(239, 68, 68, 0.05) 100%);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

.form-error strong {
    color: #991b1b;
}

.form-error p {
    color: #b91c1c;
    margin: 4px 0 0;
    font-size: 0.9rem;
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ============================================================================
   WEBINAIRES PAGE STYLES
   ============================================================================ */

.webinaires-page {
    padding-top: 85px;
}

.webinaires-hero {
    padding: 80px 0 60px;
    text-align: center;
    background: linear-gradient(180deg, #1e2334 0%, #2a3042 100%);
    color: #fff;
}

.webinaires-hero .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px;
}

.webinaires-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 50px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #fff;
    margin-bottom: 24px;
}

.live-indicator {
    width: 10px;
    height: 10px;
    background: #22c55e;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.webinaires-hero h1 {
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 800;
    margin-bottom: 20px;
    line-height: 1.2;
}

.webinaires-hero-subtitle {
    font-size: 1.15rem;
    color: rgba(255,255,255,0.8);
    line-height: 1.7;
    max-width: 700px;
    margin: 0 auto 40px;
}

.webinaires-hero-stats {
    display: flex;
    justify-content: center;
    gap: 48px;
}

.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.stat-icon {
    font-size: 1.5rem;
    margin-bottom: 4px;
}

.stat-value {
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--primary);
}

.stat-label {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.6);
}

/* Webinar Calendar Section */
.webinaires-calendar-section {
    padding: 80px 0;
    background: #f8fafc;
}

.webinaires-calendar-section .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Webinar Calendar Component */
.webinar-calendar-section {
    /* Container from shortcode */
}

.webinar-calendar-header {
    text-align: center;
    margin-bottom: 48px;
}

.webinar-calendar-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.1) 100%);
    border: 1px solid rgba(255, 122, 61, 0.2);
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--primary-dark);
    margin-bottom: 20px;
}

.webinar-calendar-header h2 {
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    font-weight: 800;
    color: var(--secondary);
    margin-bottom: 16px;
}

.webinar-calendar-header p {
    font-size: 1.1rem;
    color: var(--text-light);
    max-width: 600px;
    margin: 0 auto;
}

/* Empty State */
.webinar-calendar-empty {
    text-align: center;
    padding: 60px 20px;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}

.empty-icon {
    font-size: 4rem;
    margin-bottom: 20px;
}

.webinar-calendar-empty h3 {
    font-size: 1.3rem;
    color: var(--secondary);
    margin-bottom: 12px;
}

.webinar-calendar-empty p {
    color: var(--text-light);
    margin-bottom: 24px;
}

/* Webinar Cards Grid */
.webinar-calendar-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.webinar-card {
    display: grid;
    grid-template-columns: 100px 1fr auto;
    gap: 24px;
    align-items: center;
    background: #fff;
    border-radius: 20px;
    padding: 24px 32px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    border: 1px solid rgba(0,0,0,0.05);
    transition: all 0.3s ease;
}

.webinar-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.1);
}

.webinar-card.webinar-full {
    opacity: 0.7;
}

.webinar-card-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
    border-radius: 16px;
    color: #fff;
}

.date-day {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}

.date-month {
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.webinar-card-content {
    min-width: 0;
}

.webinar-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.webinar-card-header h3 {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--secondary);
    margin: 0;
}

.webinar-badge {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.webinar-badge-open {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(34, 197, 94, 0.15) 100%);
    color: #166534;
}

.webinar-badge-full {
    background: #f1f5f9;
    color: #64748b;
}

.webinar-description {
    font-size: 0.9rem;
    color: var(--text-light);
    margin-bottom: 12px;
    line-height: 1.5;
}

.webinar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.webinar-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text);
}

.webinar-meta-item svg {
    color: var(--text-light);
}

.webinar-card-action {
    flex-shrink: 0;
}

.webinar-card-action .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

/* Webinar Modal */
.webinar-modal {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.webinar-modal.active {
    opacity: 1;
    visibility: visible;
}

.webinar-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
}

.webinar-modal-content {
    position: relative;
    width: 100%;
    max-width: 560px;
    background: #fff;
    border-radius: 24px;
    padding: 40px;
    box-shadow: 0 25px 80px rgba(0,0,0,0.3);
    transform: scale(0.95) translateY(20px);
    transition: transform 0.3s ease;
    max-height: 90vh;
    overflow-y: auto;
}

.webinar-modal.active .webinar-modal-content {
    transform: scale(1) translateY(0);
}

.webinar-modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f1f5f9;
    border: none;
    border-radius: 50%;
    font-size: 1.5rem;
    color: var(--text-light);
    cursor: pointer;
    transition: all 0.2s;
}

.webinar-modal-close:hover {
    background: #e2e8f0;
    color: var(--secondary);
}

.webinar-modal-header {
    text-align: center;
    margin-bottom: 32px;
}

.webinar-modal-icon {
    font-size: 3rem;
    margin-bottom: 16px;
}

.webinar-modal-header h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 8px;
}

.webinar-modal-info {
    font-size: 0.95rem;
    color: var(--primary-dark);
    font-weight: 600;
}

.webinar-registration-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Benefits Section */
.webinaires-benefits {
    padding: 80px 0;
    background: #fff;
}

.webinaires-benefits .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}

.benefits-header {
    text-align: center;
    margin-bottom: 48px;
}

.benefits-header h2 {
    font-size: clamp(1.6rem, 3.5vw, 2.2rem);
    font-weight: 800;
    color: var(--secondary);
    margin-bottom: 12px;
}

.benefits-header p {
    color: var(--text-light);
    font-size: 1.05rem;
}

.benefits-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.benefit-card {
    text-align: center;
    padding: 32px 24px;
    background: #f8fafc;
    border-radius: 16px;
    transition: all 0.3s ease;
}

.benefit-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}

.benefit-icon {
    font-size: 2.5rem;
    margin-bottom: 16px;
}

.benefit-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 12px;
}

.benefit-card p {
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.6;
}

/* CTA Section */
.webinaires-cta {
    padding: 80px 0;
    background: #f8fafc;
}

.webinaires-cta .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px;
}

.cta-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding: 48px;
    background: linear-gradient(135deg, #1e2334 0%, #2a3042 100%);
    border-radius: 24px;
    color: #fff;
}

.cta-content h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 12px;
}

.cta-content p {
    color: rgba(255,255,255,0.8);
    font-size: 1rem;
}

.cta-card .btn-primary {
    flex-shrink: 0;
    white-space: nowrap;
}

/* Next Webinar Banner (for homepage) */
.next-webinar-banner {
    background: linear-gradient(135deg, #1e2334 0%, #2a3042 100%);
    border-radius: 16px;
    margin: 40px auto;
    max-width: 1200px;
    overflow: hidden;
}

.next-webinar-inner {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 24px 32px;
}

.next-webinar-badge {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: rgba(34, 197, 94, 0.15);
    border-radius: 30px;
    color: #22c55e;
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
}

.next-webinar-badge .pulse {
    width: 8px;
    height: 8px;
    background: #22c55e;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.next-webinar-content {
    flex: 1;
    min-width: 0;
}

.next-webinar-content h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.next-webinar-date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    color: rgba(255,255,255,0.7);
}

.next-webinar-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
    color: #fff;
    text-decoration: none;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.9rem;
    transition: all 0.2s;
    white-space: nowrap;
}

.next-webinar-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 122, 61, 0.4);
}

.next-webinar-full {
    padding: 10px 20px;
    background: rgba(255,255,255,0.1);
    border-radius: 8px;
    color: rgba(255,255,255,0.6);
    font-size: 0.9rem;
    font-weight: 600;
}

/* ============================================================================
   RESPONSIVE STYLES
   ============================================================================ */

@media (max-width: 1024px) {
    .contact-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .contact-sidebar {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

    .benefits-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .contact-hero {
        padding: 60px 0 40px;
    }

    .contact-content {
        padding: 40px 0 60px;
    }

    .contact-form-section {
        padding: 24px;
    }

    .form-row {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .contact-sidebar {
        grid-template-columns: 1fr;
    }

    .webinaires-hero {
        padding: 60px 0 40px;
    }

    .webinaires-hero-stats {
        gap: 24px;
    }

    .webinar-card {
        grid-template-columns: 80px 1fr;
        gap: 16px;
        padding: 20px;
    }

    .webinar-card-date {
        width: 75px;
        height: 75px;
    }

    .date-day {
        font-size: 1.5rem;
    }

    .date-month {
        font-size: 0.75rem;
    }

    .webinar-card-action {
        grid-column: 1 / -1;
    }

    .webinar-card-action .btn {
        width: 100%;
        justify-content: center;
    }

    .webinar-modal-content {
        padding: 24px;
        border-radius: 16px;
    }

    .benefits-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .cta-card {
        flex-direction: column;
        text-align: center;
        padding: 32px 24px;
    }

    .next-webinar-inner {
        flex-direction: column;
        text-align: center;
        padding: 20px;
    }

    .next-webinar-content h3 {
        white-space: normal;
    }

    .next-webinar-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ============================================================================
   DOCUMENTATION PAGE STYLES
   ============================================================================ */

.documentation-page {
    padding-top: 85px;
}

.doc-hero {
    padding: 80px 0 60px;
    text-align: center;
    background: linear-gradient(180deg, #1e2334 0%, #2a3042 100%);
    color: #fff;
}

.doc-hero .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px;
}

.doc-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 50px;
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 24px;
}

.doc-hero h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 800;
    margin-bottom: 20px;
    line-height: 1.2;
}

.doc-hero-subtitle {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.8);
    line-height: 1.7;
    margin-bottom: 40px;
}

.doc-search-container {
    max-width: 600px;
    margin: 0 auto;
}

.doc-search-box {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #fff;
    padding: 16px 24px;
    border-radius: 16px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
}

.doc-search-icon {
    color: #94a3b8;
    flex-shrink: 0;
}

.doc-search-box input {
    flex: 1;
    border: none;
    outline: none;
    font-size: 1rem;
    color: #1e293b;
}

.doc-search-box input::placeholder {
    color: #94a3b8;
}

.doc-search-clear {
    background: none;
    border: none;
    color: #94a3b8;
    cursor: pointer;
    padding: 4px;
    display: flex;
}

.doc-search-clear:hover {
    color: #64748b;
}

/* Video Section */
.doc-video-section {
    padding: 60px 0;
    background: #f8fafc;
}

.doc-video-section .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}

.doc-video-card {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: 40px;
    background: #fff;
    border-radius: 24px;
    padding: 40px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}

.doc-video-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: linear-gradient(135deg, rgba(255, 151, 96, 0.1) 0%, rgba(255, 122, 61, 0.15) 100%);
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--primary-dark);
    margin-bottom: 16px;
}

.doc-video-info h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 12px;
}

.doc-video-info p {
    color: var(--text-light);
    line-height: 1.6;
    margin-bottom: 16px;
}

.doc-video-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
}

.doc-video-meta span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text);
}

.doc-video-chapters {
    background: #f8fafc;
    border-radius: 16px;
    padding: 20px;
    max-height: 400px;
    overflow-y: auto;
}

.doc-video-chapters h4 {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--secondary);
    margin-bottom: 16px;
}

.chapters-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.chapter-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: #fff;
    border-radius: 8px;
    text-decoration: none;
    color: var(--text);
    font-size: 0.85rem;
    transition: all 0.2s;
}

.chapter-item:hover {
    background: var(--primary);
    color: #fff;
}

.chapter-time {
    font-family: monospace;
    font-size: 0.8rem;
    color: var(--text-light);
    min-width: 50px;
}

.chapter-item:hover .chapter-time {
    color: rgba(255,255,255,0.8);
}

.chapter-title {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Documentation Content */
.doc-content-section {
    padding: 60px 0 80px;
}

.doc-content-section .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.doc-section {
    margin-bottom: 60px;
}

.doc-section-header {
    margin-bottom: 32px;
}

.doc-section-header h2 {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 8px;
}

.doc-section-header p {
    color: var(--text-light);
    font-size: 1rem;
}

.doc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.doc-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: #fff;
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    border: 1px solid rgba(0,0,0,0.05);
    transition: all 0.3s ease;
}

.doc-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}

.doc-card-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    border-radius: 14px;
    flex-shrink: 0;
}

.doc-card-content {
    flex: 1;
    min-width: 0;
}

.doc-card-content h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--secondary);
    margin-bottom: 4px;
}

.doc-card-content p {
    font-size: 0.85rem;
    color: var(--text-light);
    margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.doc-card-meta {
    font-size: 0.75rem;
    color: var(--primary-dark);
    font-weight: 600;
}

.doc-card-arrow {
    color: var(--text-light);
    flex-shrink: 0;
    transition: transform 0.2s;
}

.doc-card:hover .doc-card-arrow {
    transform: translateX(4px);
    color: var(--primary);
}

/* Features List */
.doc-features-group {
    margin-bottom: 24px;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}

.doc-features-group-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--group-color) 10%, transparent), color-mix(in srgb, var(--group-color) 5%, transparent));
    border-bottom: 1px solid rgba(0,0,0,0.05);
}

.group-icon {
    font-size: 1.5rem;
}

.doc-features-group-header h3 {
    flex: 1;
    font-size: 1rem;
    font-weight: 700;
    color: var(--secondary);
    margin: 0;
}

.group-count {
    padding: 4px 10px;
    background: rgba(0,0,0,0.05);
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text);
}

.doc-features-group-items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.doc-feature-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    transition: background 0.2s;
}

.doc-feature-item:nth-child(odd) {
    border-right: 1px solid rgba(0,0,0,0.05);
}

.doc-feature-item:hover {
    background: #f8fafc;
}

.feature-title {
    font-weight: 600;
    color: var(--secondary);
    font-size: 0.9rem;
    flex-shrink: 0;
}

.feature-excerpt {
    flex: 1;
    font-size: 0.8rem;
    color: var(--text-light);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.doc-feature-item svg {
    color: var(--text-light);
    flex-shrink: 0;
}

.doc-feature-item:hover svg {
    color: var(--primary);
}

/* No Results */
.doc-no-results {
    text-align: center;
    padding: 60px 20px;
}

.no-results-icon {
    font-size: 4rem;
    margin-bottom: 16px;
}

.doc-no-results h3 {
    font-size: 1.3rem;
    color: var(--secondary);
    margin-bottom: 8px;
}

.doc-no-results p {
    color: var(--text-light);
}

/* Wiki Section */
.doc-wiki-section {
    padding: 60px 0;
    background: #f8fafc;
}

.doc-wiki-section .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px;
}

.doc-wiki-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding: 40px;
    background: linear-gradient(135deg, #1e2334 0%, #2a3042 100%);
    border-radius: 24px;
    color: #fff;
}

.doc-wiki-content {
    display: flex;
    align-items: center;
    gap: 20px;
}

.doc-wiki-icon {
    font-size: 3rem;
}

.doc-wiki-content h2 {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 6px;
}

.doc-wiki-content p {
    color: rgba(255,255,255,0.7);
    font-size: 0.95rem;
}

/* ============================================================================
   LEGAL PAGES STYLES
   ============================================================================ */

.legal-page-content {
    max-width: 800px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.legal-page-content h2 {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--secondary);
    margin: 40px 0 16px;
    padding-top: 20px;
    border-top: 1px solid #e2e8f0;
}

.legal-page-content h2:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.legal-page-content h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--secondary);
    margin: 24px 0 12px;
}

.legal-page-content p {
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 16px;
}

.legal-page-content ul {
    margin: 16px 0;
    padding-left: 24px;
}

.legal-page-content li {
    color: var(--text);
    line-height: 1.6;
    margin-bottom: 8px;
}

.legal-page-content a {
    color: var(--primary-dark);
}

.legal-page-content em {
    color: var(--text-light);
}

/* Responsive */
@media (max-width: 1024px) {
    .doc-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .doc-video-card {
        grid-template-columns: 1fr;
    }

    .doc-video-chapters {
        max-height: 300px;
    }
}

@media (max-width: 768px) {
    .doc-hero {
        padding: 60px 0 40px;
    }

    .doc-grid {
        grid-template-columns: 1fr;
    }

    .doc-video-card {
        padding: 24px;
    }

    .doc-features-group-items {
        grid-template-columns: 1fr;
    }

    .doc-feature-item:nth-child(odd) {
        border-right: none;
    }

    .feature-excerpt {
        display: none;
    }

    .doc-wiki-card {
        flex-direction: column;
        text-align: center;
        padding: 32px 24px;
    }

    .doc-wiki-content {
        flex-direction: column;
    }
}

/* ============================================================================
   MOBILE FLOATING ELEMENTS - SCROLL HIDE/SHOW BEHAVIOR
   ============================================================================ */

/* A9: Reduce overall mobile size - less zoomed feel */
@media (max-width: 768px) {
    html {
        font-size: 14px;
    }

    body {
        -webkit-text-size-adjust: 100%;
    }

    .navbar {
        height: 65px;
    }

    .nav-container {
        height: 65px;
        padding: 0 16px;
    }

    .logo-img {
        height: 36px;
    }

    /* Reduce hero section sizes */
    .hero-content h1 {
        font-size: 1.8rem;
    }

    .hero-content p {
        font-size: 0.95rem;
    }

    /* Reduce section headers */
    .section-header h2 {
        font-size: 1.5rem;
    }

    .section-header p {
        font-size: 0.9rem;
    }

    /* Reduce button sizes */
    .btn {
        padding: 12px 24px;
        font-size: 0.85rem;
    }

    .btn-primary, .btn-secondary {
        padding: 12px 20px;
    }
}

/* A10: Reduce padding on single module/feature pages for mobile */
@media (max-width: 768px) {
    .sf-content-block,
    .sf-section,
    .module-content-block,
    .feature-content-block {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .sf-content-block p,
    .sf-section p,
    .module-content p,
    .feature-content p {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Reduce nested paddings */
    .sf-content-block .sf-block-inner,
    .module-content .block-inner,
    .feature-content .block-inner {
        padding: 16px !important;
    }

    /* Text should use full width */
    .sf-text-block,
    .module-text-block,
    .feature-text-block {
        padding: 0 !important;
    }
}

/* B1: White background for module icons in menu and home widget */
.mega-module-icon,
.mobile-module-icon,
.module-item-icon,
.mobile-module-pill-icon,
.docs-module-icon,
.docs-article-icon,
.docs-nav-icon {
    background: #ffffff !important;
    color: inherit;
}

/* Also update home modules widget icons */
.home-modules-widget .module-icon,
.modules-grid .module-icon,
.module-card .module-icon {
    background: #ffffff !important;
}

/* ============================================================================
   MOBILE FLOATING ELEMENTS CONTAINER & SCROLL BEHAVIOR
   ============================================================================ */

/* A1-6: Mobile floating elements management */
@media (max-width: 768px) {
    /* Container for all mobile floating elements */
    .mobile-floating-container {
        position: fixed;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 9999;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;
        transition: all 0.3s ease;
    }

    /* Hide floating elements when scrolling down */
    .mobile-floating-container.scroll-hidden {
        transform: translateX(-50%) translateY(100px);
        opacity: 0;
        pointer-events: none;
    }

    /* Show only demo button when on scroll down */
    .mobile-floating-container.scroll-hidden .mobile-demo-btn {
        transform: translateY(-100px);
        opacity: 1;
        pointer-events: auto;
    }

    /* Main demo button - always visible */
    .mobile-demo-btn {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 14px 24px;
        background: linear-gradient(135deg, #ff9760 0%, #ff7a3d 100%);
        color: #fff;
        border-radius: 50px;
        text-decoration: none;
        font-weight: 600;
        font-size: 0.9rem;
        box-shadow: 0 4px 20px rgba(255, 122, 61, 0.4);
        transition: all 0.3s ease;
    }

    .mobile-demo-btn:hover {
        transform: scale(1.05);
        box-shadow: 0 6px 25px rgba(255, 122, 61, 0.5);
    }

    /* A7-8: Module switcher button with animation */
    .mobile-module-switcher {
        background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
        animation: moduleSwitcherPulse 2s infinite !important;
    }

    @keyframes moduleSwitcherPulse {
        0%, 100% {
            box-shadow: 0 4px 20px rgba(99, 102, 241, 0.4);
        }
        50% {
            box-shadow: 0 4px 30px rgba(99, 102, 241, 0.7), 0 0 40px rgba(139, 92, 246, 0.4);
        }
    }

    /* A7: Hide demo button when on modules section */
    body.on-modules-section .mobile-demo-btn {
        display: none !important;
    }

    body.on-modules-section .mobile-module-switcher {
        display: flex !important;
    }

    /* Hide Calendly badge when module switcher is visible */
    body.on-modules-section .calendly-badge-widget {
        display: none !important;
    }
}

/* ============================================================================
   TASK 6: USER SPACES TABS - 2 COLUMNS ON MOBILE
   ============================================================================ */
@media (max-width: 768px) {
    /* User spaces tabs: 2 per line on mobile */
    .us-showcase-tabs {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
        padding: 0 16px;
    }

    .us-showcase-tab {
        justify-content: center;
        padding: 12px 10px !important;
        font-size: 0.85rem;
    }

    .us-tab-icon {
        font-size: 1.2rem;
    }

    .us-tab-title {
        display: block !important;
        font-size: 0.75rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* Also fix user spaces panel layout on mobile */
    .us-panel-content {
        flex-direction: column !important;
    }

    .us-panel-info {
        width: 100% !important;
        padding: 20px !important;
    }

    .us-panel-screenshots {
        width: 100% !important;
    }
}

/* ============================================================================
   TASK 2: SINGLE FEATURE/FUNCTIONALITY MOBILE OPTIMIZATION
   ============================================================================ */
@media (max-width: 768px) {
    /* Reduce excessive padding on single feature pages */
    .sf-container {
        padding: 0 16px !important;
    }

    .sf-hero {
        padding: 30px 0 !important;
    }

    .sf-hero-title {
        font-size: 1.4rem !important;
        line-height: 1.3 !important;
    }

    .sf-hero-excerpt {
        font-size: 0.95rem !important;
        line-height: 1.5 !important;
    }

    .sf-main {
        padding: 24px 0 40px !important;
    }

    .sf-content {
        gap: 20px !important;
    }

    .sf-article {
        padding: 20px !important;
        font-size: 0.95rem !important;
    }

    .sf-article p,
    .sf-article li {
        line-height: 1.6 !important;
        margin-bottom: 0.8em !important;
    }

    .sf-details {
        padding: 18px !important;
    }

    .sf-details h3 {
        font-size: 1rem !important;
    }

    .sf-details li {
        padding-left: 24px !important;
        font-size: 0.9rem !important;
    }

    .sf-cta {
        padding: 20px !important;
        gap: 16px !important;
    }

    .sf-cta-content h3 {
        font-size: 1rem !important;
    }

    .sf-cta-content p {
        font-size: 0.85rem !important;
    }

    .sf-cta-actions {
        flex-direction: column !important;
        width: 100%;
    }

    .sf-cta-actions .btn {
        width: 100%;
        justify-content: center;
    }

    /* Screenshots browser: make it full width on mobile */
    .sf-screenshots {
        padding: 16px !important;
        margin: 0 -16px !important;
        width: calc(100% + 32px) !important;
        border-radius: 0 !important;
    }

    /* Spaces section on mobile */
    .sf-spaces {
        padding: 30px 0 !important;
    }

    .sf-spaces-grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    .sf-space-card {
        padding: 12px !important;
        flex-direction: column !important;
        text-align: center;
        gap: 8px;
    }

    .sf-space-icon {
        font-size: 1.3rem !important;
    }

    .sf-space-name {
        font-size: 0.8rem !important;
    }

    /* Related features on mobile */
    .sf-related {
        padding: 30px 0 !important;
    }

    .sf-related h3 {
        font-size: 1rem !important;
        padding: 0 16px;
    }
}

/* ============================================================================
   TASK 3: SCREENSHOT BROWSER - LARGER DISPLAY WITH BROWSER CONTAINER
   ============================================================================ */
/* Make screenshot browser more prominent */
.loop-screenshots-browser {
    margin: 40px 0;
}

.loop-browser-inner {
    max-width: 1100px;
    margin: 0 auto;
}

.loop-browser-frame {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.15);
}

.loop-browser-viewport img {
    width: 100%;
    height: auto;
    display: block;
}

/* Thumbnails styling */
.loop-browser-thumbnails {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 20px;
    padding: 0 20px;
}

.loop-browser-thumb {
    width: 80px;
    height: 60px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.3s ease;
    position: relative;
}

.loop-browser-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.loop-browser-thumb.active {
    border-color: var(--browser-from, #ff9760);
    box-shadow: 0 4px 15px rgba(255, 151, 96, 0.3);
}

.loop-browser-thumb:hover:not(.active) {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.loop-thumb-number {
    position: absolute;
    bottom: 4px;
    right: 4px;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 4px;
}

@media (max-width: 768px) {
    .loop-screenshots-browser {
        margin: 24px -16px;
        padding: 0;
    }

    .loop-browser-inner {
        padding: 0;
    }

    .loop-browser-header {
        padding: 20px 16px !important;
    }

    .loop-browser-header h2 {
        font-size: 1.1rem !important;
    }

    .loop-browser-frame {
        border-radius: 0;
    }

    .loop-browser-thumbnails {
        padding: 0 16px;
        gap: 8px;
    }

    .loop-browser-thumb {
        width: 60px;
        height: 45px;
    }
}

/* ============================================================================
   TASK 5: RESOURCES DROPDOWN MENU
   ============================================================================ */
/* Dropdown container */
.nav-item.has-dropdown {
    position: relative;
}

.nav-dropdown-trigger {
    cursor: pointer;
}

.nav-dropdown {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: white;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    min-width: 280px;
    padding: 12px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 1000;
}

.nav-item.has-dropdown:hover .nav-dropdown,
.nav-item.has-dropdown.active .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.nav-dropdown-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    color: #1e293b;
    text-decoration: none;
    border-radius: 12px;
    transition: all 0.2s ease;
}

.nav-dropdown-item:hover {
    background: #f8fafc;
}

.nav-dropdown-icon {
    font-size: 1.5rem;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f1f5f9;
    border-radius: 10px;
    flex-shrink: 0;
}

.nav-dropdown-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nav-dropdown-text strong {
    font-size: 0.95rem;
    font-weight: 600;
    color: #1e293b;
}

.nav-dropdown-text small {
    font-size: 0.8rem;
    color: #64748b;
}

/* Hide dropdown on mobile - shown in mobile menu instead */
@media (max-width: 1024px) {
    .nav-item.has-dropdown .nav-dropdown {
        display: none;
    }
}

/* Mobile Resources List Styles */
.mobile-resources-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
}

.mobile-resource-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: rgba(0, 0, 0, 0.03);
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.mobile-resource-link:hover {
    background: rgba(0, 0, 0, 0.06);
}

.mobile-resource-icon {
    font-size: 1.5rem;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    flex-shrink: 0;
}

.mobile-resource-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mobile-resource-name {
    font-size: 0.95rem;
    font-weight: 600;
    color: #1e293b;
}

.mobile-resource-desc {
    font-size: 0.8rem;
    color: #64748b;
}

/* ============================================================================
   HIDE ARTICLE CONTENT ON MOBILE (mod-article-content only)
   ============================================================================ */
@media (max-width: 768px) {
    /* Hide long article content on mobile - too heavy */
    .mod-article-content,
    .mod-content-magazine {
        display: none !important;
    }

    /* Hide sidebar without main content */
    .mod-sidebar {
        display: none !important;
    }

    /* Remove padding on kf-description for mobile */
    .kf-description {
        padding: 16px !important;
        border-radius: 16px;
    }
}

/* ============================================================================
   USER SPACES STRIP - 2 ITEMS PER LINE ON MOBILE
   ============================================================================ */
@media (max-width: 768px) {
    .us-strip-track {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
        padding: 0 16px !important;
        max-width: 100% !important;
    }

    .us-strip-card {
        width: 100% !important;
        min-width: unset !important;
        padding: 12px 8px !important;
    }

    .us-strip-icon {
        width: 48px !important;
        height: 48px !important;
        font-size: 24px !important;
        border-radius: 14px !important;
        margin-bottom: 8px !important;
    }

    .us-strip-card h4 {
        font-size: 11px !important;
        white-space: normal !important;
        line-height: 1.3 !important;
    }
}

/* ============================================================================
   SINGLE PAGES - FULL WIDTH SCREENSHOT BROWSER
   ============================================================================ */
/* Make screenshot browser full width on single feature page */
.sf-screenshots-main {
    margin: 0 0 32px 0;
}

.sf-screenshots-main .loop-screenshots-browser {
    margin: 0;
    padding: 0;
}

.sf-screenshots-main .loop-browser-inner {
    max-width: 100%;
    padding: 0;
}

.sf-screenshots-main .loop-browser-frame {
    border-radius: 16px;
    overflow: hidden;
}

.sf-screenshots-main .loop-browser-viewport {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f8fafc;
}

.sf-screenshots-main .loop-browser-viewport .loop-browser-main-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: top left !important;
}

/* Single Module - Full width screenshots */
.mod-hero-immersive + .mod-quick-nav + .loop-screenshots-browser {
    margin: 0;
    padding: 40px 0;
    background: #fff;
}

.mod-hero-immersive + .mod-quick-nav + .loop-screenshots-browser .loop-browser-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.mod-hero-immersive + .mod-quick-nav + .loop-screenshots-browser .loop-browser-viewport {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f8fafc;
}

.mod-hero-immersive + .mod-quick-nav + .loop-screenshots-browser .loop-browser-viewport .loop-browser-main-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: top center !important;
}

/* Generic full-width for loop-screenshots-browser on single pages */
.loop-screenshots-browser .loop-browser-viewport img {
    width: 100%;
    height: auto;
    display: block;
}

/* Make thumbnails centered and larger */
.loop-browser-thumbnails {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 20px;
    padding: 0 20px;
}

.loop-browser-thumb {
    width: 100px;
    height: 70px;
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    border: 3px solid transparent;
    transition: all 0.3s ease;
    position: relative;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.loop-browser-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.loop-browser-thumb.active {
    border-color: var(--browser-from, #ff9760);
    box-shadow: 0 4px 15px rgba(255, 151, 96, 0.4);
    transform: scale(1.05);
}

.loop-browser-thumb:hover:not(.active) {
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .loop-browser-thumb {
        width: 70px;
        height: 50px;
    }
}

/* ============================================================================
   IMMERSIVE VIEWER - ZOOM & PAN LIGHTBOX
   ============================================================================ */

/* Main container */
.loop-immersive-viewer {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    flex-direction: column;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.loop-immersive-viewer.active {
    opacity: 1;
    visibility: visible;
}

/* Backdrop with blur - semi-transparent to show there's more content when zoomed */
.loop-viewer-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(20, 20, 30, 0.75);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

/* Close button */
.loop-viewer-close {
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 10;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 12px;
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
}

.loop-viewer-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: scale(1.05);
}

/* Main viewing stage */
.loop-viewer-stage {
    position: relative;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow: hidden;
}

/* Navigation buttons */
.loop-viewer-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 16px;
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
    backdrop-filter: blur(10px);
}

.loop-viewer-prev { left: 24px; }
.loop-viewer-next { right: 24px; }

.loop-viewer-nav:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-50%) scale(1.05);
    border-color: rgba(255, 255, 255, 0.3);
}

.loop-viewer-nav:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Image container */
.loop-viewer-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.loop-viewer-image-wrapper {
    position: relative;
    max-width: 90%;
    max-height: 90%;
    transform-origin: center center;
    transition: transform 0.1s ease-out;
    cursor: grab;
}

.loop-viewer-image-wrapper.dragging {
    cursor: grabbing;
    transition: none;
}

.loop-viewer-image-wrapper.zoomed {
    cursor: grab;
}

.loop-viewer-image {
    max-width: 100%;
    max-height: calc(100vh - 200px);
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.5);
    user-select: none;
    -webkit-user-drag: none;
    /* High quality rendering when zoomed */
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/* Zoom indicator */
.loop-viewer-zoom-indicator {
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%) scale(0.9);
    padding: 10px 20px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.9), rgba(139, 92, 246, 0.9));
    border-radius: 25px;
    color: white;
    font-size: 16px;
    font-weight: 700;
    opacity: 0;
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: none;
    box-shadow: 0 4px 15px rgba(99, 102, 241, 0.4);
    backdrop-filter: blur(10px);
}

.loop-viewer-zoom-indicator.visible {
    opacity: 1;
    transform: translateX(-50%) scale(1);
}

/* Mini-map */
.loop-viewer-minimap {
    position: absolute;
    bottom: 20px;
    right: 20px;
    width: 150px;
    height: 100px;
    background: rgba(0, 0, 0, 0.6);
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 8px;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.loop-viewer-minimap.visible {
    opacity: 1;
    visibility: visible;
}

.loop-minimap-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.loop-minimap-viewport {
    position: absolute;
    border: 2px solid #fff;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    pointer-events: none;
}

/* Loader */
.loop-viewer-loader {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease;
}

.loop-viewer-loader.loading {
    opacity: 1;
    visibility: visible;
}

.loop-loader-spinner {
    width: 48px;
    height: 48px;
    border: 3px solid rgba(255, 255, 255, 0.2);
    border-top-color: white;
    border-radius: 50%;
    animation: loopSpinner 0.8s linear infinite;
}

@keyframes loopSpinner {
    to { transform: rotate(360deg); }
}

/* Bottom toolbar */
.loop-viewer-toolbar {
    position: relative;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 16px 24px 24px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
}

/* Thumbnails strip */
.loop-viewer-thumbs-strip {
    display: flex;
    gap: 8px;
    padding: 8px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    overflow-x: auto;
    max-width: 100%;
    scrollbar-width: none;
}

.loop-viewer-thumbs-strip::-webkit-scrollbar {
    display: none;
}

.loop-viewer-thumb {
    flex-shrink: 0;
    width: 64px;
    height: 48px;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s ease;
    opacity: 0.6;
}

.loop-viewer-thumb:hover {
    opacity: 0.9;
    transform: scale(1.05);
}

.loop-viewer-thumb.active {
    border-color: white;
    opacity: 1;
    box-shadow: 0 0 20px rgba(255, 255, 255, 0.3);
}

.loop-viewer-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Controls */
.loop-viewer-controls {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 8px 16px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 16px;
    backdrop-filter: blur(10px);
}

/* Counter */
.loop-viewer-counter {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    font-weight: 600;
    color: white;
    padding-right: 16px;
    border-right: 1px solid rgba(255, 255, 255, 0.2);
}

.loop-current-index {
    color: #fff;
}

.loop-counter-sep {
    opacity: 0.5;
}

.loop-total-count {
    opacity: 0.7;
}

/* Zoom controls */
.loop-viewer-zoom-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.loop-zoom-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 8px;
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
}

.loop-zoom-btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

.loop-zoom-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Zoom slider */
.loop-zoom-slider-container {
    position: relative;
    width: 100px;
    height: 36px;
    display: flex;
    align-items: center;
}

.loop-zoom-slider {
    width: 100%;
    height: 4px;
    -webkit-appearance: none;
    appearance: none;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    cursor: pointer;
}

.loop-zoom-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    background: white;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    transition: transform 0.2s ease;
}

.loop-zoom-slider::-webkit-slider-thumb:hover {
    transform: scale(1.2);
}

.loop-zoom-slider::-moz-range-thumb {
    width: 16px;
    height: 16px;
    background: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Action buttons */
.loop-viewer-action {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 8px;
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-left: 8px;
    padding-left: 16px;
    border-left: 1px solid rgba(255, 255, 255, 0.2);
}

.loop-viewer-action:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* Gesture hint */
.loop-viewer-gesture-hint {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 32px;
    background: rgba(0, 0, 0, 0.8);
    border-radius: 20px;
    color: white;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all 0.4s ease;
}

.loop-viewer-gesture-hint.visible {
    opacity: 1;
    visibility: visible;
}

.loop-gesture-icon {
    opacity: 0.8;
}

.loop-viewer-gesture-hint p {
    margin: 0;
    font-size: 14px;
    opacity: 0.9;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .loop-viewer-nav {
        width: 44px;
        height: 44px;
        border-radius: 12px;
    }

    .loop-viewer-prev { left: 12px; }
    .loop-viewer-next { right: 12px; }

    .loop-viewer-nav svg {
        width: 24px;
        height: 24px;
    }

    .loop-viewer-close {
        top: 12px;
        right: 12px;
        width: 40px;
        height: 40px;
    }

    .loop-viewer-toolbar {
        padding: 12px 16px 20px;
    }

    .loop-viewer-controls {
        flex-wrap: wrap;
        justify-content: center;
        gap: 12px;
        padding: 12px;
    }

    .loop-viewer-counter {
        padding-right: 12px;
    }

    .loop-zoom-slider-container {
        width: 80px;
    }

    .loop-viewer-thumb {
        width: 52px;
        height: 40px;
    }

    .loop-viewer-minimap {
        width: 100px;
        height: 70px;
        bottom: 100px;
        right: 12px;
    }

    .loop-viewer-image {
        max-height: calc(100vh - 250px);
    }
}

/* ============================================================================
   KEY FEATURE SCREENSHOTS SECTION
   ============================================================================ */

.kf-screenshots-section {
    padding: 40px 0 60px;
    max-width: 1200px;
    margin: 0 auto;
}

.kf-screenshots-section .loop-screenshots-browser {
    margin: 0;
}

.kf-screenshots-section .loop-browser-viewport {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f8fafc;
}

.kf-screenshots-section .loop-browser-viewport .loop-browser-main-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: top center !important;
}

@media (max-width: 768px) {
    .kf-screenshots-section {
        padding: 20px 16px 40px;
    }
}
