refactor: admin ui를 fluent v5와 html 기반으로 전환
TaxBaik CI/CD / build-and-deploy (push) Failing after 1m53s

This commit is contained in:
2026-06-29 22:37:40 +09:00
parent 1a7bc9e209
commit 1b173376ee
51 changed files with 2471 additions and 3560 deletions
+308
View File
@@ -746,3 +746,311 @@ img {
.faq-answer ul li {
margin-bottom: 0.4rem;
}
body.site-blazor {
margin: 0;
font-family: 'Noto Sans KR', sans-serif;
background: linear-gradient(180deg, #faf7f2 0%, #f4efe6 100%);
color: #3d2817;
}
.site-shell {
min-height: 100vh;
}
.site-topbar {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem 1.5rem;
border-bottom: 1px solid rgba(0,0,0,0.08);
background: rgba(255,255,255,0.72);
backdrop-filter: blur(12px);
position: sticky;
top: 0;
}
.site-logo {
font-weight: 800;
color: #2e5c4e;
text-decoration: none;
}
.site-nav {
display: flex;
gap: 1rem;
}
.site-nav a {
color: #3d2817;
text-decoration: none;
}
.site-hero {
padding: 5rem 1.5rem;
max-width: 1200px;
margin: 0 auto;
}
.site-hero-copy h1 {
font-size: clamp(2.2rem, 7vw, 4rem);
line-height: 1.1;
margin: 0.5rem 0 1rem;
}
.site-kicker {
color: #a67c52;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.site-actions {
display: flex;
gap: 0.75rem;
flex-wrap: wrap;
margin-top: 1.5rem;
}
.site-button {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 48px;
padding: 0.9rem 1.4rem;
border-radius: 12px;
text-decoration: none;
font-weight: 700;
}
.site-button.primary {
background: linear-gradient(135deg, #c89d6e 0%, #a67c52 100%);
color: white;
}
.site-button.secondary {
border: 1px solid #c89d6e;
color: #a67c52;
background: rgba(255,255,255,0.7);
}
.site-content {
max-width: 960px;
margin: 0 auto;
padding: 3rem 1.5rem;
}
.site-post-grid,
.taxbaik-skeleton-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
gap: 1rem;
}
.site-post-card,
.taxbaik-skeleton-item {
background: rgba(255,255,255,0.82);
border: 1px solid rgba(0,0,0,0.08);
border-radius: 16px;
padding: 1.25rem;
box-shadow: 0 12px 30px rgba(61,40,23,0.08);
}
.taxbaik-skeleton-line {
height: 14px;
margin-bottom: 0.75rem;
border-radius: 999px;
background: linear-gradient(90deg, rgba(201,173,140,0.18) 25%, rgba(201,173,140,0.35) 37%, rgba(201,173,140,0.18) 63%);
background-size: 400% 100%;
animation: taxbaikShimmer 1.2s ease-in-out infinite;
}
.taxbaik-skeleton-title { height: 24px; width: 70%; }
.taxbaik-skeleton-short { width: 45%; }
@keyframes taxbaikShimmer {
0% { background-position: 100% 0; }
100% { background-position: -100% 0; }
}
/* ===== Admin Polish ===== */
.admin-shell {
min-height: 100vh;
background:
radial-gradient(circle at top left, rgba(200, 157, 110, 0.10), transparent 34%),
radial-gradient(circle at top right, rgba(46, 92, 78, 0.08), transparent 28%),
linear-gradient(180deg, #fbf8f3 0%, #f4efe6 100%);
}
.admin-topbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding: 1rem 1.25rem;
border-bottom: 1px solid rgba(61, 40, 23, 0.08);
backdrop-filter: blur(16px);
background: rgba(255,255,255,0.76);
}
.admin-content-inner {
max-width: 1440px;
margin: 0 auto;
padding: 1.5rem;
}
.admin-page-hero h1,
.admin-page-hero .admin-page-title {
margin-bottom: 0.25rem;
}
.admin-page-subtitle,
.muted {
color: var(--color-text-light);
}
.admin-icon-button {
border: 1px solid rgba(61, 40, 23, 0.14);
background: rgba(255,255,255,0.8);
border-radius: 10px;
min-width: 40px;
min-height: 40px;
display: inline-flex;
align-items: center;
justify-content: center;
}
.admin-icon-button.danger {
color: var(--color-danger);
}
.admin-menu-button {
display: inline-flex;
}
.admin-drawer {
width: 280px;
padding: 1rem;
border-right: 1px solid rgba(61, 40, 23, 0.08);
background: rgba(255,255,255,0.76);
backdrop-filter: blur(16px);
}
.admin-drawer.open {
display: block;
}
.admin-content {
min-height: calc(100vh - 72px);
}
.admin-topbar-title h1 {
margin: 0;
font-size: 1.1rem;
}
.admin-topbar-kicker,
.admin-brand-subtitle,
.admin-footer-meta {
color: var(--color-text-light);
font-size: 0.85rem;
}
.admin-nav {
display: grid;
gap: 0.35rem;
margin-top: 1rem;
}
.admin-nav-link,
.admin-topbar-action {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 0.9rem;
border-radius: 12px;
color: var(--color-text);
}
.admin-nav-link:hover,
.admin-topbar-action:hover {
background: rgba(200, 157, 110, 0.10);
color: var(--color-secondary);
}
.admin-nav details {
padding: 0.25rem 0;
}
.admin-nav summary {
list-style: none;
cursor: pointer;
font-weight: 700;
padding: 0.75rem 0.9rem;
}
.admin-nav summary::-webkit-details-marker {
display: none;
}
.admin-drawer-footer {
margin-top: 1.5rem;
padding-top: 1rem;
border-top: 1px solid rgba(61, 40, 23, 0.08);
}
.admin-kv-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
gap: 0.9rem;
}
.admin-kv-grid > div {
padding: 0.75rem 0.85rem;
border-radius: 14px;
background: rgba(255,255,255,0.76);
border: 1px solid rgba(61, 40, 23, 0.08);
}
.admin-kv-grid span {
display: block;
font-size: 0.78rem;
color: var(--color-text-light);
margin-bottom: 0.25rem;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.admin-pagination {
display: flex;
justify-content: center;
gap: 0.75rem;
margin-top: 1rem;
align-items: center;
flex-wrap: wrap;
}
.admin-divider {
height: 1px;
background: rgba(61, 40, 23, 0.08);
margin: 1rem 0;
}
@media (max-width: 959px) {
.admin-shell {
display: grid;
}
.admin-drawer {
width: 100%;
border-right: none;
border-bottom: 1px solid rgba(61, 40, 23, 0.08);
}
.admin-content-inner {
padding: 1rem;
}
.admin-topbar {
flex-wrap: wrap;
}
}