.site-detail {
max-width: 960px;
margin: 0 auto;
padding: 40px 20px 60px;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
color: #1e293b;
line-height: 1.7;
}
.site-detail * { box-sizing: border-box; }
.site-detail__breadcrumb {
display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
font-size: 13px; color: #94a3b8; margin-bottom: 28px;
}
.site-detail__breadcrumb a {
color: #64748b; text-decoration: none; transition: color .15s;
}
.site-detail__breadcrumb a:hover { color: var(--theme-color, #2563eb); }
.site-detail__breadcrumb span { color: #cbd5e1; }
.site-detail__breadcrumb-current { color: #1e293b !important; font-weight: 600; }
.site-detail__preview {
margin-bottom: 32px; border-radius: 16px; overflow: hidden;
box-shadow: 0 8px 40px rgba(0,0,0,.08);
border: 1px solid #e8ecf1;
background: #f1f5f9;
}
.site-detail__preview img {
width: 100%; height: auto; display: block; aspect-ratio: 16/7; object-fit: cover;
}
.site-detail__hero {
display: flex; align-items: center; gap: 24px; padding: 32px;
background: #fff; border-radius: 20px; border: 1px solid #e8ecf1;
box-shadow: 0 2px 16px rgba(0,0,0,.04); margin-bottom: 28px;
}
.site-detail__logo {
flex-shrink: 0; width: 88px; height: 88px; border-radius: 20px;
display: flex; align-items: center; justify-content: center;
background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
font-size: 36px; color: var(--theme-color, #2563eb); font-weight: 700;
box-shadow: 0 4px 16px rgba(37,99,235,.12);
}
.site-detail__logo img {
width: 88px; height: 88px; border-radius: 20px; object-fit: cover;
}
.site-detail__hero-info { flex: 1; min-width: 0; }
.site-detail__hero-title {
font-size: 26px; font-weight: 700; margin: 0 0 6px;
letter-spacing: -.3px; color: #0f172a;
}
.site-detail__hero-summary {
font-size: 14px; color: #64748b; line-height: 1.6;
margin: 0 0 12px; padding: 6px 0;
}
.site-detail__hero-tags {
display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 14px;
}
.site-detail__tag {
display: inline-flex; align-items: center; gap: 4px;
padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 500;
}
.site-detail__tag--lang {
background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0;
}
.site-detail__tag--country {
background: #fff7ed; color: #9a3412; border: 1px solid #fed7aa;
}
.site-detail__tag--views {
background: #f8fafc; color: #64748b; border: 1px solid #e2e8f0;
}
.site-detail__tag--dead {
background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; font-weight: 600;
}
.site-detail__hero-meta {
display: flex; align-items: center; gap: 16px; font-size: 13px; color: #94a3b8;
}
.site-detail__hero-meta span { display: inline-flex; align-items: center; gap: 4px; }
.site-detail__btn {
display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px;
border-radius: 10px; font-size: 14px; font-weight: 600; cursor: pointer;
text-decoration: none; border: none; transition: all .18s; white-space: nowrap;
}
.site-detail__btn--primary {
background: var(--theme-color, #2563eb); color: #fff;
box-shadow: 0 2px 8px rgba(37,99,235,.25);
}
.site-detail__btn--primary:hover {
transform: translateY(-1px); box-shadow: 0 6px 20px rgba(37,99,235,.35);
}
.site-detail__btn--outline {
background: #fff; color: var(--theme-color, #2563eb);
border: 1.5px solid #e2e8f0;
}
.site-detail__btn--outline:hover {
border-color: var(--theme-color, #2563eb); background: #f8fafc;
}
.site-detail__btn--dead {
display: inline-flex; align-items: center; gap: 6px;
padding: 9px 20px; border-radius: 10px; font-size: 14px; font-weight: 600;
background: #fee2e2; color: #dc2626; border: 1.5px solid #fecaca;
cursor: not-allowed; user-select: none;
}
.site-detail__btn--sm {
padding: 5px 14px; font-size: 12px;
}
.site-detail__actions {
display: flex; align-items: center; gap: 12px; margin-bottom: 32px;
padding: 20px 24px; background: #f8fafc; border-radius: 16px;
border: 1px solid #e8ecf1;
}
.site-detail__actions--dead {
background: #fef2f2; border-color: #fecaca;
}
.site-detail__section { margin-bottom: 28px; }
.site-detail__section-title {
font-size: 18px; font-weight: 700; margin: 0 0 14px;
display: flex; align-items: center; gap: 8px; color: #0f172a;
}
.site-detail__section-title::before {
content: ''; display: inline-block; width: 4px; height: 20px;
background: var(--theme-color, #2563eb); border-radius: 2px;
}
.site-detail__desc {
padding: 24px 28px; background: #fff; border-radius: 16px;
border: 1px solid #e8ecf1; box-shadow: 0 2px 12px rgba(0,0,0,.03);
}
.site-detail__desc p {
margin: 0; font-size: 15px; line-height: 1.9; color: #334155;
}
.site-detail__spare {
border: 1px solid #e8ecf1; border-radius: 14px; overflow: hidden;
background: #fff; box-shadow: 0 1px 6px rgba(0,0,0,.02);
}
.site-detail__spare-item {
display: flex; align-items: center; gap: 12px; padding: 14px 20px;
border-top: 1px solid #f1f5f9; transition: background .15s;
}
.site-detail__spare-item:hover { background: #f8fafc; }
.site-detail__spare-label {
flex-shrink: 0; font-size: 12px; color: #94a3b8; font-weight: 500;
min-width: 70px;
}
.site-detail__spare-url {
flex: 1; font-size: 13px; color: #2563eb; text-decoration: none;
overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
font-family: "SF Mono", "Fira Code", "Consolas", monospace;
}
.site-detail__spare-url:hover { text-decoration: underline; }
.site-detail__article {
font-size: 15px; line-height: 1.9; color: #334155;
word-break: break-word;
}
.site-detail__article h2 { font-size: 20px; margin: 28px 0 12px; color: #0f172a; }
.site-detail__article h3 { font-size: 17px; margin: 22px 0 10px; color: #1e293b; }
.site-detail__article p { margin: 0 0 14px; }
.site-detail__article a { color: var(--theme-color, #2563eb); }
.site-detail__article img { max-width:100%; border-radius:10px; margin:12px 0; }
.site-detail__article table { width:100%; border-collapse:collapse; margin:16px 0; font-size:14px; }
.site-detail__article thead th { background:#f1f5f9; padding:10px 12px; text-align:left; font-weight:600; border:1px solid #e2e8f0; color:#0f172a; }
.site-detail__article tbody td { padding:10px 12px; border:1px solid #e2e8f0; vertical-align:top; }
.site-detail__article tbody tr:nth-child(even) { background:#f8fafc; }
.site-detail__article ul,.site-detail__article ol { margin:0 0 14px; padding-left:20px; }
.site-detail__article li { margin-bottom:6px; }
.site-detail__article dl { margin:14px 0; }
.site-detail__article dt { font-weight:600; margin-bottom:4px; color:#1e293b; }
.site-detail__article dd { margin:0 0 12px 16px; }
.site-detail__article ul,.site-detail__article ol { padding-left:20px; margin:0 0 14px; }
.site-detail__article li { margin-bottom: 6px; }
.site-detail__article blockquote {
border-left: 3px solid var(--theme-color, #2563eb); padding: 10px 18px;
margin: 16px 0; background: #f8fafc; border-radius: 0 8px 8px 0;
color: #64748b; font-style: italic;
}
.site-detail__footer {
display: flex; flex-direction: column; gap: 18px;
padding-top: 28px; margin-top: 36px;
border-top: 1px solid #e8ecf1;
}
.site-detail__footer-label {
font-size: 13px; font-weight: 600; color: #94a3b8;
margin-bottom: 6px; text-transform: uppercase; letter-spacing: .5px;
}
.site-detail__footer-tags {
display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.site-detail__cat-link {
display: inline-flex; align-items: center; gap: 4px;
padding: 6px 14px; background: #eff6ff; color: #2563eb;
border-radius: 20px; font-size: 13px; font-weight: 500; text-decoration: none;
transition: all .15s;
}
.site-detail__cat-link:hover { background: #2563eb; color: #fff; }
.site-detail__tag-link {
display: inline-flex; align-items: center; padding: 5px 12px;
background: #f8fafc; color: #64748b; border: 1px solid #e2e8f0;
border-radius: 20px; font-size: 12px; text-decoration: none; transition: all .15s;
}
.site-detail__tag-link:hover { border-color: var(--theme-color, #2563eb); color: var(--theme-color, #2563eb); }
.site-detail__related { margin-top: 42px; }
.site-detail__related-grid {
display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 12px;
}
.site-detail__related-card {
display: flex; align-items: center; gap: 10px; padding: 14px 16px;
background: #fff; border: 1px solid #e8ecf1; border-radius: 14px;
text-decoration: none; transition: all .18s;
}
.site-detail__related-card:hover {
border-color: #2563eb; box-shadow: 0 4px 16px rgba(37,99,235,.08);
transform: translateY(-2px);
}
.site-detail__related-thumb {
width: 40px; height: 40px; border-radius: 10px; object-fit: cover;
flex-shrink: 0; background: #f1f5f9;
}
.site-detail__related-name {
font-size: 14px; font-weight: 500; color: #1e293b;
overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
@media (max-width: 640px) {
.site-detail { padding: 20px 14px 40px; }
.site-detail__hero { flex-direction: column; text-align: center; padding: 24px 20px; }
.site-detail__hero-tags,.site-detail__hero-actions { justify-content: center; }
.site-detail__hero-meta { justify-content: center; flex-wrap: wrap; }
.site-detail__actions { flex-direction: column; align-items: stretch; }
.site-detail__actions a { text-align: center; justify-content: center; }
.site-detail__spare-item { flex-wrap: wrap; }
}.site-directory-container {
max-width: 1200px;
margin: 0 auto;
padding: 20px 20px 60px;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
} .sd-breadcrumb {
font-size: 13px;
color: #999;
margin-bottom: 20px;
padding: 10px 0;
border-bottom: 1px solid #f0f0f1;
}
.sd-breadcrumb a {
color: #4a6cf7;
text-decoration: none;
}
.sd-breadcrumb a:hover {
text-decoration: underline;
}
.sd-breadcrumb-sep {
margin: 0 8px;
color: #ccc;
}
.sd-breadcrumb-current {
color: #333;
font-weight: 500;
} .sd-page-header {
margin-bottom: 28px;
}
.sd-hero-header {
background: linear-gradient(135deg, #f0f1fe 0%, #e8f0fe 100%);
padding: 32px 36px;
border-radius: 16px;
border: 1px solid #dde3f9;
}
.sd-page-title {
font-size: 26px;
font-weight: 700;
margin: 0 0 10px;
color: #1a1a2e;
line-height: 1.4;
}
.sd-hero-header .sd-page-title {
font-size: 28px;
}
.sd-page-desc {
font-size: 15px;
color: #666;
line-height: 1.7;
margin: 0 0 12px;
}
.sd-hero-header .sd-page-desc {
font-size: 15px;
color: #555;
}
.sd-page-stats {
display: flex;
flex-wrap: wrap;
gap: 16px;
font-size: 13px;
color: #888;
margin-top: 10px;
}
.sd-page-stats strong {
color: #4a6cf7;
font-weight: 600;
} .sd-section-title {
font-size: 18px;
font-weight: 600;
color: #1a1a2e;
margin: 0 0 16px;
padding-bottom: 8px;
border-bottom: 2px solid #f0f0f1;
} .sd-subcats {
margin-bottom: 32px;
}
.sd-subcat-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 10px;
}
.sd-subcat-card {
display: flex;
align-items: center;
gap: 12px;
padding: 14px 16px;
background: #fff;
border: 1px solid #e8e8ef;
border-radius: 10px;
text-decoration: none;
transition: all 0.2s;
}
.sd-subcat-card:hover {
border-color: #4a6cf7;
box-shadow: 0 4px 15px rgba(74,108,247,0.08);
transform: translateY(-2px);
}
.sd-subcat-icon {
width: 40px;
height: 40px;
border-radius: 8px;
background: linear-gradient(135deg, #4a6cf7, #6d8aff);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
font-size: 18px;
font-weight: 700;
flex-shrink: 0;
}
.sd-subcat-info {
flex: 1;
min-width: 0;
}
.sd-subcat-name {
display: block;
font-size: 14px;
font-weight: 600;
color: #1a1a2e;
}
.sd-subcat-count {
display: block;
font-size: 12px;
color: #999;
margin-top: 2px;
}
.sd-subcat-arrow {
color: #ccc;
font-size: 16px;
} .sd-parent-link {
margin-bottom: 20px;
font-size: 14px;
color: #888;
}
.sd-parent-link a {
color: #4a6cf7;
font-weight: 500;
text-decoration: none;
}
.sd-parent-link a:hover {
text-decoration: underline;
} .sd-sites-section {
margin-bottom: 32px;
}
.site-directory-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 14px;
} .site-card {
background: #fff;
border: 1px solid #e8e8ef;
border-radius: 12px;
transition: all 0.25s ease;
overflow: hidden;
}
.site-card:hover {
border-color: #4a6cf7;
box-shadow: 0 8px 25px rgba(74, 108, 247, 0.10);
transform: translateY(-2px);
}
.site-card-inner {
display: flex;
align-items: center;
padding: 16px 18px;
gap: 12px;
}
.site-card-favicon {
width: 44px;
height: 44px;
border-radius: 10px;
flex-shrink: 0;
object-fit: contain;
background: #f5f5fa;
}
.site-card-body {
flex: 1;
min-width: 0;
}
.site-card-title {
font-size: 15px;
font-weight: 600;
margin: 0 0 3px;
line-height: 1.3;
}
.site-card-title a {
color: #1a1a2e;
text-decoration: none;
}
.site-card-title a:hover {
color: #4a6cf7;
}
.site-card-desc {
font-size: 12px;
color: #888;
margin: 0 0 6px;
line-height: 1.5;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.site-card-meta {
font-size: 11px;
color: #aaa;
display: flex;
align-items: center;
gap: 6px;
flex-wrap: wrap;
}
.site-card-cats a,
.site-mini-tag {
color: #4a6cf7;
text-decoration: none;
font-size: 11px;
background: #f0f1fe;
padding: 1px 6px;
border-radius: 4px;
}
.site-card-cats a:hover,
.site-mini-tag:hover {
background: #e0e3fd;
}
.site-card-tags {
display: flex;
gap: 4px;
}
.site-card-date {
color: #bbb;
} .site-card-visit {
flex-shrink: 0;
display: inline-flex;
align-items: center;
justify-content: center;
height: 32px;
padding: 0 14px;
background: #4a6cf7;
color: #fff;
font-size: 13px;
font-weight: 500;
border-radius: 8px;
text-decoration: none;
transition: background 0.2s;
}
.site-card-visit:hover {
background: #3b5de7;
color: #fff;
} .site-directory-single {
background: #fff;
border-radius: 16px;
padding: 32px 36px;
border: 1px solid #e8e8ef;
margin-bottom: 24px;
}
.site-entry-header {
margin-bottom: 20px;
}
.site-entry-header-inner {
display: flex;
align-items: center;
gap: 16px;
}
.site-favicon {
width: 64px;
height: 64px;
border-radius: 14px;
flex-shrink: 0;
object-fit: contain;
background: #f5f5fa;
}
.site-title-area {
flex: 1;
}
.site-entry-title {
font-size: 24px;
font-weight: 700;
margin: 0 0 8px;
color: #1a1a2e;
line-height: 1.3;
}
.site-entry-meta-top {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
.site-type-badge {
display: inline-block;
padding: 3px 10px;
font-size: 12px;
font-weight: 500;
background: #eef1ff;
color: #4a6cf7;
border-radius: 20px;
}
.site-views-badge {
background: #f0fdf4;
color: #166534;
border: 1px solid #bbf7d0;
}
.site-date-badge {
background: #fefce8;
color: #854d0e;
border: 1px solid #fef08a;
}
.site-status-dead {
background: #fef2f2;
color: #dc2626;
border: 1px solid #fecaca;
font-weight: 600;
}
.site-status-redirect {
background: #fffbeb;
color: #d97706;
border: 1px solid #fde68a;
} .site-action-bar {
display: flex;
align-items: center;
gap: 16px;
padding: 16px 20px;
background: #f8f9fc;
border-radius: 12px;
margin-bottom: 20px;
flex-wrap: wrap;
}
.site-visit-btn {
display: inline-flex;
align-items: center;
padding: 10px 24px;
background: #4a6cf7;
color: #fff;
font-size: 15px;
font-weight: 600;
border-radius: 10px;
text-decoration: none;
transition: background 0.2s;
}
.site-visit-btn:hover {
background: #3b5de7;
color: #fff;
}
.site-visit-disabled {
background: #9ca3af;
cursor: not-allowed;
pointer-events: none;
}
.site-action-dead {
background: #fef2f2;
border: 1px solid #fecaca;
}
.site-link-url {
font-size: 13px;
color: #999;
word-break: break-all;
} .site-entry-description {
background: #f8f9fc;
border-radius: 12px;
padding: 16px 20px;
margin-bottom: 20px;
font-size: 15px;
color: #555;
line-height: 1.7;
}
.site-entry-description p {
margin: 0;
} .site-entry-content {
font-size: 15px;
line-height: 1.8;
color: #333;
margin-bottom: 20px;
}
.site-entry-content img {
max-width: 100%;
height: auto;
border-radius: 8px;
} .site-entry-footer {
border-top: 1px solid #e8e8ef;
padding-top: 14px;
display: flex;
flex-direction: column;
gap: 8px;
}
.site-meta {
font-size: 14px;
color: #666;
}
.meta-label {
font-weight: 500;
color: #333;
}
.site-meta a {
color: #4a6cf7;
text-decoration: none;
}
.site-meta a:hover {
text-decoration: underline;
}
.site-tag {
display: inline-block;
padding: 3px 10px;
margin: 2px 4px 2px 0;
background: #f0f1fe;
color: #4a6cf7;
border-radius: 6px;
font-size: 13px;
}
.site-tag:hover {
background: #dde3f9;
} .sd-related-section {
margin-bottom: 32px;
}
.sd-related-tags {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.sd-related-link {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 14px;
background: #fff;
border: 1px solid #e8e8ef;
border-radius: 20px;
font-size: 13px;
color: #444;
text-decoration: none;
transition: all 0.2s;
}
.sd-related-link:hover {
border-color: #4a6cf7;
color: #4a6cf7;
background: #fafafe;
}
.sd-related-badge {
background: #f0f1fe;
color: #4a6cf7;
font-size: 11px;
padding: 1px 7px;
border-radius: 10px;
font-weight: 500;
} .sd-all-cats-section {
margin-bottom: 32px;
}
.sd-all-cats-grid {
display: grid;
grid-template-columns: repeat(6, 1fr);
gap: 10px;
}
.sd-all-cat-item {
display: flex;
align-items: center;
justify-content: space-between;
padding: 12px 16px;
background: #fff;
border: 1px solid #e8e8ef;
border-radius: 10px;
text-decoration: none;
font-size: 14px;
color: #444;
font-weight: 500;
transition: all 0.2s;
}
.sd-all-cat-item:hover {
border-color: #4a6cf7;
color: #4a6cf7;
background: #fafafe;
}
.sd-cat-active {
border-color: #4a6cf7;
background: #f0f1fe;
color: #4a6cf7;
}
.sd-all-cat-count {
font-size: 11px;
color: #999;
background: #f5f5fa;
padding: 1px 8px;
border-radius: 10px;
font-weight: 400;
}
.sd-cat-active .sd-all-cat-count {
background: #dde3f9;
color: #4a6cf7;
} .sd-empty {
text-align: center;
padding: 60px 20px;
color: #999;
font-size: 15px;
}
.sd-empty a {
color: #4a6cf7;
text-decoration: none;
} .navigation.pagination {
margin-top: 28px;
text-align: center;
}
.navigation.pagination .nav-links {
display: inline-flex;
gap: 6px;
}
.navigation.pagination .page-numbers {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 36px;
height: 36px;
padding: 0 10px;
background: #f5f5fa;
border-radius: 8px;
font-size: 14px;
color: #555;
text-decoration: none;
transition: all 0.2s;
}
.navigation.pagination .page-numbers.current {
background: #4a6cf7;
color: #fff;
font-weight: 600;
}
.navigation.pagination .page-numbers:hover:not(.current) {
background: #e8e8ef;
} .site-comments-area {
margin-top: 24px;
} @media (max-width: 1200px) {
.site-directory-grid { grid-template-columns: repeat(3, 1fr); }
.sd-subcat-grid { grid-template-columns: repeat(3, 1fr); }
.sd-all-cats-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 900px) {
.site-directory-grid { grid-template-columns: repeat(2, 1fr); }
.sd-subcat-grid { grid-template-columns: repeat(2, 1fr); }
.sd-all-cats-grid { grid-template-columns: repeat(3, 1fr); }
.sd-hero-header { padding: 24px 20px; }
}
@media (max-width: 768px) {
.site-directory-grid { grid-template-columns: 1fr; }
.sd-subcat-grid { grid-template-columns: 1fr; }
.sd-all-cats-grid { grid-template-columns: repeat(2, 1fr); }
.sd-page-stats { flex-direction: column; gap: 6px; }
.site-directory-single { padding: 20px 16px; }
.site-entry-header-inner { flex-direction: column; align-items: flex-start; }
.site-action-bar { flex-direction: column; align-items: flex-start; }
.site-card-inner { padding: 14px 16px; gap: 10px; }
}.landing { max-width: 1200px; margin: 0 auto; }
.landing * { box-sizing: border-box; } .landing-hero {
max-width: 1500px; margin: 0 auto; padding: 48px 24px 28px;
text-align: center;
}
.landing-hero__title {
font-size: clamp(22px, 5vw, 38px); font-weight: 800;
letter-spacing: -.5px; margin: 0 0 8px; color: var(--text-primary);
line-height: 1.25;
}
.landing-hero__desc { font-size: 15px; color: var(--text-tertiary); margin: 0 0 24px; }
.landing-hero__search { max-width: 640px; margin: 0 auto; width: 100%; }
.landing-search-tabs {
display: inline-flex; justify-content: center; gap: 2px; margin-bottom: 14px;
background: var(--bg-hover); border-radius: 8px; padding: 3px; flex-wrap: wrap;
}
.landing-search-tab {
padding: 7px 20px; border-radius: 6px; font-size: 13px; font-weight: 500;
cursor: pointer; border: none; background: transparent; color: var(--text-muted); transition: all .2s;
}
.landing-search-tab:hover { color: var(--text-secondary); }
.landing-search-tab--active {
background: var(--bg-card); color: var(--color-link);
box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.landing-search-wrap { position: relative; width: 100%; }
.landing-search-input {
width: 100%; height: 54px; border-radius: 13px; border: 1.5px solid var(--border-input);
background: var(--bg-card); font-size: 16px; padding: 0 56px 0 24px; outline: none;
transition: all .2s; box-shadow: 0 2px 8px rgba(0,0,0,.04); color: var(--text-primary);
}
.landing-search-input:focus {
border-color: var(--theme-color, #2563eb);
box-shadow: 0 0 0 4px rgba(37,99,235,.06), 0 2px 8px rgba(0,0,0,.04);
}
.landing-search-input::placeholder { color: var(--border-hover); }
.landing-search-btn {
position: absolute; right: 7px; top: 50%; transform: translateY(-50%);
width: 40px; height: 40px; border-radius: 10px; border: none;
background: var(--theme-color, #2563eb); color: #fff; cursor: pointer;
display: flex; align-items: center; justify-content: center; transition: all .2s;
}
.landing-search-btn:hover { opacity: .92; box-shadow: 0 4px 16px rgba(37,99,235,.3); }
.landing-hero__divider { max-width: 1500px; margin: 0 auto; padding: 0 24px; }
.landing-hero__divider::after {
content: ''; display: block; height: 1px;
background: linear-gradient(90deg, transparent, var(--border-input) 20%, var(--border-input) 80%, transparent);
} .landing-body { display: flex; max-width: 1500px; margin: 0 auto; padding: 28px 24px 60px; gap: 28px; } .landing-sidebar {
width: 100px !important; min-width: 100px !important; max-width: 100px !important; flex-shrink: 0;
position: sticky; top: 28px; height: fit-content;
max-height: calc(100vh - 56px); overflow-y: auto;
scrollbar-width: thin; scrollbar-color: var(--border-input) transparent;
}
.landing-sidebar::-webkit-scrollbar { width: 4px; }
.landing-sidebar::-webkit-scrollbar-track { background: transparent; }
.landing-sidebar::-webkit-scrollbar-thumb { background: var(--border-input); border-radius: 4px; }
.landing-sidebar__title {
font-size: 16px; font-weight: 700; color: var(--text-primary);
margin: 0 0 14px; text-align: center;
}
.landing-sidebar__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.landing-sidebar__link {
display: block; padding: 8px; font-size: 14px; color: var(--text-tertiary);
text-decoration: none; border-radius: var(--border-radius-sm); transition: all .2s;
line-height: 1.4; cursor: pointer; border-left: 3px solid transparent;
}
.landing-sidebar__link:hover {
background: var(--bg-secondary); color: var(--text-primary); border-left-color: var(--border-hover);
}
.landing-sidebar__link--active {
background: var(--bg-hover); color: var(--theme-color, #2563eb); font-weight: 600;
border-left-color: var(--theme-color, #2563eb);
} .landing-main { flex: 1; min-width: 0; } .landing-group { margin-bottom: 48px; }
.landing-group:last-child { margin-bottom: 0; }
.landing-group__header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4px; }
.landing-group__title {
font-size: 24px; font-weight: 700; color: var(--caption-color, var(--text-primary));
margin: 0; line-height: 1.3;
}
.landing-group__actions { display: flex; gap: 10px; flex-shrink: 0; align-items: center; }
.landing-group__action-link {
font-size: 13px; color: var(--text-muted); text-decoration: none; cursor: pointer;
display: flex; align-items: center; gap: 2px; transition: color .15s;
}
.landing-group__action-link:hover { color: var(--theme-color, #2563eb); } .landing-cards-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; margin-top: 18px; }
.landing-card {
display: flex; align-items: center; gap: 12px;
padding: 14px 16px; background: var(--bg-card); border: 1px solid var(--border-secondary);
border-radius: var(--border-radius); transition: all .2s ease; cursor: pointer;
min-width: 0; box-sizing: border-box;
}
.landing-card:hover {
border-color: var(--theme-color, #2563eb);
box-shadow: 0 4px 16px rgba(37,99,235,.08); transform: translateY(-1px);
}
.landing-card__icon {
flex-shrink: 0; width: 42px; height: 42px; border-radius: 10px;
overflow: hidden; background: var(--bg-hover);
display: flex; align-items: center; justify-content: center;
}
.landing-card__icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; }
.landing-card__icon-fallback { font-size: 18px; font-weight: 700; color: var(--text-muted); }
.landing-card__info { flex: 1; min-width: 0; }
.landing-card__name {
font-size: 13px; font-weight: 600; color: var(--text-primary);
margin: 0 0 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.landing-card__desc {
font-size: 11px; color: var(--text-muted); line-height: 1.4;
overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
} @media (max-width: 1400px) {
.landing-cards-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 1080px) {
.landing-cards-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
} @media (max-width: 900px) {
.landing-body { flex-direction: column; padding: 20px 16px 40px; }
.landing-sidebar {
width: 100% !important; min-width: unset !important; max-width: unset !important;
position: static; max-height: none; order: -1;
display: flex; overflow-x: auto; gap: 4px; padding-bottom: 12px;
-ms-overflow-style: none; scrollbar-width: none;
}
.landing-sidebar::-webkit-scrollbar { display: none; }
.landing-sidebar__title { display: none; }
.landing-sidebar__list { display: flex; gap: 4px; flex-wrap: nowrap; }
.landing-sidebar__link { white-space: nowrap; padding: 7px 14px; font-size: 12px; border-left: none; }
.landing-sidebar__link--active { border-left: none; }
.landing-cards-grid { grid-template-columns: repeat(3, 1fr); }
} @media (max-width: 700px) {
.landing-sidebar { display: none; }
.landing-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
.landing-hero { padding: 32px 16px 24px; }
.landing-hero__title { font-size: clamp(20px, 6vw, 28px); }
.landing-hero__desc { font-size: 14px; margin-bottom: 18px; }
.landing-hero__divider { padding: 0 16px; }
.landing-card {
padding: 12px 11px; gap: 10px; border-radius: 12px;
box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.03);
}
.landing-card__icon { width: 44px; height: 44px; border-radius: 10px; }
.landing-card__name { font-size: 13px; }
.landing-card__desc { font-size: 11px; }
.landing-group { margin-bottom: 32px; }
.landing-group__title { font-size: 20px; }
} .landing-hot { max-width: 1500px; margin: 0 auto; padding: 28px 24px 48px; }
.landing-hot__header { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.landing-hot__title {
font-size: 22px; font-weight: 700; color: var(--caption-color, var(--text-primary));
margin: 0; line-height: 1.3; white-space: nowrap;
}
.landing-hot__tabs { display: inline-flex; gap: 0; align-items: center; background: var(--bg-hover); border-radius: 8px; padding: 3px; }
.landing-hot__tab {
padding: 6px 18px; border-radius: 6px; border: none;
background: transparent; font-size: 13px; font-weight: 500; color: var(--text-muted); cursor: pointer;
transition: all .2s; white-space: nowrap;
}
.landing-hot__tab:hover { color: var(--text-secondary); }
.landing-hot__tab--active {
background: var(--bg-card); color: var(--theme-color, #2563eb);
box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.landing-hot-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; transition: opacity .2s ease; }
.landing-hot-card {
display: flex; align-items: center; gap: 10px;
padding: 12px 14px; background: var(--bg-card); border: 1px solid var(--border-secondary);
border-radius: var(--border-radius); cursor: pointer;
transition: all .2s ease; min-width: 0;
}
.landing-hot-card:hover {
border-color: var(--theme-color, #2563eb);
box-shadow: 0 4px 16px rgba(37,99,235,.08); transform: translateY(-1px);
}
.landing-hot-card__icon {
flex-shrink: 0; width: 38px; height: 38px; border-radius: 8px;
overflow: hidden; background: var(--bg-hover);
display: flex; align-items: center; justify-content: center;
}
.landing-hot-card__icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }
.landing-hot-card__icon-fallback { font-size: 17px; font-weight: 700; color: var(--text-muted); }
.landing-hot-card__info { flex: 1; min-width: 0; overflow: hidden; }
.landing-hot-card__name {
font-size: 13px; font-weight: 600; color: var(--text-primary);
margin: 0 0 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.landing-hot-card__desc {
font-size: 11px; color: var(--text-muted); line-height: 1.45;
overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
} @media (max-width: 1200px) { .landing-hot-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 900px) { .landing-hot-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 700px) {
.landing-hot-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.landing-hot__header { flex-wrap: wrap; gap: 12px; }
.landing-hot__title { font-size: 18px; line-height: 1.25; white-space: normal; word-break: break-word; }
.landing-hot-card {
padding: 12px 11px; gap: 10px; border-radius: 12px;
box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.03);
}
.landing-hot-card__icon { width: 44px; height: 44px; border-radius: 10px; }
.landing-hot-card__name { font-size: 13px; }
.landing-hot-card__desc { font-size: 11px; }
}
@media (max-width: 420px) {
.landing-hot-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.landing-hot-card { padding: 11px 9px; gap: 8px; border-radius: 10px; }
.landing-hot-card__icon { width: 40px; height: 40px; border-radius: 9px; }
.landing-hot-card__name { font-size: 12.5px; }
.landing-hot-card__desc { font-size: 11px; -webkit-line-clamp: 1; }
} .landing-news { padding: 48px 24px 60px; border-top: 1px solid var(--border-secondary); }
.landing-news__inner { max-width: 1500px; margin: 0 auto; }
.landing-news__header { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.landing-news__title {
font-size: 22px; font-weight: 700; color: var(--caption-color, var(--text-primary));
margin: 0; line-height: 1.3;
}
.landing-news__more {
font-size: 13px; color: var(--text-muted); text-decoration: none; cursor: pointer;
display: flex; align-items: center; gap: 2px; transition: color .15s; white-space: nowrap; flex-shrink: 0;
}
.landing-news__more:hover { color: var(--theme-color, #2563eb); }
.landing-news__subtitle { font-size: 13px; color: var(--text-muted); margin: 0 0 20px; }
.landing-news-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; }
.landing-news-card {
display: block; background: var(--bg-card); border: 1px solid var(--border-secondary);
border-radius: var(--border-radius); overflow: hidden; text-decoration: none;
transition: all .2s ease; cursor: pointer;
}
.landing-news-card:hover {
border-color: var(--theme-color, #2563eb);
box-shadow: 0 4px 16px rgba(37,99,235,.08); transform: translateY(-2px);
}
.landing-news-card__thumb { width: 100%; height: 140px; overflow: hidden; position: relative; background: var(--bg-hover); }
.landing-news-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.landing-news-card:hover .landing-news-card__thumb img { transform: scale(1.05); }
.landing-news-card__date {
position: absolute; right: 8px; bottom: 8px;
padding: 2px 8px; border-radius: 6px; background: var(--bg-card);
backdrop-filter: blur(4px); font-size: 11px; color: var(--text-secondary);
display: flex; align-items: center; gap: 4px; white-space: nowrap;
}
.landing-news-card__body { padding: 12px 14px 14px; min-width: 0; }
.landing-news-card__title {
font-size: 14px; font-weight: 600; color: var(--text-primary); line-height: 1.45;
margin: 0 0 6px; display: -webkit-box; -webkit-line-clamp: 2;
-webkit-box-orient: vertical; overflow: hidden; word-break: break-all;
}
.landing-news-card__excerpt {
font-size: 12px; color: var(--text-muted); line-height: 1.55;
margin: 0 0 10px; display: -webkit-box; -webkit-line-clamp: 2;
-webkit-box-orient: vertical; overflow: hidden; word-break: break-all;
}
.landing-news-card__tags { display: flex; flex-wrap: nowrap; gap: 4px; overflow: hidden; }
.landing-news-card__tag {
padding: 2px 8px; border-radius: 4px; border: 1px solid var(--border-input);
background: var(--bg-card); font-size: 11px; color: var(--text-secondary);
text-decoration: none; transition: all .12s; white-space: nowrap; flex-shrink: 0;
}
.landing-news-card__tag:hover { color: var(--theme-color, #2563eb); border-color: var(--border-hover); } @media (max-width: 1200px) { .landing-news-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 900px) { .landing-news-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 700px) {
.landing-news-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.landing-news-card { border-radius: 14px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.landing-news-card__thumb { height: 160px; border-radius: 14px 14px 0 0; }
.landing-news-card__body { padding: 14px 14px 16px; }
.landing-news-card__title { font-size: 15px; }
.landing-news-card__excerpt { display: none; }
.landing-news-card__tag { font-size: 12px; padding: 3px 10px; }
.landing-news__header { flex-direction: column; align-items: flex-start; }
.landing-news__title { font-size: 18px; }
.landing-news__subtitle { font-size: 12px; margin-bottom: 14px; }
.landing-news__more { font-size: 12px; }
.landing-group__title { font-size: 20px; }
}
@media (max-width: 420px) {
.landing-news-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.landing-news-card__thumb { height: 140px; }
.landing-news-card__body { padding: 12px 10px 12px; }
.landing-news-card__title { font-size: 14px; }
.landing-news__title { font-size: 16px; }
.landing-news__subtitle { font-size: 11px; }
.landing-news__more { font-size: 11px; }
} .search-section { margin-bottom: 36px; }
.search-section__title {
font-size: 18px; font-weight: 600; color: var(--text-primary);
margin: 0 0 16px; padding-bottom: 10px; border-bottom: 1px solid var(--border-secondary);
}
.search-sites-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.search-site-card {
display: flex; align-items: center; gap: 12px;
padding: 14px 16px; background: var(--bg-card); border: 1px solid var(--border-secondary);
border-radius: var(--border-radius); text-decoration: none; cursor: pointer;
transition: all .2s ease; min-width: 0; box-sizing: border-box;
}
.search-site-card:hover {
border-color: var(--theme-color, #2563eb);
box-shadow: 0 4px 16px rgba(37,99,235,.08); transform: translateY(-1px);
}
.search-site-card__icon {
flex-shrink: 0; width: 42px; height: 42px; border-radius: 10px;
overflow: hidden; background: var(--bg-hover);
display: flex; align-items: center; justify-content: center;
}
.search-site-card__icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; }
.search-site-card__icon-fallback { font-size: 18px; font-weight: 700; color: var(--text-muted); }
.search-site-card__info { flex: 1; min-width: 0; }
.search-site-card__name {
font-size: 14px; font-weight: 600; color: var(--text-primary);
margin: 0 0 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.search-site-card__desc {
font-size: 12px; color: var(--text-muted); line-height: 1.5; margin: 0;
overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
@media (max-width: 700px) {
.search-sites-list { grid-template-columns: 1fr; gap: 10px; }
.search-site-card { padding: 12px 11px; gap: 10px; border-radius: 12px; }
.search-site-card__icon { width: 44px; height: 44px; }
.search-site-card__name { font-size: 13px; }
.search-site-card__desc { font-size: 11px; }
}