/* ============================================================
   SERVICES PAGE — Premium Styles (V2)
   ============================================================ */

/* ---------- Hero Video ---------- */
.services-hero .hero-video-bg video { width:100%;height:100%;object-fit:cover; }
.services-hero .hero-overlay { background: linear-gradient(160deg, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.5) 50%, rgba(0,0,0,0.8) 100%); }

/* ---------- Shared Pillar Styles ---------- */
.pillar-section { position: relative; overflow: hidden; }
.pillar-dark { background: linear-gradient(160deg, #0f0d08 0%, #151008 40%, #110e06 100%); }
.pillar-light { background: linear-gradient(160deg, #0a0a0a 0%, #111 50%, #0e0e0e 100%); }

/* Background glows for dark pillars */
.pillar-bg-glow { position:absolute;inset:0;pointer-events:none;z-index:0; }
.p-glow { position:absolute;border-radius:50%;filter:blur(120px); }
.p-glow-1 { width:500px;height:500px;background:rgba(212,175,55,0.06);top:-100px;right:-100px;animation:ambientPulse 8s ease-in-out infinite; }
.p-glow-2 { width:400px;height:400px;background:rgba(180,130,40,0.05);bottom:-100px;left:-100px;animation:ambientPulse 10s ease-in-out infinite;animation-delay:-3s; }
@keyframes ambientPulse { 0%,100%{opacity:0.4;transform:scale(1);} 50%{opacity:0.8;transform:scale(1.1);} }

.pillar-section .container { position:relative;z-index:1; }

/* Pillar Header */
.pillar-header { margin-bottom: 48px; }
.pillar-header h2 { margin-bottom: 16px; }
.pillar-header > p { max-width: 700px; }

.pillar-number-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(212,175,55,0.15), rgba(212,175,55,0.05));
  border: 1px solid rgba(212,175,55,0.2);
  font-family: var(--font-heading); font-size: 1.2rem; font-weight: 800;
  color: var(--gold); margin-bottom: 16px;
}

/* ---------- Pillar 1 — Split Layout ---------- */
.pillar-split {
  display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: start;
}

.pillar-image-wrap {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
}
.pillar-image-wrap img {
  width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--radius-lg);
  transition: transform 0.6s var(--ease-out-expo);
}
.pillar-image-wrap:hover img { transform: scale(1.03); }
.pillar-image-wrap::after {
  content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  border:1px solid var(--gold-20);pointer-events:none;
}
.pillar-image-accent {
  position:absolute;bottom:-16px;right:-16px;width:180px;height:180px;
  border:2px solid rgba(212,175,55,0.1);border-radius:var(--radius-lg);
  pointer-events:none;z-index:-1;
}

/* Stacked cards */
.pillar-cards-stack { display:flex;flex-direction:column;gap:18px; }

.p-stack-card {
  display:flex;gap:20px;align-items:flex-start;
  padding:28px;border-radius:16px;
  background:rgba(20,16,8,0.5);backdrop-filter:blur(16px);
  border:1px solid rgba(212,175,55,0.08);
  transition:all 0.5s cubic-bezier(0.16,1,0.3,1);
}
.p-stack-card:hover {
  border-color:rgba(212,175,55,0.25);transform:translateX(8px);
  box-shadow:0 16px 48px rgba(0,0,0,0.4);
}
.p-stack-icon { font-size:2rem;flex-shrink:0;line-height:1;margin-top:2px; }
.p-stack-card h4 { font-family:var(--font-body);font-weight:600;font-size:1.05rem;margin-bottom:8px; }
.p-stack-card p { font-size:0.88rem;color:var(--text-muted);line-height:1.6; }

/* ---------- Journey Timeline ---------- */
.journey-timeline { margin-top:60px; }
.journey-timeline > h3 { font-size:1.3rem;margin-bottom:32px;text-align:center; }

.timeline-track { position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px; }

.timeline-line {
  position:absolute;top:28px;left:10%;right:10%;height:2px;
  background:linear-gradient(90deg,rgba(212,175,55,0.1),var(--gold),rgba(212,175,55,0.1));
  z-index:0;
}

.timeline-node { text-align:center;position:relative;z-index:1; }

.timeline-dot {
  width:56px;height:56px;margin:0 auto 20px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#151008,#0f0d08);
  border:2px solid var(--gold);border-radius:50%;
  font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--gold);
  box-shadow:0 0 30px rgba(212,175,55,0.15);
  transition:all 0.4s ease;
}
.timeline-node:hover .timeline-dot {
  background:var(--gold);color:#0f0d08;
  box-shadow:0 0 40px rgba(212,175,55,0.4);transform:scale(1.1);
}

.timeline-card h4 { font-family:var(--font-body);font-weight:600;font-size:0.95rem;margin-bottom:6px; }
.timeline-card p { font-size:0.82rem;color:var(--text-muted);max-width:220px;margin:0 auto; }

/* ---------- Pillar 2 — Bento Grid ---------- */
.pillar-bento {
  display:grid;grid-template-columns:1.2fr 1fr;grid-template-rows:auto auto;gap:20px;
}
.pillar-bento-img {
  grid-row:1/3;border-radius:20px;overflow:hidden;position:relative;
}
.pillar-bento-img img {
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s var(--ease-out-expo);
}
.pillar-bento-img:hover img { transform:scale(1.04); }
.pillar-bento-img::after {
  content:'';position:absolute;inset:0;border-radius:20px;
  border:1px solid rgba(212,175,55,0.1);pointer-events:none;
}

.pillar-bento-card {
  padding:32px;border-radius:18px;
  background:rgba(15,15,15,0.6);backdrop-filter:blur(16px);
  border:1px solid rgba(212,175,55,0.08);
  transition:all 0.5s cubic-bezier(0.16,1,0.3,1);
}
.pillar-bento-card:hover {
  border-color:rgba(212,175,55,0.25);transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,0.3);
}
.pillar-bento-card h4 { font-family:var(--font-body);font-weight:600;font-size:1.05rem;margin-bottom:10px;color:var(--gold); }
.pillar-bento-card p { font-size:0.88rem;color:var(--text-muted);line-height:1.6; }
.pillar-bento-wide { grid-column:1/-1; }

/* Ideal For Pills */
.ideal-grid { margin-top:48px; }
.ideal-heading { font-family:var(--font-body);font-weight:600;color:var(--gold);margin-bottom:16px; }
.ideal-pills { display:flex;flex-wrap:wrap;gap:10px; }
.ideal-pill {
  padding:10px 22px;border-radius:100px;font-size:0.85rem;font-weight:500;
  background:rgba(212,175,55,0.06);border:1px solid rgba(212,175,55,0.15);
  color:var(--text-secondary);
  transition:all 0.3s ease;
}
.ideal-pill:hover {
  background:var(--gold);color:#0f0d08;border-color:var(--gold);
  box-shadow:0 4px 16px rgba(212,175,55,0.3);
}

/* ---------- Pillar 3 — Premium Recovery Suite ---------- */
.recovery-premium {
  padding: 140px 0;
}
.recovery-suite-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  margin-top: 60px;
}

.recovery-visual-side {
  position: relative;
}

.recovery-hero-img {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 40px 100px rgba(0,0,0,0.8);
}

.recovery-hero-img img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  filter: contrast(1.1) brightness(0.85);
}

.img-overlay-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,13,8,0.9), transparent 50%);
}

.recovery-benefits-panel {
  position: absolute;
  bottom: -40px;
  right: -40px;
  background: rgba(15,15,15,0.8);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(212,175,55,0.15);
  padding: 40px;
  border-radius: 24px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.6);
  z-index: 2;
  min-width: 320px;
}

.recovery-benefits-panel h3 {
  font-size: 1.2rem;
  color: var(--gold);
  margin-bottom: 20px;
}

.rb-premium-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.rb-premium-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.95rem;
  color: #fff;
}

.rb-check {
  color: #0f0d08;
  background: var(--gold);
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: bold;
}

.recovery-cards-side {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.rc-glass-card {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  padding: 32px;
  background: rgba(20,16,8,0.4);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(212,175,55,0.08);
  border-radius: 20px;
  transition: all 0.5s cubic-bezier(0.16,1,0.3,1);
}

.rc-glass-card:hover {
  transform: translateX(-16px);
  border-color: rgba(212,175,55,0.3);
  background: rgba(20,16,8,0.7);
  box-shadow: 0 20px 40px rgba(0,0,0,0.5), inset 0 0 20px rgba(212,175,55,0.05);
}

.rc-card-icon {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(212,175,55,0.1), transparent);
  border: 1px solid rgba(212,175,55,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}

.rc-card-icon svg { width: 32px; height: 32px; }

.rc-card-content h4 {
  font-size: 1.2rem;
  color: #fff;
  margin-bottom: 8px;
}

.rc-card-content p {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
}

/* ---------- Pillar 4 — Premium Nutrition Showcase ---------- */
.nutrition-premium {
  position: relative;
  padding: 160px 0;
  overflow: hidden;
}

.nutrition-bg-image {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.nutrition-bg-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(80%) brightness(0.3);
}

.nutrition-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(10,10,10,0.95) 0%, rgba(10,10,10,0.8) 50%, rgba(10,10,10,0.95) 100%);
}

.nutrition-premium .container {
  position: relative;
  z-index: 2;
}

.nutrition-culinary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 60px;
}

.ncg-item {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  min-height: 320px;
  display: flex;
  align-items: flex-end;
  padding: 40px;
  border: 1px solid rgba(212,175,55,0.1);
  transition: all 0.5s ease;
}

.ncg-item.ncg-large {
  grid-column: span 2;
}

.ncg-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(20,20,20,0.8), rgba(10,10,10,0.95));
  z-index: 0;
  transition: all 0.5s ease;
}

.ncg-item:hover {
  transform: translateY(-8px);
  border-color: rgba(212,175,55,0.4);
  box-shadow: 0 30px 60px rgba(0,0,0,0.8);
}

.ncg-item:hover .ncg-bg {
  background: linear-gradient(135deg, rgba(30,25,15,0.9), rgba(10,10,10,0.95));
}

.ncg-content {
  position: relative;
  z-index: 1;
}

.ncg-icon {
  font-size: 2.5rem;
  margin-bottom: 24px;
  background: rgba(212,175,55,0.1);
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  border: 1px solid rgba(212,175,55,0.2);
}

.ncg-content h4 {
  font-size: 1.5rem;
  color: var(--gold);
  margin-bottom: 12px;
}

.ncg-content p {
  font-size: 1rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.6;
}

.plans-showcase-premium {
  margin-top: 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  background: rgba(15,15,15,0.6);
  backdrop-filter: blur(20px);
  border-radius: 32px;
  padding: 60px;
  border: 1px solid rgba(255,255,255,0.05);
}

.plans-sp-content h3 {
  font-size: 2rem;
  color: #fff;
  margin-bottom: 16px;
}

.plans-sp-content p {
  font-size: 1.1rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
}

.plans-sp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.plan-card-premium {
  background: rgba(0,0,0,0.4);
  padding: 24px;
  border-radius: 20px;
  border: 1px solid rgba(212,175,55,0.08);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all 0.3s ease;
}

.plan-card-premium:hover {
  background: rgba(212,175,55,0.05);
  border-color: rgba(212,175,55,0.2);
  transform: translateY(-4px);
}

.pc-icon {
  font-size: 1.8rem;
  background: rgba(255,255,255,0.03);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
}

.plan-card-premium h4 {
  font-size: 1.1rem;
  color: #fff;
  margin-bottom: 6px;
}

.plan-card-premium span {
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* ---------- Closing CTA — Video Background ---------- */
.cta-section { position:relative;text-align:center;overflow:hidden;min-height:60vh;display:flex;align-items:center; }
.cta-video-bg { position:absolute;inset:0;z-index:0; }
.cta-video-bg video { width:100%;height:100%;object-fit:cover; }
.cta-video-overlay { position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,0,0,0.82) 0%,rgba(10,10,10,0.7) 40%,rgba(0,0,0,0.85) 100%); }
.cta-section .container { position:relative;z-index:1; }
.cta-section h2 { max-width:600px;margin:0 auto 20px; }
.cta-section p { margin:0 auto 36px;text-align:center; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
  .pillar-split { grid-template-columns:1fr;gap:36px; }
  .pillar-image-wrap { max-width:500px; }
  .timeline-track { grid-template-columns:repeat(2,1fr); }
  .timeline-line { display:none; }
  .pillar-bento { grid-template-columns:1fr; }
  .pillar-bento-img { grid-row:auto;max-height:400px; }
  
  .recovery-suite-layout { grid-template-columns: 1fr; gap: 40px; }
  .recovery-benefits-panel { position: relative; bottom: 0; right: 0; margin-top: -40px; width: 100%; border-radius: 0 0 24px 24px; }
  
  .nutrition-culinary-grid { grid-template-columns: 1fr; }
  .ncg-item.ncg-large { grid-column: 1; }
  .plans-showcase-premium { grid-template-columns: 1fr; gap: 40px; padding: 40px; }
}

@media (max-width:768px) {
  .timeline-track { grid-template-columns:1fr;max-width:320px;margin:0 auto; }
  .ideal-pills { justify-content:center; }
  
  .plans-sp-grid { grid-template-columns: 1fr; }
  .rc-glass-card { flex-direction: column; align-items: center; text-align: center; }
}
