/* =========================================================
   CLICX MEDIA — components.css
   Kartice, buttoni, forme, sekcije
   ========================================================= */

/* ---------- PIXEL DEKORACIJA (suptilan brand detalj) ---------- */
.pixel-cluster {
    position: absolute;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, 8px);
    grid-template-rows: repeat(3, 8px);
    gap: 4px;
    pointer-events: none;
    opacity: 0.5;
}
.pixel-cluster span {
    width: 8px;
    height: 8px;
    border-radius: 2px;
    background: var(--accent-primary);
    animation: pixel-float 6s ease-in-out infinite;
}
.pixel-cluster span:nth-child(2),
.pixel-cluster span:nth-child(4),
.pixel-cluster span:nth-child(8) { background: var(--accent-secondary); }

.pixel-cluster span:nth-child(2n) { animation-delay: -2s; animation-duration: 7s; }
.pixel-cluster span:nth-child(3n) { animation-delay: -4s; animation-duration: 5s; }
.pixel-cluster span:nth-child(3n+1) { animation-delay: -1s; animation-duration: 6.5s; }

@keyframes pixel-float {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(3px, -3px); }
}

/* =========================================================
   HERO — pola tekst / pola slika sa maskom (Home)
   ========================================================= */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    background: var(--surface-dark);
    overflow: hidden;
}

.hero-media {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 56%;
    background: linear-gradient(135deg, var(--accent-secondary), var(--accent-primary));
    overflow: hidden;
}

.hero-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    mix-blend-mode: luminosity;
    opacity: 0.55;
}

/* Maska — lijevo se gasi prema tamnoj pozadini da tekst ostane čitljiv */
.hero-media::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(100deg, var(--surface-dark) 12%, rgba(11,15,20,0.55) 38%, rgba(11,15,20,0) 75%);
    z-index: 2;
}

.hero-content {
    position: relative;
    z-index: 3;
    width: 100%;
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 2rem;
}

.hero-content-inner {
    max-width: 560px;
    padding-top: var(--header-height);
}

.hero h1 { color: #ffffff; margin-bottom: 1.25rem; }

.hero .lead {
    color: var(--text-on-dark-secondary);
    max-width: 440px;
    margin-bottom: 2.5rem;
}

.hero-cta {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.hero-cta .btn-outline {
    color: #ffffff;
    border-color: rgba(255,255,255,0.25);
}
.hero-cta .btn-outline:hover { border-color: var(--accent-primary); color: var(--accent-primary); }

/* Hero scroll indikator */
.hero-scroll {
    position: absolute;
    left: 2rem;
    bottom: 2.5rem;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.8rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-on-dark-secondary);
}
.hero-scroll .line {
    width: 1px;
    height: 40px;
    background: rgba(255,255,255,0.25);
    position: relative;
    overflow: hidden;
}
.hero-scroll .line::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 40%;
    background: var(--accent-primary);
    animation: scroll-line 2.4s ease-in-out infinite;
}
@keyframes scroll-line {
    0% { transform: translateY(-100%); }
    100% { transform: translateY(250%); }
}

/* =========================================================
   HERO SLIDER (više slajdova — koristi se na podstranicama)
   ========================================================= */
.hero-slider {
    position: relative;
    min-height: 88vh;
    display: flex;
    align-items: center;
    background: var(--surface-dark);
    overflow: hidden;
}

.hero-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 1s ease;
}

.hero-slide.is-active { opacity: 1; visibility: visible; }

.hero-slide .hero-media { width: 56%; }

.hero-slider .hero-content { position: relative; z-index: 3; }

.slider-dots {
    position: absolute;
    right: 2rem;
    bottom: 2.5rem;
    z-index: 4;
    display: flex;
    gap: 0.6rem;
}

.slider-dots button {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.5px solid rgba(255,255,255,0.4);
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.slider-dots button.is-active {
    background: var(--accent-primary);
    border-color: var(--accent-primary);
}

/* =========================================================
   GENERIC PAGE HERO (manje stranice — H1 + intro)
   ========================================================= */
.page-hero {
    padding: calc(var(--header-height) + 4.5rem) 0 4rem;
    background: var(--bg-secondary);
    position: relative;
    overflow: hidden;
}

/* Tamna traka iza headera — osigurava kontrast bijelog teksta u navigaciji */
.page-hero::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: var(--header-height);
    background: linear-gradient(180deg, var(--surface-dark) 0%, rgba(11,15,20,0) 100%);
    z-index: 1;
    pointer-events: none;
}

.page-hero .container { position: relative; z-index: 2; }

.breadcrumbs {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--text-tertiary);
    margin-bottom: 1.25rem;
}
.breadcrumbs a:hover { color: var(--accent-primary); }
.breadcrumbs svg { width: 14px; height: 14px; transform: rotate(-90deg); }

.page-hero h1 { max-width: 760px; }
.page-hero .lead { max-width: 640px; margin-top: 1rem; }

.page-hero .pixel-cluster { top: 2.5rem; right: 6%; }

/* =========================================================
   ÜBER UNS TEASER (Home, sekcija 2)
   ========================================================= */
.about-teaser {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 4rem;
    align-items: center;
}

.about-teaser-visual {
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--bg-tertiary);
}
.about-teaser-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.about-teaser-visual:hover img { transform: scale(1.04); }
.about-teaser-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,0.2) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 0.9s ease;
    pointer-events: none;
    z-index: 1;
}
.about-teaser-visual:hover::after { transform: translateX(120%); }

.about-stat-card {
    position: absolute;
    bottom: 1.5rem;
    left: 1.5rem;
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding: 1.25rem 1.6rem;
}
.about-stat-card .num {
    font-family: var(--font-heading);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--accent-primary);
    line-height: 1;
}
.about-stat-card .label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-top: 0.35rem;
}

.about-teaser-content ul.checklist {
    margin: 1.75rem 0 2.25rem;
    display: grid;
    gap: 0.85rem;
}
.checklist li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    color: var(--text-secondary);
}
.checklist svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: var(--accent-primary);
    margin-top: 2px;
}

/* =========================================================
   SERVICE BOXES — Leistungen pregled (Home / Leistungen page)
   =========================================================  */
.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}

.service-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 2.25rem 1.75rem;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-card);
    border-color: transparent;
}

.service-card .icon-box {
    width: 54px;
    height: 54px;
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    transition: background var(--transition);
}
.service-card .icon-box svg {
    width: 26px;
    height: 26px;
    color: var(--accent-primary);
}
.service-card:hover .icon-box { background: var(--accent-primary); }
.service-card:hover .icon-box svg { color: #ffffff; }

.service-card h3 { margin-bottom: 0.6rem; }
.service-card p { font-size: 0.92rem; margin-bottom: 1.5rem; }

/* =========================================================
   FULL-SERVICE TEASER (Home)
   ========================================================= */
.fullservice-teaser {
    background: var(--surface-dark);
    border-radius: var(--radius-lg);
    padding: 4.5rem;
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    align-items: center;
    gap: 3rem;
    position: relative;
    overflow: hidden;
}

.fullservice-teaser h2,
.fullservice-teaser p { color: #ffffff; }
.fullservice-teaser p { color: var(--text-on-dark-secondary); margin: 1.25rem 0 2rem; max-width: 480px; }

.fullservice-list {
    display: grid;
    gap: 1rem;
}
.fullservice-list .item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.25rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-md);
    color: #ffffff;
    font-size: 0.92rem;
    font-weight: 500;
}
.fullservice-list .item svg { width: 20px; height: 20px; color: var(--accent-primary); flex-shrink: 0; }

/* =========================================================
   WARUM WIR — razlozi (Home teaser + page)
   ========================================================= */
.reasons-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.reason-item {
    padding: 2rem;
    border-radius: var(--radius-lg);
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
}

.reason-item .num {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--accent-primary);
    letter-spacing: 0.1em;
    margin-bottom: 1rem;
    display: block;
}

.reason-item h3 { margin-bottom: 0.6rem; }
.reason-item p { font-size: 0.92rem; }

/* =========================================================
   KONTAKT TEASER / CTA SEKCIJA (S13)
   ========================================================= */
.cta-section {
    background: linear-gradient(120deg, var(--accent-secondary), var(--accent-primary));
    border-radius: var(--radius-lg);
    padding: 4rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.cta-section h2, .cta-section p { color: #ffffff; }
.cta-section .lead { color: rgba(255,255,255,0.85); max-width: 560px; margin: 1rem auto 2.25rem; }

.cta-section .btn-primary {
    background: #ffffff;
    color: var(--accent-secondary);
    box-shadow: none;
}
.cta-section .btn-primary:hover { background: var(--surface-dark); color: #ffffff; }

.cta-section .btn-outline {
    color: #ffffff;
    border-color: rgba(255,255,255,0.4);
}
.cta-section .btn-outline:hover { border-color: #ffffff; }

.cta-actions {
    display: flex;
    gap: 1.25rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* "diskretni blok" — kombinacija s Full-Service */
.note-block {
    margin-top: 3rem;
    padding: 1.25rem 1.5rem;
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    border: 1px dashed var(--border-color-strong);
    font-size: 0.9rem;
    color: var(--text-secondary);
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
}
.note-block svg { width: 20px; height: 20px; color: var(--accent-primary); flex-shrink: 0; margin-top: 2px; }

/* =========================================================
   CONTENT SEKCIJE — generičke (Über uns, Leistungen detalji...)
   ========================================================= */
.content-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4rem;
    align-items: center;
}

.content-grid.reverse .content-visual { order: 2; }

.content-visual {
    position: relative;
    aspect-ratio: 5 / 4;
    border-radius: var(--radius-lg);
    background: var(--bg-tertiary);
    overflow: hidden;
}
.content-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.content-visual:hover img { transform: scale(1.04); }
.content-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,0.2) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 0.9s ease;
    pointer-events: none;
}
.content-visual:hover::after { transform: translateX(120%); }

.feature-list {
    display: grid;
    gap: 1.5rem;
    margin-top: 2rem;
}
.feature-list .feature {
    display: flex;
    gap: 1.25rem;
}
.feature-list .icon-box {
    width: 46px;
    height: 46px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
}
.feature-list .icon-box svg { width: 22px; height: 22px; color: var(--accent-primary); }
.feature-list h4 { margin-bottom: 0.35rem; }
.feature-list p { font-size: 0.92rem; }

/* Sekcije usluga (S4 strip — slika + tekst, horizontalno) */
.service-strip {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 3rem;
    align-items: center;
    padding: 3.5rem 0;
    border-bottom: 1px solid var(--border-color);
}
.service-strip:last-child { border-bottom: none; }
.service-strip.reverse { grid-template-columns: 1.2fr 1fr; }
.service-strip.reverse .service-strip-visual { order: 2; }

.service-strip-visual {
    aspect-ratio: 16 / 10;
    border-radius: var(--radius-lg);
    background: var(--bg-tertiary);
    overflow: hidden;
}
.service-strip-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.service-strip-visual:hover img { transform: scale(1.04); }
.service-strip-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,0.2) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 0.9s ease;
    pointer-events: none;
}
.service-strip-visual:hover::after { transform: translateX(120%); }

.service-strip-number {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--accent-primary);
    letter-spacing: 0.1em;
    margin-bottom: 0.75rem;
    display: inline-block;
}

/* =========================================================
   STATS — animirane cifre (S12)
   ========================================================= */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    text-align: center;
}
.stat-item {
    padding: 2.5rem 1.5rem;
    border-radius: var(--radius-lg);
    background: var(--bg-secondary);
}
.stat-item .num {
    font-family: var(--font-heading);
    font-size: 2.6rem;
    font-weight: 700;
    color: var(--accent-primary);
    line-height: 1;
}
.stat-item .label {
    margin-top: 0.6rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

/* =========================================================
   TESTIMONIALS (S11)
   ========================================================= */
.testimonial-slider {
    position: relative;
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.testimonial-slide {
    display: none;
}
.testimonial-slide.is-active { display: block; }

.testimonial-slide blockquote {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.5;
    color: var(--text-primary);
    margin-bottom: 1.75rem;
}
.testimonial-author {
    font-weight: 600;
    font-size: 0.95rem;
}
.testimonial-role {
    font-size: 0.85rem;
    color: var(--text-tertiary);
}

.testimonial-nav {
    display: flex;
    justify-content: center;
    gap: 0.6rem;
    margin-top: 2.5rem;
}
.testimonial-nav button {
    width: 10px; height: 10px; border-radius: 50%;
    border: 1.5px solid var(--border-color-strong);
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.testimonial-nav button.is-active {
    background: var(--accent-primary);
    border-color: var(--accent-primary);
}

/* =========================================================
   FAQ — accordion
   ========================================================= */
.accordion {
    max-width: 760px;
    margin: 0 auto;
    display: grid;
    gap: 1rem;
}
.accordion-item {
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.accordion-trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.4rem 1.6rem;
    text-align: left;
    font-family: var(--font-heading);
    font-weight: 500;
    font-size: 1.02rem;
}
.accordion-trigger svg {
    width: 20px; height: 20px;
    flex-shrink: 0;
    color: var(--accent-primary);
    transition: transform var(--transition-fast);
}
.accordion-item.is-open .accordion-trigger svg { transform: rotate(45deg); }

.accordion-panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition);
}
.accordion-panel-inner {
    padding: 0 1.6rem 1.5rem;
    font-size: 0.95rem;
    color: var(--text-secondary);
}

/* =========================================================
   TICKER traka
   ========================================================= */
.ticker {
    overflow: hidden;
    background: var(--surface-dark);
    padding: 1.4rem 0;
    white-space: nowrap;
}
.ticker-track {
    display: inline-flex;
    align-items: center;
    gap: 3rem;
    animation: ticker-scroll 32s linear infinite;
    will-change: transform;
}
.ticker-track span {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: var(--text-on-dark-secondary);
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}
.ticker-track span.is-accent { color: var(--accent-primary); }
.ticker-track span::after {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent-primary);
    display: inline-block;
    margin-left: 2.5rem;
}
@keyframes ticker-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* =========================================================
   GALERIJA s filterom (S14)
   ========================================================= */
.filter-bar {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 2.5rem;
}
.filter-btn {
    padding: 0.6rem 1.4rem;
    border-radius: var(--radius-pill);
    border: 1px solid var(--border-color);
    font-size: 0.88rem;
    font-weight: 500;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.filter-btn.is-active,
.filter-btn:hover {
    background: var(--accent-primary);
    color: #ffffff;
    border-color: var(--accent-primary);
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.gallery-item {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--bg-tertiary);
    transition: opacity var(--transition), transform var(--transition);
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item.is-hidden { display: none; }

/* Light sweep — dijagonalni prelazak svjetla na hover */
.gallery-item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,0.35) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 0.8s ease;
    pointer-events: none;
}
.gallery-item:hover::after {
    transform: translateX(120%);
}

.gallery-item .gallery-tag {
    position: absolute;
    bottom: 1rem; left: 1rem;
    background: rgba(11,15,20,0.55);
    color: #ffffff;
    font-size: 0.75rem;
    padding: 0.35rem 0.85rem;
    border-radius: var(--radius-pill);
    backdrop-filter: blur(4px);
}

/* =========================================================
   VIDEO LIGHTBOX (S5)
   ========================================================= */
.video-card {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--surface-dark);
    cursor: pointer;
}
.video-card img { width: 100%; height: 100%; object-fit: cover; opacity: 0.75; }
.video-play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.video-play span {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--accent-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform var(--transition-fast);
}
.video-play svg { width: 26px; height: 26px; color: #ffffff; }
.video-card:hover .video-play span { transform: scale(1.1); }

.lightbox {
    position: fixed;
    inset: 0;
    z-index: var(--z-loader);
    background: rgba(11,15,20,0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition);
    padding: 2rem;
}
.lightbox.is-active { opacity: 1; visibility: visible; }
.lightbox-inner {
    width: 100%;
    max-width: 960px;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: var(--radius-md);
    overflow: hidden;
}
.lightbox-inner iframe,
.lightbox-inner video { width: 100%; height: 100%; }
.lightbox-close {
    position: absolute;
    top: 2rem; right: 2rem;
    width: 44px; height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.2);
    display: flex; align-items: center; justify-content: center;
    color: #ffffff;
}
.lightbox-close svg { width: 18px; height: 18px; }

/* =========================================================
   TIMELINE / proces rada (S15)
   ========================================================= */
.timeline {
    position: relative;
    max-width: 760px;
    margin: 0 auto;
}
.timeline::before {
    content: '';
    position: absolute;
    left: 23px;
    top: 8px; bottom: 8px;
    width: 2px;
    background: var(--border-color);
}
.timeline-item {
    position: relative;
    padding-left: 5rem;
    padding-bottom: 3rem;
}
.timeline-item:last-child { padding-bottom: 0; }
.timeline-marker {
    position: absolute;
    left: 0; top: 0;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--accent-primary);
}
.timeline-item h3 { margin-bottom: 0.4rem; }
.timeline-item p { font-size: 0.92rem; }

/* =========================================================
   PRICING — Paketi
   ========================================================= */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
    align-items: stretch;
}
.pricing-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
}
.pricing-card.is-featured {
    background: var(--surface-dark);
    border-color: var(--surface-dark);
    transform: scale(1.02);
}
.pricing-card.is-featured * { color: #ffffff; }
.pricing-card.is-featured p { color: var(--text-on-dark-secondary); }
.pricing-card.is-featured .checklist svg,
.pricing-card.is-featured .price-tag .accent { color: var(--accent-primary); }

.pricing-badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-primary);
    background: var(--accent-glow);
    padding: 0.35rem 0.9rem;
    border-radius: var(--radius-pill);
    margin-bottom: 1.25rem;
    align-self: flex-start;
}
.pricing-card.is-featured .pricing-badge { background: rgba(50,150,200,0.18); }

.price-tag {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 2.6rem;
    margin: 0.5rem 0 0.25rem;
}
.price-tag span {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-secondary);
}
.pricing-card .checklist { margin: 2rem 0; flex-grow: 1; }
.pricing-card .checklist li { font-size: 0.9rem; }

/* =========================================================
   KONTAKT FORMA
   ========================================================= */
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 4rem;
}
.contact-info-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1.75rem;
}
.contact-info-item .icon-box {
    width: 46px; height: 46px; flex-shrink: 0;
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    display: flex; align-items: center; justify-content: center;
}
.contact-info-item .icon-box svg { width: 20px; height: 20px; color: var(--accent-primary); }
.contact-info-item h4 { margin-bottom: 0.25rem; }
.contact-info-item p { font-size: 0.92rem; margin: 0; }

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
}
.form-grid .full { grid-column: 1 / -1; }
.form-field { display: flex; flex-direction: column; gap: 0.5rem; }
.form-field label { font-size: 0.85rem; font-weight: 500; color: var(--text-secondary); }
.form-field input,
.form-field select,
.form-field textarea {
    padding: 0.9rem 1.1rem;
    border: 1px solid var(--border-color-strong);
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    transition: border-color var(--transition-fast);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
    outline: none;
    border-color: var(--accent-primary);
}
.form-field textarea { resize: vertical; min-height: 140px; }

/* =========================================================
   CHATBOT ZONA
   ========================================================= */
.chatbot-zone {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: var(--z-chatbot);
}

/* =========================================================
   BACK TO TOP
   ========================================================= */
#back-to-top {
    position: fixed;
    right: 28px;
    bottom: 60px;
    z-index: var(--z-back-to-top);
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: var(--bg-primary);
    border: 1px solid var(--border-color-strong);
    box-shadow: var(--shadow-card);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    transition: opacity var(--transition), transform var(--transition), visibility var(--transition), border-color var(--transition-fast);
}
#back-to-top.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
#back-to-top svg {
    width: 18px;
    height: 18px;
    color: var(--accent-primary);
    transform: rotate(-90deg);
}
#back-to-top:hover {
    border-color: var(--accent-primary);
    transform: translateY(-3px);
}
@media (max-width: 580px) {
    #back-to-top { right: 18px; bottom: 90px; width: 42px; height: 42px; }
}

/* =========================================================
   SCROLL REVEAL — animations.js
   ========================================================= */
/* =========================================================
   SCROLL REVEAL — animations.js
   Blagi motion: fade + slide up, cubic-bezier za prirodan osjecaj
   ========================================================= */
[data-aos] {
    opacity: 0;
    transform: translateY(44px);
    transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}
[data-aos].is-visible {
    opacity: 1;
    transform: translateY(0);
}

[data-aos="fade-right"] {
    transform: translateX(-36px);
    opacity: 0;
}
[data-aos="fade-right"].is-visible {
    transform: translateX(0);
    opacity: 1;
}

[data-aos="fade-left"] {
    transform: translateX(36px);
    opacity: 0;
}
[data-aos="fade-left"].is-visible {
    transform: translateX(0);
    opacity: 1;
}

[data-aos="zoom-in"] {
    transform: scale(0.92);
    opacity: 0;
}
[data-aos="zoom-in"].is-visible {
    transform: scale(1);
    opacity: 1;
}

/* Delay podrška — dodaj data-aos-delay="100" na element */
[data-aos-delay="100"] { transition-delay: 0.1s; }
[data-aos-delay="200"] { transition-delay: 0.2s; }
[data-aos-delay="300"] { transition-delay: 0.3s; }
[data-aos-delay="400"] { transition-delay: 0.4s; }

@media (prefers-reduced-motion: reduce) {
    [data-aos] {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

/* =========================================================
   RESPONSIVE — komponente (breakpointi: 1100 / 900 / 640 / 580)
   ========================================================= */
@media (max-width: 1100px) {
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .reasons-grid { grid-template-columns: repeat(2, 1fr); }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .pricing-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
    .pricing-card.is-featured { transform: none; }
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
    .about-teaser { grid-template-columns: 1fr; gap: 3rem; }
    .about-teaser-visual { max-width: 460px; }
    .content-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .content-grid.reverse .content-visual { order: 0; }
    .content-visual { max-width: 520px; aspect-ratio: 16/10; }
    .fullservice-teaser { grid-template-columns: 1fr; padding: 3rem; gap: 2.5rem; }
    .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
}

@media (max-width: 900px) {
    .hero-media, .hero-slide .hero-media { width: 100%; opacity: 0.35; }
    .hero-media::before { background: linear-gradient(180deg, var(--surface-dark) 30%, rgba(11,15,20,0.4) 100%); }
    .hero-content-inner { max-width: 100%; }

    .service-strip, .service-strip.reverse {
        grid-template-columns: 1fr;
        gap: 1.75rem;
    }
    .service-strip.reverse .service-strip-visual { order: 0; }
    .service-strip-visual { max-width: 100%; }

    .form-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
    .services-grid,
    .reasons-grid,
    .stats-grid,
    .gallery-grid { grid-template-columns: 1fr; }

    .cta-section, .fullservice-teaser { padding: 2.5rem 1.75rem; }

    .testimonial-slide blockquote { font-size: 1.15rem; }
}

/* =========================================================
   GALLERY IMAGE LIGHTBOX (#gallery-lightbox)
   ========================================================= */
#gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-loader) + 10);
    background: rgba(11,15,20,0.94);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    padding: 2rem;
}

#gallery-lightbox.is-active {
    opacity: 1;
    visibility: visible;
}

.glb-img-wrap {
    max-width: min(90vw, 1100px);
    max-height: 88vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glb-img {
    max-width: 100%;
    max-height: 88vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    display: block;
    transition: opacity 0.2s ease;
}

.glb-close,
.glb-prev,
.glb-next {
    position: absolute;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(11,15,20,0.5);
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color var(--transition-fast), background var(--transition-fast);
    backdrop-filter: blur(4px);
}

.glb-close svg,
.glb-prev svg,
.glb-next svg { width: 20px; height: 20px; }

.glb-close:hover,
.glb-prev:hover,
.glb-next:hover {
    border-color: var(--accent-primary);
    background: rgba(50,150,200,0.25);
}

.glb-close { top: 1.5rem; right: 1.5rem; }
.glb-prev  { left: 1.5rem; top: 50%; transform: translateY(-50%); }
.glb-next  { right: 1.5rem; top: 50%; transform: translateY(-50%); }

@media (max-width: 640px) {
    .glb-prev { left: 0.75rem; }
    .glb-next { right: 0.75rem; }
    .glb-close { top: 0.75rem; right: 0.75rem; }
}

/* =========================================================
   POPUP — pri dolasku na stranicu (welcome / promo popup)
   Prefix: .popup-
   Tekst je placeholder — lako zamjenjiv u footer.php
   ========================================================= */
.popup-overlay {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-loader) + 20);
    background: rgba(11,15,20,0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s ease, visibility 0.35s ease;
}

.popup-overlay.is-active {
    opacity: 1;
    visibility: visible;
}

.popup-box {
    position: relative;
    width: 100%;
    max-width: 480px;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: 3rem 2.5rem 2.5rem;
    text-align: center;
    transform: translateY(20px) scale(0.97);
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.popup-overlay.is-active .popup-box {
    transform: translateY(0) scale(1);
}

.popup-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--border-color-strong);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-primary);
    transition: border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast);
}

.popup-close svg { width: 18px; height: 18px; }

.popup-close:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
    background: var(--bg-secondary);
}

.popup-box .eyebrow { justify-content: center; }

.popup-box h3 {
    font-size: 1.5rem;
    margin: 0.5rem 0 1rem;
}

.popup-box p {
    font-size: 0.95rem;
    margin-bottom: 1.75rem;
}

.popup-actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

@media (max-width: 580px) {
    .popup-box { padding: 2.5rem 1.5rem 2rem; }
    .popup-box h3 { font-size: 1.3rem; }
    .popup-actions .btn { width: 100%; justify-content: center; }
}