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:
@@ -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>
|
||||||
|
|||||||
Reference in New Issue
Block a user