/* =========================================================
   BESYS — style.css
   Enterprise clean (2026)
   ========================================================= */

/* =========================================================
   RESET & BASE
   ========================================================= */
*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:#f4f6fa;
  color:#222;
  line-height:1.7;
  font-size:1.02rem;
  min-height:100vh;
}

a{ color:inherit; text-decoration:none; }
img, picture, video, svg{ display:block; max-width:100%; height:auto; }

/* =========================================================
   DESIGN TOKENS
   ========================================================= */
:root{
  --color-primary:#123153;
  --color-accent:#1E88E5;
  --color-muted:#5b6b7c;

  --bg:#f4f6fa;
  --surface:#ffffff;
  --text:#222;

  --content-max:1120px;
  --text-max:72ch;

  --radius:14px;
  --shadow:0 8px 30px rgba(2,31,63,.08);
  --shadow-soft:0 6px 18px rgba(2,31,63,.06);
}

/* =========================================================
   LAYOUT
   ========================================================= */
.page{ width:100%; }

.container{
  max-width:var(--content-max);
  margin:0 auto;
  padding:0 20px;
}

.container p,
.container li{ max-width:var(--text-max); }

.section{ padding:clamp(2.5rem,4vw,4rem) 0; }
.section.alt{ background:var(--surface); }
.section.tight{ padding-block:clamp(1.25rem,2.5vw,2rem); }

/* =========================================================
   TYPOGRAPHY
   ========================================================= */
h1,h2,h3{ margin-bottom:1rem; }

.lead{
  font-size:clamp(1.05rem,1.6vw,1.25rem);
  color:var(--color-muted);
}

.muted{ color:var(--color-muted); }

.microcopy{
  margin-top:.35rem;
  color:var(--color-primary);
  font-weight:700;
  font-size:.95rem;
}
/* Utility spacing (keep HTML clean, enterprise maintenance) */
.m-0{ margin:0 !important; }
.mt-14{ margin-top:14px !important; }
.mt-16{ margin-top:16px !important; }
.mt-neg-6{ margin-top:-6px !important; }

/* =========================================================
   COMPONENTS
   ========================================================= */
.card{
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:1.25rem;
  transition:.2s transform,.2s box-shadow;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}

.cards-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
/* Trust strip (About page) */
.trust-strip{ padding-block:clamp(1.25rem,2.5vw,2rem); }

.trust-grid{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  margin-top:12px;
}

.trust-item{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(2,31,63,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:14px 16px;
}

.trust-item .kicker{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  color:var(--color-primary);
}

.trust-item .kicker .i{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(18,49,83,.06);
  border:1px solid rgba(2,31,63,.08);
  color:var(--color-primary);
  overflow:hidden;
}
.trust-item .kicker .i .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}

.trust-item p{
  margin-top:6px;
  color:var(--color-muted);
  max-width:unset;
}

.list-clean{ list-style:none; padding:0; margin:0; }

/* Tech / brand grid (Index) */
.tech-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:12px;
  margin-top:12px;
}

.tech-item{
  background:var(--surface);
  border:1px solid rgba(15,23,42,.08);
  border-radius:12px;
  padding:10px 12px;
  font-weight:700;
  letter-spacing:.2px;
  box-shadow:var(--shadow-soft);
}

@media (max-width:600px){
  .tech-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:700;
  border-radius:12px;
  padding:.85rem 1.15rem;
  border:1px solid #cfd8e3;
  background:rgba(255,255,255,.85);
  color:var(--color-primary);
  cursor:pointer;
  box-shadow:0 6px 18px rgba(2,31,63,.06);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease, background .15s ease;
  min-height:48px;
}

.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 26px rgba(2,31,63,.10);
}

.btn:active{
  transform:translateY(0);
  box-shadow:0 6px 18px rgba(2,31,63,.06);
}

.btn:focus-visible{
  outline:3px solid rgba(30,136,229,.55);
  outline-offset:3px;
}

.btn-primary{
  background:var(--color-accent);
  color:#fff;
  border:1px solid transparent;
  box-shadow:0 10px 26px rgba(30,136,229,.22);
}

.btn-primary:hover{
  filter:brightness(.97);
  box-shadow:0 14px 34px rgba(30,136,229,.26);
}

.btn-ghost{
  background:transparent;
  border:1px solid #cfd8e3;
  box-shadow:none;
}

.btn-ghost:hover{
  background:rgba(30,136,229,.06);
  box-shadow:0 6px 18px rgba(2,31,63,.06);
}

/* CTA */
.cta-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:700;
  border-radius:12px;
  padding:.85rem 1.15rem;
  background:var(--color-accent);
  color:#fff;
  border:1px solid transparent;
  box-shadow:0 10px 26px rgba(30,136,229,.22);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
  min-height:48px;
}
.cta-button:hover{
  filter:brightness(.97);
  transform:translateY(-1px);
  box-shadow:0 14px 34px rgba(30,136,229,.26);
}
.cta-button:active{
  transform:translateY(0);
  box-shadow:0 10px 26px rgba(30,136,229,.20);
}
.cta-button:focus-visible{
  outline:3px solid rgba(30,136,229,.55);
  outline-offset:3px;
}

.cta-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}

/* Utility: center CTA rows without inline styles */
.cta-center{ justify-content:center; }

/* =========================================================
   NAVIGATION
   ========================================================= */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
}

.nav-container{
  position:relative; /* za mobile dropdown bez hardcoded top vrijednosti */
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 18px;
}

.brand{
  display:flex;
  align-items:center;
}

.brand picture{
  display:flex;
  align-items:center;
}

/* Logo u headeru: nikad ne rasteži — uvijek čuvaj omjer */
.brand img,
.brand svg{
  height:120px;         /* desktop: +~50% (čitkije, premium) */
  width:auto;
  max-width:320px;     /* malo više prostora za primary logo */
  object-fit:contain;
  flex:0 0 auto;
}

/* Ako je logo inline SVG, osiguraj ispravno skaliranje */
.brand svg{ display:block; }

.nav-menu{
  list-style:none;
  display:flex;
  gap:18px;
  align-items:center;
}

.nav-menu a{
  font-weight:700;
  color:var(--color-primary);
  position:relative;
}

.nav-menu a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-6px;
  height:2px;
  background:var(--color-accent);
  transform:scaleX(0);
  transition:transform .2s ease;
}

.nav-menu a:hover::after,
.nav-menu a.active::after{
  transform:scaleX(1);
}

.nav-menu a.active{
  color:var(--color-primary);
}

/* Hamburger */
.hamburger{
  display:none;
  background:none;
  border:0;
  width:40px;
  height:40px;
  position:relative;
}
.hamburger span{
  position:absolute;
  left:8px;
  right:8px;
  height:2px;
  background:var(--color-primary);
}
.hamburger span:nth-child(1){ top:12px; }
.hamburger span:nth-child(2){ top:19px; }
.hamburger span:nth-child(3){ top:26px; }

@media (max-width:900px){
  .brand img,
  .brand svg{
    height: 60px;         /* mobile/tablet: veće da ne izgleda "stisnuto" */
    max-width:260px;
  }
  .hamburger{ display:block; }

  .nav-menu{
    list-style:none;
    display:none;
    gap:12px;
    position:absolute;
    top:calc(100% + 10px);
    right:14px;
    background:var(--surface);
    border-radius:16px;
    box-shadow:0 18px 46px rgba(2,31,63,.22);
    padding:16px;
    min-width:220px;
    flex-direction:column;
  }
  .nav-menu.active{ display:flex; }

  .nav-menu a.active{
    background:rgba(30,136,229,.12);
    border-radius:8px;
    padding:6px 10px;
  }
}

/* =========================================================
   INTRO (Enterprise) — premium corporate
   ========================================================= */
.page-intro{
  padding:clamp(2.25rem,4.2vw,3.25rem) 0 clamp(1.25rem,2.2vw,2rem);
  background:
    radial-gradient(900px 520px at 12% 10%, rgba(30,136,229,.10), transparent 55%),
    radial-gradient(760px 460px at 90% 10%, rgba(18,49,83,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(244,246,250,0));
  border-bottom:1px solid rgba(2,31,63,.06);
}

.intro-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:26px;
  align-items:start;
}

/* Typo polish unutar intro sekcije (sigurno, bez “vendor lock-in-a”) */
.page-intro h1{
  font-size:clamp(1.9rem,2.6vw,2.6rem);
  letter-spacing:-0.02em;
  line-height:1.15;
  margin-bottom:.75rem;
}
.page-intro .lead{
  max-width:62ch;
  color:var(--color-muted);
}

/* Desni panel: enterprise card feel */
.intro-panel{
  background:rgba(255,255,255,.86);
  border-radius:var(--radius);
  padding:18px;
  border:1px solid rgba(2,31,63,.08);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}


/* Checklist (reusable) */
.checklist{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}

.checklist li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:#1f2b3a;
}

.checklist .check{
  display:inline-flex;
  width:22px;
  height:22px;
  flex:0 0 22px;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:rgba(30,136,229,.10);
  color:var(--color-primary);
  font-weight:900;
  margin-top:2px;
}

/* Panel uses checklist styling without redefining list appearance */
.intro-panel ul{ margin:0; }

@media (max-width:900px){
  .intro-grid{ grid-template-columns:1fr; }
  .page-intro{ padding:clamp(2rem,6vw,2.5rem) 0 1.25rem; }
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:linear-gradient(180deg,var(--color-primary),#0e2a4b);
  color:#fff;
  margin-top:48px;
}

/* Footer logo: isto pravilo — bez razvlačenja */
.site-footer .footer-logo img,
.site-footer .footer-logo svg,
.site-footer .brand img,
.site-footer .brand svg{
  height:44px;
  width:auto;
  max-width:220px;
  object-fit:contain;
  display:block;
}

@media (max-width:900px){
  .site-footer .footer-logo img,
  .site-footer .footer-logo svg,
  .site-footer .brand img,
  .site-footer .brand svg{
    height:38px;
    max-width:200px;
  }
}

.footer-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(4,1fr);
  padding:32px 20px;
}

.footer-grid a{ color:#DCE7F7; }
.footer-grid a:hover{ text-decoration:underline; }

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:12px 20px;
  text-align:center;
}

@media (max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .footer-grid{ grid-template-columns:1fr; }
}

/* =========================================================
   SCROLL TO TOP
   ========================================================= */
.scroll-to-top{
  position:fixed;
  right:16px;
  bottom:16px;
  width:48px;
  height:48px;
  border-radius:999px;
  background:var(--color-accent);
  color:#fff;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999;
}
.scroll-to-top.show{ display:flex; }

/* Backward-compatible alias (pages use .scroll-top) */
.scroll-top{ 
  position:fixed;
  right:16px;
  bottom:16px;
  width:48px;
  height:48px;
  border-radius:999px;
  background:var(--color-accent);
  color:#fff;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999;
}
.scroll-top.show{ display:flex; }

/* =========================================================
   ACCESSIBILITY & MOTION
   ========================================================= */
[id]{ scroll-margin-top:80px; }

:where(a,button):focus-visible{
  outline:3px solid var(--color-accent);
  outline-offset:2px;
}

@media (prefers-reduced-motion:reduce){
  *{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* =========================================================
   SKIP LINK (Premium, focus-only)
   ========================================================= */
.skip-link{
  position:fixed;
  top:12px;
  left:-999px;
  z-index:2000;
  background:var(--color-primary);
  color:#fff;
  padding:.6rem 1rem;
  border-radius:10px;
  font-weight:700;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.skip-link:focus,
.skip-link:focus-visible{
  left:12px;
}

/* Anchor target for skip link */
.skip-target{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
}

/* =========================================================
   INDEX — Premium corporate polish
   ========================================================= */

/* Hero: više fokusa, više “težine”, premium background */
.hero.page-hero{
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  text-align: left;
  background:
    radial-gradient(900px 520px at 12% 10%, rgba(30,136,229,.10), transparent 55%),
    radial-gradient(760px 460px at 90% 10%, rgba(18,49,83,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(244,246,250,0));
  border-bottom: 1px solid rgba(2,31,63,.06);
}
/* Badge row (ako je na indexu u formi <ul class="badge-row">) */
.badge-row{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0;
  margin:14px 0 18px;
}
.badge-row .badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:.45rem .7rem;
  border-radius:999px;
  border:1px solid rgba(2,31,63,.10);
  background:rgba(255,255,255,.75);
  box-shadow:0 4px 14px rgba(2,31,63,.06);
  font-weight:700;
  color:var(--color-primary);
  font-size:.92rem;
}

/* Badge-row icons: always outline (prevent black fills) */
.badge-row .badge .ic,
.badge-row .badge svg{
  width:16px;
  height:16px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}
.badge-row .badge .ic path,
.badge-row .badge svg path{
  fill:none;
}

/* Mali “trust” tekst ispod CTA-a */
.trust-note{
  margin-top:10px;
  color:var(--color-muted);
  font-size:.95rem;
}

/* Testimonials / citati (generički, ne kvari druge stranice) */
.quote{
  position:relative;
  padding:1.25rem;
  border-radius:var(--radius);
  background:rgba(255,255,255,.86);
  border:1px solid rgba(2,31,63,.08);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.quote blockquote{ margin:0; }
.quote blockquote p{
  margin:0;
  font-weight:650;
  color:#1f2b3a;
  line-height:1.55;
}
.quote::before{
  content:"\201C";
  position:absolute;
  top:10px;
  left:14px;
  font-size:38px;
  line-height:1;
  color:rgba(30,136,229,.25);
  font-weight:900;
}
.quote .who{
  margin-top:12px;
  color:var(--color-muted);
  font-weight:800;
  font-size:.92rem;
}

.testimonials{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}

/* Mikro-separator između sekcija (opcionalno, samo ako dodaš class) */
.section.separator{
  border-top:1px solid rgba(2,31,63,.06);
}

.hero.page-hero .container{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 26px;
  align-items: start;
}

.hero.page-hero h1{
  font-size: clamp(1.9rem, 2.6vw, 2.6rem);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: .75rem;
}

.hero.page-hero .lead{
  max-width: 62ch;
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
}

/* Desni “proces” panel: izgleda kao enterprise feature */
.hero.page-hero .intro-panel,
.hero.page-hero .card{
  border: 1px solid rgba(2,31,63,.08);
}

/* CTA gumbi: malo više premium osjećaja */
.hero-cta .btn,
.cta-row .btn{
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.hero-cta .btn:hover,
.cta-row .btn:hover{
  transform: translateY(-1px);
}

/* Alias za .btn.outline jer ga koristiš u HTML-u */
.btn.outline{
  background: transparent;
  border: 1px solid #cfd8e3;
}
.btn.outline:hover{
  background: rgba(30,136,229,.06);
}

/* Sekcije: elegantniji naslovi + malo “razmaka kao u korporaciji” */
.section .h2, .section h2{
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin-bottom: 14px;
}

.section .container > p{
  color: var(--color-muted);
}

/* Kartice: ujednači visine i klikabilnost */
.cards-grid .card,
.feature-grid .feature{
  border: 1px solid rgba(2,31,63,.07);
}

/* Feature grid: uredniji layout */
.feature-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  align-items:stretch;
}
.feature{
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  padding: 1.25rem;
  min-height: 180px;
  height:100%;
  display:flex;
  flex-direction:column;
}
.feature h3{ margin:0 0 .5rem; }
.feature p{ margin:0; }

/* Ikone: da ne izgledaju “emoji random”, nego kao badge */
.feature .icon{
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:rgba(18,49,83,.06);
  border:1px solid rgba(2,31,63,.08);
  margin-bottom:.75rem;
  color:var(--color-primary);
  overflow:hidden;
}
.feature .icon .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}

/* Mobile: hero ide u jednu kolonu */
@media (max-width:900px){
  .hero.page-hero .container{
    grid-template-columns: 1fr;
  }
  .hero.page-hero{
    text-align: left;
  }
}

/* =========================================================
   FORMS (Enterprise)
   ========================================================= */
/* Works with .form-modern (preferred) and legacy .ref-form */
.form-modern,
.ref-form{
  display:grid;
  gap:14px;
}

/* Input groups with icons — gutter layout (icon outside input) */
.input-icon-group{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Textarea group aligns to top */
.input-icon-group.is-textarea{
  align-items:flex-start;
}

.input-icon{
  flex:0 0 40px;
  width:40px;
  height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(30,136,229,.08);
  border:1px solid rgba(30,136,229,.18);
  color:var(--text);
  pointer-events:none;
  overflow:hidden;
}

.input-icon .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}

/* Slight top nudge for textarea icon */
.input-icon-group.is-textarea .input-icon{
  margin-top:2px;
}

/* Base inputs */
.form-modern input[type="text"],
.form-modern input[type="email"],
.form-modern input[type="tel"],
.form-modern input[type="url"],
.form-modern select,
.form-modern textarea,
.ref-form input[type="text"],
.ref-form input[type="email"],
.ref-form input[type="tel"],
.ref-form input[type="url"],
.ref-form select,
.ref-form textarea{
  width:100%;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid #cfd8e3;
  background:#fff;
  color:var(--text);
  outline:none;
  transition: border-color .15s ease, box-shadow .15s ease;
}

/* No extra left padding needed (icon is outside the field) */
.input-icon-group input,
.input-icon-group select,
.input-icon-group textarea{
  padding-left:14px;
}

.ref-form textarea,
.form-modern textarea{
  min-height:120px;
  resize:vertical;
}

.ref-form input::placeholder,
.ref-form textarea::placeholder,
.form-modern input::placeholder,
.form-modern textarea::placeholder{
  color:#94a3b8;
}

.ref-form input:focus,
.ref-form select:focus,
.ref-form textarea:focus,
.form-modern input:focus,
.form-modern select:focus,
.form-modern textarea:focus{
  border-color: rgba(30,136,229,.55);
  box-shadow: 0 0 0 4px rgba(30,136,229,.12);
}

/* Invalid state (ti već postavljaš aria-invalid na blur) */
[aria-invalid="true"]{
  border-color: rgba(185,28,28,.55) !important;
  box-shadow: 0 0 0 4px rgba(185,28,28,.10) !important;
}

/* Consent row */
.ref-consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid #e6eef7;
  background:rgba(2, 28, 64, .02);
}

.ref-consent input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color: var(--color-accent);
}

.ref-consent a{ text-decoration:underline; }

/* Submit button disabled state */
button.cta-button[disabled]{
  opacity:.55;
  cursor:not-allowed;
  filter:saturate(.85);
}

.contact-list .contact-ic{
  flex:0 0 34px;
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:rgba(18,49,83,.06);
  border:1px solid rgba(2,31,63,.08);
  color:var(--color-primary);
  line-height:1;
  overflow:hidden;
}

.contact-list .contact-ic .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}

/* Map embed (Kontakt) — make iframe feel like a premium card */
.map-embed{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(2,31,63,.08);
  box-shadow:0 10px 26px rgba(2,31,63,.08);
  background:rgba(255,255,255,.9);
}
.map-embed iframe{
  width:100%;
  height:320px;
  border:0;
  display:block;
}
.map-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
.map-actions .btn{
  min-height:44px;
  padding:.7rem 1rem;
}

@media (max-width:900px){
  .map-embed iframe{ height:260px; }
}

/* =========================================================
   USLUGE — Cards, SVG ikone, proces lista (2026)
   ========================================================= */

/* Service cards — SVG icons (enterprise outline, hard-limited size) */
.service-card .icon{
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:rgba(18,49,83,.06);
  border:1px solid rgba(2,31,63,.08);
  margin-bottom:.75rem;
  color:var(--color-primary);
  overflow:hidden; /* hard stop: ništa ne smije “pobjeći” */
}

/* Hard limit SVG-a (sprječava “divljanje” i crne mrlje) */
.service-card .icon svg,
.service-card .icon .ic{
  width:18px !important;
  height:18px !important;
  max-width:18px;
  max-height:18px;
  display:block;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}

/* “Kako izgleda suradnja (3 koraka)” — poravnanje s ostatkom stranice */
.process-list{
  margin:12px 0 0;
  padding-left:1.25rem; /* kontrolirani indent, ne browser default */
}
.process-list li{
  margin:.45rem 0;
}

/* =========================================================
   KARIJERE — accordion / FAQ + benefits list (2026)
   ========================================================= */

details.accordion{
  background:#fff;
  border-radius:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  padding:16px 20px;
  margin:12px 0;
  border:1px solid rgba(0,0,0,.06);
}

details.accordion[open]{
  box-shadow:0 10px 28px rgba(0,0,0,.08);
}

details.accordion>summary{
  cursor:pointer;
  list-style:none;
  font-weight:700;
  font-size:1.05rem;
  color:var(--color-primary,#0C2746);
  display:flex;
  align-items:center;
  gap:.6rem;
}

details.accordion>summary::-webkit-details-marker{ display:none; }

details.accordion>summary:after{
  content:'▾';
  margin-left:auto;
  transition:transform .2s ease;
}

details.accordion[open]>summary:after{ transform:rotate(180deg); }

/* Helperi specifični za ovu stranicu */
.benefits-list{
  margin:.5rem 0 0;
  padding-left:1.2rem;
  line-height:1.8;
}
.benefits-list li{ margin:.35rem 0; }
/* =========================================================
   PORUKA POSLANA — confirmation page (2026)
   ========================================================= */

/* Full-height center layout */
.confirm-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
}

.confirm-card{
  width:min(720px, 92vw);
  text-align:center;
}

.success-icon{
  width:86px;
  height:86px;
  border-radius:999px;
  display:grid;
  place-items:center;
  margin:0 auto 16px;
  background:
    radial-gradient(circle at 30% 30%, rgba(30,136,229,.18), rgba(2,31,63,.08));
  border:1px solid rgba(0,0,0,.06);
}

.success-icon picture,
.success-icon img{
  width:56px;
  height:56px;
}

.confirm-card h1{
  margin:8px 0 10px;
  color:var(--color-primary);
  font-size:clamp(26px, 4vw, 34px);
  letter-spacing:-0.02em;
  line-height:1.12;
}

.confirm-card p{ margin:0 0 18px; }

.muted-small{
  font-size:12px;
  color:var(--color-muted);
  margin-top:12px;
}

.btns{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:8px;
}

/* Secondary buttons inside confirmation page */
.btn.btn-ghost{ padding:.75rem 1.1rem; border-radius:12px; font-weight:700; }

/* Inline SVG in CTA buttons */
.cta-button .ic,
.btn .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}


/* =========================================================
   PODSTRANICE USLUGA — FAQ/accordion + povezano grid (2026)
   ========================================================= */

/* Reuse the same visual language as Karijere accordion */
.page-section details.accordion{
  background:#fff;
  border-radius:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  padding:14px 18px;
  margin:12px 0;
  border:1px solid rgba(0,0,0,.06);
}
.page-section details.accordion[open]{
  box-shadow:0 10px 28px rgba(0,0,0,.08);
}
.page-section details.accordion>summary{
  cursor:pointer;
  list-style:none;
  font-weight:800;
  color:var(--color-primary,#0C2746);
  display:flex;
  align-items:center;
  gap:.6rem;
}
.page-section details.accordion>summary::-webkit-details-marker{ display:none; }
.page-section details.accordion>summary:after{
  content:'▾';
  margin-left:auto;
  transition:transform .2s ease;
}
.page-section details.accordion[open]>summary:after{ transform:rotate(180deg); }
.page-section details.accordion p{ margin-top:10px; color:var(--color-muted); }

/* Povezano grid: remove inline styles and keep spacing consistent */
.why-grid{ margin-top:18px; }

/* Scroll-top SVG icon (pages that use .scroll-top) */
.scroll-top .ic{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.95;
}
/* =========================================================
   MOBILE FIX: kontakt ikone + forme (kontakt/karijera/reference)
   ========================================================= */
@media (max-width: 680px) {

  /* 1) Kontakt ikone (SVG/IMG) – hard-limit da ne “eksplodiraju” na iOS-u */
  .contact-card svg,
  .contact-details svg,
  .contact-list svg,
  .contact-info svg,
  .kontakt-card svg,
  .kontakt-podaci svg,
  .info-row svg,
  .info-item svg {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    flex: 0 0 20px !important;
  }

  /* Ako su ikone u wrapperu (.contact-ic / .icon) – drži wrapper stabilan */
  .contact-list .contact-ic,
  .contact-card .icon,
  .contact-details .icon,
  .contact-list .icon,
  .contact-info .icon,
  .kontakt-card .icon,
  .kontakt-podaci .icon,
  .info-row .icon,
  .info-item .icon {
    width: 36px !important;
    height: 36px !important;
    flex: 0 0 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px;
    overflow: hidden;
  }

  /* A ako je ikona zapravo <img> ili inline SVG unutar wrappera */
  .contact-list .contact-ic svg,
  .contact-list .contact-ic img,
  .contact-card .icon svg,
  .contact-card .icon img,
  .contact-details .icon svg,
  .contact-details .icon img,
  .kontakt-card .icon svg,
  .kontakt-card .icon img,
  .kontakt-podaci .icon svg,
  .kontakt-podaci .icon img,
  .info-row .icon svg,
  .info-row .icon img,
  .info-item .icon svg,
  .info-item .icon img {
    width: 18px !important;
    height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
  }

  /* 2) Forme – bez desktop “2 stupca” i bez bježanja textarea */
  form,
  .form,
  .form-wrap,
  .form-card,
  .form-grid,
  .form-row,
  .grid-form,
  .kontakt-forma,
  .career-form,
  .reference-form,
  .form-modern,
  .ref-form {
    max-width: 100%;
  }

  /* Ako negdje koristiš grid/2 stupca — na mobitelu 1 stupac */
  .form-grid,
  .grid-form,
  form .grid,
  form .row {
    display: grid;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Najbitnije: input+ikona wrapper (tvoj .input-icon-group) na mobitelu ide kao grid */
  .input-icon-group{
    display: grid !important;
    grid-template-columns: 44px 1fr !important;
    align-items: center !important;
    gap: 10px !important;
  }
  .input-icon-group.is-textarea{
    align-items: start !important;
  }
  .input-icon-group > input,
  .input-icon-group > select,
  .input-icon-group > textarea{
    width: 100% !important;
    min-width: 0 !important;
  }

  /* iOS: sprječava auto-zoom + daje “app” feel */
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="url"],
  input[type="search"],
  input[type="number"],
  select,
  textarea {
    width: 100% !important;
    box-sizing: border-box !important;
    font-size: 16px !important;
    line-height: 1.35 !important;
    padding: 12px 14px !important;
    border-radius: 12px !important;
  }

  textarea {
    min-height: 120px !important;
    resize: vertical;
  }

  /* Checkbox + label uredno */
  input[type="checkbox"] {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
  }

  label {
    line-height: 1.35;
  }
}

/* Extra-tight phones: ako je ekran baš uzak, stackaj ikonu iznad polja */
@media (max-width: 420px){
  .input-icon-group{
    grid-template-columns: 1fr !important;
  }
  .input-icon{
    margin-bottom: 6px;
  }
}
/* =========================================================
   SERVICE PAGES – BESYS (scoped)
   ========================================================= */
.page-service .container {
  max-width: 1100px;
}

.hero-service {
  padding: 64px 0 40px;
}

.hero-service .hero__grid {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 28px;
  align-items: start;
}

.hero-service .eyebrow {
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 12px;
  opacity: 0.8;
  margin: 0 0 10px;
}

.hero-service h1 {
  margin: 0 0 12px;
  line-height: 1.08;
}

.hero-service .lead {
  font-size: 18px;
  line-height: 1.55;
  margin: 0 0 18px;
  max-width: 62ch;
}

.hero-service .hero__cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin: 14px 0 14px;
}

.hero-service .hero__bullets {
  margin: 14px 0 0;
  padding-left: 18px;
  line-height: 1.6;
}

.section {
  padding: 56px 0;
}

.section--alt {
  background: rgba(0,0,0,0.03);
}

.section__head {
  margin-bottom: 22px;
}

.section__head h2 {
  margin: 0 0 8px;
}

.muted {
  opacity: 0.8;
}

.grid {
  display: grid;
  gap: 18px;
}

.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.card {
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  padding: 18px;
  background: #fff;
}

.card--compact {
  padding: 16px;
}

.checklist, .list {
  margin: 10px 0 0;
  padding-left: 18px;
  line-height: 1.6;
}

.card__note {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(0,0,0,0.08);
  font-size: 14px;
  line-height: 1.5;
  opacity: 0.9;
}

.steps {
  margin: 0;
  padding-left: 18px;
}

.steps li {
  margin: 14px 0;
}

.faq {
  display: grid;
  gap: 12px;
}

.faq__item {
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 14px;
  padding: 12px 14px;
  background: #fff;
}

.faq__item summary {
  cursor: pointer;
  font-weight: 700;
}

.faq__content {
  margin-top: 10px;
  line-height: 1.6;
  opacity: 0.9;
}

.cta--inline {
  margin-top: 22px;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  padding: 18px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.cta__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 900px) {
  .hero-service .hero__grid { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .cta--inline { flex-direction: column; align-items: flex-start; }
}

/* COOKIE BANNER */
#cookie-banner {
  position: fixed;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  background: #0C2746;
  color: #fff;
  padding: 14px 16px;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.25);
  max-width: 640px;
  width: calc(100% - 24px);
  z-index: 9999;
}

#cookie-banner .cookie-content {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: space-between;
}

#cookie-banner p {
  margin: 0;
  font-size: 14px;
  flex: 1;
}

#cookie-banner a {
  color: #A3C9FF;
  text-decoration: underline;
}