Template:TutorialCard/styles.css: Difference between revisions
Template page
More actions
No edit summary  |
No edit summary |
||
| 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 33: | Line 32: | ||
} | } | ||
/* 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; | |||
  margin-left: auto; | |||
  position: relative; | |||
  z-index: 20; /* Keeps button clickable over title overlay */ | |||
} | |||
.tutorial-card-flip-btn:hover { | |||
  text-decoration: underline; | |||
} | |||
/* Fixed Image Clipping */ | |||
.tutorial-card-image { | .tutorial-card-image { | ||
   width: 100%; |    width: 100%; | ||
| 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: 1; | |||
} | } | ||
| Line 139: | Line 212: | ||
   margin-top: 4px; |    margin-top: 4px; | ||
   display: flex; |    display: flex; | ||
  align-items: center; | |||
   gap: 10px; |    gap: 10px; | ||
   position: relative; | |||
 |    z-index: 1; | ||
   position: | |||
   z-index | |||
 | |||
} | } | ||
Revision as of 03:00, 2 April 2026
/* Template:TutorialCard/styles.css */
.tutorial-card-wrap {
display: inline-block;
vertical-align: top;
margin: 8px;
}
.tutorial-card {
width: 220px;
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;
margin-left: auto;
position: relative;
z-index: 20; /* Keeps button clickable over title overlay */
}
.tutorial-card-flip-btn:hover {
text-decoration: underline;
}
/* Fixed Image Clipping */
.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: 1;
}
.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 {
font-size: 0.78em;
color: var(--color-base--subtle);
margin-top: 4px;
display: flex;
align-items: center;
gap: 10px;
position: relative;
z-index: 1;
}