/* ══════════════════════════════════════════════════════
   KONI DESIGN — Avada Child Theme Styles v1.1
   Učitava se na priority 9999, nakon svih Avada stilova
══════════════════════════════════════════════════════ */

:root {
  --koni-bg:          #16151E;
  --koni-bg2:         #1D1C2A;
  --koni-bg3:         #232133;
  --koni-border:      rgba(255,255,255,.08);
  --koni-border2:     rgba(255,255,255,.14);
  --koni-accent:      #A78BFA;
  --koni-accent-dim:  rgba(167,139,250,.12);
  --koni-accent-glow: rgba(167,139,250,.30);
  --koni-purple:      #8B5CF6;
  --koni-w70:         rgba(255,255,255,.70);
  --koni-w40:         rgba(255,255,255,.40);
  --koni-w20:         rgba(255,255,255,.20);
  --koni-light:       #F8F7FF;
  --koni-dark:        #1A1828;
  --koni-r:           16px;
  --koni-rl:          24px;
  --koni-font-d:      'Epilogue', sans-serif;
  --koni-font-b:      'Figtree', sans-serif;
}

/* ══ GLOBALNI FONT ══ */
body, .fusion-body { font-family: var(--koni-font-b) !important; -webkit-font-smoothing: antialiased; }
p, .fusion-text p, .fusion-column-content p, .post-content p, .entry-content p {
  font-size: 17px !important; line-height: 1.8 !important; font-family: var(--koni-font-b) !important;
}
h1,h2,h3,h4,h5, .fusion-title h1, .fusion-title h2, .fusion-title h3, .fusion-title h4 {
  font-family: var(--koni-font-d) !important;
}

/* ══ AVADA HEADER ══ */
#nav, .fusion-header-wrapper, .fusion-header {
  background-color: transparent !important;
  transition: background-color .4s ease !important;
}
.fusion-header-wrapper.fusion-is-sticky,
.fusion-header-wrapper.awb-sticky-applied {
  background-color: rgba(22,21,30,.92) !important;
  backdrop-filter: blur(24px) !important;
  -webkit-backdrop-filter: blur(24px) !important;
  border-bottom: 1px solid var(--koni-border) !important;
}
.fusion-logo .fusion-logo-text, .fusion-header .fusion-logo-text {
  font-family: var(--koni-font-d) !important; font-size: 22px !important;
  font-weight: 800 !important; letter-spacing: -.03em !important; color: #fff !important;
}
.fusion-main-menu > ul > li > a, .fusion-navbar-nav > li > a, .awb-main-menu > li > a {
  font-family: var(--koni-font-b) !important; font-size: 14px !important;
  font-weight: 500 !important; color: var(--koni-w40) !important;
  letter-spacing: .02em !important; transition: color .3s !important;
}
.fusion-main-menu > ul > li > a:hover, .fusion-navbar-nav > li > a:hover,
.fusion-main-menu > ul > li.current-menu-item > a { color: #fff !important; }
.fusion-main-menu > ul > li.nav-cta > a,
.fusion-navbar-nav > li.nav-cta > a {
  background: var(--koni-accent) !important; color: var(--koni-dark) !important;
  padding: 10px 26px !important; border-radius: 100px !important; font-weight: 700 !important;
}
.fusion-main-menu > ul > li.nav-cta > a:hover { transform: scale(1.04) !important; box-shadow: 0 0 32px var(--koni-accent-glow) !important; }
.fusion-megamenu-wrapper, .fusion-dropdown-menu, .fusion-main-menu .sub-menu {
  background: rgba(22,21,30,.96) !important; backdrop-filter: blur(20px) !important;
  border: 1px solid var(--koni-border) !important; border-top: 2px solid var(--koni-accent) !important;
}
.fusion-megamenu-wrapper a, .fusion-dropdown-menu a, .fusion-main-menu .sub-menu a { color: var(--koni-w40) !important; }
.fusion-megamenu-wrapper a:hover, .fusion-dropdown-menu a:hover, .fusion-main-menu .sub-menu a:hover { color: var(--koni-accent) !important; }

/* ══ AVADA FOOTER ══ */
#footer, .fusion-footer, .fusion-footer-widget-area { background-color: var(--koni-bg2) !important; border-top: 1px solid var(--koni-border) !important; }
.fusion-footer-copyright-area { background-color: var(--koni-bg) !important; border-top: 1px solid var(--koni-border) !important; }
.fusion-footer p, .fusion-footer a, .fusion-footer span { font-family: var(--koni-font-b) !important; color: var(--koni-w40) !important; }
.fusion-footer a:hover { color: var(--koni-accent) !important; }
.fusion-footer-widget-area h4, .fusion-footer-widget-area .widget-title {
  font-family: var(--koni-font-d) !important; font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .2em !important; text-transform: uppercase !important; color: var(--koni-w20) !important; border-bottom: none !important;
}
.fusion-footer .fusion-social-links-footer a { width: 40px !important; height: 40px !important; border: 1px solid var(--koni-border2) !important; border-radius: 10px !important; background: transparent !important; transition: all .3s !important; }
.fusion-footer .fusion-social-links-footer a:hover { border-color: var(--koni-accent) !important; color: var(--koni-accent) !important; background: var(--koni-accent-dim) !important; }

/* ══ KONI SECTIONS — koristimo koni-section umjesto fusion-fullwidth ══ */
.koni-section {
  width: 100%;
  position: relative;
}
.koni-inner {
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 48px;
}
.koni-section.koni-dark  { background-color: var(--koni-bg) !important; }
.koni-section.koni-dark2 { background-color: var(--koni-bg2) !important; }
.koni-section.koni-light { background-color: var(--koni-light) !important; }
.koni-section.koni-white { background-color: #fff !important; }
.koni-section.koni-light p, .koni-section.koni-light h1, .koni-section.koni-light h2, .koni-section.koni-light h3,
.koni-section.koni-white p, .koni-section.koni-white h1, .koni-section.koni-white h2, .koni-section.koni-white h3 { color: var(--koni-dark) !important; }

/* ══ GUMBI ══ */
a.koni-btn-primary, button.koni-btn-primary, .fusion-button.koni-btn-primary {
  background: var(--koni-accent) !important; color: var(--koni-dark) !important;
  border: none !important; border-radius: 100px !important;
  font-family: var(--koni-font-b) !important; font-size: 15px !important; font-weight: 700 !important;
  padding: 14px 34px !important; transition: all .3s !important;
  display: inline-flex !important; align-items: center !important; gap: 10px !important;
  text-decoration: none !important;
}
a.koni-btn-primary:hover { transform: translateY(-2px) !important; box-shadow: 0 16px 48px var(--koni-accent-glow) !important; color: var(--koni-dark) !important; }
a.koni-btn-ghost, button.koni-btn-ghost, .fusion-button.koni-btn-ghost {
  background: transparent !important; border: 1px solid var(--koni-border2) !important;
  color: var(--koni-w70) !important; border-radius: 100px !important;
  font-family: var(--koni-font-b) !important; font-size: 15px !important; font-weight: 500 !important;
  padding: 13px 22px !important; transition: all .3s !important;
  display: inline-flex !important; align-items: center !important; gap: 8px !important;
  text-decoration: none !important;
}
a.koni-btn-ghost:hover { color: #fff !important; background: rgba(255,255,255,.04) !important; }
.koni-light a.koni-btn-ghost, .koni-white a.koni-btn-ghost {
  color: rgba(26,24,40,.6) !important; border-color: rgba(26,24,40,.2) !important;
}
.koni-light a.koni-btn-ghost:hover, .koni-white a.koni-btn-ghost:hover {
  color: var(--koni-dark) !important; border-color: rgba(26,24,40,.5) !important; background: rgba(26,24,40,.04) !important;
}

/* ══ TIPOGRAFIJA POMOĆNE KLASE ══ */
.koni-section-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--koni-accent); font-family: var(--koni-font-b); margin-bottom: 16px;
}
.koni-section-tag::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--koni-accent); flex-shrink: 0; }
.koni-h2 { font-family: var(--koni-font-d) !important; font-size: clamp(38px,4vw,60px) !important; font-weight: 800 !important; letter-spacing: -.03em !important; line-height: 1.05 !important; }
.koni-grad { background: linear-gradient(135deg,#A78BFA 0%,#C4B5FD 50%,#8B5CF6 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.koni-muted-light { color: rgba(26,24,40,.25) !important; }
.koni-muted-dark  { color: var(--koni-w20) !important; }

/* Fusion Builder Title / Text overrides */
.fusion-title.koni-title h1, .fusion-title.koni-title h2, .fusion-title.koni-title h3 { font-family: var(--koni-font-d) !important; font-weight: 800 !important; letter-spacing: -.03em !important; color: #fff !important; }
.fusion-title.koni-title-dark h1, .fusion-title.koni-title-dark h2, .fusion-title.koni-title-dark h3 { font-family: var(--koni-font-d) !important; font-weight: 800 !important; letter-spacing: -.03em !important; color: var(--koni-dark) !important; }
.fusion-text.koni-section-tag > .fusion-column-content > p { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 12px !important; font-weight: 700 !important; letter-spacing: .15em !important; text-transform: uppercase !important; color: var(--koni-accent) !important; }
.fusion-text.koni-section-tag > .fusion-column-content > p::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--koni-accent); flex-shrink: 0; }
.fusion-button.koni-btn-primary { background-color: var(--koni-accent) !important; border-color: var(--koni-accent) !important; color: var(--koni-dark) !important; border-radius: 100px !important; }
.fusion-button.koni-btn-ghost { background-color: transparent !important; border: 1px solid var(--koni-border2) !important; color: var(--koni-w70) !important; border-radius: 100px !important; }

/* ══ CURSOR GLOW ══ */
#koniCursorGlow { position: fixed; width: 400px; height: 400px; background: radial-gradient(circle,rgba(167,139,250,.06),transparent 70%); pointer-events: none; transform: translate(-50%,-50%); z-index: 0; transition: opacity .3s; }

/* ══ HERO ══ */
.koni-section.koni-hero { background-color: var(--koni-bg) !important; min-height: 100vh; overflow: hidden; }
.koni-hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; padding: 160px 48px 100px; max-width: 1360px; margin: 0 auto; position: relative; z-index: 2; }
.koni-blob-wrap { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.koni-blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .5; animation: koniBlobFloat 8s ease-in-out infinite; }
.koni-blob-1 { width: 600px; height: 600px; background: radial-gradient(circle,rgba(167,139,250,.18),transparent 70%); top: -100px; left: -100px; animation-duration: 10s; }
.koni-blob-2 { width: 500px; height: 500px; background: radial-gradient(circle,rgba(139,92,246,.2),transparent 70%); top: 20%; right: -100px; animation-delay: -3s; animation-duration: 12s; }
.koni-blob-3 { width: 400px; height: 400px; background: radial-gradient(circle,rgba(0,150,255,.12),transparent 70%); bottom: 0; left: 30%; animation-delay: -6s; animation-duration: 9s; }
@keyframes koniBlobFloat { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-20px) scale(1.05)} 66%{transform:translate(-20px,30px) scale(.95)} }
.koni-grid-overlay { position: absolute; inset: 0; z-index: 0; pointer-events: none; background-image: linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size: 80px 80px; mask-image: radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%); }
.koni-hero-badge { display: inline-flex; align-items: center; gap: 10px; border: 1px solid rgba(167,139,250,.25); background: rgba(167,139,250,.06); padding: 8px 20px; border-radius: 100px; font-size: 13px; font-weight: 600; color: var(--koni-accent); letter-spacing: .06em; animation: koniFadeUp .7s .2s both; margin-bottom: 28px; }
.koni-pulse { width: 6px; height: 6px; background: var(--koni-accent); border-radius: 50%; display: inline-block; animation: koniPulse 2s infinite; }
@keyframes koniPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
.koni-hero-title { font-family: var(--koni-font-d) !important; font-size: clamp(36px,4vw,64px) !important; font-weight: 800 !important; line-height: 1.18 !important; letter-spacing: -.02em !important; color: #fff !important; margin-bottom: 24px; animation: koniFadeUp .8s .35s both; }
.koni-outline { -webkit-text-stroke: 1.5px rgba(255,255,255,.25); color: transparent !important; -webkit-text-fill-color: transparent; }
.koni-hero-sub { font-size: 20px !important; font-weight: 400 !important; line-height: 1.8 !important; color: var(--koni-w40) !important; max-width: 500px; margin-bottom: 40px; animation: koniFadeUp .8s .5s both; }
.koni-hero-actions { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-bottom: 56px; animation: koniFadeUp .8s .65s both; }
.koni-stats { display: flex; gap: 40px; flex-wrap: wrap; animation: koniFadeUp .8s .8s both; }
.koni-stat-num { font-family: var(--koni-font-d); font-size: 44px; font-weight: 800; letter-spacing: -.03em; color: #fff; line-height: 1; }
.koni-stat-label { font-size: 13px; font-weight: 500; color: var(--koni-w40); letter-spacing: .04em; margin-top: 4px; }
.koni-stat-sep { width: 1px; background: var(--koni-border2); align-self: stretch; }
.koni-hero-card-wrap { position: relative; }
.koni-hero-card { background: var(--koni-bg3); border: 1px solid var(--koni-border); border-radius: var(--koni-rl); overflow: hidden; box-shadow: 0 40px 100px rgba(0,0,0,.5); animation: koniFadeIn 1.2s .4s both; }
.koni-hero-card img { width: 100%; height: 360px; object-fit: cover; display: block; }
.koni-hero-card-body { padding: 28px; background: var(--koni-bg3); }
.koni-hero-card-tag { font-size: 11px; font-weight: 700; color: var(--koni-accent); letter-spacing: .15em; text-transform: uppercase; margin-bottom: 8px; }
.koni-hero-card-name { font-family: var(--koni-font-d); font-size: 20px; font-weight: 700; color: #fff; }
.koni-float-badge { position: absolute; background: rgba(22,21,30,.9); backdrop-filter: blur(16px); border: 1px solid var(--koni-border2); border-radius: 14px; padding: 14px 20px; white-space: nowrap; box-shadow: 0 20px 40px rgba(0,0,0,.4); z-index: 2; }
.koni-float-1 { bottom: 80px; left: -50px; animation: koniFloatY 4s ease-in-out infinite; }
.koni-float-2 { top: 30px; right: -30px; animation: koniFloatY 5s ease-in-out -2s infinite; }
@keyframes koniFloatY { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.koni-float-num { font-family: var(--koni-font-d); font-size: 26px; font-weight: 800; color: var(--koni-accent); line-height: 1; }
.koni-float-2 .koni-float-num { color: #8B5CF6; }
.koni-float-label { font-size: 11px; color: var(--koni-w40); margin-top: 2px; }
@keyframes koniFadeUp { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:none} }
@keyframes koniFadeIn { from{opacity:0} to{opacity:1} }

/* ══ MARQUEE ══ */
.koni-marquee-wrap { background: var(--koni-accent); padding: 14px 0; overflow: hidden; }
.koni-marquee-track { display: flex; animation: koniMarquee 20s linear infinite; }
.koni-marquee-item { display: inline-flex; align-items: center; gap: 16px; padding: 0 32px; font-family: var(--koni-font-d); font-size: 14px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--koni-dark); white-space: nowrap; flex-shrink: 0; }
.koni-marquee-dot { width: 6px; height: 6px; background: var(--koni-dark); opacity: .4; border-radius: 50%; }
@keyframes koniMarquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ══ USLUGE ══ */
.koni-services-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 64px; flex-wrap: wrap; gap: 24px; }
.koni-srv-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(167,139,250,.15); }
.koni-service-card { background: var(--koni-light); padding: 48px 40px; position: relative; overflow: hidden; transition: background .4s, box-shadow .4s; border: 1px solid rgba(167,139,250,.1); }
.koni-service-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,rgba(167,139,250,.06),transparent 60%); opacity: 0; transition: opacity .4s; pointer-events: none; }
.koni-service-card:hover { background: #fff; box-shadow: 0 20px 60px rgba(167,139,250,.12); }
.koni-service-card:hover::after { opacity: 1; }
.koni-service-icon { width: 48px; height: 48px; background: rgba(167,139,250,.1); border: 1px solid rgba(167,139,250,.25); border-radius: 12px; display: flex; align-items: center; justify-content: center; color: var(--koni-accent); margin-bottom: 28px; transition: all .3s; }
.koni-service-card:hover .koni-service-icon { background: rgba(167,139,250,.18); box-shadow: 0 0 24px var(--koni-accent-glow); }
.koni-service-num { font-size: 11px; font-weight: 700; color: rgba(26,24,40,.2); letter-spacing: .2em; display: block; margin-bottom: 32px; }
.koni-service-card h3 { font-family: var(--koni-font-d) !important; font-size: 22px !important; font-weight: 700 !important; letter-spacing: -.02em !important; color: var(--koni-dark) !important; margin-bottom: 12px !important; }
.koni-service-card p { font-size: 17px !important; color: rgba(26,24,40,.5) !important; }
.koni-service-link { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--koni-accent) !important; margin-top: 24px; opacity: 0; transform: translateY(6px); transition: all .3s; text-decoration: none; }
.koni-service-card:hover .koni-service-link { opacity: 1; transform: none; }
.koni-service-link::after { content: '→'; margin-left: 4px; }

/* ══ CHATBOT ══ */
.koni-section.koni-chatbot { background-color: var(--koni-bg2) !important; }
.koni-section.koni-chatbot::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg,transparent,var(--koni-accent-glow),transparent); }
.koni-section.koni-chatbot::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg,transparent,rgba(139,92,246,.3),transparent); }
.koni-chatbot-inner { display: grid; grid-template-columns: 1fr 1fr; min-height: 640px; }
.koni-chatbot-text { padding: 100px 64px; display: flex; flex-direction: column; justify-content: center; }
.koni-chatbot-visual { display: flex; align-items: center; justify-content: center; padding: 64px; position: relative; }
.koni-chatbot-visual::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 400px; height: 400px; background: radial-gradient(circle,rgba(167,139,250,.08),transparent 70%); pointer-events: none; }
.koni-chat-window { background: var(--koni-bg); border: 1px solid var(--koni-border); border-radius: var(--koni-rl); overflow: hidden; box-shadow: 0 40px 100px rgba(0,0,0,.5); max-width: 380px; margin: 0 auto; width: 100%; }
.koni-chat-header { padding: 18px 22px; background: var(--koni-bg2); border-bottom: 1px solid var(--koni-border); display: flex; align-items: center; gap: 14px; }
.koni-chat-av { width: 38px; height: 38px; background: var(--koni-accent-dim); border: 1px solid rgba(167,139,250,.2); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--koni-accent); }
.koni-chat-name { font-family: var(--koni-font-d); font-size: 14px; font-weight: 700; color: #fff; }
.koni-chat-status { font-size: 11px; color: var(--koni-accent); display: flex; align-items: center; gap: 5px; }
.koni-chat-status::before { content: ''; width: 6px; height: 6px; background: var(--koni-accent); border-radius: 50%; }
.koni-chat-body { padding: 20px; min-height: 280px; display: flex; flex-direction: column; gap: 12px; background: var(--koni-bg); }
.koni-msg { max-width: 82%; padding: 12px 16px; border-radius: 14px; font-size: 14px !important; line-height: 1.6 !important; animation: koniMsgPop .4s cubic-bezier(.34,1.56,.64,1) both; }
.koni-msg-bot { background: var(--koni-bg3); color: var(--koni-w70) !important; border-bottom-left-radius: 4px; align-self: flex-start; }
.koni-msg-user { background: var(--koni-accent); color: var(--koni-dark) !important; font-weight: 500 !important; border-bottom-right-radius: 4px; align-self: flex-end; }
.koni-msg:nth-child(1){animation-delay:.3s}.koni-msg:nth-child(2){animation-delay:.9s}.koni-msg:nth-child(3){animation-delay:1.6s}.koni-msg:nth-child(4){animation-delay:2.3s}.koni-msg:nth-child(5){animation-delay:3s}
@keyframes koniMsgPop { from{opacity:0;transform:scale(.85) translateY(8px)} to{opacity:1;transform:none} }
.koni-typing { display: flex; gap: 4px; align-self: flex-start; padding: 14px 18px; background: var(--koni-bg3); border-radius: 14px; border-bottom-left-radius: 4px; animation: koniMsgPop .4s 3.6s both; }
.koni-typing span { width: 7px; height: 7px; background: var(--koni-w40); border-radius: 50%; animation: koniTypeBob 1.2s infinite; }
.koni-typing span:nth-child(2){animation-delay:.2s}.koni-typing span:nth-child(3){animation-delay:.4s}
@keyframes koniTypeBob { 0%,100%{transform:none;opacity:.3} 50%{transform:translateY(-4px);opacity:1} }
.koni-chat-input { padding: 16px 20px; background: var(--koni-bg2); border-top: 1px solid var(--koni-border); display: flex; align-items: center; gap: 12px; }
.koni-chat-field { flex: 1; background: var(--koni-bg3); border: 1px solid var(--koni-border); border-radius: 100px; padding: 10px 16px; font-size: 13px; color: var(--koni-w40); }
.koni-chat-send { width: 36px; height: 36px; background: var(--koni-accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; flex-shrink: 0; }
.koni-chat-send svg { width: 15px; height: 15px; color: var(--koni-dark); }
.koni-feat-list { display: flex; flex-direction: column; margin-top: 40px; }
.koni-feat-item { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--koni-border); font-size: 17px !important; color: var(--koni-w40) !important; }
.koni-feat-item:last-child { border: none; }
.koni-feat-item::before { content: ''; width: 20px; height: 20px; flex-shrink: 0; background: var(--koni-accent-dim) url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='%23A78BFA' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center; border: 1px solid rgba(167,139,250,.2); border-radius: 6px; }

/* ══ PROJEKTI ══ */
.koni-section.koni-projects { background-color: #fff !important; overflow: hidden; }
.koni-carousel-viewport { overflow: hidden; padding: 0 48px; }
.koni-carousel-track { display: flex; gap: 16px; transition: transform .6s cubic-bezier(.22,.61,.36,1); will-change: transform; }
.koni-project-card { flex-shrink: 0; background: var(--koni-light); border: 1px solid rgba(167,139,250,.15); border-radius: var(--koni-rl); overflow: hidden; transition: all .4s; cursor: pointer; }
.koni-project-card:hover { border-color: rgba(167,139,250,.4); transform: translateY(-6px); box-shadow: 0 20px 60px rgba(167,139,250,.15); }
.koni-project-img { height: 260px; overflow: hidden; position: relative; }
.koni-project-img img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .7s; display: block; }
.koni-project-card:hover .koni-project-img img { transform: scale(1.06); }
.koni-project-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom,transparent 60%,var(--koni-light)); }
.koni-project-body { padding: 28px; }
.koni-project-tag { font-size: 11px; font-weight: 700; color: var(--koni-accent); letter-spacing: .15em; text-transform: uppercase; margin-bottom: 8px; }
.koni-project-name { font-family: var(--koni-font-d); font-size: 22px; font-weight: 700; letter-spacing: -.02em; color: var(--koni-dark); margin-bottom: 6px; }
.koni-project-desc { font-size: 16px !important; color: rgba(26,24,40,.5) !important; line-height: 1.7 !important; }
.koni-proj-head { max-width: 1360px; margin: 0 auto 64px; padding: 0 48px; display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 24px; }
.koni-carousel-nav { display: flex; align-items: center; gap: 12px; justify-content: center; margin-top: 48px; }
.koni-cbtn { width: 52px; height: 52px; border: 1px solid rgba(26,24,40,.15); border-radius: 50%; background: transparent; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .3s; }
.koni-cbtn:hover { background: var(--koni-accent); border-color: var(--koni-accent); }
.koni-cbtn svg { width: 18px; height: 18px; color: rgba(26,24,40,.4); transition: color .3s; }
.koni-cbtn:hover svg { color: #fff; }
.koni-cdots { display: flex; gap: 6px; align-items: center; }
.koni-cdot { width: 8px; height: 8px; border-radius: 100px; background: rgba(26,24,40,.15); transition: all .3s; cursor: pointer; }
.koni-cdot.koni-active { background: var(--koni-accent); width: 28px; }

/* ══ PROCES ══ */
.koni-section.koni-process { background-color: var(--koni-bg2) !important; }
.koni-section.koni-process::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg,transparent,rgba(167,139,250,.2),transparent); }
.koni-steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--koni-border); margin-top: 64px; }
.koni-step { padding: 48px 36px; position: relative; overflow: hidden; transition: background .4s; border-right: none; background: var(--koni-bg2); }
.koni-step::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg,var(--koni-accent),var(--koni-purple)); transform: scaleX(0); transform-origin: left; transition: transform .5s; }
.koni-step:hover::before { transform: scaleX(1); }
.koni-step:hover { background: var(--koni-bg3); }
.koni-step-bg-num { font-family: var(--koni-font-d); font-size: 80px; font-weight: 800; color: rgba(255,255,255,.03); position: absolute; right: 16px; top: 0; line-height: 1; pointer-events: none; }
.koni-step-idx { font-size: 11px; font-weight: 700; color: var(--koni-accent); letter-spacing: .2em; text-transform: uppercase; margin-bottom: 24px; display: block; }
.koni-step h4 { font-family: var(--koni-font-d) !important; font-size: 22px !important; font-weight: 700 !important; color: #fff !important; margin-bottom: 14px !important; }
.koni-step p { font-size: 17px !important; color: var(--koni-w40) !important; }

/* ══ RECENZIJE ══ */
.koni-section.koni-testi { background-color: var(--koni-light) !important; }
.koni-testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 64px; }
.koni-testi-card { background: #fff; border: 1px solid rgba(167,139,250,.18); border-radius: var(--koni-rl); padding: 48px 40px; position: relative; overflow: hidden; transition: all .4s; }
.koni-testi-card::before { content: '"'; position: absolute; top: -10px; right: 20px; font-family: var(--koni-font-d); font-size: 120px; font-weight: 800; color: rgba(167,139,250,.07); line-height: 1; pointer-events: none; }
.koni-testi-card:hover { border-color: rgba(167,139,250,.4); transform: translateY(-4px); box-shadow: 0 20px 60px rgba(167,139,250,.12); }
.koni-testi-stars { color: var(--koni-accent); font-size: 14px; letter-spacing: 3px; margin-bottom: 24px; }
.koni-testi-text { font-family: var(--koni-font-d) !important; font-size: 22px !important; font-weight: 600 !important; letter-spacing: -.02em !important; line-height: 1.55 !important; color: rgba(26,24,40,.75) !important; margin-bottom: 32px; }
.koni-testi-author { display: flex; align-items: center; gap: 14px; }
.koni-testi-av { width: 48px; height: 48px; background: rgba(167,139,250,.1); border: 1px solid rgba(167,139,250,.25); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-family: var(--koni-font-d); font-size: 20px; font-weight: 800; color: var(--koni-accent); }
.koni-testi-name { font-family: var(--koni-font-d) !important; font-size: 15px !important; font-weight: 700 !important; color: var(--koni-dark) !important; }
.koni-testi-role { font-size: 12px !important; color: rgba(26,24,40,.4) !important; margin-top: 2px; }

/* ══ CTA ══ */
.koni-section.koni-cta { background-color: var(--koni-bg) !important; }
.koni-section.koni-cta::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg,transparent,rgba(167,139,250,.3),rgba(139,92,246,.3),transparent); }
.koni-cta-glow { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(135deg,rgba(167,139,250,.08) 0%,rgba(139,92,246,.12) 50%,rgba(0,212,255,.08) 100%); }
.koni-cta-inner { max-width: 900px; margin: 0 auto; text-align: center; position: relative; z-index: 1; }
.koni-cta-title { font-family: var(--koni-font-d) !important; font-size: clamp(40px,5vw,72px) !important; font-weight: 800 !important; letter-spacing: -.04em !important; line-height: 1.02 !important; color: #fff !important; margin-bottom: 20px; }
.koni-cta-desc { font-size: 20px !important; color: var(--koni-w40) !important; line-height: 1.8 !important; max-width: 560px; margin: 0 auto 40px; }
.koni-cta-actions { display: flex; justify-content: center; align-items: center; gap: 20px; flex-wrap: wrap; }
.koni-cta-checks { display: flex; justify-content: center; gap: 40px; margin-top: 32px; flex-wrap: wrap; }
.koni-check-item { font-size: 13px; font-weight: 600; color: var(--koni-w40); display: inline-flex; align-items: center; gap: 6px; }
.koni-check-item::before { content: '✓'; color: var(--koni-accent); font-weight: 800; }

/* ══ SCROLL REVEAL ══════════════════════════════════════
   KLJUČNO: opacity:0 se aktivira SAMO kad body ima koni-js klasu.
   Ako JS ne učita, elementi su uvijek vidljivi.
══════════════════════════════════════════════════════ */
body.koni-js .koni-rv {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
body.koni-js .koni-rv.koni-visible { opacity: 1; transform: none; }
body.koni-js .koni-d1 { transition-delay: .1s; }
body.koni-js .koni-d2 { transition-delay: .2s; }
body.koni-js .koni-d3 { transition-delay: .3s; }
body.koni-js .koni-d4 { transition-delay: .4s; }

/* ══ RESPONSIVE — TABLET 1100px ══ */
@media (max-width: 1100px) {
  .koni-hero-inner        { grid-template-columns: 1fr; gap: 0; }
  .koni-hero-card-wrap    { display: none; }
  .koni-chatbot-inner     { grid-template-columns: 1fr; }
  .koni-chatbot-visual    { display: none; }
  .koni-srv-grid          { grid-template-columns: 1fr 1fr; }
  .koni-steps-grid        { grid-template-columns: 1fr 1fr; }
  .koni-testi-grid        { grid-template-columns: 1fr 1fr; }
  .koni-footer-top        { grid-template-columns: 1fr 1fr; gap: 40px; }
}

/* ══ RESPONSIVE — MOBILE 768px ══ */
@media (max-width: 768px) {

  /* ─ Globalno ─ */
  body { padding-top: 64px !important; }
  .koni-section.koni-hero { margin-top: -64px !important; }

  p, .fusion-text p, .post-content p, .entry-content p {
    font-size: 16px !important;
  }

  /* ─ Header ─ */
  .koni-nav-wrap          { height: 64px; }
  .koni-nav-inner         { padding: 0 20px; height: 64px; }
  .koni-hamburger         { display: flex; }

  /* Nav overlay — visibility approach, ne display:none */
  .koni-nav-links {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    top: 64px; left: 0; right: 0;
    height: auto;
    max-height: calc(100vh - 64px);
    background: rgba(16,15,28,.98);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    flex-direction: column;
    justify-content: flex-start;
    padding: 20px 24px 32px;
    gap: 0;
    overflow-y: auto;
    z-index: 9998;
    display: flex !important; /* uvijek flex, vidljivost kontrolira visibility */
    transform: translateY(-8px);
    transition: opacity .25s ease, transform .25s ease, visibility .25s;
    border-bottom: 1px solid var(--koni-border);
  }
  .koni-nav-links.koni-open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  .koni-nav-links a {
    font-size: 17px !important;
    font-weight: 500 !important;
    color: var(--koni-w70) !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid var(--koni-border) !important;
    width: 100% !important;
    letter-spacing: -.01em !important;
  }
  .koni-nav-links a:last-child { border: none !important; }
  .koni-nav-links a.nav-cta,
  .koni-nav-links li.nav-cta > a {
    background: var(--koni-accent) !important;
    color: var(--koni-dark) !important;
    border-radius: 10px !important;
    padding: 13px 20px !important;
    margin-top: 12px !important;
    border: none !important;
    text-align: center !important;
    font-weight: 700 !important;
    font-size: 14px !important;
  }

  /* ─ Hero ─ */
  .koni-hero-inner {
    padding: 100px 20px 64px;
    gap: 0;
  }
  .koni-hero-badge {
    font-size: 11px !important;
    padding: 6px 14px !important;
    margin-bottom: 20px !important;
  }
  .koni-hero-title {
    font-size: clamp(32px, 9vw, 48px) !important;
    line-height: 1.2 !important;
    letter-spacing: -.02em !important;
    margin-bottom: 20px !important;
  }
  .koni-hero-sub {
    font-size: 16px !important;
    margin-bottom: 28px !important;
  }
  .koni-hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 12px !important;
    margin-bottom: 36px !important;
  }
  .koni-hero-actions a {
    justify-content: center !important;
    text-align: center !important;
  }
  .koni-stats {
    gap: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr;
  }
  .koni-stat-sep { display: none !important; }
  .koni-stat-num  { font-size: 28px !important; }
  .koni-stat-label { font-size: 11px !important; }

  /* ─ Marquee ─ */
  .koni-marquee-item {
    font-size: 12px !important;
    padding: 0 20px !important;
    gap: 10px !important;
  }

  /* ─ Usluge ─ */
  .koni-section.koni-light,
  .koni-section.koni-white {
    padding: 64px 0 !important;
  }
  .koni-inner { padding: 0 20px !important; }
  .koni-services-head {
    flex-direction: column;
    align-items: flex-start !important;
    margin-bottom: 36px !important;
    gap: 16px !important;
  }
  .koni-h2 { font-size: clamp(28px,8vw,40px) !important; }
  .koni-srv-grid { grid-template-columns: 1fr !important; gap: 0 !important; }
  .koni-service-card {
    padding: 32px 24px !important;
    border-bottom: 1px solid rgba(167,139,250,.15) !important;
    border-right: none !important;
    border-left: none !important;
    border-top: none !important;
  }
  .koni-service-card:first-child { border-top: 1px solid rgba(167,139,250,.15) !important; }

  /* ─ Chatbot ─ */
  .koni-section.koni-chatbot { padding: 0 !important; }
  .koni-chatbot-text { padding: 56px 20px !important; }
  .koni-chatbot-text h2 { font-size: clamp(28px,8vw,40px) !important; }
  .koni-chatbot-text p  { font-size: 16px !important; }
  .koni-feat-item       { font-size: 15px !important; padding: 12px 0 !important; }

  /* ─ Projekti ─ */
  .koni-section.koni-projects { padding: 64px 0 !important; }
  .koni-proj-head {
    padding: 0 20px !important;
    flex-direction: column;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 32px !important;
  }
  .koni-carousel-viewport { padding: 0 20px !important; }
  .koni-carousel-nav { margin-top: 28px !important; }

  /* ─ Proces ─ */
  .koni-section.koni-process { padding: 64px 0 !important; }
  .koni-steps-grid {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  .koni-step {
    padding: 32px 24px !important;
    border-right: none !important;
    border-bottom: 1px solid var(--koni-border) !important;
  }
  .koni-step:last-child { border-bottom: none !important; }
  .koni-step h4 { font-size: 18px !important; }

  /* ─ Recenzije ─ */
  .koni-section.koni-testi { padding: 64px 0 !important; }
  .koni-testi-grid { grid-template-columns: 1fr !important; gap: 12px !important; margin-top: 32px !important; }
  .koni-testi-card { padding: 32px 24px !important; }
  .koni-testi-text { font-size: 18px !important; }

  /* ─ CTA ─ */
  .koni-section.koni-cta { padding: 64px 0 !important; }
  .koni-cta-inner { padding: 0 20px !important; }
  .koni-cta-title { font-size: clamp(28px,8vw,44px) !important; }
  .koni-cta-desc  { font-size: 16px !important; }
  .koni-cta-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 12px !important;
  }
  .koni-cta-actions a { justify-content: center !important; text-align: center !important; }
  .koni-cta-checks {
    flex-direction: column;
    align-items: center;
    gap: 10px !important;
    margin-top: 24px !important;
  }

  /* ─ Footer ─ */
  .koni-footer-wrap { padding: 40px 0 0; }
  .koni-footer-inner { padding: 0 20px !important; }
  .koni-footer-top {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
  }

  /* Brand sekcija — kompaktna */
  .koni-footer-brand {
    padding-bottom: 24px;
    border-bottom: 1px solid var(--koni-border);
    margin-bottom: 0;
  }
  .koni-footer-desc {
    max-width: 100% !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin-top: 10px !important;
    color: var(--koni-w20) !important;
  }
  .koni-footer-socials { margin-top: 14px !important; }
  .koni-social-btn { width: 34px !important; height: 34px !important; }

  /* Linkovi — accordion stil, 2 stupca */
  .koni-footer-col {
    padding: 20px 0;
    border-bottom: 1px solid var(--koni-border);
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto;
    align-items: start;
    gap: 0 24px;
  }
  .koni-footer-col h5 {
    font-size: 10px !important;
    letter-spacing: .18em !important;
    margin-bottom: 0 !important;
    padding-top: 2px;
    grid-column: 1;
    grid-row: 1 / span 10;
    white-space: nowrap;
    writing-mode: horizontal-tb;
    min-width: 64px;
    color: var(--koni-w40) !important;
  }
  .koni-footer-col a {
    font-size: 13px !important;
    padding: 2px 0 !important;
    color: var(--koni-w40) !important;
    grid-column: 2;
  }
  .koni-footer-location {
    font-size: 12px !important;
    grid-column: 2;
    padding-top: 4px !important;
  }

  .koni-footer-bottom {
    flex-direction: column !important;
    gap: 6px !important;
    text-align: center !important;
    padding: 16px 0 20px !important;
    font-size: 11px !important;
    color: var(--koni-w20) !important;
  }
  .koni-footer-bottom div {
    display: flex;
    gap: 16px;
    justify-content: center;
  }
  .koni-footer-bottom a {
    font-size: 11px !important;
    margin-left: 0 !important;
  }

  /* ─ Section naslovi ─ */
  .koni-section-tag { font-size: 10px !important; margin-bottom: 10px !important; }

  /* ─ Skriveni section padding ─ */
  .koni-section { overflow: hidden; }
}

/* ══ RESPONSIVE — MALI MOBILE 480px ══ */
@media (max-width: 480px) {
  .koni-hero-title { font-size: clamp(28px, 8vw, 38px) !important; }
  .koni-stats { grid-template-columns: 1fr 1fr 1fr; }
  .koni-stat-num { font-size: 24px !important; }
  .koni-chat-window { max-width: 100% !important; }
  .koni-testi-text { font-size: 16px !important; }
}

/* ══════════════════════════════════════════════════════
   CHILD TEMA HEADER — koni-nav-wrap
   (aktivira se samo kad postoji header.php u child temi)
══════════════════════════════════════════════════════ */
.koni-nav-wrap {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  height: 72px;
  transition: background-color .4s ease, border-color .4s ease;
}
.koni-nav-inner {
  max-width: 1360px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 48px;
}
.koni-nav-wrap.koni-scrolled {
  background-color: rgba(22,21,30,.92) !important;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--koni-border);
}

/* Logo */
.koni-logo { display: flex; align-items: center; text-decoration: none; }
.koni-logo span { font-family: var(--koni-font-d); font-size: 22px; font-weight: 800; letter-spacing: -.03em; color: #fff; }
.koni-logo-dot { color: var(--koni-accent); }
.koni-logo img { height: 36px; width: auto; }

/* Nav linkovi */
.koni-nav-links { display: flex; align-items: center; gap: 40px; }
.koni-nav-links a { font-family: var(--koni-font-b); font-size: 14px; font-weight: 500; color: var(--koni-w40); letter-spacing: .02em; text-decoration: none; transition: color .3s; }
.koni-nav-links a:hover,
.koni-nav-links a[aria-current="page"] { color: #fff; }
/* CTA link — dodaj klasu "nav-cta" na menu item */
.koni-nav-links a.nav-cta,
.koni-nav-links li.nav-cta > a {
  background: var(--koni-accent) !important;
  color: var(--koni-dark) !important;
  padding: 10px 26px !important;
  border-radius: 100px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  transition: all .3s !important;
}
.koni-nav-links a.nav-cta:hover { transform: scale(1.04) !important; box-shadow: 0 0 32px var(--koni-accent-glow) !important; }

/* Hamburger — mobile */
.koni-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.koni-hamburger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: all .3s; }

/* Pushdown za sadržaj ispod headera */
body { padding-top: 72px !important; }
.koni-section.koni-hero { margin-top: -72px !important; padding-top: 0 !important; }

/* ══════════════════════════════════════════════════════
   CHILD TEMA FOOTER — koni-footer-wrap
══════════════════════════════════════════════════════ */
.koni-footer-wrap {
  background-color: var(--koni-bg2);
  border-top: 1px solid var(--koni-border);
  padding: 80px 0 0;
  font-family: var(--koni-font-b);
}
.koni-footer-inner {
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 48px;
}
.koni-footer-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 56px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--koni-border);
}
.koni-footer-logo span { font-family: var(--koni-font-d); font-size: 22px; font-weight: 800; letter-spacing: -.03em; color: #fff; }
.koni-footer-logo img { height: 36px; width: auto; }
.koni-footer-desc { font-size: 15px; line-height: 1.8; color: var(--koni-w40); margin-top: 16px; max-width: 320px; }
.koni-footer-socials { display: flex; gap: 10px; margin-top: 20px; }
.koni-social-btn { width: 40px; height: 40px; border: 1px solid var(--koni-border2); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--koni-w40); transition: all .3s; }
.koni-social-btn:hover { border-color: var(--koni-accent); color: var(--koni-accent); background: var(--koni-accent-dim); }
.koni-footer-col h5 { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--koni-w20); margin-bottom: 20px; font-family: var(--koni-font-b); }
.koni-footer-col a { display: block; font-size: 15px; color: var(--koni-w40); padding: 4px 0; text-decoration: none; transition: color .3s; }
.koni-footer-col a:hover { color: var(--koni-accent); }
.koni-footer-location { font-size: 13px; color: var(--koni-w20); display: block; padding-top: 8px; }
.koni-footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 24px 0; font-size: 12px; color: var(--koni-w20); }
.koni-footer-bottom a { color: var(--koni-w20); margin-left: 20px; text-decoration: none; transition: color .3s; }
.koni-footer-bottom a:hover { color: var(--koni-accent); }

/* ══ RESPONSIVE — tablet footer ══ */
@media (max-width: 1100px) {
  .koni-footer-top { grid-template-columns: 1fr 1fr; gap: 36px; }
}
