:root{
    --bg:#f7f7f5;
    --card:#ffffff;
    --text:#111111;
    --muted:#666666;
    --line:#e8e8e8;
    --orange:#f25e18;
    --orange-dark:#d94d0d;
    --black:#101010;
    --radius:24px;
    --shadow:0 20px 60px rgba(0,0,0,.08);
    --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Inter, Arial, sans-serif;
    background:var(--bg);
    color:var(--text);
    line-height:1.5;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.container{
    width:min(calc(100% - 32px), var(--container));
    margin:0 auto;
}

.pass-header{
    position:sticky;
    top:0;
    z-index:1000;
    background:rgba(247,247,245,.90);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(0,0,0,.05);
}

.nav{
    min-height:78px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
}

.brand-text{
    display:inline-flex;
    align-items:flex-start;
    gap:0;
    font-weight:900;
    letter-spacing:-.04em;
    line-height:1;
    font-size:2.15rem;
}

.brand-prodi{color:#2f2f35}
.brand-app{color:var(--orange)}
.brand-tm{
    font-size:.78rem;
    margin-left:4px;
    color:#444;
    font-weight:800;
    position:relative;
    top:2px;
}

.nav-right{
    display:flex;
    align-items:center;
    gap:12px;
}

.lang-switch{
    display:inline-flex;
    align-items:center;
    gap:4px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:999px;
    padding:4px;
}

.lang-switch a{
    padding:8px 12px;
    border-radius:999px;
    font-weight:800;
    font-size:.85rem;
    color:#555;
}

.lang-switch a.active{
    background:var(--orange);
    color:#fff;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:50px;
    padding:0 18px;
    border-radius:16px;
    font-weight:800;
    border:1px solid transparent;
    transition:.22s ease;
    cursor:pointer;
    text-align:center;
    white-space:nowrap;
}

.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-dark)}
.btn-dark{background:var(--black);color:#fff}
.btn-outline{background:transparent;border-color:#111;color:#111}
.btn-lg{
    min-height:56px;
    padding:0 24px;
    font-size:1rem;
}

.hero{
    padding:72px 0 42px;
}

.hero-grid{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:44px;
    align-items:center;
}

.eyebrow{
    display:inline-block;
    padding:8px 14px;
    border-radius:999px;
    background:rgba(242,94,24,.12);
    color:var(--orange);
    font-weight:800;
    font-size:.88rem;
    margin-bottom:18px;
}
.eyebrow.light{
    background:rgba(255,255,255,.12);
    color:#fff;
}

.hero h1{
    font-size:clamp(2.5rem, 5.4vw, 5rem);
    line-height:.98;
    letter-spacing:-.06em;
    margin:0 0 18px;
    max-width:780px;
}

.hero-text{
    font-size:1.08rem;
    color:var(--muted);
    max-width:670px;
    margin:0 0 24px;
}

.hero-points{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-bottom:24px;
}

.hero-points div{
    background:#fff;
    border:1px solid var(--line);
    border-radius:999px;
    padding:10px 14px;
    font-weight:700;
    font-size:.92rem;
}

.hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
}
.hero-actions.center{
    justify-content:center;
}

.hero-note{
    margin:18px 0 0;
    color:#777;
    font-size:.96rem;
    max-width:640px;
}

.hero-visual{
    display:flex;
    justify-content:center;
}

.hero-card{
    background:#fff;
    border-radius:34px;
    overflow:hidden;
    box-shadow:var(--shadow);
    width:100%;
    max-width:520px;
}
.hero-card img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.simple-strip{
    padding:12px 0 24px;
}

.strip-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}

.strip-item{
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    padding:18px;
    text-align:center;
    font-weight:800;
}

.why{
    padding:74px 0 28px;
}

.narrow{
    max-width:860px;
    text-align:center;
}

.narrow h2{
    font-size:clamp(1.9rem, 3vw, 3rem);
    line-height:1.08;
    letter-spacing:-.04em;
    margin:0 0 14px;
}

.narrow p{
    margin:0;
    color:var(--muted);
    font-size:1.05rem;
}

.benefits{
    padding:34px 0 86px;
}

.benefits-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
}

.benefit-card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:24px;
    padding:28px;
    box-shadow:0 10px 35px rgba(0,0,0,.04);
}

.benefit-card h3{
    margin:0 0 10px;
    font-size:1.2rem;
    line-height:1.1;
}

.benefit-card p{
    margin:0;
    color:var(--muted);
}

.final-cta{
    padding:0 0 86px;
}

.final-box{
    background:linear-gradient(135deg,#111 0%, #1e1e1e 100%);
    color:#fff;
    border-radius:36px;
    padding:56px 28px;
    text-align:center;
    box-shadow:var(--shadow);
}

.final-box h2{
    font-size:clamp(2rem, 4vw, 3.4rem);
    line-height:1.05;
    letter-spacing:-.04em;
    margin:0 0 14px;
}

.final-box p{
    margin:0 0 24px;
    color:rgba(255,255,255,.82);
    font-size:1.02rem;
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
}

.pass-footer{
    background:#fff;
    border-top:1px solid var(--line);
    padding:22px 0 28px;
}

.footer-wrap p{
    margin:0;
    text-align:center;
    color:#777;
    font-size:.94rem;
}

@media (max-width: 980px){
    .hero-grid,
    .benefits-grid,
    .strip-grid{
        grid-template-columns:1fr;
    }

    .hero{
        padding:52px 0 28px;
    }

    .hero h1{
        max-width:100%;
    }
}

@media (max-width: 640px){
    .container{
        width:min(calc(100% - 20px), var(--container));
    }

    .nav{
        min-height:72px;
    }

    .brand-text{
        font-size:1.8rem;
    }

    .nav-right{
        gap:8px;
    }

    .btn{
        width:100%;
        white-space:normal;
        padding:14px 16px;
        min-height:52px;
    }

    .nav-btn{
        width:auto;
        min-height:46px;
        padding:0 14px;
        white-space:nowrap;
    }

    .hero-actions{
        flex-direction:column;
    }

    .hero-card{
        border-radius:24px;
    }

    .final-box{
        border-radius:28px;
        padding:42px 18px;
    }
}