/* School Values & Activities styles migrated from React */
.values-activities-wrapper { display: flex; flex-wrap: wrap; justify-content: center; align-items: stretch; gap: 30px; padding: 40px 20px; }
.flip-card { background: transparent; perspective: 1200px; width: 330px; height: 420px; min-width: 0; display: flex; align-items: stretch; }
.sva-flip-card-inner { position: relative; width: 100%; height: 100%; transition: transform 0.7s cubic-bezier(0.68, -0.25, 0.27, 1.25); transform-style: preserve-3d; border-radius: 20px; box-shadow: 0 12px 28px rgba(0,0,0,0.19); }
.flip-card:hover .sva-flip-card-inner, .flip-card:focus-within .sva-flip-card-inner { transform: rotateY(180deg) scale(1.04); }
.flip-card-face { position: absolute; width: 100%; height: 100%; backface-visibility: hidden; border-radius: 20px; border: 3px solid #ffd900; background-clip: padding-box; display: flex; align-items: center; justify-content: center; padding: 0; box-sizing: border-box; overflow: hidden; }
.center-contents { width: 100%; padding: 35px 22px; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.flip-card-back { transform: rotateY(180deg); box-shadow: inset 0 0 30px rgba(255,255,255,0.09); }
.contents-scroll { padding: 28px 15px 18px 15px; width: 100%; height: 100%; overflow-y: auto; display: flex; flex-direction: column; justify-content: flex-start; align-items: center; }
.moral-card { background: linear-gradient(135deg, #314755, #26a0da); color: #fff; }
.cultural-card { background: linear-gradient(135deg, #9b59b6, #8e44ad); color: #f0e6ff; }
.sports-card { background: linear-gradient(135deg, #e67e22, #d35400); color: #fff8f0; }
.moral-title, .cultural-title, .sports-title { font-size: 1.6rem; font-weight: 800; text-transform: uppercase; text-align: center; margin-bottom: 10px; letter-spacing: 0.03em; }
.moral-quote, .cultural-quote, .sports-quote { font-size: 1.07rem; font-style: italic; font-weight: 500; margin: 0; color: #eaf6ff; text-align: center; }
.cultural-quote { color: #d6c8ff; }
.sports-quote  { color: #ffe2c4; }
.moral-desc, .cultural-desc, .sports-desc, .sports-conclusion { font-size: 1rem; line-height: 1.5; text-align: center; margin-bottom: 17px; }
.sports-conclusion { color: #ffe6d1; margin-top: 8px; }
.moral-icons, .cultural-icons, .sports-icons { display: flex; justify-content: center; gap: 22px; margin: 17px 0 12px 0; }
.moral-icon    { font-size: 2rem; color: #ffd166; transition: transform 0.3s, color 0.3s; }
.cultural-icon { font-size: 2rem; color: #c0a9e9; transition: transform 0.3s, color 0.3s; }
.sport-icon    { font-size: 2rem; color: #fdd32a;  transition: transform 0.3s, color 0.3s; }
.moral-icon:hover    { transform: scale(1.19); color: #ffe9a6; }
.cultural-icon:hover { transform: scale(1.19); color: #f9f5ff; }
.sport-icon:hover    { transform: scale(1.19); color: #fff199; }
.sports-stats { text-align: left; margin-bottom: 10px; width: 100%; color: #fffae5; }
.sports-stats p { margin: 3px 0 3px 0; font-size: 0.98rem; display: flex; align-items: center; }
.sports-highlight { display: inline-flex; align-items: center; font-size: 1.15em; color: #fdc432; margin-right: 9px; }
.stats-detail { color: #ffbb6a; margin-left: 32px; font-weight: 500; }
@media (max-width: 1100px) { .values-activities-wrapper { gap: 18px; } .flip-card { width: 290px; height: 390px; } }
@media (max-width: 910px) { .values-activities-wrapper { align-items: center; } }
@media (max-width: 400px) { .flip-card { width: 98vw; min-width: 0; } }
