/* Sanatan Bliss — about.css */
/* Page-specific styles, loaded via @push('styles') */

/* ── from sanatanbliss_about ── */
html { scroll-behavior: smooth; }
    body { font-family: var(--font-body); background: var(--cream); color: var(--stone); overflow-x: hidden; }

    /* ── BREADCRUMB ── */
    .breadcrumb { background: var(--cream-dark); padding: 11px 40px; display: flex; align-items: center; gap: 8px; font-size: .74rem; color: var(--stone-mid); }
    .breadcrumb a { color: var(--saffron); text-decoration: none; }
    .breadcrumb a:hover { text-decoration: underline; }

    /* ── HERO ── */
    .about-hero { position: relative; min-height: 56vh; display: grid; place-items: center; overflow: hidden; }
    .ah-bg { position: absolute; inset: 0; background: linear-gradient(155deg, #0D0005 0%, #2A0A0A 40%, var(--maroon) 75%, #4A1A00 100%); }
    .ah-grain { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E"); opacity: .35; }
    .ah-om-bg { position: absolute; right: -40px; top: 50%; transform: translateY(-50%); font-family: var(--font-hindi); font-size: 32rem; color: rgba(255,255,255,.025); pointer-events: none; line-height: 1; }
    .ah-ring { position: absolute; border-radius: 50%; border: 1px solid rgba(212,160,23,.08); animation: ahspin 90s linear infinite; }
    .ah-ring-1 { width: 600px; height: 600px; top: 50%; left: 50%; transform: translate(-50%,-50%); }
    .ah-ring-2 { width: 420px; height: 420px; top: 50%; left: 50%; border-style: dashed; border-color: rgba(255,255,255,.04); animation-direction: reverse; animation-duration: 60s; transform: translate(-50%,-50%); }
    @keyframes ahspin { to { transform: translate(-50%,-50%) rotate(360deg); } }
    .ah-content { position: relative; z-index: 2; text-align: center; padding: 64px 24px; max-width: 760px; animation: fadeUp .9s ease both; }
    @keyframes fadeUp { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: translateY(0); } }
    .ah-kicker { font-size: .68rem; letter-spacing: .24em; text-transform: uppercase; color: var(--gold-light); font-weight: 600; display: block; margin-bottom: 14px; opacity: .8; }
    .ah-title { font-family: var(--font-display); font-size: clamp(2.6rem, 5.5vw, 4.8rem); font-weight: 300; color: white; line-height: 1.08; margin-bottom: 8px; }
    .ah-title em { font-style: italic; color: var(--saffron-light); }
    .ah-title-hi { font-family: var(--font-hindi); font-size: 1.3rem; color: rgba(255,255,255,.4); display: block; margin-bottom: 18px; }
    .ah-divider { width: 44px; height: 2px; background: linear-gradient(90deg,transparent,var(--gold),transparent); margin: 0 auto 18px; }
    .ah-sub { font-family: var(--font-display); font-style: italic; font-size: 1.1rem; color: rgba(255,255,255,.65); line-height: 1.75; max-width: 560px; margin: 0 auto; }

    /* ── MAIN CONTENT ── */
    .page-body { max-width: 1200px; margin: 0 auto; padding: 64px 40px 80px; }

    /* ── SECTION LABEL ── */
    
    

    /* ── ORIGIN STORY ── */
    .origin-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 64px; align-items: center; margin-bottom: 80px; }
    .origin-visual { position: relative; }
    .origin-card { background: linear-gradient(145deg, var(--maroon), #4A0E00); border-radius: 28px; padding: 48px 36px; text-align: center; position: relative; overflow: hidden; }
    .origin-card-om { position: absolute; bottom: -20px; right: -10px; font-family: var(--font-hindi); font-size: 12rem; color: rgba(255,255,255,.04); pointer-events: none; line-height: 1; }
    .origin-card-year { font-family: var(--font-display); font-size: 4rem; font-weight: 700; color: var(--gold-light); display: block; line-height: 1; margin-bottom: 4px; }
    .origin-card-label { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.5); display: block; margin-bottom: 24px; }
    .origin-card-quote { font-family: var(--font-display); font-style: italic; font-size: 1.2rem; color: rgba(255,255,255,.8); line-height: 1.7; }
    .origin-badge { position: absolute; top: -12px; right: 24px; background: var(--gold); color: var(--stone); font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 6px 14px; border-radius: 20px; }
    .origin-text h2 { font-family: var(--font-display); font-size: 2.4rem; font-weight: 300; color: var(--maroon); line-height: 1.2; margin-bottom: 18px; }
    .origin-text h2 em { font-style: italic; }
    .origin-text p { font-size: .9rem; color: var(--stone-mid); line-height: 1.85; margin-bottom: 14px; }
    .origin-text p strong { color: var(--stone); font-weight: 600; }

    /* ── MVV (Mission / Vision / Values) ── */
    .mvv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 80px; }
    .mvv-card { border-radius: 24px; padding: 32px 26px; position: relative; overflow: hidden; }
    .mvv-card-mission { background: var(--maroon); }
    .mvv-card-vision { background: linear-gradient(135deg, var(--saffron-pale), #FDE8C0); border: 1px solid rgba(194,96,10,.15); }
    .mvv-card-values { background: linear-gradient(135deg, var(--green-light), #C6EFDA); border: 1px solid rgba(26,92,58,.15); }
    .mvv-icon { font-size: 2rem; display: block; margin-bottom: 14px; }
    .mvv-head { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; margin-bottom: 8px; display: block; }
    .mvv-card-mission .mvv-head { color: rgba(255,255,255,.5); }
    .mvv-card-vision .mvv-head { color: var(--saffron); }
    .mvv-card-values .mvv-head { color: var(--green); }
    .mvv-title { font-family: var(--font-display); font-size: 1.5rem; font-weight: 600; line-height: 1.25; margin-bottom: 12px; }
    .mvv-card-mission .mvv-title { color: white; }
    .mvv-card-vision .mvv-title { color: var(--maroon); }
    .mvv-card-values .mvv-title { color: var(--green); }
    .mvv-body { font-size: .84rem; line-height: 1.75; }
    .mvv-card-mission .mvv-body { color: rgba(255,255,255,.65); }
    .mvv-card-vision .mvv-body { color: var(--stone-mid); }
    .mvv-card-values .mvv-body { color: var(--stone-mid); }

    /* ── WHAT WE OFFER ── */
    .offer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 80px; }
    .offer-card { background: white; border: 1px solid var(--cream-dark); border-radius: 20px; padding: 24px 22px; text-decoration: none; color: var(--stone); transition: all .3s; display: block; }
    .offer-card:hover { transform: translateY(-4px); box-shadow: 0 12px 36px rgba(107,30,15,.1); border-color: rgba(194,96,10,.2); }
    .offer-icon { font-size: 1.8rem; display: block; margin-bottom: 12px; }
    .offer-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--maroon); margin-bottom: 6px; }
    .offer-desc { font-size: .8rem; color: var(--stone-mid); line-height: 1.7; margin-bottom: 12px; }
    .offer-link { font-size: .74rem; color: var(--saffron); font-weight: 600; }

    /* ── STATS STRIP ── */
    .stats-strip { background: linear-gradient(135deg, var(--maroon), #4A1A00); border-radius: 24px; padding: 48px 40px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 80px; position: relative; overflow: hidden; }
    .stats-strip::after { content: 'ॐ'; font-family: var(--font-hindi); font-size: 18rem; color: rgba(255,255,255,.025); position: absolute; right: -40px; bottom: -60px; line-height: 1; pointer-events: none; }
    .stat-item { text-align: center; position: relative; z-index: 1; }
    .stat-num { font-family: var(--font-display); font-size: 2.8rem; font-weight: 700; color: var(--gold-light); display: block; line-height: 1; margin-bottom: 4px; }
    .stat-label { font-size: .72rem; color: rgba(255,255,255,.55); letter-spacing: .08em; text-transform: uppercase; }
    .stat-sep { width: 1px; background: rgba(255,255,255,.1); }

    /* ── VALUES ── */
    .values-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 80px; }
    .value-item { display: flex; gap: 16px; align-items: flex-start; padding: 20px; background: white; border: 1px solid var(--cream-dark); border-radius: 16px; transition: all .25s; }
    .value-item:hover { border-color: rgba(194,96,10,.2); box-shadow: 0 6px 20px rgba(107,30,15,.07); }
    .value-icon { font-size: 1.5rem; width: 44px; height: 44px; background: var(--saffron-pale); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .value-body h4 { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--stone); margin-bottom: 4px; }
    .value-body p { font-size: .8rem; color: var(--stone-mid); line-height: 1.7; }

    /* ── TIMELINE ── */
    .timeline { position: relative; margin-bottom: 80px; }
    .timeline::before { content: ''; position: absolute; left: 28px; top: 0; bottom: 0; width: 2px; background: linear-gradient(180deg, var(--gold), var(--saffron), transparent); }
    .tl-item { display: flex; gap: 24px; margin-bottom: 32px; position: relative; }
    .tl-dot { width: 58px; height: 58px; border-radius: 50%; background: white; border: 2px solid var(--gold); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: var(--font-display); font-size: .8rem; font-weight: 700; color: var(--maroon); z-index: 1; }
    .tl-body { padding-top: 10px; flex: 1; }
    .tl-year { font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--saffron); font-weight: 700; margin-bottom: 4px; }
    .tl-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--stone); margin-bottom: 6px; }
    .tl-desc { font-size: .82rem; color: var(--stone-mid); line-height: 1.7; }

    /* ── TEAM ── */
    .team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 80px; }
    .team-card { background: white; border: 1px solid var(--cream-dark); border-radius: 20px; padding: 28px 22px; text-align: center; transition: all .3s; }
    .team-card:hover { transform: translateY(-3px); box-shadow: 0 10px 32px rgba(107,30,15,.09); }
    .team-avatar { width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 14px; display: flex; align-items: center; justify-content: center; font-size: 2rem; }
    .team-name { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--stone); margin-bottom: 3px; }
    .team-role { font-size: .72rem; color: var(--saffron); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 10px; }
    .team-bio { font-size: .8rem; color: var(--stone-mid); line-height: 1.7; }

    /* ── CTA STRIP ── */
    .cta-strip { background: linear-gradient(135deg, var(--saffron-pale), var(--gold-light)); border: 1px solid rgba(212,160,23,.25); border-radius: 24px; padding: 48px 40px; text-align: center; margin-bottom: 80px; position: relative; overflow: hidden; }
    .cta-strip::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(212,160,23,.08), transparent); }
    .cta-title { font-family: var(--font-display); font-size: 2.4rem; font-weight: 300; color: var(--maroon); margin-bottom: 10px; position: relative; z-index: 1; }
    .cta-title em { font-style: italic; }
    .cta-sub { font-size: .9rem; color: var(--stone-mid); margin-bottom: 28px; max-width: 480px; margin-left: auto; margin-right: auto; line-height: 1.7; position: relative; z-index: 1; }
    .cta-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; position: relative; z-index: 1; }
    .btn-maroon { background: var(--maroon); color: white; border: none; padding: 13px 28px; border-radius: 50px; font-family: var(--font-body); font-size: .88rem; font-weight: 600; cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: all .25s; }
    .btn-maroon:hover { background: var(--maroon-mid); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(107,30,15,.25); }
    .btn-outline { background: transparent; color: var(--maroon); border: 2px solid var(--maroon); padding: 11px 26px; border-radius: 50px; font-family: var(--font-body); font-size: .88rem; font-weight: 600; cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: all .25s; }
    .btn-outline:hover { background: var(--maroon); color: white; transform: translateY(-2px); }

    /* ── FADE-UP ── */
    
    

    /* ── RESPONSIVE ── */
    @media (max-width: 1024px) {
      .origin-grid { grid-template-columns: 1fr; gap: 36px; }
      .origin-visual { max-width: 480px; margin: 0 auto; }
      .mvv-grid { grid-template-columns: 1fr; }
      .offer-grid { grid-template-columns: repeat(2, 1fr); }
      .stats-strip { grid-template-columns: repeat(2, 1fr); }
      .stat-sep { display: none; }
      .team-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 768px) {
      .page-body { padding: 40px 20px 60px; }
      .breadcrumb { padding: 10px 20px; }
      .origin-text h2 { font-size: 2rem; }
      .offer-grid { grid-template-columns: 1fr; }
      .stats-strip { padding: 32px 24px; grid-template-columns: repeat(2, 1fr); }
      .values-list { grid-template-columns: 1fr; }
      .team-grid { grid-template-columns: 1fr; }
      .cta-strip { padding: 36px 24px; }
      .cta-title { font-size: 1.9rem; }
      .timeline::before { left: 22px; }
      .tl-dot { width: 46px; height: 46px; font-size: .7rem; }
    }


/* ── LEGAL PAGES (privacy, terms, contact) ── */
.legal-hero {
  background: linear-gradient(135deg, var(--stone) 0%, #5a3d2b 100%);
  padding: 56px 40px 48px; text-align: center;
}
.legal-hero-inner { max-width: 600px; margin: 0 auto; }
.legal-hero-om { font-family: var(--font-hindi); font-size: 2.5rem; color: rgba(255,255,255,.3); margin-bottom: 10px; }
.legal-hero-title { font-family: var(--font-display); font-size: clamp(1.8rem,5vw,3rem); font-weight: 700; color: white; margin-bottom: 8px; }
.legal-hero-meta { font-size: .8rem; color: rgba(255,255,255,.5); }

.legal-layout {
  max-width: 1060px; margin: 0 auto;
  display: grid; grid-template-columns: 220px 1fr; gap: 48px;
  padding: 56px 40px 80px;
}
@media (max-width: 768px) {
  .legal-layout { grid-template-columns: 1fr; padding: 32px 20px 60px; }
  .legal-toc { display: none; }
  .legal-hero { padding: 40px 20px; }
}
.legal-toc { position: sticky; top: 80px; align-self: start; }
.legal-toc-title { font-size: .65rem; text-transform: uppercase; letter-spacing: .14em; color: var(--stone-mid); font-weight: 700; margin-bottom: 12px; }
.legal-toc nav { display: flex; flex-direction: column; gap: 2px; }
.legal-toc nav a { font-size: .8rem; color: var(--stone-mid); text-decoration: none; padding: 6px 10px; border-radius: 6px; transition: all .15s; }
.legal-toc nav a:hover { background: var(--saffron-pale); color: var(--maroon); }
.legal-toc nav a.active { background: var(--saffron-pale); color: var(--maroon); font-weight: 600; }

.legal-content h2 { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: var(--stone); margin: 40px 0 14px; padding-bottom: 10px; border-bottom: 2px solid var(--saffron-pale); }
.legal-content h2:first-child { margin-top: 0; }
.legal-content h3 { font-size: .9rem; font-weight: 700; color: var(--stone); margin: 20px 0 8px; text-transform: uppercase; letter-spacing: .06em; }
.legal-content p { font-size: .9rem; color: var(--stone-mid); line-height: 1.8; margin-bottom: 14px; }
.legal-content ul { padding-left: 20px; margin-bottom: 14px; display: flex; flex-direction: column; gap: 6px; }
.legal-content ul li { font-size: .9rem; color: var(--stone-mid); line-height: 1.6; }
.legal-content a { color: var(--maroon); }
.legal-content section { margin-bottom: 8px; scroll-margin-top: 90px; }
.legal-intro-box { background: var(--saffron-pale); border-left: 4px solid var(--saffron); border-radius: 0 12px 12px 0; padding: 16px 20px; font-size: .88rem; color: var(--stone); line-height: 1.6; margin-bottom: 32px; }
.legal-contact-box { background: var(--cream); border: 1px solid var(--cream-dark); border-radius: 12px; padding: 20px 24px; font-size: .88rem; color: var(--stone); line-height: 1.9; margin-top: 12px; }
.legal-contact-box a { color: var(--maroon); text-decoration: none; }
.legal-table-wrap { overflow-x: auto; margin: 16px 0 20px; }
.legal-table { width: 100%; border-collapse: collapse; font-size: .84rem; }
.legal-table th { background: var(--cream); padding: 10px 14px; text-align: left; font-weight: 700; color: var(--stone); border-bottom: 2px solid var(--cream-dark); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; }
.legal-table td { padding: 10px 14px; border-bottom: 1px solid var(--cream-dark); color: var(--stone-mid); vertical-align: top; }
.legal-table tr:last-child td { border-bottom: none; }
