Optimizacije — SQLite WAL, template keš, gzip kompresija, build skript

This commit is contained in:
2026-06-03 21:18:12 +02:00
parent 2401f6d5ec
commit 974d76360a
46 changed files with 1470 additions and 579 deletions
+29 -18
View File
@@ -21,7 +21,7 @@ body {
/* sidebar */
.sidebar {
width: 220px;
background: var(--sb-pozadina);
background: var(--sidebar-pozadina);
display: flex;
flex-direction: column;
transition: width 0.28s cubic-bezier(.4,0,.2,1);
@@ -40,7 +40,7 @@ body {
height: 72px;
padding: 0 12px;
gap: 10px;
border-bottom: 0.5px solid rgba(255,255,255,0.07);
border-bottom: 0.5px solid var(--ivica);
flex-shrink: 0;
}
@@ -49,7 +49,7 @@ body {
background: none;
border: none;
cursor: pointer;
color: var(--sb-tekst-aktivan);
color: var(--tekst-jak);
padding: 6px;
border-radius: 6px;
display: flex;
@@ -60,7 +60,7 @@ body {
}
.hamburger:hover {
background: var(--sb-hover);
background: var(--pozadina-hover);
}
/* logo zona */
@@ -81,14 +81,14 @@ body {
}
.logo-naziv {
color: var(--sb-tekst-aktivan);
color: var(--tekst-jak);
font-weight: 500;
font-size: 15px;
white-space: nowrap;
}
.logo-podnazlov {
color: var(--sb-tekst);
color: var(--tekst-sporedni);
font-size: 11px;
white-space: nowrap;
}
@@ -110,7 +110,7 @@ body {
font-size: 10px;
text-transform: uppercase;
letter-spacing: 0.08em;
color: var(--sb-tekst);
color: var(--tekst-sporedni);
padding: 12px 16px 4px;
white-space: nowrap;
opacity: 1;
@@ -127,7 +127,7 @@ body {
gap: 12px;
padding: 9px 16px;
cursor: pointer;
color: var(--sb-tekst);
color: var(--tekst-sporedni);
white-space: nowrap;
position: relative;
text-decoration: none;
@@ -135,13 +135,13 @@ body {
}
.nav-stavka:hover {
background: var(--sb-hover);
color: var(--sb-tekst-aktivan);
background: var(--pozadina-hover);
color: var(--tekst-jak);
}
.nav-stavka.aktivan {
background: var(--sb-aktivan);
color: var(--sb-tekst-aktivan);
color: var(--tekst-jak);
}
.nav-stavka.aktivan::before {
@@ -174,7 +174,7 @@ body {
.nav-separator {
height: 0.5px;
background: rgba(255,255,255,0.07);
background: var(--ivica);
margin: 8px 12px;
}
@@ -207,7 +207,7 @@ body {
/* dno sidebara */
.sidebar-dno {
padding: 8px 0;
border-top: 0.5px solid rgba(255,255,255,0.07);
border-top: 0.5px solid var(--ivica);
}
/* glavni sadržaj */
@@ -221,7 +221,7 @@ body {
/* topbar */
.topbar {
height: 56px;
background: var(--topbar);
background: var(--kartica);
border-bottom: 0.5px solid var(--ivica);
display: flex;
align-items: center;
@@ -250,12 +250,13 @@ body {
border: 0.5px solid var(--ivica);
border-radius: 12px;
padding: 16px;
box-shadow: var(--senka);
transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s;
}
.kartica:hover {
transform: translateY(-4px);
box-shadow: 0 8px 24px rgba(0,0,0,0.08);
box-shadow: var(--senka);
}
/* input polja — konzistentna za sve teme */
@@ -286,13 +287,23 @@ select:focus {
/* poruka o uspehu — konzistentna za sve teme */
.poruka-uspeh {
background: var(--kartica);
border: 0.5px solid var(--sb-akcent);
background: var(--poruka-uspeh-bg);
border: 0.5px solid var(--poruka-uspeh-boja);
border-radius: 10px;
padding: 12px 16px;
margin-bottom: 20px;
font-size: 14px;
color: var(--sb-akcent);
color: var(--poruka-uspeh-boja);
}
.poruka-greska {
background: rgba(207, 87, 87, 0.12);
border: 0.5px solid var(--greska);
border-radius: 10px;
padding: 12px 16px;
margin-bottom: 20px;
font-size: 14px;
color: var(--greska);
}
/* overlay za mobilni — tamni sloj iza sidebara */
-15
View File
@@ -1,15 +0,0 @@
:root {
--sb-pozadina: #4a3580;
--sb-hover: #5a4295;
--sb-aktivan: #6d52b0;
--sb-tekst: #c4b5e8;
--sb-tekst-aktivan: #ffffff;
--sb-akcent: #a855f7;
--pozadina: #f5f0ff;
--kartica: #ffffff;
--tekst-glavni: #1a1d2e;
--tekst-sporedni: #6b7280;
--ivica: #e5e7eb;
--topbar: #ffffff;
}
+19 -13
View File
@@ -1,15 +1,21 @@
:root {
--sb-pozadina: #f8fafc;
--sb-hover: #f1f5f9;
--sb-aktivan: #e8f0fe;
--sb-tekst: #64748b;
--sb-tekst-aktivan: #1a1d2e;
--sb-akcent: #4f7ef8;
--pozadina: #f0f2f8;
--kartica: #ffffff;
--tekst-glavni: #1a1d2e;
--tekst-sporedni: #6b7280;
--ivica: #e5e7eb;
--topbar: #ffffff;
--pozadina: #f6f8fa;
--kartica: #ffffff;
--kartica-2: #f0f2f5;
--pozadina-hover: #ebeef1;
--tekst-glavni: #24292f;
--tekst-sporedni: #57606a;
--tekst-jak: #1f2328;
--ivica: #d0d7de;
--sb-akcent: #1f6feb;
--sb-akcent-hover: #388bfd;
--sb-aktivan: #ebeef1;
--uspeh: #1a7f37;
--upozorenje: #9a6700;
--greska: #cf222e;
--info: #0969da;
--senka: 0 4px 12px rgba(0, 0, 0, 0.08);
--sidebar-pozadina: #ffffff;
--poruka-uspeh-bg: rgba(26, 127, 55, 0.1);
--poruka-uspeh-boja: #1a7f37;
}
+19 -13
View File
@@ -1,15 +1,21 @@
:root {
--sb-pozadina: #1a1d2e;
--sb-hover: #2a2d40;
--sb-aktivan: #3d4f7c;
--sb-tekst: #a0a8c0;
--sb-tekst-aktivan: #ffffff;
--sb-akcent: #4f7ef8;
--pozadina: #0f1117;
--kartica: #1a1d2e;
--tekst-glavni: #e2e8f0;
--tekst-sporedni: #8892a4;
--ivica: #2a2d40;
--topbar: #13151f;
--pozadina: #1f2228;
--kartica: #22262d;
--kartica-2: #2c313a;
--pozadina-hover: #2a2f37;
--tekst-glavni: #dbdee4;
--tekst-sporedni: #a0a8b5;
--tekst-jak: #f0f3f6;
--ivica: #353a44;
--sb-akcent: #4684d6;
--sb-akcent-hover: #5a96e6;
--sb-aktivan: #2a2f37;
--uspeh: #5db876;
--upozorenje: #e1b04a;
--greska: #cf5757;
--info: #5cb1d6;
--senka: 0 4px 12px rgba(0, 0, 0, 0.4);
--sidebar-pozadina: #1a1c20;
--poruka-uspeh-bg: rgba(93, 184, 118, 0.15);
--poruka-uspeh-boja: #5db876;
}
-15
View File
@@ -1,15 +0,0 @@
:root {
--sb-pozadina: #1a4d2e;
--sb-hover: #245c38;
--sb-aktivan: #2d7a47;
--sb-tekst: #a8d5b5;
--sb-tekst-aktivan: #ffffff;
--sb-akcent: #22c55e;
--pozadina: #f0faf4;
--kartica: #ffffff;
--tekst-glavni: #1a1d2e;
--tekst-sporedni: #6b7280;
--ivica: #e5e7eb;
--topbar: #ffffff;
}