:root{
  /* ── BAZA ── */
  --bg:#0a1310;
  --bg-deep:#06100d;
  --panel:rgba(18,30,26,.58);
  --panel-hover:rgba(22,36,31,.72);
  --panel-solid:#121e1a;
  --line:rgba(120,180,160,.13);
  --line-strong:rgba(120,180,160,.26);
  --ink:#eef3ef;
  --ink-soft:#dde6e1;
  --muted:#7c9088;
  /* ── AKCENTI ── */
  --teal:#8fdf96;
  --teal-glow:#aef0b0;
  --topaz:#5cc6e8;
  --brass:#d7a94b;
  --brass-glow:#f0c66e;
  --rose:#e8758a;
  --sage:#9fd17a;
  /* ── GRAF ── */
  --root:#d7a94b;
  --folder:#8fdf96;
  --file:#5cc6e8;
  /* ── AKCENTI S PROZIRNOSCU (cisto, umjesto var(--teal)18 hакova) ── */
  --teal-08:rgba(143,223,150,.08);
  --teal-14:rgba(143,223,150,.14);
  --teal-22:rgba(143,223,150,.22);
  --teal-44:rgba(143,223,150,.44);
  --brass-14:rgba(215,169,75,.14);
  --brass-22:rgba(215,169,75,.22);
  --brass-44:rgba(215,169,75,.44);
  --rose-18:rgba(232,117,138,.18);
  --rose-2a:rgba(232,117,138,.26);
  --rose-44:rgba(232,117,138,.44);
  /* ── RITAM PRIJELAZA (ujednaceno) ── */
  --t-fast:.15s ease;
  --t-med:.22s cubic-bezier(.2,.7,.3,1);
  /* ── SJENE ── */
  --shadow-card:0 1px 0 rgba(255,255,255,.02), 0 10px 30px rgba(0,0,0,.28);
  --shadow-lift:0 1px 0 rgba(255,255,255,.04), 0 18px 44px rgba(0,0,0,.42);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{height:100%}
/* nikad ne dopusti vodoravno razvlačenje (na mobitelu razvlači cijeli layout) */
html,body{max-width:100%;overflow-x:hidden}
body{
  background: var(--bg);
  color:var(--ink);
  font-family:"Nunito Sans","Newsreader",system-ui,sans-serif;
  min-height:100vh;
  position:relative;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(rgba(120,180,160,.08) 1px, transparent 1px);
  background-size:26px 26px;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.03;z-index:60;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.mono{font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:1.5px}

/* LOGIN */
#login{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.card-login{
  width:min(380px,90vw);background:var(--panel);backdrop-filter:blur(20px);
  border:1px solid var(--line);border-radius:18px;padding:42px 34px 32px;
  box-shadow:0 30px 90px rgba(0,0,0,.6);animation:rise .7s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.card-login h1{font-size:30px;font-weight:600;letter-spacing:-.5px;margin-bottom:3px}
.card-login .sub{font-size:11px;color:var(--muted);margin-bottom:28px;font-family:"JetBrains Mono",monospace;letter-spacing:1px}
.field{margin-bottom:14px}
.field label{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:7px;font-family:"JetBrains Mono",monospace}
.field input{width:100%;background:var(--bg-deep);border:1px solid var(--line);color:var(--ink);padding:12px 14px;border-radius:10px;font-family:"JetBrains Mono",monospace;font-size:14px;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(143,223,150,.13)}
.field input::placeholder{color:rgba(124,144,136,.6)}
.btn{width:100%;margin-top:12px;padding:13px;border-radius:10px;cursor:pointer;background:linear-gradient(180deg,var(--teal),#5cc06a);color:#04130e;border:none;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;transition:filter var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);box-shadow:0 6px 18px rgba(143,223,150,.18)}
.btn:hover{filter:brightness(1.08);box-shadow:0 8px 24px rgba(143,223,150,.28)}
.btn:active{transform:translateY(1px)}
.err{color:var(--rose);font-size:12px;margin-top:12px;min-height:16px;font-family:"JetBrains Mono",monospace}
.ok{color:var(--teal);font-size:12px;margin-top:12px;min-height:16px;font-family:"JetBrains Mono",monospace}
.switch-line{margin-top:18px;font-size:12px;color:var(--muted);text-align:center;font-family:"JetBrains Mono",monospace}
.switch-line a{color:var(--teal);cursor:pointer;text-decoration:underline;transition:color var(--t-fast)}
.switch-line a:hover{color:var(--teal-glow)}

/* APP — bočni izbornik (lijevo) + sadržaj (desno) */
#app{display:none;position:relative;z-index:1;max-width:1320px;margin:0 auto;padding:0 26px 60px}
/* kad app.js postavi display:block (nakon prijave) → pretvori u grid (izbornik | sadržaj).
   !important jer inline style="display:block" inače nadjača. */
#app[style*="block"]{display:grid !important;grid-template-columns:236px 1fr;gap:30px;align-items:start}
/* stranica "Moji kursevi": zaključaj app na visinu ekrana → scroll ostaje u stupcima (izbornik + sadržaj), ne skrola cijela stranica. Ostale stranice (Dashboard/Profil/Dnevnik) ostaju normalne. */
#app.citac-aktivan[style*="block"]{height:100vh;overflow:hidden;padding-bottom:0}
#app.citac-aktivan #page-znanje{height:100%;overflow:hidden}
#app.citac-aktivan #page-znanje > section.block{height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:0;margin-bottom:0}
nav{display:flex;flex-direction:column;align-items:stretch;gap:14px;padding:24px 0 18px;position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;border-right:1px solid var(--line);margin-right:4px}
nav::-webkit-scrollbar{width:7px}
nav::-webkit-scrollbar-thumb{background:rgba(120,180,160,.2);border-radius:4px}
nav::-webkit-scrollbar-track{background:transparent}
@media(max-width:820px){ nav{border-right:none;margin-right:0} }
.brand{display:flex;align-items:center;gap:12px;padding:0 8px 4px}
.mark{width:34px;height:34px;border-radius:50%;background:conic-gradient(from 0deg,var(--teal),var(--topaz),var(--brass),var(--teal));display:flex;align-items:center;justify-content:center;position:relative}
.mark::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--teal-glow);box-shadow:0 0 12px var(--teal-glow);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.brand .name{font-size:18px;font-weight:600;line-height:1}
.brand .tag{font-size:9px;color:var(--muted);font-family:"JetBrains Mono",monospace;letter-spacing:2px;margin-top:3px}
.spacer{flex:1}
.clock{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--teal);letter-spacing:1px;padding:0 8px}
nav .logout{background:transparent;border:1px solid var(--line);color:var(--muted);padding:10px 12px;border-radius:8px;font-family:"JetBrains Mono",monospace;font-size:10px;cursor:pointer;letter-spacing:1px;transition:color var(--t-fast),border-color var(--t-fast);text-align:left}
nav .logout:hover{color:var(--ink);border-color:var(--line-strong)}

/* TABOVI → bočni izbornik (uspravni stupac) */
.tabs{display:flex;flex-direction:column;gap:4px;background:transparent;border:none;border-radius:0;padding:8px 0}
.tab{padding:11px 14px;border-radius:10px;cursor:pointer;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.5px;text-transform:none;color:var(--muted);border:1px solid transparent;background:transparent;transition:color var(--t-fast),background var(--t-fast),border-color var(--t-fast);text-align:left;width:100%}
.tab:hover{color:var(--ink);background:var(--teal-08)}
.tab.active{background:var(--teal-14);color:var(--teal);border-color:var(--teal-44);font-weight:500}

.panel{background:var(--panel);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow-card);transition:border-color var(--t-med),box-shadow var(--t-med),transform var(--t-med)}
.eyebrow{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:2.5px;color:var(--teal);text-transform:uppercase;margin-bottom:6px}
h2.big{font-size:clamp(28px,4vw,46px);font-weight:500;letter-spacing:-1px;margin-bottom:22px}

.tabview{display:none;animation:fade .4s ease}
.tabview.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.block{margin-bottom:48px;animation:fade .5s ease both}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--panel);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:14px;padding:20px;border-top:2px solid;box-shadow:var(--shadow-card);transition:transform var(--t-med),box-shadow var(--t-med),border-color var(--t-med)}
.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.stat .l{font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}
.stat .v{font-size:38px;font-weight:600;margin-top:8px;line-height:1}
.stat .s{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);margin-top:6px}

.row2{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;margin-top:18px}
@media(max-width:900px){.row2{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}}

.donutwrap{display:flex;align-items:center;gap:20px}
.legend{font-family:"JetBrains Mono",monospace;font-size:11px;line-height:2}
.legend .dot{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:8px}

.feed-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);transition:padding-left var(--t-fast)}
.feed-item:last-child{border:0}
.feed-item:hover{padding-left:4px}
.badge{font-family:"JetBrains Mono",monospace;font-size:9px;padding:3px 8px;border-radius:5px;letter-spacing:1px}
.feed-item .nm{flex:1;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feed-item .tm{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted)}

.notes-layout{display:grid;grid-template-columns:300px 1fr;gap:18px;min-height:560px}
@media(max-width:900px){.notes-layout{grid-template-columns:1fr}}
.note-list{max-height:640px;overflow:auto}
.folder-group{margin-bottom:14px}
.folder-group .fh{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:1.5px;color:var(--brass);text-transform:uppercase;margin:6px 0 6px;padding:4px 2px;cursor:pointer;display:flex;align-items:center;gap:6px;border-radius:6px;transition:background var(--t-fast)}
.folder-group .fh:hover{background:var(--teal-08)}
.folder-group .fh .fh-tw{display:inline-block;width:10px;font-size:9px;opacity:.8}
.folder-group .fh .fh-cnt{margin-left:auto;color:var(--muted);font-size:9px;letter-spacing:0}
.folder-notes.collapsed{display:none}
.note-row{padding:9px 11px;border-radius:8px;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),padding-left var(--t-fast);border-left:2px solid transparent}
.note-row:hover{background:var(--teal-08);padding-left:14px}
.note-row.sel{background:var(--teal-14);border-left-color:var(--teal)}
.note-row .t{font-size:14px;line-height:1.3}
.note-row .p{font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.preview{overflow:auto;max-height:640px}
.preview .empty{color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12px;text-align:center;padding-top:120px;letter-spacing:1px}
.md h1{font-size:26px;font-weight:600;margin:0 0 14px;letter-spacing:-.5px}
.md h2{font-size:20px;font-weight:600;margin:22px 0 10px;color:var(--teal-glow)}
.md h3{font-size:16px;font-weight:600;margin:18px 0 8px;color:var(--topaz)}
.md p{font-size:15px;line-height:1.7;margin:10px 0;color:var(--ink-soft)}
.md ul,.md ol{margin:10px 0 10px 22px}
.md li{font-size:15px;line-height:1.7;margin:4px 0}
.md code{font-family:"JetBrains Mono",monospace;font-size:12px;background:var(--bg-deep);padding:2px 6px;border-radius:4px;color:var(--brass-glow)}
.md pre{background:var(--bg-deep);border:1px solid var(--line);border-radius:8px;padding:14px;overflow:auto;margin:12px 0}
.md pre code{background:none;padding:0;color:#c9d4ce}
.md table{border-collapse:collapse;margin:12px 0;width:100%}
.md th,.md td{border:1px solid var(--line);padding:7px 11px;font-size:13px;text-align:left}
.md th{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:1px;color:var(--muted)}
.md blockquote{border-left:2px solid var(--teal);padding-left:14px;color:var(--muted);margin:12px 0}
.md hr{border:0;border-top:1px solid var(--line);margin:18px 0}

/* GRAF (struktura) */
.struktura-layout{display:grid;grid-template-columns:380px 1fr;gap:18px}
@media(max-width:900px){.struktura-layout{grid-template-columns:1fr}}
.graf-wrap{position:relative;height:600px;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:rgba(8,17,14,.4)}
#grafCanvas{display:block;cursor:grab;touch-action:none}
#grafCanvas:active{cursor:grabbing}
.graf-legend{position:absolute;left:16px;bottom:16px;background:var(--panel);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:10px;padding:12px 15px;font-family:"JetBrains Mono",monospace;font-size:11px;line-height:1.9}
.graf-legend .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:8px;vertical-align:middle}

/* file tree */
.tree{font-family:"JetBrains Mono",monospace;font-size:13px;max-height:600px;overflow:auto}
.tree-item{padding:4px 6px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:background var(--t-fast);user-select:none}
.tree-item:hover{background:var(--teal-08)}
.tree-item .tw{display:inline-block;width:12px;color:var(--muted);font-size:10px;flex:none;text-align:center}
.tree-item .ic{flex:none}
.tree-item .lbl{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tree-item .sz{color:var(--muted);font-size:10px;flex:none}
.tree-children{margin-left:16px;border-left:1px solid var(--line);padding-left:4px}
.tree-children.collapsed{display:none}
.tree-item.is-file .lbl{color:var(--ink-soft)}
.tree-item.is-folder .lbl{font-weight:500}

/* size bars */
.sizebar-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}
.sizebar-row:last-child{border:0}
.sizebar-row .nm{font-family:"JetBrains Mono",monospace;font-size:11px;width:120px;flex:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sizebar-track{flex:1;height:6px;background:rgba(120,180,160,.1);border-radius:3px;overflow:hidden}
.sizebar-fill{height:100%;border-radius:3px}
.sizebar-row .val{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);width:64px;text-align:right;flex:none}

.loading{text-align:center;padding:60px;color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12px}

/* MOJ RAČUN */
.acct-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;align-items:start}
@media(max-width:760px){.acct-grid{grid-template-columns:1fr}}
.acct-card{max-width:none}
.acct-head{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--brass);margin-bottom:16px}
.acct-card .field{margin-bottom:12px}
.acct-card input:disabled{opacity:.5;cursor:not-allowed}
.abtn.save{font-family:"JetBrains Mono",monospace;font-size:11px;padding:9px 16px;border-radius:8px;cursor:pointer;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast);margin-top:4px}
.abtn.save:hover{background:var(--teal-22);border-color:var(--teal)}
.msg{font-family:"JetBrains Mono",monospace;font-size:11px;margin-top:8px;min-height:14px}
.msg.ok{color:var(--teal)}
.msg.err{color:var(--rose)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.danger-zone{border-color:var(--rose-44)}
.danger-head{color:var(--rose)}
.dz-text{font-size:13px;line-height:1.55;color:var(--muted);margin-bottom:14px}
.acct-note{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);margin-top:14px;line-height:1.5}
.apikey-status{font-family:"JetBrains Mono",monospace;font-size:12px;padding:8px 12px;border-radius:8px;display:inline-block}
.apikey-status.set{background:var(--teal-22);color:var(--teal)}
.apikey-status.unset{background:var(--brass-22);color:var(--brass)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(5,12,10,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-card{background:var(--panel-solid);border:1px solid var(--line-strong);border-radius:16px;padding:28px;max-width:420px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:popIn .18s ease}
@keyframes popIn{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-title{font-family:"Nunito Sans",sans-serif;font-size:22px;font-weight:600;margin-bottom:10px;color:var(--ink)}
.modal-text{font-size:14px;line-height:1.6;color:var(--muted);margin-bottom:24px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}
.modal-btn{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 18px;border-radius:9px;cursor:pointer;letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast);border:1px solid var(--line);background:transparent;color:var(--ink)}
.modal-btn.cancel:hover{border-color:var(--ink);background:rgba(255,255,255,.04)}
.modal-btn.confirm{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.modal-btn.confirm:hover{background:var(--rose-2a);border-color:var(--rose)}

/* ADMIN korisnici */
.user-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.user-row:last-child{border:0}
.user-row .who{flex:1;min-width:0}
.user-row .who .u{font-size:15px;font-weight:500}
.user-row .who .e{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-row .st{font-family:"JetBrains Mono",monospace;font-size:10px;padding:4px 9px;border-radius:6px;letter-spacing:1px;text-transform:uppercase;flex:none}
.st-ceka{background:var(--brass-22);color:var(--brass)}
.st-odobren{background:var(--teal-22);color:var(--teal)}
.st-blokiran{background:var(--rose-2a);color:var(--rose)}
.user-row .acts{display:flex;gap:6px;flex:none}
.abtn{font-family:"JetBrains Mono",monospace;font-size:10px;padding:6px 11px;border-radius:6px;cursor:pointer;border:1px solid var(--line);background:transparent;color:var(--ink);letter-spacing:.5px;transition:color var(--t-fast),border-color var(--t-fast)}
.abtn:hover{border-color:var(--teal);color:var(--teal)}
.abtn.danger:hover{border-color:var(--rose);color:var(--rose)}
.urole{font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--muted);margin-left:6px}

/* FINANCIAL RESEARCH (uskladeno s paletom — prije tvrde boje #0f1923 itd.) */
.fr-box{max-width:720px;margin:0 auto;padding:20px}
.fr-opis{color:var(--muted);margin-bottom:16px;line-height:1.6}
.fr-input{width:100%;box-sizing:border-box;padding:13px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg-deep);color:var(--ink);font-size:15px;font-family:"JetBrains Mono",monospace;resize:vertical;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.fr-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(143,223,150,.13)}
.fr-input::placeholder{color:rgba(124,144,136,.6)}
.fr-gumb{margin-top:12px;padding:12px 24px;border:none;border-radius:10px;background:linear-gradient(180deg,var(--teal),#5cc06a);color:#04201c;font-weight:700;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:filter var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);box-shadow:0 6px 18px rgba(143,223,150,.18)}
.fr-gumb:hover{filter:brightness(1.08);box-shadow:0 8px 24px rgba(143,223,150,.28)}
.fr-gumb:active{transform:translateY(1px)}
.fr-gumb:disabled{opacity:.6;cursor:default;box-shadow:none;filter:none}
.fr-odgovor{margin-top:18px;padding:28px 30px;border-radius:14px;background:var(--bg-deep);border:1px solid var(--line);border-top:2px solid var(--teal);line-height:1.7;white-space:normal;color:var(--ink-soft);box-shadow:var(--shadow-card)}
.fr-odgovor:empty{display:none}
.fr-odgovor h1,.fr-odgovor h2{font-family:"Nunito Sans",sans-serif;font-size:21px;font-weight:600;color:var(--teal-glow);margin:26px 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(120,180,160,.18);letter-spacing:-.3px}
.fr-odgovor h1:first-child,.fr-odgovor h2:first-child{margin-top:0}
.fr-odgovor h3{font-family:"Nunito Sans",sans-serif;font-size:17px;font-weight:600;color:var(--topaz);margin:20px 0 8px}
.fr-odgovor p{margin:0 0 14px;font-size:15px;line-height:1.75}
.fr-odgovor p:last-child{margin-bottom:0}
.fr-odgovor ul,.fr-odgovor ol{margin:0 0 14px 22px}
.fr-odgovor li{margin:5px 0;line-height:1.7}
.fr-odgovor strong{color:var(--brass-glow);font-weight:600}
.fr-odgovor p:last-of-type:not(:only-of-type){margin-top:18px;padding-top:14px;border-top:1px solid rgba(120,180,160,.12);font-size:13px;color:var(--muted);font-style:italic}

/* SKINI VAULT gumb (admin) */
.vault-actions{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.vault-dl-btn{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;padding:10px 18px;border-radius:9px;cursor:pointer;border:1px solid var(--brass-44);background:var(--brass-14);color:var(--brass);transition:background var(--t-fast),border-color var(--t-fast)}
.vault-dl-btn:hover{background:var(--brass-22);border-color:var(--brass)}
.vault-dl-btn:disabled{opacity:.6;cursor:default}
.vault-dl-msg{font-family:"JetBrains Mono",monospace;font-size:11px;min-height:14px}
.vault-dl-msg.ok{color:var(--teal)}
.vault-dl-msg.err{color:var(--rose)}

/* ============================================
   ZNANJE — agent-učitelj (chat sučelje)
   ============================================ */
.zn-opis{color:var(--muted);margin-bottom:18px;line-height:1.6}
/* izbornik modela */
.zn-model-red{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.zn-model-red label{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-soft)}
.zn-model{padding:9px 12px;border-radius:9px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink);font-family:"JetBrains Mono",monospace;font-size:13px;cursor:pointer;transition:border-color var(--t-fast)}
.zn-model:focus{outline:none;border-color:var(--teal)}
.zn-model-info{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
/* izbor teme */
.zn-teme{display:flex;flex-wrap:wrap;gap:12px}
.zn-tema-btn{display:flex;flex-direction:column;gap:5px;text-align:left;padding:16px 20px;min-width:200px;border-radius:12px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}
.zn-tema-btn:hover{border-color:var(--teal);background:var(--panel-hover);transform:translateY(-2px)}
.zn-tema-ime{font-family:"Nunito Sans",sans-serif;font-size:18px;font-weight:600;color:var(--teal-glow)}
.zn-tema-meta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
/* chat panel */
.zn-chat-panel{display:flex;flex-direction:column}
.zn-chat-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.zn-head-akcije{display:flex;gap:8px;flex-wrap:wrap}
.zn-chat-tema{font-family:"Nunito Sans",sans-serif;font-size:18px;font-weight:600;color:var(--teal-glow)}
.zn-novi{font-family:"JetBrains Mono",monospace;font-size:11px;padding:7px 13px;border-radius:8px;cursor:pointer;border:1px solid var(--line-strong);background:transparent;color:var(--muted);transition:color var(--t-fast),border-color var(--t-fast)}
.zn-novi:hover{color:var(--ink);border-color:var(--teal)}
/* poruke */
.zn-poruke{display:flex;flex-direction:column;gap:14px;min-height:240px;max-height:52vh;overflow-y:auto;padding:4px 2px 8px}
.zn-poruka{max-width:85%;padding:13px 16px;border-radius:14px;line-height:1.65;font-size:15px;white-space:normal}
.zn-poruka.agent{align-self:flex-start;background:var(--bg-deep);border:1px solid var(--line);border-top-left-radius:4px;color:var(--ink-soft)}
.zn-poruka.korisnik{align-self:flex-end;background:var(--teal-14);border:1px solid var(--teal-22);border-top-right-radius:4px;color:var(--ink)}
.zn-poruka p{margin:0 0 10px}
.zn-poruka p:last-child{margin:0}
.zn-poruka strong{color:var(--brass-glow);font-weight:600}
.zn-poruka em{color:var(--muted)}
.zn-tipka{align-self:flex-start;color:var(--muted);font-style:italic;font-size:13px;padding:6px 4px}
/* unos */
.zn-unos-red{display:flex;gap:10px;margin-top:16px;align-items:flex-end}
.zn-unos{flex:1;box-sizing:border-box;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg-deep);color:var(--ink);font-size:15px;font-family:"JetBrains Mono",monospace;resize:vertical;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.zn-unos:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(143,223,150,.13)}
.zn-unos::placeholder{color:rgba(124,144,136,.6)}
.zn-posalji{padding:12px 22px;border:none;border-radius:10px;background:linear-gradient(180deg,var(--teal),#5cc06a);color:#04201c;font-weight:700;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:filter var(--t-fast),transform var(--t-fast)}
.zn-posalji:hover{filter:brightness(1.08)}
.zn-posalji:active{transform:translateY(1px)}
.zn-posalji:disabled{opacity:.6;cursor:default;filter:none}

/* ============================================
   ZNANJE — ČITAČ LEKCIJA (Network+)
   ============================================ */
.zn-citac-panel{display:flex;flex-direction:column;max-height:calc(100vh - 90px);overflow:hidden}
/* kad je app zaključan (stranica Moji kursevi), panel popuni preostalu visinu */
#app.citac-aktivan .zn-citac-panel{max-height:none;flex:1;min-height:0}
/* izbor teme / chat na zaključanoj stranici: smiju skrolati unutar sebe */
#app.citac-aktivan #znanjeIzbor,#app.citac-aktivan .zn-chat-panel{flex:1;min-height:0;overflow-y:auto}
.zn-citac-panel > .zn-chat-head{flex:none}
/* ── KURSEVI/LEKCIJE U BOČNOM IZBORNIKU (ispod "Moji kursevi") ── */
.zn-nav-kursevi{display:flex;flex-direction:column;gap:2px;margin:2px 0 6px;padding-left:6px;border-left:1px solid var(--line)}
.zn-nav-prazno{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);padding:8px 10px}
/* TEMA (Network+/Security+/C#) — prva razina akordeona u izborniku */
.zn-nav-tema-glava{display:flex;align-items:center;gap:7px;padding:8px 9px;cursor:pointer;user-select:none;border-radius:8px;transition:background var(--t-fast)}
.zn-nav-tema-glava:hover{background:var(--teal-08)}
.zn-nav-tema-tw{display:inline-block;width:9px;font-size:8px;color:var(--teal);flex:none}
.zn-nav-tema-ime{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.3px;color:var(--teal-glow);flex:1;line-height:1.3}
.zn-nav-tema.otvorena .zn-nav-tema-ime{color:var(--teal)}
/* pod-okvir kurseva teme — vidljiv samo kad je tema otvorena */
.zn-nav-tema-kursevi{display:none;flex-direction:column;gap:2px;padding:2px 0 4px 6px;margin-left:4px;border-left:1px solid var(--line)}
.zn-nav-tema.otvorena .zn-nav-tema-kursevi{display:flex}
/* kurs (sklopiv) u izborniku */
.zn-nav-kursevi .znc-kurs{margin-bottom:2px;border:none;border-radius:8px;overflow:hidden;background:transparent}
.zn-nav-kursevi .znc-kurs-glava{display:flex;align-items:center;gap:7px;padding:8px 9px;cursor:pointer;user-select:none;border-radius:8px;transition:background var(--t-fast)}
.zn-nav-kursevi .znc-kurs-glava:hover{background:var(--teal-08)}
.zn-nav-kursevi .znc-kurs-tw{display:inline-block;width:9px;font-size:8px;color:var(--teal);flex:none}
.zn-nav-kursevi .znc-kurs-naslov{font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--brass);flex:1;line-height:1.35}
.zn-nav-kursevi .znc-kurs.otvoren .znc-kurs-naslov{color:var(--brass-glow)}
.zn-nav-kursevi .znc-kurs-brojka{font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--muted);flex:none}
/* progress traka — sakrivena u uskom izborniku (premalo mjesta), brojka je dovoljna */
.zn-nav-kursevi .znc-kurs-progress{display:none !important}
/* lekcije — vidljive samo kad je kurs otvoren */
.zn-nav-kursevi .znc-lekcije{display:none;flex-direction:column;gap:2px;padding:3px 0 6px 6px}
.zn-nav-kursevi .znc-kurs.otvoren .znc-lekcije{display:flex}
.zn-nav-kursevi .znc-lek-btn{display:flex;align-items:center;gap:7px;text-align:left;width:100%;padding:6px 8px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--ink-soft);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-nav-kursevi .znc-lek-btn:hover{border-color:var(--teal);background:var(--panel-hover)}
.zn-nav-kursevi .znc-lek-btn.aktivna{border-color:var(--teal-44);background:var(--teal-14)}
.zn-nav-kursevi .znc-lek-kvacica{font-family:"JetBrains Mono",monospace;font-size:11px;width:12px;text-align:center;color:var(--muted);flex:none}
.zn-nav-kursevi .znc-lek-btn.procitano .znc-lek-kvacica{color:var(--teal)}
.zn-nav-kursevi .znc-lek-btn.procitano{opacity:.6}
.zn-nav-kursevi .znc-lek-btn.procitano:hover,.zn-nav-kursevi .znc-lek-btn.aktivna{opacity:1}
.zn-nav-kursevi .znc-lek-broj{font-family:"JetBrains Mono",monospace;font-size:8.5px;color:var(--teal);background:var(--teal-14);border:1px solid var(--teal-22);min-width:17px;height:17px;padding:0 3px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex:none}
.zn-nav-kursevi .znc-lek-ime{font-size:11px;line-height:1.3}
/* Practice Lab placeholder u izborniku (sitan) */
.zn-nav-kursevi .znc-lab-uskoro{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:7px;border:1px dashed var(--line-strong);opacity:.5;cursor:default}
/* Kviz teme (klikabilno) u izborniku */
.zn-nav-kursevi .znc-lab-kviz{display:flex;align-items:center;gap:7px;width:100%;padding:6px 8px;border-radius:7px;border:1px solid var(--brass-44);background:var(--brass-14);color:var(--brass);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-nav-kursevi .znc-lab-kviz:hover{background:var(--brass-22);border-color:var(--brass)}
.zn-nav-kursevi .znc-lab-kviz .znc-lab-ikona{font-size:11px;width:12px;text-align:center;flex:none;filter:none}
.zn-nav-kursevi .znc-lab-kviz .znc-lab-ime{font-size:10px;flex:1;color:var(--brass)}
.zn-nav-kursevi .znc-lab-kviz .znc-lab-oznaka{font-family:"JetBrains Mono",monospace;font-size:7.5px;letter-spacing:.5px;text-transform:uppercase;padding:2px 5px;border-radius:5px;background:transparent;color:var(--muted);flex:none}
/* Vodič teme (klikabilno) u izborniku — teal, da se razlikuje od kviza (brass) */
.zn-nav-kursevi .znc-lab-vodic{display:flex;align-items:center;gap:7px;width:100%;margin-top:4px;padding:6px 8px;border-radius:7px;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-nav-kursevi .znc-lab-vodic:hover{background:var(--teal-22);border-color:var(--teal)}
.zn-nav-kursevi .znc-lab-vodic .znc-lab-ikona{font-size:11px;width:12px;text-align:center;flex:none;filter:none}
.zn-nav-kursevi .znc-lab-vodic .znc-lab-ime{font-size:10px;flex:1;color:var(--teal)}
.zn-nav-kursevi .znc-lab-vodic .znc-lab-oznaka{font-family:"JetBrains Mono",monospace;font-size:7.5px;letter-spacing:.5px;text-transform:uppercase;padding:2px 5px;border-radius:5px;background:transparent;color:var(--muted);flex:none}
/* vodič tekst (desno) */
.zn-vodic{padding:4px 2px}
.zn-vodic h2{font-size:18px;font-weight:600;margin:20px 0 8px;color:var(--teal-glow)}
.zn-vodic h2:first-child{margin-top:0}
/* gumb "Vježba" na lekciji (ljubičasto-plavi, da se razlikuje) */
.zn-vjezba-btn{padding:8px 14px;border-radius:8px;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);font-size:13px;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-vjezba-btn:hover{background:var(--teal-22);border-color:var(--teal)}
/* vježba: objašnjeni primjer + zadaci */
.zn-vj-primjer{margin:4px 0 18px}
.zn-vj-primjer-naslov{font-size:14px;font-weight:600;color:var(--teal-glow);margin-bottom:8px}
.zn-vj-objasnjenje{margin-top:10px;font-size:14px;line-height:1.6;color:var(--ink)}
.zn-vj-zadaci-naslov{font-size:14px;font-weight:600;color:var(--brass);margin:18px 0 10px;display:flex;align-items:center;gap:8px}
.zn-vj-lista{display:flex;flex-direction:column;gap:6px}
.zn-nav-kursevi .znc-lab-ikona{font-size:11px;width:12px;text-align:center;flex:none;filter:grayscale(1)}
.zn-nav-kursevi .znc-lab-ime{font-size:10px;flex:1;color:var(--muted)}
.zn-nav-kursevi .znc-lab-oznaka{font-family:"JetBrains Mono",monospace;font-size:7.5px;letter-spacing:.5px;text-transform:uppercase;padding:2px 5px;border-radius:5px;background:rgba(120,180,160,.1);color:var(--muted);flex:none}
/* stranica "Moji kursevi": zbij naslov gore da čitač krene više (manje praznog prostora) */
#page-znanje .block{margin-bottom:0}
#page-znanje h2.big{margin-bottom:14px}
#page-znanje .eyebrow{margin-bottom:4px}
/* DVOSTUPAC: lijevo navigacija (kursevi/lekcije), desno sadržaj */
.znc-split{display:grid;grid-template-columns:300px 1fr;gap:22px;align-items:start;margin-top:4px}
.znc-nav{position:sticky;top:8px;max-height:calc(100vh - 120px);overflow-y:auto;padding-right:4px}
.znc-sadrzaj{min-width:0;flex:1;overflow-y:auto;padding-right:6px}
/* prazno stanje desno (dok ništa nije izabrano) */
.znc-prazno{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:300px;text-align:center;color:var(--muted)}
.znc-prazno-ikona{font-size:42px;opacity:.5}
.znc-prazno-tekst{font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:.5px;max-width:280px;line-height:1.6}
/* popis kurseva (akordeon) + lekcije */
.znc-kurs{margin-bottom:8px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-deep)}
.znc-kurs-glava{display:flex;align-items:center;gap:9px;padding:12px 14px;cursor:pointer;user-select:none;transition:background var(--t-fast)}
.znc-kurs-glava:hover{background:var(--teal-08)}
.znc-kurs-tw{display:inline-block;width:12px;font-size:10px;color:var(--teal);flex:none}
.znc-kurs-naslov{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--brass);flex:1;line-height:1.45}
.znc-kurs.otvoren .znc-kurs-naslov{color:var(--brass-glow)}
.znc-kurs-brojka{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);flex:none}
/* progress traka kursa (ispod glave) — vidljiva samo kad je kurs otvoren */
.znc-kurs-progress{display:none;align-items:center;gap:10px;padding:0 14px 4px}
.znc-kurs.otvoren .znc-kurs-progress{display:flex}
.znc-kurs-traka{flex:1;height:5px;background:rgba(120,180,160,.12);border-radius:3px;overflow:hidden}
.znc-kurs-traka-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--teal),var(--teal-glow));transition:width var(--t-med)}
/* lekcije — vidljive samo kad je kurs otvoren (akordeon) */
.znc-lekcije{display:none;flex-direction:column;gap:5px;padding:6px 10px 12px}
.znc-kurs.otvoren .znc-lekcije{display:flex}
.znc-lek-btn{display:flex;align-items:center;gap:10px;text-align:left;width:100%;padding:9px 11px;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--ink-soft);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),padding-left var(--t-fast)}
.znc-lek-btn:hover{border-color:var(--teal);background:var(--panel-hover);padding-left:15px}
.znc-lek-btn.aktivna{border-color:var(--teal-44);background:var(--teal-14)}
.znc-lek-broj{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--teal);background:var(--teal-14);border:1px solid var(--teal-22);width:23px;height:23px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex:none}
.znc-lek-ime{font-size:13px;line-height:1.35}
/* kvačica pročitano */
.znc-lek-kvacica{font-family:"JetBrains Mono",monospace;font-size:13px;width:16px;text-align:center;color:var(--muted);flex:none}
.znc-lek-btn.procitano .znc-lek-kvacica{color:var(--teal)}
.znc-lek-btn.procitano{opacity:.62}
.znc-lek-btn.procitano:hover,.znc-lek-btn.aktivna{opacity:1}
.znc-lek-btn.procitano .znc-lek-broj{background:var(--teal-22);border-color:var(--teal-44)}
/* Practice Lab placeholder (sivkasti red "uskoro" na dnu kursa — ne radi ništa zasad) */
.znc-lab-uskoro{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;border:1px dashed var(--line-strong);background:transparent;color:var(--muted);opacity:.55;cursor:default;user-select:none}
.znc-lab-ikona{font-size:14px;width:16px;text-align:center;flex:none;filter:grayscale(1)}
.znc-lab-ime{font-size:13px;flex:1}
.znc-lab-oznaka{font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:6px;background:rgba(120,180,160,.1);color:var(--muted);flex:none}
/* dugme "Označi pročitano" na dnu lekcije */
.zn-procitano{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 18px;border-radius:9px;cursor:pointer;border:1px solid var(--line-strong);background:transparent;color:var(--muted);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.zn-procitano:hover{border-color:var(--teal);color:var(--teal)}
.zn-procitano.procitano{background:var(--teal-14);border-color:var(--teal-44);color:var(--teal)}
/* prikaz lekcije */
.zn-lek-naslov{font-family:"Nunito Sans",sans-serif;font-size:24px;font-weight:600;color:var(--teal-glow);margin:6px 0 18px;letter-spacing:-.4px}
.zn-sekcije{display:flex;flex-direction:column;gap:10px}
/* sekcija (sklopiva kartica) */
.znc-sekcija{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-deep)}
.znc-sek-glava{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none;transition:background var(--t-fast)}
.znc-sek-glava:hover{background:var(--teal-08)}
.znc-sek-tw{display:inline-block;width:12px;font-size:10px;color:var(--teal);flex:none}
.znc-sek-naslov{font-family:"Nunito Sans",sans-serif;font-size:17px;font-weight:600;color:var(--topaz)}
.znc-sek-tijelo{padding:0 18px 16px 38px}
.znc-sekcija.collapsed .znc-sek-tijelo{display:none}
/* navigacija lekcija + pitaj AI */
.zn-lek-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--line);flex-wrap:wrap}
.zn-pitaj-ai{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 18px;border-radius:9px;cursor:pointer;border:1px solid var(--brass-44);background:var(--brass-14);color:var(--brass);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-pitaj-ai:hover{background:var(--brass-22);border-color:var(--brass)}

/* ── KVIZ (provjera znanja) ── */
.zn-kviz-uvod{font-size:14px;line-height:1.6;color:var(--ink-soft);padding:12px 14px;margin-bottom:8px;border:1px solid var(--brass-44);border-left:2px solid var(--brass);border-radius:10px;background:var(--brass-14)}
.zn-kviz-prazno{color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:13px;padding:18px 4px;line-height:1.6}
.zn-kviz-pitanje{margin:16px 0;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--bg-deep)}
.zn-kviz-tekst{font-size:15px;line-height:1.5;margin-bottom:12px;color:var(--ink)}
.zn-kviz-opcije{display:flex;flex-direction:column;gap:8px}
.zn-kviz-opcija{text-align:left;padding:11px 14px;border-radius:9px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;font-size:14px;line-height:1.4;transition:border-color var(--t-fast),background var(--t-fast)}
.zn-kviz-opcija:hover:not(:disabled){border-color:var(--teal);background:var(--teal-08)}
.zn-kviz-opcija.izabrano{border-color:var(--teal);background:var(--teal-14);color:var(--ink)}
.zn-kviz-opcija.tocno{border-color:var(--teal);background:var(--teal-22);color:var(--teal)}
.zn-kviz-opcija.netocno{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.zn-kviz-opcija:disabled{cursor:default}
.zn-kviz-rezultat{margin-top:14px;font-size:16px;color:var(--ink);min-height:20px}
.zn-kviz-rezultat strong{color:var(--teal)}

/* ── FLASHCARTICE (pamćenje) ── */
.zn-flash-brojac{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;color:var(--muted);text-align:center;margin:6px 0 12px}
.zn-flash-kartica{min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:28px 22px;border:1px solid var(--line-strong);border-radius:16px;background:var(--bg-deep);cursor:pointer;text-align:center;transition:border-color var(--t-fast),background var(--t-fast)}
.zn-flash-kartica:hover{border-color:var(--teal)}
.zn-flash-kartica.okrenuta{cursor:default;border-color:var(--teal-44);background:var(--teal-08)}
.zn-flash-strana{font-size:18px;line-height:1.5;color:var(--ink)}
.zn-flash-strana.odgovor{color:var(--ink-soft);font-size:16px}
.zn-flash-uputa{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.zn-flash-gumbi{display:flex;gap:10px;margin-top:14px}
.zn-flash-znao,.zn-flash-nisam{flex:1;padding:12px;border-radius:10px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.5px;cursor:pointer;border:1px solid;transition:background var(--t-fast),border-color var(--t-fast)}
.zn-flash-znao{background:var(--teal-14);border-color:var(--teal-44);color:var(--teal)}
.zn-flash-znao:hover{background:var(--teal-22);border-color:var(--teal)}
.zn-flash-nisam{background:transparent;border-color:var(--line-strong);color:var(--muted)}
.zn-flash-nisam:hover{border-color:var(--rose-44);color:var(--rose)}
.zn-flash-kraj{text-align:center;font-size:16px;color:var(--ink);line-height:1.7;padding:24px 12px}
.zn-flash-kraj strong{color:var(--teal)}

/* ============================================
   TRAINING LIBRARY — vježba kroz pitanja
   ============================================ */
/* izbor predmeta (kartice) */
.tl-predmeti-grid{display:flex;flex-wrap:wrap;gap:12px}
.tl-predmet-btn{display:flex;flex-direction:column;gap:6px;text-align:left;padding:18px 22px;min-width:220px;border-radius:12px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}
.tl-predmet-btn:hover{border-color:var(--teal);background:var(--panel-hover);transform:translateY(-2px)}
.tl-predmet-ime{font-family:"Nunito Sans",sans-serif;font-size:18px;font-weight:600;color:var(--teal-glow)}
.tl-predmet-meta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
/* lista kvizova */
.tl-kvizovi-lista{display:flex;flex-direction:column;gap:10px}
.tl-kviz-kartica{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:var(--bg-deep);flex-wrap:wrap}
.tl-kviz-info{flex:1;min-width:200px}
.tl-kviz-ime{font-size:16px;font-weight:500;color:var(--ink);margin-bottom:4px}
.tl-kviz-stat{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.tl-kviz-akcije{display:flex;gap:8px;flex-wrap:wrap}
.tl-kviz-start{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 18px;border-radius:9px;cursor:pointer;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast)}
.tl-kviz-start:hover{background:var(--teal-22);border-color:var(--teal)}
.tl-kviz-pogr{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 16px;border-radius:9px;cursor:pointer;border:1px solid var(--brass-44);background:var(--brass-14);color:var(--brass);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast)}
.tl-kviz-pogr:hover{background:var(--brass-22);border-color:var(--brass)}
/* kviz u tijeku */
.tl-kviz-meta{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;color:var(--muted);margin-bottom:16px}
.tl-pitanje{margin:14px 0;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--bg-deep)}
.tl-pitanje-tekst{font-size:15px;line-height:1.5;margin-bottom:12px;color:var(--ink)}
.tl-opcije{display:flex;flex-direction:column;gap:8px}
.tl-opcija{text-align:left;padding:11px 14px;border-radius:9px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;font-size:14px;line-height:1.4;transition:border-color var(--t-fast),background var(--t-fast)}
.tl-opcija:hover:not(:disabled){border-color:var(--teal);background:var(--teal-08)}
.tl-opcija.izabrano{border-color:var(--teal);background:var(--teal-14);color:var(--ink)}
.tl-opcija.tocno{border-color:var(--teal);background:var(--teal-22);color:var(--teal)}
.tl-opcija.netocno{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.tl-opcija:disabled{cursor:default}
.tl-objasnjenje{margin-top:10px;padding:10px 14px;border-left:2px solid var(--topaz);background:var(--teal-08);border-radius:6px;font-size:13px;line-height:1.55;color:var(--ink-soft)}
/* rezultat */
.tl-rezultat-box{margin-top:16px;padding:16px 18px;border-radius:12px;font-size:16px;color:var(--ink);border:1px solid var(--line)}
.tl-rezultat-box strong{color:var(--teal)}
.tl-rezultat-box.ok{border-color:var(--teal-44);background:var(--teal-08)}
.tl-rezultat-box.slabo{border-color:var(--brass-44);background:var(--brass-14)}
.tl-rezultat-box.err{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.tl-rezultat-akcije{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
/* postavke prije kviza (mod / broj / tema) */
.tl-kviz-postavke{display:flex;gap:12px;flex-wrap:wrap;width:100%;margin:4px 0 4px}
.tl-postavka{display:flex;flex-direction:column;gap:4px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.tl-postavka select{padding:8px 10px;border-radius:8px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink);font-family:"JetBrains Mono",monospace;font-size:12px;cursor:pointer;transition:border-color var(--t-fast)}
.tl-postavka select:focus{outline:none;border-color:var(--teal)}
/* tajmer (certification) */
.tl-tajmer{font-family:"JetBrains Mono",monospace;font-size:14px;letter-spacing:1px;color:var(--brass);background:var(--brass-14);border:1px solid var(--brass-44);padding:6px 12px;border-radius:8px}
/* fill-in tekstualno polje */
.tl-upis{width:100%;box-sizing:border-box;padding:11px 14px;border-radius:9px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink);font-size:15px;font-family:"JetBrains Mono",monospace;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.tl-upis:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(143,223,150,.13)}
.tl-upis.tocno{border-color:var(--teal);background:var(--teal-22);color:var(--teal)}
.tl-upis.netocno{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.tl-upis:disabled{cursor:default}
.tl-tocan-upis{margin-top:8px;padding:8px 12px;border-left:2px solid var(--teal);background:var(--teal-08);border-radius:6px;font-size:13px;color:var(--teal)}
/* izbor moda (Practice / Certification) */
.tl-mod-grid{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}
.tl-mod-kartica{flex:1;min-width:260px;display:flex;flex-direction:column;gap:12px;padding:20px;border:1px solid var(--line-strong);border-radius:14px;background:var(--bg-deep)}
.tl-mod-naslov{font-family:"Nunito Sans",sans-serif;font-size:20px;font-weight:700;color:var(--teal-glow)}
.tl-mod-opis{font-size:13px;line-height:1.5;color:var(--ink-soft)}
.tl-mod-napomena{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:2px}
/* ── SLABE TEME (Faza 2 — pomoć) ── */
.tl-slabe-teme{margin-bottom:18px;padding:18px 20px;border:1px solid var(--brass-44);border-radius:14px;background:var(--brass-14)}
.tl-slabe-naslov{font-family:"Nunito Sans",sans-serif;font-size:17px;font-weight:700;color:var(--brass-glow);margin-bottom:4px}
.tl-slabe-opis{font-size:13px;color:var(--ink-soft);margin-bottom:14px;line-height:1.5}
.tl-slabe-prazno{font-size:14px;color:var(--ink-soft);line-height:1.6}
.tl-slabe-lista{display:flex;flex-direction:column;gap:10px}
.tl-slabe-red{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg-deep);flex-wrap:wrap}
.tl-slabe-info{display:flex;flex-direction:column;gap:3px;min-width:160px;flex:1}
.tl-slabe-ime{font-size:15px;font-weight:600;color:var(--ink)}
.tl-slabe-skor{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--rose)}
.tl-slabe-akcije{display:flex;gap:8px;flex-wrap:wrap}
.tl-slabe-vjezbaj{font-family:"JetBrains Mono",monospace;font-size:11px;padding:9px 14px;border-radius:8px;cursor:pointer;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);letter-spacing:.3px;transition:background var(--t-fast),border-color var(--t-fast)}
.tl-slabe-vjezbaj:hover{background:var(--teal-22);border-color:var(--teal)}
.tl-slabe-lekcija{font-family:"JetBrains Mono",monospace;font-size:11px;padding:9px 14px;border-radius:8px;cursor:pointer;border:1px solid var(--line-strong);background:transparent;color:var(--muted);letter-spacing:.3px;transition:color var(--t-fast),border-color var(--t-fast)}
.tl-slabe-lekcija:hover{color:var(--ink);border-color:var(--topaz)}
/* ── SLIDER za broj pitanja (Practice) ── */
.tl-broj-prikaz{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--teal);font-weight:700;text-transform:none;letter-spacing:0}
.tl-broj-info{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--teal);padding:6px 0}
.tl-broj-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:4px;background:rgba(120,180,160,.18);outline:none;margin:8px 0 4px;cursor:pointer}
.tl-broj-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--teal);border:2px solid var(--bg-deep);box-shadow:0 2px 8px rgba(143,223,150,.4);cursor:pointer;transition:transform var(--t-fast)}
.tl-broj-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.tl-broj-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--teal);border:2px solid var(--bg-deep);box-shadow:0 2px 8px rgba(143,223,150,.4);cursor:pointer}
.tl-broj-slider::-moz-range-track{height:6px;border-radius:4px;background:rgba(120,180,160,.18)}
.tl-broj-skala{display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:0;text-transform:none}
/* certification: pregled (mreža brojeva) */
.tl-cert-pregled{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tl-cert-kvadrat{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-strong);background:var(--bg-deep);color:var(--ink-soft);font-family:"JetBrains Mono",monospace;font-size:12px;cursor:pointer;transition:all var(--t-fast)}
.tl-cert-kvadrat:hover{border-color:var(--teal)}
.tl-cert-kvadrat.odgovoreno{background:var(--teal-22);border-color:var(--teal-44);color:var(--teal)}
.tl-cert-kvadrat.trenutno{outline:2px solid var(--teal);outline-offset:1px}
.tl-cert-kvadrat.tocan{background:var(--teal-22);border-color:var(--teal);color:var(--teal)}
.tl-cert-kvadrat.netocan{background:var(--rose-18);border-color:var(--rose-44);color:var(--rose)}
/* certification: broj pitanja + navigacija */
.tl-cert-broj{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;color:var(--muted);margin-bottom:8px}
.tl-cert-nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;align-items:center}
.tl-cert-nav .zn-posalji{margin-left:auto}
/* certification: detalj odgovora u rezultatu */
.tl-cert-detalj{margin-top:8px}
.tl-cert-det-red{font-size:13px;padding:6px 10px;border-radius:6px;margin-top:6px;font-family:"JetBrains Mono",monospace}
.tl-cert-det-red.tocno{background:var(--teal-08);color:var(--teal)}
.tl-cert-det-red.netocno{background:var(--rose-18);color:var(--rose)}
/* tajmer: zadnja minuta upozorenje */
.tl-tajmer.isticanje{background:var(--rose-18);border-color:var(--rose-44);color:var(--rose);animation:tlPuls 1s infinite}
@keyframes tlPuls{0%,100%{opacity:1}50%{opacity:.55}}

/* ============================================
   MOBILNA PRILAGODBA (telefon)
   ============================================ */
@media(max-width:1024px){
  #app{padding:0 16px 50px}
  /* na mobitelu NE zaključavaj visinu — normalan scroll cijele stranice */
  #app.citac-aktivan[style*="block"]{height:auto;overflow:visible;padding-bottom:50px}
  #app.citac-aktivan #page-znanje,#app.citac-aktivan #page-znanje > section.block{height:auto;overflow:visible;display:block}
  #app.citac-aktivan .zn-citac-panel,#app.citac-aktivan #znanjeIzbor,#app.citac-aktivan .zn-chat-panel{flex:none;min-height:0;overflow:visible}
  nav{flex-direction:row;align-items:center;flex-wrap:wrap;gap:12px;padding:16px 2px 14px;position:static;height:auto}
  /* ── MOBITEL: cijeli #app je jedan okomiti stupac ──
     Uzrok ranijeg nereda: na desktopu je #app grid (nav | sadržaj). Na mobitelu
     to NE želimo — sve ide jedno ispod drugog. Flex column + jasan redoslijed. */
  #app[style*="block"]{display:flex !important;flex-direction:column;gap:0}
  #app[style*="block"] > nav{order:1;width:100%}
  #app[style*="block"] > .tabpage,
  #app[style*="block"] > section.tabpage{order:2;width:100%}
  /* NAV sam po sebi: okomiti niz, bez praznih okvira */
  #app[style*="block"] > nav{display:flex;flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:10px}
  nav .brand{order:1;width:100%}
  nav .spacer{display:none}          /* prazni rastezljivi razmak — makni na mobitelu */
  nav .clock{order:2;text-align:left;padding:0 8px}
  nav .logout{order:3;align-self:flex-start;width:auto}
  nav .tabs{order:4;width:100%}
  nav #znNavKursevi{order:5;width:100%}
  /* tabovi: mreža 3-u-red (umjesto uspravnog stupca), svi vidljivi */
  #app[style*="block"] nav .tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:6px 0 2px}
  #app[style*="block"] nav .tab{white-space:normal;text-align:center;padding:12px 8px;font-size:11px;line-height:1.25;border:1px solid var(--line);background:var(--teal-08);width:auto}
  #app[style*="block"] nav .tab.active{background:var(--teal-14);border-color:var(--teal-44)}
  /* kursevi u izborniku: puna širina, bez lijevog ruba */
  #app[style*="block"] nav #znNavKursevi{border-left:none;padding-left:0;margin-top:6px}
  /* čitač (My Courses): bez fiksne visine, normalno teče */
  #app .zn-citac-panel{max-height:none;overflow:visible;display:block}
  #app .znc-sadrzaj{min-height:0}
  #app .znc-prazno{min-height:160px;padding:20px 10px}
}
@media(max-width:768px){
  #app{padding:0 12px 40px}
  nav{flex-wrap:wrap;gap:10px;padding:14px 2px 12px}
  .brand{order:1;width:100%}
  .clock{order:2;font-size:11px;text-align:left;padding:0 8px}
  nav .logout{order:3;align-self:flex-start}
  .tabs{order:4;width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:6px 0 2px;overflow:visible}
  .tab{flex:none;white-space:normal;width:auto;text-align:center;padding:12px 8px;font-size:11px;line-height:1.25;border:1px solid var(--line);background:var(--teal-08)}
  .tab.active{background:var(--teal-14)}
  /* kursevi u izborniku na mobitelu: puna širina ispod tabova (ne u vodoravnom scrollu) */
  .zn-nav-kursevi{order:5;width:100%;border-left:none;padding-left:0;margin-top:6px}
  h2.big{font-size:26px;margin-bottom:16px}
  .block{margin-bottom:32px}
  .panel{padding:16px;border-radius:14px}
  .stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat{padding:14px}
  .stat .v{font-size:28px}
  .row2{grid-template-columns:1fr;gap:14px}
  .struktura-layout{grid-template-columns:1fr;gap:14px}
  .notes-layout{grid-template-columns:1fr;gap:14px}
  .acct-grid{grid-template-columns:1fr;gap:14px}
  .donutwrap{flex-direction:column;align-items:flex-start;gap:14px}
  .tree{max-height:340px}
  .note-list{max-height:300px}
  .preview{max-height:none}
  .graf-wrap{height:380px}
  .struktura-layout .panel:last-child .graf-wrap{height:380px}
  .graf-legend{font-size:10px;padding:8px 10px;left:10px;bottom:10px}
  .vault-actions{flex-direction:column;align-items:stretch}
  .vault-dl-btn{width:100%;padding:12px;text-align:center}
  .fr-gumb{width:100%;padding:14px}
  .fr-input{font-size:16px}
  .zn-unos-red{flex-direction:column;align-items:stretch}
  .zn-unos{font-size:16px}
  .zn-posalji{width:100%;padding:14px}
  .zn-tema-btn{min-width:0;width:100%}
  .zn-poruka{max-width:92%}
  .zn-poruke{max-height:60vh}
  .zn-lek-nav{flex-direction:column;align-items:stretch}
  .zn-lek-nav .zn-novi,.zn-pitaj-ai{width:100%;text-align:center;padding:12px}
  .zn-lek-nav .zn-procitano{width:100%;text-align:center;padding:12px}
  .zn-lek-naslov{font-size:20px}
  /* ── TRAINING LIBRARY na telefonu ── */
  /* mod kartice (Practice/Certification): pune širine, jedna ispod druge */
  .tl-mod-grid{flex-direction:column;gap:12px}
  .tl-mod-kartica{min-width:0;width:100%;padding:16px}
  /* postavke prije kviza (tema/razina/slider): svaka u svoj puni red */
  .tl-kviz-postavke{flex-direction:column;gap:14px}
  .tl-postavka{width:100%}
  .tl-postavka select{width:100%;padding:11px 12px;font-size:14px}
  /* predmeti i kartice kvizova: puna širina */
  .tl-predmet-btn{min-width:0;width:100%}
  .tl-kviz-kartica{flex-direction:column;align-items:stretch;gap:10px}
  .tl-kviz-akcije{width:100%}
  .tl-kviz-akcije .tl-kviz-start,.tl-kviz-akcije .tl-kviz-pogr{flex:1;text-align:center;padding:12px}
  /* slabe teme: gumbi pune širine, jedan red */
  .tl-slabe-red{flex-direction:column;align-items:stretch}
  .tl-slabe-akcije{width:100%}
  .tl-slabe-akcije .tl-slabe-vjezbaj,.tl-slabe-akcije .tl-slabe-lekcija{flex:1;text-align:center;padding:11px}
  /* odgovori na pitanja: malo veći razmak za prst */
  .tl-opcija{padding:13px 14px;font-size:15px}
  /* certification navigacija + pregled brojeva */
  .tl-cert-nav{flex-direction:column;align-items:stretch}
  .tl-cert-nav .zn-posalji{margin-left:0;width:100%;padding:14px}
  .tl-rezultat-akcije{flex-direction:column}
  .tl-rezultat-akcije > *{width:100%;text-align:center}
  /* čitač: dvostupac → jedan stupac (nav gore, sadržaj ispod) */
  .znc-split{grid-template-columns:1fr;gap:14px}
  .znc-nav{position:static;max-height:none;overflow:visible;padding-right:0}
  .znc-sadrzaj{position:static;max-height:none;overflow:visible;padding-right:0}
  /* na mobitelu panel čitača nema fiksnu visinu — normalan scroll cijele stranice */
  .zn-citac-panel{max-height:none;overflow:visible}
  .znc-sek-tijelo{padding:0 12px 14px 24px}
  /* čitač: lekcije i sekcije — veći razmak za prst, čitljiviji tekst */
  .znc-lek-btn{padding:12px 12px}
  .znc-lek-ime{font-size:14px}
  .znc-kurs-glava{padding:14px 14px}
  .znc-sek-glava{padding:14px 14px}
  .znc-sek-naslov{font-size:16px}
  .znc-sadrzaj .md p,.znc-sadrzaj .md li{font-size:15px;line-height:1.7}
  .field input{font-size:16px}
  .abtn.save{width:100%;text-align:center;padding:12px}
  .btn-row{flex-direction:column}
  .btn-row .abtn{width:100%;text-align:center}
  .user-row{flex-wrap:wrap;gap:8px}
  .user-row .who{flex-basis:100%}
  .user-row .acts{flex-basis:100%}
  .user-row .acts .abtn{flex:1}
  .modal-card{padding:22px;width:94%}
  .modal-actions{flex-direction:column-reverse;gap:8px}
  .modal-btn{width:100%;text-align:center;padding:12px}
  .card-login{padding:32px 24px 26px}
  .md{overflow-x:auto}
  .md table{font-size:12px}
}
@media(max-width:480px){
  h2.big{font-size:22px}
  .stats{grid-template-columns:1fr}
  .stat .v{font-size:32px}
  .brand .name{font-size:16px}
  .graf-wrap{height:320px}
}

/* ============================================
   C# CODING — pisanje koda + AI provjera
   ============================================ */
.cs-napredak{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);margin-bottom:14px}
.cs-napredak strong{color:var(--teal)}
/* SKLOPIVA kategorija (accordion): klik na glavu otvori/zatvori zadatke */
.cs-kat{margin-bottom:8px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-deep)}
.cs-kat-glava{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;user-select:none;transition:background var(--t-fast)}
.cs-kat-glava:hover{background:var(--teal-08)}
.cs-kat-tw{display:inline-block;width:12px;font-size:10px;color:var(--teal);flex:none}
.cs-kat-ime{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--brass);flex:1;line-height:1.4}
.cs-kat.otvorena .cs-kat-ime{color:var(--brass-glow)}
.cs-kat-brojka{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);flex:none}
/* zadaci kategorije — vidljivi SAMO kad je kategorija otvorena */
.cs-kat .cs-lista{display:none;padding:6px 12px 12px}
.cs-kat.otvorena .cs-lista{display:flex}
/* stara klasa (više se ne koristi, ostavljena za svaki slučaj) */
.cs-kat-naslov{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--brass);margin:16px 0 8px}
.cs-lista{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.cs-zad-btn{display:flex;align-items:center;gap:10px;text-align:left;width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg-deep);color:var(--ink-soft);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),padding-left var(--t-fast)}
.cs-zad-btn:hover{border-color:var(--teal);background:var(--panel-hover);padding-left:18px}
.cs-zad-btn.prosao{opacity:.7}
.cs-zad-btn.prosao:hover{opacity:1}
.cs-zad-kvacica{font-family:"JetBrains Mono",monospace;font-size:14px;width:16px;text-align:center;color:var(--muted);flex:none}
.cs-zad-btn.prosao .cs-zad-kvacica{color:var(--teal)}
.cs-zad-naslov{font-size:14px;line-height:1.35}
/* otvoreni zadatak */
.cs-zadatak-box{background:var(--bg-deep);border:1px solid var(--line);border-left:2px solid var(--topaz);border-radius:12px;padding:18px;margin-bottom:16px}
.cs-zadatak-naslov{font-family:"Nunito Sans",sans-serif;font-size:18px;font-weight:600;color:var(--teal-glow);margin-bottom:10px}
.cs-prosao-oznaka{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--teal);background:var(--teal-14);border:1px solid var(--teal-44);padding:2px 8px;border-radius:6px;margin-left:8px;vertical-align:middle}
.cs-zadatak-tekst{font-size:15px;line-height:1.6;color:var(--ink-soft)}
.cs-ocekivano{margin-top:12px;padding:10px 14px;background:var(--teal-08);border-radius:8px;font-size:13px;line-height:1.5;color:var(--ink-soft)}
.cs-ocekivano strong{color:var(--teal)}
.cs-kod-label{display:block;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.cs-kod-polje{width:100%;box-sizing:border-box;padding:14px;border-radius:10px;border:1px solid var(--line-strong);background:#0a1310;color:#c9d4ce;font-family:"JetBrains Mono",monospace;font-size:13px;line-height:1.6;resize:vertical;tab-size:4;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.cs-kod-polje:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(143,223,150,.13)}
.cs-rezultat{margin-top:16px}
.cs-rezultat:empty{display:none}
.cs-ocjena{padding:16px 18px;border-radius:12px;border:1px solid var(--line)}
.cs-ocjena.ok{border-color:var(--teal-44);background:var(--teal-08)}
.cs-ocjena.ne{border-color:var(--brass-44);background:var(--brass-14)}
.cs-ocjena.err{border-color:var(--rose-44);background:var(--rose-18);color:var(--rose)}
.cs-ocjena-naslov{font-family:"Nunito Sans",sans-serif;font-size:17px;font-weight:700;margin-bottom:8px}
.cs-ocjena.ok .cs-ocjena-naslov{color:var(--teal)}
.cs-ocjena.ne .cs-ocjena-naslov{color:var(--brass-glow)}
.cs-ocjena-tekst{font-size:14px;line-height:1.6;color:var(--ink-soft)}
.cs-objasnjenje{margin-top:12px;padding:14px 16px;background:var(--bg-deep);border:1px solid var(--line);border-left:2px solid var(--teal);border-radius:10px;font-size:14px;line-height:1.6;color:var(--ink-soft)}
.cs-objasnjenje strong{color:var(--teal)}
/* PUNI PRIMJER RJEŠENJA (nakon prolaska) + dugme Kopiraj */
.cs-primjer{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-deep)}
.cs-primjer-glava{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--teal-08)}
.cs-primjer-naslov{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--teal)}
.cs-kopiraj{font-family:"JetBrains Mono",monospace;font-size:11px;padding:7px 13px;border-radius:8px;cursor:pointer;border:1px solid var(--teal-44);background:var(--teal-14);color:var(--teal);letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast);white-space:nowrap}
.cs-kopiraj:hover{background:var(--teal-22);border-color:var(--teal)}
.cs-primjer-opis{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);padding:8px 14px 0;line-height:1.5}
.cs-primjer-kod{margin:0;padding:14px;font-family:"JetBrains Mono",monospace;font-size:13px;line-height:1.6;color:#c9d4ce;white-space:pre;overflow-x:auto;tab-size:4}
/* DUGMAD POMOĆI (Hint / Pokaži rješenje) + hint blok */
.cs-pomoc-red{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.cs-pomoc-btn{font-family:"JetBrains Mono",monospace;font-size:12px;padding:10px 16px;border-radius:9px;cursor:pointer;letter-spacing:.5px;transition:background var(--t-fast),border-color var(--t-fast)}
.cs-pomoc-btn:disabled{opacity:.6;cursor:default}
.cs-pomoc-btn.hint{border:1px solid var(--brass-44);background:var(--brass-14);color:var(--brass)}
.cs-pomoc-btn.hint:hover:not(:disabled){background:var(--brass-22);border-color:var(--brass)}
.cs-pomoc-btn.rjesenje{border:1px solid var(--line-strong);background:transparent;color:var(--muted)}
.cs-pomoc-btn.rjesenje:hover:not(:disabled){border-color:var(--topaz);color:var(--topaz)}
.cs-pomoc-box{margin-top:12px}
.cs-pomoc-box:empty{display:none}
.cs-hint{padding:14px 16px;border:1px solid var(--brass-44);border-left:2px solid var(--brass);border-radius:10px;background:var(--brass-14)}
.cs-hint-naslov{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--brass);margin-bottom:6px}
.cs-hint-tekst{font-size:14px;line-height:1.6;color:var(--ink-soft)}
@media(max-width:768px){
  .cs-kod-polje{font-size:14px}
  .cs-zad-btn{padding:14px}
}

/* ============================================
   PROJEKTI — pregled ideja/planova (4 stanja)
   ============================================ */
.proj-grupa{margin-bottom:22px}
.proj-grupa-glava{font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--brass);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.proj-grupa-broj{font-size:11px;color:var(--muted);background:var(--brass-14);border:1px solid var(--brass-44);border-radius:6px;padding:1px 8px}
.proj-lista{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.proj-prazno{color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12px;padding:4px 2px}
.proj-kartica{border:1px solid var(--line);border-radius:12px;background:var(--bg-deep);padding:16px;display:flex;flex-direction:column;gap:8px}
.proj-naslov{font-family:"Nunito Sans",sans-serif;font-size:16px;font-weight:600;color:var(--teal-glow);line-height:1.3}
.proj-sazetak{font-size:13px;line-height:1.55;color:var(--ink-soft)}
.proj-meta{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted)}
.proj-akcije{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;border-top:1px solid var(--line);padding-top:10px}
.proj-stanje-btn{font-family:"JetBrains Mono",monospace;font-size:10px;padding:5px 9px;border-radius:7px;cursor:pointer;border:1px solid var(--line-strong);background:transparent;color:var(--muted);letter-spacing:.3px;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.proj-stanje-btn:hover{border-color:var(--teal);color:var(--teal)}
.proj-stanje-btn.aktivno{background:var(--teal-14);border-color:var(--teal-44);color:var(--teal)}
@media(max-width:768px){
  .proj-lista{grid-template-columns:1fr}
}