/* ============================================================
   reload.rs — inner page components (pages.css)
   Loaded after styles.css on sub-pages.
   ============================================================ */

/* ---------- Page hero (compact, dark) ---------- */
.page-hero {
  position: relative; background: var(--ink); color: var(--on-dark);
  padding-top: calc(var(--nav-h) + clamp(56px, 9vw, 110px));
  padding-bottom: clamp(56px, 8vw, 96px);
  overflow: hidden;
}
.page-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: 0.5;
  background:
    radial-gradient(900px 380px at 88% -10%, rgba(255,199,53,0.12), transparent 60%),
    radial-gradient(700px 360px at -5% 110%, rgba(255,199,53,0.06), transparent 60%);
}
.page-hero .wrap { position: relative; z-index: 1; }
.page-hero .crumbs {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap; white-space: nowrap;
  font-family: var(--font-mono);
  font-size: 12.5px; letter-spacing: 0.06em; color: var(--on-dark-3); margin-bottom: 22px;
}
.page-hero .crumbs a { color: var(--on-dark-3); transition: color 0.2s; }
.page-hero .crumbs a:hover { color: var(--teal); }
.page-hero .crumbs .sep { color: var(--on-dark-3); opacity: 0.6; }
.page-hero h1 {
  font-family: var(--font-display); font-weight: 600; letter-spacing: -0.045em; line-height: 0.96;
  font-size: clamp(40px, 6.6vw, 92px); color: var(--on-dark); max-width: 18ch;
}
.page-hero .ph-lead { color: var(--on-dark-2); font-size: clamp(17px, 1.8vw, 21px); max-width: 56ch; margin: 24px 0 0; }
.page-hero .ph-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }

/* generic section head reused on inner pages */
.shead { max-width: 60ch; }

/* ============================================================
   PROCESS STEPS (Usluge)
   ============================================================ */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(24px, 3vw, 44px); margin-top: clamp(48px, 6vw, 64px); }
.step {
  position: relative; padding: 22px 0 0; background: transparent;
  border: none; border-top: 2px solid var(--ink); border-radius: 0;
}
.step .s-no {
  font-family: var(--font-display); font-weight: 700; font-size: 40px; letter-spacing: -0.04em;
  color: var(--teal-deep); line-height: 1;
}
.step h3 { font-size: 19px; margin-top: 14px; letter-spacing: -0.02em; }
.step p { color: var(--muted); font-size: 14.5px; margin-top: 8px; line-height: 1.5; }
.step .s-line { font-family: var(--font-mono); font-size: 11.5px; color: var(--muted-2); margin-top: 16px; letter-spacing: 0.04em; }
@media (max-width: 820px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .steps { grid-template-columns: 1fr; } }

/* editorial feature list (zamena za .svc-grid kartice) */
.rl-flist { margin-top: clamp(40px, 5vw, 60px); display: grid; grid-template-columns: 1fr 1fr; gap: 0 clamp(40px, 5vw, 72px); border-top: 1px solid var(--line); }
.rl-fitem { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: 26px 0; border-bottom: 1px solid var(--line); align-items: start; }
.rl-fitem .ic { width: 46px; height: 46px; border-radius: 10px; display: grid; place-items: center; background: var(--teal); color: var(--ink); flex: none; }
.rl-fitem .ic svg { width: 23px; height: 23px; }
.rl-fitem h3 { font-family: var(--font-display); font-size: 19px; font-weight: 600; letter-spacing: -0.01em; }
.rl-fitem p { color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-top: 7px; }
.on-dark-block .rl-flist { border-color: var(--ink-line); }
.on-dark-block .rl-fitem { border-color: var(--ink-line); }
.on-dark-block .rl-fitem p { color: var(--on-dark-2); }
@media (max-width: 720px) { .rl-flist { grid-template-columns: 1fr; } }

/* big alternating service rows */







.svc-list { list-style: none; padding: 0; margin: 24px 0 0; display: grid; gap: 11px; }
.svc-list li { display: flex; gap: 11px; font-size: 15.5px; color: var(--muted); }
.svc-list li svg { flex: 0 0 auto; width: 19px; height: 19px; color: var(--teal-deep); margin-top: 3px; }




/* ============================================================
   BLOG
   ============================================================ */



















/* ============================================================
   ARTICLE (prose)
   ============================================================ */
.article-hero { background: var(--ink); color: var(--on-dark); }
.article-wrap { max-width: 760px; margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }
.article-meta-row { display: flex; flex-wrap: wrap; gap: 10px 18px; align-items: center; margin-top: 22px; font-family: var(--font-mono); font-size: 12.5px; color: var(--on-dark-3); letter-spacing: 0.03em; }
.article-meta-row .cat { color: var(--ink); background: var(--teal); padding: 4px 11px; border-radius: 999px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; }
.prose { max-width: 768px; margin: 0 auto; padding: clamp(48px, 7vw, 88px) var(--pad); }
.prose > * { max-width: 100%; }
.prose p { font-size: 18.5px; line-height: 1.72; color: var(--text); margin: 0 0 26px; }
.prose .lead { font-size: 22px; line-height: 1.55; color: var(--text); font-family: var(--font-display); font-weight: 500; letter-spacing: -0.01em; margin-bottom: 34px; }
.prose h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(26px, 3.4vw, 38px); letter-spacing: -0.03em; margin: 52px 0 18px; line-height: 1.08; scroll-margin-top: 100px; }
.prose h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.02em; margin: 36px 0 12px; }
.prose ul, .prose ol { font-size: 18px; line-height: 1.7; color: var(--text); margin: 0 0 26px; padding-left: 24px; }
.prose li { margin: 0 0 10px; }
.prose li::marker { color: var(--teal-deep); }
.prose blockquote {
  border-left: 3px solid var(--teal); margin: 34px auto; padding: 6px 0 6px 26px;
  font-family: var(--font-display); font-weight: 500; font-size: 24px; line-height: 1.4; letter-spacing: -0.02em; color: var(--text);
}
.prose figure { margin: 40px auto; max-width: 760px; }
.prose .pull {
  background: var(--paper-2); border: 1px solid var(--line); border-radius: 18px; padding: 28px 30px; margin: 36px auto;
}
.prose .pull .pull-k { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal-deep); }
.prose .pull p { font-size: 17px; margin: 10px 0 0; color: var(--muted); }
.prose code { font-family: var(--font-mono); font-size: 0.86em; background: var(--paper-3); padding: 2px 7px; border-radius: 6px; }
.prose a, .about-body a, .about-side a { color: var(--teal-deep); border-bottom: 1.5px solid rgba(255,199,53,0.55); text-decoration: none; transition: border-color .2s, color .2s; }
.prose a:hover, .about-body a:hover, .about-side a:hover { border-bottom-color: var(--teal-deep); }

.article-foot { border-top: 1px solid var(--line); margin-top: 10px; }
.share { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.share .lab { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted-2); }
.share a { width: 40px; height: 40px; border-radius: 11px; border: 1px solid var(--line-2); display: grid; place-items: center; color: var(--muted); transition: all 0.22s var(--ease); }
.share a:hover { color: var(--teal-deep); border-color: var(--teal); transform: translateY(-3px); }
.share svg { width: 18px; height: 18px; }

/* ============================================================
   TIMELINE (O nama)
   ============================================================ */
.timeline { max-width: 860px; margin: 56px auto 0; position: relative; }
.timeline::before { content: ""; position: absolute; left: 50%; transform: translateX(-50%); top: 8px; bottom: 8px; width: 2px; background: var(--line-2); }
.tl-item { position: relative; width: 50%; box-sizing: border-box; padding-bottom: 48px; }
.tl-item:nth-child(odd) { left: 0; padding-right: 42px; text-align: right; }
.tl-item:nth-child(even) { left: 50%; padding-left: 42px; text-align: left; }
.tl-item:last-child { padding-bottom: 0; }
.tl-item::before {
  content: ""; position: absolute; top: 4px; width: 16px; height: 16px; border-radius: 50%;
  background: var(--paper); border: 3px solid var(--teal); box-shadow: 0 0 0 4px var(--paper);
}
.tl-item:nth-child(odd)::before { right: -8px; }
.tl-item:nth-child(even)::before { left: -8px; }
@media (max-width: 680px) {
  .timeline { max-width: none; }
  .timeline::before { left: 11px; transform: none; }
  .tl-item, .tl-item:nth-child(odd), .tl-item:nth-child(even) { width: 100%; left: 0; padding: 0 0 38px 46px; text-align: left; }
  .tl-item::before, .tl-item:nth-child(odd)::before, .tl-item:nth-child(even)::before { left: 4px; right: auto; }
}
.tl-year { font-family: var(--font-mono); font-size: 13px; color: var(--teal-deep); letter-spacing: 0.06em; font-weight: 500; }
.tl-item h3 { font-size: 21px; letter-spacing: -0.02em; margin: 6px 0 0; }
.tl-item p { color: var(--muted); font-size: 15.5px; margin: 8px 0 0; max-width: 60ch; }

/* ============================================================
   TEAM
   ============================================================ */
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(24px, 3vw, 44px); margin-top: clamp(48px, 6vw, 60px); }
.member { background: transparent; border: none; border-top: 2px solid var(--ink); border-radius: 0; padding: 20px 0 0; }
.member .m-no { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em; color: var(--teal-deep); }
.member .m-name { font-family: var(--font-display); font-weight: 600; font-size: 19px; letter-spacing: -0.02em; margin-top: 12px; }
.member .m-role { font-family: var(--font-mono); font-size: 12px; color: var(--muted-2); margin-top: 7px; letter-spacing: 0.03em; line-height: 1.5; }
@media (max-width: 760px) { .team-grid { grid-template-columns: 1fr 1fr; } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(36px, 5vw, 72px); margin-top: 56px; align-items: start; }
.contact-form { display: grid; gap: 18px; }
.field { display: grid; gap: 8px; }
.field label { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted-2); }
.field input, .field select, .field textarea {
  font-family: var(--font-body); font-size: 16px; color: var(--text);
  padding: 14px 16px; border-radius: 13px; border: 1.5px solid var(--line-2); background: var(--paper);
  transition: border-color 0.2s, box-shadow 0.2s; width: 100%;
}
.field textarea { resize: vertical; min-height: 130px; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--teal); box-shadow: 0 0 0 4px rgba(255,199,53,0.18);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-note { font-family: var(--font-mono); font-size: 12px; color: var(--muted-2); }
.form-success {
  display: none; align-items: center; gap: 12px; padding: 16px 18px; border-radius: 14px;
  background: rgba(255,199,53,0.12); border: 1.5px solid rgba(255,199,53,0.4); color: var(--text); font-size: 15px;
}
.form-success.show { display: flex; }
.form-success svg { color: var(--teal-deep); flex: 0 0 auto; }

.contact-aside { display: grid; gap: 16px; }
.info-card { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; padding: 24px; }
.info-row { display: flex; gap: 14px; align-items: flex-start; padding: 12px 0; }
.info-row:not(:last-child) { border-bottom: 1px solid var(--line); }
.info-row .ir-ico { flex: 0 0 auto; width: 40px; height: 40px; border-radius: 11px; background: var(--teal-soft); color: var(--teal-dark); display: grid; place-items: center; }
.info-row .ir-ico svg { width: 20px; height: 20px; }
.info-row .ir-k { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted-2); }
.info-row .ir-v { font-size: 16px; font-weight: 600; margin-top: 2px; color: var(--text); }
.info-row .ir-v a { color: var(--text); }
.info-row .ir-v a:hover { color: var(--teal-deep); }
.map-embed { border-radius: 18px; overflow: hidden; border: 1px solid var(--line); height: 240px; background: var(--paper-3); }
.map-embed iframe { width: 100%; height: 100%; border: 0; display: block; filter: grayscale(0.2); }

/* ============================================================
   FAQ
   ============================================================ */
.faq { margin-top: 48px; max-width: 820px; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: 22px 0; display: flex; align-items: center; justify-content: space-between; gap: 20px;
  font-family: var(--font-display); font-weight: 600; font-size: clamp(18px, 2vw, 22px); letter-spacing: -0.02em; color: var(--text);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .fq-ico { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 9px; border: 1.5px solid var(--line-2); display: grid; place-items: center; transition: transform 0.3s var(--ease), background 0.3s, border-color 0.3s, color 0.3s; color: var(--muted); }
.faq-item[open] summary .fq-ico { transform: rotate(45deg); background: var(--teal); border-color: var(--teal); color: var(--ink); }
.faq-item .fq-body { overflow: hidden; }
.faq-item .fq-body p { color: var(--muted); font-size: 16.5px; padding: 0 0 24px; max-width: 70ch; margin: 0; }

/* ============================================================
   FILTER CHIPS (Portfolio)
   ============================================================ */
.chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 40px; }
.chip {
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.02em; color: var(--on-dark-2);
  padding: 9px 16px; border-radius: 999px; border: 1.5px solid var(--ink-line-2); background: transparent;
  cursor: pointer; transition: all 0.22s var(--ease); white-space: nowrap;
}
.chip:hover { color: var(--on-dark); border-color: rgba(255,255,255,0.4); }
.chip.active { background: var(--teal); color: var(--ink); border-color: var(--teal); font-weight: 600; }


/* ===== SCROLL-FILL MANIFESTO ===== */
.manifest2 { position: relative; background: var(--paper); height: 200vh; }
.m2-sticky { position: sticky; top: 0; min-height: 100vh; display: flex; align-items: center; padding: 96px 0; }
.m2-head { display: inline-flex; margin-bottom: 30px; }
.m2-text {
  font-family: var(--font-display); font-weight: 600; font-size: clamp(34px, 5.6vw, 84px);
  letter-spacing: -0.04em; line-height: 1.12; max-width: 17ch; margin: 0;
}
.m2-text .w { color: rgba(12,15,20,0.19); transition: color 0.3s var(--ease); }
.m2-text .w.on { color: var(--text); }
.m2-text .w.hot.on { background: linear-gradient(transparent 58%, var(--teal-glow) 58%); }
@media (prefers-reduced-motion: reduce) { .m2-text .w { color: var(--text); } .manifest2 { height: auto; } .m2-sticky { min-height: 0; } }

/* ===== PRINCIPI (minimal numbered) ===== */
.principi-grid { display: grid; grid-template-columns: repeat(3, 1fr); margin-top: 56px; border-top: 1.5px solid var(--line); }
.principle { padding: 40px 30px 38px; border-left: 1.5px solid var(--line); }
.principle:first-child { border-left: none; padding-left: 0; }
.principle .pr-num {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(48px, 6vw, 78px); letter-spacing: -0.05em; line-height: 1;
  color: transparent; -webkit-text-stroke: 2px var(--muted-2); text-stroke: 2px var(--muted-2);
  transition: -webkit-text-stroke-color 0.35s var(--ease), color 0.35s var(--ease);
}
.principle:hover .pr-num { color: var(--teal); -webkit-text-stroke-color: var(--teal); }
.principle h3 { font-size: 22px; letter-spacing: -0.02em; margin: 22px 0 0; }
.principle p { color: var(--muted); font-size: 15px; margin: 10px 0 0; max-width: 34ch; }
@media (max-width: 760px) {
  .principi-grid { grid-template-columns: 1fr; }
  .principle { border-left: none; border-top: 1.5px solid var(--line); padding: 30px 0; }
  .principle:first-child { border-top: none; }
}

/* ===== TESTIMONIAL (macro, dark) ===== */
.testi-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 0; align-items: stretch; border-radius: 28px; overflow: hidden; border: 1.5px solid var(--ink-line); background: var(--ink-2); }
.testi-photo { position: relative; overflow: hidden; min-height: 540px; background: var(--ink-3); }
.testi-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 22%; filter: grayscale(0.1) contrast(1.03); transition: transform 0.8s var(--ease); }
.testi-photo:hover img { transform: scale(1.05); }
.testi-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(105deg, transparent 55%, rgba(18,22,29,0.85)); }
.testi-photo .testi-badge {
  position: absolute; left: 22px; top: 22px; z-index: 2; display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.02em;
  color: var(--ink); background: var(--teal); padding: 9px 15px; border-radius: 999px; font-weight: 700;
}
.testi-badge svg { width: 15px; height: 15px; }
.testi-body { padding: clamp(36px, 4.5vw, 68px); display: flex; flex-direction: column; justify-content: center; }
.testi-body .eyebrow { color: var(--teal); }
.testi-mark { display: block; font-family: var(--font-display); font-weight: 700; font-size: 130px; line-height: 0.5; color: var(--teal); height: 52px; margin: 18px 0 0; }
.testi-quote { font-family: var(--font-display); font-weight: 500; font-size: clamp(26px, 3.4vw, 46px); letter-spacing: -0.025em; line-height: 1.2; color: var(--on-dark); margin: 0; }
.testi-quote mark.hl { background: linear-gradient(transparent 58%, var(--teal-glow) 58%); color: var(--on-dark); }
.testi-by { margin-top: 34px; display: flex; align-items: center; gap: 16px; }
.testi-by .tb-av { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; object-position: center 22%; border: 2px solid var(--teal); flex: 0 0 auto; }
.testi-name { font-family: var(--font-display); font-weight: 600; font-size: 19px; letter-spacing: -0.01em; color: var(--on-dark); }
.testi-role { font-family: var(--font-mono); font-size: 12.5px; color: var(--teal); margin-top: 4px; letter-spacing: 0.02em; }
.testi-stars { color: var(--teal); margin-left: auto; letter-spacing: 4px; font-size: 18px; }
@media (max-width: 860px) {
  .testi-grid { grid-template-columns: 1fr; }
  .testi-photo { min-height: 360px; }
  .testi-photo::after { background: linear-gradient(transparent 50%, rgba(18,22,29,0.9)); }
  .testi-stars { margin-left: 0; margin-top: 16px; }
  .testi-by { flex-wrap: wrap; }
}

/* CTA reused */
.cta-band .wrap { text-align: center; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .steps { grid-template-columns: 1fr 1fr; }
  .svc-row { grid-template-columns: 1fr; }
  
  .post-card, .post-card.feature { grid-column: span 1; }
  .post-card.feature { flex-direction: column; }
  .post-card.feature .post-thumb { width: 100%; aspect-ratio: 16/10; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .steps, .blog-grid, .team-grid { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
}

/* ============================================================
   WordPress integracija (pager, CF7, blokovi)
   ============================================================ */
.pager .page-numbers {
  display: inline-grid; place-items: center; min-width: 44px; height: 44px; padding: 0 12px;
  border: 1.5px solid var(--line-2); border-radius: 12px; color: var(--text);
  font-family: var(--font-mono); font-size: 14px; transition: all 0.2s var(--ease);
}
.pager a.page-numbers:hover { border-color: var(--teal); color: var(--teal-deep); }
.pager .page-numbers.current { background: var(--ink); color: var(--on-dark); border-color: var(--ink); }
.pager .page-numbers.dots { border: none; }

/* Contact Form 7 u dizajnu */
.contact-form-wrap .wpcf7 { width: 100%; }
.contact-form-wrap .wpcf7-form p { margin: 0 0 18px; }
.contact-form-wrap .field { margin: 0; }
.wpcf7-not-valid-tip { color: #c0392b; font-size: 12.5px; font-family: var(--font-mono); margin-top: 6px; display: block; }
.wpcf7-response-output {
  border-radius: 13px !important; padding: 14px 18px !important; margin: 16px 0 0 !important;
  font-size: 14.5px; border-width: 1.5px !important;
}
.wpcf7 form.sent .wpcf7-response-output { background: rgba(255,199,53,0.12); border-color: var(--teal) !important; color: var(--text); }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.failed .wpcf7-response-output { background: #fdeaea; border-color: #e7a6a3 !important; color: #8a2a26; }
.wpcf7-spinner { margin: 8px auto 0; }

/* Blokovi unutar .prose */
.prose img, .prose figure img { border-radius: 12px; }
.prose .wp-block-image { margin: 30px 0; }
.prose .aligncenter { text-align: center; }
.prose .wp-block-list { padding-left: 24px; }
.prose .wp-block-quote { border-left: 3px solid var(--teal); padding-left: 26px; margin: 34px 0; font-family: var(--font-display); }

/* Logo (slika umesto tekstualnog brenda) */
.brand-img img { height: 42px; width: auto; display: block; }
.foot-brand .brand-img img { height: 46px; }
@media (max-width: 640px) { .brand-img img { height: 34px; } }

/* Osnivač blok (O nama) */
.founder { display: flex; gap: 16px; align-items: center; margin-top: 32px; padding: 18px 20px; background: var(--paper); border: 1px solid var(--line); border-radius: 16px; }




.founder-link { display: inline-flex; align-items: center; gap: 7px; margin-top: 6px; font-family: var(--font-mono); font-size: 13px; color: var(--teal-deep); font-weight: 500; }
.founder-link:hover { color: var(--teal-dark); }

/* ===== GEO / lokacija (naslovna) — ogromna tipografija + tamna mapa ===== */
.geo .geo-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; flex-wrap: wrap; margin-top: 20px; }
.geo-big { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.055em; line-height: 0.82; color: var(--on-dark); font-size: clamp(64px, 15vw, 220px); margin: 0; }
.geo-big .geo-sub { display: block; color: transparent; -webkit-text-stroke: 2px var(--teal); text-stroke: 2px var(--teal); }
.geo-addr { font-family: var(--font-mono); font-size: 13.5px; color: var(--on-dark-2); letter-spacing: 0.05em; text-align: right; line-height: 1.9; }
.geo-addr .ga-k { color: var(--teal); }
.geo-map { position: relative; margin-top: clamp(26px, 4vw, 46px); overflow: hidden; height: clamp(340px, 48vw, 540px); border-radius: 20px; border: 1px solid var(--ink-line); isolation: isolate; }
.geo-map iframe { width: 100%; height: 100%; border: 0; display: block; filter: invert(1) hue-rotate(180deg) brightness(0.92) contrast(0.95); transform: translateZ(0); will-change: transform; backface-visibility: hidden; }
/* vinjeta — centar transparentan, ivice prelaze u boju pozadine (mapa se utapa) */
@media (max-width: 640px) { .geo-addr { text-align: left; } }

/* ===================== MEGA MENU (Claude Design „Mega Menu") ===================== */
.scrim { position: fixed; inset: var(--nav-h) 0 0 0; z-index: 96; background: rgba(8,9,11,0.55); opacity: 0; pointer-events: none; transition: opacity 0.4s var(--ease); }
.scrim.show { opacity: 1; pointer-events: auto; }
.mega {
  position: fixed; top: var(--nav-h); left: 0; right: 0; z-index: 98;
  background: var(--ink-2); border-bottom: 1px solid var(--ink-line);
  overflow: hidden; max-height: 0; transition: max-height 0.5s var(--ease);
  box-shadow: 0 34px 70px -24px rgba(0,0,0,0.6);
}
.mega::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(80% 120% at 88% -20%, rgba(255,199,53,0.07), transparent 60%); }
.mega.open { max-height: 600px; }
.mega-spot { position: absolute; width: 680px; height: 680px; left: 0; top: 0; border-radius: 50%; pointer-events: none; z-index: 0; background: radial-gradient(circle, rgba(255,199,53,0.10), transparent 62%); transform: translate(-50%,-50%); opacity: 0; transition: opacity 0.4s var(--ease); }
.mega.open .mega-spot { opacity: 1; }
.panel { display: none; max-width: var(--maxw); margin: 0 auto; padding: 44px var(--pad) 50px; position: relative; z-index: 1; }
.panel.on { display: grid; }
#panel-usluge { grid-template-columns: 1.15fr 1fr 1fr; gap: 36px; }
#panel-radovi { grid-template-columns: repeat(3, 1fr); gap: 20px; }
#panel-resursi { grid-template-columns: 1fr 1fr 1.1fr; gap: 36px; }

.pcol-head { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--teal); margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.pcol-head .ln { flex: 1; height: 1px; background: var(--ink-line); }
.link { display: flex; align-items: flex-start; gap: 14px; padding: 13px 14px; border-radius: 12px; position: relative; transition: background 0.25s var(--ease), transform 0.25s var(--ease); }
.link .ico { width: 42px; height: 42px; flex: none; border-radius: 11px; background: rgba(255,255,255,0.05); border: 1px solid var(--ink-line); display: flex; align-items: center; justify-content: center; color: var(--teal); transition: background 0.25s, color 0.25s, border-color 0.25s; }
.link .ico svg { width: 20px; height: 20px; }
.link .tx b { display: block; font-family: var(--font-display); font-size: 15.5px; font-weight: 600; letter-spacing: -0.01em; color: #fff; }
.link .tx span { display: block; font-size: 12.5px; color: var(--on-dark-3); margin-top: 3px; line-height: 1.45; }
.link .go { position: absolute; right: 14px; top: 50%; transform: translateY(-50%) translateX(-6px); opacity: 0; color: var(--teal); transition: opacity 0.25s var(--ease), transform 0.25s var(--ease); }
.link .go svg { width: 22px; height: auto; }
.link:hover { background: rgba(255,255,255,0.04); transform: translateX(2px); }
.link:hover .ico { background: var(--teal); color: var(--ink); border-color: var(--teal); }
.link:hover .go { opacity: 1; transform: translateY(-50%) translateX(0); }

.promo { position: relative; border-radius: 18px; overflow: hidden; background: rgba(255,255,255,0.03); border: 1px solid var(--ink-line); padding: 30px; display: flex; flex-direction: column; justify-content: space-between; min-height: 320px; transition: border-color 0.3s; }
.promo:hover { border-color: rgba(255,199,53,0.4); }
.promo .badge { align-self: flex-start; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink); background: var(--teal); padding: 6px 12px; border-radius: 3px; position: relative; z-index: 2; white-space: nowrap; }
.promo .bigarrow { position: absolute; right: -14%; top: 50%; transform: translateY(-50%); width: 62%; opacity: 0.15; color: var(--teal); }
.promo .bigarrow svg { width: 100%; height: auto; overflow: visible; }
.promo h3 { position: relative; z-index: 2; font-family: var(--font-display); font-size: 28px; font-weight: 700; letter-spacing: -0.025em; line-height: 0.98; margin-top: auto; color: #fff; }
.promo p { position: relative; z-index: 2; color: var(--on-dark-3); font-size: 14px; line-height: 1.5; margin-top: 12px; max-width: 32ch; }
.promo .plink { position: relative; z-index: 2; margin-top: 22px; display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal); }
.promo .plink svg { width: 26px; height: auto; transition: transform 0.3s var(--ease); }
.promo:hover .plink svg { transform: translateX(6px); }

.tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; padding: 0 14px; }
.tag { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; color: #cfcfd4; border: 1px solid var(--ink-line); padding: 7px 12px; border-radius: 999px; transition: border-color 0.25s, color 0.25s, background 0.25s; }
.tag:hover { border-color: var(--teal); color: var(--teal); background: rgba(255,199,53,0.06); }

.wcard { position: relative; border-radius: 16px; overflow: hidden; border: 1px solid var(--ink-line); min-height: 290px; background: var(--ink-3); display: flex; flex-direction: column; justify-content: flex-end; padding: 22px; transition: transform 0.3s var(--ease), border-color 0.3s; }
.wcard img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; filter: grayscale(0.2) brightness(0.7); transition: transform 0.5s var(--ease), filter 0.4s; }
.wcard .wkg { position: absolute; inset: 0; background: linear-gradient(transparent 30%, rgba(8,10,14,0.92)); }
.wcard .num { position: absolute; top: 16px; left: 18px; z-index: 2; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; color: var(--on-dark-2); }
.wcard .wkb { position: relative; z-index: 2; }
.wcard .cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--teal); margin-bottom: 8px; }
.wcard h4 { font-family: var(--font-display); font-size: 21px; font-weight: 700; letter-spacing: -0.02em; color: #fff; }
.wcard:hover { transform: translateY(-4px); border-color: rgba(255,199,53,0.4); }
.wcard:hover img { transform: scale(1.05); filter: grayscale(0) brightness(0.85); }

.seeall { grid-column: 1 / -1; display: flex; justify-content: space-between; align-items: center; margin-top: 6px; padding-top: 22px; border-top: 1px solid var(--ink-line); gap: 16px; flex-wrap: wrap; }
.seeall .l { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--on-dark-3); }
.seeall a { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-size: 15px; font-weight: 600; color: #fff; }
.seeall a svg { width: 26px; height: auto; color: var(--teal); transition: transform 0.3s var(--ease); }
.seeall a:hover svg { transform: translateX(6px); }

.mega.open .panel.on > * { animation: rlrise 0.5s var(--ease) both; }
.mega.open .panel.on > *:nth-child(1) { animation-delay: 0.04s; }
.mega.open .panel.on > *:nth-child(2) { animation-delay: 0.10s; }
.mega.open .panel.on > *:nth-child(3) { animation-delay: 0.16s; }
.mega.open .panel.on > *:nth-child(4) { animation-delay: 0.22s; }
@keyframes rlrise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .mega.open .panel.on > * { animation: none; } }

/* ===== CLIENTS WALL (Već nam veruju) — centriran naslov + dvoredni marquee ===== */
.gov-pitch { max-width: 760px; }
.gov-pitch .gov-feats { margin-top: 26px; }







/* full-bleed marquee rows */




@keyframes cwMarq { to { transform: translateX(-50%); } }
/* big-name treatment (Scroll Sections .cli) */





@media (prefers-reduced-motion: reduce) { .cw-mq-track { animation: none; flex-wrap: wrap; width: 100%; justify-content: center; } .cw-marquee { mask-image: none; -webkit-mask-image: none; } }

/* ============================================================
   HORIZONTAL GALLERY (portfolio) — pinned scroll (Claude Design)
   ============================================================ */
.rl-gal { position: relative; background: var(--ink); }
.rl-gal-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; flex-direction: column; justify-content: center; }
.rl-gal-head { position: absolute; top: 0; left: 0; right: 0; padding: 36px clamp(20px,5vw,56px); display: flex; justify-content: space-between; align-items: center; z-index: 5; gap: 20px; }
.rl-gal-head .gh-t { font-family: var(--font-display); font-size: clamp(22px,2.6vw,34px); font-weight: 700; letter-spacing: -0.02em; color: var(--on-dark); }
.rl-gal-head .gh-t em { font-style: normal; color: var(--teal); }
.rl-gal-head .gh-cue { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.2em; color: var(--on-dark-3); white-space: nowrap; }
.rl-gal-track { display: flex; gap: 24px; padding: 0 clamp(20px,5vw,56px); will-change: transform; }
.rl-work { flex: none; width: min(46vw, 560px); height: 62vh; border-radius: 18px; overflow: hidden; position: relative; border: 1px solid var(--ink-line); background: var(--ink-2); display: flex; flex-direction: column; justify-content: flex-end; text-decoration: none; }
.rl-work img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; filter: grayscale(0.25) brightness(0.82); transition: transform 0.7s var(--ease), filter 0.5s; }
.rl-work:hover img { transform: scale(1.05); filter: grayscale(0) brightness(1); }
.rl-work .wk-grad { position: absolute; inset: 0; background: linear-gradient(transparent 32%, rgba(8,10,14,.55) 60%, rgba(8,10,14,.94)); }
.rl-work .wk-num { position: absolute; top: 24px; left: 28px; z-index: 3; font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.2em; color: var(--on-dark-2); }
.rl-work .wk-arrow { position: absolute; top: 22px; right: 24px; z-index: 3; width: 40px; height: 40px; border-radius: 11px; border: 1px solid var(--ink-line-2); display: grid; place-items: center; color: var(--on-dark-2); transition: color 0.25s, background 0.25s, border-color 0.25s, transform 0.25s; }
.rl-work:hover .wk-arrow { color: var(--ink); background: var(--teal); border-color: var(--teal); transform: translate(2px,-2px); }
.rl-work .wk-body { position: relative; z-index: 2; padding: 30px; }
.rl-work .wk-cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--teal); }
.rl-work h4 { font-family: var(--font-display); font-size: clamp(22px,2.2vw,30px); font-weight: 700; letter-spacing: -0.02em; line-height: 1.05; color: #fff; margin: 10px 0 0; }
.rl-work .wk-meta { font-family: var(--font-mono); font-size: 12px; color: var(--on-dark-3); margin-top: 12px; }
@media (max-width: 900px) {
  .rl-gal { height: auto !important; }
  .rl-gal-sticky { position: static; height: auto; padding: 28px 0 36px; }
  .rl-gal-head { position: static; padding: 0 24px 8px; }
  .rl-gal-track { overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 12px; -webkit-overflow-scrolling: touch; transform: none !important; }
  .rl-work { width: 80vw; height: 58vh; scroll-snap-align: start; }
}

/* Static grid variant of the work card (portfolio page) */
.rl-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; grid-auto-flow: dense; }
.rl-grid .rl-work { width: auto; height: auto; aspect-ratio: 16/11; }
.rl-grid .rl-work.span2 { grid-column: span 2; aspect-ratio: 21/9; }
@media (max-width: 760px) {
  .rl-grid { grid-template-columns: 1fr; }
  .rl-grid .rl-work, .rl-grid .rl-work.span2 { aspect-ratio: 16/11; grid-column: auto; }
}

/* ============================================================
   OSNIVAČ — macro founder section (Claude Design)
   ============================================================ */
.rl-founder { background: var(--ink-2); color: var(--on-dark); padding: clamp(80px,11vw,150px) 0; position: relative; overflow: hidden; }
.rl-founder .bigyr {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  font-family: var(--font-display); font-size: clamp(200px,34vw,520px); font-weight: 700;
  color: rgba(255,255,255,0.025); letter-spacing: -0.05em; z-index: 0; pointer-events: none; line-height: 1;
}
.rl-founder .wrap { position: relative; z-index: 2; display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(36px,5vw,72px); align-items: center; }
.rl-founder-photo { position: relative; border-radius: 22px; overflow: hidden; aspect-ratio: 4/5; border: 1px solid var(--ink-line); background: #222; }
.rl-founder-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; display: block; }
.rl-founder-photo .badge {
  position: absolute; left: 20px; bottom: 20px; z-index: 3; font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink);
  background: var(--teal); padding: 9px 15px; border-radius: 4px;
}
.rl-founder-copy h2 { font-family: var(--font-display); font-size: clamp(36px,4.8vw,74px); font-weight: 700; letter-spacing: -0.035em; line-height: 0.98; margin: 22px 0 0; color: var(--on-dark); }
.rl-founder-copy h2 em { font-style: normal; color: var(--teal); }
.rl-founder-copy .q { font-size: clamp(18px,1.7vw,23px); line-height: 1.55; color: var(--on-dark-2); margin-top: 28px; max-width: 44ch; }
.rl-founder-copy .sign { margin-top: 34px; display: flex; align-items: center; gap: 16px; }
.rl-founder-copy .sign .ln { width: 36px; height: 1px; background: var(--ink-line-2); }
.rl-founder-copy .sign .nm { font-family: var(--font-display); font-weight: 600; font-size: 18px; color: var(--on-dark); }
.rl-founder-copy .sign .ro { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-dark-3); margin-top: 3px; }
.rl-founder-copy .sign .founder-link { margin-left: auto; width: 42px; height: 42px; border-radius: 11px; border: 1px solid var(--ink-line); display: grid; place-items: center; color: var(--on-dark-2); transition: all 0.22s var(--ease); }
.rl-founder-copy .sign .founder-link:hover { color: var(--ink); background: var(--teal); border-color: var(--teal); transform: translateY(-3px); }
@media (max-width: 860px) {
  .rl-founder .wrap { grid-template-columns: 1fr; gap: 36px; }
  .rl-founder .bigyr { font-size: 46vw; }
}

/* ===== JAVNI SEKTOR — tekst + radial burst (naslovna) ===== */
.gov-merge { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(36px, 5vw, 80px); align-items: center; }
.gov-merge-copy .gov-feats { list-style: none; padding: 0; margin: 26px 0 0; display: grid; gap: 12px; }
.gov-merge-copy .gov-feats li { display: flex; gap: 11px; align-items: flex-start; color: var(--on-dark-2); font-size: 15.5px; line-height: 1.5; }
.gov-merge-copy .gov-feats li svg { flex: 0 0 auto; width: 18px; height: 18px; color: var(--teal); margin-top: 3px; }
.gov-merge-vis { position: relative; min-height: clamp(360px, 42vw, 540px); display: grid; place-items: center; overflow: hidden; border: none; background: radial-gradient(70% 70% at 50% 50%, rgba(255,199,53,0.05), transparent 72%); }
.gov-merge-vis .rla-radial-stage { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.gov-merge-vis .hub { position: relative; z-index: 3; width: 86px; height: 86px; border-radius: 50%; background: var(--teal); display: flex; align-items: center; justify-content: center; box-shadow: 0 12px 40px rgba(255,199,53,0.3); }
.gov-merge-vis .hub svg { width: 42px; height: 42px; color: var(--ink); }
.gov-vis-cap { position: absolute; bottom: 20px; left: 0; right: 0; text-align: center; z-index: 3; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-dark-3); }
@media (max-width: 900px) { .gov-merge { grid-template-columns: 1fr; gap: 40px; } .gov-merge-vis { min-height: 320px; } }

/* ===== USLUGE — stacking cards (Scroll Sections .pcard) ===== */
.rl-stack { margin-top: clamp(48px, 6vw, 72px); position: relative; }
.rl-scard {
  position: sticky; border-radius: 24px; padding: clamp(28px, 4vw, 54px);
  min-height: 54vh; display: flex; flex-direction: column; justify-content: space-between;
  overflow: hidden; box-shadow: 0 30px 60px -40px rgba(12,15,20,0.5);
}
.rl-scard:nth-child(1) { top: 94px; }
.rl-scard:nth-child(2) { top: 108px; }
.rl-scard:nth-child(3) { top: 122px; }
.rl-scard:nth-child(4) { top: 136px; }
.rl-scard:nth-child(5) { top: 150px; }
.rl-scard:nth-child(6) { top: 164px; }
.rl-scard + .rl-scard { margin-top: 28px; }
.sc-head { display: flex; align-items: center; gap: 16px; position: relative; z-index: 2; }
.sc-ico { width: 54px; height: 54px; border-radius: 14px; display: grid; place-items: center; flex: none; background: var(--ink); color: var(--teal); border: 1px solid var(--ink); }
.sc-ico svg { width: 27px; height: 27px; }
.sc-pn { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; opacity: 0.75; }
.sc-body { position: relative; z-index: 2; margin-top: auto; }
.rl-scard h3 { font-family: var(--font-display); font-size: clamp(30px, 4.4vw, 58px); font-weight: 700; letter-spacing: -0.03em; line-height: 0.98; }
.rl-scard p { font-size: clamp(15px, 1.5vw, 18.5px); line-height: 1.5; max-width: 54ch; margin-top: 14px; }
.sc-link { display: inline-flex; align-items: center; gap: 8px; margin-top: 22px; font-family: var(--font-mono); font-size: 13px; font-weight: 600; letter-spacing: 0.02em; transition: gap 0.2s var(--ease); }
.sc-link:hover { gap: 13px; }
.sc-arw { position: absolute; right: clamp(20px, 3vw, 46px); top: clamp(24px, 3.5vw, 48px); width: clamp(70px, 9vw, 120px); color: var(--teal); opacity: 0.9; pointer-events: none; }
.sc-arw svg { width: 100%; height: auto; overflow: visible; }
/* color variants */
.rl-scard.c1 { background: var(--ink); color: #fff; }
.rl-scard.c2 { background: var(--teal); color: var(--ink); }
.rl-scard.c3 { background: #fff; color: var(--ink); border: 1.5px solid var(--ink); }
.rl-scard.c4 { background: var(--ink-2); color: #fff; }
.rl-scard.c5 { background: var(--teal); color: var(--ink); }
.rl-scard.c6 { background: #fff; color: var(--ink); border: 1.5px solid var(--ink); }
.rl-scard.c1 p, .rl-scard.c4 p { color: rgba(243,246,248,0.74); }
.rl-scard.c2 p, .rl-scard.c5 p { color: rgba(12,15,20,0.72); }
.rl-scard.c3 p, .rl-scard.c6 p { color: var(--muted); }
.rl-scard.c2 .sc-arw, .rl-scard.c5 .sc-arw { color: var(--ink); }
.rl-scard.c3 .sc-arw, .rl-scard.c6 .sc-arw { color: var(--teal); }
@media (prefers-reduced-motion: reduce) { .rl-scard { position: static; min-height: 0; } }
@media (max-width: 720px) { .rl-scard { min-height: 0; position: static; } .rl-scard + .rl-scard { margin-top: 16px; } }

/* ===== BLOG — editorial lista (bez slika/kartica) ===== */
.blog-list { margin-top: clamp(40px, 5vw, 60px); border-top: 1px solid var(--line); }
.post-row { display: grid; grid-template-columns: 1fr auto; gap: 20px 40px; align-items: center; padding: clamp(24px, 3vw, 40px) 0; border-bottom: 1px solid var(--line); transition: padding 0.3s var(--ease); }
.post-row .pr-kicker { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.pr-cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--teal-deep); }
.pr-meta { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--muted-2); }
.pr-title { font-family: var(--font-display); font-size: clamp(22px, 2.8vw, 36px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; margin: 13px 0 0; color: var(--text); transition: color 0.25s var(--ease); }
.pr-ex { color: var(--muted); font-size: 15.5px; line-height: 1.55; margin: 11px 0 0; max-width: 72ch; }
.pr-arrow { width: 52px; height: 52px; border-radius: 50%; border: 1px solid var(--line-2); display: grid; place-items: center; color: var(--text); flex: none; transition: background 0.25s var(--ease), color 0.25s, border-color 0.25s, transform 0.25s var(--ease); }
.post-row:hover { padding-left: 12px; }
.post-row:hover .pr-title { color: var(--teal-deep); }
.post-row:hover .pr-arrow { background: var(--teal); border-color: var(--teal); color: var(--ink); transform: translate(3px, -3px); }
/* na tamnoj podlozi (npr. povezani na dnu) */
.on-dark-block .post-row { border-color: var(--ink-line); }
.on-dark-block .pr-title { color: var(--on-dark); }
.on-dark-block .pr-meta { color: var(--on-dark-3); }
.on-dark-block .pr-arrow { border-color: var(--ink-line-2); color: var(--on-dark); }
.pr-more { cursor: default; }
.pr-more .pr-title { font-weight: 400; font-size: clamp(16px,1.4vw,19px); }
.on-dark-block .pr-more .pr-title { color: var(--on-dark-3); }
.on-dark-block .post-row:hover .pr-title { color: var(--teal); }
@media (max-width: 640px) { .post-row { grid-template-columns: 1fr; gap: 14px; } .pr-arrow { display: none; } }

/* ===== PAKETI — flat bordered grid (Vizuelni identitet swatches) ===== */
.rl-plans { margin-top: clamp(48px, 6vw, 64px); display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 6px; overflow: hidden; }
.rl-plan { background: #fff; padding: clamp(26px, 2.6vw, 40px); display: flex; flex-direction: column; position: relative; transition: background 0.25s var(--ease); }
.rl-plan:hover { background: var(--paper-2); }
.rl-plan.featured { background: var(--ink); color: #fff; }
.rl-plan.featured:hover { background: var(--ink); }
.rl-plan-badge { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink); background: var(--teal); padding: 5px 10px; border-radius: 3px; align-self: flex-start; margin-bottom: 16px; }
.rl-plan-name { font-family: var(--font-display); font-size: 23px; font-weight: 700; letter-spacing: -0.02em; }
.rl-plan-desc { color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-top: 10px; }
.rl-plan.featured .rl-plan-desc { color: rgba(255,255,255,0.72); }
.rl-feats { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 11px; }
.rl-feats li { display: flex; gap: 10px; font-size: 14px; color: var(--text); line-height: 1.42; }
.rl-plan.featured .rl-feats li { color: rgba(255,255,255,0.86); }
.rl-feats li svg { flex: 0 0 auto; width: 17px; height: 17px; color: var(--teal-deep); margin-top: 2px; }
.rl-plan.featured .rl-feats li svg { color: var(--teal); }
.rl-plan-link { margin-top: auto; padding-top: 26px; display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--teal-deep); transition: gap 0.2s var(--ease); }
.rl-plan.featured .rl-plan-link { color: var(--teal); }
.rl-plan-link:hover { gap: 13px; }
@media (max-width: 860px) { .rl-plans { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .rl-plans { grid-template-columns: 1fr; } }

/* ===== USLUGE — editorial linije (bez slika/kartica) ===== */
.svc-lines { margin-top: clamp(48px, 6vw, 70px); border-top: 1px solid var(--line); }
.svc-line { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(24px, 4vw, 64px); padding: clamp(34px, 5vw, 60px) 0; border-bottom: 1px solid var(--line); align-items: start; }
.svc-line-head .eyebrow { display: inline-flex; margin-bottom: 16px; color: var(--teal-deep); }
.svc-line-head h2 { font-family: var(--font-display); font-size: clamp(28px, 3.4vw, 46px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.0; }
.svc-line-body p { color: var(--muted); font-size: 16.5px; line-height: 1.6; max-width: 56ch; }
.svc-line-body .svc-list { margin-top: 22px; }
@media (max-width: 820px) { .svc-line { grid-template-columns: 1fr; gap: 16px; } }

/* /usluge overview — svc-line kao link */
a.svc-line { text-decoration: none; color: inherit; transition: padding 0.3s var(--ease); }
a.svc-line:hover { padding-left: 10px; }
.svc-line-head h2 { transition: color 0.25s var(--ease); }
a.svc-line:hover .svc-line-head h2 { color: var(--teal-deep); }
.svc-line-go { display: inline-flex; align-items: center; gap: 8px; margin-top: 16px; font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--teal-deep); }
.svc-line-go svg { transition: transform 0.25s var(--ease); }
a.svc-line:hover .svc-line-go svg { transform: translateX(4px); }

/* ===== Rečnik pojmova — editorial lista ===== */
.recnik { margin-top: clamp(40px, 5vw, 56px); border-top: 1px solid var(--line); }
.rterm { padding: 24px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: baseline; scroll-margin-top: 100px; }
.rterm h3 { font-family: var(--font-display); font-size: 20px; font-weight: 600; letter-spacing: -0.02em; }
.rterm p { color: var(--muted); font-size: 16px; line-height: 1.62; max-width: 70ch; }
.rterm-link { margin-left: 6px; font-family: var(--font-mono); font-size: 12.5px; color: var(--teal-deep); white-space: nowrap; border-bottom: 1px solid rgba(255,199,53,0.5); }
.rterm-link:hover { color: var(--ink); }
@media (max-width: 720px) { .rterm { grid-template-columns: 1fr; gap: 8px; } }

/* Povezane usluge u blog postu (interlink) */
.post-services { margin: 40px 0 0; padding: 24px 26px; border-left: 3px solid var(--teal); background: var(--paper-2); border-radius: 0 10px 10px 0; }
.post-services .ps-k { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--teal-deep); display: block; margin-bottom: 8px; }
.post-services p { margin: 0; font-size: 16px; line-height: 1.6; color: var(--text); }
.post-services a { color: var(--teal-deep); border-bottom: 1px solid rgba(255,199,53,0.5); font-weight: 600; }
.post-services a:hover { color: var(--ink); }

/* Blog post tagovi — chip stil */
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.ptag { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.03em; color: var(--muted); border: 1px solid var(--line-2); padding: 6px 12px; border-radius: 999px; transition: color 0.2s, border-color 0.2s, background 0.2s; }
.ptag:hover { color: var(--teal-deep); border-color: var(--teal); background: var(--paper-2); }

/* ===== Usluge — 2-col editorial index (bez kartica/ikonica) + chevron animacija ===== */
.rl-svc-index { margin-top: clamp(40px, 5vw, 60px); display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.svci { display: grid; grid-template-columns: 44px 1fr 30px; align-items: center; gap: 20px; padding: clamp(22px, 2.4vw, 32px) 8px; border-bottom: 1px solid var(--line); text-decoration: none; color: var(--text); position: relative; transition: background 0.35s var(--ease); }
.svci:nth-child(odd) { border-right: 1px solid var(--line); padding-right: clamp(24px, 3vw, 48px); }
.svci:nth-child(even) { padding-left: clamp(24px, 3vw, 48px); }
.svci::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--teal); transform: scaleY(0); transition: transform 0.35s var(--ease); }
.svci:hover { background: linear-gradient(90deg, rgba(255,199,53,0.08), transparent 60%); }
.svci:hover::before { transform: scaleY(1); }
.svci-n { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.1em; color: var(--muted-2); align-self: start; padding-top: 5px; }
.svci-main { display: flex; flex-direction: column; min-width: 0; }
.svci-title { font-family: var(--font-display); font-size: clamp(22px, 2.1vw, 30px); font-weight: 600; letter-spacing: -0.025em; line-height: 1.05; transition: color 0.25s var(--ease); }
.svci:hover .svci-title { color: var(--teal-deep); }
.svci-desc { color: var(--muted); font-size: 14px; line-height: 1.45; margin-top: 8px; }
.svci-arrow { color: var(--muted-2); transition: color 0.25s var(--ease); }
.svci-arrow svg { width: 28px; height: auto; display: block; overflow: visible; }
.svci:hover .svci-arrow { color: var(--teal-deep); }
.svci:hover .svci-arrow svg { animation: svciChev 0.85s var(--ease) infinite; }
@keyframes svciChev { 0% { transform: translateX(0); } 50% { transform: translateX(6px); } 100% { transform: translateX(0); } }
@media (prefers-reduced-motion: reduce) { .svci:hover .svci-arrow svg { animation: none; } }
@media (max-width: 760px) { .rl-svc-index { grid-template-columns: 1fr; } .svci:nth-child(odd) { border-right: none; padding-right: 8px; } .svci:nth-child(even) { padding-left: 8px; } .svci-desc { display: none; } }

/* ---------- O nama macro + principi (naslovna, jedna sekcija) ---------- */
.about-macro { font-family: var(--font); font-weight: 600; font-size: clamp(26px,3.5vw,46px); line-height: 1.2; letter-spacing: -0.02em; color: var(--ink); margin: 22px 0 0; }
.principi-block { margin-top: clamp(64px,9vw,120px); }
.about-macro-foot { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 22px 48px; margin-top: clamp(30px,4vw,52px); padding-top: clamp(26px,3vw,36px); border-top: 1px solid var(--line); }
.about-macro-sub { color: var(--muted); font-size: clamp(15px,1.15vw,16.5px); line-height: 1.6; max-width: 60ch; margin: 0; }
.about-macro-foot .svc-line-go { white-space: nowrap; }
@media (max-width: 640px) { .about-macro-foot { flex-direction: column; align-items: flex-start; } }

/* ---------- Paketi (naslovna) — horizontalna galerija panela ---------- */
.rl-gal-head .gh-l { display: flex; flex-direction: column; gap: 10px; }
.pkg-gal .rl-gal-track { align-items: stretch; }
.pkg-panel { position: relative; flex: none; width: min(46vw, 520px); height: auto; min-height: 500px; display: flex; flex-direction: column; justify-content: flex-start; gap: clamp(22px,2.6vw,32px); padding: clamp(32px,3.2vw,50px); border-radius: 18px; border: 1px solid var(--ink-line); background: var(--ink-2); overflow: hidden; text-decoration: none; transition: transform .4s var(--ease), border-color .3s; }
.pkg-panel::before { content: attr(data-n); position: absolute; right: -8px; bottom: -54px; font-family: var(--font); font-weight: 700; font-size: 260px; line-height: 1; color: rgba(255,255,255,0.035); pointer-events: none; }
.pp-top { position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.pp-no { font-family: var(--font-mono); font-size: 13px; letter-spacing: .2em; color: var(--on-dark-3); }
.pp-badge { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); background: var(--teal); padding: 6px 11px; border-radius: 100px; }
.pp-feats { position: relative; z-index: 2; list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.pp-feats li { display: flex; align-items: flex-start; gap: 11px; font-size: clamp(14.5px,1.15vw,17px); line-height: 1.4; color: var(--on-dark); }
.pp-feats li svg { flex: 0 0 auto; width: 17px; height: 17px; margin-top: 2px; color: var(--teal); }
.pp-mid { position: relative; z-index: 2; margin-top: auto; }
.pp-name { font-family: var(--font); font-weight: 600; font-size: clamp(30px,3.4vw,46px); line-height: 1; letter-spacing: -0.02em; color: var(--paper); margin: 0; }
.pp-desc { margin: 16px 0 0; font-size: clamp(15px,1.2vw,17px); line-height: 1.55; color: var(--on-dark-2); max-width: 34ch; }
.pp-go { position: relative; z-index: 2; display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--teal); }
.pp-go svg { width: 24px; height: 24px; transition: transform .3s var(--ease); }
.pkg-panel:hover { transform: translateY(-5px); border-color: rgba(255,199,53,0.42); }
.pkg-panel:hover .pp-go svg { transform: translateX(6px); }
.pkg-panel-feat { border-color: rgba(255,199,53,0.5); background: linear-gradient(160deg, rgba(255,199,53,0.08), var(--ink-2)); }
.pkg-panel-cta { background: linear-gradient(150deg, #3a3208, var(--ink-2)); }
.pkg-panel-cta .pp-name { color: var(--teal); }
@media (max-width: 900px) {
  .pkg-panel { width: 82vw; min-height: 0; }
}

/* ---------- Klijenti (naslovna, svetlo) — sticky dvokolonski zid ---------- */
.cl-wrap { display: grid; grid-template-columns: 0.85fr 1.35fr; gap: clamp(36px,6vw,90px); align-items: start; }
.cl-side { position: sticky; top: calc(var(--nav-h) + 30px); }
.cl-side .section-lead { margin-top: 18px; }
.cl-side .svc-line-go { margin-top: 26px; }
.cl-list { border-top: 1px solid var(--line); }
.cl-row { display: flex; align-items: baseline; justify-content: space-between; gap: 18px; padding: clamp(14px,1.5vw,19px) 0; border-bottom: 1px solid var(--line); transition: padding-left .3s var(--ease); }
.cl-rname { font-family: var(--font); font-weight: 500; font-size: clamp(18px,1.6vw,22px); letter-spacing: -0.01em; color: var(--ink); transition: color .3s var(--ease); }
.cl-row-feat { padding: clamp(18px,2vw,26px) 0; }
.cl-row-feat .cl-rname { font-weight: 600; font-size: clamp(28px,3.4vw,46px); line-height: 1; }
.cl-rend { display: inline-flex; align-items: center; gap: 14px; flex: 0 0 auto; }
.cl-rcat { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); white-space: nowrap; }
.cl-rarrow svg { display: block; width: 18px; height: 18px; color: var(--teal-deep); opacity: 0; transform: translate(-6px,2px); transition: all .3s var(--ease); }
.cl-row-feat .cl-rarrow svg { width: 22px; height: 22px; }
.cl-row:hover { padding-left: 10px; }
.cl-row:hover .cl-rname { color: var(--teal-deep); }
.cl-row:hover .cl-rarrow svg { opacity: 1; transform: translate(0,0); }
.cl-row-cta { border-bottom: none; }
.cl-row-cta .cl-rname { color: var(--teal-deep); }
@media (max-width: 900px) {
  .cl-wrap { grid-template-columns: 1fr; gap: 30px; }
  .cl-side { position: static; }
}
@media (max-width: 520px) { .cl-rcat { display: none; } }

/* ---------- Mega-meni: CTA kartica (Sledeći projekat možete biti vi) ---------- */
.wcard-cta { background: linear-gradient(150deg, #3a3208, var(--ink-2)); justify-content: flex-end; }
.wcard-cta .wc-badge { position: absolute; top: 18px; left: 18px; z-index: 2; font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); background: var(--teal); padding: 6px 11px; border-radius: 100px; }
.wcard-cta .wc-loop { position: absolute; right: -22px; top: 50%; transform: translateY(-50%); width: 150px; opacity: .14; color: var(--teal); z-index: 1; }
.wcard-cta .wc-loop svg { width: 100%; height: auto; }
.wcard-cta h4 { position: relative; z-index: 2; font-size: 24px; line-height: 1.05; }
.wcard-cta .wc-link { position: relative; z-index: 2; margin-top: 16px; display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--teal); }
.wcard-cta .wc-link svg { width: 26px; height: auto; transition: transform .3s var(--ease); }
.wcard-cta:hover { transform: translateY(-4px); border-color: rgba(255,199,53,0.4); }
.wcard-cta:hover .wc-link svg { transform: translateX(6px); }
