/* ============================================================
   company-our-story.css  |  Aurelio Travels  |  Our Story
   All values reference main.css design tokens only.
   ============================================================ */

/* ── Loading ────────────────────────────────────────────────── */
.loading-overlay{position:fixed;inset:0;z-index:9999;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
.loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:.75rem}
.spinner-ring{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--primary-gold);border-radius:50%;animation:osSpin .85s linear infinite}
@keyframes osSpin{to{transform:rotate(360deg)}}
.loading-text{font-family:var(--font-heading);color:var(--primary-gold);font-size:1.1rem;letter-spacing:.15em}

/* ── Reveal ─────────────────────────────────────────────────── */
.reveal-on-scroll{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal-on-scroll.revealed{opacity:1;transform:none}

/* ── Sections ───────────────────────────────────────────────── */
.os-section{padding:5rem 0;background:var(--bg-primary)}
.os-section-alt{background:var(--bg-secondary)}
.os-section-dark{background:var(--gradient-primary)}
.os-eyebrow{display:inline-block;font-family:var(--font-secondary);font-size:.72rem;font-weight:var(--font-weight-semibold);letter-spacing:.22em;text-transform:uppercase;color:var(--primary-gold);margin-bottom:.5rem}
.os-eyebrow--light{color:var(--secondary-gold)}
.os-section-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:.75rem}
.os-section-title--light{color:var(--white)}
.os-section-subtitle{font-family:var(--font-primary);font-size:1rem;color:var(--text-muted);max-width:560px;margin:0 auto;line-height:1.7}
.os-body-text{font-family:var(--font-primary);font-size:.95rem;color:var(--text-secondary);line-height:1.78;margin-bottom:1rem}
.os-body-text--light{color:rgba(255,255,255,.72)}

/* ── Quote Block ────────────────────────────────────────────── */
.os-quote-block{border-left:3px solid var(--primary-gold);padding-left:1.5rem;margin-top:1.5rem}
.os-quote-text{font-family:var(--font-heading);font-size:1.05rem;font-style:italic;color:var(--primary-gold);line-height:1.58;margin-bottom:.5rem}
.os-quote-cite{font-family:var(--font-primary);font-size:.8rem;color:var(--text-muted);font-style:normal}

/* ── Origin Facts ───────────────────────────────────────────── */
.os-origin-facts{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.os-fact-item{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;background:var(--bg-secondary);border:1px solid var(--border-gray);border-radius:12px;transition:border-color .3s}
.os-fact-item:hover{border-color:var(--primary-gold)}
.os-fact-icon{width:40px;height:40px;border-radius:10px;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.25);display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--primary-gold);flex-shrink:0}
.os-fact-title{font-family:var(--font-heading);font-size:.95rem;font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:.3rem}
.os-fact-text{font-family:var(--font-primary);font-size:.85rem;color:var(--text-muted);line-height:1.65;margin:0}

/* ── Timeline ───────────────────────────────────────────────── */
.os-timeline{position:relative;padding-left:2rem}
.os-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--primary-gold),rgba(212,175,55,.12))}
.os-timeline-item{position:relative;padding:0 0 2.5rem 2rem}
.os-timeline-item:last-child{padding-bottom:0}
.os-timeline-marker{position:absolute;left:-2.45rem;top:.15rem;width:14px;height:14px;border-radius:50%;background:var(--primary-gold);border:2px solid var(--bg-secondary);box-shadow:0 0 10px rgba(212,175,55,.4);transition:transform .25s}
.os-timeline-marker--future{background:transparent;border-color:var(--primary-gold)}
.os-timeline-item:hover .os-timeline-marker{transform:scale(1.5)}
.os-timeline-dot{display:none} /* alias – marker handles dot styling */
.os-timeline-dot--future{display:none}
.os-timeline-content{}
.os-timeline-year{display:inline-block;font-family:var(--font-secondary);font-size:.7rem;font-weight:var(--font-weight-bold);letter-spacing:.1em;text-transform:uppercase;color:var(--primary-gold);background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.3);border-radius:100px;padding:.15rem .65rem;margin-bottom:.5rem}
.os-timeline-title{font-family:var(--font-heading);font-size:1.05rem;font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:.4rem}
.os-timeline-text{font-family:var(--font-primary);font-size:.87rem;color:var(--text-muted);line-height:1.7;margin:0}

/* ── Future Cards ───────────────────────────────────────────── */
.os-future-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:2rem;height:100%;transition:border-color .3s,background .3s}
.os-future-card:hover{border-color:var(--primary-gold);background:rgba(212,175,55,.05)}
.os-future-phase{display:inline-block;font-family:var(--font-secondary);font-size:.68rem;font-weight:var(--font-weight-bold);letter-spacing:.12em;text-transform:uppercase;color:var(--bg-primary);background:var(--primary-gold);border-radius:100px;padding:.2rem .75rem;margin-bottom:.75rem}
.os-future-title{font-family:var(--font-heading);font-size:1rem;font-weight:var(--font-weight-bold);color:var(--white);margin-bottom:.75rem}
.os-future-text{font-family:var(--font-primary);font-size:.87rem;color:rgba(255,255,255,.65);line-height:1.7;margin:0}

/* ── Community Stat ─────────────────────────────────────────── */
.os-community-stat{background:var(--bg-secondary);border:1px solid var(--primary-gold);border-radius:16px;padding:2.5rem;text-align:center;box-shadow:var(--shadow-luxury)}
.os-community-num{font-family:var(--font-heading);font-size:clamp(3rem,7vw,5.5rem);font-weight:var(--font-weight-bold);color:var(--primary-gold);line-height:1;margin-bottom:.5rem}
.os-community-label{font-family:var(--font-primary);font-size:.9rem;color:var(--text-muted);line-height:1.6}

/* ── CTA ────────────────────────────────────────────────────── */
.os-cta-section{background:var(--gradient-premium);padding:5rem 0}
.os-cta-inner{max-width:640px;margin:0 auto}
.os-cta-eyebrow{font-family:var(--font-secondary);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--secondary-gold);margin-bottom:.75rem;display:block}
.os-cta-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3vw,2.6rem);font-weight:var(--font-weight-bold);color:var(--white);margin-bottom:1rem;line-height:1.2}
.os-cta-subtitle{font-family:var(--font-secondary);font-size:1rem;font-style:italic;color:rgba(255,255,255,.68);margin-bottom:2rem}
.os-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.os-btn-primary{display:inline-flex;align-items:center;font-family:var(--font-primary);font-size:.9rem;font-weight:var(--font-weight-semibold);color:var(--bg-primary);background:var(--gradient-gold);border-radius:8px;padding:.82rem 2rem;text-decoration:none;box-shadow:var(--shadow-gold);transition:box-shadow .3s,transform .2s}
.os-btn-primary:hover{box-shadow:0 8px 30px rgba(212,175,55,.5);transform:translateY(-2px);color:var(--bg-primary)}
.os-btn-outline{display:inline-flex;align-items:center;font-family:var(--font-primary);font-size:.9rem;font-weight:var(--font-weight-semibold);color:var(--white);background:transparent;border:1.5px solid rgba(255,255,255,.35);border-radius:8px;padding:.82rem 2rem;text-decoration:none;transition:border-color .3s,background .3s,color .3s}
.os-btn-outline:hover{border-color:var(--primary-gold);color:var(--primary-gold);background:rgba(212,175,55,.08)}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:991.98px){.os-section{padding:4rem 0}}
@media(max-width:767.98px){.os-section{padding:3rem 0}.os-timeline{padding-left:1.5rem}.os-timeline-item{padding-left:1.5rem}.os-cta-section{padding:3.5rem 0}}
