/* ============================================
   J&J Capital Private Limited — Stylesheet
   ============================================ */

:root{
  --gold: #de9d14;
  --gold-dark: #b9810c;
  --navy: #16243c;
  --navy-soft: #24385c;
  --paper: #ffffff;
  --cream: #faf8f4;
  --ink: #232323;
  --ink-soft: #5a5f6b;
  --line: #e8e3da;
  --radius: 2px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', -apple-system, Segoe UI, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}

.container{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:0 28px;
}

h1,h2,h3,h4{
  font-family: var(--font-display);
  font-weight:700;
  color: var(--navy);
  line-height:1.18;
}

.eyebrow{
  font-family: var(--font-body);
  font-size:0.78rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: var(--gold-dark);
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:28px;
  height:1px;
  background: var(--gold);
  display:inline-block;
}

/* ============== HEADER (fixed) ============== */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:1000;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  transition: box-shadow .3s ease, padding .3s ease;
}
.site-header.scrolled{
  box-shadow: 0 6px 24px rgba(22,36,60,0.08);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 28px;
  max-width:1180px;
  margin:0 auto;
}

.brand{
  display:flex;
  align-items:center;
}
.brand-logo{
  height:50px;
  width:auto;
  max-width:180px;
  object-fit:contain;
  display:block;
}

.main-nav ul{
  display:flex;
  gap:38px;
}
.main-nav a{
  font-size:0.92rem;
  font-weight:500;
  color: var(--navy);
  position:relative;
  padding:6px 0;
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0;
  height:2px;
  background: var(--gold);
  transition: width .25s ease;
}
.main-nav a:hover::after,
.main-nav a.active::after{
  width:100%;
}
.main-nav a.active{ color: var(--gold-dark); }

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:6px;
}
.nav-toggle span{
  width:24px; height:2px;
  background: var(--navy);
  transition: all .3s ease;
}

/* ============== HERO ============== */
.hero{
  padding:168px 0 96px;
  background:
    radial-gradient(ellipse at top right, rgba(222,157,20,0.07), transparent 55%),
    var(--cream);
  position:relative;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap:60px;
  align-items:center;
}
.hero h1{
  font-size: clamp(2.3rem, 4.2vw, 3.4rem);
  margin: 18px 0 22px;
}
.hero h1 .accent{ color: var(--gold-dark); font-style:italic; }
.hero p.lead{
  font-size:1.08rem;
  color: var(--ink-soft);
  max-width: 540px;
  margin-bottom: 32px;
}
.hero-cta{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 28px;
  font-size:0.92rem;
  font-weight:600;
  border-radius: var(--radius);
  border:1.5px solid transparent;
  cursor:pointer;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn-primary{
  background: var(--navy);
  color:#fff;
}
.btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(22,36,60,0.25);
  background: var(--navy-soft);
}
.btn-ghost{
  border-color: var(--navy);
  color: var(--navy);
  background:transparent;
}
.btn-ghost:hover{
  border-color: var(--gold);
  color: var(--gold-dark);
  transform: translateY(-2px);
}

/* Hero growth-line visual (signature element) */
.hero-visual{
  position:relative;
  height:340px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.growth-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:4px;
  padding:26px 26px 18px;
  box-shadow: 0 24px 60px rgba(22,36,60,0.12);
  width:100%;
  max-width:420px;
}
.growth-card-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:14px;
}
.growth-card-head span{
  font-size:0.72rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color: var(--ink-soft);
}
.growth-card-head strong{
  font-family: var(--font-display);
  color: var(--navy);
  font-size:1.4rem;
}
.growth-path{
  fill:none;
  stroke: var(--gold);
  stroke-width:2.5;
  stroke-linecap:round;
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: drawLine 2.2s ease forwards 0.4s;
}
.growth-area{
  fill: url(#goldFade);
  opacity:0;
  animation: fadeIn 1.2s ease forwards 1.6s;
}
.growth-dot{
  fill: var(--gold-dark);
  opacity:0;
  animation: popIn .5s ease forwards;
}
@keyframes drawLine{ to{ stroke-dashoffset:0; } }
@keyframes fadeIn{ to{ opacity:1; } }
@keyframes popIn{ to{ opacity:1; } }

.trust-row{
  display:flex;
  gap:34px;
  margin-top:36px;
  padding-top:28px;
  border-top:1px solid var(--line);
  flex-wrap:wrap;
}
.trust-row div{ font-size:0.82rem; color: var(--ink-soft); }
.trust-row strong{
  display:block;
  font-family: var(--font-display);
  font-size:1.5rem;
  color: var(--navy);
}

/* ============== Reveal-on-scroll ============== */
.reveal{
  opacity:0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.in-view{
  opacity:1;
  transform:none;
}
.reveal.delay-1{ transition-delay:.1s; }
.reveal.delay-2{ transition-delay:.2s; }
.reveal.delay-3{ transition-delay:.3s; }
.reveal.delay-4{ transition-delay:.4s; }

/* ============== Section generic ============== */
section{ padding: 88px 0; }
.section-head{
  max-width:620px;
  margin-bottom:48px;
}
.section-head h2{
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  margin-top:14px;
}
.section-head p{
  color: var(--ink-soft);
  margin-top:14px;
  font-size:1.02rem;
}
.section-alt{ background: var(--cream); }

/* ============== Cards / Grid ============== */
.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.grid-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:4px;
  padding:34px 28px;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.card:hover{
  transform: translateY(-6px);
  box-shadow: 0 20px 44px rgba(22,36,60,0.1);
  border-color: rgba(222,157,20,0.4);
}
.card .num{
  font-family: var(--font-display);
  font-size:0.85rem;
  color: var(--gold-dark);
  letter-spacing:0.08em;
}
.card h3{
  font-size:1.18rem;
  margin:12px 0 10px;
}
.card p{ color: var(--ink-soft); font-size:0.94rem; }
.card-icon{
  width:46px;height:46px;
  border-radius:50%;
  background: rgba(222,157,20,0.12);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
  color: var(--gold-dark);
}

/* ============== Pillars / value strip ============== */
.value-strip{
  display:flex;
  gap:0;
  border:1px solid var(--line);
  border-radius:4px;
  overflow:hidden;
}
.value-strip > div{
  flex:1;
  padding:30px 26px;
  border-right:1px solid var(--line);
}
.value-strip > div:last-child{ border-right:none; }
.value-strip h4{
  font-size:1rem;
  margin-bottom:8px;
}
.value-strip p{ font-size:0.86rem; color: var(--ink-soft); }

/* ============== Disclaimer banner ============== */
.disclaimer{
  background: var(--navy);
  color:#fff;
  border-radius:4px;
  padding:30px 32px;
  display:flex;
  gap:20px;
  align-items:flex-start;
  border-left:4px solid var(--gold);
}
.disclaimer svg{ flex-shrink:0; margin-top:3px; color: var(--gold); }
.disclaimer h4{ color:#fff; font-size:1rem; margin-bottom:8px; }
.disclaimer p{ color: rgba(255,255,255,0.78); font-size:0.9rem; }

/* ============== About page specifics ============== */
.timeline-fact{
  display:flex;
  align-items:center;
  gap:22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:4px;
  padding:26px 30px;
  margin-bottom:18px;
}
.timeline-fact .icon{
  width:48px;height:48px;
  border-radius:50%;
  background: var(--navy);
  color: var(--gold);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.timeline-fact h4{ font-size:0.78rem; text-transform:uppercase; letter-spacing:0.08em; color: var(--ink-soft); margin-bottom:4px;}
.timeline-fact p{ font-family: var(--font-display); font-size:1.15rem; color: var(--navy); }

.director-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.director-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:4px;
  padding:28px 24px;
  text-align:left;
  transition: transform .3s ease, box-shadow .3s ease;
}
.director-card:hover{
  transform: translateY(-5px);
  box-shadow: 0 18px 38px rgba(22,36,60,0.1);
}
.director-avatar{
  width:56px;height:56px;
  border-radius:50%;
  background: linear-gradient(135deg, var(--navy), var(--navy-soft));
  color: var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family: var(--font-display);
  font-size:1.2rem;
  margin-bottom:16px;
}
.director-card h3{ font-size:1.05rem; margin-bottom:10px; }
.director-card .d-meta{ font-size:0.85rem; color: var(--ink-soft); display:flex; flex-direction:column; gap:6px;}
.director-card .d-meta a{ color: var(--navy); }
.director-card .d-meta a:hover{ color: var(--gold-dark); }

.mission-vision{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
}
.mv-card{
  padding:36px 32px;
  border-radius:4px;
  border:1px solid var(--line);
}
.mv-card.gold{
  background: var(--navy);
  color:#fff;
}
.mv-card.gold h3{ color: var(--gold); }
.mv-card.gold p{ color: rgba(255,255,255,0.78); }
.mv-card h3{ margin-bottom:14px; font-size:1.3rem; }
.mv-card p{ color: var(--ink-soft); }

/* ============== Services page ============== */
.status-banner{
  text-align:center;
  padding:64px 0 20px;
}
.status-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background: rgba(222,157,20,0.1);
  border:1px solid rgba(222,157,20,0.35);
  color: var(--gold-dark);
  padding:8px 18px;
  border-radius:30px;
  font-size:0.82rem;
  font-weight:600;
  letter-spacing:0.03em;
  margin-bottom:22px;
}
.status-pill .dot{
  width:8px;height:8px;
  border-radius:50%;
  background: var(--gold);
  animation: pulse 1.8s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(222,157,20,0.5); }
  70%{ box-shadow:0 0 0 10px rgba(222,157,20,0); }
  100%{ box-shadow:0 0 0 0 rgba(222,157,20,0); }
}

.future-services{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.future-service{
  display:flex;
  gap:18px;
  padding:26px;
  border:1px dashed var(--line);
  border-radius:4px;
  position:relative;
  opacity:0.92;
}
.future-service .tag{
  position:absolute;
  top:14px; right:14px;
  font-size:0.62rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  background: var(--cream);
  border:1px solid var(--line);
  color: var(--ink-soft);
  padding:3px 8px;
  border-radius:20px;
}
.future-service .icon{
  width:42px;height:42px;
  border-radius:50%;
  background: rgba(22,36,60,0.06);
  display:flex;align-items:center;justify-content:center;
  color: var(--navy);
  flex-shrink:0;
}
.future-service h4{ font-size:1rem; margin-bottom:6px; }
.future-service p{ font-size:0.86rem; color: var(--ink-soft); }

.process-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  position:relative;
}
.process-steps::before{
  content:"";
  position:absolute;
  top:23px; left:8%; right:8%;
  height:1px;
  background: var(--line);
}
.process-step{
  text-align:center;
  position:relative;
  padding:0 14px;
}
.process-step .circ{
  width:46px;height:46px;
  border-radius:50%;
  background:#fff;
  border:2px solid var(--gold);
  color: var(--gold-dark);
  display:flex;align-items:center;justify-content:center;
  font-family: var(--font-display);
  font-weight:700;
  margin:0 auto 16px;
  position:relative;
  z-index:1;
}
.process-step.done .circ{ background: var(--gold); color:#fff; }
.process-step h4{ font-size:0.92rem; margin-bottom:6px; color: var(--navy); }
.process-step p{ font-size:0.8rem; color: var(--ink-soft); }

/* ============== Contact page ============== */
.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:40px;
}
.contact-info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:4px;
  padding:30px 28px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  margin-bottom:18px;
}
.contact-info-card .icon{
  width:44px;height:44px;
  border-radius:50%;
  background: rgba(222,157,20,0.12);
  color: var(--gold-dark);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.contact-info-card h4{ font-size:0.95rem; margin-bottom:6px; color: var(--navy); font-family:var(--font-display);}
.contact-info-card p, .contact-info-card a{ font-size:0.9rem; color: var(--ink-soft); }
.contact-info-card a:hover{ color: var(--gold-dark); }

.map-frame{
  width:100%;
  height:100%;
  min-height:380px;
  border-radius:4px;
  overflow:hidden;
  border:1px solid var(--line);
}
.map-frame iframe{ width:100%; height:100%; min-height:380px; border:0; filter: grayscale(15%); }

/* ============== Footer ============== */
.site-footer{
  background: var(--navy);
  color: rgba(255,255,255,0.85);
  padding:64px 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
  font-family: var(--font-display);
  font-size:1.2rem;
  color:#fff;
}
.footer-grid p{ font-size:0.88rem; color: rgba(255,255,255,0.6); max-width:320px; }
.footer-col h4{
  color: var(--gold);
  font-family: var(--font-body);
  font-size:0.78rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.footer-col ul li{ margin-bottom:11px; }
.footer-col a{ font-size:0.9rem; color: rgba(255,255,255,0.72); transition:color .2s; }
.footer-col a:hover{ color: var(--gold); }
.footer-col .fc-item{
  display:flex;
  gap:10px;
  font-size:0.88rem;
  color: rgba(255,255,255,0.72);
  margin-bottom:14px;
  align-items:flex-start;
}
.footer-col .fc-item svg{ flex-shrink:0; margin-top:3px; color: var(--gold); }
.footer-bottom{
  padding:24px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  font-size:0.8rem;
  color: rgba(255,255,255,0.45);
}

/* ============== Responsive ============== */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero{ padding-top:140px; }
  .grid-3, .director-grid, .future-services, .mission-vision, .contact-grid, .footer-grid{ grid-template-columns:1fr 1fr; }
  .process-steps{ grid-template-columns:1fr 1fr; gap:32px 0; }
  .process-steps::before{ display:none; }
}
@media (max-width: 760px){
  .main-nav{
    position:fixed;
    top:78px; left:0; right:0;
    background:#fff;
    border-bottom:1px solid var(--line);
    flex-direction:column;
    padding:10px 28px 26px;
    transform: translateY(-130%);
    opacity:0;
    transition: all .3s ease;
    box-shadow: 0 14px 30px rgba(22,36,60,0.08);
  }
  .main-nav.open{ transform:translateY(0); opacity:1; }
  .main-nav ul{ flex-direction:column; gap:6px; }
  .main-nav a{ display:block; padding:12px 0; border-bottom:1px solid var(--line); }
  .nav-toggle{ display:flex; }
  .grid-3, .grid-2, .director-grid, .future-services, .mission-vision, .contact-grid, .footer-grid, .value-strip{ grid-template-columns:1fr; }
  .value-strip > div{ border-right:none; border-bottom:1px solid var(--line); }
  .value-strip > div:last-child{ border-bottom:none; }
  .process-steps{ grid-template-columns:1fr; }
  .trust-row{ gap:24px; }
}