Template:Main Page/styles.css: Difference between revisions
Template page
More actions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
/** | /** | ||
* ComputerScience.wiki Main Page Styles | * ComputerScience.wiki Main Page Styles | ||
* Using colors and styles from MediaWiki-Common.css | * Using colors and styles from MediaWiki-Common.css with proper theme support | ||
*/ | */ | ||
Line 12: | Line 12: | ||
/* Top Banner */ | /* Top Banner */ | ||
#mp-topbanner { | #mp-topbanner { | ||
background: | background: var(--color-primary); | ||
color: | color: var(--color-base--inverted); | ||
padding: 32px 24px; | padding: 32px 24px; | ||
border-radius: 8px; | border-radius: 8px; | ||
Line 19: | Line 19: | ||
margin-bottom: 40px; | margin-bottom: 40px; | ||
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | ||
} | |||
.skin-vector-2022.skin-vector-max-width #mp-topbanner { | |||
background: linear-gradient(135deg, #2e51a3, #4c6fc6); | |||
} | |||
.skin-vector-2022.vector-feature-limited-width-clientpref-1.skin-vector-max-width #mp-topbanner { | |||
background: linear-gradient(135deg, #2e51a3, #4c6fc6); | |||
} | } | ||
Line 43: | Line 51: | ||
.mp-search-box { | .mp-search-box { | ||
background-color: | background-color: var(--color-surface-1); | ||
border: 1px solid | border: 1px solid var(--border-color-base); | ||
border-radius: 8px; | border-radius: 8px; | ||
padding: 20px; | padding: 20px; | ||
Line 56: | Line 64: | ||
margin: 32px 0 24px; | margin: 32px 0 24px; | ||
text-align: center; | text-align: center; | ||
color: | color: var(--color-primary); | ||
position: relative; | position: relative; | ||
} | } | ||
Line 65: | Line 73: | ||
width: 60px; | width: 60px; | ||
height: 3px; | height: 3px; | ||
background: | background: var(--color-primary); | ||
margin: 10px auto 0; | margin: 10px auto 0; | ||
border-radius: 1px; | border-radius: 1px; | ||
Line 83: | Line 91: | ||
/* Category Cards */ | /* Category Cards */ | ||
.mp-category-card { | .mp-category-card { | ||
background-color: | background-color: var(--color-surface-1); | ||
border-radius: 8px; | border-radius: 8px; | ||
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | ||
Line 90: | Line 98: | ||
min-width: 250px; | min-width: 250px; | ||
max-width: 350px; | max-width: 350px; | ||
border: 1px solid | border: 1px solid var(--border-color-base); | ||
margin: 0 10px 20px; | margin: 0 10px 20px; | ||
transition: box-shadow 0.2s; | transition: box-shadow 0.2s; | ||
Line 115: | Line 123: | ||
font-weight: 600; | font-weight: 600; | ||
margin: 0; | margin: 0; | ||
color: | color: var(--color-primary); | ||
} | } | ||
Line 126: | Line 134: | ||
.mp-category-list li { | .mp-category-list li { | ||
padding: 8px 0; | padding: 8px 0; | ||
border-bottom: 1px solid | border-bottom: 1px solid var(--border-color-base); | ||
} | } | ||
Line 133: | Line 141: | ||
margin-top: 10px; | margin-top: 10px; | ||
font-weight: 500; | font-weight: 500; | ||
color: | color: var(--color-primary); | ||
} | } | ||
Line 164: | Line 172: | ||
flex: 1 1 300px; | flex: 1 1 300px; | ||
min-width: 250px; | min-width: 250px; | ||
background-color: | background-color: var(--color-surface-1); | ||
border-radius: 8px; | border-radius: 8px; | ||
padding: 20px; | padding: 20px; | ||
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | ||
border: 1px solid | border: 1px solid var(--border-color-base); | ||
margin: 0 12px 24px; | margin: 0 12px 24px; | ||
} | } | ||
Line 177: | Line 185: | ||
margin-bottom: 16px; | margin-bottom: 16px; | ||
padding-bottom: 10px; | padding-bottom: 10px; | ||
border-bottom: 1px solid | border-bottom: 1px solid var(--border-color-base); | ||
color: | color: var(--color-primary); | ||
} | } | ||
Line 198: | Line 206: | ||
.mp-stat-card { | .mp-stat-card { | ||
background-color: | background-color: var(--color-surface-1); | ||
border-radius: 8px; | border-radius: 8px; | ||
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12); | ||
Line 204: | Line 212: | ||
min-width: 140px; | min-width: 140px; | ||
text-align: center; | text-align: center; | ||
border: 1px solid | border: 1px solid var(--border-color-base); | ||
flex: 1 1 140px; | flex: 1 1 140px; | ||
margin: 0 12px 24px; | margin: 0 12px 24px; | ||
Line 212: | Line 220: | ||
font-size: 1.8rem; | font-size: 1.8rem; | ||
font-weight: 700; | font-weight: 700; | ||
color: | color: var(--color-primary); | ||
margin-bottom: 8px; | margin-bottom: 8px; | ||
} | } | ||
Line 218: | Line 226: | ||
.mp-stat-label { | .mp-stat-label { | ||
font-size: 0.95rem; | font-size: 0.95rem; | ||
color: # | color: var(--color-base--subtle); | ||
} | |||
/* Fallback colors for non-supporting environments */ | |||
.mp-search-box, | |||
.mp-category-card, | |||
.mp-community-card, | |||
.mp-stat-card { | |||
background-color: #ffffff; | |||
} | |||
/* Dark mode fallback if variables don't work */ | |||
@media (prefers-color-scheme: dark) { | |||
.mp-search-box, | |||
.mp-category-card, | |||
.mp-community-card, | |||
.mp-stat-card { | |||
background-color: #111827; | |||
border-color: #374151; | |||
} | |||
.mp-category-list li { | |||
border-color: #374151; | |||
} | |||
.mp-community-card h3 { | |||
border-color: #374151; | |||
} | |||
.mp-stat-number { | |||
color: #818cf8; | |||
} | |||
.mp-stat-label { | |||
color: #9ca3af; | |||
} | |||
.mp-section-heading, | |||
.mp-category-title, | |||
.mp-category-list li:last-child, | |||
.mp-community-card h3 { | |||
color: #818cf8; | |||
} | |||
.mp-section-heading:after { | |||
background: #818cf8; | |||
} | |||
} | } | ||
Revision as of 17:17, 10 August 2025
/**
* ComputerScience.wiki Main Page Styles
* Using colors and styles from MediaWiki-Common.css with proper theme support
*/
/* General Layout */
.mp-box {
margin-bottom: 32px;
position: relative;
}
/* Top Banner */
#mp-topbanner {
background: var(--color-primary);
color: var(--color-base--inverted);
padding: 32px 24px;
border-radius: 8px;
text-align: center;
margin-bottom: 40px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}
.skin-vector-2022.skin-vector-max-width #mp-topbanner {
background: linear-gradient(135deg, #2e51a3, #4c6fc6);
}
.skin-vector-2022.vector-feature-limited-width-clientpref-1.skin-vector-max-width #mp-topbanner {
background: linear-gradient(135deg, #2e51a3, #4c6fc6);
}
#mp-welcome h1 {
font-size: 2.3rem;
margin: 0 0 8px;
font-weight: 700;
}
#mp-free {
font-size: 1.2rem;
opacity: 0.9;
max-width: 600px;
margin: 0 auto;
}
/* Search Box */
.mp-search-container {
max-width: 650px;
margin: -24px auto 32px;
position: relative;
z-index: 5;
}
.mp-search-box {
background-color: var(--color-surface-1);
border: 1px solid var(--border-color-base);
border-radius: 8px;
padding: 20px;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
/* Section Headings */
.mp-section-heading {
font-size: 1.6rem;
font-weight: 700;
margin: 32px 0 24px;
text-align: center;
color: var(--color-primary);
position: relative;
}
.mp-section-heading:after {
content: "";
display: block;
width: 60px;
height: 3px;
background: var(--color-primary);
margin: 10px auto 0;
border-radius: 1px;
}
/* Category Layout */
#mp-categories-container {
margin: 32px 0;
}
.mp-category-row {
display: flex;
flex-wrap: wrap;
margin: 0 -10px 20px;
}
/* Category Cards */
.mp-category-card {
background-color: var(--color-surface-1);
border-radius: 8px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
padding: 20px;
flex: 1;
min-width: 250px;
max-width: 350px;
border: 1px solid var(--border-color-base);
margin: 0 10px 20px;
transition: box-shadow 0.2s;
}
.mp-category-card:hover {
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
}
/* Category Header with Icon and Title on same line */
.mp-category-header {
display: flex;
align-items: center;
margin-bottom: 16px;
}
.mp-category-icon {
font-size: 24px;
margin-right: 12px;
}
.mp-category-title {
font-size: 1.25rem;
font-weight: 600;
margin: 0;
color: var(--color-primary);
}
.mp-category-list {
list-style: none;
padding: 0;
margin: 0;
}
.mp-category-list li {
padding: 8px 0;
border-bottom: 1px solid var(--border-color-base);
}
.mp-category-list li:last-child {
border-bottom: none;
margin-top: 10px;
font-weight: 500;
color: var(--color-primary);
}
/* Feature & Trending Grids */
.mp-featured-grid,
.mp-trending-grid,
.mp-paths-grid {
display: flex;
flex-wrap: wrap;
margin: 0 -12px;
padding: 20px 0;
}
.mp-featured-grid > *,
.mp-trending-grid > *,
.mp-paths-grid > * {
flex: 1 1 300px;
margin: 0 12px 24px;
min-width: 250px;
}
/* Community Section */
.mp-community-flex {
display: flex;
flex-wrap: wrap;
margin: 0 -12px;
}
.mp-community-card {
flex: 1 1 300px;
min-width: 250px;
background-color: var(--color-surface-1);
border-radius: 8px;
padding: 20px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
border: 1px solid var(--border-color-base);
margin: 0 12px 24px;
}
.mp-community-card h3 {
font-size: 1.1rem;
margin-top: 0;
margin-bottom: 16px;
padding-bottom: 10px;
border-bottom: 1px solid var(--border-color-base);
color: var(--color-primary);
}
.mp-community-card ul {
padding-left: 20px;
margin: 0;
}
.mp-community-card li {
margin-bottom: 8px;
}
/* Statistics Section */
.mp-statistics-container {
display: flex;
flex-wrap: wrap;
margin: 0 -12px;
}
.mp-stat-card {
background-color: var(--color-surface-1);
border-radius: 8px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
padding: 20px;
min-width: 140px;
text-align: center;
border: 1px solid var(--border-color-base);
flex: 1 1 140px;
margin: 0 12px 24px;
}
.mp-stat-number {
font-size: 1.8rem;
font-weight: 700;
color: var(--color-primary);
margin-bottom: 8px;
}
.mp-stat-label {
font-size: 0.95rem;
color: var(--color-base--subtle);
}
/* Fallback colors for non-supporting environments */
.mp-search-box,
.mp-category-card,
.mp-community-card,
.mp-stat-card {
background-color: #ffffff;
}
/* Dark mode fallback if variables don't work */
@media (prefers-color-scheme: dark) {
.mp-search-box,
.mp-category-card,
.mp-community-card,
.mp-stat-card {
background-color: #111827;
border-color: #374151;
}
.mp-category-list li {
border-color: #374151;
}
.mp-community-card h3 {
border-color: #374151;
}
.mp-stat-number {
color: #818cf8;
}
.mp-stat-label {
color: #9ca3af;
}
.mp-section-heading,
.mp-category-title,
.mp-category-list li:last-child,
.mp-community-card h3 {
color: #818cf8;
}
.mp-section-heading:after {
background: #818cf8;
}
}
/* Responsive Adjustments */
@media (max-width: 768px) {
.mp-category-card {
flex: 0 0 100%;
max-width: 100%;
}
#mp-welcome h1 {
font-size: 1.8rem;
}
.mp-section-heading {
font-size: 1.4rem;
}
}