Template:TutorialCard/styles.css: Difference between revisions
Template page
More actions
No edit summary  |
No edit summary  |
||
| (2 intermediate revisions by the same user not shown) | |||
| Line 7: | Line 7: | ||
.tutorial-card { | .tutorial-card { | ||
   width: |    width: 250px; /* Increased to fix squished text */ | ||
   background-color: var(--color-surface-1); |    background-color: var(--color-surface-1); | ||
   border: 1px solid; |    border: 1px solid; | ||
| Line 19: | Line 19: | ||
   box-sizing: border-box; |    box-sizing: border-box; | ||
   position: relative; |    position: relative; | ||
   text-align: left; |    text-align: left; | ||
   transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s; |    transition: box-shadow 0.2s, border-top-color 0.2s, border-right-color 0.2s, border-bottom-color 0.2s, border-left-color 0.2s, transform 0.2s; | ||
} | } | ||
| Line 31: | Line 30: | ||
   border-left-color: var(--wiki-primary); |    border-left-color: var(--wiki-primary); | ||
   transform: translateY(-2px); |    transform: translateY(-2px); | ||
} | |||
/* Sanitizer-Safe 2D Flip Logic */ | |||
.tutorial-card-inner { | |||
  width: 100%; | |||
  height: 100%; | |||
  display: flex; | |||
  flex-direction: column; | |||
} | |||
.tutorial-card-front { | |||
  display: block; | |||
  width: 100%; | |||
} | |||
.tutorial-card-back { | |||
  display: none; | |||
  width: 100%; | |||
  height: 100%; | |||
  padding: 16px; | |||
  box-sizing: border-box; | |||
  background-color: var(--color-surface-1); | |||
  color: var(--color-base); | |||
  flex-direction: column; | |||
} | |||
.tutorial-card-inner.is-flipped .tutorial-card-front { | |||
  display: none; | |||
} | |||
.tutorial-card-inner.is-flipped .tutorial-card-back { | |||
  display: flex; | |||
} | |||
.tutorial-card-back-header { | |||
  display: flex; | |||
  justify-content: space-between; | |||
  align-items: center; | |||
  border-bottom: 1px solid; | |||
  border-bottom-color: var(--border-color-base); | |||
  padding-bottom: 6px; | |||
  margin-bottom: 10px; | |||
} | |||
.tutorial-card-back-title { | |||
  font-weight: bold; | |||
  font-size: 0.95em; | |||
  color: var(--wiki-primary); | |||
} | |||
.tutorial-card-back-content { | |||
  font-size: 0.88em; | |||
  line-height: 1.5; | |||
  overflow-y: auto; | |||
} | |||
.tutorial-card-flip-btn { | |||
  background: none; | |||
  border: none; | |||
  color: var(--wiki-primary); | |||
  font-size: 0.85em; | |||
  font-weight: bold; | |||
  cursor: pointer; | |||
  padding: 0; | |||
  align-self: flex-end; | |||
  margin-top: 4px; | |||
  position: relative; | |||
  z-index: 30; | |||
} | |||
.tutorial-card-flip-btn:hover { | |||
  text-decoration: underline; | |||
} | } | ||
| Line 48: | Line 119: | ||
.tutorial-card-image img { | .tutorial-card-image img { | ||
   width: 100%; |    max-width: 100%; | ||
   height: 100%; |    max-height: 100%; | ||
   object-fit: |    object-fit: contain; | ||
   border-radius: 3px; |    border-radius: 3px; | ||
   display: block; |    display: block; | ||
| Line 107: | Line 178: | ||
   gap: 4px; |    gap: 4px; | ||
   margin-bottom: 6px; |    margin-bottom: 6px; | ||
  position: relative; | |||
  z-index: 20; | |||
} | } | ||
| Line 135: | Line 208: | ||
.tutorial-card-stats { | .tutorial-card-stats { | ||
  display: flex; | |||
  flex-direction: column; | |||
  align-items: flex-start; | |||
  gap: 3px; | |||
  margin-top: 6px; | |||
  padding-top: 8px; | |||
  border-top: 1px solid var(--border-color-base); | |||
   font-size: 0.78em; |    font-size: 0.78em; | ||
   color: var(--color-base--subtle); |    color: var(--color-base--subtle); | ||
   position: relative; | |||
   z-index: 20; | |||
 | |||
   position: | |||
   z-index: | |||
 | |||
} | } | ||
Latest revision as of 23:02, 2 April 2026
/* Template:TutorialCard/styles.css */
.tutorial-card-wrap {
display: inline-block;
vertical-align: top;
margin: 8px;
}
.tutorial-card {
width: 250px; /* Increased to fix squished text */
background-color: var(--color-surface-1);
border: 1px solid;
border-top-color: var(--border-color-base);
border-right-color: var(--border-color-base);
border-bottom-color: var(--border-color-base);
border-left-color: var(--border-color-base);
border-radius: 4px;
box-shadow: 0 1px 3px rgba(0,0,0,0.07);
overflow: hidden;
box-sizing: border-box;
position: relative;
text-align: left;
transition: box-shadow 0.2s, border-top-color 0.2s, border-right-color 0.2s, border-bottom-color 0.2s, border-left-color 0.2s, transform 0.2s;
}
.tutorial-card:hover {
box-shadow: 0 4px 16px rgba(0,0,0,0.2);
border-top-color: var(--wiki-primary);
border-right-color: var(--wiki-primary);
border-bottom-color: var(--wiki-primary);
border-left-color: var(--wiki-primary);
transform: translateY(-2px);
}
/* Sanitizer-Safe 2D Flip Logic */
.tutorial-card-inner {
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
}
.tutorial-card-front {
display: block;
width: 100%;
}
.tutorial-card-back {
display: none;
width: 100%;
height: 100%;
padding: 16px;
box-sizing: border-box;
background-color: var(--color-surface-1);
color: var(--color-base);
flex-direction: column;
}
.tutorial-card-inner.is-flipped .tutorial-card-front {
display: none;
}
.tutorial-card-inner.is-flipped .tutorial-card-back {
display: flex;
}
.tutorial-card-back-header {
display: flex;
justify-content: space-between;
align-items: center;
border-bottom: 1px solid;
border-bottom-color: var(--border-color-base);
padding-bottom: 6px;
margin-bottom: 10px;
}
.tutorial-card-back-title {
font-weight: bold;
font-size: 0.95em;
color: var(--wiki-primary);
}
.tutorial-card-back-content {
font-size: 0.88em;
line-height: 1.5;
overflow-y: auto;
}
.tutorial-card-flip-btn {
background: none;
border: none;
color: var(--wiki-primary);
font-size: 0.85em;
font-weight: bold;
cursor: pointer;
padding: 0;
align-self: flex-end;
margin-top: 4px;
position: relative;
z-index: 30;
}
.tutorial-card-flip-btn:hover {
text-decoration: underline;
}
.tutorial-card-image {
width: 100%;
height: 160px;
display: flex;
align-items: center;
justify-content: center;
background-color: var(--color-surface-2);
padding: 10px;
box-sizing: border-box;
overflow: hidden;
position: relative;
z-index: 0;
}
.tutorial-card-image img {
max-width: 100%;
max-height: 100%;
object-fit: contain;
border-radius: 3px;
display: block;
}
.tutorial-card-image-fallback {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
background-color: var(--color-surface-2);
border-radius: 3px;
border: 1px dashed;
border-top-color: var(--border-color-base);
border-right-color: var(--border-color-base);
border-bottom-color: var(--border-color-base);
border-left-color: var(--border-color-base);
}
.tutorial-card-body {
padding: 10px 12px 12px;
}
.tutorial-card-title {
font-weight: bold;
font-size: 0.95em;
line-height: 1.3;
margin-bottom: 8px;
display: block;
}
.tutorial-card-title a {
color: var(--color-base);
text-decoration: none;
display: block;
}
.tutorial-card-title a::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 10;
}
.tutorial-card:hover .tutorial-card-title a {
color: var(--wiki-primary);
}
.tutorial-card-meta {
display: flex;
flex-wrap: wrap;
gap: 4px;
margin-bottom: 6px;
position: relative;
z-index: 20;
}
.tutorial-card-tag {
display: inline-block;
background-color: var(--wiki-primary-subtle);
color: var(--wiki-primary);
font-size: 0.75em;
font-weight: bold;
padding: 2px 7px;
border-radius: 3px;
white-space: nowrap;
}
.tutorial-card-difficulty-beginner,
.tutorial-card-difficulty-intermediate,
.tutorial-card-difficulty-advanced {
display: inline-block;
font-size: 0.75em;
font-weight: bold;
padding: 2px 7px;
border-radius: 3px;
}
.tutorial-card-difficulty-beginner { background-color: rgba(40, 167, 69, 0.15); color: #28a745; }
.tutorial-card-difficulty-intermediate { background-color: rgba(255, 193, 7, 0.20); color: #b8860b; }
.tutorial-card-difficulty-advanced { background-color: rgba(220, 53, 69, 0.15); color: #dc3545; }
.tutorial-card-stats {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 3px;
margin-top: 6px;
padding-top: 8px;
border-top: 1px solid var(--border-color-base);
font-size: 0.78em;
color: var(--color-base--subtle);
position: relative;
z-index: 20;
}