/* ==========================================================================
   _main.css
   --------------------------------------------------------------------------
   Page background: light #F2A800 -> pink (as before)
   Box hover: Armenia gradient TOP -> BOTTOM on hover (smooth, via overlay)
   Reveal: fade + slide when entering viewport
   Container: full width
   ========================================================================== */

:root {
    /* Page background gradient */
    --bg: #ffffff;
    --bg-soft: rgba(255, 255, 255, 0.70);

    --bg-gold: rgba(242, 168, 0, 0.12);     /* #F2A800 (very light) */
    --bg-pink: rgba(255, 105, 180, 0.10);   /* light pink */

    --card: #ffffff;
    --text: #0f172a;
    --text-muted: #475569;
    --border: rgba(15, 23, 42, 0.12);

    --accent: rgb(0, 51, 160);
    --accent-weak: rgba(0, 51, 160, 0.12);

    --shadow-1: 0 8px 24px rgba(15, 23, 42, 0.08);
    --shadow-2: 0 16px 44px rgba(15, 23, 42, 0.10);

    --r-1: 10px;
    --r-2: 16px;
    --r-pill: 999px;

    --container-pad: 18px;

    /* Box hover overlay (Armenia colors, light) */
    --box-hov-r: rgba(217, 0, 18, 0.12);     /* #D90012 */
    --box-hov-b: rgba(0, 51, 160, 0.12);     /* #0033A0 */
    --box-hov-o: rgba(242, 168, 0, 0.14);    /* #F2A800 */
}

* {
    box-sizing: border-box;
}

html, body {
    height: 100%;
    overflow-x: hidden;
}

body {
    margin: 0;
    font-family: Roboto, system-ui, -apple-system, Segoe UI, Arial, sans-serif;

    /* Page background ONLY */
    /* background: white; */
    /* background:
        radial-gradient(900px 600px at 18% 12%, rgba(242, 168, 0, 0.18), transparent 62%),
        radial-gradient(900px 600px at 82% 22%, rgba(255, 105, 180, 0.14), transparent 65%); */
    background:
        radial-gradient(900px 600px at 18% 12%, var(--bg-gold), transparent 62%),
        radial-gradient(900px 600px at 82% 18%, var(--bg-pink), transparent 65%),
        linear-gradient(135deg, rgba(242, 168, 0, 0.08) 0%, rgba(255, 105, 180, 0.07) 100%);

    color: var(--text);

}

/* Full-width container */
.container {
    width: 100%;
    /* max-width: 2000px; */
    max-width: 1800px;
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
    margin: 0 auto;
}

.section {
    padding: 44px 0;
}

/* Typography */
.h1 {
    font-size: clamp(30px, 4vw, 46px);
    line-height: 1.1;
    letter-spacing: -0.6px;
    margin: 0;
}

.h2 {
    font-size: clamp(22px, 2.8vw, 32px);
    line-height: 1.2;
    margin: 0;
}

h4{
    font-weight: 900;
    /* font-size: 18px !important; */
  /* color: #fff !important;
  text-shadow: 2px 2px 8px #000000;     */
    /* color: black !important; */
    text-shadow: 
                    -1px -1px 0px #fff,
                    1px -1px 0px #fff,
                    -1px 1px 0px #fff,
                    1px 1px 0px #fff;
    /* text-shadow: 0 0 5px #fff, 0 0 10px #fff; */
}

.p {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.65;
    font-size: 16px;
}

/* Spacing */
.mt-8 { margin-top: 8px; }
.mt-12 { margin-top: 12px; }
.mt-18 { margin-top: 18px; }

h4.p.mt-12
{

}

/* Cards */
.card {
    border: 1px solid var(--border);
    background: var(--card);
    border-radius: var(--r-2);
    box-shadow: var(--shadow-1);
}

.card-pad {
    padding: 18px;
}

/* Badge */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: var(--r-pill);
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.60);
    color: var(--text);
    font-weight: 800;
    font-size: 13px;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: var(--r-pill);
    border: 1px solid var(--border);
    text-decoration: none;
    font-weight: 900;
    letter-spacing: 0.2px;
    user-select: none;

    transition:
        transform 360ms ease,
        box-shadow 360ms ease,
        background 360ms ease,
        border-color 360ms ease;
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-1);
}

.btn.primary {
    border-color: rgba(0, 51, 160, 0.35);
    background: var(--accent);
    color: #ffffff;
}
.btn.primary:hover{
    background: rgb(242, 168, 0);
    border-color: rgba(242, 168, 0, 0.35);
}

.btn.secondary {
    background: rgba(255, 255, 255, 0.85);
    color: var(--text);
}

/* Grid */
.grid {
    display: grid;
    gap: 18px;
}

.grid.cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* ==========================================================================
   BOX HOVER ANIMATION (Smooth gradient top -> bottom)
   ========================================================================== */

.card,
.home-hero__trust-item,
.home-hero__media-card,
.home-strip__inner,
.zvn-footer__brand.card,
.zvn-footer__col.card {
    position: relative;
    overflow: hidden;

    transition:
        transform 480ms ease,
        box-shadow 480ms ease,
        border-color 480ms ease;
}

/* gradient overlay */
.card::before,
.home-hero__trust-item::before,
.home-hero__media-card::before,
.home-strip__inner::before,
.zvn-footer__brand.card::before,
.zvn-footer__col.card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;

    /* background: linear-gradient(
        to bottom,
        var(--box-hov-r) 0%,
        var(--box-hov-b) 50%,
        var(--box-hov-o) 100%
    ); */
    background: linear-gradient(
        to bottom,
        white 0%,
        var(--box-hov-o) 100%
    );

    opacity: 0;

    transition: opacity 640ms ease;
}
.home-hero__media-card::before{
    background: none;
}

/* keep real content above overlay */
.card > *,
.home-hero__trust-item > *,
.home-hero__media-card > *,
.home-strip__inner > *,
.zvn-footer__brand.card > *,
.zvn-footer__col.card > * {
    position: relative;
    z-index: 1;
}

.card:hover,
.home-hero__trust-item:hover,
.home-hero__media-card:hover,
.home-strip__inner:hover,
.zvn-footer__brand.card:hover,
.zvn-footer__col.card:hover {
    /* transform: translateY(-4px) !important; */
    transform: scale(1.03) !important;

    box-shadow: var(--shadow-2);
    border-color: rgba(15, 23, 42, 0.18);
}
.home-hero__media-card:hover
{
    box-shadow: none;
}

.card:hover::before,
.home-hero__trust-item:hover::before,
.home-hero__media-card:hover::before,
.home-strip__inner:hover::before,
.zvn-footer__brand.card:hover::before,
.zvn-footer__col.card:hover::before {
    opacity: 1;
}

/* ==========================================================================
   Viewport reveal (fade + slide)
   ========================================================================== */

.reveal {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 1040ms ease, transform 1040ms ease;
}

.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Responsive */
@media (max-width: 980px) {
    .grid.cols-3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    :root {
        --container-pad: 14px;
    }

    .badge_top{
        width: 100%;
    }
}
