/* ================================================================
   PHARMATECH PRO — Creative Redesign v2.0
   Bold, modern, SaaS-grade design system
   ================================================================ */

/* ── 0. DESIGN TOKENS ─────────────────────────────────────────── */
:root {
    /* Brand */
    --p:        #0e3d52;      /* deep navy-teal  */
    --p2:       #1a5c79;      /* mid teal        */
    --p3:       #2580a6;      /* bright teal     */
    --g:        #00c896;      /* emerald green   */
    --g2:       #00a87e;      /* deeper green    */
    --g-fade:   rgba(0,200,150,.12);
    --gold:     #f59e0b;

    /* Surfaces */
    --bg-dark:  #060f1a;      /* deep night      */
    --bg-card:  #0d1e2d;      /* card dark       */
    --bg-glass: rgba(255,255,255,.06);
    --bg-light: #f3f8fb;
    --bg-white: #ffffff;

    /* Text */
    --txt-dark:  #0d1b2a;
    --txt-mid:   #344054;
    --txt-light: #637381;
    --txt-muted: #98a2b3;

    /* Borders */
    --bdr:       rgba(255,255,255,.10);
    --bdr-light: #dde8ef;

    /* Gradients */
    --grad-hero:   linear-gradient(135deg, #060f1a 0%, #0e3d52 50%, #0a2a3a 100%);
    --grad-brand:  linear-gradient(135deg, var(--p) 0%, var(--p3) 100%);
    --grad-green:  linear-gradient(135deg, var(--g) 0%, var(--g2) 100%);
    --grad-card:   linear-gradient(145deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%);

    /* Shadows */
    --sh-xs:  0 1px 3px rgba(0,0,0,.06);
    --sh-sm:  0 2px 10px rgba(14,61,82,.08);
    --sh-md:  0 6px 24px rgba(14,61,82,.12);
    --sh-lg:  0 16px 48px rgba(14,61,82,.18);
    --sh-xl:  0 24px 64px rgba(14,61,82,.24);
    --sh-g:   0 8px 28px rgba(0,200,150,.35);

    /* Radius */
    --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px; --r-2xl: 32px; --r-full: 9999px;

    /* Transitions */
    --t: 0.22s cubic-bezier(.4,0,.2,1);
    --t-slow: 0.4s cubic-bezier(.4,0,.2,1);

    --title-font: "Instrument Sans", serif;
}

/* ── 1. BASE ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--title-font);
    color: var(--txt-dark);
    background: var(--bg-white);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}
a, a:hover { transition: var(--t) !important; }
section { padding: 88px 0; }

/* ── 2. TYPOGRAPHY ────────────────────────────────────────────── */
.langing-section-title {
    font-size: 44px;
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: -.025em;
    color: var(--txt-dark);
    font-family: var(--title-font);
}
.langing-section-title .title-span-color {
    background: linear-gradient(90deg, var(--g) 0%, #00e5b0 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.section-description {
    font-size: 17px !important;
    line-height: 1.7;
    color: var(--txt-light);
    padding-top: 14px;
    margin-bottom: 0;
}

/* Section badge */
.section-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px;
    background: var(--g-fade);
    color: var(--g2);
    border: 1px solid rgba(0,200,150,.25);
    border-radius: var(--r-full);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.section-badge::before {
    content: "";
    width: 6px; height: 6px;
    background: var(--g);
    border-radius: 50%;
    display: inline-block;
}

/* ── 3. HEADER ────────────────────────────────────────────────── */
.header-section.home-header {
    background: rgba(6,15,26,.75) !important;
    border-bottom: 1px solid var(--bdr);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    padding: 12px 0;
    transition: background var(--t), box-shadow var(--t);
}
.header-scrolled {
    background: rgba(6,15,26,.92) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,.3) !important;
}
.header-section.home-header a {
    color: rgba(255,255,255,.85) !important;
}
.header-section .nav-link {
    font-size: 14.5px;
    font-weight: 500;
    color: rgba(255,255,255,.80) !important;
    padding: 7px 14px !important;
    border-radius: var(--r-sm);
    transition: color var(--t), background var(--t) !important;
}
.header-section .nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.08);
}
/* Active nav link */
.header-section .nav-link.active { color: var(--g) !important; }

/* Logo */
.nav-logo { height: 52px; width: auto; object-fit: contain; }

/* CTA button in header */
.header-section .get-app-btn,
.header-section .get-app-btn:hover {
    background: var(--grad-green) !important;
    color: #fff !important;
    border: none !important;
    font-size: 14px;
    font-weight: 700;
    border-radius: var(--r-md);
    padding: 10px 22px !important;
    box-shadow: var(--sh-g);
    transition: transform var(--t), box-shadow var(--t) !important;
}
.header-section .get-app-btn:hover {
    transform: translateY(-2px) scale(1.02) !important;
    box-shadow: 0 12px 32px rgba(0,200,150,.45) !important;
}

/* Language pill */
.lang-pill {
    background: rgba(255,255,255,.08) !important;
    color: rgba(255,255,255,.8) !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    border-radius: var(--r-full) !important;
    padding: 5px 12px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    transition: all var(--t) !important;
}
.lang-pill:hover {
    background: var(--g) !important;
    color: #fff !important;
    border-color: var(--g) !important;
}
.lang-switcher-menu {
    background: var(--bg-card) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.4) !important;
    padding: 6px !important;
}
.lang-switcher-menu .dropdown-item {
    color: rgba(255,255,255,.75) !important;
    border-radius: var(--r-sm);
    padding: 9px 14px;
    font-size: 14px;
    transition: all var(--t) !important;
}
.lang-switcher-menu .dropdown-item:hover,
.lang-switcher-menu .dropdown-item.lang-active {
    background: var(--g) !important;
    color: #fff !important;
}

/* Mobile menu */
.header-section .mobile-menu {
    background: var(--bg-card) !important;
    border-right: 1px solid rgba(255,255,255,.08) !important;
}
.header-section .mobile-menu .offcanvas-header {
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.header-section .accordion-button {
    font-size: 15px; font-weight: 500;
    color: rgba(255,255,255,.8) !important;
    padding: 14px 0 !important;
    background: transparent !important;
}
.header-section .accordion-item {
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    background: transparent;
}
.header-section .accordion-button:not(.collapsed) { color: var(--g) !important; }
.header-section .accordion-button::after { filter: invert(1) opacity(.6); }

/* ── 4. BUTTONS ───────────────────────────────────────────────── */
.ps-custom-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: var(--grad-green) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--r-md) !important;
    padding: 14px 28px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
    box-shadow: var(--sh-g) !important;
    transition: transform var(--t), box-shadow var(--t) !important;
    cursor: pointer;
}
.ps-custom-btn:hover {
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: 0 16px 40px rgba(0,200,150,.45) !important;
}
.ps-custom-btn .btn-icon { transition: transform var(--t); }
.ps-custom-btn:hover .btn-icon { transform: translateX(5px); }

/* Outline btn */
.custom-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1.5px solid rgba(255,255,255,.30) !important;
    border-radius: var(--r-md) !important;
    padding: 12px 24px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background: rgba(255,255,255,.07) !important;
    backdrop-filter: blur(8px);
    transition: all var(--t) !important;
}
.custom-btn:hover {
    background: rgba(255,255,255,.15) !important;
    border-color: rgba(255,255,255,.5) !important;
    transform: translateY(-2px) !important;
}
.custom-btn.custom-primary-btn {
    background: var(--grad-green) !important;
    border-color: transparent !important;
    box-shadow: var(--sh-g);
}
.custom-btn.custom-primary-btn:hover {
    box-shadow: 0 16px 40px rgba(0,200,150,.45) !important;
    border-color: transparent !important;
}

/* ── 5. HERO ──────────────────────────────────────────────────── */
.home-banner-section {
    background: var(--grad-hero);
    padding-top: 88px;
    padding-bottom: 0;
    position: relative;
    overflow: hidden;
}
/* Animated mesh orbs */
.home-banner-section::before {
    content: "";
    position: absolute;
    top: -20%; left: -15%;
    width: 700px; height: 700px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,200,150,.12) 0%, transparent 65%);
    animation: orbFloat 12s ease-in-out infinite alternate;
    pointer-events: none; z-index: 0;
}
.home-banner-section::after {
    content: "";
    position: absolute;
    top: 10%; right: -10%;
    width: 600px; height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(37,128,166,.14) 0%, transparent 65%);
    animation: orbFloat 15s ease-in-out 3s infinite alternate-reverse;
    pointer-events: none; z-index: 0;
}
@keyframes orbFloat {
    0%   { transform: translate(0,0) scale(1); }
    100% { transform: translate(40px, 30px) scale(1.15); }
}

/* hero-bg rounded card wrapper */
.home-banner-section .hero-bg {
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
    position: relative;
    z-index: 2;
}
/* Override any fixed heights */
.home-banner-section .hero-bg { height: auto !important; min-height: unset !important; }

/* Banner content inner wrapper */
.home-banner-section .banner-content {
    position: relative;
    z-index: 8;
    text-align: center;
    padding-top: 0 !important;
}

/* Headline */
.home-banner-section .banner-content h1 {
    font-size: 72px !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
    letter-spacing: -.035em !important;
    color: #ffffff !important;
    max-width: 920px !important;
    margin: 0 auto !important;
    padding-top: 0 !important;
    text-shadow: 0 4px 32px rgba(0,0,0,.2);
    font-family: var(--title-font) !important;
}
.home-banner-section .banner-content h1 span,
.home-banner-section .banner-content h1 .typed-text {
    background: linear-gradient(90deg, var(--g) 0%, #00e8b5 50%, #00d4ff 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

/* Sub-headline */
.home-banner-section .banner-content p {
    color: rgba(255,255,255,.65) !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 1.7 !important;
    max-width: 580px !important;
    margin: 0 auto !important;
    padding-top: 20px !important;
}

/* Button group */
.home-banner-section .banner-content .demo-btn-group {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 16px !important;
    margin-top: 36px !important;
}

/* Watch video link inside hero */
.watch-text { color: rgba(255,255,255,.80) !important; font-weight: 500 !important; font-size: 15px !important; }
.home-banner-section .banner-content a.d-flex { color: rgba(255,255,255,.80) !important; }

/* Play button */
.video-play-button, .play-button {
    width: 52px !important; height: 52px !important;
    background: rgba(0,200,150,.15) !important;
    border: 2px solid rgba(0,200,150,.45) !important;
    border-radius: 50% !important;
    backdrop-filter: blur(8px) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: all var(--t) !important;
}
.video-play-button:hover, .play-button:hover {
    background: var(--g) !important;
    border-color: var(--g) !important;
    transform: scale(1.1) !important;
}
.play-button::before {
    background-color: transparent !important;
    border: 3px solid rgba(0,200,150,.35) !important;
    top: -12px !important; left: -12px !important;
    animation: pulsate1 2.5s infinite !important;
}
.play-button::after {
    background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2213%22%20height%3D%2216%22%20viewBox%3D%220%200%2013%2016%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M0.316406%201.58167C0.316406%200.790499%201.19165%200.312658%201.85716%200.740487L11.8412%207.15882C12.4536%207.55246%2012.4536%208.44754%2011.8412%208.84118L1.85716%2015.2595C1.19165%2015.6873%200.316406%2015.2095%200.316406%2014.4183V1.58167Z%22%20fill%3D%22%2300c896%22%2F%3E%3C%2Fsvg%3E") !important;
}

/* Hero stats bar */
.hero-stats-bar {
    display: inline-flex !important;
    background: rgba(255,255,255,.06) !important;
    backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: var(--r-xl) !important;
    padding: 16px 32px !important;
    gap: 0 !important;
    margin-top: 48px !important;
}
.hero-stat-item {
    text-align: center;
    padding: 4px 28px;
    border-right: 1px solid rgba(255,255,255,.12);
}
.hero-stat-item:last-child { border-right: none; }
.hero-stat-item h3 {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    margin: 0;
    line-height: 1;
    font-family: var(--title-font);
}
.hero-stat-item h3 span { color: var(--g); }
.hero-stat-item p {
    font-size: 12.5px;
    color: rgba(255,255,255,.55);
    margin: 5px 0 0;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* Hero image container — browser mock */
.hero-img-container {
    height: 460px !important;
    margin: 48px auto 0 !important;
    position: relative;
    z-index: 8;
}
.hero-img-container img {
    width: 1100px !important;
    height: 440px !important;
    object-fit: cover !important;
    border-radius: 16px 16px 0 0 !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-bottom: none !important;
    box-shadow: 0 -12px 60px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.06) !important;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
/* Glow under the screenshot */
.hero-img-container::after {
    content: "";
    position: absolute;
    bottom: 0; left: 50%;
    transform: translateX(-50%);
    width: 80%; height: 80px;
    background: radial-gradient(ellipse at center, rgba(0,200,150,.2) 0%, transparent 70%);
    z-index: 9;
    pointer-events: none;
}

/* Floating decorative elements */
.home-banner-section .element1,
.home-banner-section .element2 {
    filter: drop-shadow(0 4px 16px rgba(0,200,150,.2)) !important;
    opacity: .7;
}

/* Wave divider after hero */
.hero-wave-divider {
    background: var(--grad-hero);
    line-height: 0;
    overflow: hidden;
    margin-bottom: -2px;
}
.hero-wave-divider svg { display: block; }

/* ── 6. TRUST STRIP (logos of global companies) ───────────────── */
.trust-strip-section {
    background: var(--bg-light);
    padding: 36px 0;
    border-top: 1px solid var(--bdr-light);
    border-bottom: 1px solid var(--bdr-light);
}
.trust-strip-label {
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--txt-muted);
    margin-bottom: 20px;
}
.trust-strip-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
    opacity: .55;
    filter: grayscale(1);
    transition: opacity var(--t);
}
.trust-strip-logos:hover { opacity: .75; }
.trust-strip-logos img {
    height: 32px; width: auto;
    object-fit: contain;
}

/* ── 7. FEATURES SECTION ──────────────────────────────────────── */
.service-section {
    background: var(--bg-light);
    padding: 88px 0;
    position: relative;
}
.service-section::before {
    content: "";
    position: absolute;
    top: -1px; left: 0; right: 0;
    height: 80px;
    background: linear-gradient(to bottom, var(--bg-white) 0%, transparent 100%);
    pointer-events: none;
}

/* Feature card — glass + border reveal on hover */
.service-section .service-card {
    background: var(--bg-white) !important;
    border: 1px solid var(--bdr-light) !important;
    border-radius: var(--r-xl) !important;
    padding: 32px 24px !important;
    box-shadow: var(--sh-xs) !important;
    transition: transform var(--t-slow), box-shadow var(--t-slow), border-color var(--t-slow) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 16px !important;
    height: 100% !important;
    position: relative;
    overflow: hidden;
}
/* Bottom gradient reveal line */
.service-section .service-card::after {
    content: "";
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--grad-green);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--t-slow);
    border-radius: 0 0 var(--r-xl) var(--r-xl);
}
.service-section .service-card:hover {
    transform: translateY(-8px) !important;
    box-shadow: var(--sh-lg) !important;
    border-color: rgba(0,200,150,.3) !important;
}
.service-section .service-card:hover::after { transform: scaleX(1); }

/* Icon wrapper */
.service-section .image {
    width: 72px !important; height: 72px !important;
    background: linear-gradient(135deg, rgba(0,200,150,.10) 0%, rgba(14,61,82,.08) 100%) !important;
    border: 1px solid rgba(0,200,150,.18) !important;
    border-radius: var(--r-lg) !important;
    display: flex !important;
    align-items: center !important; justify-content: center !important;
    transition: background var(--t-slow), transform var(--t-slow) !important;
}
.service-section .service-card:hover .image {
    background: linear-gradient(135deg, rgba(0,200,150,.18) 0%, rgba(14,61,82,.14) 100%) !important;
    transform: scale(1.08) rotate(-3deg);
}
.service-section .image img {
    width: 38px !important; height: 38px !important;
    object-fit: contain;
}
.service-section .service-content h6 {
    font-size: 14.5px !important;
    font-weight: 700 !important;
    color: var(--txt-dark) !important;
    margin: 0 !important;
    line-height: 1.4 !important;
    text-align: center;
}
.feature-header { margin-top: 0 !important; }

/* ── 8. INTERFACE SLIDER SECTION ──────────────────────────────── */
.slick-slider-section {
    background: var(--bg-white);
    padding: 88px 0;
    overflow: hidden;
}
.slick-slider-section .slick-prev,
.slick-slider-section .slick-next {
    background: var(--p) !important;
    border-radius: 50% !important;
    width: 40px !important; height: 40px !important;
    box-shadow: var(--sh-md) !important;
    transition: background var(--t) !important;
}
.slick-slider-section .slick-prev:hover,
.slick-slider-section .slick-next:hover {
    background: var(--g) !important;
}

/* ── 9. GET APP SECTION ───────────────────────────────────────── */
.get-app-container {
    background: linear-gradient(135deg, var(--p) 0%, var(--bg-dark) 100%);
    padding: 88px 0;
    position: relative;
    overflow: hidden;
}
.get-app-container::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 10% 50%, rgba(0,200,150,.12) 0%, transparent 60%),
        radial-gradient(ellipse 50% 60% at 90% 30%, rgba(37,128,166,.12) 0%, transparent 60%);
    pointer-events: none;
}
.get-app-content { position: relative; z-index: 2; text-align: center; }
.get-app-content .langing-section-title,
.get-app-content h4 { color: #fff !important; -webkit-text-fill-color: #fff; }
.get-app-content .title-span-color {
    background: linear-gradient(90deg, var(--g), #00e8b5) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
.get-app-content .section-description { color: rgba(255,255,255,.60) !important; }

.get-app-container .download-on {
    height: 50px;
    width: auto;
    border-radius: var(--r-md);
    transition: transform var(--t), filter var(--t) !important;
    filter: brightness(.95);
}
.get-app-container .download-on:hover {
    transform: translateY(-3px) scale(1.04) !important;
    filter: brightness(1.05);
}
.get-app-logo {
    height: 60px; width: auto;
    margin-bottom: 20px;
    filter: brightness(10) opacity(.9);
}

/* ── 10. WATCH DEMO SECTION ───────────────────────────────────── */
.watch-demo-section {
    background: var(--bg-light) !important;
    padding: 88px 0;
}
.watch-video-container {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 64px !important;
    align-items: center !important;
}
.video-wrapper {
    border-radius: var(--r-2xl) !important;
    overflow: hidden !important;
    box-shadow: var(--sh-xl) !important;
    border: none !important;
    position: relative;
}
.video-wrapper::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(14,61,82,.35) 0%, rgba(6,15,26,.2) 100%);
    z-index: 1;
    pointer-events: none;
    border-radius: var(--r-2xl);
}
.video-wrapper img {
    width: 100% !important;
    height: 360px !important;
    object-fit: cover !important;
    display: block !important;
    border: none !important;
    border-radius: 0 !important;
}
.play-btn {
    width: 72px !important; height: 72px !important;
    background: rgba(255,255,255,.18) !important;
    border: 2px solid rgba(255,255,255,.50) !important;
    backdrop-filter: blur(12px) !important;
    border-radius: 50% !important;
    z-index: 5 !important;
    transition: all var(--t) !important;
}
.play-btn:hover {
    background: var(--g) !important;
    border-color: var(--g) !important;
    transform: translate(-50%, -50%) scale(1.12) !important;
}

.watch-video-content .langing-section-title { color: var(--txt-dark) !important; -webkit-text-fill-color: unset; }
.watch-video-content .section-description { color: var(--txt-light) !important; }
.download-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--grad-green) !important;
    color: #fff !important;
    border-radius: var(--r-md) !important;
    padding: 14px 28px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    border: none !important;
    box-shadow: var(--sh-g) !important;
    margin-top: 28px !important;
    transition: transform var(--t), box-shadow var(--t) !important;
}
.download-btn:hover {
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: 0 16px 40px rgba(0,200,150,.45) !important;
}

/* ── 11. PRICING PLANS ────────────────────────────────────────── */
.pricing-plan-section {
    background: var(--bg-white);
    padding: 88px 0;
    position: relative;
}
.pricing-plan-section::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 400px;
    background: linear-gradient(180deg, var(--bg-light) 0%, transparent 100%);
    pointer-events: none;
}
.plans-list .card {
    background: var(--bg-white) !important;
    border: 1.5px solid var(--bdr-light) !important;
    border-radius: var(--r-2xl) !important;
    overflow: hidden !important;
    box-shadow: var(--sh-xs) !important;
    height: 100% !important;
    transition: transform var(--t-slow), box-shadow var(--t-slow), border-color var(--t-slow) !important;
    position: relative;
}
.plans-list .card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--sh-lg) !important;
    border-color: rgba(0,200,150,.35) !important;
    margin-top: 0 !important;
}

/* Featured card */
.featured-plan-card {
    border: 2px solid var(--g) !important;
    box-shadow: 0 0 0 4px rgba(0,200,150,.10), var(--sh-lg) !important;
    transform: translateY(-10px) !important;
    background: var(--bg-white) !important;
    overflow: visible !important;
}
.featured-plan-card:hover {
    transform: translateY(-16px) !important;
    box-shadow: 0 0 0 4px rgba(0,200,150,.15), var(--sh-xl) !important;
}
.featured-plan-badge {
    position: absolute;
    top: -16px; left: 50%;
    transform: translateX(-50%);
    background: var(--grad-green);
    color: #fff;
    font-size: 11.5px;
    font-weight: 800;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: 6px 20px;
    border-radius: var(--r-full);
    white-space: nowrap;
    box-shadow: var(--sh-g);
    z-index: 20;
}

/* Plan card header */
.plans-list .card .card-header {
    border-radius: 0 !important;
    background: var(--bg-light) !important;
    padding: 28px 28px 20px !important;
    border-bottom: 1px solid var(--bdr-light) !important;
    text-align: center !important;
}
.featured-plan-card .card-header {
    background: linear-gradient(160deg, rgba(0,200,150,.07) 0%, rgba(14,61,82,.05) 100%) !important;
    border-bottom: 1px solid rgba(0,200,150,.15) !important;
}
.plan-name-label {
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    color: var(--txt-muted) !important;
    margin-bottom: 12px !important;
    margin-top: 0 !important;
    line-height: 1 !important;
}
.featured-plan-card .plan-name-label { color: var(--g2) !important; }
.plan-price {
    font-size: 42px !important;
    font-weight: 900 !important;
    color: var(--p) !important;
    margin: 4px 0 !important;
    line-height: 1 !important;
    font-family: var(--title-font) !important;
    letter-spacing: -.02em;
}
.featured-plan-card .plan-price { color: var(--g2) !important; }
.plans-list .card-header .price-span {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--txt-muted) !important;
}

/* Card body */
.plans-list .card .card-body { padding: 24px 28px 28px !important; }
.plans-list .card .features-list { gap: 10px !important; }
.plans-list .card .feature-item {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}
.single-features { font-size: 14px !important; color: var(--txt-mid) !important; line-height: 1.5 !important; }
.plan-icon { width: 18px !important; height: 18px !important; flex-shrink: 0 !important; }
.see-more-btn, .see-less-btn {
    color: var(--p3) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    padding: 0 !important;
}

/* Subscribe button */
.subscribe-plan {
    width: 100% !important;
    border: 2px solid var(--p) !important;
    color: var(--p) !important;
    border-radius: var(--r-md) !important;
    padding: 13px 20px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    transition: all var(--t) !important;
    background: transparent !important;
}
.subscribe-plan:hover,
.plans-list .subscribe-plan:hover,
.plans-list .card .subscribe-plan:hover {
    background: var(--p) !important;
    color: #fff !important;
    border-color: var(--p) !important;
    box-shadow: var(--sh-md) !important;
    transform: translateY(-1px) !important;
}
.featured-plan-card .subscribe-plan {
    background: var(--grad-green) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: var(--sh-g) !important;
}
.featured-plan-card .subscribe-plan:hover {
    background: var(--grad-green) !important;
    box-shadow: 0 12px 36px rgba(0,200,150,.45) !important;
    transform: translateY(-2px) !important;
}

/* ── 12. PAYMENT SECTION ──────────────────────────────────────── */
.payment-method-container {
    background: linear-gradient(135deg, var(--bg-dark) 0%, var(--p) 100%) !important;
    padding: 80px 0 !important;
    position: relative;
    overflow: hidden;
}
.payment-method-container::before {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 60% 70% at 15% 60%, rgba(0,200,150,.10) 0%, transparent 55%),
        radial-gradient(ellipse 50% 50% at 85% 30%, rgba(37,128,166,.10) 0%, transparent 55%);
    pointer-events: none;
}
.payment-title {
    color: #fff !important;
    font-size: 36px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
}
.payment-color-span {
    background: linear-gradient(90deg, var(--g), #00e8b5) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
.payment-pera { color: rgba(255,255,255,.60) !important; font-size: 16px !important; }
.payment-img img {
    border-radius: var(--r-lg) !important;
    box-shadow: 0 24px 64px rgba(0,0,0,.4) !important;
}

/* ── 13. TESTIMONIALS ─────────────────────────────────────────── */
.customer-section {
    background: var(--bg-light) !important;
    padding: 88px 0 !important;
    position: relative;
    overflow: hidden;
}
.customer-section::after {
    content: "";
    position: absolute;
    bottom: -80px; right: -80px;
    width: 400px; height: 400px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,200,150,.07) 0%, transparent 70%);
    pointer-events: none;
}
.customer-section .customer-card {
    background: var(--bg-white) !important;
    border: 1px solid var(--bdr-light) !important;
    border-radius: var(--r-xl) !important;
    padding: 36px 24px 28px !important;
    box-shadow: var(--sh-sm) !important;
    margin: 44px 10px 12px !important;
    position: relative;
    transition: transform var(--t-slow), box-shadow var(--t-slow) !important;
}
.customer-section .customer-card::before {
    content: "\201C";
    position: absolute;
    top: 18px; left: 22px;
    font-size: 64px;
    line-height: 1;
    color: var(--g);
    opacity: .18;
    font-family: Georgia, serif;
    pointer-events: none;
}
.customer-section .customer-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--sh-lg) !important;
}
.customer-section .customer-card img {
    width: 72px !important; height: 72px !important;
    border-radius: 50% !important;
    border: 3px solid var(--bg-white) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.12) !important;
    top: -36px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    object-fit: cover !important;
}
.customer-section .customer-slider-section p {
    color: var(--txt-mid) !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    text-align: center !important;
    margin-top: 28px !important;
}
.customer-section .customer-card h5 {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--txt-dark) !important;
    line-height: 1.3 !important;
}
.customer-section .customer-card small {
    color: var(--txt-muted) !important;
    font-size: 13px !important;
}
.customer-section .customer-star {
    color: var(--gold) !important;
    font-size: 15px !important;
    letter-spacing: 2px !important;
    margin-top: 8px !important;
}

/* ── 14. BLOG CARDS ───────────────────────────────────────────── */
.blog-shadow {
    border-radius: var(--r-xl) !important;
    overflow: hidden !important;
    border: 1px solid var(--bdr-light) !important;
    box-shadow: var(--sh-xs) !important;
    background: var(--bg-white) !important;
    transition: transform var(--t-slow), box-shadow var(--t-slow) !important;
}
.blog-shadow:hover {
    transform: translateY(-8px) !important;
    box-shadow: var(--sh-lg) !important;
}
.blog-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--txt-dark) !important;
    line-height: 1.45 !important;
    transition: color var(--t) !important;
}
.blog-shadow:hover .blog-title { color: var(--p3) !important; }
.blog-img-1 {
    transition: transform var(--t-slow) !important;
}
.blog-shadow:hover .blog-img-1 { transform: scale(1.06) !important; }

/* ── 15. FOOTER ───────────────────────────────────────────────── */
.footer-section {
    background: linear-gradient(160deg, #06101a 0%, #091824 100%) !important;
    position: relative;
    overflow: hidden;
}
.footer-section::before {
    content: "";
    position: absolute;
    top: -60px; left: 50%;
    transform: translateX(-50%);
    width: 800px; height: 300px;
    background: radial-gradient(ellipse at center, rgba(0,200,150,.06) 0%, transparent 70%);
    pointer-events: none;
}
.footer-section p, .footer-section li, .footer-section li a {
    color: rgba(255,255,255,.50) !important;
    font-size: 14px !important;
    line-height: 2 !important;
    transition: color var(--t) !important;
}
.footer-section li a:hover { color: var(--g) !important; opacity: 1 !important; }
.footer-section .footer-title {
    color: rgba(255,255,255,.90) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: .02em !important;
    margin-bottom: 20px !important;
}
.footer-section .footer-logo {
    height: 44px !important; width: auto !important;
    object-fit: contain !important;
    opacity: .9;
}
.footer-section hr { border-color: rgba(255,255,255,.08) !important; margin: 32px 0 18px !important; }
.footer-section .text-white { color: rgba(255,255,255,.35) !important; font-size: 13px !important; }
.footer-section .social-icon a {
    background: rgba(255,255,255,.06) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    border-radius: 50% !important;
    width: 40px !important; height: 40px !important;
    transition: all var(--t) !important;
}
.footer-section .social-icon a:hover {
    background: var(--g) !important;
    border-color: var(--g) !important;
    transform: translateY(-2px);
}
.footer-section .social-icon img {
    filter: brightness(10) !important;
    height: 15px !important; width: 15px !important;
    object-fit: contain !important;
    padding: 0 !important;
}
.footer-shape1, .footer-shape2 { opacity: .04 !important; }

/* ── 16. FAQ ──────────────────────────────────────────────────── */
.faqs-section .accordion-item {
    border-radius: var(--r-md) !important;
    border: 1px solid var(--bdr-light) !important;
    box-shadow: var(--sh-xs) !important;
    margin-bottom: 10px !important;
    overflow: hidden !important;
    transition: box-shadow var(--t-slow) !important;
    background: var(--bg-white) !important;
}
.faqs-section .accordion-item:hover { box-shadow: var(--sh-sm) !important; }
.faqs-section .accordion-button {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--txt-dark) !important;
    padding: 20px 18px !important;
    background: transparent !important;
}
.faqs-section .accordion-button:not(.collapsed) { color: var(--p3) !important; }

/* ── 17. CONTACT ──────────────────────────────────────────────── */
.contact-section form input,
.contact-section form textarea {
    border-radius: var(--r-md) !important;
    border: 1.5px solid var(--bdr-light) !important;
    padding: 13px 16px !important;
    font-size: 14.5px !important;
    transition: border-color var(--t), box-shadow var(--t) !important;
    background: var(--bg-white) !important;
}
.contact-section form input:focus,
.contact-section form textarea:focus {
    border-color: var(--g) !important;
    box-shadow: 0 0 0 4px rgba(0,200,150,.10) !important;
    outline: none !important;
}

/* ── 18. MODALS ───────────────────────────────────────────────── */
.modal-custom-design .modal-content {
    border-radius: var(--r-xl) !important;
    border: 1px solid var(--bdr-light) !important;
    box-shadow: var(--sh-xl) !important;
    overflow: hidden;
}
.modal-custom-design .modal-header {
    border-bottom: 1px solid var(--bdr-light) !important;
    padding: 16px 20px !important;
}

/* ── 19. PAGE BANNER (inner pages) ───────────────────────────── */
.banner-bg {
    background: linear-gradient(135deg, var(--bg-light) 0%, rgba(0,200,150,.06) 100%) !important;
    border-radius: var(--r-xl) !important;
    height: 130px !important;
    border: 1px solid var(--bdr-light) !important;
}
.banner-bg p {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--txt-dark) !important;
}

/* ── 20. SCROLLBAR ────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: var(--p); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--g); }

/* ── 21. SECTION DIVIDER WAVE ─────────────────────────────────── */
.wave-divider-down {
    position: relative;
    z-index: 1;
}
.wave-divider-down::after {
    content: "";
    position: absolute;
    bottom: -2px; left: 0; right: 0;
    height: 64px;
    background: inherit;
    clip-path: ellipse(56% 100% at 50% 0%);
    z-index: 2;
}

/* ── 21a. INNER-PAGE HEADER (non-home pages) ──────────────────── */
.header-section:not(.home-header) {
    background: var(--bg-dark) !important;
    border-bottom: 1px solid rgba(255,255,255,.07) !important;
}
.header-section:not(.home-header) a {
    color: rgba(255,255,255,.80) !important;
}
.header-section:not(.home-header) .nav-link:hover {
    color: var(--g) !important;
    background: rgba(255,255,255,.07) !important;
}

/* ── 21b. HERO PILL BADGE ─────────────────────────────────────── */
.hero-pill-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(0,200,150,.14);
    color: #7fffcf;
    border: 1px solid rgba(0,200,150,.30);
    border-radius: var(--r-full);
    padding: 7px 18px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .04em;
    backdrop-filter: blur(8px);
    margin-bottom: 28px;
    animation: pilseGlow 3s ease-in-out infinite;
}
.hero-pill-dot {
    width: 8px; height: 8px;
    background: var(--g);
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 6px var(--g), 0 0 12px rgba(0,200,150,.5);
    animation: dotPulse 2s ease-in-out infinite;
}
@keyframes pilseGlow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(0,200,150,0); }
    50%       { box-shadow: 0 0 20px rgba(0,200,150,.15); }
}
@keyframes dotPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50%       { transform: scale(1.4); opacity: .7; }
}

/* ── 22. RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 1536px) {
    .home-banner-section .banner-content h1 { font-size: 60px !important; }
    .hero-img-container { height: 420px !important; }
    .hero-img-container img { width: 900px !important; height: 400px !important; }
    .langing-section-title { font-size: 38px !important; }
}
@media (max-width: 1380px) {
    .home-banner-section .banner-content h1 { font-size: 52px !important; padding-top: 0 !important; }
    .hero-img-container { height: 380px !important; }
    .hero-img-container img { width: 750px !important; height: 360px !important; }
}
@media (max-width: 1200px) {
    .home-banner-section .banner-content h1 { font-size: 46px !important; }
    .langing-section-title { font-size: 34px !important; }
    .watch-video-container { grid-template-columns: 1fr !important; gap: 40px !important; }
    .watch-video-content { text-align: center !important; }
    .featured-plan-card { transform: translateY(0) !important; }
    .featured-plan-card:hover { transform: translateY(-8px) !important; }
}
@media (max-width: 1024px) {
    .hero-img-container { height: 300px !important; }
    .hero-img-container img { width: 600px !important; height: 280px !important; }
}
@media (max-width: 991px) {
    section { padding: 64px 0; }
    .home-banner-section .banner-content h1 { font-size: 40px !important; }
    .hero-img-container { height: 240px !important; }
    .hero-img-container img { width: 100% !important; max-width: 520px !important; height: 220px !important; }
    .langing-section-title { font-size: 30px !important; }
    .home-banner-section::before, .home-banner-section::after { display: none; }
}
@media (max-width: 768px) {
    .home-banner-section .banner-content h1 { font-size: 34px !important; }
    .home-banner-section .banner-content p { font-size: 16px !important; }
    .home-banner-section .banner-content .demo-btn-group { flex-direction: column !important; gap: 14px !important; }
    .ps-custom-btn { width: 100%; justify-content: center !important; }
    .hero-stats-bar { flex-direction: row; flex-wrap: wrap; justify-content: center !important; padding: 16px 20px !important; }
    .hero-stat-item { border-right: none !important; border-bottom: 1px solid rgba(255,255,255,.10); width: 50%; padding: 10px 12px !important; }
    .hero-stat-item:nth-child(2n) { border-right: none !important; }
    .hero-stat-item:last-child { border-bottom: none; }
    .hero-img-container { height: 180px !important; }
    .hero-img-container img { max-width: 380px !important; height: 180px !important; }
    .video-wrapper img { height: 240px !important; }
}
@media (max-width: 576px) {
    section { padding: 52px 0; }
    .home-banner-section .banner-content h1 { font-size: 28px !important; line-height: 1.15 !important; }
    .langing-section-title { font-size: 26px !important; line-height: 1.2 !important; }
    .hero-img-container { height: 150px !important; }
    .hero-img-container img { max-width: 300px !important; height: 150px !important; }
    .hero-stats-bar { margin-top: 28px !important; }
    .hero-stat-item h3 { font-size: 22px !important; }
    .plans-list .card .card-body { padding: 20px 18px !important; }
    .plans-list .card .card-header { padding: 22px 18px 16px !important; }
}
@media (max-width: 400px) {
    .home-banner-section .banner-content h1 { font-size: 24px !important; }
    .hero-stats-bar { margin-top: 20px !important; }
    .hero-stat-item { width: 100% !important; border-bottom: 1px solid rgba(255,255,255,.10) !important; border-right: none !important; }
}

/* ── 23. RTL ──────────────────────────────────────────────────── */
[dir="rtl"] .hero-stat-item { border-right: none; border-left: 1px solid rgba(255,255,255,.12); }
[dir="rtl"] .hero-stat-item:last-child { border-left: none; }
[dir="rtl"] .ps-custom-btn .btn-icon { transform: scaleX(-1); }
[dir="rtl"] .ps-custom-btn:hover .btn-icon { transform: scaleX(-1) translateX(-5px); }
[dir="rtl"] .featured-plan-badge { direction: rtl; }
[dir="rtl"] .section-badge { direction: rtl; }
[dir="rtl"] .service-section .service-card::after { transform-origin: right; }
