/* =====================================================
   Гусь ВПН — gusvpn-app.mom
   Palette: orange (#FF8551) + violet (#5C4B99) on cream
   Fonts: Poppins (headings) + Nunito (body)
   ===================================================== */

:root{
    --primary: #FF8551;
    --primary-dark: #E36A37;
    --accent: #5C4B99;
    --accent-light: #8472BB;
    --bg: #FFF8EE;
    --bg-alt: #FFEFD9;
    --text: #2A2438;
    --text-muted: #6B6477;
    --card-bg: #FFFFFF;
    --border: #F1E4CE;
    --radius: 18px;
    --radius-sm: 14px;
    --radius-lg: 28px;
    --shadow-sm: 0 4px 14px rgba(92, 75, 153, 0.06);
    --shadow-md: 0 10px 28px rgba(92, 75, 153, 0.10);
    --shadow-lg: 0 18px 50px rgba(255, 133, 81, 0.18);
    --gradient: linear-gradient(135deg, #FF8551 0%, #FF9B6E 50%, #5C4B99 100%);
    --gradient-soft: linear-gradient(135deg, #FFEFD9 0%, #FFF8EE 100%);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font-family: 'Nunito', system-ui, sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.65;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

h1,h2,h3,h4{
    font-family: 'Poppins', system-ui, sans-serif;
    font-weight: 700;
    line-height: 1.2;
    color: var(--text);
}

a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary)}

img{max-width:100%;display:block}

.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* ===== ACCENT BAR (top stripe) ===== */
.accent-bar{
    height: 4px;
    background: var(--gradient);
    width: 100%;
}

/* ===== HEADER (white, sticky) ===== */
.site-header{
    position: sticky;
    top: 0;
    background: #FFFFFF;
    border-bottom: 1px solid var(--border);
    z-index: 100;
    transition: box-shadow .25s;
}
.site-header.scrolled{box-shadow: 0 6px 20px rgba(92, 75, 153, 0.08)}

.header-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 14px 0;
    gap: 32px;
}

.logo{
    display:flex;
    align-items:center;
    gap:10px;
    font-family:'Poppins',sans-serif;
    font-weight:800;
    font-size:20px;
    color:var(--text);
}
.logo:hover{color:var(--text)}
.logo-mark{
    width:38px;height:38px;
    border-radius:12px;
    background: var(--gradient);
    display:grid;place-items:center;
    color:#fff;font-weight:800;font-size:18px;
    box-shadow: var(--shadow-sm);
}

.nav-links{
    display:flex;
    align-items:center;
    gap:28px;
    list-style:none;
}
.nav-links a{
    font-weight:600;
    color:var(--text);
    font-size:15px;
}
.nav-links a:hover{color:var(--primary)}

.nav-links a.nav-cta{
    background: var(--primary);
    color: #000000;
    font-weight: 800;
    padding: 10px 22px;
    border-radius: 14px;
    box-shadow: var(--shadow-sm);
    transition: transform .2s, box-shadow .25s, background .2s;
    display:inline-flex;align-items:center;gap:8px;
}
.nav-links a.nav-cta:hover{
    color: #000000;
    background: var(--primary-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.nav-links a.nav-cta::after{content:"→";font-weight:700}

.burger{
    display:none;
    width:42px;height:42px;
    border:none;background:transparent;
    flex-direction:column;justify-content:center;align-items:center;
    gap:5px;cursor:pointer;
}
.burger span{
    display:block;width:22px;height:2px;background:var(--text);
    border-radius:2px;transition:transform .25s, opacity .2s;
}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== MOBILE NAV ===== */
.mobile-nav{
    display:none;
    position:fixed;
    top:64px;left:0;right:0;
    background:#FFF;
    border-bottom:1px solid var(--border);
    padding:24px;
    z-index:99;
    transform:translateY(-110%);
    transition:transform .3s ease;
    box-shadow: var(--shadow-md);
}
.mobile-nav.show{transform:translateY(0)}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:16px}
.mobile-nav a{font-weight:600;color:var(--text);font-size:17px}
.mobile-nav a.nav-cta{
    background: var(--primary);
    color:#000000;
    font-weight:800;
    text-align:center;
    padding:12px;
    border-radius:14px;
    margin-top:8px;
}

/* ===== HERO (centered card) ===== */
.hero{
    padding: 80px 0 90px;
    background: radial-gradient(ellipse at top, #FFEFD9 0%, var(--bg) 60%);
    position:relative;
    overflow:hidden;
}
.hero::before{
    content:"";
    position:absolute;
    top:-120px;right:-100px;
    width:380px;height:380px;
    background: var(--accent);
    opacity:.08;
    border-radius:50%;
    filter: blur(40px);
}
.hero::after{
    content:"";
    position:absolute;
    bottom:-150px;left:-120px;
    width:420px;height:420px;
    background: var(--primary);
    opacity:.10;
    border-radius:50%;
    filter: blur(50px);
}

.hero-card{
    position:relative;
    max-width: 760px;
    margin: 0 auto;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: 56px 48px;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border);
    text-align:center;
    z-index:2;
}

.hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    background: var(--bg-alt);
    color: var(--accent);
    font-weight:700;
    padding: 8px 18px;
    border-radius: 999px;
    font-size: 13px;
    margin-bottom: 22px;
    border: 1px solid #F4DDB6;
}
.hero-badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--primary)}

.hero h1{
    font-size: clamp(32px, 5vw, 48px);
    margin-bottom: 18px;
    letter-spacing:-.5px;
}
.hero h1 .accent{color:var(--primary)}

.hero-desc{
    font-size: 17px;
    color: var(--text-muted);
    max-width: 560px;
    margin: 0 auto 32px;
    line-height: 1.7;
}

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

.btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding: 14px 28px;
    border-radius: 14px;
    font-family:'Poppins',sans-serif;
    font-weight: 700;
    font-size:15px;
    text-decoration:none;
    transition: transform .2s, box-shadow .2s, background .2s;
    cursor:pointer;
    border:none;
}
.btn-primary{
    background: var(--primary);
    color: #000000;
    box-shadow: var(--shadow-md);
}
.btn-primary:hover{
    background: var(--primary-dark);
    color:#000;
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}
.btn-primary::after{content:"→";font-weight:800}

.btn-secondary{
    background: transparent;
    color: var(--accent);
    border: 2px solid var(--accent);
}
.btn-secondary:hover{
    background: var(--accent);
    color:#FFF;
    transform: translateY(-2px);
}
.btn-secondary::after{content:"↓";font-weight:800}

.trust{
    display:flex;flex-wrap:wrap;
    justify-content:center;
    gap: 18px 28px;
    padding-top: 24px;
    border-top: 1px dashed var(--border);
}
.trust span{
    font-size:13px;
    color: var(--text-muted);
    font-weight:600;
    display:inline-flex;align-items:center;gap:6px;
}
.trust span::before{content:"✓";color:var(--primary);font-weight:800}

/* ===== STATS ROW ===== */
.stats{
    padding: 56px 0;
    background: var(--card-bg);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.stats-grid{
    display:grid;
    grid-template-columns: repeat(4,1fr);
    gap: 24px;
    text-align:center;
}
.stat-num{
    font-family:'Poppins',sans-serif;
    font-size:34px;
    font-weight:800;
    color: var(--primary);
    line-height:1;
    margin-bottom:6px;
}
.stat-label{
    font-size:14px;
    color:var(--text-muted);
    font-weight:600;
}

/* ===== SECTION BASE ===== */
section{padding: 88px 0}
.section-head{text-align:center;max-width:680px;margin: 0 auto 50px}
.section-head .eyebrow{
    display:inline-block;
    color:var(--accent);
    font-weight:800;
    font-size:13px;
    letter-spacing:1.5px;
    text-transform:uppercase;
    margin-bottom:10px;
}
.section-head h2{
    font-size: clamp(26px, 4vw, 36px);
    margin-bottom: 14px;
}
.section-head p{
    color:var(--text-muted);
    font-size:16px;
}

/* White bg + coloured accent block (Sections G) */
.accent-block{
    background: var(--gradient-soft);
    border-radius: var(--radius-lg);
    padding: 50px;
    border: 1px solid var(--border);
}

/* ===== FEATURES (horizontal cards) ===== */
.features{background: var(--card-bg)}
.features-grid{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
}
.feature{
    display:flex;
    align-items:flex-start;
    gap: 20px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 26px;
    transition: transform .25s, box-shadow .25s, border-color .25s;
}
.feature:hover{
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--primary);
}
.feature-icon{
    flex-shrink:0;
    width: 60px;height: 60px;
    border-radius: 16px;
    background: var(--gradient);
    color:#FFF;
    display:grid;place-items:center;
    font-size: 26px;
    box-shadow: var(--shadow-sm);
}
.feature-text h3{
    font-size: 18px;
    margin-bottom:6px;
}
.feature-text p{
    color: var(--text-muted);
    font-size: 14.5px;
    line-height:1.6;
}

/* ===== PLATFORMS ===== */
.platforms{background: var(--bg)}
.platform-grid{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap: 18px;
}
.platform{
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 24px;
    text-align:center;
    transition: transform .25s, box-shadow .25s;
    color: var(--text);
    display:block;
}
.platform:hover{
    transform: translateY(-6px) scale(1.01);
    box-shadow: var(--shadow-md);
    color: var(--text);
}
.platform .icon{
    width:56px;height:56px;
    margin: 0 auto 14px;
    border-radius: 14px;
    background: var(--bg-alt);
    color: var(--accent);
    display:grid;place-items:center;
    font-size:24px;
    transition: background .25s, color .25s;
}
.platform:hover .icon{
    background: var(--accent);
    color:#FFF;
}
.platform h4{font-size:17px;margin-bottom:4px}
.platform .meta{font-size:13px;color:var(--text-muted);font-weight:600}
.platform .arrow{
    display:block;
    margin-top:14px;
    color:var(--primary);
    font-weight:800;
    font-size:14px;
}
.platform .arrow::after{content:" →"}

/* ===== WHY US ===== */
.why{background: var(--card-bg)}
.why-grid{
    display:grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 50px;
    align-items:center;
}
.why-text h2{font-size:32px;margin-bottom:20px}
.why-text p{color:var(--text-muted);margin-bottom:14px;font-size:15.5px}
.why-list{
    list-style:none;margin-top:18px;
    display:flex;flex-direction:column;gap:12px;
}
.why-list li{
    display:flex;align-items:flex-start;gap:12px;
    color: var(--text);
    font-weight:600;
    font-size:15px;
}
.why-list li::before{
    content:"✓";
    flex-shrink:0;
    width:26px;height:26px;
    border-radius:8px;
    background: var(--primary);
    color:#FFF;
    display:grid;place-items:center;
    font-size:14px;font-weight:800;
}
.why-visual{
    background: var(--gradient);
    border-radius: var(--radius-lg);
    padding: 44px;
    color:#FFF;
    text-align:center;
    box-shadow: var(--shadow-lg);
    position:relative;
    overflow:hidden;
}
.why-visual::before{
    content:"";
    position:absolute;
    top:-50%;right:-30%;
    width:200%;height:200%;
    background: radial-gradient(circle at center, rgba(255,255,255,.15) 0%, transparent 50%);
    pointer-events:none;
}
.why-visual h3{
    color:#FFF;font-size:28px;margin-bottom:14px;
    position:relative;
}
.why-visual p{color:rgba(255,255,255,.9);position:relative;margin-bottom:22px}
.why-visual .btn{
    background:#FFF;color: var(--accent);
    position:relative;
}
.why-visual .btn:hover{background:#FFEFD9;color:var(--accent)}

/* ===== USE CASES ===== */
.cases{background: var(--bg)}
.cases-grid{
    display:grid;
    grid-template-columns: repeat(2,1fr);
    gap:22px;
}
.case{
    display:flex;align-items:flex-start;gap:18px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    border-radius: var(--radius);
    padding: 24px;
    transition: transform .25s, box-shadow .25s, border-left-color .25s;
}
.case:hover{
    transform: translateX(4px);
    box-shadow: var(--shadow-md);
    border-left-color: var(--primary);
}
.case-num{
    flex-shrink:0;
    width: 50px;height:50px;
    border-radius: 14px;
    background: var(--bg-alt);
    color: var(--accent);
    display:grid;place-items:center;
    font-family:'Poppins',sans-serif;
    font-weight:800;font-size:18px;
}
.case-text h3{font-size:17px;margin-bottom:6px}
.case-text p{color:var(--text-muted);font-size:14.5px;line-height:1.6}

/* ===== PRICING / CTA GRADIENT CARD ===== */
.pricing{padding: 80px 0;background: var(--card-bg)}
.price-card{
    background: var(--gradient);
    border-radius: var(--radius-lg);
    padding: 60px 48px;
    text-align:center;
    color:#FFF;
    box-shadow: var(--shadow-lg);
    position:relative;
    overflow:hidden;
}
.price-card::before{
    content:"";
    position:absolute;
    top:-40%;left:-10%;
    width:60%;height:140%;
    background: rgba(255,255,255,.08);
    transform: rotate(20deg);
}
.price-card::after{
    content:"";
    position:absolute;
    bottom:-30%;right:-15%;
    width:50%;height:120%;
    background: rgba(92,75,153,.20);
    transform: rotate(-15deg);
}
.price-card > *{position:relative;z-index:2}
.price-tag{
    display:inline-block;
    background: rgba(255,255,255,.20);
    color:#FFF;
    font-weight:800;
    padding: 6px 18px;
    border-radius: 999px;
    font-size: 13px;
    margin-bottom:18px;
    backdrop-filter: blur(6px);
}
.price-card h2{
    color:#FFF;
    font-size: clamp(28px, 4vw, 40px);
    margin-bottom: 14px;
}
.price-card p{
    color: rgba(255,255,255,.92);
    max-width: 540px;
    margin: 0 auto 28px;
    font-size: 16px;
}
.price-amount{
    font-family:'Poppins',sans-serif;
    font-size: 56px;
    font-weight:800;
    margin-bottom:6px;
    line-height:1;
}
.price-amount small{font-size:20px;font-weight:600;opacity:.85}
.price-note{
    font-size:13px;
    opacity:.85;
    margin-bottom: 28px;
}
.price-card .btn{
    background:#FFF;
    color: var(--primary);
    font-size:16px;
    padding: 16px 34px;
}
.price-card .btn:hover{
    background: #FFEFD9;
    color: var(--primary-dark);
}

/* ===== FAQ ACCORDION ===== */
.faq{background: var(--bg)}
.faq-wrap{
    max-width: 820px;
    margin: 0 auto;
    display:flex;flex-direction:column;
    gap: 12px;
}
.faq-item{
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow:hidden;
    transition: border-color .25s, box-shadow .25s;
}
.faq-item.open{
    border-color: var(--primary);
    box-shadow: var(--shadow-md);
}
.faq-q{
    width:100%;
    text-align:left;
    background:transparent;
    border:none;
    padding: 22px 26px;
    font-family:'Poppins',sans-serif;
    font-weight:600;
    font-size:16px;
    color: var(--text);
    cursor:pointer;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
    transition: background .2s;
}
.faq-q:hover{background: var(--bg-alt)}
.faq-toggle{
    flex-shrink:0;
    width:32px;height:32px;
    border-radius:10px;
    background: var(--bg-alt);
    color: var(--accent);
    display:grid;place-items:center;
    font-weight:800;
    font-size:18px;
    transition: transform .3s, background .25s, color .25s;
}
.faq-item.open .faq-toggle{
    transform: rotate(45deg);
    background: var(--primary);
    color:#FFF;
}
.faq-a{
    max-height:0;
    overflow:hidden;
    transition: max-height .35s ease;
}
.faq-a-inner{
    padding: 0 26px 22px;
    color: var(--text-muted);
    font-size:15px;
    line-height:1.7;
}

/* ===== INSTRUKTSIYA STEPS ===== */
.steps{background: var(--card-bg)}
.steps-grid{
    display:grid;
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 880px;
    margin: 0 auto;
}
.step{
    display:flex;
    align-items:flex-start;
    gap: 24px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    transition: transform .25s, box-shadow .25s;
}
.step:hover{
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.step-num{
    flex-shrink:0;
    width:64px;height:64px;
    border-radius:18px;
    background: var(--gradient);
    color:#FFF;
    display:grid;place-items:center;
    font-family:'Poppins',sans-serif;
    font-size:26px;
    font-weight:800;
    box-shadow: var(--shadow-sm);
}
.step-text h3{font-size:22px;margin-bottom:10px}
.step-text p{color:var(--text-muted);font-size:15px;line-height:1.7;margin-bottom:14px}
.step-text .btn{margin-top:6px;font-size:14px;padding:11px 22px}

.tips{background: var(--bg)}
.tips-grid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}
.tip{
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 24px;
    transition: transform .25s, box-shadow .25s;
}
.tip:hover{
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.tip-icon{
    width:50px;height:50px;
    border-radius:14px;
    background: var(--bg-alt);
    color: var(--primary);
    display:grid;place-items:center;
    font-size:22px;
    margin-bottom:14px;
}
.tip h3{font-size:17px;margin-bottom:8px}
.tip p{color:var(--text-muted);font-size:14.5px;line-height:1.6}

.after-pay{background: var(--card-bg)}
.after-grid{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap:18px;
    margin-top:30px;
}
.after-card{
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 22px;
    text-align:center;
}
.after-card .ic{
    width:46px;height:46px;
    margin: 0 auto 12px;
    border-radius:12px;
    background: var(--gradient);
    color:#FFF;
    display:grid;place-items:center;
    font-size:20px;
}
.after-card h4{font-size:15px;margin-bottom:4px}
.after-card .meta{font-size:13px;color:var(--text-muted);font-weight:600}

/* ===== CTA BANNER (instr last) ===== */
.cta-mini{
    background: var(--gradient);
    border-radius: var(--radius-lg);
    padding: 50px 40px;
    text-align:center;
    color:#FFF;
    box-shadow: var(--shadow-lg);
}
.cta-mini h2{color:#FFF;margin-bottom:12px}
.cta-mini p{color: rgba(255,255,255,.92);margin-bottom: 24px;max-width:540px;margin-left:auto;margin-right:auto}
.cta-mini .btn{
    background:#FFF;color:var(--primary);
}
.cta-mini .btn:hover{background:#FFEFD9;color:var(--primary-dark)}

/* ===== FOOTER (two-level) ===== */
.site-footer{
    background: #25203A;
    color: #C4BED4;
    padding-top: 60px;
}
.footer-top{
    display:grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,.10);
}
.footer-brand .logo{color:#FFF}
.footer-brand .logo:hover{color:#FFF}
.footer-brand p{
    color:#9F98AF;
    font-size:14.5px;
    line-height:1.7;
    margin-top: 14px;
}
.footer-col h4{
    color:#FFF;
    font-size:15px;
    font-weight:700;
    margin-bottom:16px;
    font-family:'Poppins',sans-serif;
    letter-spacing:.3px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:#9F98AF;font-size:14.5px}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{
    padding: 22px 0;
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap: 14px;
    font-size: 13.5px;
    color: #807997;
}
.footer-bottom .small-eng{color:#5F587A;font-size:12.5px}

/* ===== RESPONSIVE ===== */
@media (max-width: 980px){
    .nav-links{display:none}
    .burger{display:flex}
    .mobile-nav{display:block}
    section{padding: 64px 0}
    .hero{padding: 56px 0 70px}
    .hero-card{padding: 40px 28px}
    .stats-grid{grid-template-columns: repeat(2,1fr); gap:30px}
    .features-grid{grid-template-columns: 1fr}
    .platform-grid{grid-template-columns: repeat(2,1fr)}
    .why-grid{grid-template-columns: 1fr;gap:30px}
    .cases-grid{grid-template-columns: 1fr}
    .tips-grid{grid-template-columns: 1fr}
    .after-grid{grid-template-columns: repeat(2,1fr)}
    .footer-top{grid-template-columns: 1fr 1fr;gap:30px}
    .price-card{padding: 44px 24px}
    .accent-block{padding:32px 22px}
}

@media (max-width: 640px){
    .container{padding: 0 18px}
    .hero h1{font-size: 28px}
    .hero-card{padding: 32px 20px}
    .hero-actions{flex-direction:column}
    .hero-actions .btn{width:100%;justify-content:center}
    .stats-grid{grid-template-columns: 1fr 1fr;gap:24px}
    .stat-num{font-size:28px}
    .platform-grid{grid-template-columns: 1fr}
    .after-grid{grid-template-columns: 1fr}
    .footer-top{grid-template-columns: 1fr}
    .footer-bottom{flex-direction:column;text-align:center}
    .step{flex-direction:column;padding:24px}
    .feature{flex-direction:column}
    .case{flex-direction:column}
    .price-amount{font-size:42px}
    .price-card{padding: 36px 20px}
    .why-visual{padding: 32px 22px}
}
