style: refine tasks page — tighter spacing, matching tab/modal/row styles

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Yusuf Suleman
2026-03-30 21:22:55 -05:00
parent c7eaf20582
commit c7f8f4b709

View File

@@ -549,6 +549,8 @@
{/if} {/if}
<style> <style>
/* ═══ Tasks page — Zinc/Emerald design ═══ */
.page-header { .page-header {
display: flex; display: flex;
align-items: center; align-items: center;
@@ -557,41 +559,52 @@
.header-actions { .header-actions {
display: flex; display: flex;
gap: var(--sp-2); gap: 8px;
} }
/* ── Tab bar ── */
.tasks-tabs { .tasks-tabs {
overflow-x: auto; overflow-x: auto;
-webkit-overflow-scrolling: touch; -webkit-overflow-scrolling: touch;
scrollbar-width: none; scrollbar-width: none;
padding-bottom: var(--sp-2); padding-bottom: 8px;
margin-bottom: var(--sp-3); margin-bottom: 12px;
gap: var(--sp-2); gap: 6px;
} }
.tasks-tabs::-webkit-scrollbar { display: none; } .tasks-tabs::-webkit-scrollbar { display: none; }
.tasks-tabs > :global(.tab) { .tasks-tabs > :global(.tab) {
white-space: nowrap; white-space: nowrap;
flex-shrink: 0; flex-shrink: 0;
padding: var(--sp-1.5) var(--sp-3); padding: 4px 12px;
font-size: var(--text-sm); font-size: 13px;
font-weight: 500;
color: var(--text-4);
border: 1px solid var(--border); border: 1px solid var(--border);
border-radius: 6px;
transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
}
.tasks-tabs > :global(.tab:hover) {
color: var(--text-2);
background: rgba(0,0,0,0.03);
} }
.tasks-tabs > :global(.tab.active) { .tasks-tabs > :global(.tab.active) {
background: var(--accent); background: var(--accent);
color: white; color: white;
border-color: var(--accent); border-color: var(--accent);
font-weight: 600;
} }
/* ── Add form ── */
.add-form { .add-form {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: var(--sp-3); gap: 12px;
margin-bottom: var(--section-gap); margin-bottom: 24px;
} }
.add-row { .add-row {
display: flex; display: flex;
gap: var(--sp-2); gap: 8px;
flex-wrap: wrap; flex-wrap: wrap;
align-items: center; align-items: center;
} }
@@ -602,22 +615,23 @@
.add-priority { width: 130px; } .add-priority { width: 130px; }
.add-repeat { width: 150px; } .add-repeat { width: 150px; }
.add-toggle { .add-toggle {
font-size: var(--text-sm); font-size: 13px;
color: var(--text-2); color: var(--text-3);
display: flex; display: flex;
align-items: center; align-items: center;
gap: var(--sp-1); gap: 4px;
cursor: pointer; cursor: pointer;
} }
/* ── Task rows ── */
.task-item { .task-item {
display: flex; display: flex;
align-items: flex-start; align-items: flex-start;
gap: var(--sp-3); gap: 12px;
transition: opacity 0.3s; transition: opacity 0.3s;
} }
.task-item.fading { opacity: 0.2; } .task-item.fading { opacity: 0.15; }
.task-check { .task-check {
flex-shrink: 0; flex-shrink: 0;
@@ -626,7 +640,10 @@
background: none; background: none;
border: none; border: none;
cursor: pointer; cursor: pointer;
opacity: 0.5;
transition: opacity 0.15s;
} }
.task-item:hover .task-check { opacity: 1; }
.task-check:hover svg rect { .task-check:hover svg rect {
stroke: var(--accent); stroke: var(--accent);
@@ -640,26 +657,28 @@
} }
.task-name { .task-name {
font-size: var(--text-base); font-size: 14px;
font-weight: 500;
color: var(--text-1); color: var(--text-1);
line-height: var(--leading-snug); line-height: 1.35;
} }
.task-name.overdue-text { color: var(--error); } .task-name.overdue-text { color: var(--error); }
.task-name.completed-name { .task-name.completed-name {
text-decoration: line-through; text-decoration: line-through;
color: var(--text-3); color: var(--text-4);
font-weight: 400;
} }
.completed-item { opacity: 0.7; } .completed-item { opacity: 0.6; }
.task-sub { .task-sub {
font-size: var(--text-sm); font-size: 12px;
color: var(--text-3); color: var(--text-4);
margin-top: 2px; margin-top: 2px;
display: flex; display: flex;
align-items: center; align-items: center;
gap: var(--sp-2); gap: 6px;
flex-wrap: wrap; flex-wrap: wrap;
} }
@@ -668,7 +687,7 @@
opacity: 0; opacity: 0;
transition: opacity 0.15s; transition: opacity 0.15s;
color: var(--text-4); color: var(--text-4);
font-size: var(--text-lg); font-size: 16px;
} }
.task-item:hover .task-delete { opacity: 1; } .task-item:hover .task-delete { opacity: 1; }
@@ -676,12 +695,13 @@
.overdue-label { color: var(--error) !important; } .overdue-label { color: var(--error) !important; }
.empty-state { .empty-state {
padding: var(--sp-8); padding: 48px 16px;
text-align: center; text-align: center;
color: var(--text-3); color: var(--text-4);
font-size: var(--text-base); font-size: 13px;
} }
/* ── Modal ── */
.modal-overlay { .modal-overlay {
position: fixed; position: fixed;
inset: 0; inset: 0;
@@ -694,7 +714,7 @@
.modal { .modal {
background: var(--card); background: var(--card);
border-radius: var(--radius); border-radius: 16px;
box-shadow: var(--shadow-xl); box-shadow: var(--shadow-xl);
width: 90%; width: 90%;
max-width: 420px; max-width: 420px;
@@ -705,26 +725,27 @@
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
padding: var(--card-pad) var(--card-pad) 0; padding: 22px 24px 0;
} }
.modal-title { .modal-title {
font-size: var(--text-lg); font-size: 17px;
font-weight: 600; font-weight: 700;
color: var(--text-1); color: var(--text-1);
letter-spacing: -0.02em;
} }
.modal-body { .modal-body {
padding: var(--sp-4) var(--card-pad); padding: 16px 24px;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: var(--sp-3); gap: 12px;
} }
.modal-actions { .modal-actions {
display: flex; display: flex;
gap: var(--sp-2); gap: 8px;
justify-content: flex-end; justify-content: flex-end;
padding: 0 var(--card-pad) var(--card-pad); padding: 0 24px 22px;
} }
</style> </style>