/* ============================================================
   Samvik Capital Solutions – Main Stylesheet
   Premium Dark Theme: Navy (#040814) + Gold (#D4AF37)
   Fonts: Playfair Display (serif) + Manrope (sans)
   ============================================================ */

/* ── CSS Variables ── */
:root {
  --bg-base: #142A4A;
  --surface: #0A1128;
  --surface-alt: rgba(10, 17, 40, 0.4);
  --gold: #D4AF37;
  --gold-light: #F3E5AB;
  --gold-10: rgba(212, 175, 55, 0.1);
  --gold-20: rgba(212, 175, 55, 0.2);
  --white: #FFFFFF;
  --text-secondary: #94A3B8;
  --text-muted: #64748B;
  --border: rgba(255, 255, 255, 0.1);
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans: 'Manrope', -apple-system, sans-serif;
  --radius: 1rem;
  --radius-xl: 1.25rem;
}

/* ── Reset / Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-sans); background: var(--bg-base); color: var(--white); overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
::selection { background: rgba(212, 175, 55, 0.3); color: #fff; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-base); }
::-webkit-scrollbar-thumb { background: rgba(212, 175, 55, 0.3); border-radius: 3px; }

/* ── Layout ── */
.container { max-width: 80rem; margin: 0 auto; padding: 0 1.5rem; }
.container-narrow { max-width: 56rem; }
.section { padding: 6rem 0; }
.bg-base { background: var(--bg-base); }
.bg-surface-alt { background: var(--surface-alt); }
.text-center { text-align: center; }
.text-gold { color: var(--gold); }
.text-secondary { color: var(--text-secondary); }
.text-muted { color: var(--text-muted); }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: 2rem; }
.mb-10 { margin-bottom: 2.5rem; }

@media (min-width: 768px) {
  .container { padding: 0 3rem; }
  .section { padding: 8rem 0; }
}
@media (min-width: 1024px) {
  .section { padding: 10rem 0; }
}

.grid-2col { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 1024px) { .grid-2col { grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; } }

/* ── Typography ── */
.font-serif, h1, h2, h3 { font-family: var(--font-serif); }
.overline { text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.75rem; color: var(--gold); font-weight: 600; margin-bottom: 1rem; font-family: var(--font-sans); }
.heading-lg { font-size: clamp(1.875rem, 4vw, 3.25rem); line-height: 1.15; letter-spacing: -0.01em; color: var(--white); margin-bottom: 1.5rem; font-weight: 500; }
.body-text { font-size: 1.125rem; line-height: 1.75; color: var(--text-secondary); }
.body-text-sm { font-size: 0.875rem; line-height: 1.7; color: var(--text-secondary); }
.section-intro { max-width: 42rem; margin-bottom: 3rem; }

/* ── Buttons ── */
.btn-gold { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.75rem 2rem; background: var(--gold); color: var(--bg-base); font-weight: 600; font-size: 0.875rem; transition: all 0.2s; }
.btn-gold:hover { background: var(--gold-light); transform: scale(1.03); }
.btn-outline-gold { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.75rem 2rem; border: 1px solid var(--gold); color: var(--gold); font-weight: 600; font-size: 0.875rem; transition: all 0.2s; }
.btn-outline-gold:hover { background: var(--gold-10); }
.btn-pill { border-radius: 9999px; }
.btn-lg { padding: 1rem 2.5rem; font-size: 1rem; }
.btn-sm { padding: 0.625rem 1.25rem; font-size: 0.875rem; }
.btn-full { width: 100%; justify-content: center; padding: 1rem; border-radius: var(--radius-xl); }
.link-gold { color: var(--gold); font-size: 0.875rem; text-decoration: underline; background: none; border: none; cursor: pointer; }

/* ── Navigation ── */
.nav-bar { position: fixed; top: 0; left: 0; right: 0; z-index: 50; transition: all 0.3s; }
.nav-scrolled { background: rgba(20, 42, 74, 0.82); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); box-shadow: 0 4px 24px rgba(0,0,0,0.2); }
.nav-inner { max-width: 80rem; margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; justify-content: space-between; height: 5rem; }
@media (min-width: 768px) { .nav-inner { padding: 0 3rem; } }
.nav-logo img { height: 3rem; width: auto; }
.nav-logo .custom-logo { height: 3rem; width: auto; }
@media (min-width: 1024px) {
  .nav-logo img,
  .nav-logo .custom-logo { height: 4.5rem; }
}
.nav-links-desktop { display: none; align-items: center; gap: 2.5rem; }
@media (min-width: 1024px) { .nav-links-desktop { display: flex; } }
.nav-link { font-size: 0.875rem; font-weight: 500; color: var(--text-secondary); transition: color 0.2s; letter-spacing: 0.02em; }
.nav-link:hover { color: var(--white); }
.nav-mobile-toggle { display: block; color: var(--white); }
@media (min-width: 1024px) { .nav-mobile-toggle { display: none; } }
.nav-mobile-menu { display: none; background: rgba(20, 42, 74, 0.95); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); }
.nav-mobile-menu.is-open { display: block; }
.nav-mobile-inner { padding: 1.5rem; display: flex; flex-direction: column; gap: 1rem; }
.nav-mobile-link { color: var(--text-secondary); font-size: 1rem; padding: 0.5rem 0; transition: color 0.2s; }
.nav-mobile-link:hover { color: var(--white); }
.nav-mobile-cta { margin-top: 0.5rem; text-align: center; }

/* ── Hero ── */
.hero-section { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(20,42,74,0.75), rgba(20,42,74,0.55), var(--bg-base)); }
.hero-glow { position: absolute; top: 33%; left: 50%; transform: translateX(-50%); width: 37rem; height: 37rem; background: rgba(212,175,55,0.04); border-radius: 50%; filter: blur(150px); pointer-events: none; }
.hero-content { position: relative; z-index: 10; max-width: 52rem; margin: 0 auto; padding: 0 1.5rem; text-align: center; }
.hero-heading { font-size: clamp(2.5rem, 6vw, 4.5rem); line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 2rem; font-weight: 500; }
.hero-sub { font-size: clamp(1rem, 2vw, 1.25rem); color: var(--text-secondary); max-width: 38rem; margin: 0 auto 3rem; line-height: 1.7; }
.hero-ctas { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
@media (min-width: 640px) { .hero-ctas { flex-direction: row; justify-content: center; } }
.hero-scroll-indicator { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); animation: bounce 2s infinite; color: rgba(212,175,55,0.5); }
@keyframes bounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }

/* ── Client Logos Marquee ── */
.logos-section { padding: 4rem 0; border-top: 1px solid rgba(255,255,255,0.05); border-bottom: 1px solid rgba(255,255,255,0.05); overflow: hidden; }
.marquee-track { overflow: hidden; mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent); -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent); margin-top: 2rem; }
.marquee-content { display: flex; gap: 3rem; animation: marquee-scroll 30s linear infinite; width: max-content; }
@keyframes marquee-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.marquee-item { display: flex; align-items: center; gap: 0.5rem; opacity: 0.4; transition: opacity 0.3s; white-space: nowrap; }
.marquee-item:hover { opacity: 0.7; }
.marquee-icon { width: 2rem; height: 2rem; border-radius: 50%; border: 1px solid rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 0.75rem; font-weight: 700; }
.marquee-text { color: var(--text-muted); font-size: 0.875rem; font-weight: 500; letter-spacing: 0.05em; }

/* ── About ── */
.about-image-wrap { position: relative; }
.about-image-glow { position: absolute; inset: -1rem; background: linear-gradient(135deg, var(--gold-10), transparent); border-radius: var(--radius-xl); filter: blur(24px); }
.about-image { position: relative; width: 100%; height: 25rem; object-fit: cover; border-radius: var(--radius-xl); border: 1px solid var(--border); }
@media (min-width: 1024px) { .about-image { height: 31rem; } }
.about-stat-badge { position: absolute; bottom: 1.5rem; left: 1.5rem; right: 1.5rem; padding: 1.25rem; background: rgba(10,17,40,0.8); backdrop-filter: blur(16px); border-radius: var(--radius); border: 1px solid var(--border); }
.about-stat-title { color: var(--gold); font-weight: 600; font-size: 0.875rem; }
.about-stat-sub { color: var(--text-secondary); font-size: 0.75rem; margin-top: 0.25rem; }
.mini-cards-row { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .mini-cards-row { grid-template-columns: repeat(3, 1fr); } }
.mini-card { padding: 1rem; border-radius: var(--radius); background: rgba(10,17,40,0.6); border: 1px solid var(--border); }
.mini-card-title { color: var(--white); font-weight: 600; font-size: 0.875rem; margin-bottom: 0.25rem; }
.mini-card-desc { color: var(--text-muted); font-size: 0.75rem; }

/* ── Value Proposition (Bento Grid) ── */
.bento-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 768px) { .bento-grid { grid-template-columns: repeat(12, 1fr); } }
.span-3 { grid-column: span 1; } .span-4 { grid-column: span 1; } .span-5 { grid-column: span 1; } .span-6 { grid-column: span 1; }
@media (min-width: 768px) { .span-3 { grid-column: span 3; } .span-4 { grid-column: span 4; } .span-5 { grid-column: span 5; } .span-6 { grid-column: span 6; } }
.bento-card { padding: 1.75rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); transition: all 0.3s; }
.bento-card:hover { border-color: rgba(212,175,55,0.3); transform: translateY(-4px); }
.bento-icon { width: 3rem; height: 3rem; border-radius: var(--radius); background: var(--gold-10); display: flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; color: var(--gold); }
.bento-card:hover .bento-icon { background: var(--gold-20); }
.bento-title { font-size: 1.25rem; color: var(--white); margin-bottom: 0.75rem; }
.bento-desc { font-size: 0.875rem; line-height: 1.65; color: var(--text-secondary); }

/* ── Core Services (Accordion) ── */
.accordion-stack { display: flex; flex-direction: column; gap: 1rem; }
.accordion-item { border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: hidden; background: rgba(10,17,40,0.4); transition: all 0.3s; }
.accordion-item.is-open { background: var(--surface); border-color: rgba(212,175,55,0.2); }
.accordion-trigger { width: 100%; padding: 1.5rem 2rem; display: flex; align-items: center; justify-content: space-between; text-align: left; color: var(--white); }
.accordion-trigger-left { display: flex; align-items: center; gap: 1.25rem; }
.accordion-icon { width: 3rem; height: 3rem; border-radius: var(--radius); background: var(--gold-10); display: flex; align-items: center; justify-content: center; color: var(--gold); flex-shrink: 0; }
.accordion-title { font-size: 1.25rem; color: var(--white); }
@media (min-width: 768px) { .accordion-title { font-size: 1.5rem; } }
.accordion-subtitle { color: var(--text-muted); font-size: 0.875rem; margin-top: 0.25rem; font-family: var(--font-sans); }
.accordion-chevron { color: var(--gold); transition: transform 0.3s; flex-shrink: 0; }
.accordion-item.is-open .accordion-chevron { transform: rotate(180deg); }
.accordion-body { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
.accordion-item.is-open .accordion-body { max-height: 30rem; }
.accordion-body-inner { padding: 0 2rem 2rem; padding-left: calc(2rem + 3rem + 1.25rem); }

/* ── Bullet List ── */
.bullet-list { list-style: none; display: flex; flex-direction: column; gap: 0.625rem; }
.bullet-list li { display: flex; align-items: flex-start; gap: 0.75rem; font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }
.bullet-list li::before { content: ''; width: 0.375rem; height: 0.375rem; border-radius: 50%; background: var(--gold); flex-shrink: 0; margin-top: 0.5rem; }

/* ── Engagement Steps ── */
.steps-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; position: relative; }
@media (min-width: 640px) { .steps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .steps-grid { grid-template-columns: repeat(4, 1fr); } }
.steps-line { display: none; }
@media (min-width: 1024px) { .steps-line { display: block; position: absolute; top: 4.5rem; left: 12%; right: 12%; height: 1px; background: linear-gradient(to right, transparent, rgba(212,175,55,0.3), transparent); } }
.step-card-inner { padding: 1.75rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); transition: border-color 0.3s; height: 100%; }
.step-card-inner:hover { border-color: rgba(212,175,55,0.2); }
.step-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.step-icon-wrap { width: 3.5rem; height: 3.5rem; border-radius: var(--radius-xl); background: var(--gold-10); display: flex; align-items: center; justify-content: center; color: var(--gold); position: relative; z-index: 1; }
.step-num { font-family: var(--font-serif); font-size: 1.875rem; font-weight: 700; color: rgba(212,175,55,0.4); }
.step-title { font-size: 1.25rem; color: var(--white); margin-bottom: 0.75rem; }
.step-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }
.process-footnote { text-align: center; color: var(--text-secondary); font-size: 0.875rem; font-style: italic; margin-top: 3rem; max-width: 36rem; margin-left: auto; margin-right: auto; }

/* ── Key Sectors ── */
.sectors-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .sectors-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .sectors-grid { grid-template-columns: repeat(5, 1fr); } }
.sector-card { padding: 1.5rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); text-align: center; transition: all 0.3s; }
.sector-card:hover { border-color: rgba(212,175,55,0.3); transform: translateY(-4px); }
.sector-icon { width: 3.5rem; height: 3.5rem; border-radius: var(--radius-xl); background: var(--gold-10); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; color: var(--gold); }
.sector-card:hover .sector-icon { background: var(--gold-20); }
.sector-title { font-size: 1.125rem; color: var(--white); margin-bottom: 0.75rem; }
.sector-desc { font-size: 0.75rem; color: var(--text-secondary); line-height: 1.65; }

/* ── Team ── */
.team-grid { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 1024px) { .team-grid { grid-template-columns: 2fr 3fr; gap: 4rem; align-items: start; } }
.team-photo-col { position: relative; }
.team-photo-glow { position: absolute; inset: -0.75rem; background: linear-gradient(135deg, rgba(212,175,55,0.12), transparent); border-radius: var(--radius-xl); filter: blur(16px); }
.team-photo { position: relative; width: 100%; aspect-ratio: 3/4; object-fit: cover; border-radius: var(--radius-xl); border: 1px solid var(--border); }
.team-photo-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.5rem; background: linear-gradient(to top, var(--bg-base), transparent); border-radius: 0 0 var(--radius-xl) var(--radius-xl); }
.team-photo-name { font-family: var(--font-serif); font-size: 1.5rem; color: var(--white); }
.team-photo-role { color: var(--gold); font-size: 0.875rem; font-weight: 600; }
.team-bio-col { display: flex; flex-direction: column; gap: 2rem; }
.team-block { display: flex; align-items: flex-start; gap: 1rem; }
.team-block-icon { width: 2.5rem; height: 2.5rem; border-radius: 0.5rem; background: var(--gold-10); display: flex; align-items: center; justify-content: center; color: var(--gold); flex-shrink: 0; margin-top: 0.25rem; }
.team-block-title { color: var(--white); font-weight: 600; font-size: 0.875rem; margin-bottom: 0.5rem; font-family: var(--font-sans); }
.cred-pills { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.cred-pill { font-size: 0.75rem; color: var(--text-secondary); background: var(--surface); border: 1px solid var(--border); padding: 0.375rem 0.75rem; border-radius: 9999px; }
.team-sector-line { color: var(--text-muted); font-size: 0.875rem; margin-top: 0.75rem; }
.team-sector-line strong { color: var(--text-secondary); }

/* ── Blog Cards ── */
.blog-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; margin-top: 2rem; }
@media (min-width: 768px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }
.blog-card { border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); overflow: hidden; transition: all 0.3s; }
.blog-card:hover { border-color: rgba(212,175,55,0.2); }
.blog-card-bar { height: 0.125rem; background: linear-gradient(to right, var(--gold), rgba(212,175,55,0.4)); }
.blog-card-body { padding: 1.75rem; }
.blog-card-meta { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.blog-cat { font-size: 0.75rem; color: var(--gold); background: var(--gold-10); padding: 0.25rem 0.75rem; border-radius: 9999px; font-weight: 600; }
.blog-time { display: flex; align-items: center; gap: 0.25rem; font-size: 0.75rem; color: var(--text-muted); }
.blog-card-title { font-family: var(--font-serif); font-size: 1.125rem; color: var(--white); margin-bottom: 0.75rem; line-height: 1.4; }
.blog-card-title a { color: inherit; transition: color 0.2s; }
.blog-card:hover .blog-card-title a { color: var(--gold); }
.blog-card-excerpt { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.65; margin-bottom: 1.5rem; }
.blog-card-footer { display: flex; align-items: center; justify-content: space-between; }
.blog-author { font-size: 0.75rem; color: var(--text-muted); }
.blog-arrow { color: var(--gold); transition: transform 0.2s; }
.blog-card:hover .blog-arrow { transform: translateX(4px); }

/* ── CTA Section ── */
.cta-section { position: relative; overflow: hidden; }
.cta-glow { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 50rem; height: 50rem; background: rgba(212,175,55,0.03); border-radius: 50%; filter: blur(200px); pointer-events: none; }
.cta-cards { display: grid; grid-template-columns: 1fr; gap: 1.5rem; margin: 2rem 0 3rem; }
@media (min-width: 768px) { .cta-cards { grid-template-columns: repeat(3, 1fr); } }
.cta-card { padding: 1.5rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); text-align: center; }
.cta-card-icon { width: 3rem; height: 3rem; border-radius: var(--radius); background: var(--gold-10); display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; color: var(--gold); }
.cta-card-title { font-family: var(--font-serif); font-size: 1.125rem; color: var(--white); margin-bottom: 0.5rem; }
.cta-card-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }
.cta-disclaimer { color: var(--text-muted); font-size: 0.875rem; margin-top: 1rem; }

/* ── Contact Section ── */
.contact-details { display: flex; flex-direction: column; gap: 1.25rem; margin-bottom: 1.5rem; }
.contact-row { display: flex; align-items: flex-start; gap: 1rem; }
.contact-icon-wrap { width: 2.5rem; height: 2.5rem; border-radius: 0.5rem; background: var(--gold-10); display: flex; align-items: center; justify-content: center; color: var(--gold); flex-shrink: 0; }
.contact-name { color: var(--white); font-size: 0.875rem; font-weight: 600; }
.contact-addr { color: var(--text-secondary); font-size: 0.875rem; }
.contact-email-link { color: var(--text-secondary); font-size: 0.875rem; transition: color 0.2s; }
.contact-email-link:hover { color: var(--gold); }

.newsletter-box { margin-top: 2.5rem; padding: 1.5rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); }
.newsletter-title { color: var(--white); font-weight: 600; font-size: 0.875rem; margin-bottom: 0.5rem; }
.newsletter-desc { color: var(--text-muted); font-size: 0.75rem; margin-bottom: 1rem; }
.newsletter-form { display: flex; gap: 0.5rem; }

.contact-form-card { padding: 2rem 2.5rem; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); }
.contact-form-title { font-family: var(--font-serif); font-size: 1.5rem; color: var(--white); margin-bottom: 0.5rem; }
.contact-form-sub { color: var(--text-muted); font-size: 0.875rem; margin-bottom: 2rem; }
.form-row { display: grid; grid-template-columns: 1fr; gap: 1.25rem; margin-bottom: 1.25rem; }
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-group { display: flex; flex-direction: column; gap: 0.5rem; }
.form-group label { color: var(--text-secondary); font-size: 0.75rem; }
.form-group + .form-group:last-child:not(.form-row .form-group) { margin-bottom: 1.25rem; }

.input-dark { width: 100%; padding: 0.75rem 1rem; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--radius); color: var(--white); font-size: 0.875rem; font-family: var(--font-sans); transition: all 0.2s; }
.input-dark::placeholder { color: var(--text-muted); }
.input-dark:focus { outline: none; box-shadow: 0 0 0 2px rgba(212,175,55,0.35); border-color: rgba(212,175,55,0.5); }
.input-pill { border-radius: 9999px; }
textarea.input-dark { resize: none; border-radius: var(--radius); }

.form-msg { font-size: 0.875rem; margin-top: 0.75rem; margin-bottom: 0.75rem; }
.form-msg-success { color: var(--gold); }
.form-msg-error { color: #f87171; }

.form-success { text-align: center; padding: 3rem 0; }
.form-success h4 { font-family: var(--font-serif); font-size: 1.25rem; color: var(--white); margin: 1rem 0 0.5rem; }
.form-success p { color: var(--text-secondary); font-size: 0.875rem; margin-bottom: 1.5rem; }

/* ── Footer ── */
.site-footer { border-top: 1px solid rgba(255,255,255,0.05); background: var(--bg-base); }
.site-footer .container { padding-top: 3rem; padding-bottom: 3rem; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }
.footer-brand img, .footer-brand .custom-logo { height: 2.5rem; width: auto; margin-bottom: 1rem; }
.footer-tagline { color: var(--text-muted); font-size: 0.875rem; line-height: 1.6; max-width: 20rem; }
.footer-heading { color: var(--white); font-size: 0.875rem; font-weight: 600; margin-bottom: 1rem; font-family: var(--font-sans); }
.footer-list { list-style: none; display: flex; flex-direction: column; gap: 0.625rem; }
.footer-list li a, .footer-list li span { color: var(--text-muted); font-size: 0.875rem; transition: color 0.2s; }
.footer-list li a:hover { color: var(--gold); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.05); padding-top: 2rem; display: flex; flex-direction: column; gap: 0.5rem; align-items: center; }
@media (min-width: 768px) { .footer-bottom { flex-direction: row; justify-content: space-between; } }
.footer-bottom p { color: var(--text-muted); font-size: 0.75rem; }

/* ── Single Post ── */
.back-link { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--text-secondary); font-size: 0.875rem; margin-bottom: 2rem; transition: color 0.2s; }
.back-link:hover { color: var(--gold); }
.single-meta { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.single-title { font-family: var(--font-serif); font-size: clamp(1.75rem, 4vw, 2.75rem); line-height: 1.2; margin-bottom: 1rem; }
.single-author { color: var(--text-muted); font-size: 0.875rem; margin-bottom: 2rem; }
.single-thumb { margin-bottom: 2.5rem; border-radius: var(--radius-xl); overflow: hidden; }
.single-thumb img { width: 100%; }
.prose { color: var(--text-secondary); font-size: 1.0625rem; line-height: 1.8; }
.prose h2, .prose h3, .prose h4 { color: var(--white); margin-top: 2rem; margin-bottom: 1rem; }
.prose p { margin-bottom: 1.25rem; }
.prose ul, .prose ol { margin-bottom: 1.25rem; padding-left: 1.5rem; }
.prose a { color: var(--gold); text-decoration: underline; }
.single-nav { display: flex; justify-content: space-between; gap: 1rem; margin-top: 4rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.single-nav-link { color: var(--text-secondary); font-size: 0.875rem; transition: color 0.2s; max-width: 45%; }
.single-nav-link:hover { color: var(--gold); }

/* ── Pagination ── */
.pagination { margin-top: 3rem; text-align: center; }
.pagination .nav-links { display: flex; justify-content: center; gap: 0.5rem; }
.pagination .page-numbers { padding: 0.5rem 1rem; border-radius: 0.5rem; background: var(--surface); border: 1px solid var(--border); color: var(--text-secondary); font-size: 0.875rem; transition: all 0.2s; }
.pagination .page-numbers.current, .pagination .page-numbers:hover { background: var(--gold-10); border-color: rgba(212,175,55,0.3); color: var(--gold); }

/* ── Scroll Animations ── */
.anim-fade-up { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.anim-fade-up.anim-visible { opacity: 1; transform: translateY(0); }

/* ── WordPress admin bar fix ── */
.admin-bar .nav-bar { top: 32px; }
@media (max-width: 782px) { .admin-bar .nav-bar { top: 46px; } }
