diff --git a/webui/html/style.css b/webui/html/style.css
index c8e26e3..aaf4b59 100644
--- a/webui/html/style.css
+++ b/webui/html/style.css
@@ -1,15 +1,16 @@
:root {
--bottom-reserve: 0px;
--radius-sm: 4px;
- --radius-md: 8px;
- --shadow-elevated: 0 10px 28px rgba(12, 20, 32, 0.18);
+ --radius-md: 9px;
+ --shadow-elevated: 0 14px 34px rgba(12, 20, 32, 0.18);
+ --shadow-panel: 0 2px 8px rgba(8, 14, 22, 0.06);
}
:root[data-theme="dark"] {
--color-page-bg: #161c25;
--color-surface: #1d2531;
--color-surface-elevated: #222c39;
- --color-border: #324052;
+ --color-border: #314052;
--color-border-strong: #55739f;
--color-text-primary: #e7edf6;
--color-text-muted: #9aa9bd;
@@ -23,6 +24,8 @@
--color-button-bg: #283444;
--color-button-hover: #314258;
--color-button-secondary-bg: #202935;
+ --color-list-header-bg: rgba(255, 255, 255, 0.02);
+ --color-list-row-hover: rgba(106, 165, 255, 0.08);
--color-danger: #ff8e8e;
--color-danger-bg: #462328;
--color-overlay-bg: rgba(8, 12, 18, 0.62);
@@ -46,6 +49,8 @@
--color-button-bg: #f6f9fd;
--color-button-hover: #edf3fb;
--color-button-secondary-bg: #f3f6fb;
+ --color-list-header-bg: #f8fbff;
+ --color-list-row-hover: #f5f9ff;
--color-danger: #b42323;
--color-danger-bg: #fdecec;
--color-overlay-bg: rgba(18, 28, 40, 0.30);
@@ -71,10 +76,12 @@ html, body {
body {
margin: 0;
- font-family: "Segoe UI", Tahoma, sans-serif;
+ font-family: Inter, "Segoe UI", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
background: var(--color-page-bg);
color: var(--color-text-primary);
overflow: hidden;
+ -webkit-font-smoothing: antialiased;
+ text-rendering: optimizeLegibility;
}
#app-shell {
@@ -84,18 +91,19 @@ body {
}
#title-zone {
- padding: 7px 10px;
+ padding: 8px 12px;
border-bottom: 1px solid var(--color-border);
background: var(--color-surface-elevated);
display: flex;
align-items: center;
justify-content: space-between;
+ box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03);
}
#title-zone-actions {
display: flex;
align-items: center;
- gap: 8px;
+ gap: 10px;
min-width: 0;
}
@@ -104,15 +112,17 @@ h1, h2, h3 {
}
h1 {
- font-size: 16px;
+ font-size: 15px;
+ font-weight: 700;
+ letter-spacing: -0.01em;
line-height: 1.2;
}
.workspace {
display: grid;
grid-template-columns: 1fr 1fr;
- gap: 6px;
- padding: 6px 10px;
+ gap: 8px;
+ padding: 8px 12px;
min-height: 0;
}
@@ -121,6 +131,7 @@ h1 {
border: 1px solid var(--color-border);
border-radius: var(--radius-md);
padding: 8px;
+ box-shadow: var(--shadow-panel);
}
.pane {
@@ -132,13 +143,13 @@ h1 {
.pane.active-pane {
border-color: var(--color-active-pane-border);
- box-shadow: 0 0 0 1px var(--color-active-pane-border) inset;
+ box-shadow: 0 0 0 1px var(--color-active-pane-border) inset, var(--shadow-panel);
background: var(--color-surface);
}
.pane-header {
flex: 0 0 auto;
- margin-bottom: 4px;
+ margin-bottom: 5px;
}
.pane-content {
@@ -146,7 +157,7 @@ h1 {
min-height: 0;
overflow-y: auto;
border-top: 1px solid var(--color-border);
- padding-top: 4px;
+ padding-top: 5px;
}
.toolbar {
@@ -167,9 +178,11 @@ h1 {
.pane-title {
min-width: 42px;
- font-size: 13px;
+ font-size: 12px;
+ font-weight: 700;
text-transform: uppercase;
- letter-spacing: 0.02em;
+ letter-spacing: 0.08em;
+ color: var(--color-text-muted);
}
.checkbox {
@@ -197,23 +210,24 @@ button {
background: var(--color-button-bg);
color: var(--color-text-primary);
cursor: pointer;
- transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
+ transition: background 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
}
button:hover {
background: var(--color-button-hover);
border-color: var(--color-accent);
+ box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset;
}
button:disabled {
- opacity: 0.5;
+ opacity: 0.56;
cursor: not-allowed;
}
#theme-toggle {
- width: 28px;
- min-width: 28px;
- height: 28px;
+ width: 30px;
+ min-width: 30px;
+ height: 30px;
padding: 0;
display: inline-flex;
align-items: center;
@@ -243,7 +257,7 @@ button:disabled {
display: flex;
flex-wrap: wrap;
gap: 4px;
- margin-bottom: 3px;
+ margin-bottom: 4px;
color: var(--color-text-muted);
font-size: 12px;
}
@@ -270,13 +284,15 @@ button:disabled {
display: grid;
grid-template-columns: 14px minmax(0, 1fr) 88px 138px;
gap: 6px;
- padding: 2px 0 4px 0;
+ padding: 4px 6px 5px 6px;
border-bottom: 1px solid var(--color-border);
- margin-bottom: 2px;
+ margin-bottom: 3px;
+ background: var(--color-list-header-bg);
+ border-radius: var(--radius-sm);
color: var(--color-text-muted);
font-size: 11px;
text-transform: uppercase;
- letter-spacing: 0.03em;
+ letter-spacing: 0.05em;
}
.col-size,
@@ -286,17 +302,22 @@ button:disabled {
.list li {
border-top: 1px solid var(--color-border);
- padding: 5px 0 4px 0;
+ padding: 6px 6px 5px 6px;
display: grid;
grid-template-columns: 14px minmax(0, 1fr) 88px 138px;
gap: 6px;
align-items: center;
+ border-radius: var(--radius-sm);
}
.list li.selectable {
cursor: pointer;
}
+.list li.selectable:hover {
+ background: var(--color-list-row-hover);
+}
+
.list li.is-selected {
background: var(--color-selection-bg);
}
@@ -380,12 +401,14 @@ button:disabled {
font-size: 12px;
min-width: 0;
text-align: right;
+ font-weight: 500;
+ letter-spacing: -0.01em;
}
#footer-bar {
border-top: 1px solid var(--color-border);
background: var(--color-surface-elevated);
- padding: 4px 10px 3px 10px;
+ padding: 5px 12px 4px 12px;
display: flex;
flex-direction: column;
align-items: center;
@@ -407,7 +430,7 @@ button:disabled {
#function-bar button {
min-width: 72px;
- padding: 3px 8px;
+ padding: 4px 9px;
display: inline-flex;
align-items: baseline;
gap: 6px;
@@ -441,7 +464,7 @@ button:disabled {
background: var(--color-surface-elevated);
border: 1px solid var(--color-border);
border-radius: var(--radius-md);
- padding: 10px;
+ padding: 11px;
box-shadow: var(--shadow-elevated);
}
@@ -488,7 +511,7 @@ button:disabled {
.viewer-content,
.editor-content {
margin: 6px 0 0 0;
- padding: 10px;
+ padding: 11px;
overflow: auto;
border: 1px solid var(--color-border);
border-radius: var(--radius-sm);