fix(studio): Toolbox UI — читаемый текст, крупнее шрифты, иконка+название в строку

Плитки категорий: убрал зависимость от CSS-переменных --text/--text-dim
(не заданы в модалке → текст был тёмный на тёмном). Явные светлые цвета.
Иконка теперь слева в одну линию с названием (grid 2 колонки), название 18px,
описание 13px. Верхние вкладки 15px. Советы/«скоро» крупнее. Trending-карточки
читаемее.
This commit is contained in:
min 2026-06-05 01:38:34 +03:00
parent 5e1a0edf9b
commit b774f92d40

View File

@ -448,133 +448,155 @@
color: var(--text-dim); color: var(--text-dim);
} }
/* ====================== Roblox-style Toolbox (задача 17) ====================== */ /* ====================== Roblox-style Toolbox (задача 17) ======================
Явные светлые цвета (не --text-переменные они в этой модалке не заданы и
давали тёмный текст на тёмном фоне). Крупнее шрифты. */
.topTabs { .topTabs {
display: flex; display: flex;
gap: 2px; gap: 4px;
padding: 0 14px; padding: 0 16px;
border-bottom: 1px solid var(--border, rgba(255,255,255,0.08)); border-bottom: 1px solid rgba(255,255,255,0.10);
flex: 0 0 auto; flex: 0 0 auto;
} }
.topTab { .topTab {
flex: 1; flex: 1;
display: flex; display: flex;
flex-direction: column; flex-direction: row;
align-items: center; align-items: center;
gap: 3px; justify-content: center;
padding: 10px 4px 8px; gap: 8px;
padding: 14px 4px 12px;
background: none; background: none;
border: none; border: none;
border-bottom: 2px solid transparent; border-bottom: 2px solid transparent;
color: var(--text-dim, #9aa3b2); color: #aab2c0;
font-size: 12px; font-size: 15px;
font-weight: 600;
cursor: pointer; cursor: pointer;
transition: color .12s, border-color .12s; transition: color .12s, border-color .12s;
} }
.topTab:hover { color: var(--text, #e8ecf2); } .topTab:hover { color: #ffffff; }
.topTabActive { .topTabActive {
color: var(--accent, #4d6bff); color: #6f8bff;
border-bottom-color: var(--accent, #4d6bff); border-bottom-color: #6f8bff;
} }
.breadcrumb { .breadcrumb {
display: flex; display: flex;
align-items: center; align-items: center;
gap: 10px; gap: 12px;
padding: 8px 16px 4px; padding: 12px 18px 6px;
flex: 0 0 auto; flex: 0 0 auto;
} }
.backBtn { .backBtn {
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
gap: 4px; gap: 6px;
background: rgba(255,255,255,0.06); background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.14);
color: var(--text, #e8ecf2); color: #e8ecf2;
padding: 5px 10px; padding: 7px 14px;
border-radius: 8px; border-radius: 9px;
font-size: 13px; font-size: 14px;
font-weight: 600;
cursor: pointer; cursor: pointer;
} }
.backBtn:hover { background: rgba(255,255,255,0.12); } .backBtn:hover { background: rgba(255,255,255,0.15); }
.crumbCurrent { font-weight: 700; color: var(--text, #e8ecf2); } .crumbCurrent { font-weight: 700; font-size: 15px; color: #ffffff; }
.storeHome { overflow-y: auto; padding: 12px 16px 18px; flex: 1; } .storeHome { overflow-y: auto; padding: 16px 20px 22px; flex: 1; }
.sectionLabel { .sectionLabel {
display: flex; align-items: center; gap: 6px; display: flex; align-items: center; gap: 8px;
font-weight: 700; font-size: 14px; color: var(--text, #e8ecf2); font-weight: 700; font-size: 17px; color: #ffffff;
margin-bottom: 10px; margin-bottom: 14px;
} }
.sectionLabel svg { color: #6f8bff; }
.catGrid { .catGrid {
display: grid; display: grid;
grid-template-columns: repeat(2, 1fr); grid-template-columns: repeat(2, 1fr);
gap: 12px; gap: 14px;
} }
.catTile { .catTile {
display: flex; flex-direction: column; align-items: flex-start; gap: 4px; display: grid;
padding: 16px; grid-template-columns: auto 1fr;
background: rgba(255,255,255,0.05); grid-template-rows: auto auto;
border: 1px solid rgba(255,255,255,0.09); column-gap: 14px;
border-radius: 12px; row-gap: 4px;
align-items: center;
padding: 18px 20px;
background: rgba(255,255,255,0.06);
border: 1px solid rgba(255,255,255,0.10);
border-radius: 14px;
cursor: pointer; cursor: pointer;
text-align: left; text-align: left;
transition: transform .1s, background .12s, border-color .12s; transition: transform .1s, background .12s, border-color .12s;
} }
.catTile:hover { .catTile:hover {
background: rgba(77,107,255,0.12); background: rgba(111,139,255,0.16);
border-color: var(--accent, #4d6bff); border-color: #6f8bff;
transform: translateY(-2px); transform: translateY(-2px);
} }
.catTileIcon { color: var(--accent, #4d6bff); margin-bottom: 4px; } /* Иконка — слева, занимает обе строки (в одну линию с названием). */
.catTileLabel { font-weight: 700; font-size: 15px; color: var(--text, #e8ecf2); } .catTileIcon {
.catTileDesc { font-size: 11px; opacity: 0.7; line-height: 1.3; } grid-row: 1 / 3;
display: flex; align-items: center; justify-content: center;
width: 52px; height: 52px;
background: rgba(111,139,255,0.16);
border-radius: 12px;
color: #8aa0ff;
}
.catTileLabel { font-weight: 800; font-size: 18px; color: #ffffff; align-self: end; }
.catTileDesc { font-size: 13px; color: #aab2c0; line-height: 1.35; align-self: start; }
.trendRow { .trendRow {
display: grid; display: grid;
grid-template-columns: repeat(4, 1fr); grid-template-columns: repeat(4, 1fr);
gap: 12px; gap: 14px;
} }
.trendCard { .trendCard {
position: relative; position: relative;
display: flex; flex-direction: column; align-items: center; gap: 8px; display: flex; flex-direction: column; align-items: center; gap: 10px;
padding: 14px 8px; padding: 14px 10px 16px;
background: rgba(255,255,255,0.05); background: rgba(255,255,255,0.06);
border: 1px solid rgba(255,255,255,0.09); border: 1px solid rgba(255,255,255,0.10);
border-radius: 12px; border-radius: 14px;
cursor: pointer; cursor: pointer;
transition: transform .1s, border-color .12s; transition: transform .1s, border-color .12s;
} }
.trendCard:hover { transform: translateY(-2px); border-color: var(--accent, #4d6bff); } .trendCard:hover { transform: translateY(-2px); border-color: #6f8bff; }
.trendIcon { .trendIcon {
width: 100%; height: 70px; width: 100%; height: 78px;
display: flex; align-items: center; justify-content: center; display: flex; align-items: center; justify-content: center;
background: linear-gradient(135deg, rgba(77,107,255,0.22), rgba(54,213,122,0.16)); background: linear-gradient(135deg, rgba(111,139,255,0.28), rgba(54,213,122,0.18));
border-radius: 8px; border-radius: 10px;
color: var(--text, #e8ecf2); color: #ffffff;
} }
.trendName { font-size: 12px; font-weight: 600; text-align: center; color: var(--text, #e8ecf2); } .trendName { font-size: 14px; font-weight: 700; text-align: center; color: #ffffff; }
.freeBadge { .freeBadge {
position: absolute; top: 8px; right: 8px; position: absolute; top: 10px; right: 10px;
font-size: 9px; font-weight: 800; letter-spacing: 0.5px; font-size: 10px; font-weight: 800; letter-spacing: 0.5px;
color: #36d57a; color: #3ce087;
background: rgba(54,213,122,0.14); background: rgba(54,213,122,0.18);
padding: 2px 6px; border-radius: 6px; padding: 3px 7px; border-radius: 6px;
} }
.soon { .soon {
flex: 1; flex: 1;
display: flex; flex-direction: column; align-items: center; justify-content: center; display: flex; flex-direction: column; align-items: center; justify-content: center;
gap: 10px; padding: 40px; gap: 12px; padding: 50px;
color: var(--text-dim, #9aa3b2); text-align: center; color: #aab2c0; text-align: center;
} }
.soonTitle { font-size: 18px; font-weight: 700; color: var(--text, #e8ecf2); } .soon svg { color: #6f8bff; }
.soonText { font-size: 13px; max-width: 360px; opacity: 0.75; } .soonTitle { font-size: 22px; font-weight: 800; color: #ffffff; }
.soonText { font-size: 15px; max-width: 400px; color: #aab2c0; line-height: 1.5; }
.tips { .tips {
overflow-y: auto; padding: 16px 22px; flex: 1; overflow-y: auto; padding: 22px 28px; flex: 1;
color: var(--text, #e8ecf2); line-height: 1.55; color: #e8ecf2; line-height: 1.6;
} }
.tips h3 { margin: 4px 0 12px; font-size: 17px; } .tips h3 { margin: 4px 0 16px; font-size: 21px; color: #ffffff; }
.tips ul { margin: 0 0 14px; padding-left: 18px; } .tips ul { margin: 0 0 18px; padding-left: 22px; }
.tips li { margin-bottom: 9px; font-size: 13px; } .tips li { margin-bottom: 12px; font-size: 15px; color: #d4dae4; }
.tips b { color: var(--accent, #6f8bff); } .tips b { color: #8aa0ff; }
.tips p { font-size: 14px; }