﻿/* -- Vision Page: Founder Spotlight -- */
.vision-founder-section {
    background: linear-gradient(180deg, #0d0d16 0%, #0a0a14 100%);
    padding: clamp(60px, 8vw, 100px) 40px clamp(60px, 8vw, 100px) calc(var(--sidebar, 130px) + 40px);
}
.vision-founder-inner {
    max-width: 1200px; margin: 0 auto;
    display: grid; grid-template-columns: 340px 1fr;
    gap: clamp(40px, 6vw, 80px); align-items: center;
}
@media (max-width: 980px) {
    .vision-founder-section { padding-left: calc(var(--sidebar, 84px) + 24px); padding-right: 24px; }
}
@media (max-width: 900px) {
    .vision-founder-inner { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .vision-founder-section { padding-left: calc(var(--sidebar, 52px) + 16px); padding-right: 16px; }
}
.vision-founder-photo-col { display: flex; flex-direction: column; align-items: center; gap: 24px; }
.vision-founder-frame { position: relative; width: clamp(160px, 20vw, 240px); height: clamp(160px, 20vw, 240px); cursor: pointer; border-radius: 50%;
    /* Instagram-like gradient ring */
    background: conic-gradient(#f09433, #e6683c, #dc2743, #cc2366, #bc1888, #f09433);
    padding: 6px; display: inline-block;
}
.vision-founder-frame img {
    width: 100%; height: 100%; border-radius: 50%; box-sizing: border-box;
    object-fit: contain; object-position: center center; /* show more of the image */
    display: block; position: relative; z-index: 2; background: #0f1014;
    box-shadow: 0 8px 26px rgba(0,0,0,.48), inset 0 0 0 3px rgba(17,18,24,.35);
    transition: transform .3s ease, box-shadow .3s ease;
}
.vision-founder-frame:hover img {
    transform: scale(1.04);
    box-shadow: 0 20px 60px rgba(0,0,0,.75), 0 0 0 5px rgba(255,215,0,.5);
}
.vision-founder-ring {
    position: absolute; inset: -10px; border-radius: 50%;
    border: 2px dashed rgba(255,215,0,.28); z-index: 1;
    animation: vfRingRotate 14s linear infinite;
}
@keyframes vfRingRotate { to { transform: rotate(360deg); } }

.vision-divider {
    height: 4px;
    background: linear-gradient(90deg, rgba(212,175,55,0.98), rgba(255,215,115,0.9));
    box-shadow: 0 2px 6px rgba(212,175,55,0.08);
    border-radius: 2px;
    margin: 1.1rem 0;
    opacity: 0.95;
}

.vision-divider.vd-sm { width: 18%; margin-left: 0; }
.vision-divider.vd-md { width: 36%; margin-left: 0; }
.vision-divider.vd-lg { width: 58%; margin-left: 0; }

@media (max-width: 600px) {
    .vision-divider { height: 3px; margin: .9rem 0; }
}
.vision-founder-badge { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.vision-founder-badge img { filter: invert(1) brightness(1.2); opacity: .85; pointer-events: none; }
.vision-founder-badge span { font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--primary, #FFD700); }
.vision-founder-heading {
    font-family: var(--font-heading, 'Montserrat', sans-serif);
    font-size: clamp(28px, 4vw, 44px); font-weight: 800; text-transform: uppercase; letter-spacing: 2px;
    margin: 18px 0 24px;
    background: linear-gradient(135deg, #fff 30%, var(--primary, #FFD700) 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.vision-founder-para { font-size: clamp(16px, 1.4vw, 20px); line-height: 1.9; color: rgba(255,255,255,.82); margin-bottom: 18px; }
.vision-founder-quote {
    margin: 28px 0 0; padding: 22px 28px;
    border-left: 4px solid var(--primary, #FFD700);
    background: rgba(255,215,0,.06); border-radius: 0 14px 14px 0;
    font-size: clamp(16px, 1.6vw, 22px); font-style: italic; font-weight: 700; color: #f1c27d; line-height: 1.7;
}

/* ── Signature Quote Section ─────────────────────────────────────────────── */
.vision-quote-section {
    background: linear-gradient(135deg, rgba(10,10,28,.98) 0%, rgba(15,15,35,.98) 100%);
    border-top: 1px solid rgba(255,215,0,.1);
    border-bottom: 1px solid rgba(255,215,0,.1);
    padding: clamp(60px, 8vw, 100px) 40px clamp(60px, 8vw, 100px) calc(var(--sidebar, 130px) + 40px);
}
@media (max-width: 980px) {
    .vision-quote-section { padding-left: calc(var(--sidebar, 84px) + 24px); padding-right: 24px; }
}
@media (max-width: 600px) {
    .vision-quote-section { padding-left: calc(var(--sidebar, 52px) + 16px); padding-right: 16px; }
}
.vision-quote-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.vision-quote-icon { font-size: 48px; color: rgba(255,215,0,.3); margin-bottom: 24px; }
.vision-quote-inner blockquote {
    font-family: var(--font-heading, 'Montserrat', sans-serif);
    font-size: clamp(18px, 2.2vw, 26px); font-style: italic; font-weight: 700;
    color: #fff; line-height: 1.55; margin: 0 0 20px;
    text-shadow: 0 2px 15px rgba(255,215,0,.1);
}
.vision-quote-inner figcaption { font-size: 14px; color: rgba(255,255,255,.45); letter-spacing: 1px; }

/* ── CTA Button Group ────────────────────────────────────────────────────── */
.vision-cta-btns {
    display: flex; align-items: center; justify-content: center;
    gap: 16px; flex-wrap: wrap; margin-top: 8px;
}
.vision-cta-outline {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 16px 38px; background: transparent;
    color: var(--primary, #FFD700); font-size: 14px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px; text-decoration: none;
    border-radius: 50px; border: 2px solid var(--primary, #FFD700);
    transition: all .4s ease;
}
.vision-cta-outline:hover {
    background: rgba(255,215,0,.1);
    box-shadow: 0 8px 30px rgba(255,215,0,.2);
    transform: translateY(-3px);
}

/* ── Founder Photo Modal ─────────────────────────────────────────────────── */
.founder-photo-modal {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.88);
    backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
    z-index: 20000; display: flex; align-items: center; justify-content: center;
    opacity: 0; visibility: hidden;
    transition: opacity .3s ease, visibility .3s ease;
}
.founder-photo-modal.active { opacity: 1; visibility: visible; }
.founder-photo-modal-content {
    position: relative; max-width: min(85vw, 520px);
    animation: modalZoomIn .35s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes modalZoomIn {
    from { transform: scale(.8); opacity: 0; }
    to   { transform: scale(1); opacity: 1; }
}
.founder-photo-modal img {
    width: 100%; height: auto; border-radius: 20px; display: block; object-fit: contain;
    box-shadow: 0 30px 80px rgba(0,0,0,.8), 0 0 0 4px rgba(255,215,0,.25);
}
.modal-closer {
    position: absolute; top: -18px; right: -18px; z-index: 20001;
    background: rgba(0,0,0,.6); border: none; border-radius: 50%;
    width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: transform .25s ease, background .25s ease; padding: 0;
}
.modal-closer:hover { transform: scale(1.12) rotate(90deg); background: rgba(255,215,0,.15); }

/* ── Mobile Performance ──────────────────────────────────────────────────── */
@media (pointer: coarse) { .vision-founder-ring { animation: none; } }

@media (min-width: 901px) {
    .vision-founder-inner { align-items: start; }
    .vision-founder-photo-col { align-items: flex-start; }
    .vision-founder-frame img { object-position: top center; }
}
