:root {
            --g950: #0f5230;
            --g900: #1B7A47;
            /* vibrant emerald — was near-black #0D2818 */
            --g800: #228F57;
            --g700: #2DA868;
            --g600: #38C07C;
            --g500: #55D49D;
            --gold: #C9A84C;
            --gold-l: #D4B86A;
            --gold-ll: #E8C97A;
            --white: #FFFFFF;
            --gray-50: #F9FAFB;
            --gray-100: #F3F4F6;
            --gray-200: #E5E7EB;
            --gray-600: #4B5563;
            --gray-800: #1F2937;
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        html {
            scroll-behavior: smooth;
        }

        body {
            font-family: 'Inter', sans-serif;
            background: #fff;
            color: var(--gray-800);
            overflow-x: hidden;
        }

        /* ─── NAVBAR ─────────────────────────────── */
        .navbar {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 1000;
            padding: 1.1rem 0;
            transition: all .3s;
        }

        .navbar.scrolled {
            background: rgba(27, 122, 71, .96);
            backdrop-filter: blur(12px);
            padding: .75rem 0;
            box-shadow: 0 2px 24px rgba(0, 0, 0, .2);
        }

        .nav-wrap {
            max-width: 1400px;
            margin: 0 auto;
            padding: 0 3rem;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .nav-logo {
            display: flex;
            align-items: center;
            gap: .7rem;
            text-decoration: none;
        }

        .nav-logo-icon {
            width: 40px;
            height: 40px;
            background: linear-gradient(135deg, var(--gold), var(--gold-ll));
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.2rem;
        }

        .nav-logo-name {
            font-size: 1.05rem;
            font-weight: 700;
            color: #fff;
            line-height: 1.1;
        }

        .nav-logo-ar {
            font-family: 'Amiri', serif;
            font-size: .85rem;
            color: var(--gold-l);
            line-height: 1;
        }

        .nav-links {
            display: flex;
            align-items: center;
            gap: 1.8rem;
            list-style: none;
        }

        .nav-links a {
            color: rgba(255, 255, 255, .8);
            text-decoration: none;
            font-size: .9rem;
            font-weight: 500;
            transition: color .2s;
        }

        .nav-links a:hover {
            color: var(--gold-l);
        }

        .nav-cta {
            background: linear-gradient(135deg, var(--gold), var(--gold-l)) !important;
            color: var(--g900) !important;
            padding: .55rem 1.4rem;
            border-radius: 8px;
            font-weight: 700 !important;
        }

        .nav-cta:hover {
            transform: translateY(-1px);
            box-shadow: 0 4px 16px rgba(201, 168, 76, .45);
        }

        .nav-burger {
            display: none;
            flex-direction: column;
            gap: 5px;
            cursor: pointer;
            padding: 5px;
        }

        .nav-burger span {
            width: 24px;
            height: 2px;
            background: #fff;
            border-radius: 2px;
            transition: all .3s;
        }

        /* ─── HERO ───────────────────────────────── */
        .hero {
            min-height: 100vh;
            background: linear-gradient(140deg, var(--g900) 0%, var(--g800) 55%, var(--g950) 100%);
            position: relative;
            display: flex;
            align-items: center;
            overflow: hidden;
        }

        .hero::before {
            content: '';
            position: absolute;
            inset: 0;
            pointer-events: none;
            background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.018' fill-rule='evenodd'%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/svg%3E");
        }

        .hero-glow {
            position: absolute;
            width: 700px;
            height: 700px;
            border-radius: 50%;
            background: radial-gradient(circle, rgba(255, 255, 255, .1) 0%, transparent 70%);
            top: -150px;
            right: -150px;
            pointer-events: none;
        }

        .hero-glow2 {
            position: absolute;
            width: 400px;
            height: 400px;
            border-radius: 50%;
            background: radial-gradient(circle, rgba(201, 168, 76, .12) 0%, transparent 70%);
            bottom: -100px;
            left: -100px;
            pointer-events: none;
        }

        .hero-wrap {
            max-width: 1400px;
            margin: 0 auto;
            padding: 8rem 3rem 4rem;
            display: grid;
            grid-template-columns: 1fr 40rem;
            gap: 3rem;
            align-items: center;
            width: 100%;
        }

        .hero-badge {
            display: inline-flex;
            align-items: center;
            gap: .5rem;
            background: rgba(201, 168, 76, .13);
            border: 1px solid rgba(201, 168, 76, .28);
            padding: .4rem 1rem;
            border-radius: 100px;
            color: var(--gold-l);
            font-size: .78rem;
            font-weight: 600;
            letter-spacing: .05em;
            text-transform: uppercase;
            margin-bottom: 1.4rem;
        }

        .hero-ar {
            font-family: 'Amiri', serif;
            font-size: 1.7rem;
            color: var(--gold);
            opacity: .65;
            display: block;
            margin-bottom: .4rem;
            direction: rtl;
        }

        .hero-title {
            font-size: clamp(2.1rem, 3.8vw, 3.4rem);
            font-weight: 800;
            line-height: 1.14;
            color: #fff;
            margin-bottom: 1.4rem;
        }

        .hero-title .hl {
            background: linear-gradient(135deg, var(--gold), var(--gold-ll));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .hero-sub {
            font-size: 1.1rem;
            color: rgba(255, 255, 255, .68);
            line-height: 1.72;
            margin-bottom: 2.4rem;
            max-width: 500px;
        }

        .hero-btns {
            display: flex;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .btn-p {
            background: linear-gradient(135deg, var(--gold), var(--gold-l));
            color: var(--g900);
            padding: .85rem 2rem;
            border-radius: 10px;
            font-weight: 700;
            font-size: .97rem;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: .5rem;
            transition: all .3s;
            border: none;
            cursor: pointer;
        }

        .btn-p:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 26px rgba(201, 168, 76, .5);
        }

        .btn-o {
            background: transparent;
            color: #fff;
            padding: .85rem 2rem;
            border-radius: 10px;
            font-weight: 600;
            font-size: .97rem;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: .5rem;
            border: 1px solid rgba(255, 255, 255, .28);
            transition: all .3s;
        }

        .btn-o:hover {
            background: rgba(255, 255, 255, .1);
            border-color: rgba(255, 255, 255, .55);
        }

        .hero-stats {
            display: flex;
            gap: 2.2rem;
            margin-top: 3rem;
            padding-top: 2rem;
            border-top: 1px solid rgba(255, 255, 255, .1);
        }

        .hero-stat-num {
            font-size: 1.75rem;
            font-weight: 800;
            color: var(--gold-l);
            display: block;
        }

        .hero-stat-lbl {
            font-size: .75rem;
            color: rgba(255, 255, 255, .45);
            text-transform: uppercase;
            letter-spacing: .05em;
        }

        /* TV Mockup */
        .hero-visual {
            position: relative;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 40rem;
        }

        .hero-visual>div {
            width: 100%;
            position: relative;
        }

        .tv {
            width: 100%;
            max-width: 660px;
            background: #080808;
            border-radius: 16px;
            padding: 10px;
            box-shadow: 0 40px 80px rgba(0, 0, 0, .65), 0 0 0 1px rgba(255, 255, 255, .04);
            position: relative;
        }

        .tv-screen {
            background: #040a07;
            border-radius: 9px;
            overflow: hidden;
            aspect-ratio: 16/9;
            position: relative;
        }

        .tv-stand {
            width: 55px;
            height: 9px;
            background: #161616;
            margin: 0 auto;
            border-radius: 0 0 4px 4px;
        }

        .tv-base {
            width: 90px;
            height: 4px;
            background: #121212;
            margin: 0 auto;
            border-radius: 4px;
        }

        /* Phone mini */
        .phone-mini {
            position: absolute;
            right: -85px;
            bottom: -155px;
            width: 155px;
            background: #181818;
            border-radius: 25px;
            padding: 7px;
            box-shadow: 0 18px 36px rgba(0, 0, 0, .55);
        }

        .phone-mini-screen {
            background: #040a07;
            border-radius: 20px;
            overflow: hidden;
            aspect-ratio: 9/19;
            position: relative;
        }

        .phone-mini-notch {
            width: 36px;
            height: 5px;
            background: #080808;
            border-radius: 2px;
            margin: 3px auto 0;
        }

        .phone-mini-screen .sl-arr {
            width: 18px;
            height: 18px;
            font-size: .5rem;
        }

        .phone-mini-screen .s-dot {
            width: 3px;
            height: 3px;
        }

        .phone-mini-screen .s-dot.on {
            width: 8px;
        }

        .phone-mini-screen .slider-dots {
            bottom: .25rem;
        }

        .phone-mini-screen .img-ph i {
            font-size: 1rem;
        }

        .phone-mini-screen .img-ph b {
            font-size: .32rem;
        }

        .phone-mini-screen .img-ph code {
            display: none;
        }

        .phone-mini-screen .img-ph small {
            display: none;
        }

        /* ─── SECTION UTILS ──────────────────────── */
        .container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 0 3rem;
        }

        .sec-lbl {
            display: flex;
            align-items: center;
            gap: .5rem;
            color: var(--g700);
            font-size: .78rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: .1em;
            margin-bottom: .7rem;
        }

        .sec-lbl::before {
            content: '';
            width: 22px;
            height: 2px;
            background: var(--g700);
            border-radius: 2px;
        }

        .sec-lbl.center {
            justify-content: center;
        }

        .sec-lbl.center::before {
            display: none;
        }

        .sec-lbl.light {
            color: var(--gold-l);
        }

        .sec-lbl.light::before {
            background: var(--gold-l);
        }

        .sec-title {
            font-size: clamp(1.75rem, 2.8vw, 2.4rem);
            font-weight: 800;
            line-height: 1.22;
            color: var(--g900);
            margin-bottom: .9rem;
        }

        .sec-title.white {
            color: #fff;
        }

        .sec-title.center {
            text-align: center;
        }

        .sec-sub {
            font-size: 1.05rem;
            color: var(--gray-600);
            line-height: 1.72;
            max-width: 580px;
        }

        .sec-sub.center {
            text-align: center;
            margin: 0 auto;
        }

        .sec-sub.white {
            color: rgba(255, 255, 255, .62);
        }

        /* ─── PAIN ───────────────────────────────── */
        .pain-sec {
            padding: 6rem 0;
            background: #0b1e12;
            position: relative;
            overflow: hidden;
        }

        .pain-sec::after {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(ellipse 70% 55% at 50% 0%, rgba(27,122,71,.18) 0%, transparent 70%);
            pointer-events: none;
        }

        .pain-hdr {
            text-align: center;
            margin-bottom: 3.5rem;
            position: relative;
            z-index: 1;
        }

        .pain-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.5rem;
            margin-top: 3rem;
            position: relative;
            z-index: 1;
        }

        .pain-card {
            background: rgba(255, 255, 255, .04);
            border: 1px solid rgba(255, 255, 255, .07);
            border-radius: 20px;
            padding: 2rem;
            position: relative;
            overflow: hidden;
            transition: all .3s;
        }

        .pain-card:hover {
            background: rgba(255, 255, 255, .07);
            border-color: rgba(239, 68, 68, .28);
            transform: translateY(-4px);
        }

        .pain-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 2px;
            background: linear-gradient(90deg, #ef4444, #f97316);
            pointer-events: none;
        }

        .pain-qmark {
            font-family: Georgia, serif;
            font-size: 3.5rem;
            line-height: .9;
            color: rgba(239, 68, 68, .22);
            display: block;
            margin-bottom: .6rem;
        }

        .pain-scenario {
            font-size: 1.02rem;
            font-weight: 600;
            font-style: italic;
            color: #fff;
            line-height: 1.52;
            margin-bottom: 1rem;
        }

        .pain-txt {
            font-size: .85rem;
            color: rgba(255, 255, 255, .45);
            line-height: 1.68;
        }

        .pain-tag {
            display: inline-flex;
            align-items: center;
            gap: .35rem;
            background: rgba(239, 68, 68, .1);
            border: 1px solid rgba(239, 68, 68, .18);
            color: #f87171;
            font-size: .7rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: .07em;
            padding: .28rem .75rem;
            border-radius: 100px;
            margin-top: 1.4rem;
        }

        .pain-divider {
            display: flex;
            align-items: center;
            gap: 1.2rem;
            margin: 3.2rem 0 2rem;
            position: relative;
            z-index: 1;
        }

        .pain-divider::before,
        .pain-divider::after {
            content: '';
            flex: 1;
            height: 1px;
            background: rgba(255, 255, 255, .07);
        }

        .pain-divider-icon {
            width: 42px;
            height: 42px;
            background: linear-gradient(135deg, var(--g800), var(--g700));
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: #fff;
            font-size: 1rem;
            animation: bob 2s ease-in-out infinite;
            flex-shrink: 0;
        }

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

        .pain-solution {
            text-align: center;
            position: relative;
            z-index: 1;
        }

        .pain-badge {
            display: inline-flex;
            align-items: center;
            gap: .6rem;
            background: linear-gradient(135deg, var(--g800), var(--g700));
            color: #fff;
            padding: .85rem 2.2rem;
            border-radius: 100px;
            font-weight: 700;
            font-size: 1rem;
            box-shadow: 0 8px 24px rgba(34,143,87,.35);
        }

        .pain-badge-sub {
            display: block;
            color: rgba(255,255,255,.55);
            font-size: .82rem;
            font-weight: 400;
            margin-top: .6rem;
        }

        /* ─── FEATURES ───────────────────────────── */
        .features-sec {
            padding: 6rem 0;
            background: #fff;
        }

        .features-hdr {
            text-align: center;
            margin-bottom: 4rem;
        }

        .features-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.8rem;
        }

        .f-card {
            background: #fff;
            border: 1px solid var(--gray-200);
            border-radius: 20px;
            padding: 1.9rem;
            transition: all .3s;
            position: relative;
            overflow: hidden;
        }

        .f-card:hover {
            transform: translateY(-4px);
            box-shadow: 0 20px 40px rgba(0, 0, 0, .08);
            border-color: var(--g500);
        }

        .f-card.feat,
        .features-grid .f-card:nth-child(even) {
            background: linear-gradient(140deg, var(--g900), var(--g800));
            border: none;
        }

        .f-icon {
            width: 54px;
            height: 54px;
            background: linear-gradient(135deg, var(--g700), var(--g600));
            border-radius: 14px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.35rem;
            color: #fff;
            margin-bottom: 1.2rem;
        }

        .f-card.feat .f-icon,
        .features-grid .f-card:nth-child(even) .f-icon {
            background: rgba(201, 168, 76, .18);
            border: 1px solid rgba(201, 168, 76, .3);
            color: var(--gold-l);
        }

        .f-title {
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--g900);
            margin-bottom: .65rem;
        }

        .f-card.feat .f-title,
        .features-grid .f-card:nth-child(even) .f-title {
            color: #fff;
        }

        .f-desc {
            font-size: .875rem;
            color: var(--gray-600);
            line-height: 1.65;
            margin-bottom: .9rem;
        }

        .f-card.feat .f-desc,
        .features-grid .f-card:nth-child(even) .f-desc {
            color: rgba(255, 255, 255, .65);
        }

        .f-list {
            list-style: none;
            display: flex;
            flex-direction: column;
            gap: .38rem;
        }

        .f-list li {
            font-size: .83rem;
            color: var(--gray-600);
            display: flex;
            align-items: flex-start;
            gap: .45rem;
        }

        .f-card.feat .f-list li,
        .features-grid .f-card:nth-child(even) .f-list li {
            color: rgba(255, 255, 255, .6);
        }

        .f-list li::before {
            content: '✓';
            color: var(--g600);
            font-weight: 700;
            flex-shrink: 0;
            margin-top: 1px;
        }

        .f-card.feat .f-list li::before,
        .features-grid .f-card:nth-child(even) .f-list li::before {
            color: var(--gold-l);
        }

        /* ─── SCREENS SHOWCASE ───────────────────── */
        .screens-sec {
            padding: 6rem 0;
            background: linear-gradient(140deg, var(--g900), var(--g950));
        }

        .screens-hdr {
            text-align: center;
            margin-bottom: 3.5rem;
        }

        .screens-tabs {
            display: flex;
            gap: .5rem;
            justify-content: center;
            flex-wrap: wrap;
            margin-bottom: 2.5rem;
        }

        .s-tab {
            background: rgba(255, 255, 255, .07);
            border: 1px solid rgba(255, 255, 255, .1);
            color: rgba(255, 255, 255, .6);
            padding: .55rem 1.15rem;
            border-radius: 8px;
            font-size: .85rem;
            font-weight: 500;
            cursor: pointer;
            transition: all .2s;
        }

        .s-tab:hover,
        .s-tab.active {
            background: rgba(201, 168, 76, .14);
            border-color: rgba(201, 168, 76, .3);
            color: var(--gold-l);
        }

        .screen-wrap {
            max-width: 780px;
            margin: 0 auto;
        }

        .screen-shell {
            background: #060606;
            border-radius: 16px;
            padding: 9px;
            box-shadow: 0 40px 80px rgba(0, 0, 0, .55);
        }

        .screen-pane {
            border-radius: 10px;
            overflow: hidden;
            aspect-ratio: 16/9;
            display: none;
            position: relative;
        }

        .screen-pane.active {
            display: block;
        }

        /* ─── IMAGE SLIDERS ──────────────────────── */
        .img-slider {
            position: absolute;
            inset: 0;
            overflow: hidden;
        }

        .slider-track {
            display: flex;
            height: 100%;
            transition: transform .52s cubic-bezier(.4, 0, .2, 1);
        }

        .slider-slide {
            min-width: 100%;
            height: 100%;
            position: relative;
            overflow: hidden;
            background: #040a07;
        }

        .slider-slide img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }

        .img-ph {
            width: 100%;
            height: 100%;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: .55rem;
            background: rgba(255, 255, 255, .025);
            text-align: center;
            padding: 1.2rem;
        }

        .img-ph i {
            font-size: 2.2rem;
            color: rgba(255, 255, 255, .15);
        }

        .img-ph b {
            color: rgba(255, 255, 255, .5);
            font-size: .82rem;
            font-weight: 600;
        }

        .img-ph code {
            color: rgba(255, 255, 255, .25);
            font-size: .67rem;
            background: rgba(255, 255, 255, .06);
            padding: .18rem .5rem;
            border-radius: 4px;
            font-family: monospace;
        }

        .img-ph small {
            color: rgba(255, 255, 255, .18);
            font-size: .62rem;
        }

        .s-dot {
            width: 7px;
            height: 7px;
            border-radius: 50%;
            background: rgba(255, 255, 255, .25);
            cursor: pointer;
            transition: all .22s;
            border: none;
            padding: 0;
            display: inline-block;
        }

        .s-dot.on {
            background: var(--gold-l);
            width: 20px;
            border-radius: 3px;
        }

        .slider-dots {
            position: absolute;
            bottom: .7rem;
            left: 50%;
            transform: translateX(-50%);
            display: flex;
            gap: .4rem;
            z-index: 10;
        }

        .sl-arr {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            width: 32px;
            height: 32px;
            background: rgba(0, 0, 0, .42);
            border: 1px solid rgba(255, 255, 255, .14);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: rgba(255, 255, 255, .65);
            cursor: pointer;
            z-index: 10;
            transition: all .2s;
            font-size: .72rem;
            padding: 0;
        }

        .sl-arr:hover {
            background: rgba(201, 168, 76, .3);
            border-color: rgba(201, 168, 76, .4);
            color: var(--gold-l);
        }

        .sl-prev {
            left: .7rem;
        }

        .sl-next {
            right: .7rem;
        }

        /* Hero slider — scaled dots & arrows */
        .tv-screen .sl-arr {
            width: 26px;
            height: 26px;
            font-size: .6rem;
        }

        .tv-screen .s-dot {
            width: 5px;
            height: 5px;
        }

        .tv-screen .s-dot.on {
            width: 14px;
        }

        .tv-screen .slider-dots {
            bottom: .4rem;
        }

        .tv-screen .img-ph i {
            font-size: 1.6rem;
        }

        .tv-screen .img-ph b {
            font-size: .62rem;
        }

        .tv-screen .img-ph code {
            font-size: .52rem;
        }

        .tv-screen .img-ph small {
            font-size: .46rem;
        }

        /* Phone slider */
        .phone-lg-screen {
            background: #0e4828;
            border-radius: 28px;
            overflow: hidden;
            aspect-ratio: 9/19;
            position: relative;
        }

        .phone-lg-screen .img-ph i {
            font-size: 1.4rem;
        }

        .phone-lg-screen .img-ph b {
            font-size: .46rem;
        }

        .phone-lg-screen .img-ph code {
            font-size: .38rem;
        }

        .phone-lg-screen .img-ph small {
            font-size: .35rem;
        }

        .phone-lg-screen .s-dot {
            width: 4px;
            height: 4px;
        }

        .phone-lg-screen .s-dot.on {
            width: 10px;
        }

        .phone-lg-screen .slider-dots {
            bottom: .35rem;
        }

        .phone-lg-screen .sl-arr {
            width: 20px;
            height: 20px;
            font-size: .52rem;
        }

        /* Slide-in caption bar */
        .slide-caption {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            padding: .5rem .9rem;
            background: linear-gradient(transparent, rgba(0, 0, 0, .65));
            color: rgba(255, 255, 255, .7);
            font-size: .75rem;
            z-index: 5;
        }

        /* ─── HOW IT WORKS ───────────────────────── */
        .how-sec {
            padding: 6rem 0;
            background: var(--gray-50);
        }

        .how-hdr {
            text-align: center;
            margin-bottom: 4rem;
        }

        .steps {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 2rem;
            position: relative;
        }

        .steps::before {
            content: '';
            position: absolute;
            top: 34px;
            left: calc(16.67% + 24px);
            right: calc(16.67% + 24px);
            height: 2px;
            background: linear-gradient(90deg, var(--g600), var(--g500));
            z-index: 0;
        }

        .step {
            text-align: center;
            position: relative;
            z-index: 1;
        }

        .step-num {
            width: 68px;
            height: 68px;
            background: linear-gradient(135deg, var(--g700), var(--g600));
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.45rem;
            font-weight: 800;
            color: #fff;
            margin: 0 auto 1.4rem;
            box-shadow: 0 4px 20px rgba(45, 106, 79, .42);
        }

        .step-title {
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--g900);
            margin-bottom: .65rem;
        }

        .step-desc {
            font-size: .88rem;
            color: var(--gray-600);
            line-height: 1.65;
        }

        /* ─── MOBILE SECTION ─────────────────────── */
        .mobile-sec {
            padding: 6rem 0;
            background: #fff;
        }

        .mobile-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 5rem;
            align-items: center;
        }

        .mobile-feats {
            display: flex;
            flex-direction: column;
            gap: 1.4rem;
            margin-top: 2.2rem;
        }

        .m-feat {
            display: flex;
            gap: .95rem;
            align-items: flex-start;
        }

        .m-feat-icon {
            width: 44px;
            height: 44px;
            background: linear-gradient(135deg, rgba(55, 212, 157, .12), rgba(55, 212, 157, .22));
            border: 1px solid rgba(55, 212, 157, .35);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.1rem;
            color: var(--g700);
            flex-shrink: 0;
        }

        .m-feat-text h4 {
            font-size: .93rem;
            font-weight: 700;
            color: var(--g900);
            margin-bottom: .22rem;
        }

        .m-feat-text p {
            font-size: .84rem;
            color: var(--gray-600);
            line-height: 1.58;
        }

        .mobile-vis {
            display: flex;
            justify-content: center;
            position: relative;
        }

        /* Large phone mockup */
        .phone-lg {
            width: 270px;
            background: #111;
            border-radius: 38px;
            padding: 11px;
            box-shadow: 0 40px 80px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .05);
            position: relative;
            z-index: 1;
        }

        /* float cards */
        .fl-card {
            position: absolute;
            background: #fff;
            border-radius: 12px;
            padding: .7rem .9rem;
            box-shadow: 0 10px 30px rgba(0, 0, 0, .12);
            display: flex;
            align-items: center;
            gap: .7rem;
            transition: opacity .25s;
        }
        .fl-card.fading { opacity: 0; }

        .fl-card.c1 {
            top: 55px;
            right: -65px;
        }

        .fl-card.c2 {
            bottom: 95px;
            left: -75px;
        }

        .fl-ic {
            width: 34px;
            height: 34px;
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: .95rem;
            flex-shrink: 0;
        }

        .fl-txt h5 {
            font-size: .72rem;
            font-weight: 700;
            color: var(--g900);
            margin-bottom: 2px;
        }

        .fl-txt p {
            font-size: .62rem;
            color: var(--gray-600);
        }

        /* ─── TESTIMONIALS ───────────────────────── */
        .test-sec {
            padding: 6rem 0;
            background: var(--gray-50);
        }

        .test-hdr {
            text-align: center;
            margin-bottom: 3.5rem;
        }

        .test-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.8rem;
        }

        .t-card {
            background: #fff;
            border-radius: 16px;
            padding: 1.8rem;
            border: 1px solid var(--gray-200);
        }

        .t-stars {
            color: var(--gold);
            font-size: .88rem;
            margin-bottom: .9rem;
        }

        .t-quote {
            font-size: .92rem;
            color: var(--gray-600);
            line-height: 1.7;
            margin-bottom: 1.4rem;
            font-style: italic;
        }

        .t-author {
            display: flex;
            align-items: center;
            gap: .7rem;
        }

        .t-av {
            width: 42px;
            height: 42px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            font-size: .88rem;
            color: #fff;
        }

        .t-name {
            font-size: .88rem;
            font-weight: 700;
            color: var(--g900);
        }

        .t-role {
            font-size: .76rem;
            color: var(--gray-600);
        }

        /* ─── CTA ────────────────────────────────── */
        .cta-sec {
            padding: 6rem 0;
            background: linear-gradient(140deg, var(--g900), var(--g800), var(--g700));
            position: relative;
            overflow: hidden;
        }

        .cta-sec::before {
            content: '';
            position: absolute;
            inset: 0;
            pointer-events: none;
            background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.015' fill-rule='evenodd'%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/svg%3E");
        }

        .cta-body {
            text-align: center;
            position: relative;
            z-index: 1;
        }

        .cta-title {
            font-size: clamp(1.9rem, 3.3vw, 2.8rem);
            font-weight: 800;
            color: #fff;
            margin-bottom: .9rem;
        }

        .cta-sub {
            font-size: 1.05rem;
            color: rgba(255, 255, 255, .62);
            max-width: 480px;
            margin: 0 auto 2.3rem;
            line-height: 1.65;
        }

        .cta-btns {
            display: flex;
            gap: 1rem;
            justify-content: center;
            flex-wrap: wrap;
        }

        .cta-note {
            margin-top: 1.4rem;
            font-size: .82rem;
            color: rgba(255, 255, 255, .35);
        }

        /* ─── FOOTER ─────────────────────────────── */
        .footer {
            background: #0b3d22;
            padding: 4rem 0 2rem;
        }

        .footer-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 1fr 1fr;
            gap: 2.8rem;
            padding-bottom: 2.8rem;
            border-bottom: 1px solid rgba(255, 255, 255, .07);
        }

        .footer-brand {
            display: flex;
            flex-direction: column;
            gap: .9rem;
        }

        .fl-logo {
            display: flex;
            align-items: center;
            gap: .7rem;
        }

        .fl-logo-ic {
            width: 38px;
            height: 38px;
            background: linear-gradient(135deg, var(--gold), var(--gold-ll));
            border-radius: 9px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.1rem;
        }

        .fl-logo-name {
            font-size: 1rem;
            font-weight: 700;
            color: #fff;
        }

        .fl-logo-ar {
            font-family: 'Amiri', serif;
            color: var(--gold-l);
            font-size: .82rem;
        }

        .footer-tag {
            color: rgba(255, 255, 255, .38);
            font-size: .84rem;
            line-height: 1.65;
            max-width: 260px;
        }

        .footer-social {
            display: flex;
            gap: .65rem;
            margin-top: .3rem;
        }

        .footer-social a {
            width: 34px;
            height: 34px;
            background: rgba(255, 255, 255, .05);
            border: 1px solid rgba(255, 255, 255, .07);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: rgba(255, 255, 255, .38);
            text-decoration: none;
            font-size: .82rem;
            transition: all .2s;
        }

        .footer-social a:hover {
            background: rgba(201, 168, 76, .1);
            border-color: rgba(201, 168, 76, .2);
            color: var(--gold-l);
        }

        .footer-col-title {
            font-size: .72rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: .1em;
            color: rgba(255, 255, 255, .45);
            margin-bottom: 1.1rem;
        }

        .footer-links {
            display: flex;
            flex-direction: column;
            gap: .55rem;
            list-style: none;
        }

        .footer-links a {
            color: rgba(255, 255, 255, .38);
            text-decoration: none;
            font-size: .84rem;
            transition: color .2s;
        }

        .footer-links a:hover {
            color: var(--gold-l);
        }

        .footer-bottom {
            padding-top: 1.8rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .footer-copy {
            color: rgba(255, 255, 255, .22);
            font-size: .78rem;
        }

        .footer-copy span {
            color: var(--gold-l);
        }

        /* ─── ANIMATIONS ─────────────────────────── */
        .fade-up {
            opacity: 0;
            transform: translateY(28px);
            transition: opacity .6s ease, transform .6s ease;
        }

        .fade-up.vis {
            opacity: 1;
            transform: translateY(0);
        }

        .fade-up:nth-child(2) {
            transition-delay: .1s;
        }

        .fade-up:nth-child(3) {
            transition-delay: .2s;
        }

        .fade-up:nth-child(4) {
            transition-delay: .3s;
        }

        /* ─── PROBLEM SECTION ───────────────────────── */
        .problem-sec {
            padding: 5.5rem 0;
            background: #F9FAFB;
        }

        .problem-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.8rem;
            margin-top: 3rem;
        }

        /* ─── RESPONSIVE ─────────────────────────── */

        /* ── Tablet (≤1024px) ── */
        @media(max-width:1024px) {
            .nav-wrap,
            .container { padding: 0 2rem; }

            .hero-wrap {
                grid-template-columns: 1fr 32rem;
                padding: 7rem 2rem 3.5rem;
                gap: 2rem;
            }
            .hero-visual { width: 32rem; }

            .features-grid,
            .test-grid { grid-template-columns: repeat(2, 1fr); }

            .problem-grid { grid-template-columns: repeat(2, 1fr); }

            .mobile-grid { gap: 3rem; }

            .footer-grid { grid-template-columns: repeat(2, 1fr); }
        }

        /* ── Mobile (≤768px) ── */
        @media(max-width:768px) {
            .nav-wrap,
            .container { padding: 0 1.2rem; }

            .nav-links { display: none; }
            .nav-burger { display: flex; }

            .hero-wrap {
                grid-template-columns: 1fr;
                text-align: center;
                padding: 5.5rem 1.2rem 2.5rem;
            }

            /* Hero text */
            .hero .hero-badge { display: none; }
            .hero-ar { display: none; }
            .hero-btns .btn-o { display: none; }
            .hero-title { font-size: clamp(1.75rem, 6.5vw, 2.2rem); }
            .hero-sub { font-size: 1rem; margin: 0 auto 2rem; }
            .hero-stat-num { font-size: 1.5rem; }
            .hero-stats { justify-content: center; gap: 1.5rem; margin-top: 2rem; padding-top: 1.5rem; }
            .hero-btns { justify-content: center; }
            .hero-visual { width: 100%; }
            .phone-mini { right: -10px; bottom: -110px; width: 110px; }

            .features-sec, .screens-sec, .how-sec,
            .mobile-sec, .test-sec, .cta-sec { padding: 4rem 0; }
            .problem-sec { padding: 3.5rem 0; }

            /* Section headers */
            .sec-lbl { font-size: .72rem; }
            .sec-title { font-size: clamp(1.5rem, 5.5vw, 1.9rem); }
            .sec-sub { font-size: .95rem; }
            .features-hdr, .screens-hdr, .how-hdr, .test-hdr { margin-bottom: 2.5rem; }

            /* Features */
            .f-title { font-size: .95rem; }

            /* How it works */
            .step-title { font-size: .95rem; }

            /* Mobile section */
            .m-feat-text h4 { font-size: .88rem; }

            /* Testimonials */
            .t-quote { font-size: .88rem; }

            /* CTA */
            .cta-title { font-size: clamp(1.6rem, 5.5vw, 2rem); }
            .cta-sub { font-size: .95rem; margin-bottom: 1.8rem; }

            .pain-grid, .features-grid, .steps,
            .test-grid, .problem-grid { grid-template-columns: 1fr; }
            .steps::before { display: none; }

            .mobile-grid { grid-template-columns: 1fr; gap: 2.5rem; }
            .mobile-vis { order: -1; }
            .fl-card { display: none; }

            .screens-tabs {
                overflow-x: auto;
                flex-wrap: nowrap;
                justify-content: flex-start;
                padding-bottom: .5rem;
                -webkit-overflow-scrolling: touch;
                scrollbar-width: none;
            }
            .screens-tabs::-webkit-scrollbar { display: none; }
            .s-tab { font-size: .78rem; padding: .48rem .88rem; flex-shrink: 0; }

            .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
            .footer-brand { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; gap: 1rem; }
            .footer-tag { max-width: 100%; flex: 1 1 100%; }
            .footer-social { flex: 1 1 100%; }
            .footer-bottom { flex-direction: column; gap: .8rem; text-align: center; }
        }

        /* ── Small mobile (≤480px) ── */
        @media(max-width:480px) {
            .phone-mini { display: none; }

            /* Hero text */
            .hero-badge { font-size: .66rem; padding: .3rem .75rem; }
            .hero-ar { font-size: 1.15rem; }
            .hero-title { font-size: clamp(1.5rem, 7.5vw, 1.85rem); line-height: 1.18; }
            .hero-sub { font-size: .88rem; line-height: 1.65; }
            .hero-stat-num { font-size: 1.25rem; }
            .hero-stat-lbl { font-size: .62rem; }
            .hero-stats { gap: .8rem; margin-top: 1.8rem; padding-top: 1.2rem; }

            /* Buttons */
            .btn-p, .btn-o { font-size: .88rem; padding: .72rem 1.4rem; }

            /* Hero TV slider — smaller controls on narrow screens */
            .tv-screen .sl-arr { width: 20px; height: 20px; font-size: .5rem; }
            .tv-screen .s-dot { width: 4px; height: 4px; }
            .tv-screen .s-dot.on { width: 10px; }
            .tv-screen .slider-dots { bottom: .25rem; gap: .28rem; }
            .slide-caption { font-size: .62rem; padding: .35rem .6rem; }

            /* Section headers */
            .sec-lbl { font-size: .68rem; }
            .sec-title { font-size: clamp(1.35rem, 6vw, 1.65rem); }
            .sec-sub { font-size: .88rem; }

            /* Features */
            .f-title { font-size: .9rem; }
            .f-desc { font-size: .82rem; }

            /* How it works */
            .step-num { width: 56px; height: 56px; font-size: 1.2rem; }
            .step-title { font-size: .9rem; }

            /* Mobile section */
            .m-feat-icon { width: 38px; height: 38px; font-size: .95rem; }
            .m-feat-text h4 { font-size: .85rem; }

            /* Testimonials */
            .t-quote { font-size: .82rem; }
            .t-card { padding: 1.4rem; }

            /* CTA */
            .cta-title { font-size: clamp(1.4rem, 7vw, 1.75rem); }
            .cta-sub { font-size: .88rem; }
            .cta-note { font-size: .75rem; }

            /* Footer */
            .footer { padding: 2.5rem 0 1.5rem; }
            .footer-grid { gap: 1.2rem; }
            .fl-logo-name { font-size: .9rem; }
        }

        /* ─── DEMO MODAL ─────────────────────────────── */
        .modal-overlay {
            display: none;
            position: fixed;
            inset: 0;
            z-index: 2000;
            align-items: center;
            justify-content: center;
            padding: .5rem 1rem;
        }

        .modal-overlay.open {
            display: flex;
        }

        .modal-backdrop {
            position: absolute;
            inset: 0;
            background: rgba(0, 0, 0, .5);
            backdrop-filter: blur(20px);
        }

        .modal-box {
            position: relative;
            background: #fff;
            border-radius: 24px;
            padding: 2rem 2rem 2.2rem;
            width: 100%;
            max-width: 640px;
            max-height: 90vh;
            overflow-y: auto;
            box-shadow: 0 25px 50px rgba(0, 0, 0, .25);
            z-index: 1;
        }

        .modal-close {
            position: absolute;
            top: .75rem;
            right: .75rem;
            width: 36px;
            height: 36px;
            background: #e5e5e5;
            border: none;
            border-radius: 50%;
            font-size: 1.2rem;
            font-weight: 700;
            color: #555;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            line-height: 1;
        }

        .modal-close:hover {
            background: #d0d0d0;
        }

        .modal-title {
            font-size: 1.6rem;
            font-weight: 800;
            color: #0a7c6a;
            text-align: center;
            margin-bottom: 1.5rem;
        }

        .modal-form {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .form-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 1rem;
        }

        .form-group {
            display: flex;
            flex-direction: column;
            gap: .4rem;
        }

        .form-group label {
            font-size: .85rem;
            font-weight: 600;
            color: #0a7c6a;
        }

        .form-group input,
        .form-group select,
        .form-group textarea {
            width: 100%;
            padding: .75rem 1rem;
            border-radius: 12px;
            border: 2px solid #e5e5e5;
            background: #fafafa;
            font-size: .93rem;
            font-family: inherit;
            outline: none;
            transition: border-color .2s;
        }

        .form-group input:focus,
        .form-group select:focus,
        .form-group textarea:focus {
            border-color: #0a7c6a;
        }

        .form-group textarea {
            resize: none;
        }

        .phone-row {
            display: flex;
            gap: .5rem;
        }

        .phone-row select {
            width: 90px;
            flex-shrink: 0;
        }

        .phone-row input {
            flex: 1;
            min-width: 0;
        }

        .modal-submit {
            width: 100%;
            padding: .9rem;
            border: none;
            border-radius: 12px;
            background: linear-gradient(135deg, #0a7c6a, #064e3b);
            color: #fff;
            font-size: 1rem;
            font-weight: 700;
            cursor: pointer;
            transition: opacity .2s;
        }

        .modal-submit:hover {
            opacity: .88;
        }

        .modal-submit:disabled {
            opacity: .5;
            cursor: not-allowed;
        }

        .modal-success {
            text-align: center;
            padding: 2rem 1rem;
        }

        .modal-success .success-icon {
            font-size: 3rem;
            margin-bottom: .75rem;
        }

        .modal-success h3 {
            font-size: 1.4rem;
            font-weight: 800;
            color: #0a7c6a;
            margin-bottom: .5rem;
        }

        .modal-success p {
            color: #555;
            font-size: .93rem;
            line-height: 1.6;
        }

        .modal-error {
            background: #FEF2F2;
            border: 1px solid #FECACA;
            color: #B91C1C;
            border-radius: 10px;
            padding: .75rem 1rem;
            font-size: .85rem;
            margin-top: .25rem;
            display: none;
        }

        @media(max-width:540px) {
            .form-row {
                grid-template-columns: 1fr;
            }
        }
