/* ==========================================================================
   Nevesinjska olimpijada — glavna stranica dogadjaja, content sloj
   Ne dira navbar i hero. Stilizuje:
     - moto premium sekciju
     - intro/opis dogadjaja
     - info kartice
     - content blokove (text, text_image, background_text, image, youtube,
       video_link, note, button)
     - bottom CTA strip
     - reveal-on-scroll animacije
     - subtle parallax za image blokove

   Stil: 2026 editorial / premium / sportsko-tradicionalni. Neutralne boje,
   diskretan bronze accent, bez kica.
   ========================================================================== */

:root {
    /* --- Boje --- */
    --evp-bg:         #faf9f6;     /* off-white pozadina */
    --evp-bg-soft:    #f4f1ea;
    --evp-text:       #14161a;     /* primary text */
    --evp-text-strong:#0e1014;     /* headings */
    --evp-text-soft:  #4b4f57;     /* body */
    --evp-text-mute:  #7a7e87;     /* meta */
    --evp-border:     rgba(0,0,0,.08);
    --evp-border-soft:rgba(0,0,0,.05);
    --evp-accent:     #b9852c;     /* diskretni bronze — koristi se samo za male linije/hover, nikad za large tekst */

    /* --- Sjenke (suzdržane, ne dramatic) --- */
    --evp-shadow-sm:  0 1px 2px rgba(15,17,22,.04);
    --evp-shadow-md:  0 8px 24px rgba(15,17,22,.06);
    --evp-shadow-lg:  0 20px 48px rgba(15,17,22,.08);

    /* --- Radius skala --- */
    --evp-radius-sm:  10px;
    --evp-radius-md:  18px;
    --evp-radius-lg:  24px;
    --evp-radius-xl:  32px;

    /* --- Tipografska skala (clamp za responsive) --- */
    --evp-fs-display: clamp(2.4rem, 4.8vw, 3.6rem);   /* hero only, ne content blocks */
    --evp-fs-h1:      clamp(1.95rem, 3.4vw, 2.65rem); /* title bloka — text, discipline, schedule */
    --evp-fs-h2:      clamp(1.55rem, 2.6vw, 2.05rem); /* sub-title */
    --evp-fs-h3:      clamp(1.15rem, 1.6vw, 1.32rem); /* note title, day label */
    --evp-fs-lead:    clamp(1.05rem, 1.3vw, 1.15rem); /* short_description / lead */
    --evp-fs-body:    1rem;                            /* default body */
    --evp-fs-meta:    .92rem;                          /* location / date */
    --evp-fs-small:   .82rem;                          /* kicker / day label */

    /* --- Line-height tokens --- */
    --evp-lh-tight:   1.15;
    --evp-lh-snug:    1.35;
    --evp-lh-body:    1.7;
    --evp-lh-loose:   1.8;

    /* --- Letter-spacing tokens --- */
    --evp-ls-tight:   -.015em;     /* headings */
    --evp-ls-normal:  0;
    --evp-ls-wide:    .03em;       /* kicker / day label — diskretno */

    /* --- Reading width tokens (max-width za body tekst) --- */
    --evp-width-narrow:  640px;
    --evp-width-default: 720px;     /* editorial reading width — ~65 chars */
    --evp-width-wide:    880px;
    --evp-width-x:       1180px;
    --evp-width-xx:      1340px;
}

/* Stranica dogadjaja: blago topla off-white pozadina */
body.public-page {
    background: var(--evp-bg);
}

/* ==========================================================================
   Reveal-on-scroll (svi content blokovi)
   ========================================================================== */

.reveal-on-scroll {
    opacity: 0;
    transform: translateY(36px);
    filter: blur(6px);
    transition: opacity .7s cubic-bezier(.22,.61,.36,1),
                transform .8s cubic-bezier(.22,.61,.36,1),
                filter   .7s cubic-bezier(.22,.61,.36,1);
    will-change: opacity, transform, filter;
}

.reveal-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

.reveal-on-scroll[data-reveal="scale"] {
    transform: translateY(36px) scale(0.97);
}
.reveal-on-scroll[data-reveal="scale"].is-visible {
    transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
    .reveal-on-scroll {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}

/* ==========================================================================
   Event-meta pill (datum + lokacija) — kompaktni element iznad mota
   ========================================================================== */

.evp-event-meta {
    display: flex;
    justify-content: center;
    padding: clamp(36px, 6vw, 64px) 24px 0;
}

.evp-event-meta__pill {
    display: inline-flex;
    align-items: center;
    gap: 18px;
    padding: 12px 22px;
    background: rgba(255,255,255,.78);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--evp-border);
    border-radius: 999px;
    font-size: .9rem;
    color: var(--evp-text);
    box-shadow: var(--evp-shadow-sm);
}

.evp-event-meta__item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--evp-text-soft);
    font-weight: 500;
}

.evp-event-meta__item svg {
    color: var(--evp-accent);
    flex-shrink: 0;
}

.evp-event-meta__sep {
    color: var(--evp-text-mute);
    opacity: .5;
}

@media (max-width: 540px) {
    .evp-event-meta__pill {
        flex-direction: column;
        gap: 8px;
        padding: 14px 22px;
        border-radius: 20px;
    }
    .evp-event-meta__sep { display: none; }
}

/* ==========================================================================
   MOTO sekcija — clean, centralni statement.
   Bez labela, bez navodnika, bez bronze akcenta. Samo veliki serif tekst
   sa premium word-by-word reveal animacijom (translateY + blur-to-sharp).
   Pozadina je suptilan neutralni gradient sa jedva primjetnim glow-om iza
   teksta.
   ========================================================================== */

.evp-motto {
    position: relative;
    background:
        radial-gradient(ellipse 70% 55% at 50% 50%, rgba(0,0,0,.04) 0%, transparent 70%),
        linear-gradient(180deg, #f7f5f1 0%, #fbfaf7 100%);
    min-height: 60vh;
    padding: clamp(80px, 12vw, 160px) 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    isolation: isolate;
}

.evp-motto__quote {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 0;
    max-width: 1100px;
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(2.4rem, 7vw, 6rem);
    line-height: 1.05;
    font-weight: 500;
    letter-spacing: -.02em;
    color: #0f0f10;
    quotes: none;
}
.evp-motto__quote::before,
.evp-motto__quote::after { content: none; }

/* Svaka rijec ulazi nezavisno — translateY + blur-to-sharp + stagger */
.evp-motto__word {
    display: inline-block;
    white-space: nowrap;
    opacity: 0;
    transform: translateY(46px);
    filter: blur(12px);
    transition:
        opacity 1s ease,
        transform 1.05s cubic-bezier(.2,.7,.3,1),
        filter .9s ease;
    transition-delay: calc(var(--i, 0) * 80ms + 100ms);
}

.evp-motto.is-visible .evp-motto__word {
    opacity: 1;
    transform: none;
    filter: blur(0);
}

@media (prefers-reduced-motion: reduce) {
    .evp-motto__word {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}

/* ==========================================================================
   ABOUT — editorial story sekcija (opis dogadjaja)
   ========================================================================== */

.evp-about {
    padding: clamp(80px, 13vw, 160px) 24px;
    max-width: 980px;
    margin: 0 auto;
    text-align: center;
    position: relative;
}

.evp-about__label {
    display: inline-block;
    font-size: .76rem;
    font-weight: 600;
    letter-spacing: .32em;
    text-transform: uppercase;
    color: var(--evp-accent);
    margin: 0 0 22px;
}

.evp-about__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(2.2rem, 5.2vw, 4.4rem);
    line-height: 1.05;
    letter-spacing: -.015em;
    color: var(--evp-text);
    margin: 0;
    font-weight: 600;
}

.evp-about__divider {
    width: 60px;
    height: 1px;
    background: var(--evp-accent);
    margin: clamp(32px, 5vw, 48px) auto;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .9s cubic-bezier(.22,.61,.36,1);
    transition-delay: .35s;
}
.evp-about.is-visible .evp-about__divider { transform: scaleX(1); }

.evp-about__lead {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(1.2rem, 1.8vw, 1.55rem);
    line-height: 1.5;
    color: var(--evp-text-soft);
    font-style: italic;
    max-width: 56ch;
    margin: 0 auto clamp(24px, 4vw, 36px);
}

.evp-about__body {
    font-size: clamp(1.05rem, 1.25vw, 1.18rem);
    line-height: 1.85;
    color: var(--evp-text-soft);
    max-width: 70ch;
    margin: 0 auto;
    text-align: left;
}

.evp-about__body p { margin: 0 0 1.1em; }
.evp-about__body p:last-child { margin-bottom: 0; }

/* Drop cap na prvom slovu prvog paragrafa */
.evp-about__body > p:first-child::first-letter {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: 4.2em;
    line-height: .85;
    font-weight: 600;
    color: var(--evp-text);
    float: left;
    padding: 6px 14px 0 0;
    margin-top: 6px;
}

@media (prefers-reduced-motion: reduce) {
    .evp-about__divider { transform: scaleX(1) !important; transition: none !important; }
}

/* ==========================================================================
   Content blokovi — override starih .cb-* stilova za premium feel
   ========================================================================== */

/* Razmaci izmedju blokova — obican block flow, da `margin: 0 auto`
   centriranje radi pouzdano na svim block tipovima (ukljucujuci youtube
   sa iframe + aspect-ratio koji se ne snalazi dobro u flex kontejnerima). */
.evp-blocks {
    padding: clamp(64px, 9vw, 112px) 0;
}

.evp-blocks > * + * {
    margin-top: clamp(80px, 10vw, 144px);
}

/* CTA dugmad i video_link blokovi su vizuelno mali — dodatni vazdusni
   prostor poslije i prije njih da ne dijeluje "zalijepljeno" sa videom
   ili sledecim blokom. */
.evp-blocks > .evp-cb-button + *,
.evp-blocks > .evp-cb-videolink + *,
.evp-blocks > * + .evp-cb-button,
.evp-blocks > * + .evp-cb-videolink {
    margin-top: clamp(96px, 12vw, 168px);
}

/* ----- TEXT block ----- */

.evp-cb-text {
    max-width: var(--evp-width-default);   /* 720px — editorial reading width (~65ch) */
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-text__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: var(--evp-fs-h1);
    line-height: var(--evp-lh-tight);
    letter-spacing: var(--evp-ls-tight);
    color: var(--evp-text-strong);
    margin: 0 0 22px;
    font-weight: 700;
}

.evp-cb-text__body {
    font-size: var(--evp-fs-lead);
    line-height: var(--evp-lh-body);
    color: var(--evp-text-soft);
}

.evp-cb-text__body p { margin: 0 0 1.1em; }
.evp-cb-text__body p:last-child { margin-bottom: 0; }
.evp-cb-text__body strong { color: var(--evp-text-strong); font-weight: 700; }
.evp-cb-text__body a {
    color: var(--evp-text-strong);
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, var(--evp-accent) 55%, transparent);
    text-decoration-thickness: 1.5px;
    text-underline-offset: 3px;
    transition: text-decoration-color .2s ease;
}
.evp-cb-text__body a:hover { text-decoration-color: var(--evp-accent); }

/* ----- TEXT + IMAGE block (dvije kolone) ----- */

.evp-cb-textimg {
    max-width: var(--evp-width-x);   /* 1180px — magazine layout */
    margin-inline: auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(32px, 5vw, 64px);
    align-items: center;
}

.evp-cb-textimg.is-reverse > :first-child { order: 2; }

@media (max-width: 860px) {
    .evp-cb-textimg { grid-template-columns: 1fr; gap: 28px; }
    .evp-cb-textimg.is-reverse > :first-child { order: 0; }
}

.evp-cb-textimg__image {
    border-radius: var(--evp-radius-md);
    overflow: hidden;
    box-shadow: var(--evp-shadow-md);
    aspect-ratio: 4 / 3;
}

.evp-cb-textimg__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ----- BACKGROUND TEXT block (centriran, prirodne proporcije slike) -----
   Slika se NE crop-uje i NE rasteze. Renderuje se u svojoj prirodnoj
   proporciji (max-width 1200px), tekst je apsolutno pozicioniran preko nje. */

.evp-cb-bg {
    max-width: var(--evp-width-xx);   /* 1340px */
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-bg__inner {
    position: relative;
    width: 100%;
    border-radius: var(--evp-radius-lg);
    overflow: hidden;
    isolation: isolate;
    box-shadow: var(--evp-shadow-md);
    /* Tanki border, bez outline trick-a. Cleaner editorial frame. */
    border: 1px solid rgba(0,0,0,.08);
}

.evp-cb-bg__image {
    position: relative;
    display: block;
    width: 100%;
    height: auto;          /* prirodne proporcije — full HD ostaje cijela */
    z-index: 1;
}

.evp-cb-bg__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    /* Suzdržan overlay — slika diše, ali tekst ostaje čitljiv.
       Bottom-heavy linear gradient bez agresivnog vignette efekta. */
    background:
        linear-gradient(180deg, rgba(8,10,14,.15) 0%, rgba(8,10,14,.50) 100%);
    pointer-events: none;
}

.evp-cb-bg__content {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: clamp(32px, 6vw, 80px);
    color: #fff;
    /* Sirok content kontejner — tekst i naslov dišu, blok izgleda
       monumentalno. Centriranje preko margin-inline + width.
       Tekst NIJE u uskoj koloni. */
    width: min(1080px, 92%);
    margin-inline: auto;
}

.evp-cb-bg__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    /* Veci naslov za monumentalan look (do 4rem). Ne sužavati i ne lomiti
       prerano — letter-spacing slabo negativan za premium feel. */
    font-size: clamp(2.2rem, 4vw, 4rem);
    color: #fff;
    line-height: 1.08;
    letter-spacing: -.02em;
    margin: 0 0 22px;
    font-weight: 700;
    text-shadow: 0 1px 2px rgba(0,0,0,.20);
    /* Bez max-width restrikcije — naslov koristi punu širinu content kontejnera. */
}

.evp-cb-bg__text {
    font-family: var(--font-sans, 'Inter', system-ui, sans-serif);
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.65;
    color: rgba(255,255,255,.94);
    margin: 0 auto;
    /* Dovoljno sirok opis — ne usko stisnut u kolonu. */
    max-width: 850px;
    text-shadow: 0 1px 2px rgba(0,0,0,.18);
}

/* ----- BACKGROUND TEXT block — mobile override -----
   Na mobile prebacujemo iz "prirodna proporcija slike + absolute tekst"
   layouta u "wrapper definise visinu + slika cover + tekst u normalnom
   toku". To rjesava tri problema:
     1) Roditelj sada raste sa tekstom (nema overflow preko sljedeceg bloka)
     2) Slika 16:9 ne postaje ~200px visoka — wrapper drzi min-height
     3) Sljedeci blok (npr. YouTube) ne moze ulaziti preko ovog bloka jer
        je tekst u normal flow i doprinosi visini.
*/
@media (max-width: 768px) {
    .evp-cb-bg {
        padding: 0 16px;
    }

    .evp-cb-bg__inner {
        min-height: 460px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 20px;
        outline-offset: -4px;
    }

    .evp-cb-bg__image {
        /* Slika postaje pozadina sa cover umjesto prirodne proporcije. */
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
    }

    .evp-cb-bg__overlay {
        /* Tamniji overlay za citljivost preko fotografija. */
        background: linear-gradient(180deg,
            rgba(8,10,14,.50) 0%,
            rgba(8,10,14,.68) 100%);
    }

    .evp-cb-bg__content {
        /* Tekst u normalnom toku unutar flex containera, ne absolute. */
        position: relative;
        inset: auto;
        width: 100%;
        padding: 56px 22px;
    }

    .evp-cb-bg__title {
        font-size: clamp(1.6rem, 8.5vw, 2.4rem);
        line-height: 1.08;
        margin: 0 0 14px;
        text-shadow: 0 2px 18px rgba(0,0,0,.45);
        overflow-wrap: anywhere;
    }

    .evp-cb-bg__text {
        font-size: 1rem;
        line-height: 1.55;
        max-width: 34rem;
        margin: 0 auto;
        color: rgba(255,255,255,.94);
        text-shadow: 0 1px 12px rgba(0,0,0,.35);
    }
}

/* Garantovan vertikalan razmak iza background_text bloka, da YouTube
   ili sljedeci blok ne dodju previse blizu. (Vazi za mobile; clamp
   na desktopu je vec u .evp-blocks > * + *.) */
@media (max-width: 768px) {
    .evp-blocks > * + * {
        margin-top: 72px;
    }
    .evp-blocks > .evp-cb-bg + * {
        margin-top: 88px;
    }
    .evp-blocks > .evp-cb-button + *,
    .evp-blocks > .evp-cb-videolink + *,
    .evp-blocks > * + .evp-cb-button,
    .evp-blocks > * + .evp-cb-videolink {
        margin-top: 96px;
    }
}

/* ----- IMAGE block — full-screen filmski trenutak -----
   Slika zauzima cio viewport (100vh) ispod navbara kad korisnik skroluje do nje.
   Scale 1.10 daje prostor za suptilan translateY parallax tokom skrolovanja
   (kao da se slika "navlaci" iz dna). */

.evp-cb-image {
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: hidden;
}

.evp-cb-image__frame {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 480px;
    overflow: hidden;
    line-height: 0;
}

.evp-cb-image__frame img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.10) translateY(0);
    transform-origin: center;
    will-change: transform;
    transition: transform .15s linear;
}

.evp-cb-image__caption {
    text-align: center;
    color: var(--evp-text-mute);
    font-size: .9rem;
    padding: 16px 24px 4px;
    max-width: 1500px;
    margin: 0 auto;
}

@media (max-width: 640px) {
    /* na mobile manje agresivno — 75vh da sve stane uz adresnu traku */
    .evp-cb-image__frame { height: 75vh; min-height: 380px; }

    /* NOTE block — manji padding i radius, krug malo manji da ne dominira. */
    .evp-cb-note { padding: 0 16px; }
    .evp-cb-note__inner {
        padding: 20px 22px 22px 24px;
        border-radius: 14px;
        font-size: .98rem;
        line-height: 1.65;
    }
    .evp-cb-note__inner::after {
        top: -28px; right: -28px;
        width: 80px; height: 80px;
    }
    .evp-cb-note__title {
        margin-bottom: 8px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .evp-cb-image__frame img { transform: none; transition: none; }
}

/* ----- YOUTUBE block ----- */

.evp-cb-youtube {
    max-width: 1100px;
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-youtube__title {
    text-align: center;
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: var(--evp-fs-h2);
    line-height: var(--evp-lh-tight);
    letter-spacing: var(--evp-ls-tight);
    color: var(--evp-text-strong);
    margin: 0 0 28px;
    font-weight: 700;
}

.evp-cb-youtube__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: var(--evp-radius-lg);
    overflow: hidden;
    background: #111;
    box-shadow: var(--evp-shadow-lg);
}

.evp-cb-youtube__frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* ----- VIDEO LINK block ----- */

.evp-cb-videolink {
    max-width: 880px;
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-videolink__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    background: #fff;
    border: 1px solid var(--evp-border);
    border-radius: var(--evp-radius-md);
    padding: 24px 28px;
    box-shadow: var(--evp-shadow-sm);
}

.evp-cb-videolink__title {
    font-size: var(--evp-fs-h3);
    font-weight: 600;
    margin: 0 0 4px;
    color: var(--evp-text-strong);
    letter-spacing: .005em;
}

.evp-cb-videolink__text {
    margin: 0;
    color: var(--evp-text-mute);
    font-size: var(--evp-fs-meta);
    line-height: var(--evp-lh-snug);
}

/* ----- NOTE block (callout / Napomena) -----
   Brand-aligned callout. Topla pastel pozadina, lijevi bronze akcent,
   tanki border + layered sjenka. Dekorativni circle u gornjem desnom uglu
   daje malo karaktera bez vizuelnog šuma. Template ostaje netaknut. */

.evp-cb-note {
    max-width: var(--evp-width-wide);   /* 880px */
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-note__inner {
    position: relative;
    overflow: hidden;
    padding: 28px 32px 30px 36px;
    border-radius: var(--evp-radius-md);
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--evp-bg) 92%, transparent),
            color-mix(in srgb, var(--evp-bg-soft) 88%, transparent));
    border: 1px solid color-mix(in srgb, var(--evp-accent) 18%, transparent);
    border-left: 3px solid var(--evp-accent);
    box-shadow: var(--evp-shadow-sm);
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-body);
    line-height: var(--evp-lh-body);
}

/* Suptilni dekorativni krug u gornjem desnom uglu — daje "brand polish"
   bez ikonice ili tipičnog alert simbola. */
.evp-cb-note__inner::after {
    content: "";
    position: absolute;
    top: -38px;
    right: -38px;
    width: 110px;
    height: 110px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--evp-accent) 10%, transparent);
    pointer-events: none;
}

.evp-cb-note__title {
    margin: 0 0 10px;
    color: var(--evp-text);
    font-family: var(--font-sans, 'Inter', system-ui, sans-serif);
    font-weight: 700;
    font-size: clamp(1.05rem, 1.4vw, 1.18rem);
    letter-spacing: .005em;
    line-height: 1.3;
}

/* Tekst koji korisnik unese (linebreaksbr dodaje <br>, nema <p> wrapper),
   pa stilizovanje radi inherited na .__inner. Eksplicitno čistimo bilo koji
   eventualni <p> koji bi došao iz linebreaks filtera (ako se promijeni). */
.evp-cb-note__inner > p {
    margin: 0 0 .8em;
}
.evp-cb-note__inner > p:last-child {
    margin-bottom: 0;
}

/* ----- BUTTON / CTA block ----- */

.evp-cb-button {
    text-align: center;
    padding: 0 24px;
}

/* Premium solid CTA — bez gradient-a, bez kičastih sjenki, fokus na čistom
   tipografskom kontrastu. Bronze hover linija dolazi suptilno preko box-shadow. */
.evp-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 30px;
    border-radius: 999px;
    font-family: var(--font-sans);
    font-size: var(--evp-fs-body);
    font-weight: 600;
    letter-spacing: .01em;
    color: #fff;
    background: var(--evp-text-strong);
    border: 1px solid var(--evp-text-strong);
    box-shadow: var(--evp-shadow-sm);
    text-decoration: none;
    cursor: pointer;
    transition:
        background-color .25s ease,
        transform .25s ease,
        box-shadow .3s ease;
}

.evp-cta__arrow {
    display: inline-block;
    transition: transform .25s ease;
}

.evp-cta:hover {
    background: #000;
    transform: translateY(-2px);
    box-shadow: var(--evp-shadow-md);
    color: #fff;
}

.evp-cta:hover .evp-cta__arrow {
    transform: translateX(4px);
}

.evp-cta:focus-visible {
    outline: 2px solid var(--evp-accent);
    outline-offset: 3px;
}

/* ==========================================================================
   Bottom CTA strip (prijava / vijesti / galerija / kontakt)
   ========================================================================== */

.evp-bottom-cta {
    max-width: 1280px;
    margin: 0 auto clamp(64px, 10vw, 120px);
    padding: 0 24px;
}

.evp-bottom-cta__inner {
    background: linear-gradient(160deg, #14161a 0%, #1f242b 100%);
    border-radius: var(--evp-radius-xl);
    padding: clamp(48px, 7vw, 80px) clamp(24px, 5vw, 64px);
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.evp-bottom-cta__inner::before {
    content: "";
    position: absolute;
    top: -40%;
    right: -10%;
    width: 540px;
    height: 540px;
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(185,133,44,.18) 0%, transparent 60%);
    pointer-events: none;
}

.evp-bottom-cta__label {
    display: inline-block;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--evp-accent);
    margin-bottom: 16px;
}

.evp-bottom-cta__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(1.8rem, 3.6vw, 2.8rem);
    color: #fff;
    margin: 0 0 14px;
    line-height: 1.1;
}

.evp-bottom-cta__text {
    color: rgba(255,255,255,.78);
    font-size: 1.05rem;
    max-width: 56ch;
    margin: 0 auto 28px;
    line-height: 1.6;
}

.evp-bottom-cta__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
}

.evp-bottom-cta .evp-cta {
    background: linear-gradient(135deg, var(--evp-accent) 0%, #d6a647 60%, var(--evp-accent) 100%);
    background-size: 200% 200%;
    border-color: var(--evp-accent);
    color: #1a1a1a;
}

.evp-bottom-cta .evp-cta:hover { color: #1a1a1a; }

.evp-bottom-cta__secondary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 16px 24px;
    border-radius: 999px;
    color: #fff;
    border: 1px solid rgba(255,255,255,.28);
    text-decoration: none;
    font-size: .95rem;
    font-weight: 500;
    transition: background-color .25s ease, border-color .25s ease, transform .25s ease;
}

.evp-bottom-cta__secondary:hover {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.55);
    transform: translateY(-2px);
    color: #fff;
}

/* ==========================================================================
   Discipline (competition units): quick nav + content block + results stranica
   ========================================================================== */

/* ---- Quick nav (pill scroller iznad discipline blokova) ---- */

.evp-disc-nav {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 24px;
}

.evp-disc-nav__inner {
    background: #fff;
    border: 1px solid var(--evp-border);
    border-radius: 999px;
    padding: 8px;
    box-shadow: var(--evp-shadow-sm);
}

.evp-disc-nav__scroller {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.evp-disc-nav__scroller::-webkit-scrollbar { display: none; }

.evp-disc-nav__chip {
    flex: 0 0 auto;
    scroll-snap-align: start;
    display: inline-flex;
    align-items: center;
    padding: 10px 18px;
    border-radius: 999px;
    background: transparent;
    color: var(--evp-text);
    font-size: .92rem;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid transparent;
    transition: background-color .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
    white-space: nowrap;
}

.evp-disc-nav__chip:hover {
    background: var(--evp-bg-soft);
    transform: translateY(-2px);
    color: var(--evp-text);
}

.evp-disc-nav__chip.is-active {
    background: #14161a;
    color: #fff;
    border-color: #14161a;
}

@media (max-width: 720px) {
    .evp-disc-nav__inner { border-radius: 18px; padding: 8px; }
    .evp-disc-nav__scroller { justify-content: flex-start; flex-wrap: nowrap; overflow-x: auto; }
}

/* ---- Discipline content block (landing-like sekcija) ---- */

.evp-cb-discipline {
    max-width: 1180px;
    margin-inline: auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(28px, 5vw, 64px);
    align-items: center;
    scroll-margin-top: 96px;
}

.evp-cb-discipline.is-reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
}
.evp-cb-discipline.is-reverse .evp-cb-discipline__media { order: 2; }
.evp-cb-discipline.is-reverse .evp-cb-discipline__body  { order: 1; }

.evp-cb-discipline__media {
    position: relative;
    border-radius: var(--evp-radius-xl);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: var(--evp-bg-soft);
    box-shadow: var(--evp-shadow-md);
}

.evp-cb-discipline__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1.2s cubic-bezier(.22,.61,.36,1);
}

.evp-cb-discipline.reveal-on-scroll.is-visible .evp-cb-discipline__media img {
    transform: scale(1.02);
}

.evp-cb-discipline__media.is-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: 5rem;
    color: var(--evp-text-mute);
    letter-spacing: .04em;
}

.evp-cb-discipline__body {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* Kicker / label iznad naslova (npr. "Disciplina", "Konjička trka", "Koncert").
   Diskretan meta element sa malom akcent linijom — bez agresivnog uppercase-a
   i bez agresivne zlatne boje za tekst. */
.evp-cb-discipline__label {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--evp-fs-small);
    font-weight: 600;
    letter-spacing: var(--evp-ls-wide);
    text-transform: none;
    color: color-mix(in srgb, var(--evp-text) 60%, transparent);
}

.evp-cb-discipline__label::before {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--evp-accent);
    opacity: .65;
    flex-shrink: 0;
}

.evp-cb-discipline__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: var(--evp-fs-h1);
    line-height: var(--evp-lh-tight);
    letter-spacing: var(--evp-ls-tight);
    color: var(--evp-text-strong);
    margin: 0;
    font-weight: 700;
}

.evp-cb-discipline__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    color: var(--evp-text-mute);
    font-size: var(--evp-fs-meta);
    margin: 0;
}

.evp-cb-discipline__dot { color: var(--evp-text-mute); }

.evp-cb-discipline__lead {
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-lead);
    line-height: var(--evp-lh-body);
    margin: 0;
}

.evp-cb-discipline__text {
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-body);
    line-height: var(--evp-lh-body);
}

.evp-cb-discipline__update {
    margin-top: 6px;
    padding: 14px 18px;
    border-left: 3px solid var(--evp-accent);
    background: var(--evp-bg-soft);
    border-radius: 0 12px 12px 0;
}

.evp-cb-discipline__update-label {
    font-size: .76rem;
    font-weight: 600;
    letter-spacing: .02em;
    color: color-mix(in srgb, var(--evp-text) 62%, transparent);
}

.evp-cb-discipline__update-title {
    font-weight: 600;
    margin: 4px 0 4px;
    color: var(--evp-text);
}

.evp-cb-discipline__update-text {
    margin: 0;
    font-size: .92rem;
    color: var(--evp-text-soft);
    line-height: 1.55;
}

.evp-cb-discipline__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}

@media (max-width: 860px) {
    .evp-cb-discipline,
    .evp-cb-discipline.is-reverse {
        grid-template-columns: 1fr;
    }
    .evp-cb-discipline.is-reverse .evp-cb-discipline__media { order: 1; }
    .evp-cb-discipline.is-reverse .evp-cb-discipline__body  { order: 2; }
}

/* ==========================================================================
   Stranica /rezultati/
   ========================================================================== */

.evp-results-hero {
    max-width: 980px;
    margin: 0 auto;
    padding: clamp(64px, 10vw, 120px) 24px 24px;
    text-align: center;
}

.evp-results-hero__label {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--evp-accent);
    margin: 0 0 14px;
}

.evp-results-hero__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(2.6rem, 6vw, 4.4rem);
    line-height: 1;
    margin: 0 0 18px;
    color: var(--evp-text);
    font-weight: 600;
}

.evp-results-hero__lead {
    color: var(--evp-text-soft);
    font-size: 1.05rem;
    max-width: 56ch;
    margin: 0 auto;
    line-height: 1.6;
}

.evp-results-nav {
    margin: 8px auto 12px;
}

.evp-results-list {
    max-width: 1180px;
    margin: 0 auto;
    padding: clamp(28px, 5vw, 48px) 24px clamp(64px, 9vw, 120px);
    display: flex;
    flex-direction: column;
    gap: clamp(48px, 7vw, 96px);
}

.evp-results-unit {
    background: #fff;
    border: 1px solid var(--evp-border);
    border-radius: var(--evp-radius-lg);
    padding: clamp(24px, 4vw, 40px);
    box-shadow: var(--evp-shadow-sm);
    scroll-margin-top: 96px;
}

.evp-results-unit__header {
    margin-bottom: 18px;
}

.evp-results-unit__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: clamp(1.7rem, 3vw, 2.4rem);
    line-height: 1.15;
    margin: 0 0 6px;
    font-weight: 600;
    color: var(--evp-text);
}

.evp-results-unit__lead {
    color: var(--evp-text-soft);
    font-size: 1rem;
    margin: 0;
    line-height: 1.55;
}

.evp-results-section {
    margin-top: 22px;
}

.evp-results-section__title {
    font-size: .98rem;
    color: var(--evp-text);
    text-transform: uppercase;
    letter-spacing: .12em;
    border-bottom: 1px solid var(--evp-border);
    padding-bottom: 10px;
    margin: 0 0 14px;
    font-weight: 600;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.evp-results-section__title span { font-weight: 400; color: var(--evp-text-mute); letter-spacing: .04em; text-transform: none; }

.evp-results-table__wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.evp-results-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 640px;
}

.evp-results-table th,
.evp-results-table td {
    padding: 12px 14px;
    text-align: left;
    font-size: .95rem;
    border-bottom: 1px solid var(--evp-border);
}

.evp-results-table th {
    font-size: .78rem;
    color: var(--evp-text-mute);
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 600;
    background: var(--evp-bg-soft);
}

.evp-results-table .is-num {
    width: 56px;
    text-align: center;
    font-variant-numeric: tabular-nums;
}

.evp-results-table tbody tr:hover { background: rgba(0,0,0,.015); }

.evp-results-empty {
    padding: 24px;
    background: var(--evp-bg-soft);
    border-radius: var(--evp-radius-md);
    color: var(--evp-text-soft);
    font-style: italic;
    text-align: center;
}

/* ==========================================================================
   Schedule (Raspored) blok
   ========================================================================== */

.evp-cb-schedule {
    max-width: 1180px;
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-schedule__inner {
    background: #fff;
    border: 1px solid var(--evp-border);
    border-radius: var(--evp-radius-lg);
    padding: clamp(28px, 4vw, 48px);
    box-shadow: var(--evp-shadow-sm);
}

.evp-cb-schedule__header {
    text-align: center;
    margin-bottom: clamp(20px, 3vw, 36px);
}

.evp-cb-schedule__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: var(--evp-fs-h1);
    line-height: var(--evp-lh-tight);
    letter-spacing: var(--evp-ls-tight);
    color: var(--evp-text-strong);
    margin: 0 0 12px;
    font-weight: 700;
}

.evp-cb-schedule__lead {
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-lead);
    line-height: var(--evp-lh-body);
    max-width: 56ch;
    margin: 0 auto;
}

.evp-cb-schedule__days {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 32px);
}

.evp-cb-schedule__empty {
    padding: 24px;
    background: var(--evp-bg-soft);
    border-radius: var(--evp-radius-md);
    color: var(--evp-text-soft);
    font-style: italic;
    text-align: center;
}

/* ---- Day card ---- */

.evp-sched-day {
    border: 1px solid var(--evp-border);
    border-radius: var(--evp-radius-md);
    overflow: hidden;
    background: #fff;
}

.evp-sched-day__label {
    margin: 0;
    padding: 16px 22px;
    background: var(--evp-bg-soft);
    border-bottom: 1px solid var(--evp-border-soft);
    font-family: inherit;
    font-size: var(--evp-fs-small);
    font-weight: 600;
    letter-spacing: var(--evp-ls-wide);
    text-transform: none;
    color: var(--evp-text-strong);
}

.evp-sched-day__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* ---- Item row ---- */

.evp-sched-item {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 18px;
    align-items: start;
    padding: 16px 20px;
    border-bottom: 1px solid var(--evp-border);
    transition: background-color .15s ease;
}
.evp-sched-item:last-child { border-bottom: none; }

.evp-sched-item:hover { background: rgba(0,0,0,.012); }

.evp-sched-item__time {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    font-variant-numeric: tabular-nums;
}

.evp-sched-item__start {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: 1.6rem;
    line-height: 1;
    color: var(--evp-text);
    font-weight: 600;
}

.evp-sched-item__end {
    font-size: .8rem;
    color: var(--evp-text-mute);
    margin-top: 2px;
}

.evp-sched-item__body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.evp-sched-item__title {
    margin: 0;
    font-size: 1.04rem;
    line-height: 1.35;
    color: var(--evp-text);
    font-weight: 600;
    overflow-wrap: anywhere;
}

.evp-sched-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 10px;
    font-size: .88rem;
    color: var(--evp-text-soft);
    align-items: center;
}

.evp-sched-item__location {
    color: var(--evp-text-mute);
}

.evp-sched-item__badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    border-radius: 999px;
    background: var(--evp-bg-soft);
    border: 1px solid var(--evp-border);
    font-size: .75rem;
    color: var(--evp-text);
    letter-spacing: .02em;
}

.evp-sched-item__badge--unit { color: var(--evp-accent); border-color: rgba(185,133,44,.35); }
.evp-sched-item__badge--warn { color: #92590a; background: #fbf2e3; border-color: rgba(185,133,44,.35); }
.evp-sched-item__badge--danger { color: #8b1d24; background: #fbe9eb; border-color: rgba(139,29,36,.25); }
.evp-sched-item__badge--ok { color: #1e6b3a; background: #e7f4ec; border-color: rgba(30,107,58,.25); }

.evp-sched-item__result {
    font-weight: 600;
    color: var(--evp-text);
}

.evp-sched-item__desc {
    margin: 4px 0 0;
    font-size: .9rem;
    line-height: 1.5;
    color: var(--evp-text-soft);
}

/* Cancelled stavka — diskretno crossover */
.evp-sched-item.is-cancelled .evp-sched-item__title,
.evp-sched-item.is-cancelled .evp-sched-item__start {
    text-decoration: line-through;
    color: var(--evp-text-mute);
}

/* ==========================================================================
   Tabela ekipa (Team standings) blok
   ========================================================================== */

.evp-cb-standings {
    max-width: 1100px;
    margin-inline: auto;
    padding: 0 24px;
}

.evp-cb-standings__inner {
    background: #fff;
    border: 1px solid var(--evp-border);
    border-radius: var(--evp-radius-lg);
    padding: clamp(28px, 4vw, 48px);
    box-shadow: var(--evp-shadow-sm);
}

.evp-cb-standings__header {
    text-align: center;
    margin-bottom: clamp(20px, 3vw, 32px);
}

.evp-cb-standings__title {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: var(--evp-fs-h1);
    line-height: var(--evp-lh-tight);
    letter-spacing: var(--evp-ls-tight);
    color: var(--evp-text-strong);
    margin: 0 0 10px;
    font-weight: 700;
}

.evp-cb-standings__lead {
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-lead);
    line-height: var(--evp-lh-body);
    max-width: 56ch;
    margin: 0 auto 6px;
}

.evp-cb-standings__scope {
    display: inline-block;
    margin: 0 auto;
    padding: 4px 14px;
    border-radius: 999px;
    background: var(--evp-bg-soft);
    border: 1px solid var(--evp-border);
    color: var(--evp-text-soft);
    font-size: var(--evp-fs-small);
    letter-spacing: var(--evp-ls-wide);
    text-transform: uppercase;
}

.evp-cb-standings__empty {
    padding: 24px;
    background: var(--evp-bg-soft);
    border-radius: var(--evp-radius-md);
    color: var(--evp-text-soft);
    font-style: italic;
    text-align: center;
}

.evp-standings-table__wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.evp-standings-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 480px;
}

.evp-standings-table thead th {
    font-size: var(--evp-fs-small);
    font-weight: 600;
    letter-spacing: var(--evp-ls-wide);
    text-transform: none;
    color: var(--evp-text-mute);
    padding: 14px 16px;
    border-bottom: 1px solid var(--evp-border);
    background: var(--evp-bg-soft);
    text-align: left;
}
.evp-standings-table th.is-num { text-align: center; }

.evp-standings-table tbody td {
    padding: 16px;
    border-bottom: 1px solid var(--evp-border-soft);
    font-size: var(--evp-fs-body);
    color: var(--evp-text);
    vertical-align: middle;
}
.evp-standings-table tbody tr:last-child td { border-bottom: none; }
.evp-standings-table tbody tr:hover { background: rgba(0,0,0,.018); }

.evp-standings-table .is-num {
    width: 64px;
    text-align: center;
    font-variant-numeric: tabular-nums;
}

.evp-standings-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    padding: 0 8px;
    border-radius: 999px;
    background: var(--evp-bg-soft);
    color: var(--evp-text);
    font-weight: 600;
    font-size: .92rem;
}

.evp-standings-table .is-first .evp-standings-rank {
    background: var(--evp-accent);
    color: #fff;
}

.evp-standings-team {
    font-weight: 600;
}

.evp-standings-points {
    font-family: var(--font-serif, 'Libre Baskerville', Georgia, serif);
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--evp-text);
    text-align: right !important;
}

@media (max-width: 640px) {
    .evp-cb-standings { padding: 0 16px; }
    .evp-cb-standings__inner { padding: 20px 16px; }
    .evp-standings-table { min-width: 360px; }
    .evp-standings-table thead th,
    .evp-standings-table tbody td { padding: 10px; }
    .evp-standings-points { font-size: 1.2rem; }
}

/* ==========================================================================
   Google Maps button — u event-meta pill-u i u event_contact listi
   ========================================================================== */

.evp-event-meta__maps,
.evp-maps-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--evp-text);
    color: #fff !important;
    font-size: .82rem;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid var(--evp-text);
    line-height: 1;
    transition: background-color .15s ease, transform .15s ease;
    white-space: nowrap;
}

.evp-event-meta__maps:hover,
.evp-maps-btn:hover {
    background: var(--evp-accent);
    border-color: var(--evp-accent);
    color: #fff !important;
    transform: translateY(-1px);
}

.evp-event-meta__maps svg,
.evp-maps-btn svg {
    flex-shrink: 0;
}

/* U event-meta pill-u, dodaj malo prostora od lokacije */
.evp-event-meta__maps {
    margin-left: 4px;
}

/* U event_contact listi — manje agresivan stil, da se uklopi sa kontakt linijama */
.evp-maps-btn {
    margin-left: 10px;
    background: transparent;
    color: var(--evp-text) !important;
    border: 1px solid var(--evp-border);
}
.evp-maps-btn:hover {
    background: var(--evp-text);
    color: #fff !important;
    border-color: var(--evp-text);
}

/* ---- Mobile ---- */

@media (max-width: 720px) {
    .evp-cb-schedule {
        padding: 0 16px;
    }
    .evp-cb-schedule__inner {
        padding: 20px 16px;
    }
    .evp-sched-item {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 16px;
    }
    .evp-sched-item__time {
        flex-direction: row;
        align-items: baseline;
        gap: 8px;
    }
    .evp-sched-item__start {
        font-size: 1.35rem;
    }
    .evp-sched-day__label {
        padding: 12px 16px;
        font-size: .76rem;
    }
}

/* ==========================================================================
   Program (globalna /program/ stranica + per-event /program/) — dodaci
   na evp-sched-* osnove. Reuse-ujemo schedule day card.
   ========================================================================== */

.evp-program-list {
    /* Identican layout kao schedule day list, ali sa CTA dugmadima i
       prosirenim meta info-om za globalni prikaz. */
}

/* CTA dugme "Pogledaj dogadjaj" na globalnom programu */
.evp-sched-item__actions {
    margin-top: 12px;
}

.evp-sched-item__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 999px;
    background: #14161a;
    color: #fff !important;
    font-size: .86rem;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid #14161a;
    transition: background-color .15s ease, transform .15s ease;
    white-space: nowrap;
}

.evp-sched-item__cta:hover {
    background: var(--evp-accent);
    border-color: var(--evp-accent);
    color: #fff !important;
    transform: translateY(-1px);
}

.evp-sched-item__event {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    flex-wrap: wrap;
}
.evp-sched-item__event-label {
    color: var(--evp-text-mute);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}

/* Switch dugmad iznad liste (Cijeli program / Danas) */
.evp-program-switch {
    display: inline-flex;
    gap: 6px;
    margin-top: 18px;
    padding: 4px;
    background: var(--evp-bg-soft);
    border: 1px solid var(--evp-border);
    border-radius: 999px;
}

.evp-program-switch__btn {
    display: inline-flex;
    align-items: center;
    padding: 8px 18px;
    border-radius: 999px;
    color: var(--evp-text);
    font-size: .9rem;
    font-weight: 500;
    text-decoration: none;
    transition: background-color .15s ease, color .15s ease;
}
.evp-program-switch__btn:hover { color: var(--evp-text); background: #fff; }
.evp-program-switch__btn.is-active {
    background: #14161a;
    color: #fff !important;
}

/* Mobile: smanjeniji evp-sched-item time, da CTA stane lijepo */
@media (max-width: 720px) {
    .evp-sched-item__cta { padding: 8px 14px; font-size: .82rem; }
    .evp-sched-item__event-label { font-size: .72rem; }
}

/* ==========================================================================
   Image fit-mode (cover / contain / auto + blurred background)

   Dizajn pristup:
   - Wrapper (npr. .evp-cb-textimg__image, .evp-cb-image__frame,
     .evp-cb-discipline__media) zadrzava SVOJU velicinu, border-radius,
     shadow i aspect-ratio. NE mijenjamo ga.
   - Unutar wrapper-a dodaju se DVIJE <img> oznake:
       .evp-img-blur-bg — duplikat slike, cover + blur + scale + opacity.
                          Sluzi kao popunjavac okvira za portret slike.
       .evp-img-main    — glavna slika koja se zaista vidi.
   - Mode klasa na wrapper-u kontrolise sta se zaista renderuje:
       .is-fit-cover     → main: cover, blur-bg: skriven
       .is-fit-contain   → main: contain, blur-bg: vidljiv
       .is-fit-auto      → default cover; JS dodaje .is-portrait kada
                            naturalHeight > naturalWidth, sto onda ponasa
                            wrapper kao contain.
   ========================================================================== */

.evp-img-wrap {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

/* Blur-bg sloj — uvijek u DOM, prikaz kontrolisan modom. */
.evp-img-wrap > .evp-img-blur-bg {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    filter: blur(28px);
    transform: scale(1.15);
    opacity: .28;
    pointer-events: none;
    z-index: 0;
    display: none;
}

/* Main image sloj — defaultno cover, ide preko blur-bg.
   Apsolutno pozicioniran tako da popunjava ENTIRE wrapper bez obzira da li
   wrapper definise visinu kroz aspect-ratio (textimg/discipline) ili kroz
   eksplicitnu height (image block sa 100vh). */
.evp-img-wrap > .evp-img-main {
    position: absolute;
    inset: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* ----- Mode: COVER (eksplicitno) ----- */
.evp-img-wrap.is-fit-cover > .evp-img-main { object-fit: cover; }
.evp-img-wrap.is-fit-cover > .evp-img-blur-bg { display: none; }

/* ----- Mode: CONTAIN (eksplicitno) ----- */
.evp-img-wrap.is-fit-contain > .evp-img-main { object-fit: contain; }
.evp-img-wrap.is-fit-contain > .evp-img-blur-bg { display: block; }

/* ----- Mode: AUTO (default = cover; JS dodaje .is-portrait) ----- */
.evp-img-wrap.is-fit-auto > .evp-img-main { object-fit: cover; }
.evp-img-wrap.is-fit-auto > .evp-img-blur-bg { display: none; }
.evp-img-wrap.is-fit-auto.is-portrait > .evp-img-main { object-fit: contain; }
.evp-img-wrap.is-fit-auto.is-portrait > .evp-img-blur-bg { display: block; }

/* ---- Per-block override: reveal scale na discipline image ----
   Original `.evp-cb-discipline.is-visible .evp-cb-discipline__media img`
   bi zahvatio I blur-bg I main, sto bi pobijedilo nase transform: scale(1.15)
   na blur-bg-u. Preusmjeravamo na .evp-img-main da blur-bg zadrzi svoj scale. */
.evp-cb-discipline.reveal-on-scroll.is-visible .evp-cb-discipline__media .evp-img-main {
    transform: scale(1.02);
}

/* Image block: parallax-image vec ima .parallax-image klasu na main only
   (template ga dodjeljuje), pa JS targetuje samo main. Blur-bg ostaje
   staticki sa svojim scale(1.15) blur transformom. */

/* ==========================================================================
   Share dugmad + Add to calendar (centralizovan SEO/marketing layer)
   ========================================================================== */

.evp-share {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 16px 0;
}
.evp-share__label {
    color: var(--evp-text-mute);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-right: 4px;
}
.evp-share__btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 50%;
    background: var(--evp-bg-soft);
    color: var(--evp-text);
    border: 1px solid var(--evp-border);
    text-decoration: none;
    cursor: pointer;
    transition: background-color .15s ease, transform .15s ease, color .15s ease, border-color .15s ease;
}
.evp-share__btn svg { display: block; }
.evp-share__btn:hover {
    transform: translateY(-1px);
}
/* Brand boje na hover */
.evp-share__btn--fb:hover {
    background: #1877F2;
    color: #fff;
    border-color: #1877F2;
}
.evp-share__btn--wa:hover {
    background: #25D366;
    color: #fff;
    border-color: #25D366;
}
.evp-share__btn--viber:hover {
    background: #7360F2;
    color: #fff;
    border-color: #7360F2;
}
.evp-share__btn--copy {
    font-family: inherit;
    background: var(--evp-bg-soft);
}
.evp-share__btn--copy:hover {
    background: var(--evp-text);
    color: #fff;
    border-color: var(--evp-text);
}
.evp-share__btn--copy.is-copied,
.evp-share__copied-flash:not(:empty) {
    background: #14a76c;
    color: #fff;
    border-color: #14a76c;
}
.evp-share__copied-flash {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: inherit;
    color: inherit;
    border-radius: inherit;
    font-weight: 700;
    pointer-events: none;
}
.evp-share__copied-flash:empty { display: none; }

.evp-cal-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    background: #fff;
    color: var(--evp-text);
    border: 1px solid var(--evp-border);
    text-decoration: none;
    font-size: .92rem;
    font-weight: 500;
    transition: background-color .15s ease, color .15s ease, transform .15s ease;
}
.evp-cal-btn:hover {
    background: var(--evp-accent);
    color: #fff !important;
    border-color: var(--evp-accent);
    transform: translateY(-1px);
}

/* ==========================================================================
   Language switcher (SR / EN)
   ========================================================================== */
.lang-switcher {
    display: inline-flex;
    gap: 0;
    padding: 1px;
    background: var(--evp-bg-soft);
    border: 1px solid var(--evp-border);
    border-radius: 999px;
    margin-left: 2px;
    line-height: 1;
}
.lang-switcher__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    padding: 1px 3px;
    border-radius: 999px;
    color: var(--evp-text-soft);
    font-size: .38rem;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 1;
    text-decoration: none;
    transition: background-color .15s ease, color .15s ease;
}
.lang-switcher__btn:hover { color: var(--evp-text); background: #fff; }
.lang-switcher__btn.is-active {
    background: #14161a;
    color: #fff !important;
}
.nav-lang { display: inline-flex; align-items: center; }
@media (max-width: 860px) {
    .nav-lang { margin: 12px 0 4px 0; }
}

/* ==========================================================================
   Editorial text — premium izgled za tekstualne blokove bez slike
   - evp-about              (event detail "O događaju" sekcija)
   - evp-cb-textimg--text-only  (text_image blok bez slike)
   - evp-cb-text--editorial (samo tekst blok — fina nadgradnja)
   Bez agresivnih animacija, bez tamnih blokova, bez kica.
   ========================================================================== */

/* ---------- 1. ABOUT — premium editorial wrapper ---------- */

.evp-about {
    /* Override-uje postojeci flat layout sa premium card prezentacijom.
       Postojece evp-about__label / __title / __divider / __body ostaju
       netaknute u svojim pravilima — samo dobijaju lepsi container. */
    padding: clamp(54px, 8vw, 96px) clamp(28px, 5vw, 64px);
    max-width: 1060px;
    border-radius: var(--evp-radius-xl);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.97), rgba(250,246,241,0.92));
    border: 1px solid rgba(213, 180, 150, 0.25);
    box-shadow: 0 22px 60px rgba(15, 17, 22, 0.055);
    overflow: hidden;
}

/* Diskretni glow u gornjem desnom uglu */
.evp-about::before {
    content: "";
    position: absolute;
    top: -90px;
    right: -90px;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: rgba(213, 180, 150, 0.16);
    filter: blur(6px);
    pointer-events: none;
    z-index: 0;
}

/* Suptilne diagonalne linije preko cele sekcije */
.evp-about::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(135deg, rgba(120, 95, 70, 0.045) 1px, transparent 1px);
    background-size: 28px 28px;
    opacity: 0.5;
    pointer-events: none;
    z-index: 0;
}

/* Sav sadrzaj iznad pseudo elemenata */
.evp-about > * {
    position: relative;
    z-index: 1;
}

/* Mobile dorade */
@media (max-width: 640px) {
    .evp-about {
        margin-inline: 16px;
        padding: clamp(40px, 9vw, 56px) clamp(20px, 6vw, 32px);
        border-radius: var(--evp-radius-lg);
    }
    .evp-about::before {
        width: 160px;
        height: 160px;
        top: -60px;
        right: -60px;
    }
    .evp-about::after { background-size: 22px 22px; opacity: 0.4; }
}

/* ---------- 2. TEXT-ONLY blok unutar text_image (kad nema slike) ---------- */

.evp-cb-textimg--text-only {
    position: relative;
    display: block;             /* skida 2-kolonski grid layout */
    max-width: 980px;
    margin-inline: auto;
    padding: clamp(40px, 6vw, 72px) clamp(28px, 5vw, 64px);
    border-radius: var(--evp-radius-xl);
    background:
        radial-gradient(circle at top right, rgba(213, 180, 150, 0.14), transparent 38%),
        linear-gradient(135deg, rgba(255,255,255,0.98), rgba(250,246,241,0.92));
    border: 1px solid rgba(213, 180, 150, 0.28);
    box-shadow: 0 22px 60px rgba(15, 17, 22, 0.06);
    overflow: hidden;
}

/* Diskretne diagonalne linije u pozadini */
.evp-cb-textimg--text-only::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(135deg, rgba(120, 95, 70, 0.05) 1px, transparent 1px);
    background-size: 26px 26px;
    opacity: 0.42;
    pointer-events: none;
}

/* Tanka zlatna linija sa leve strane (samo na desktopu) */
.evp-cb-textimg--text-only::after {
    content: "";
    position: absolute;
    left: 0; top: 18%; bottom: 18%;
    width: 2px;
    background: linear-gradient(180deg, transparent, rgba(213, 180, 150, 0.5), transparent);
    pointer-events: none;
}

.evp-cb-textimg--text-only > * {
    position: relative;
    z-index: 1;
}

/* Skida is-reverse efekat (jedna kolona, nemamo sta da reversujemo) */
.evp-cb-textimg--text-only.is-reverse > :first-child { order: 0; }

/* Naslov u text-only kartici — finiji ritam */
.evp-cb-textimg--text-only .evp-cb-text__title {
    margin: 0 0 20px;
    line-height: 1.12;
}

/* Mali zlatni divider ispod naslova */
.evp-cb-textimg--text-only .evp-cb-text__title::after {
    content: "";
    display: block;
    width: 64px;
    height: 1.5px;
    margin-top: 20px;
    background: linear-gradient(90deg, rgba(213, 180, 150, 0.85), transparent);
}

/* Body — bolja sirina reda + line-height */
.evp-cb-textimg--text-only .evp-cb-text__body {
    max-width: 780px;
    line-height: 1.85;
}

/* Mobile dorade */
@media (max-width: 640px) {
    .evp-cb-textimg--text-only {
        margin-inline: 16px;
        padding: clamp(32px, 8vw, 48px) clamp(22px, 6vw, 32px);
        border-radius: var(--evp-radius-lg);
    }
    .evp-cb-textimg--text-only::before {
        background-size: 22px 22px;
        opacity: 0.35;
    }
    .evp-cb-textimg--text-only::after { display: none; }
    .evp-cb-textimg--text-only .evp-cb-text__title::after {
        width: 48px; margin-top: 14px;
    }
}

/* ---------- 3. TEXT blok (samo tekst, bez slike) — fina nadgradnja ---------- */
/* Postojeci .evp-cb-text vec ima dobar reading width.
   Modifier .evp-cb-text--editorial dodaje suptilan ornament za "premium feel"
   bez mijenjanja layout-a. */

.evp-cb-text--editorial {
    position: relative;
    padding-top: 8px;
}

/* Tanak zlatni ornament iznad teksta (ne preko bloka, ne kartica) */
.evp-cb-text--editorial::before {
    content: "";
    display: block;
    width: 42px;
    height: 1px;
    background: linear-gradient(90deg, rgba(213, 180, 150, 0.85), rgba(213, 180, 150, 0.1));
    margin: 0 auto 22px;
    opacity: 0.9;
}

/* Naslov dobija fini divider tek u editorial varijanti */
.evp-cb-text--editorial .evp-cb-text__title {
    text-align: center;
}

.evp-cb-text--editorial .evp-cb-text__title::after {
    content: "";
    display: block;
    width: 52px;
    height: 1.5px;
    margin: 18px auto 0;
    background: linear-gradient(90deg, transparent, rgba(213, 180, 150, 0.7), transparent);
}

/* Body ostaje levo poravnat za citljivost */
.evp-cb-text--editorial .evp-cb-text__body {
    margin-top: 30px;
    line-height: 1.85;
}

@media (max-width: 640px) {
    .evp-cb-text--editorial::before { margin-bottom: 16px; }
    .evp-cb-text--editorial .evp-cb-text__title::after { margin-top: 14px; width: 42px; }
    .evp-cb-text--editorial .evp-cb-text__body { margin-top: 22px; }
}
