Optimizacije — SQLite WAL, template keš, gzip kompresija, build skript
This commit is contained in:
+29
-18
@@ -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 */
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
<svg width="300" height="300" viewBox="0 0 300 300" xmlns="http://www.w3.org/2000/svg">
|
||||
<defs>
|
||||
<!-- Gradijent pozadine -->
|
||||
<linearGradient id="bgGrad" x1="0%" y1="0%" x2="100%" y2="100%">
|
||||
<stop offset="0%" stop-color="#0f2027"></stop>
|
||||
<stop offset="50%" stop-color="#203a43"></stop>
|
||||
<stop offset="100%" stop-color="#2c5364"></stop>
|
||||
</linearGradient>
|
||||
|
||||
<!-- Senka -->
|
||||
<filter id="textShadow" x="-50%" y="-50%" width="200%" height="200%">
|
||||
<feDropShadow dx="0" dy="6" stdDeviation="6" flood-color="#000" flood-opacity="0.5"></feDropShadow>
|
||||
</filter>
|
||||
</defs>
|
||||
|
||||
<!-- Pozadina -->
|
||||
<rect width="300" height="300" rx="30" ry="30" fill="url(#bgGrad)"></rect>
|
||||
|
||||
<!-- Prsten -->
|
||||
<ellipse cx="150" cy="160" rx="130" ry="36" fill="none" stroke="white" stroke-width="3" opacity="0.15" transform="rotate(-15 150 160)"></ellipse>
|
||||
|
||||
<!-- Unutrašnji prsten -->
|
||||
<ellipse cx="150" cy="160" rx="110" ry="30" fill="none" stroke="white" stroke-width="1.5" opacity="0.1" transform="rotate(-15 150 160)"></ellipse>
|
||||
|
||||
<!-- VM tekst -->
|
||||
<text x="50%" y="162" text-anchor="middle" dominant-baseline="middle" font-family="'Orbitron', sans-serif" font-size="100" fill="#ffffff" filter="url(#textShadow)">
|
||||
VM
|
||||
</text>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 1.2 KiB |
Reference in New Issue
Block a user