diff --git a/package.json b/package.json
index 692f1c48..4ac6c9dc 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "homepage",
- "version": "1.13.1",
+ "version": "1.13.2",
"private": true,
"type": "module",
"scripts": {
diff --git a/src/routes/fitness/[stats=fitnessStats]/+page.svelte b/src/routes/fitness/[stats=fitnessStats]/+page.svelte
index 5ed5e122..9e94d4ff 100644
--- a/src/routes/fitness/[stats=fitnessStats]/+page.svelte
+++ b/src/routes/fitness/[stats=fitnessStats]/+page.svelte
@@ -265,8 +265,8 @@
/>
{/if}
- {#if ns}
-
+
+ {#if ns}
{#if ns.avgProteinPerKg != null}
@@ -391,15 +391,25 @@
{macro.label}
{/each}
+
+
+
+ {lang === 'en' ? 'Actual' : 'Ist'}
+
+
+
+ {lang === 'en' ? 'Target' : 'Ziel'}
+
+
{/if}
-
- {/if}
+ {/if}
-
-
{t('muscle_balance', lang)}
-
+
+
{t('muscle_balance', lang)}
+
+
@@ -695,11 +705,38 @@
}
/* Nutrition masonry grid */
- .nutrition-grid {
+ .muscle-nutrition-layout {
display: grid;
- grid-template-columns: repeat(3, 1fr);
+ grid-template-columns: 1fr 1fr 1fr;
gap: 0.6rem;
}
+ .muscle-nutrition-layout .muscle-heatmap-block {
+ grid-column: 1 / -1;
+ }
+ @media (min-width: 1024px) {
+ .muscle-nutrition-layout {
+ grid-template-columns: 1fr 1fr 1fr 1fr;
+ grid-template-rows: auto 1fr;
+ }
+ .muscle-nutrition-layout .macro-card {
+ grid-column: 4;
+ grid-row: 1 / 3;
+ flex-direction: column !important;
+ align-items: center !important;
+ }
+ .muscle-nutrition-layout .macro-card .macro-rings {
+ flex-direction: column;
+ align-items: center;
+ gap: 0.5rem;
+ }
+ .muscle-nutrition-layout .macro-card .macro-header {
+ text-align: center;
+ margin-bottom: 1.25rem;
+ }
+ .muscle-nutrition-layout .muscle-heatmap-block {
+ grid-column: 1 / 4;
+ }
+ }
.protein-card::before { background: var(--nord14); }
.balance-card::before { background: var(--color-text-secondary); }
.balance-card.surplus::before { background: var(--nord14); }
@@ -726,10 +763,10 @@
color: var(--nord13);
background: color-mix(in srgb, var(--nord13) 15%, transparent);
}
- .nutrition-grid .card-icon {
+ .muscle-nutrition-layout .card-icon {
flex-shrink: 0;
}
- .nutrition-grid .card-hint {
+ .muscle-nutrition-layout .card-hint {
display: block;
width: 100%;
text-align: center;
@@ -783,7 +820,7 @@
opacity: 0.5;
}
- /* Macro split card — spans full row, horizontal layout */
+ /* Macro split card — spans full row on mobile, sidebar on desktop */
.macro-card {
grid-column: 1 / -1;
padding: 1rem 1.25rem;
@@ -791,6 +828,13 @@
align-items: center !important;
gap: 1.25rem !important;
}
+ @media (min-width: 1024px) {
+ .macro-card {
+ grid-column: auto;
+ padding: 0.75rem;
+ gap: 0.75rem !important;
+ }
+ }
.macro-header {
font-size: 1.15rem;
font-weight: 700;
@@ -855,9 +899,27 @@
font-size: 7px;
font-weight: 700;
}
+ .macro-legend {
+ display: none;
+ }
+ @media (min-width: 1024px) {
+ .macro-legend {
+ display: flex;
+ gap: 1rem;
+ justify-content: center;
+ margin-top: 0.75rem;
+ font-size: 0.7rem;
+ color: var(--color-text-secondary);
+ }
+ .macro-legend-item {
+ display: flex;
+ align-items: center;
+ gap: 0.3rem;
+ }
+ }
@media (max-width: 600px) {
- .nutrition-grid {
+ .muscle-nutrition-layout {
grid-template-columns: repeat(3, 1fr);
}
.macro-card {
@@ -868,9 +930,12 @@
}
}
@media (max-width: 400px) {
- .nutrition-grid {
+ .muscle-nutrition-layout {
grid-template-columns: 1fr;
}
+ .muscle-nutrition-layout .muscle-heatmap-block {
+ grid-column: 1;
+ }
.macro-card {
grid-column: 1;
flex-direction: column !important;