/* ==============================================
   about.css  —  place in: css/about.css
   Load AFTER students.css (inherits all CSS vars)
   ============================================== */

/* ══ ACTIVE NAV LINK ═══════════════════════════ */
a.nav-active[href="about.html"] {
    color: #c084fc !important;
}

/* ══ HERO ══════════════════════════════════════ */
.about-hero {
    position: relative; z-index: 1;
    min-height: 72vh;
    display: flex; align-items: center; justify-content: center;
    padding: 10rem 2rem 6rem;
    text-align: center;
    overflow: hidden;
}
.about-hero-glow {
    position: absolute; top: 0; left: 50%; transform: translateX(-50%);
    width: 800px; height: 500px; border-radius: 50%;
    background: radial-gradient(ellipse, rgba(138,43,226,.12) 0%, rgba(42,250,223,.06) 50%, transparent 75%);
    pointer-events: none; filter: blur(20px);
}
.about-hero-inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }

.about-hero-eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: .82rem; font-weight: 600; letter-spacing: 2px;
    text-transform: uppercase; color: var(--accent-teal);
    margin-bottom: 1.8rem;
    animation: fadeUp .8s ease both;
}
.eyebrow-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--accent-teal); box-shadow: 0 0 10px var(--accent-teal);
    animation: pulse 2s ease infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }

.about-hero-title {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800; line-height: 1.1;
    color: var(--text-primary);
    margin-bottom: 1.4rem;
    animation: fadeUp .8s ease .1s both;
}
.about-hero-accent {
    background: var(--grad-main);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.about-hero-desc {
    font-size: 1.08rem; color: var(--text-secondary);
    line-height: 1.75; max-width: 600px; margin: 0 auto 2.5rem;
    animation: fadeUp .8s ease .2s both;
}
.about-hero-stats {
    display: flex; align-items: center; justify-content: center;
    gap: 2rem; flex-wrap: wrap;
    animation: fadeUp .8s ease .3s both;
}
.about-stat-item { text-align: center; }
.about-stat-num {
    font-family: 'Poppins', sans-serif; font-size: 2.2rem; font-weight: 800;
    background: var(--grad-main); -webkit-background-clip: text;
    -webkit-text-fill-color: transparent; background-clip: text; display: block;
}
.about-stat-lbl { font-size: .72rem; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }
.about-stat-div { width: 1px; height: 40px; background: rgba(42,250,223,.15); }

/* ══ SHARED LAYOUT ════════════════════════════ */
.about-container {
    max-width: 1200px; margin: 0 auto; padding: 0 2rem;
}
.about-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .78rem; font-weight: 700; letter-spacing: 2.5px;
    text-transform: uppercase; color: var(--accent-teal);
    margin-bottom: .9rem;
}
.about-section-heading {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 800; color: var(--text-primary);
    line-height: 1.2; margin-bottom: 1.2rem;
}
.about-section-body {
    font-size: 1rem; color: var(--text-secondary);
    line-height: 1.8; margin-bottom: 1.1rem; max-width: 560px;
}

/* ══ STORY SECTION ════════════════════════════ */
.about-story {
    position: relative; z-index: 1;
    padding: 7rem 2rem;
    background: rgba(17,34,64,.4);
    border-top: 1px solid rgba(42,250,223,.07);
    border-bottom: 1px solid rgba(42,250,223,.07);
}
.about-story-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: start;
}
.about-story-cards {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
}
.story-card {
    background: rgba(22,33,62,.7);
    border: 1px solid rgba(42,250,223,.1);
    border-radius: var(--r-lg); padding: 1.4rem;
    backdrop-filter: blur(10px); transition: var(--ease);
    position: relative; overflow: hidden;
    opacity: 0; transform: translateY(24px);
}
.story-card::before {
    content: ''; position: absolute; top: 0; left: 0;
    width: 100%; height: 3px;
}
.story-card--teal::before  { background: var(--grad-main); }
.story-card--purple::before{ background: linear-gradient(135deg,#8a2be2,#b06aff); }
.story-card--blue::before  { background: var(--grad-blue); }
.story-card--gold::before  { background: var(--grad-gold); }
.story-card:hover { transform: translateY(-5px) !important; border-color: rgba(42,250,223,.25); box-shadow: var(--glow); }
.story-card--purple:hover  { border-color: rgba(138,43,226,.3); box-shadow: 0 0 22px rgba(138,43,226,.2); }
.story-card--blue:hover    { border-color: rgba(79,195,247,.3);  box-shadow: 0 0 22px rgba(79,195,247,.2); }
.story-card--gold:hover    { border-color: rgba(255,215,0,.3);   box-shadow: 0 0 22px rgba(255,215,0,.2); }
.story-card-icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: rgba(42,250,223,.1); border: 1px solid rgba(42,250,223,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; color: var(--accent-teal);
    margin-bottom: .9rem;
}
.story-card--purple .story-card-icon { background:rgba(138,43,226,.1);border-color:rgba(138,43,226,.25);color:#b06aff; }
.story-card--blue   .story-card-icon { background:rgba(79,195,247,.1); border-color:rgba(79,195,247,.25); color:var(--accent-blue); }
.story-card--gold   .story-card-icon { background:rgba(255,215,0,.1);  border-color:rgba(255,215,0,.25);  color:var(--accent-gold); }
.story-card h3 {
    font-family: 'Poppins', sans-serif; font-size: .98rem;
    font-weight: 700; color: var(--text-primary); margin-bottom: .5rem;
}
.story-card p { font-size: .82rem; color: var(--text-secondary); line-height: 1.65; }

/* ══ FEATURES PILLS ═══════════════════════════ */
.about-features-strip {
    position: relative; z-index: 1;
    padding: 6rem 2rem;
}
.features-pills-grid {
    display: flex; flex-wrap: wrap; gap: .7rem; justify-content: center;
}
.fpill {
    display: inline-flex; align-items: center; gap: 8px;
    padding: .55rem 1.2rem; border-radius: 30px;
    font-size: .85rem; font-weight: 600;
    border: 1px solid; backdrop-filter: blur(8px);
    transition: var(--ease);
    opacity: 0; transform: translateY(16px);
    cursor: default;
}
.fpill:hover { transform: translateY(-3px) scale(1.04) !important; }
.fpill--teal   { background: rgba(42,250,223,.08);  border-color: rgba(42,250,223,.25);  color: var(--accent-teal); }
.fpill--purple { background: rgba(138,43,226,.08);  border-color: rgba(138,43,226,.25);  color: #b06aff; }
.fpill--blue   { background: rgba(79,195,247,.08);  border-color: rgba(79,195,247,.25);  color: var(--accent-blue); }
.fpill--amber  { background: rgba(255,154,60,.08);  border-color: rgba(255,154,60,.25);  color: var(--accent-amber); }
.fpill--pink   { background: rgba(255,46,99,.08);   border-color: rgba(255,46,99,.25);   color: #ff6b8a; }
.fpill--gold   { background: rgba(255,215,0,.08);   border-color: rgba(255,215,0,.25);   color: var(--accent-gold); }
.fpill--red    { background: rgba(255,68,68,.08);   border-color: rgba(255,68,68,.25);   color: #ff6b6b; }

/* ══ TEAM SECTION ══════════════════════════════ */
.about-team {
    position: relative; z-index: 1;
    padding: 6rem 2rem;
    background: rgba(10,20,50,.5);
    border-top: 1px solid rgba(42,250,223,.08);
    border-bottom: 1px solid rgba(42,250,223,.08);
}
.team-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 2rem; align-items: start;
}

/* ── Team Card ─────────────────────────── */
.team-card {
    background: rgba(22,33,62,.8);
    border: 1px solid rgba(42,250,223,.15);
    border-radius: 28px; overflow: hidden;
    backdrop-filter: blur(16px);
    transition: var(--ease);
    position: relative;
    opacity: 0; transform: translateY(32px);
}
.team-card--leader  { border-color: rgba(42,250,223,.25); }
.team-card--designer{ border-color: rgba(138,43,226,.25); }
.team-card:hover { transform: translateY(-6px) !important; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
.team-card--leader:hover  { box-shadow: 0 20px 60px rgba(42,250,223,.12); }
.team-card--designer:hover{ box-shadow: 0 20px 60px rgba(138,43,226,.12); }

.team-card-top-accent {
    height: 4px; background: var(--grad-main); width: 100%;
}
.team-card-top-accent--designer {
    background: linear-gradient(135deg, #8a2be2, #b06aff);
}

.team-badge-wrap { padding: 1.2rem 1.5rem .5rem; }
.team-role-badge {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: .75rem; font-weight: 700; letter-spacing: .5px;
    text-transform: uppercase; padding: .4rem 1rem; border-radius: 30px;
}
.badge--leader {
    background: rgba(42,250,223,.12); color: var(--accent-teal);
    border: 1px solid rgba(42,250,223,.3);
}
.badge--designer {
    background: rgba(138,43,226,.12); color: #b06aff;
    border: 1px solid rgba(138,43,226,.3);
}

/* Photo */
.team-photo-wrap {
    display: flex; justify-content: center;
    padding: 1.5rem 1.5rem 1rem;
    position: relative;
}
.team-photo-ring {
    width: 160px; height: 160px; border-radius: 50%;
    padding: 4px; position: relative; z-index: 1;
    background: var(--grad-main);
    flex-shrink: 0;
}
.team-photo-ring--designer {
    background: linear-gradient(135deg, #8a2be2, #b06aff);
}
.team-photo {
    width: 100%; height: 100%; border-radius: 50%;
    object-fit: cover; object-position: center top;
    display: block;
    border: 3px solid rgba(10,25,47,.8);
}
.team-photo-glow {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 200px; height: 200px; border-radius: 50%;
    pointer-events: none; z-index: 0;
    filter: blur(30px); opacity: .25;
}
.team-photo-glow--leader   { background: var(--accent-teal); }
.team-photo-glow--designer { background: #8a2be2; }

/* Info */
.team-info { padding: .5rem 1.5rem 1.8rem; }
.team-name {
    font-family: 'Poppins', sans-serif; font-size: 1.25rem;
    font-weight: 800; color: var(--text-primary);
    text-align: center; margin-bottom: .35rem;
}
.team-roll {
    text-align: center; font-size: .8rem;
    color: var(--accent-teal); margin-bottom: 1rem;
    display: flex; align-items: center; justify-content: center; gap: 6px;
}
.team-card--designer .team-roll { color: #b06aff; }
.team-desc {
    font-size: .88rem; color: var(--text-secondary);
    line-height: 1.72; margin-bottom: 1.2rem;
}
.team-tech-row {
    display: flex; flex-wrap: wrap; gap: .4rem;
    margin-bottom: 1.2rem;
}
.tech-chip {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: .72rem; font-weight: 700; padding: 3px 10px;
    border-radius: 20px;
    background: rgba(42,250,223,.1); color: var(--accent-teal);
    border: 1px solid rgba(42,250,223,.25);
}
.tech-chip--purple {
    background: rgba(138,43,226,.1); color: #b06aff;
    border-color: rgba(138,43,226,.3);
}
.team-contributions { display: flex; flex-direction: column; gap: .4rem; }
.contrib-item {
    display: flex; align-items: center; gap: 8px;
    font-size: .82rem; color: var(--text-secondary);
}
.contrib-item i { color: var(--accent-teal); font-size: .82rem; }
.contrib-item--purple i { color: #b06aff; }

/* ══ TECH STACK ════════════════════════════════ */
.about-tech-stack {
    position: relative; z-index: 1;
    padding: 6rem 2rem;
}
.tech-stack-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}
.tech-stack-item {
    background: rgba(22,33,62,.7);
    border: 1px solid rgba(42,250,223,.1);
    border-radius: var(--r-lg); padding: 1.8rem 1.4rem;
    text-align: center; transition: var(--ease);
    backdrop-filter: blur(10px);
    opacity: 0; transform: translateY(20px);
}
.tech-stack-item:hover { transform: translateY(-5px) !important; border-color: rgba(42,250,223,.28); box-shadow: var(--glow); }
.tech-stack-icon { font-size: 2.5rem; margin-bottom: .8rem; }
.tech-stack-name {
    font-family: 'Poppins', sans-serif; font-size: 1rem;
    font-weight: 700; color: var(--text-primary); margin-bottom: .4rem;
}
.tech-stack-desc { font-size: .8rem; color: var(--text-secondary); line-height: 1.6; }

/* ══ MENTOR ═════════════════════════════════════ */
.about-mentor {
    position: relative; z-index: 1;
    padding: 6rem 2rem;
    background: rgba(10,20,50,.5);
    border-top: 1px solid rgba(42,250,223,.07);
    border-bottom: 1px solid rgba(42,250,223,.07);
}
.mentor-card {
    background: rgba(22,33,62,.85);
    border: 1px solid rgba(255,215,0,.2);
    border-radius: 28px; padding: 3rem;
    backdrop-filter: blur(16px);
    position: relative; overflow: hidden;
    display: flex; gap: 3rem; align-items: flex-start;
    opacity: 0; transform: translateY(32px);
    transition: opacity .7s ease, transform .7s ease;
}
.mentor-card.revealed { opacity: 1; transform: translateY(0); }
.mentor-card:hover { border-color: rgba(255,215,0,.35); box-shadow: 0 0 40px rgba(255,215,0,.08); }
.mentor-glow {
    position: absolute; top: -80px; right: -80px;
    width: 300px; height: 300px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,215,0,.08) 0%, transparent 70%);
    pointer-events: none;
}
.mentor-icon-wrap { position: relative; flex-shrink: 0; }
.mentor-icon {
    width: 90px; height: 90px; border-radius: 50%;
    background: linear-gradient(135deg, rgba(255,215,0,.2), rgba(255,154,60,.15));
    border: 2px solid rgba(255,215,0,.4);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--accent-gold);
    position: relative; z-index: 1;
    box-shadow: 0 0 30px rgba(255,215,0,.2);
}
.mentor-ring {
    position: absolute; inset: -8px; border-radius: 50%;
    border: 2px dashed rgba(255,215,0,.2);
    animation: mentorSpin 12s linear infinite;
}
@keyframes mentorSpin { to { transform: rotate(360deg); } }
.mentor-content { flex: 1; min-width: 0; }
.mentor-eyebrow { color: var(--accent-gold); }
.mentor-name {
    font-family: 'Poppins', sans-serif; font-size: 1.7rem;
    font-weight: 800; color: var(--text-primary); margin-bottom: .3rem;
}
.mentor-title {
    font-size: .88rem; color: var(--accent-amber);
    font-weight: 600; margin-bottom: 1.2rem;
}
.mentor-divider {
    height: 1px; background: rgba(255,215,0,.15);
    margin-bottom: 1.2rem;
}
.mentor-message {
    font-size: .95rem; color: var(--text-secondary);
    line-height: 1.8; margin-bottom: 1rem;
}
.mentor-thanks-badge {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .8rem; font-weight: 700; padding: .5rem 1.2rem;
    border-radius: 30px;
    background: rgba(255,215,0,.1); color: var(--accent-gold);
    border: 1px solid rgba(255,215,0,.3);
    margin-top: .5rem;
}
.mentor-thanks-badge i { color: #ff6b6b; }

/* ══ HOURS SECTION ════════════════════════════ */
.about-hours {
    position: relative; z-index: 1;
    padding: 6rem 2rem;
}
.hours-inner {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: center;
}
.hours-stats-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.hours-stat {
    background: rgba(22,33,62,.7);
    border: 1px solid rgba(42,250,223,.12);
    border-radius: var(--r-lg); padding: 1.5rem 1rem;
    text-align: center; transition: var(--ease);
    opacity: 0; transform: translateY(20px);
}
.hours-stat:hover { transform: translateY(-4px) !important; border-color: rgba(42,250,223,.28); box-shadow: var(--glow); }
.hours-stat-icon { font-size: 1.5rem; color: var(--accent-teal); margin-bottom: .7rem; }
.hours-stat-val {
    font-family: 'Poppins', sans-serif; font-size: 1.5rem;
    font-weight: 800; background: var(--grad-main);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    display: block; margin-bottom: .2rem;
}
.hours-stat-lbl { font-size: .7rem; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }

/* ══ ANIMATIONS ════════════════════════════════ */
@keyframes fadeUp   { from{opacity:0;transform:translateY(30px);}  to{opacity:1;transform:translateY(0);} }
@keyframes fadeLeft { from{opacity:0;transform:translateX(30px);}  to{opacity:1;transform:translateX(0);} }

/* ══ RESPONSIVE ════════════════════════════════ */
@media (max-width: 1024px) {
    .about-story-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .about-section-body { max-width: 100%; }
    .team-grid { grid-template-columns: 1fr; max-width: 560px; margin: 0 auto; }
    .tech-stack-grid { grid-template-columns: repeat(2, 1fr); }
    .hours-inner { grid-template-columns: 1fr; gap: 2.5rem; }
    .hours-stats-grid { grid-template-columns: repeat(4, 1fr); }
    .mentor-card { flex-direction: column; align-items: center; text-align: center; }
    .mentor-eyebrow { justify-content: center; }
}
@media (max-width: 768px) {
    .about-story-cards { grid-template-columns: 1fr; }
    .tech-stack-grid { grid-template-columns: 1fr 1fr; }
    .hours-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .about-hero-stats { gap: 1.2rem; }
    .about-stat-div { display: none; }
    .mentor-card { padding: 2rem 1.4rem; }
}
@media (max-width: 480px) {
    .about-hero { padding: 8rem 1rem 4rem; }
    .tech-stack-grid { grid-template-columns: 1fr; }
    .hours-stats-grid { grid-template-columns: 1fr 1fr; }
    .team-photo-ring { width: 130px; height: 130px; }
    .team-info { padding: .5rem 1.2rem 1.5rem; }
}