/* aldonia.css */
:root{


  --max: 1100px;
  --r: 18px;
  --shadow: 0 3px 6px rgba(0,0,0,.35);
}



img {
  border-radius: 6px;
}

*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
html, body { height: 100%; }

body{
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI",
               Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  line-height: 1.6;
}


  /* NOVO: jednolika pozadina RGB(101,61,136) */
  background: rgb(101,61,136);

  color: var(--text);
  line-height: 1.6;
}


a{ color: inherit; text-decoration: none; }
a:hover{ color: var(--accent-2); }

.container{
  width: min(100% - 40px, var(--max));
  margin: 0 auto;
}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left: 20px; top: 20px; width:auto; height:auto;
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 10px 14px;
  border-radius: 10px;
  z-index: 9999;
}


/* =========================================================
   HEADER — FINAL (purple bg, white text, no underline, fixed)
   ========================================================= */

:root{
  --brand: rgb(101,61,136); /* RGB(101,61,136) */
  --header-h: 72px;         /* prilagodi ako header bude viši/niži */
}

/* header uvijek fiksan */
.header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;

  background: var(--brand);
  border-bottom: 1px solid rgba(255,255,255,.18);

  /* ukloni bilo kakav blur/prozirnost iz starih stilova */
  backdrop-filter: none;
}

/* da sadržaj stranice ne ode ispod fiksnog headera */
body{
  padding-top: var(--header-h);
}

/* tipografija u headeru: sve bijelo */
.header,
.header *{
  color: #ffffff !important;
}

/* navigacija u redu (horizontalno) */
.nav{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* linkovi bez podcrtavanja + bijeli */
.nav a{
  text-decoration: none !important;
  color: #ffffff !important;

  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid transparent;
}

/* hover da ostane čitljivo na ljubičastoj */
.nav a:hover{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
}

/* (opcionalno) aktivni anchor link, ako ga kasnije dodaš */
.nav a[aria-current="page"],
.nav a.is-active{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.28);
}



.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  padding: 14px 0;
}
.brand{
  display:flex; align-items:center; gap: 12px;
}
.brand img{
  height: 44px; width:auto;
  display:block;
}
.brand__tagline{
  font-weight: 650;
  letter-spacing: .2px;
  color: var(--muted);
}
.brand__tagline strong{ color: var(--accent); }

.nav{
  display:flex; gap: 14px; flex-wrap: wrap; justify-content:flex-end;
}






.hero{
  padding: 56px 0 34px;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: start;
}
.kicker{
  color: var(--accent-2);
  font-weight: 650;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 12px;
}
h1{
  margin: 10px 0 12px;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.12;
}
.lead{
  color: var(--muted);
  font-size: 19px;
}

.cta{
  display:flex; gap: 12px; flex-wrap: wrap;
  margin-top: 18px;
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--text);
  box-shadow: none;
}
.btn--primary{
  background: linear-gradient(135deg, rgba(101,61,136,.85), rgba(155,120,182,.75));
  border-color: rgba(101,61,136,.35);
}
.btn svg{ width: 14px; height: 14px; fill: currentColor; }

.card{
  background: rgba(255,255,255);
  border: 0px;
  border-radius: var(--r);
  }







.section{
  padding: 44px 0;
}
.section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.02), transparent);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section h2{
  margin: 0 0 14px;
  font-size: 26px;
}
.section h2 span{
  color: var(--accent);
}



th, td {
  padding-top: 0px;
  padding-bottom: 22px;
  padding-left: 0px;
  padding-right: 44px;
}


/* IZNIMKE: sekcije koje NE smiju biti na ljubičastoj pozadini */
#voditelj,
#projekti{
  background: #ffffff; /* ili druga neutralna boja po želji */
}

/* da sadržaj ne “lijepi” uz rubove kad promijeniš background */
#voditelj .container,
#projekti .container{
  padding-top: 22px;
  padding-bottom: 22px;
}





/* === VODITELJ + PROJEKTI: tekst lijevo i ljubičasta boja === */

#voditelj,
#projekti{
  text-align: left;
  color: rgb(101,61,136);
}

/* Naslovi u tim sekcijama */
#voditelj h2,
#voditelj h3,
#projekti h2,
#projekti h3{
  text-align: left;
  color: rgb(101,61,136);
}

/* Paragrafi, liste i tablice */
#voditelj p,
#voditelj li,
#voditelj td,
#voditelj th,
#projekti p,
#projekti li{
  text-align: left;
  color: rgb(101,61,136);
}

/* Linkovi unutar tih sekcija */
#voditelj a,
#projekti a{
  color: rgb(101,61,136);
}
#voditelj a:hover,
#projekti a:hover{
  color: #5f3f77; /* malo tamnija za hover */
}




/* === VODITELJ: reset težine teksta === */

/* SVE u voditelju je normalne težine */
#voditelj,
#voditelj p,
#voditelj td,
#voditelj th,
#voditelj li {
  font-weight: 400;
}

/* SAMO eksplicitni <b> ostaje bold */
#voditelj b {
  font-weight: 700;
}

/* Ako se negdje pojavi <strong>, izjednači ga s normalnim tekstom */
#voditelj strong {
  font-weight: 400;
}


/* === VODITELJ: poravnanje sadržaja tablice po GORNJEM rubu === */

#voditelj table th,
#voditelj table td {
  vertical-align: top;
}






.split{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 22px;
  align-items: start;
}
.portrait{
  overflow:hidden;
}
.portrait img{
  width: 100%;
  height: auto;
  display:block;
  border-radius: 16px;
}
.meta h3{
  margin: 0 0 6px;
  font-size: 20px;
  color: var(--accent);
}
.meta p{ margin: 10px 0; color: var(--muted); }

.testimonials{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.quote{
  padding: 16px;
}
.quote p{ margin: 0 0 12px; color: var(--muted); }




/* === WHO (samo reference): bijelo + centrirano === */

#reference .who{
  margin: 0;
  font-weight: 350;
  font-size: 1.15rem;
  line-height: 1.40;
  color: #ffffff;
  text-align: center;
}




/* === REFERENCE: veći UNUTARNJI (inner) padding po lijevo/desno === */

#reference .card,
#reference .quote,
#reference .testimonials > div {
  padding-left: 32px;
  padding-right: 32px;
}


@media (max-width: 900px){
  #reference .card,
  #reference .quote,
  #reference .testimonials > div {
    padding-left: 20px;
    padding-right: 20px;
  }
}





.projects ul{ margin: 8px 0 0; padding-left: 18px; color: var(--muted); }
.projects li{ margin: 6px 0; }

.contact{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: start;
}
.form{
  padding: 16px;
}
.field{ display:grid; gap: 6px; margin-bottom: 12px; }
label{ color: var(--muted); font-size: 13px; }
input, textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.2);
  color: var(--text);
  outline: none;
}
textarea{ min-height: 140px; resize: vertical; }

.center {
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 50%;
}

.footer{
  padding: 22px 0;
  border-top: 1px solid var(--line);
  color: rgb(101,61,136);
  font-size: 14px;
}
.footer__inner{
  display:flex; justify-content:space-between; gap: 12px; flex-wrap: wrap;
}
.social{
  display:flex; gap: 10px; align-items:center;
}
.social a{
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
}

/* Responsive */
@media (max-width: 900px){
  .hero__grid{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .testimonials{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; }
  .nav{ display:none; } /* ili zamijeni hamburgerom */
}


/* === HEADER (ALWAYS FIXED): purple bg + white text + no underline === */

:root{
  --brand: rgb(101,61,136);
  --accent: rgb(250,210,100);   /* #FAD264 - topla žuta */
  --accent-2: rgba(214,176,83,.18); /* za hover/pozadine */
  --header-h: 72px; /* po potrebi prilagodi nakon vizualne provjere */
}

/* fiksni header */
.header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;

  background: var(--brand);
  border-bottom: 1px solid rgba(255,255,255,.18);

  /* ukloni prozirnost / blur ako postoji u starom CSS-u */
  backdrop-filter: none;
}

/* sadržaj headera bijeli */
.header,
.header *{
  color: #ffffff;
}

/* izbornik bez podcrtavanja */
.nav a{
  text-decoration: none;
  color: #ffffff;
}

/* hover stanje (ostaje čitljivo na ljubičastoj) */
.nav a:hover{
  color: #ffffff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
}

/* offset da fiksni header ne prekriva vrh stranice */
body{
  padding-top: var(--header-h);
}








/* === BACKGROUND: all sections purple except voditelj & projekti === */

/* default za sve sekcije */
.hero,
.section{
  background: var(--brand);
}

/* section--alt trenutno dodaje gradient / border — poništi da bude čista ljubičasta */
.section--alt{
  background: var(--brand) !important;
  border-top: none;
  border-bottom: none;
}

/* iznimke */
#voditelj,
#projekti{
  background: #0f0d12; /* ili neka druga neutralna/tamna */
}



/* === CONTACT FORM: white input backgrounds === */

#kontakt input,
#kontakt textarea{
  background: #ffffff;
  color: #0f0d12;               /* tamni tekst radi čitljivosti */
  border-color: rgba(0,0,0,.18);
}

#kontakt input::placeholder,
#kontakt textarea::placeholder{
  color: rgba(0,0,0,.55);
}

/* da labeli ostanu čitljivi na ljubičastoj */
#kontakt label{
  color: #ffffff;
}



/* =====================================================
   GLOBALNA RASPODJELA BOJE TEKSTA PO SEKCIJAMA
   ===================================================== */

:root{
  --brand: rgb(101,61,136);
}

/* --- HEADER: ljubičasti tekst --- */
header,
header *{
  color: var(--brand);
}

/* --- VODITELJ & PROJEKTI: ljubičasti tekst --- */
#voditelj,
#voditelj *,
#projekti,
#projekti *{
  color: var(--brand);
}

/* --- SVE OSTALE SEKCIJE: bijeli tekst --- */
.hero,
.hero *,
.section,
.section *{
  color: #ffffff;
}

/* --- IZUZECI: vrati ljubičastu tamo gdje treba --- */
/* (jači selektori pobjeđuju opći .section stil) */
#voditelj *,
#projekti *{
  color: var(--brand);
}



/* =====================================================
   POZADINA: VODITELJ & PROJEKTI BIJELA
   ===================================================== */

#voditelj,
#projekti{
  background: #ffffff;
}


/* =====================================================
   REFERENCE: tipografija = ostatak stranice
   (boja ostaje bijela)
   ===================================================== */

/* reset fonta i veličine na default body vrijednosti */
#reference,
#reference p,
#reference li,
#reference .who{
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

/* zadrži postojeću boju */
#reference,
#reference *{
  color: #ffffff;
}




/* =====================================================
   HERO CTA BUTTON – realniji gumb
   ===================================================== */

.btn,
.btn b{
  text-decoration: none;     /* nikad underline */
  color: #ffffff;            /* bijeli tekst */
}

/* primarni CTA */
.btn--primary{
  background: rgb(101,61,136);
  border: 1px solid rgba(0,0,0,.15);
  box-shadow: non
    0 3px 6px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.25);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

/* hover */
.btn--primary:hover{
  background: rgb(112,72,144);
  box-shadow:
    0 3px 6px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.25);
  transform: translateY(-1px);
}

/* active (klik) */
.btn--primary:active{
  transform: translateY(0);
  box-shadow:
    0 3px 6px rgba(0,0,0,.35),
    inset 0 2px 4px rgba(0,0,0,.25);
}




/* =====================================================
   STO-RADIMO: +10px bočni padding po stupcu
   ===================================================== */

#sto-radimo .card.quote{
  padding-left: 26px;   /* 16 + 10 */
  padding-right: 26px;  /* 16 + 10 */
}


@media (max-width: 900px){
  #sto-radimo .card.quote{
    padding-left: 20px;
    padding-right: 20px;
  }
}


/* =====================================================
   GLOBAL: H2 između H2 i H3
   ===================================================== */

.section h2{
  font-size: 23px;     /* između 26px (staro H2) i 20px (H3) */
  line-height: 1.25;
}


.who-role{
  font-size: 0.9em;   /* 10% manje od osnovnog teksta */
}



/* =====================================================
   ICON BUTTONS (LinkedIn / WhatsApp)
   60x60 circle, same feel as CTA "Razgovarajmo"
   ===================================================== */

.icon-btn{
  width: 60px;
  height: 60px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgb(101,61,136);
  border: 1px solid rgba(0,0,0,.15);
  box-shadow:
    0 4px 10px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.25);

  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

/* centriraj i smanji ikonice unutar gumba */
.icon-btn img{
  width: 40px;   /* po želji 28–34 */
  height: 40px;
  display: block;
}

/* hover */
.icon-btn:hover{
  background: rgb(112,72,144);
  box-shadow:
    0 6px 14px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.25);
  transform: translateY(-1px);
}

/* active (klik) */
.icon-btn:active{
  transform: translateY(0);
  box-shadow:
    0 3px 6px rgba(0,0,0,.35),
    inset 0 2px 4px rgba(0,0,0,.25);
}

/* (opcionalno) razmak između gumba */
.icon-btn + .icon-btn{
  margin-left: 10px;
}



/* =====================================================
   CAROUSEL (5 items visible, infinite loop)
   ===================================================== */

.section--carousel{
  background: var(--brand);
  color: #fff;
}

.carousel{
  position: relative;
  margin-top: 14px;
  border-radius: 18px;
  padding: 14px 56px; /* prostor za strelice */
  background: rgba(255,255,255,.05);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.14);
}

.carousel__viewport{
  overflow: hidden;
  border-radius: 16px;
}

.carousel__track{
  display: flex;
  gap: 12px;
  will-change: transform;
  transition: transform .35s ease;
}

.carousel__item{
  flex: 0 0 calc((100% - 48px) / 5); /* 5 komada, 4 gap-a * 12px = 48px */
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
}

.carousel__item img{
  display: block;
  width: 100%;
  height: 140px;              /* možeš promijeniti */
  object-fit: cover;
  transform: scale(1);
  transition: transform .18s ease, filter .18s ease;
}

.carousel__item:hover img{
  transform: scale(1.03);
  filter: brightness(1.03);
}

.carousel__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.15);
  background: rgb(101,61,136);
  color: #fff;
  box-shadow:
    0 4px 10px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.25);
  cursor: pointer;
  user-select: none;
  display: grid;
  place-items: center;
  font-size: 26px;
  line-height: 1;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.carousel__nav:hover{
  background: rgb(112,72,144);
  box-shadow:
    0 6px 14px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.25);
}

.carousel__nav:active{
  transform: translateY(-50%) scale(.98);
}

.carousel__nav--prev{ left: 12px; }
.carousel__nav--next{ right: 12px; }

/* Responsive: zadrži 5 u redu, ali smanji visinu */
@media (max-width: 900px){
  .carousel{ padding: 12px 52px; }
  .carousel__item img{ height: 120px; }
}


/* =========================================================
   GALERIJA — full-bleed carousel, no outer border, 3 columns
   ========================================================= */

#galerija{
  background: #ffffff;
  padding: 44px 0;
}

#galerija,
#galerija *{
  color: rgb(101,61,136);
}

/* carousel: bez vanjskog obruba + proširen na punu širinu viewporta */
#galerija .carousel{
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0;

  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  padding: 0 64px; /* prostor za strelice */
}

/* viewport */
#galerija .carousel__viewport{
  border-radius: 0;
}

/* track: bez razmaka, separator je border */
#galerija .carousel__track{
  gap: 0;
}

/* item = stupac */
#galerija .carousel__item{
  flex: 0 0 calc(100% / 3);
  background: #ffffff;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
  cursor: pointer;

  border-left: 1px solid rgba(101,61,136,.35);
}

/* (opcionalno) makni crtu prije prvog itema u nizu */
#galerija .carousel__item:first-child{
  border-left: none;
}

/* slika */
#galerija .carousel__item img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  border-radius: 0;
}

/* opis ispod slike */
#galerija .gallery__caption{
  padding: 12px 16px 16px;
  font-size: 14px;
  line-height: 1.45;
  background: #ffffff;
  color: rgb(101,61,136);
  min-height: 56px;
}

/* strelice minimalističke */
#galerija .carousel__nav{
  background: #ffffff !important;
  color: rgb(101,61,136) !important;
  border: 1px solid rgba(101,61,136,.25) !important;
  box-shadow: none !important;
}

#galerija .carousel__nav:hover{
  background: rgba(101,61,136,.06) !important;
}

/* responsive: 2 stupca */
@media (max-width: 1200px){
  #galerija .carousel__item{
    flex-basis: 50%;
  }
}

/* responsive: 1 stupac + manji padding za strelice */
@media (max-width: 700px){
  #galerija .carousel{
    padding: 0 52px;
  }
  #galerija .carousel__item{
    flex-basis: 100%;
  }
  #galerija .carousel__item img{
    height: 240px;
  }
}



/* =========================================================
   BUTTONS — 15% lighter than background RGB(101,61,136)
   ========================================================= */
:root{
  --btn-bg: rgb(132,92,162);        /* svjetlije od RGB(101,61,136) */
  --btn-bg-hover: rgb(130,90,162);  /* blago tamnije */
  --btn-bg-active: rgb(126,95,155);  /* još nijansu tamnije */
  --btn-text: #ffffff;
}

/* Ciljaj sve gumbe koji se koriste na webu */
.btn,
a.btn,
button.btn,
.btn--primary,
button,
input[type="submit"],
.icon-btn,
.carousel__nav{
  background: var(--btn-bg) !important;
  color: var(--btn-text) !important;

  border: 0px  !important;
  border-radius: 12px;

  text-decoration: none !important;

  box-shadow:
    0 2px 0 rgba(0,0,0,.22),
    0 6px 14px rgba(0,0,0,.10) !important;

  transform: translateY(0);
  transition: background .15s ease, transform .12s ease, box-shadow .12s ease;
}

/* Hover */
.btn:hover,
a.btn:hover,
button.btn:hover,
.btn--primary:hover,
button:hover,
input[type="submit"]:hover,
.icon-btn:hover,
.carousel__nav:hover{
  background: var(--btn-bg-hover) !important;
}

/* Active */
.btn:active,
a.btn:active,
button.btn:active,
.btn--primary:active,
button:active,
input[type="submit"]:active,
.icon-btn:active,
.carousel__nav:active{
  background: var(--btn-bg-active) !important;
  transform: translateY(2px);
  box-shadow:
    0 1px 0 rgba(0,0,0,.20),
    0 4px 10px rgba(0,0,0,.08) !important;
}

/* Fokus */
.btn:focus-visible,
a.btn:focus-visible,
button:focus-visible,
input[type="submit"]:focus-visible,
.icon-btn:focus-visible,
.carousel__nav:focus-visible{
  outline: 2px solid rgba(255,255,255,.65);
  outline-offset: 2px;
}




/* STO-RADIMO: kartice bijele, sav tekst ljubičast */
#sto-radimo .card,
#sto-radimo .card *{
  color: rgb(101,61,136) !important;
}

#sto-radimo .card{
  background: #ffffff !important;
  border: 1px solid rgba(101,61,136,.18) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.12) !important;
  padding: 32px 36px;
}

/* makni "muted" pravilo za p unutar quote (override) */
#sto-radimo .quote p{
  color: rgb(101,61,136) !important;
}


/* REFERENCE: kartice bijele, sav tekst ljubičast */
#reference .card,
#reference .card *{
  color: rgb(101,61,136) !important;
}

#reference .card{
  background: #ffffff !important;
  border: 1px solid rgba(101,61,136,.18) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.12) !important;
  padding: 32px 36px;
}

/* makni "muted" pravilo za p unutar quote (override) */
#reference .quote p{
  color: rgb(101,61,136) !important;
}




/* =========================================================
   PROJEKTI — responsive grid (mobile → tablet → desktop)
   ========================================================= */

/* osnovno (mobile-first) */
#projekti .projects-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-top: 20px;
}

/* tipografija i razmaci unutar stupaca */
#projekti h2{
  margin-bottom: 16px;
}

#projekti h3{
  margin: 0 0 8px;
  line-height: 1.25;
}

#projekti ul{
  margin: 0 0 18px;
  padding-left: 18px;
}

#projekti li{
  margin: 6px 0;
}

/* tablet (>= 600px): 2 kolone */
@media (min-width: 600px){
  #projekti .projects-grid{
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }
}

/* laptop/desktop (>= 900px): više zraka */
@media (min-width: 900px){
  #projekti .projects-grid{
    gap: 32px;
    margin-top: 24px;
  }

  #projekti ul{
    margin-bottom: 22px;
  }
}

/* veliki ekrani (>= 1200px): još malo razmaka */
@media (min-width: 1200px){
  #projekti .projects-grid{
    gap: 40px;
  }
}



/* =========================================================
   GALERIJA — 3 stupca (carousel, infinite), white + brand purple
   ========================================================= */

.section--gallery{
  background: #ffffff !important;
  border-top: 1px solid rgba(101,61,136,.18);
  border-bottom: 1px solid rgba(101,61,136,.18);
}

#galerija,
#galerija *{
  color: rgb(101,61,136);
}

/* Carousel shell: bijelo i “flat” */
#galerija .carousel{
  background: #ffffff;
  border: 1px solid rgba(101,61,136,.18);
  box-shadow: none;
  padding: 14px 56px; /* prostor za strelice */
}

/* viewport bez dodatnih efekata */
#galerija .carousel__viewport{
  border-radius: 0;
}

/* track */
#galerija .carousel__track{
  gap: 0; /* jer separator rješavamo borderom */
}

/* 3 stupca vidljiva */
#galerija .carousel__item{
  flex: 0 0 calc(100% / 3);
  background: #ffffff;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  overflow: hidden;

  /* tanka brand crta između stupaca */
  border-left: 1px solid rgba(101,61,136,.35);
}

/* da prva vidljiva kartica nema lijevu crtu (opcionalno) */
#galerija .carousel__item:first-child{
  border-left: none;
}

/* slika */
#galerija .carousel__item img{
  width: 100%;
  height: 180px;         /* po želji */
  object-fit: cover;
  border-radius: 0;
  display:block;
}

/* caption */
#galerija .gallery__caption{
  padding: 14px 16px 16px;
  font-size: 14px;
  line-height: 1.45;
  color: rgb(101,61,136);
  background: #ffffff;
  min-height: 54px; /* drži visinu konzistentnom */
}

/* strelice minimalističke */
#galerija .carousel__nav{
  background: #ffffff !important;
  color: rgb(101,61,136) !important;
  border: 1px solid rgba(101,61,136,.25) !important;
  box-shadow: none !important;
}

#galerija .carousel__nav:hover{
  background: rgba(101,61,136,.06) !important;
}

/* Responsive */
@media (max-width: 900px){
  /* 1 stupac na mobitelu */
  #galerija .carousel__item{
    flex-basis: 100%;
  }
  #galerija .carousel{
    padding: 12px 52px;
  }
  #galerija .carousel__item img{
    height: 200px;
  }
}

@media (min-width: 901px) and (max-width: 1200px){
  /* 2 stupca na tablet/laptop srednje širine */
  #galerija .carousel__item{
    flex-basis: 50%;
  }
}


/* =========================================================
   KONTAKT — bijele kartice, brand ljubičasti tekst i obrubi
   ========================================================= */

#kontakt{
  background: var(--brand); /* sekcija ostaje na ljubičastoj */
}

/* kartice u kontaktu */
#kontakt .card{
  background: #ffffff !important;
  color: var(--brand) !important;
  border: 1px solid rgba(101,61,136,.18);
  box-shadow: none !important;
}

/* forma kao kartica */
#kontakt .form{
  background: #ffffff !important;
}

/* sav tekst u kontakt sekciji */
#kontakt,
#kontakt *{
  color: var(--brand);
}

/* labeli */
#kontakt label{
  color: var(--brand);
  font-weight: 500;
}

/* inputi i textarea */
#kontakt input,
#kontakt textarea{
  background: #ffffff !important;
  color: var(--brand) !important;

  border: 1px solid rgba(101,61,136,.35);
  border-radius: 12px;

  box-shadow: none;
}

/* placeholder */
#kontakt input::placeholder,
#kontakt textarea::placeholder{
  color: rgba(101,61,136,.55);
}

/* fokus — vrlo diskretan */
#kontakt input:focus,
#kontakt textarea:focus{
  outline: none;
  border-color: rgb(101,61,136);
}

/* gumb zadrži, ali neka se uklopi vizualno */
#kontakt .btn{
  margin-top: 6px;
}

/* info kartica desno */
#kontakt .card h3,
#kontakt .card p{
  color: var(--brand);
}

/* ikonice — zadrži postojeći stil, ali bez tamne sjene */
#kontakt .icon-btn{
  background: !important;
  border: 1px solid rgba(101,61,136,.35) !important;
  box-shadow: none !important;
}

/* hover vrlo suptilan */
#kontakt .icon-btn:hover{
  background: rgba(101,61,136,.06) !important;
}


/* =========================================================
   KONTAKT — naslov i ikone (finalni detalji)
   ========================================================= */

/* H2 "Razgovarajmo" u brand boji */
#kontakt h2{
  color: var(--brand) !important;
}

/* icon-btn: bez filtera u normalnom stanju */
#kontakt .icon-btn img{
  filter: none;
  transition: filter .15s ease, transform .15s ease;
}

/* hover: suptilno posvjetljenje slike */
#kontakt .icon-btn:hover img{
  filter: brightness(1.15);
  transform: translateY(-1px); /* vrlo diskretno */
}

/* active: lagani "klik" osjećaj */
#kontakt .icon-btn:active img{
  transform: translateY(0);
}


/* =========================================================
   KONTAKT — gumb "Pošalji" (konačni fix)
   ========================================================= */

/* boja gumba */
#kontakt .btn,
#kontakt .btn--primary{
  color: #ffffff !important;
  font-weight: 700;
}

/* boja teksta UNUTAR gumba (b, span, itd.) */
#kontakt .btn *,
#kontakt .btn--primary *{
  color: #ffffff !important;
}




/* =========================================================
   HERO — accent riječ u H1 + CTA tekst u accent boji
   (final override)
   ========================================================= */

/* "dobra" u H1 */
.hero .accent{
  color: var(--accent) !important;
}

/* CTA "Razgovarajmo" u HERO-u: tekst u accent boji */
.hero .btn--primary,
.hero .btn--primary *{
  color: var(--accent) !important;
  font-weight: 700; /* ako želiš da izgleda “CTA” */
}



/* =========================================================
   PROJEKTI — portfolio grid (responsive)
   ========================================================= */

#projekti .projects-divider{
  border: 0;
  height: 1px;
  background: rgba(101,61,136,.18);
  margin: 26px 0 18px;
}

#projekti .projects-subtitle{
  margin: 0 0 14px;
  color: rgb(101,61,136);
  font-size: 20px;
  line-height: 1.25;
}

/* GRID: 3/2/1 */
#projekti .portfolio-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 0; /* separator rješavamo borderom */
  border: 1px solid rgba(101,61,136,.18);
  background: #ffffff;
}

@media (min-width: 700px){
  #projekti .portfolio-grid{
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1100px){
  #projekti .portfolio-grid{
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* KARTICA */
#projekti .portfolio-card{
  background: #ffffff;
  padding: 18px 18px 20px;
  color: rgb(101,61,136);
  position: relative;
}

/* tanka brand crta između stupaca i redova */
#projekti .portfolio-card{
  border-left: 1px solid rgba(101,61,136,.18);
  border-top: 1px solid rgba(101,61,136,.18);
}
#projekti .portfolio-card:nth-child(1),
#projekti .portfolio-card:nth-child(2),
#projekti .portfolio-card:nth-child(3){
  /* prvi red: bez top crte (kad je 3 kolone); ne smeta na 1/2 kolone */
  border-top: 0;
}
#projekti .portfolio-card:nth-child(3n+1){
  /* prvi stupac: bez lijeve crte kad je 3 kolone */
  border-left: 0;
}
@media (max-width: 1099px){
  #projekti .portfolio-card:nth-child(3n+1){ border-left: 1px solid rgba(101,61,136,.18); }
}
@media (min-width: 700px) and (max-width: 1099px){
  #projekti .portfolio-card:nth-child(2n+1){ border-left: 0; }
}
@media (max-width: 699px){
  #projekti .portfolio-card{ border-left: 0; }
}

/* MEDIA (klik) */
#projekti .portfolio-media{
  display: block;
  width: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

#projekti .portfolio-media img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  border-radius: 0;
  transition: transform .18s ease, filter .18s ease;
}

#projekti .portfolio-media:hover img{
  transform: scale(1.02);
  filter: brightness(1.06);
}

#projekti .portfolio-title{
  margin: 14px 0 8px;
  font-size: 16px;
  line-height: 1.25;
  color: rgb(101,61,136);
}

#projekti .portfolio-desc{
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(101,61,136,.92);
}

/* TAGS (minimal) */
#projekti .portfolio-tags{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

#projekti .tag{
  font-size: 12px;
  padding: 6px 10px;
  border: 1px solid rgba(101,61,136,.22);
  border-radius: 999px;
  background: rgba(101,61,136,.06);
  color: rgb(101,61,136);
}

/* responsive visina slike */
@media (max-width: 699px){
  #projekti .portfolio-media img{ height: 240px; }
}



/* =========================================================
   PROJEKTI — PORTFOLIO (responsive 1/2/3)
   ========================================================= */

#projekti .projects-divider{
  border: 0;
  height: 1px;
  background: rgba(101,61,136,.18);
  margin: 26px 0 18px;
}

#projekti .projects-subtitle{
  margin: 0 0 14px;
  color: rgb(101,61,136);
  font-size: 20px;
  line-height: 1.25;
}

/* GRID: 1 / 2 / 3 stupca */
#projekti .portfolio-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 0; /* separator ide preko bordera */
  border: 1px solid rgba(101,61,136,.18);
  background: #ffffff;
}

@media (min-width: 700px){
  #projekti .portfolio-grid{
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1100px){
  #projekti .portfolio-grid{
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* KARTICA */
#projekti .portfolio-card{
  background: #ffffff;
  padding: 18px 18px 20px;
  color: rgb(101,61,136);
}

/* tanka brand crta između “stupaca” i “redova” */
#projekti .portfolio-card{
  border-left: 1px solid rgba(101,61,136,.18);
  border-top: 1px solid rgba(101,61,136,.18);
}

/* prva kolona: bez lijeve crte (mobile, tablet, desktop) */
@media (max-width: 699px){
  #projekti .portfolio-card{ border-left: 0; }
}
@media (min-width: 700px) and (max-width: 1099px){
  #projekti .portfolio-card:nth-child(2n+1){ border-left: 0; }
}
@media (min-width: 1100px){
  #projekti .portfolio-card:nth-child(3n+1){ border-left: 0; }
}

/* prvi red: bez gornje crte */
@media (max-width: 699px){
  #projekti .portfolio-card:nth-child(1){ border-top: 0; }
}
@media (min-width: 700px) and (max-width: 1099px){
  #projekti .portfolio-card:nth-child(-n+2){ border-top: 0; }
}
@media (min-width: 1100px){
  #projekti .portfolio-card:nth-child(-n+3){ border-top: 0; }
}

/* MEDIA BUTTON */
#projekti .portfolio-media{
  display: block;
  width: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

#projekti .portfolio-media img{
  width: 100%;
  height: 230px;
  object-fit: cover;
  display: block;
  border-radius: 0;
  transition: transform .18s ease, filter .18s ease;
}

#projekti .portfolio-media:hover img{
  transform: scale(1.02);
  filter: brightness(1.06);
}

#projekti .portfolio-title{
  margin: 14px 0 8px;
  font-size: 16px;
  line-height: 1.25;
  color: rgb(101,61,136);
}

#projekti .portfolio-desc{
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(101,61,136,.92);
}

/* mobile: malo veća slika (da bolje “nosi”) */
@media (max-width: 699px){
  #projekti .portfolio-media img{ height: 260px; }
}


/* =========================================================
   LIGHTBOX — baza + panel 700px + opis ispod
   ========================================================= */

.lightbox{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 10000;
}

.lightbox.is-open{ display: block; }

.lightbox__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.68);
}

.lightbox__panel{
  position: relative;
  width: min(700px, calc(100vw - 40px));
  margin: 8vh auto 0;
  background: #ffffff;
  border: 1px solid rgba(101,61,136,.18);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
  overflow: hidden;
}

.lightbox__img{
  display: block;
  width: 100%;
  height: auto;
  max-height: 70vh;
  object-fit: contain;
  background: #ffffff;
}

.lightbox__caption{
  padding: 14px 16px 18px;
  color: rgb(101,61,136);
  font-size: 14px;
  line-height: 1.45;
  background: #ffffff;
  border-top: 1px solid rgba(101,61,136,.14);
}

.lightbox__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(101,61,136,.25);
  background: #ffffff;
  color: rgb(101,61,136);
  font-size: 22px;
  cursor: pointer;
}


@media (max-width: 900px){
  .nav{
    display: flex !important;
    width: 100%;
    justify-content: flex-start;
    gap: 10px;
    flex-wrap: wrap;
  }
  .header__inner{
    flex-wrap: wrap;
    align-items: flex-start;
  }
}


@media (max-width: 900px){
  #voditelj table,
  #voditelj tbody,
  #voditelj tr,
  #voditelj th,
  #voditelj td{
    display: block;
    width: 100%;
  }

  #voditelj th{
    padding-right: 0 !important;
  }

  #voditelj img{
    max-width: 220px;
    width: 100%;
    height: auto;
    display: block;
    margin: 0 0 10px;
  }
}


@media (max-width: 900px){
  th, td{
    padding-right: 0 !important;
  }
}



img{
  max-width: 100%;
  height: auto;
}



.gdpr-note{
  font-size: 12px;
  line-height: 1.4;
  color: rgba(101,61,136,.85);
  margin: 8px 0 12px;
}



/* =========================================================
   MOBILE NAV (Hamburger)
   ========================================================= */

/* desktop: hamburger i mobile nav skriveni */
.nav-toggle,
.nav-mobile{ display: none; }

/* hamburger button */
.nav-toggle{
  width: 46px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  cursor: pointer;

  display: none;
  align-items: center;
  justify-content: center;
  gap: 5px;

  padding: 10px;
}

/* tri crtice */
.nav-toggle span{
  display: block;
  width: 22px;
  height: 2px;
  background: #ffffff;
  border-radius: 2px;
  transition: transform .15s ease, opacity .15s ease;
}

/* animacija u "X" kad je otvoreno */
.nav-toggle.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity: 0; }
.nav-toggle.is-open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* mobile breakpoint */
@media (max-width: 900px){
  /* sakrij desktop nav */
  .nav{ display: none !important; }

  /* prikaži hamburger */
  .nav-toggle{ display: inline-flex; }

  /* mobilni nav dropdown */
  .nav-mobile{
    display: block;
    position: absolute;
    right: 20px;
    top: calc(var(--header-h) - 6px);

    width: min(320px, calc(100vw - 40px));
    background: #ffffff;
    border: 1px solid rgba(101,61,136,.18);
    border-radius: 14px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
    overflow: hidden;
    z-index: 10000;
  }

  .nav-mobile a{
    display: block;
    padding: 12px 14px;
    color: rgb(101,61,136);
    text-decoration: none;
    border-top: 1px solid rgba(101,61,136,.14);
  }

  .nav-mobile a:first-child{ border-top: 0; }

  .nav-mobile a:hover{
    background: rgba(101,61,136,.06);
  }
}



/* =========================================================
   HERO — suptilna PNG podloga (7%), ulazi s desne strane
   ========================================================= */

.hero{
  position: relative;
  overflow: hidden; /* sakriva desnu polovicu PNG-a */
}

/* overlay PNG */
.hero::after{
  content: "";
  position: absolute;
  top: 0;
  right: 0;                /* sidro desno */
  height: 140%;
  width: 140%;             /* PNG je širi od vidljivog dijela */

  background-image: url("img/al_donia_svijet_white2.png");
  background-repeat: no-repeat;
  background-size: auto 120%;   /* malo veći da “diše” */
  background-position: right center;

  opacity: 0.07;           /* 7% vidljivosti */
  pointer-events: none;   /* nikad ne hvata klik */
  z-index: 0;
}

/* sadržaj HERO-a ide iznad PNG-a */
.hero > .container{
  position: relative;
  z-index: 1;
}






/* =========================================================
   STO RADIMO — bijela podloga + brand ljubičasti H2
   ========================================================= */

/* bijela podloga cijele sekcije */
#sto-radimo{
  background: #ffffff !important;
}

/* H2 naslov u brand ljubičastoj */
#sto-radimo h2{
  color: rgb(101,61,136) !important;
}

/* (sigurnosno) sav tekst u sekciji neka ostane ljubičast */
#sto-radimo,
#sto-radimo *{
  color: rgb(101,61,136);
}




/* STO-RADIMO: vizualno veći naslovi kartica bez promjene heading razine */
#sto-radimo .card.quote h3{
  font-size: 22px;      /* po potrebi 21–24 */
  line-height: 1.2;
  font-weight: 700;
  margin: 0 0 12px;
  letter-spacing: .1px;
}


#sto-radimo .card{
  box-shadow: 0 2px 8px rgba(0,0,0,.06) !important;
}




/* =========================================================
   WATERMARK overlay (HERO + REFERENCE + KONTAKT)
   7% vidljivo, ulazi s desne strane, desna polovica PNG-a sakrivena
   ========================================================= */

.hero,
#reference,
#kontakt{
  position: relative;
  overflow: hidden; /* sakrije dio PNG-a koji ide van sekcije */
}

/* overlay PNG */
.hero::after,
#reference::after,
#kontakt::after{
  content: "";
  position: absolute;
  top: 0;
  right: 0;                 /* sidro desno */
  width: 140%;
  height: 140%;

  background-image: url("img/al_donia_svijet_white2.png");
  background-repeat: no-repeat;
  background-size: auto 120%;
  background-position: right center;

  opacity: 0.07;
  pointer-events: none;
  z-index: 0;
}

/* sadržaj iznad overlay-a */
.hero > .container,
#reference > .container,
#kontakt > .container{
  position: relative;
  z-index: 1;
}


@media (max-width: 700px){
  .hero::after,
  #reference::after,
  #kontakt::after{
    opacity: 0.04;
    background-size: auto 140%;
  }

  [hidden] {
    display: none !important;
  }

  .header, .header * {
    color: #7f599e !important;
  }
}



/* =========================================================
   MOBILE — watermark 2× manji
   ========================================================= */

@media (max-width: 700px){
  .hero::after,
  #reference::after,
  #kontakt::after{
    width: 70%;
    height: 70%;
    background-size: auto 80%;
    opacity: 0.04; /* još suptilnije na mobitelu */
  }
}




/* =========================================================
   KONTAKT — H2 naslov bijeli (final override)
   ========================================================= */

#kontakt h2{
  color: #ffffff !important;
}



/* =========================================================
   HERO — H1 Montserrat Black samo na mobitelu
   ========================================================= */

@media (max-width: 700px){
  .hero h1{
    font-family: "Montserrat", system-ui, sans-serif;
    font-weight: 700;        /* Montserrat Black */
    letter-spacing: -0.02em; /* da ne izgleda preteško */
  }
}



/* =========================================================
   MOBILE — H2 naslovi (izvan HERO): Montserrat 700
   ========================================================= */

@media (max-width: 700px){
  section:not(.hero) h2{
    font-family: "Montserrat", system-ui, sans-serif;
    font-weight: 700;
  }
}



.footer-link {
  color: inherit;
  text-decoration: none;
  font-weight: normal;
}

.footer-link:hover {
  text-decoration: underline;
}
