/* ============================================================
   KORIJEN DESIGN SYSTEM v1.0
   Imanje Korijen — Internal Portal
   Typefaces: Cormorant Garamond (serif), Jost (sans)
   ============================================================ */

/* 3A — Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:ital,wght@0,200;0,300;0,400;0,500;1,300&display=swap');

/* 3B — Design tokens */
:root {
  /* Brand colours */
  --forest:    #2D4A22;   /* deep forest green — primary */
  --forest-lt: #4B5D34;   /* lighter forest green */
  --bark:      #3B2E1E;   /* dark warm brown — text */
  --earth:     #6B4C2A;   /* medium warm brown */
  --ochre:     #B8922B;   /* golden ochre — accent */
  --ochre-lt:  #D4AC4E;   /* lighter ochre */
  --stone:     #7A7264;   /* warm grey — secondary text */
  --stone-lt:  #A89F96;   /* light stone */
  --cream:     #F5F0E8;   /* warm off-white — page bg */
  --cream-dk:  #EDE7D8;   /* slightly darker cream — card bg */
  --linen:     #FAF7F2;   /* near-white for header */
  --white:     #FFFFFF;

  /* Typography */
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', system-ui, sans-serif;

  /* Spacing scale */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;

  /* Border */
  --border: 1px solid rgba(59, 46, 30, 0.12);
  --border-strong: 1px solid rgba(59, 46, 30, 0.28);

  /* Shadow */
  --shadow-sm: 0 1px 3px rgba(45, 74, 34, 0.08);
  --shadow-md: 0 4px 12px rgba(45, 74, 34, 0.12);

  /* Border radius */
  --radius: 3px;
}

/* 3C — Base reset + body */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

body {
  background: var(--cream);
  color: var(--bark);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a {
  color: var(--forest);
  text-decoration: none;
}
a:hover {
  color: var(--ochre);
}

/* 3D — Typography */
h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 36px;
  letter-spacing: 0.01em;
  color: var(--bark);
  line-height: 1.2;
}
h2 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 26px;
  color: var(--bark);
  line-height: 1.25;
}
h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 20px;
  color: var(--bark);
}
h4 {
  font-family: var(--sans);
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--forest);
}

.label-caps {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--forest);
}

.body-serif {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 300;
  color: var(--bark);
  line-height: 1.7;
}

.caption {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.12em;
  color: var(--stone);
}

p {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 14px;
  color: var(--bark);
  line-height: 1.65;
}

.meta {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 300;
  color: var(--stone);
  margin-top: var(--sp-1);
}

/* 3E — Site header */
.site-header {
  background: var(--bark);
  border-bottom: 2px solid var(--forest);
  padding: 0 var(--sp-6);
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  position: sticky;
  top: 0;
  z-index: 100;
}

.site-header .logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.site-header .logo img {
  display: block;
}

/* 3F — Site nav */
.site-nav {
  display: flex;
  list-style: none;
  gap: var(--sp-1);
  align-items: center;
}
.site-nav li a {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--stone-lt);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius);
  transition: color 0.15s, background 0.15s;
  white-space: nowrap;
}
.site-nav li a:hover,
.site-nav li a.aktivan {
  color: var(--ochre-lt);
  background: rgba(184, 146, 43, 0.12);
}

/* Nav toggle (mobile) */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--sp-2);
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--stone-lt);
  border-radius: 1px;
}

/* 3G — Main + page header */
.site-main {
  flex: 1;
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
  padding: var(--sp-6) var(--sp-6);
}

.page-header {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-4);
  border-bottom: var(--border-strong);
}
.page-header .label-caps {
  margin-bottom: var(--sp-2);
}
.page-header h1 {
  margin-bottom: var(--sp-1);
}

/* 3H — Status badge */
.status-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 2px var(--sp-2);
  border-radius: 2px;
  white-space: nowrap;
  flex-shrink: 0;
}
.status-badge--nije {
  color: var(--stone);
  background: rgba(122, 114, 100, 0.10);
  border: 1px solid rgba(122, 114, 100, 0.22);
}
.status-badge--u-toku {
  color: var(--ochre);
  background: rgba(184, 146, 43, 0.10);
  border: 1px solid rgba(184, 146, 43, 0.30);
}
.status-badge--zavrseno {
  color: var(--forest);
  background: rgba(45, 74, 34, 0.09);
  border: 1px solid rgba(45, 74, 34, 0.22);
}
.status-badge--blokirano {
  color: #8B2E2E;
  background: rgba(139, 46, 46, 0.09);
  border: 1px solid rgba(139, 46, 46, 0.22);
}

/* 3I — Progress bar */
.progres-traka {
  height: 4px;
  background: rgba(59, 46, 30, 0.10);
  border-radius: 2px;
  overflow: hidden;
}
.progres-traka--debela {
  height: 8px;
}
.progres-traka__punilo {
  height: 100%;
  background: linear-gradient(90deg, var(--forest) 0%, var(--forest-lt) 100%);
  border-radius: 2px;
  transition: width 0.4s ease;
  min-width: 2px;
}
.progres-broj {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 500;
  color: var(--forest);
  line-height: 1;
}
.progres-oznaka {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 300;
  color: var(--stone);
}

/* 3J — Cards */
.kartica {
  background: var(--cream-dk);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.kartica-oblast {
  display: block;
  text-decoration: none;
  padding: var(--sp-4);
  background: var(--cream-dk);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.18s, border-color 0.18s;
  cursor: pointer;
}
.kartica-oblast:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(75, 93, 52, 0.30);
  color: inherit;
}
.kartica-oblast .kartica__broj-zadataka {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 300;
  color: var(--stone);
}
.kartica-stat {
  background: var(--cream-dk);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--sp-4) var(--sp-5);
  text-align: center;
  box-shadow: var(--shadow-sm);
}

/* 3K — Task cards */
.zadatak-kartica {
  background: var(--cream-dk);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-2);
  cursor: pointer;
  transition: box-shadow 0.15s;
}
.zadatak-kartica:hover {
  box-shadow: var(--shadow-sm);
}
.zadatak-zaglavlje {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-3);
}
.zadatak-naslov {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 400;
  color: var(--bark);
  line-height: 1.4;
}
.zadatak-meta {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-top: var(--sp-1);
}
.zadatak-rok {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.12em;
  color: var(--stone);
}
.zadatak-opis {
  display: none;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 300;
  color: var(--earth);
  margin-top: var(--sp-2);
  line-height: 1.6;
  padding-top: var(--sp-2);
  border-top: var(--border);
}
.zadatak-napomena {
  background: rgba(184, 146, 43, 0.08);
  border-left: 2px solid var(--ochre);
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 300;
  color: var(--earth);
  border-radius: 0 var(--radius) var(--radius) 0;
  margin-top: var(--sp-2);
}
.zadatak-kartica.otvoren .zadatak-opis {
  display: block;
}

/* 3L — Domain / area header */
.oblast-zaglavlje {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: var(--border-strong);
}
.oblast-broj {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ochre);
  flex-shrink: 0;
}
.oblast-naslov {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  color: var(--bark);
  flex: 1;
}
.oblast-progres {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}
.oblast-progres-tekst {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 300;
  color: var(--stone);
}

/* 3M — Grid layouts */
.grid-oblasti {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--sp-3);
}
.grid-statistike {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}
.grid-finansije {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}

/* 3N — Markdown content */
.markdown-sadrzaj {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 300;
  color: var(--bark);
  line-height: 1.7;
  max-width: 72ch;
}
.markdown-sadrzaj h1,
.markdown-sadrzaj h2,
.markdown-sadrzaj h3,
.markdown-sadrzaj h4 {
  margin-top: var(--sp-6);
  margin-bottom: var(--sp-3);
}
.markdown-sadrzaj h1 { font-size: 30px; }
.markdown-sadrzaj h2 { font-size: 22px; }
.markdown-sadrzaj h3 { font-size: 18px; }
.markdown-sadrzaj p {
  margin-bottom: var(--sp-3);
  font-size: 15px;
}
.markdown-sadrzaj ul,
.markdown-sadrzaj ol {
  padding-left: var(--sp-5);
  margin-bottom: var(--sp-3);
}
.markdown-sadrzaj li {
  margin-bottom: var(--sp-1);
}
.markdown-sadrzaj table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--sp-4);
  font-size: 14px;
}
.markdown-sadrzaj th {
  background: var(--cream-dk);
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--forest);
  padding: var(--sp-2) var(--sp-3);
  border: var(--border);
  text-align: left;
}
.markdown-sadrzaj td {
  padding: var(--sp-2) var(--sp-3);
  border: var(--border);
  font-weight: 300;
}
.markdown-sadrzaj blockquote {
  border-left: 3px solid var(--ochre);
  padding-left: var(--sp-4);
  margin: var(--sp-4) 0;
  color: var(--stone);
  font-style: italic;
}
.markdown-sadrzaj code {
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 13px;
  background: var(--cream-dk);
  padding: 1px var(--sp-1);
  border-radius: 2px;
  color: var(--earth);
}
.markdown-sadrzaj pre {
  background: var(--cream-dk);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--sp-4);
  overflow-x: auto;
  margin-bottom: var(--sp-4);
}
.markdown-sadrzaj pre code {
  background: none;
  padding: 0;
  font-size: 13px;
  color: var(--bark);
}
.markdown-sadrzaj hr {
  border: none;
  border-top: var(--border-strong);
  margin: var(--sp-5) 0;
}

/* 3O-a — Ornament divider */
.razdjelnick {
  display: flex;
  justify-content: center;
  margin: var(--sp-5) 0;
}

/* 3O-b — Site footer */
.site-footer {
  background: var(--bark);
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: var(--sp-3) var(--sp-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--stone-lt);
}
.footer-lijevo, .footer-desno {
  opacity: 0.7;
}

/* 3P — Responsive */
@media (max-width: 1024px) {
  .site-main {
    padding: var(--sp-5) var(--sp-4);
  }
  .grid-statistike,
  .grid-finansije {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .site-header {
    padding: 0 var(--sp-4);
  }
  .site-header nav {
    display: none;
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    background: var(--bark);
    border-bottom: 2px solid var(--forest);
    padding: var(--sp-3) var(--sp-4);
    z-index: 99;
  }
  .site-header nav.otvorena {
    display: block;
  }
  .site-nav {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
  .site-nav li {
    width: 100%;
  }
  .site-nav li a {
    display: block;
    padding: var(--sp-3) var(--sp-2);
    border-radius: 0;
  }
  .nav-toggle {
    display: flex;
  }
  .grid-oblasti {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-statistike,
  .grid-finansije {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .grid-oblasti {
    grid-template-columns: 1fr;
  }
  .site-main {
    padding: var(--sp-4) var(--sp-3);
  }
  .page-header h1 {
    font-size: 28px;
  }
  .progres-broj {
    font-size: 26px;
  }
}

/* 3Q — Admin panel */

.admin-banner { background: var(--ochre); padding: var(--sp-2) var(--sp-6);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-4); margin-bottom: var(--sp-6); border-radius: var(--radius); }

.admin-subnav { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.admin-subnav a { font-family: var(--sans); font-size: 11px; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--bark);
  opacity: 0.75; padding: var(--sp-1) var(--sp-3); border-radius: var(--radius);
  transition: opacity 0.15s, background 0.15s; }
.admin-subnav a:hover, .admin-subnav a.aktivan {
  opacity: 1; background: rgba(59,46,30,0.12); color: var(--bark); }

.admin-upozorenje { background: rgba(184,146,43,0.10);
  border-left: 3px solid var(--ochre); border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-4); font-family: var(--sans); font-size: 13px;
  font-weight: 300; color: var(--earth); margin-bottom: var(--sp-5); line-height: 1.6; }

.admin-saved-notice { background: rgba(45,74,34,0.09);
  border-left: 3px solid var(--forest); border-radius: var(--radius);
  padding: var(--sp-2) var(--sp-4); font-family: var(--sans); font-size: 13px;
  font-weight: 400; color: var(--forest); margin-bottom: var(--sp-4); }

.admin-input, .admin-select, .admin-textarea {
  width: 100%; font-family: var(--sans); font-size: 14px; font-weight: 300;
  color: var(--bark); background: var(--linen); border: var(--border-strong);
  border-radius: var(--radius); padding: var(--sp-2) var(--sp-3);
  transition: border-color 0.15s; }
.admin-input:focus, .admin-select:focus, .admin-textarea:focus {
  outline: none; border-color: var(--ochre);
  box-shadow: 0 0 0 2px rgba(184,146,43,0.18); }
.admin-textarea { resize: vertical; min-height: 72px; }

.btn-admin-save { display: inline-flex; align-items: center; font-family: var(--sans);
  font-size: 11px; font-weight: 400; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--linen); background: var(--forest); border: none; border-radius: var(--radius);
  padding: var(--sp-2) var(--sp-4); cursor: pointer; text-decoration: none;
  transition: background 0.15s; }
.btn-admin-save:hover { background: var(--forest-lt); color: var(--linen); }
