/* === Messaging Page - Unique Styles ===
   Shared base styles are in functionPages.css
*/

/* HERO */

/* Hero floaters */

.hero-floaters {
            position: absolute;
            inset: 0;
            pointer-events: none;
            z-index: 1
        }

.hero-floater {
            position: absolute;
            backdrop-filter: blur(8px)
        }

@media(max-width:900px) {
            .hero-floater {
                display: none
            }
        }

/* Left: Push notification stack */

.hero-floater.left {
            left: 3%;
            bottom: 10%;
            animation: float-left 8s ease-in-out infinite
        }

.notif-card {
            background: rgba(255,255,255,.07);
            border: 1px solid rgba(255,255,255,.1);
            border-radius: 14px;
            padding: 12px 16px;
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 8px;
            min-width: 220px;
            transition: opacity .3s
        }

.notif-card:last-child {
                margin-bottom: 0
            }

.notif-card.faded {
                opacity: .45;
                transform: scale(.96);
                transform-origin: top left
            }

.notif-icon {
            width: 34px;
            height: 34px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            font-size: .9rem
        }

.notif-icon.blue {
                background: rgba(21,93,238,.25)
            }

.notif-icon.green {
                background: rgba(22,163,74,.25)
            }

.notif-icon.amber {
                background: rgba(217,119,6,.25)
            }

.notif-body {
            display: flex;
            flex-direction: column;
            gap: 1px
        }

.notif-title {
            font-size: .72rem;
            font-weight: 600;
            color: rgba(255,255,255,.85);
            font-family: var(--font-body);
            white-space: nowrap
        }

.notif-desc {
            font-size: .62rem;
            color: rgba(255,255,255,.4);
            font-family: var(--font-body);
            white-space: nowrap
        }

.notif-time {
            font-size: .55rem;
            color: rgba(255,255,255,.25);
            font-family: var(--font-body);
            margin-left: auto;
            flex-shrink: 0;
            align-self: flex-start;
            padding-top: 2px
        }

/* Right: Mini phone screen */

.hero-floater.right {
            right: 3%;
            top: 15%;
            animation: float-right 7s ease-in-out infinite
        }

.mini-phone {
            background: rgba(255,255,255,.05);
            border: 1px solid rgba(255,255,255,.12);
            border-radius: 20px;
            width: 180px;
            overflow: hidden
        }

.mini-phone-status {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 14px 4px;
            font-size: .5rem;
            color: rgba(255,255,255,.3);
            font-family: var(--font-body)
        }

.mini-phone-header {
            padding: 4px 14px 10px;
            text-align: center
        }

.mini-phone-header span {
                font-size: .7rem;
                font-weight: 600;
                color: rgba(255,255,255,.7);
                font-family: var(--font-body)
            }

.mini-phone-body {
            padding: 0 10px 12px;
            display: flex;
            flex-direction: column;
            gap: 6px
        }

.mini-shift {
            display: flex;
            align-items: center;
            gap: 8px;
            background: rgba(255,255,255,.06);
            border-radius: 8px;
            padding: 7px 10px
        }

.mini-shift-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            flex-shrink: 0
        }

.mini-shift-dot.blue {
                background: rgba(21,93,238,.7)
            }

.mini-shift-dot.green {
                background: rgba(22,163,74,.7)
            }

.mini-shift-dot.purple {
                background: rgba(124,58,237,.7)
            }

.mini-shift-info {
            display: flex;
            flex-direction: column;
            gap: 0
        }

.mini-shift-name {
            font-size: .6rem;
            font-weight: 600;
            color: rgba(255,255,255,.7);
            font-family: var(--font-body)
        }

.mini-shift-time {
            font-size: .52rem;
            color: rgba(255,255,255,.35);
            font-family: var(--font-body)
        }

main {
            overflow: hidden;
        }

a {
            color: var(--accent);
            text-decoration: none;
            transition: color 0.25s ease;
        }

a:hover {
                color: var(--accent-hover);
            }

/* =============================================
                                   SHARED LAYOUT HELPERS
                                ============================================= */

.feature-page {
            position: relative;
            width: 100%;
        }

.section-label {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            background: var(--accent-light);
            color: var(--accent);
            font-size: 0.8rem;
            font-weight: 600;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            padding: 0.35rem 0.9rem;
            border-radius: 2rem;
            margin-bottom: 1rem;
            border: 1px solid var(--accent-mid);
        }

.section-header h2 {
                font-family: var(--font-display);
                font-size: clamp(1.75rem, 3.5vw, 2.5rem);
                font-weight: 400;
                color: var(--text);
                margin-bottom: 0.75rem;
                line-height: 1.25;
            }

.section-header p {
                font-size: 1.1rem;
                color: var(--faded-text);
                max-width: 560px;
                margin: 0 auto;
                line-height: 1.65;
            }

/* =============================================
                                   ANIMATION SYSTEM
                                   Uses CSS only — no layout-affecting props,
                                   only opacity + transform (compositor-only)
                                ============================================= */

@keyframes slideInLeft {
            from {
                opacity: 0;
                transform: translateX(-28px);
            }

            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

@keyframes slideInRight {
            from {
                opacity: 0;
                transform: translateX(28px);
            }

            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

@keyframes scaleIn {
            from {
                opacity: 0;
                transform: scale(0.93);
            }

            to {
                opacity: 1;
                transform: scale(1);
            }
        }

@keyframes pulse-ring {
            0% {
                transform: scale(1);
                opacity: 0.6;
            }

            100% {
                transform: scale(1.6);
                opacity: 0;
            }
        }

@keyframes wave {
            0% {
                transform: rotate(0deg);
            }

            100% {
                transform: rotate(360deg);
            }
        }

/* Scroll-triggered reveal — applied via JS IntersectionObserver */

/* Stagger children */

/* =============================================
                                   HERO SECTION
                                ============================================= */

.msg-hero {
            position: relative;
            background: var(--sec-background);
            padding: 7rem 1.5rem 5rem;
            overflow: hidden;
            display: flex;
            align-items: center;
            min-height: 58vh;
        }

/* Decorative circles — purely visual, no layout impact */

.msg-hero::before,
            .msg-hero::after {
                content: '';
                position: absolute;
                border-radius: 50%;
                pointer-events: none;
            }

.msg-hero::before {
                width: 560px;
                height: 560px;
                background: radial-gradient(circle, rgba(21,93,238,0.07) 0%, transparent 70%);
                top: -140px;
                right: -100px;
            }

.msg-hero::after {
                width: 380px;
                height: 380px;
                background: radial-gradient(circle, rgba(21,93,238,0.05) 0%, transparent 70%);
                bottom: -120px;
                left: -80px;
            }

.msg-hero .container {
                position: relative;
                z-index: 1;
            }

.hero-inner {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3.5rem;
            align-items: center;
        }

.hero-text {
            animation: fadeUp 0.7s ease both;
        }

.hero-text h1 {
                font-family: var(--font-display);
                font-size: clamp(2rem, 4.5vw, 3.4rem);
                font-weight: 400;
                color: var(--text);
                line-height: 1.18;
                margin-bottom: 1.25rem;
                letter-spacing: -0.01em;
            }

.hero-text h1 span {
                    color: var(--accent);
                }

.hero-text p {
                font-size: 1.15rem;
                color: var(--faded-text);
                line-height: 1.7;
                margin-bottom: 2rem;
                max-width: 480px;
                animation: fadeUp 0.7s ease 0.15s both;
            }

.btn-outline {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            background: transparent;
            color: var(--accent);
            padding: 0.75rem 1.5rem;
            border-radius: var(--radius-md);
            font-weight: 600;
            font-size: 0.95rem;
            border: 2px solid var(--accent-mid);
            transition: border-color 0.25s ease, background 0.25s ease, transform 0.2s ease;
        }

.btn-outline:hover {
                border-color: var(--accent);
                background: var(--accent-light);
                color: var(--accent);
                transform: translateY(-2px);
            }

/* Hero visual — animated chat mockup */

.hero-visual {
            display: flex;
            justify-content: center;
            align-items: center;
            animation: fadeIn 0.8s ease 0.3s both;
        }

.chat-mockup {
            background: #fff;
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-xl);
            border: 1px solid var(--border);
            padding: 1.25rem;
            width: 100%;
            max-width: 360px;
            animation: float 5s ease-in-out infinite;
        }

.chat-mockup-header {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding-bottom: 1rem;
            border-bottom: 1px solid #f0f0f0;
            margin-bottom: 1rem;
        }

.chat-avatar {
            width: 38px;
            height: 38px;
            border-radius: 50%;
            background: var(--accent);
            display: flex;
            align-items: center;
            justify-content: center;
            color: #fff;
            font-weight: 700;
            font-size: 0.85rem;
            flex-shrink: 0;
        }

.chat-avatar.green {
                background: #12b76a;
            }

.chat-avatar.orange {
                background: #f79009;
            }

.chat-name {
            font-weight: 600;
            font-size: 0.9rem;
            color: var(--text);
        }

.chat-status {
            font-size: 0.75rem;
            color: #12b76a;
            display: flex;
            align-items: center;
            gap: 0.3rem;
        }

.chat-status::before {
                content: '';
                width: 7px;
                height: 7px;
                background: #12b76a;
                border-radius: 50%;
                display: inline-block;
            }

.chat-bubble-row {
            display: flex;
            gap: 0.6rem;
            margin-bottom: 0.75rem;
            align-items: flex-end;
        }

.chat-bubble-row.mine {
                flex-direction: row-reverse;
            }

.bubble-avatar {
            width: 28px;
            height: 28px;
            border-radius: 50%;
            background: var(--sec-background);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 0.7rem;
            font-weight: 700;
            color: var(--accent);
            flex-shrink: 0;
        }

.chat-bubble-row.mine .bubble-avatar {
            background: var(--accent);
            color: #fff;
        }

.bubble {
            padding: 0.55rem 0.9rem;
            border-radius: 1rem;
            font-size: 0.82rem;
            line-height: 1.4;
            max-width: 200px;
            background: var(--sec-background);
            color: var(--text);
        }

.bubble.mine {
                background: var(--accent);
                color: #fff;
                border-bottom-right-radius: 0.25rem;
            }

.bubble:not(.mine) {
                border-bottom-left-radius: 0.25rem;
            }

.bubble-time {
            font-size: 0.68rem;
            color: var(--faded-text);
            opacity: 0.6;
            margin-top: 0.2rem;
        }

.chat-bubble-row.mine .bubble-time {
            text-align: right;
        }

.bubble-col {
            display: flex;
            flex-direction: column;
        }

.chat-bubble-row.mine .bubble-col {
            align-items: flex-end;
        }

.typing-indicator {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 0;
        }

.typing-dots {
            display: flex;
            gap: 4px;
        }

.typing-dots span {
                width: 6px;
                height: 6px;
                background: var(--border);
                border-radius: 50%;
                animation: typing 1.2s ease infinite;
            }

.typing-dots span:nth-child(2) {
                    animation-delay: 0.2s;
                }

.typing-dots span:nth-child(3) {
                    animation-delay: 0.4s;
                }

@keyframes typing {
            0%, 80%, 100% {
                transform: scale(1);
                opacity: 0.5;
            }

            40% {
                transform: scale(1.3);
                opacity: 1;
            }
        }

/* =============================================
                                   HOW IT WORKS — CHANNEL STRIP
                                ============================================= */

.msg-channels {
            padding: 5rem 1.5rem;
            background: var(--element-background);
        }

.channels-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.5rem;
            margin-top: 1rem;
        }

.channel-card {
            background: var(--element-background);
            border: 1px solid var(--border);
            border-radius: var(--radius-lg);
            padding: 2rem 1.5rem;
            text-align: center;
            transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
            position: relative;
            overflow: hidden;
        }

.channel-card::before {
                content: '';
                position: absolute;
                top: 0;
                left: 0;
                right: 0;
                height: 3px;
                background: var(--accent);
                transform: scaleX(0);
                transform-origin: left;
                transition: transform 0.35s ease;
            }

.channel-card:hover {
                box-shadow: var(--shadow-lg);
                border-color: var(--accent-mid);
                transform: translateY(-4px);
            }

.channel-card:hover::before {
                    transform: scaleX(1);
                }

.channel-icon {
            width: 60px;
            height: 60px;
            background: var(--sec-background);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1.25rem;
            transition: background 0.3s ease;
        }

.channel-card:hover .channel-icon {
            background: var(--accent-light);
        }

.channel-icon svg {
            width: 30px;
            height: 30px;
            fill: var(--accent);
        }

.channel-card h3 {
            font-family: var(--font-display);
            font-size: 1.1rem;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 0.5rem;
        }

.channel-card p {
            font-size: 0.92rem;
            color: var(--faded-text);
            line-height: 1.6;
        }

/* =============================================
                                   FEATURE DETAIL — ALTERNATING ROWS
                                ============================================= */

.msg-detail {
            padding: 5rem 1.5rem;
            background: var(--sec-background);
        }

.detail-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 3.5rem;
            align-items: center;
            margin-bottom: 5rem;
        }

.detail-row:last-child {
                margin-bottom: 0;
            }

.detail-row.flip .detail-text {
                order: 2;
            }

.detail-row.flip .detail-visual {
                order: 1;
            }

.detail-text h2 {
            font-family: var(--font-display);
            font-size: clamp(1.5rem, 3vw, 2.1rem);
            font-weight: 400;
            color: var(--text);
            margin-bottom: 1rem;
            line-height: 1.25;
        }

.detail-text h2 span {
                color: var(--accent);
            }

.detail-text p {
            font-size: 1rem;
            color: var(--faded-text);
            line-height: 1.7;
            margin-bottom: 1.5rem;
        }

.feature-list {
            list-style: none;
            padding: 0;
            margin: 0;
            display: flex;
            flex-direction: column;
            gap: 0.7rem;
        }

.feature-list li {
                display: flex;
                align-items: flex-start;
                gap: 0.75rem;
                font-size: 0.95rem;
                color: var(--faded-text);
                line-height: 1.55;
            }

.feature-list li .check {
                    width: 20px;
                    height: 20px;
                    background: var(--accent-light);
                    border-radius: 50%;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                    flex-shrink: 0;
                    margin-top: 0.1rem;
                }

.feature-list li .check svg {
                        width: 11px;
                        height: 11px;
                        fill: var(--accent);
                    }

/* Detail visual cards */

.detail-visual {
            display: flex;
            justify-content: center;
            align-items: center;
        }

.msg-visual-card {
            background: #fff;
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-xl);
            border: 1px solid var(--border);
            padding: 1.5rem;
            width: 100%;
            max-width: 380px;
        }

/* Announcement visual */

.announcement-preview {
            background: #fff;
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-xl);
            border: 1px solid var(--border);
            overflow: hidden;
            width: 100%;
            max-width: 380px;
        }

.ann-header {
            background: var(--accent);
            color: #fff;
            padding: 1rem 1.25rem;
            display: flex;
            align-items: center;
            gap: 0.6rem;
            font-weight: 600;
            font-size: 0.9rem;
        }

.ann-header svg {
                width: 18px;
                height: 18px;
                fill: #fff;
            }

.ann-body {
            padding: 1.25rem;
        }

.ann-item {
            padding: 0.9rem;
            border-radius: var(--radius-md);
            border: 1px solid var(--border);
            margin-bottom: 0.75rem;
            transition: border-color 0.2s;
        }

.ann-item:last-child {
                margin-bottom: 0;
            }

.ann-item:hover {
                border-color: var(--accent-mid);
            }

.ann-title {
            font-weight: 600;
            font-size: 0.85rem;
            color: var(--text);
            margin-bottom: 0.3rem;
        }

.ann-meta {
            font-size: 0.75rem;
            color: var(--faded-text);
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

.ann-tag {
            background: var(--accent-light);
            color: var(--accent);
            border-radius: 1rem;
            padding: 0.1rem 0.5rem;
            font-size: 0.7rem;
            font-weight: 600;
        }

/* Group chat visual */

.group-visual {
            background: #fff;
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-xl);
            border: 1px solid var(--border);
            overflow: hidden;
            width: 100%;
            max-width: 380px;
        }

.group-header {
            padding: 1rem 1.25rem;
            border-bottom: 1px solid #f0f0f0;
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }

.group-icon-wrap {
            width: 38px;
            height: 38px;
            border-radius: 50%;
            background: var(--accent);
            display: flex;
            align-items: center;
            justify-content: center;
        }

.group-icon-wrap svg {
                width: 18px;
                height: 18px;
                fill: #fff;
            }

.group-name {
            font-weight: 700;
            font-size: 0.9rem;
            color: var(--text);
        }

.group-members {
            font-size: 0.75rem;
            color: var(--faded-text);
        }

.group-messages {
            padding: 1rem 1.25rem;
            display: flex;
            flex-direction: column;
            gap: 0.7rem;
        }

.group-msg {
            display: flex;
            gap: 0.6rem;
            align-items: flex-end;
        }

.gm-avatar {
            width: 26px;
            height: 26px;
            border-radius: 50%;
            font-size: 0.65rem;
            font-weight: 700;
            color: #fff;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

.gm-bubble {
            background: var(--sec-background);
            border-radius: 0.85rem 0.85rem 0.85rem 0.2rem;
            padding: 0.5rem 0.8rem;
            font-size: 0.8rem;
            color: var(--text);
            max-width: 200px;
        }

.gm-sender {
            font-weight: 600;
            font-size: 0.7rem;
            color: var(--accent);
            margin-bottom: 0.2rem;
        }

/* =============================================
                                   KEY FEATURES GRID
                                ============================================= */

.msg-features {
            padding: 5rem 1.5rem;
            background: var(--element-background);
        }

.features-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.25rem;
        }

.feat-card {
            background: var(--element-background);
            border: 1px solid var(--border);
            border-radius: var(--radius-lg);
            padding: 1.75rem 1.5rem;
            transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
        }

.feat-card:hover {
                box-shadow: var(--shadow-lg);
                border-color: var(--accent-mid);
                transform: translateY(-3px);
            }

.feat-icon {
            width: 48px;
            height: 48px;
            background: var(--sec-background);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1.1rem;
            transition: background 0.3s ease;
        }

.feat-card:hover .feat-icon {
            background: var(--accent-light);
        }

.feat-icon svg {
            width: 24px;
            height: 24px;
            fill: var(--accent);
        }

.feat-card h3 {
            font-family: var(--font-display);
            font-size: 1.05rem;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 0.5rem;
        }

.feat-card p {
            font-size: 0.9rem;
            color: var(--faded-text);
            line-height: 1.6;
        }

/* =============================================
                                   USE CASES
                                ============================================= */

.msg-usecases {
            padding: 5rem 1.5rem;
            background: var(--sec-background);
        }

.usecases-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1.5rem;
        }

.usecase-card {
            background: #fff;
            border: 1px solid var(--border);
            border-radius: var(--radius-lg);
            padding: 1.75rem;
            display: flex;
            gap: 1.25rem;
            align-items: flex-start;
            transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
        }

.usecase-card:hover {
                box-shadow: var(--shadow-md);
                border-color: var(--accent-mid);
                transform: translateY(-3px);
            }

.uc-icon {
            width: 52px;
            height: 52px;
            background: var(--sec-background);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

.uc-icon svg {
                width: 26px;
                height: 26px;
                fill: var(--accent);
            }

.uc-content h3 {
            font-family: var(--font-display);
            font-size: 1.05rem;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 0.5rem;
        }

.uc-content p {
            font-size: 0.9rem;
            color: var(--faded-text);
            line-height: 1.6;
        }

/* =============================================
                                   KEY BENEFITS — REDESIGNED
                                ============================================= */

.msg-benefits {
            padding: 5rem 1.5rem;
            background: var(--bg);
            position: relative;
            overflow: hidden;
        }

.msg-benefits::before {
                content: '';
                position: absolute;
                inset: 0;
                background: radial-gradient(ellipse 70% 50% at 50% 0%, rgba(21,93,238,.04), transparent);
                pointer-events: none;
            }

/* ---- Header area ---- */

.benefits-header {
            text-align: center;
            margin-bottom: 3rem;
        }

.benefits-header h2 {
                font-family: var(--font-display);
                font-size: clamp(1.75rem, 3.5vw, 2.5rem);
                font-weight: 400;
                color: var(--text);
                margin-bottom: 0.75rem;
                line-height: 1.25;
            }

.benefits-header p {
                font-size: 1.05rem;
                color: var(--text-light);
                max-width: 540px;
                margin: 0 auto;
                line-height: 1.65;
            }

/* ---- Primary benefit cards grid ---- */

.benefit-cards {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.25rem;
            margin-bottom: 1.25rem;
        }

.benefit-card {
            background: var(--surface);
            border: 1px solid var(--border);
            border-radius: var(--radius-lg);
            padding: 1.75rem 1.5rem 1.6rem;
            position: relative;
            overflow: hidden;
            /* compositor-only transitions — no layout thrash */
            transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
            will-change: transform;
        }

.benefit-card::after {
                content: '';
                position: absolute;
                inset: 0;
                border-radius: inherit;
                background: linear-gradient(135deg, rgba(21,93,238,.055) 0%, transparent 60%);
                opacity: 0;
                transition: opacity 0.28s ease;
                pointer-events: none;
            }

.benefit-card:hover {
                transform: translateY(-4px);
                box-shadow: var(--shadow-lg);
                border-color: rgba(21,93,238,.25);
            }

.benefit-card:hover::after {
                    opacity: 1;
                }

/* Accent top-bar (pure CSS, zero paint cost) */

.benefit-card::before {
                content: '';
                position: absolute;
                top: 0;
                left: 1.5rem;
                right: 1.5rem;
                height: 2px;
                background: var(--accent);
                border-radius: 0 0 4px 4px;
                transform: scaleX(0);
                transform-origin: left;
                transition: transform 0.3s ease;
            }

.benefit-card:hover::before {
                transform: scaleX(1);
            }

.benefit-icon-wrap {
            width: 48px;
            height: 48px;
            background: var(--accent-light);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1.1rem;
            transition: background 0.28s ease, transform 0.28s ease;
        }

.benefit-card:hover .benefit-icon-wrap {
            background: var(--accent);
            transform: scale(1.08);
        }

.benefit-icon-wrap svg {
            width: 22px;
            height: 22px;
            fill: var(--accent);
            transition: fill 0.28s ease;
        }

.benefit-card:hover .benefit-icon-wrap svg {
            fill: #fff;
        }

.benefit-card h3 {
            font-family: var(--font-display);
            font-size: 1.02rem;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 0.45rem;
            line-height: 1.3;
        }

.benefit-card p {
            font-size: 0.89rem;
            color: var(--text-light);
            line-height: 1.6;
            margin: 0;
        }

/* ---- Bottom stat strip ---- */

.benefit-stats-strip {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 1px;
            background: var(--border);
            border: 1px solid var(--border);
            border-radius: var(--radius-lg);
            overflow: hidden;
        }

.bstat {
            background: var(--surface);
            padding: 1.5rem 1.25rem;
            text-align: center;
            transition: background 0.25s ease;
        }

.bstat:hover {
                background: var(--accent-light);
            }

.bstat-value {
            font-size: 1.75rem;
            font-weight: 800;
            color: var(--accent);
            line-height: 1;
            margin-bottom: 0.35rem;
            font-family: var(--font-display);
        }

.bstat-desc {
            font-size: 0.8rem;
            color: var(--text-light);
            font-weight: 500;
            line-height: 1.4;
        }

/* ---- Responsive ---- */

@media (max-width: 1024px) {
            .benefit-cards {
                grid-template-columns: repeat(2, 1fr);
            }

            .benefit-stats-strip {
                grid-template-columns: repeat(2, 1fr);
            }
        }

@media (max-width: 600px) {
            .benefit-cards {
                grid-template-columns: 1fr;
                gap: 1rem;
            }

            .benefit-stats-strip {
                grid-template-columns: repeat(2, 1fr);
            }

            .bstat-value {
                font-size: 1.5rem;
            }

            .msg-benefits {
                padding: 3.5rem 1.25rem;
            }

            .benefit-card {
                padding: 1.4rem 1.25rem;
            }
        }

@media (max-width: 360px) {
            .benefit-stats-strip {
                grid-template-columns: 1fr;
            }
        }

/* =============================================
                                   FAQ SECTION
                                ============================================= */

/* FAQ */

.msg-faq {
            padding: 5rem 1.5rem;
            background: var(--surface-alt);
        }

.faq-list {
            max-width: 720px;
            margin: 0 auto;
            display: flex;
            flex-direction: column;
            gap: 8px
        }

.faq-item {
            background: var(--surface);
            border: 1px solid var(--border);
            border-radius: var(--radius-md);
            overflow: hidden;
            transition: border-color .25s
        }

.faq-item.open {
                border-color: var(--accent)
            }

.faq-trigger {
            width: 100%;
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 18px 20px;
            background: none;
            border: none;
            font-family: var(--font-body);
            font-size: .95rem;
            font-weight: 600;
            color: var(--text);
            cursor: pointer;
            text-align: left;
            gap: 12px
        }

.faq-chevron {
            width: 20px;
            height: 20px;
            fill: var(--text-light);
            transition: transform .3s;
            flex-shrink: 0
        }

.faq-item.open .faq-chevron {
            transform: rotate(180deg)
        }

.faq-body {
            max-height: 0;
            overflow: hidden;
            transition: max-height .35s ease
        }

.faq-body-inner {
            padding: 0 20px 18px;
            font-size: .9rem;
            color: var(--text-mid);
            line-height: 1.7
        }


/* =============================================
    RESPONSIVE
============================================= */

@media (max-width: 1024px) {
            .channels-grid {
                grid-template-columns: repeat(2, 1fr);
            }

            .features-grid {
                grid-template-columns: repeat(2, 1fr);
            }
        }

@media (max-width: 768px) {
            .msg-hero {
                padding: 5.5rem 1.25rem 3.5rem;
                min-height: auto;
            }

            .hero-inner {
                grid-template-columns: 1fr;
                gap: 2.5rem;
            }

            .hero-visual {
                display: none;
            }

            .hero-text p {
                max-width: 100%;
            }

            .channels-grid {
                grid-template-columns: 1fr;
                gap: 1rem;
            }

            .detail-row {
                grid-template-columns: 1fr;
                gap: 2rem;
                margin-bottom: 3rem;
            }

                .detail-row.flip .detail-text {
                    order: 1;
                }

                .detail-row.flip .detail-visual {
                    order: 2;
                }

            .detail-visual {
                display: none;
            }
            /* hide heavy visuals on mobile to keep clean layout */

            .features-grid {
                grid-template-columns: 1fr;
            }

            .usecases-grid {
                grid-template-columns: 1fr;
            }

            .related-grid {
                grid-template-columns: 1fr;
            }

            .section-header {
                margin-bottom: 2rem;
            }
        }

@media (max-width: 480px) {
            .hero-actions {
                flex-direction: column;
            }

            .btn-primary, .btn-outline {
                width: 100%;
                justify-content: center;
            }
        }

/* =============================================
            ACCESSIBILITY
        ============================================= */

@media (prefers-reduced-motion: reduce) {
            *, *::before, *::after {
                animation-duration: 0.01ms !important;
                animation-iteration-count: 1 !important;
                transition-duration: 0.01ms !important;
            }

            .reveal, .reveal-left, .reveal-right, .reveal-scale,
            .stagger > * {
                opacity: 1 !important;
                transform: none !important;
            }
        }