/* =====================================================
   ROOT VARIABLES
===================================================== */
:root{
    --primary:#4f46e5;
    --primary-dark:#4338ca;
    --dark:#020617;
    --muted:#64748b;
    --light:#f8fafc;

    --radius-xl:28px;
    --radius-lg:22px;
    --radius-md:14px;

    --shadow-soft:0 10px 30px rgba(15,23,42,.08);
    --shadow-premium:0 25px 60px rgba(15,23,42,.15);

    --glass-bg:rgba(255,255,255,.75);
    --glass-border:rgba(255,255,255,.25);
}

/* =====================================================
   BASE
===================================================== */
body{
    font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
    background:var(--light);
    color:#0f172a;
    -webkit-font-smoothing:antialiased;
}

section{
    scroll-margin-top:80px;
}

/* =====================================================
   NAVBAR
===================================================== */
.navbar{
    height:74px;
    background:var(--glass-bg)!important;
    backdrop-filter:blur(18px);
    border-bottom:1px solid var(--glass-border);
    transition:.3s;
}

/*.navbar-spacer{ height:74px; }*/

.navbar-brand{
    display:flex;
    align-items:center;
    gap:10px;
    font-weight:800;
    font-size:20px;
}

.navbar-logo{
    height:44px;
    width:auto;
}

.nav-link{
    font-weight:500;
    padding:8px 14px!important;
}

.nav-link:hover,
.nav-active{
    color:var(--primary)!important;
    font-weight:600;
}

/* =====================================================
   BUTTONS
===================================================== */
.btn{ transition:.3s; }

.btn-primary{
    background:linear-gradient(135deg,#4f46e5,#6366f1);
    border:none;
    box-shadow:0 10px 25px rgba(79,70,229,.35);
}

.btn-primary:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 40px rgba(79,70,229,.45);
}

/* =====================================================
   HERO
===================================================== */
.hero{
    padding:160px 0 100px;
    background:
        radial-gradient(circle at top right,#6366f1,transparent 40%),
        linear-gradient(135deg,#4f46e5,#4338ca);
    color:#fff;
    overflow:hidden;
}

.hero-content{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    align-items:center;
    gap:60px;
}

.hero-title{
    font-size:48px;
    font-weight:800;
    line-height:1.15;
}

.hero-desc{
    font-size:18px;
    opacity:.95;
    margin:20px 0 32px;
}

.hero-actions{
    display:flex;
    gap:16px;
    flex-wrap:wrap;
}

.hero-note{
    margin-top:14px;
    opacity:.8;
}

.hero-image img{
    max-width:560px;
    width:100%;
    border-radius:20px;
    box-shadow:var(--shadow-premium);
}

/* =====================================================
   CARDS
===================================================== */
.feature-card,
.feature-box,
.step-card,
.api-card,
.price-card{
    background:#fff;
    border-radius:var(--radius-lg);
    padding:30px;
    box-shadow:var(--shadow-soft);
    transition:.35s;
}

.feature-card:hover,
.feature-box:hover,
.step-card:hover,
.api-card:hover,
.price-card:hover{
    transform:translateY(-8px);
    box-shadow:var(--shadow-premium);
}
/* =====================================
   HOW IT WORKS – HERO FIX (FINAL)
===================================== */

/* =====================================================
   PREMIUM HERO – COMMON FOR ALL LANDING PAGES
===================================================== */

.page-hero,
.hero,
.hiw-hero,
.features-hero,
.pricing-hero,
.api-hero,
.faq-hero {
    position: relative;
    z-index: 2;

    /* Spacing (navbar safe) */
    padding: 120px 0 80px;
    margin-top: 0;

    /* Premium SaaS Gradient */
    background:
        radial-gradient(
            1200px circle at top right,
            rgba(99,102,241,0.35),
            transparent 45%
        ),
        linear-gradient(
            135deg,
            #4f46e5 0%,
            #4338ca 50%,
            #312e81 100%
        );

    color: #ffffff;
    text-align: center;
}

/* Badge (top label) */
.page-hero .badge,
.hero .badge,
.hiw-hero .badge,
.features-hero .badge,
.pricing-hero .badge,
.api-hero .badge,
.faq-hero .badge {
    font-size: 13px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 999px;
    background: #fde047;
    color: #111827;
}

/* Headings */
.page-hero h1,
.hero h1,
.hiw-hero h1,
.features-hero h1,
.pricing-hero h1,
.api-hero h1,
.faq-hero h1 {
    font-size: 42px;
    font-weight: 800;
    margin-top: 14px;
    line-height: 1.2;
    letter-spacing: -0.02em;
    text-shadow: 0 6px 30px rgba(0,0,0,0.25);
}

/* Highlight text inside heading */
.page-hero h1 span,
.hero h1 span,
.hiw-hero h1 span,
.features-hero h1 span,
.pricing-hero h1 span,
.api-hero h1 span,
.faq-hero h1 span {
    color: #fde047;
}

/* Paragraph */
.page-hero p,
.hero p,
.hiw-hero p,
.features-hero p,
.pricing-hero p,
.api-hero p,
.faq-hero p {
    max-width: 760px;
    margin: 16px auto 0;
    font-size: 18px;
    opacity: 0.95;
    text-shadow: 0 4px 18px rgba(0,0,0,0.18);
}

/* =====================================================
   RESPONSIVE – MOBILE / TABLET
===================================================== */

/* Tablets & phones */
@media (max-width: 768px) {

    .page-hero,
    .hero,
    .hiw-hero,
    .features-hero,
    .pricing-hero,
    .api-hero,
    .faq-hero {
        padding: 100px 0 60px;
    }

    .page-hero h1,
    .hero h1,
    .hiw-hero h1,
    .features-hero h1,
    .pricing-hero h1,
    .api-hero h1,
    .faq-hero h1 {
        font-size: 32px;
    }

    .page-hero p,
    .hero p,
    .hiw-hero p,
    .features-hero p,
    .pricing-hero p,
    .api-hero p,
    .faq-hero p {
        font-size: 16px;
    }
}

/* Small phones */
@media (max-width: 480px) {
    .page-hero,
    .hero,
    .hiw-hero,
    .features-hero,
    .pricing-hero,
    .api-hero,
    .faq-hero {
        padding: 90px 0 50px;
    }
}
/* =====================================================
   PRICING
===================================================== */
.price{
    font-size:40px;
    font-weight:800;
    color:var(--primary);
}

.price-card.popular{
    border:2px solid var(--primary);
    transform:scale(1.05);
}

/* =====================================================
   FOOTER
===================================================== */
.site-footer{
    background:linear-gradient(135deg,#020617,#0f172a);
    color:#94a3b8;
    padding:60px 0 25px;
}

/* ==========================
   BLOG LISTING – PREMIUM
========================== */
.blog-card {
    border-radius: 22px;
    overflow: hidden;
    transition: 0.35s;
    box-shadow: 0 12px 35px rgba(15,23,42,.08);
}

.blog-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 22px 55px rgba(15,23,42,.15);
}

.blog-image-wrap {
    overflow: hidden;
}

.blog-image-wrap img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    transition: transform .4s ease;
}

.blog-card:hover img {
    transform: scale(1.05);
}

/* =====================================================
   TESTIMONIALS
===================================================== */
.testimonial-card{
    background:#ffffff;
    border-radius:22px;
    padding:30px;
    box-shadow:var(--shadow-soft);
    transition:.35s;
    border:1px solid rgba(226,232,240,.7);
}

.testimonial-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow-premium);
}

.testimonial-text{
    font-size:16px;
    line-height:1.7;
    color:#0f172a;
    margin-bottom:24px;
}

.testimonial-user{
    display:flex;
    align-items:center;
    gap:14px;
}

.avatar{
    width:44px;
    height:44px;
    border-radius:50%;
    background:linear-gradient(135deg,#4f46e5,#6366f1);
    color:#fff;
    font-weight:800;
    display:flex;
    align-items:center;
    justify-content:center;
}

/* Mobile */
@media(max-width:768px){
    .testimonial-text{
        font-size:15px;
    }
}

/* =====================================================
   MEDIA QUERIES – ALL DEVICES
===================================================== */

/* Small phones */
@media (max-width:360px){
    .hero-title{font-size:28px;}
    .hero-desc{font-size:15px;}
    .navbar{height:68px;}
    .navbar-spacer{height:68px;}
}

/* Phones */
@media (max-width:480px){
    .hero{padding:120px 0 70px;}
    .hero-title{font-size:30px;}
    .hero-actions{flex-direction:column;}
}

/* Large phones */
@media (max-width:576px){
    .hero-title{font-size:32px;}
    .navbar-logo{height:36px;}
}

/* Tablet portrait */
@media (max-width:768px){
    .hero-title{font-size:34px;}
    .hero-desc{font-size:16px;}
}

/* Tablet landscape */
@media (max-width:991px){
    .hero-content{
        grid-template-columns:1fr;
        text-align:center;
    }
    .hero-image img{
        margin:40px auto 0;
    }
}

/* Laptop */
@media (max-width:1200px){
    .hero-title{font-size:42px;}
}

/* Large screens / iMac */
@media (min-width:1400px){
    .container{max-width:1320px;}
    .hero-title{font-size:54px;}
    .hero-desc{font-size:20px;}
}
/* =====================================
   MOBILE FULLSCREEN MENU (PREMIUM)
===================================== */
/* =====================================
   MOBILE FULLSCREEN MENU – FIXED
===================================== */
@media (max-width: 991px) {

    /* Fullscreen menu overlay */
    .navbar-collapse {
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100dvh; /* iOS fix */
        background: linear-gradient(135deg, #4f46e5, #4338ca);
        padding: 100px 24px 40px;
        z-index: 9999;

        display: flex;
        flex-direction: column;
        gap: 12px;

        transform: translateY(-100%);
        transition: transform 0.35s ease;
    }

    /* Show menu */
    .navbar-collapse.show {
        transform: translateY(0);
    }

    /* Menu items */
    .navbar-nav {
        width: 100%;
    }

    .navbar-nav .nav-link {
        color: #ffffff !important;
        font-size: 20px;
        font-weight: 600;
        padding: 14px 0 !important;
        display: block;
    }

    .navbar-nav .nav-link:hover {
        color: #fde047 !important;
    }

    /* Buttons inside menu */
    .navbar-nav .btn {
        width: 100%;
        margin-top: 16px;
        padding: 14px;
        border-radius: 999px;
        font-size: 16px;
    }

    /* LOCK BACKGROUND */
    body.menu-open {
        overflow: hidden;
    }

    body.menu-open main {
        filter: blur(6px);
        pointer-events: none;
        user-select: none;
    }
}
.navbar {
    z-index: 10000;
}

