/* ─── ADVISORY SERVICES ─── */
#advisory-services {
  padding: 160px 0;
  background: var(--bg);
  position: relative;
}
#advisory-services::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.adv-header {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: end;
  margin-bottom: 80px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--border);
}
.adv-header h2 {
  font-family: var(--serif);
  font-size: clamp(2.6rem, 4.5vw, 3.5rem);
  font-weight: 500; line-height: 1.05; letter-spacing: -0.02em;
}
.adv-header h2 em { color: var(--red); font-style: italic; }
.adv-header-right p {
  font-size: 1.05rem; line-height: 1.8; color: var(--muted);
  margin-bottom: 16px;
}
.adv-partner-label {
  font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--red); margin-bottom: 0; display: inline-flex; align-items: center; gap: 10px;
}
.adv-partner-label::before { content: ''; width: 24px; height: 1px; background: var(--red); display: block; }
.adv-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--border);
  border: 1px solid var(--border);
}
.adv-item {
  background: var(--surface);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 16px;
  transition: background 0.3s ease;
  position: relative; overflow: hidden;
}
.adv-item:hover { background: var(--surface2); }
.adv-item::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; background: var(--red);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.35s ease;
}
.adv-item:hover::after { transform: scaleX(1); }
.adv-item-num {
  font-family: var(--serif);
  font-size: 0.75rem; font-weight: 600;
  color: var(--red); letter-spacing: 0.1em;
}
.adv-item h4 {
  font-family: var(--serif);
  font-size: 1.05rem; font-weight: 600;
  color: var(--text); line-height: 1.3;
}
.adv-item-bg-num {
  font-family: var(--serif);
  font-size: 5rem; font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 1px rgba(200,33,59,0.07);
  position: absolute; bottom: -10px; right: 12px;
  user-select: none; line-height: 1;
}

/* ─── FAMILY OFFICE ADVISORY ─── */
#family-office {
  padding: 160px 0;
  background: var(--surface);
  position: relative;
}
#family-office::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
#family-office::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.foa-inner {
  display: grid; grid-template-columns: 1fr;
  gap: 50px; align-items: flex-start;
}
.foa-left h2 {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 4vw, 4.5rem);
  font-weight: 500; line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 28px;
}
.foa-left h2 em { color: var(--red); font-style: italic; }
.foa-left p {
  font-size: 1rem; line-height: 1.8; color: var(--muted);
  margin-bottom: 20px;
}
.foa-left p:last-of-type { margin-bottom: 36px; }
.foa-left-quote {
  border-left: 2px solid var(--red);
  padding: 20px 24px;
  background: var(--red-glow);
  font-family: var(--serif);
  font-size: 1rem; font-style: italic;
  color: var(--text); line-height: 1.6;
}
.foa-cards {
  display: flex; flex-direction: row; gap: 1px;
  background: var(--border); border: 1px solid var(--border);
}
.foa-card {
  background: var(--bg);
  padding: 44px 40px;
  display: flex; flex-direction: column; gap: 16px;
  transition: background 0.3s ease;
  position: relative; overflow: hidden;
}
.foa-card:hover { background: var(--surface2); }
.foa-card::after {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px; background: var(--red);
  transform: scaleY(0); transform-origin: top;
  transition: transform 0.4s ease;
}
.foa-card:hover::after { transform: scaleY(1); }
.foa-card-num {
  font-family: var(--serif);
  font-size: 2.8rem; font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 1px rgba(200,33,59,0.2);
  line-height: 1; user-select: none;
  transition: -webkit-text-stroke-color 0.3s ease;
}
.foa-card:hover .foa-card-num { -webkit-text-stroke-color: rgba(200,33,59,0.5); }
.foa-card-icon {
  width: 44px; height: 44px;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--muted);
  transition: border-color 0.3s ease, color 0.3s ease, background 0.3s ease;
}
.foa-card:hover .foa-card-icon { border-color: var(--red); color: var(--red); background: var(--red-glow); }
.foa-card h3 {
  font-family: var(--serif);
  font-size: 1.2rem; font-weight: 600; color: var(--text);
  line-height: 1.25;
}
.foa-card p { font-size: 0.92rem; line-height: 1.75; color: var(--muted); }
.foa-card-tag {
  font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--red); padding-top: 14px; border-top: 1px solid var(--border);
}

/* ─── DIVERSE OFFERINGS ─── */
#diverse-offerings {
  padding: 160px 0;
  background: var(--bg);
  position: relative;
}
#diverse-offerings::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.do-header {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: end;
  margin-bottom: 80px;
}
.do-header h2 {
  font-family: var(--serif);
  font-size: clamp(2.6rem, 4.5vw, 3.5rem);
  font-weight: 500; line-height: 1.05; letter-spacing: -0.02em;
}
.do-header h2 em { color: var(--red); font-style: italic; }
.do-header p { font-size: 1.05rem; line-height: 1.8; color: var(--muted); }
.do-list {
  display: flex; flex-direction: column; gap: 0;
  border: 1px solid var(--border);
}
.do-item {
  display: grid; grid-template-columns: 72px 1fr auto;
  align-items: center; gap: 32px;
  padding: 28px 40px;
  border-bottom: 1px solid var(--border);
  transition: background 0.25s ease;
  position: relative;
}
.do-item:last-child { border-bottom: none; }
.do-item:hover { background: var(--surface); }
.do-item::after {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px; background: var(--red);
  transform: scaleY(0); transform-origin: bottom;
  transition: transform 0.35s ease;
}
.do-item:hover::after { transform: scaleY(1); }
.do-item-num {
  font-family: var(--serif);
  font-size: 0.8rem; font-weight: 600;
  color: var(--red); letter-spacing: 0.12em;
  flex-shrink: 0;
}
.do-item h4 {
  font-family: var(--serif);
  font-size: 1.15rem; font-weight: 500;
  color: var(--text); line-height: 1.3;
}
.do-item-arrow {
  width: 36px; height: 36px;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); flex-shrink: 0;
  transition: border-color 0.3s ease, color 0.3s ease, background 0.3s ease;
}
.do-item:hover .do-item-arrow { border-color: var(--red); color: var(--red); background: var(--red-glow); }

/* ─── RUN. ACQUIRE. GROW. BAND ─── */
#rag-band {
  padding: 160px 0;
  background: var(--surface);
  position: relative;
}
#rag-band::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
#rag-band::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.rag-headline {
  max-width: 860px; margin: 0 auto 80px; text-align: center;
}
.rag-headline .section-label { justify-content: center; margin-bottom: 32px; }
.rag-headline blockquote {
  font-family: var(--serif);
  font-size: clamp(1.55rem, 2.8vw, 2.3rem);
  font-weight: 500; line-height: 1.4; color: var(--text); font-style: italic;
}
.rag-headline blockquote em { color: var(--red); font-style: italic; }
.rag-cols {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border); border: 1px solid var(--border);
}
.rag-col {
  background: var(--bg); padding: 52px 44px;
  display: flex; flex-direction: column; gap: 20px;
  transition: background 0.3s ease; position: relative; overflow: hidden;
}
.rag-col:hover { background: var(--surface2); }
.rag-col::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; background: var(--red);
  transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease;
}
.rag-col:hover::after { transform: scaleX(1); }
.rag-col-word {
  font-family: var(--serif); font-size: 4rem; font-weight: 700;
  color: transparent; -webkit-text-stroke: 1px rgba(255,255,255,0.08);
  line-height: 1; transition: -webkit-text-stroke-color 0.35s ease;
  user-select: none; letter-spacing: -0.02em;
}
.rag-col:hover .rag-col-word { -webkit-text-stroke-color: rgba(200,33,59,0.4); }
.rag-col-icon {
  width: 44px; height: 44px; border: 1px solid var(--border); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; color: var(--muted);
  transition: border-color 0.3s ease, color 0.3s ease, background 0.3s ease;
}
.rag-col:hover .rag-col-icon { border-color: var(--red); color: var(--red); background: var(--red-glow); }
.rag-col h3 { font-family: var(--serif); font-size: 1.25rem; font-weight: 600; color: var(--text); margin: 0; }
.rag-col p { font-size: 0.95rem; line-height: 1.75; color: var(--muted); flex: 1; }
.rag-col-tag {
  display: block; font-size: 0.68rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--red); padding-top: 16px; border-top: 1px solid var(--border); line-height: 1.8;
}
.rag-col-img { width: 100%; aspect-ratio: 3/2; overflow: hidden; }
.rag-col-img img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%) brightness(0.55) contrast(1.2); transition: transform 0.6s ease, filter 0.5s ease; }
.rag-col:hover .rag-col-img img { transform: scale(1.05); filter: grayscale(70%) brightness(0.65) contrast(1.2); }

/* ─── CTA ─── */
#cta {
  padding: 160px 0;
  background: var(--bg);
  position: relative; overflow: hidden;
}
#cta::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.cta-bg-text {
  position: absolute; bottom: -20px; left: -20px;
  font-family: var(--serif); font-size: clamp(100px, 14vw, 200px); font-weight: 700;
  color: transparent; -webkit-text-stroke: 1px rgba(200,33,59,0.25);
  white-space: nowrap; user-select: none; pointer-events: none; line-height: 1;
}
.cta-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center; position: relative; z-index: 1;
}
.cta-left h2 {
  font-family: var(--serif);
  font-size: clamp(2.8rem, 4.5vw, 5.5rem);
  font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 24px;
}
.cta-left h2 em { color: var(--red); font-style: italic; }
.cta-left p { font-size: 1rem; line-height: 1.8; color: var(--muted); }
.cta-right {
  display: flex; flex-direction: column; gap: 20px;
  padding-left: 60px; border-left: 1px solid var(--border);
}
.contact-item {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 24px; border: 1px solid var(--border);
  transition: border-color 0.3s ease, background 0.3s ease;
}
.contact-item:hover { border-color: rgba(200,33,59,0.3); background: var(--red-glow); }
.contact-item-icon {
  width: 40px; height: 40px; flex-shrink: 0;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; color: var(--red);
}
.contact-item-text .label {
  font-size: 0.65rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 4px;
}
.contact-item-text .value { font-size: 1rem; color: var(--text); }
.cta-actions { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }

/* ─── Responsive (services-specific) ─── */
@media (max-width: 1100px) {
  #advisory-services, #family-office, #diverse-offerings, #rag-band, #cta { padding: 120px 0; }
  .adv-header { grid-template-columns: 1fr; gap: 40px; }
  .adv-grid { grid-template-columns: repeat(2, 1fr); }
  .foa-inner { grid-template-columns: 1fr; gap: 60px; }
  .do-header { grid-template-columns: 1fr; gap: 32px; }
  .rag-headline { margin-bottom: 56px; }
  .rag-cols { grid-template-columns: 1fr; }
  .rag-col { padding: 40px 32px; }
  .reveal-bottom-left { opacity: 1 !important; transform: translateX(0) translateY(0) scale(1) !important; }
}
@media (max-width: 768px) {
  #advisory-services, #family-office, #diverse-offerings, #rag-band, #cta { padding: 80px 0; }
  .adv-grid { grid-template-columns: 1fr 1fr; }
  .do-item { grid-template-columns: 48px 1fr; padding: 22px 24px; }
  .do-item-arrow { display: none; }
}
@media (max-width: 480px) {
  #advisory-services, #family-office, #diverse-offerings, #rag-band, #cta { padding: 60px 0; }
  .page-hero-content { padding-top: 88px; }
  .adv-grid { grid-template-columns: 1fr; }
  .rag-col { padding: 32px 24px; }
  .rag-col-word { font-size: 3rem; }
  .do-item { padding: 20px; gap: 16px; }
  .do-item h4 { font-size: 1rem; }
}
