/* ============================================================
   ABOUT PAGE — THE SHARP LENS
   Extends main.css with about-specific components
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */
.about-hero {
    position: relative; overflow: hidden;
    min-height: 420px; display: flex; align-items: center;
}
.about-hero__bg {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    width: 100%; height: 100%; object-fit: cover;
    filter: brightness(0.3);
}
.about-hero__content {
    position: relative; z-index: 2;
    max-width: 680px; color: #fff;
    padding: var(--space-4xl) 0;
}
.about-hero__label {
    display: inline-block; background: var(--accent-red); color: #fff;
    font-size: 0.6rem; font-weight: 700; letter-spacing: 0.16em;
    text-transform: uppercase; padding: 4px 12px; border-radius: 2px;
    margin-bottom: var(--space-lg);
}
.about-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 800; line-height: 1.15;
    margin-bottom: var(--space-lg);
}
.about-hero__subtitle {
    font-size: 1.1rem; opacity: 0.8;
    line-height: 1.65; max-width: 560px;
}

/* ============================================================
   MISSION & VALUES
   ============================================================ */
.mission-section { padding: var(--space-4xl) 0; }
.mission-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl); align-items: center;
}
.mission__label {
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--accent-red);
    margin-bottom: var(--space-md);
}
.mission__title {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 2.5vw, 2.2rem);
    font-weight: 700; line-height: 1.2;
    margin-bottom: var(--space-lg);
}
.mission__text {
    font-size: 1.05rem; color: var(--ink-secondary);
    line-height: 1.75; margin-bottom: var(--space-lg);
}
.mission__quote {
    padding: var(--space-lg) var(--space-xl);
    border-left: 3px solid var(--accent-red);
    background: var(--paper-warm);
    font-family: var(--font-display);
    font-size: 1.1rem; font-style: italic;
    line-height: 1.55; color: var(--ink);
    border-radius: 0 4px 4px 0;
}
.mission__quote-attr {
    margin-top: var(--space-lg); padding-left: var(--space-xl);
}
.mission__quote-name { font-weight: 700; font-size: 0.92rem; }
.mission__quote-org { font-size: 0.78rem; color: var(--ink-muted); }

/* Values Cards */
.values-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: var(--space-xl); margin-top: var(--space-3xl);
}
.value-card {
    padding: var(--space-xl);
    border: 1px solid var(--border); border-radius: 6px;
    transition: transform 0.3s, box-shadow 0.3s;
}
.value-card:hover {
    transform: translateY(-4px); box-shadow: var(--shadow-lg);
}
.value-card__icon {
    width: 48px; height: 48px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: var(--space-lg);
}
.value-card__icon--red { background: rgba(196,30,58,0.08); color: var(--accent-red); }
.value-card__icon--blue { background: rgba(26,82,118,0.08); color: var(--accent-blue); }
.value-card__icon--gold { background: rgba(196,151,59,0.08); color: var(--accent-gold); }
.value-card__icon--green { background: rgba(30,122,77,0.08); color: var(--accent-green); }
.value-card__icon--purple { background: rgba(109,40,217,0.08); color: var(--accent-purple); }
.value-card__icon--ink { background: rgba(26,26,26,0.06); color: var(--ink); }
.value-card__title {
    font-family: var(--font-display);
    font-size: 1.1rem; font-weight: 700;
    margin-bottom: var(--space-sm);
}
.value-card__desc {
    font-size: 0.88rem; color: var(--ink-secondary); line-height: 1.6;
}

/* ============================================================
   STATS BAR
   ============================================================ */
.about-stats-bar {
    background: var(--ink); color: var(--paper);
    padding: var(--space-3xl) 0;
}
.about-stats-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: var(--space-xl); text-align: center;
}
.about-stat__number {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800; line-height: 1;
    margin-bottom: var(--space-sm);
    color: var(--accent-gold);
}
.about-stat__label {
    font-size: 0.82rem; opacity: 0.6; letter-spacing: 0.04em;
}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline-section {
    padding: var(--space-4xl) 0;
    background: var(--paper-warm);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.about-section-label {
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--accent-red);
    text-align: center; margin-bottom: var(--space-sm);
}
.about-section-title {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 2.5vw, 2.2rem);
    font-weight: 700; text-align: center;
    margin-bottom: var(--space-3xl);
}
.timeline {
    position: relative; max-width: 800px; margin: 0 auto;
    padding-left: var(--space-2xl);
}
.timeline::before {
    content: ''; position: absolute;
    left: 8px; top: 0; bottom: 0;
    width: 2px; background: var(--border);
}
.timeline-item {
    position: relative;
    padding-bottom: var(--space-2xl);
    padding-left: var(--space-xl);
}
.timeline-item:last-child { padding-bottom: 0; }
.timeline-item__dot {
    position: absolute; left: calc(-1 * var(--space-2xl) + 1px);
    top: 4px; width: 16px; height: 16px;
    background: var(--accent-red); border-radius: 50%;
    border: 3px solid var(--paper-warm);
}
.timeline-item__year {
    font-family: var(--font-display);
    font-size: 1.4rem; font-weight: 800;
    color: var(--accent-red); margin-bottom: var(--space-xs);
}
.timeline-item__title {
    font-family: var(--font-display);
    font-size: 1.1rem; font-weight: 700;
    margin-bottom: var(--space-sm);
}
.timeline-item__desc {
    font-size: 0.92rem; color: var(--ink-secondary); line-height: 1.6;
}

/* ============================================================
   TEAM
   ============================================================ */
.team-section { padding: var(--space-4xl) 0; }
.team-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: var(--space-xl);
}
.team-card { text-align: center; }
.team-card__img-wrap {
    width: 140px; height: 140px; border-radius: 50%;
    overflow: hidden; margin: 0 auto var(--space-lg);
    border: 3px solid var(--border); transition: border-color 0.3s;
}
.team-card:hover .team-card__img-wrap { border-color: var(--accent-red); }
.team-card__img { width: 100%; height: 100%; object-fit: cover; }
.team-card__name {
    font-family: var(--font-display);
    font-size: 1.05rem; font-weight: 700; margin-bottom: 2px;
}
.team-card__role {
    font-size: 0.78rem; color: var(--accent-red);
    font-weight: 600; letter-spacing: 0.04em;
    margin-bottom: var(--space-sm);
}
.team-card__bio {
    font-size: 0.82rem; color: var(--ink-muted); line-height: 1.5;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.about-cta-section {
    padding: var(--space-4xl) 0;
    background: var(--ink); color: var(--paper);
    position: relative; overflow: hidden;
}
.about-cta-section::before {
    content: ''; position: absolute;
    top: -100px; right: -100px;
    width: 350px; height: 350px;
    background: var(--accent-red); border-radius: 50%; opacity: 0.06;
}
.about-cta-section::after {
    content: ''; position: absolute;
    bottom: -80px; left: -80px;
    width: 250px; height: 250px;
    background: var(--accent-gold); border-radius: 50%; opacity: 0.04;
}
.cta-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl); align-items: center;
    position: relative; z-index: 1;
}
.cta__label {
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--accent-gold);
    margin-bottom: var(--space-md);
}
.cta__title {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 700; line-height: 1.2;
    margin-bottom: var(--space-lg);
}
.cta__text {
    font-size: 0.95rem; opacity: 0.7;
    line-height: 1.65; margin-bottom: var(--space-xl);
}
.cta__form { display: flex; gap: var(--space-sm); }
.cta__input {
    flex: 1; background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    padding: 12px 16px; border-radius: 4px;
    color: #fff; font-family: var(--font-body);
    font-size: 0.9rem; outline: none; transition: border-color 0.2s;
}
.cta__input::placeholder { color: rgba(255,255,255,0.35); }
.cta__input:focus { border-color: var(--accent-red); }
.cta__btn {
    background: var(--accent-red); color: #fff;
    padding: 12px 24px; border-radius: 4px;
    font-weight: 700; font-size: 0.82rem;
    letter-spacing: 0.06em; text-transform: uppercase;
    transition: background 0.2s; white-space: nowrap;
}
.cta__btn:hover { background: var(--accent-red-hover); }

.cta-contact { position: relative; z-index: 1; }
.cta-contact__item {
    display: flex; align-items: flex-start;
    gap: var(--space-md); margin-bottom: var(--space-xl);
}
.cta-contact__item:last-child { margin-bottom: 0; }
.cta-contact__icon {
    width: 42px; height: 42px; border-radius: 50%;
    background: rgba(255,255,255,0.06);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; color: var(--accent-gold);
}
.cta-contact__label {
    font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.08em; text-transform: uppercase;
    opacity: 0.5; margin-bottom: 2px;
}
.cta-contact__value { font-size: 1rem; font-weight: 500; }
.cta-contact__value a { color: var(--accent-gold); transition: opacity 0.2s; }
.cta-contact__value a:hover { opacity: 0.7; }

/* ============================================================
   ABOUT RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
    .mission-grid { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: repeat(2, 1fr); }
    .team-grid { grid-template-columns: repeat(2, 1fr); }
    .cta-grid { grid-template-columns: 1fr; }
    .about-stats-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-xl); }
}
@media (max-width: 768px) {
    .about-hero { min-height: 320px; }
    .about-hero__title { font-size: 1.8rem; }
    .values-grid { grid-template-columns: 1fr; }
    .team-grid { grid-template-columns: 1fr 1fr; }
    .about-stats-grid { grid-template-columns: 1fr 1fr; }
    .cta__form { flex-direction: column; }
}
@media (max-width: 480px) {
    .team-grid { grid-template-columns: 1fr; }
    .about-stats-grid { grid-template-columns: 1fr; }
}
@media print {
    .about-stats-bar, .about-cta-section { display: none !important; }
}
