/* Pravya Writing — shared styles */
:root{
  --black:#000000;
  --white:#FFFFFF;
  --green:#22C55E;
  --green-dim:#16A34A;
  --gray:#E5E7EB;
  --gray-mid:#9CA3AF;
  --gray-dark:#374151;
  --text:#000000;
  --maxw:1180px;
  --r:14px;
  --space-d:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--text);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--space-d);line-height:1.08;letter-spacing:-0.02em;font-weight:700}
.eyebrow{
  font-family:var(--space-d);
  font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green-dim);
}
.eyebrow.on-dark{color:var(--green)}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--black);color:var(--white);
  border-bottom:1px solid #1a1a1a;
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:var(--space-d);font-weight:700;font-size:1.35rem;letter-spacing:-.02em;color:var(--white);display:flex;align-items:center;gap:.5rem}
.logo .mark{color:var(--green)}
.navlinks{display:flex;gap:30px;align-items:center}
.navlinks a{font-size:.95rem;font-weight:500;color:#d4d4d4;transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--green)}
.nav-cta{
  background:var(--green);color:var(--black)!important;
  padding:11px 20px;border-radius:999px;font-weight:600;font-size:.9rem;
  transition:transform .15s,background .2s;
}
.nav-cta:hover{background:var(--white);transform:translateY(-1px)}
.burger{display:none;background:none;border:0;color:var(--white);font-size:1.6rem;cursor:pointer}

/* ---------- HERO ---------- */
.hero{background:var(--black);color:var(--white);padding:96px 0 110px;position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:16ch}
.hero h1 .hl{color:var(--green)}
.hero p.lede{font-size:1.2rem;color:#c9c9c9;max-width:54ch;margin-top:24px}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.btn{
  display:inline-block;font-weight:600;border-radius:999px;padding:14px 26px;
  font-size:.98rem;cursor:pointer;border:2px solid transparent;transition:transform .15s,background .2s,color .2s;
}
.btn-green{background:var(--green);color:var(--black)}
.btn-green:hover{background:#fff;transform:translateY(-2px)}
.btn-ghost{border-color:#3a3a3a;color:#fff;background:transparent}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-dark{background:var(--black);color:#fff}
.btn-dark:hover{background:var(--green);color:var(--black);transform:translateY(-2px)}

/* signature: proof-mark ticks faint in hero bg */
.proof-bg{position:absolute;inset:0;z-index:1;opacity:.07;pointer-events:none}

/* ---------- TRUST BAR ---------- */
.trust{background:var(--green);color:var(--black)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:10px 44px;justify-content:center;padding:18px 24px;font-weight:600;font-size:.95rem}
.trust span{display:flex;align-items:center;gap:8px}

/* ---------- SECTIONS ---------- */
section{padding:84px 0}
.sec-head{max-width:60ch;margin-bottom:48px}
.sec-head h2{font-size:clamp(2rem,4vw,2.9rem);margin-top:12px}
.sec-head p{color:var(--gray-dark);font-size:1.08rem;margin-top:14px}
.alt{background:var(--gray)}

/* ---------- CARDS ---------- */
.grid{display:grid;gap:22px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--white);border:1.5px solid var(--gray);border-radius:var(--r);
  padding:30px 26px;transition:transform .18s,border-color .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-4px);border-color:var(--green);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.card .ico{
  width:48px;height:48px;border-radius:12px;background:var(--black);color:var(--green);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:18px;font-family:var(--space-d);font-weight:700;
}
.card h3{font-size:1.25rem;margin-bottom:10px}
.card p{color:var(--gray-dark);font-size:.97rem}
.card .more{display:inline-block;margin-top:16px;color:var(--green-dim);font-weight:600;font-size:.92rem}
.card .more:hover{text-decoration:underline}

/* pills */
.pill{display:inline-block;background:var(--black);color:var(--green);padding:7px 15px;border-radius:999px;font-size:.85rem;font-weight:600;margin:5px 6px 5px 0}
.pill.lite{background:var(--gray);color:var(--black)}

/* process steps */
.steps{counter-reset:s;display:grid;gap:22px;grid-template-columns:repeat(4,1fr)}
.step{position:relative;padding-top:18px}
.step .n{font-family:var(--space-d);font-weight:700;font-size:2.4rem;color:var(--green)}
.step h4{font-size:1.12rem;margin:6px 0 8px}
.step p{color:var(--gray-dark);font-size:.94rem}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat .num{font-family:var(--space-d);font-weight:700;font-size:3rem;color:var(--green-dim);line-height:1}
.stat .lbl{color:var(--gray-dark);font-size:.95rem;margin-top:8px}

/* check list */
.checks{list-style:none;display:grid;gap:12px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:1.02rem}
.checks li::before{content:"";flex:none;width:22px;height:22px;margin-top:3px;border-radius:6px;background:var(--green);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/68% no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/68% no-repeat;}

/* CTA band */
.cta-band{background:var(--black);color:var(--white);text-align:center;padding:80px 0}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);max-width:20ch;margin:0 auto}
.cta-band p{color:#c9c9c9;margin:16px auto 30px;max-width:50ch}

/* testimonials */
.quote{background:var(--white);border:1.5px solid var(--gray);border-left:5px solid var(--green);border-radius:var(--r);padding:28px}
.quote p{font-size:1.05rem;font-style:italic;color:var(--gray-dark)}
.quote .who{margin-top:16px;font-weight:600;font-family:var(--space-d);font-style:normal;color:var(--black)}
.quote .who small{display:block;color:var(--gray-mid);font-weight:400;font-family:var(--body)}

/* ---------- SERVICE HERO (sub pages) ---------- */
.svc-hero{background:var(--black);color:var(--white);padding:72px 0}
.svc-hero .crumb{font-size:.85rem;color:var(--gray-mid);margin-bottom:18px}
.svc-hero .crumb a:hover{color:var(--green)}
.svc-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);max-width:18ch}
.svc-hero p{color:#c9c9c9;font-size:1.15rem;max-width:55ch;margin-top:20px}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.plan{background:#fff;border:1.5px solid var(--gray);border-radius:var(--r);padding:34px 28px;position:relative}
.plan.feat{border:2px solid var(--green);box-shadow:0 14px 40px rgba(34,197,94,.18)}
.plan .tag{position:absolute;top:-13px;left:28px;background:var(--green);color:#000;font-weight:700;font-size:.78rem;padding:5px 14px;border-radius:999px}
.plan h3{font-size:1.4rem}
.plan .amt{font-family:var(--space-d);font-weight:700;font-size:2.6rem;margin:14px 0 4px}
.plan .amt small{font-size:.95rem;color:var(--gray-mid);font-weight:400;font-family:var(--body)}
.plan .usd{color:var(--gray-mid);font-size:.92rem;margin-bottom:22px}
.plan ul{list-style:none;display:grid;gap:11px;margin:22px 0}
.plan ul li{display:flex;gap:10px;font-size:.96rem}
.plan ul li::before{content:"✓";color:var(--green-dim);font-weight:700}
.plan .btn{width:100%;text-align:center}

/* timeline */
.timeline{position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--green)}
.tl-item{position:relative;padding-bottom:34px}
.tl-item::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--green);border:3px solid #fff;box-shadow:0 0 0 2px var(--green)}
.tl-item .yr{font-family:var(--space-d);font-weight:700;color:var(--green-dim)}
.tl-item h4{margin:4px 0 6px}
.tl-item p{color:var(--gray-dark);font-size:.97rem}

/* values / team */
.val{padding:26px;border:1.5px solid var(--gray);border-radius:var(--r);background:#fff}
.val .ico{font-size:1.8rem;margin-bottom:12px}
.val h4{font-size:1.15rem;margin-bottom:8px}
.val p{color:var(--gray-dark);font-size:.95rem}
.member{text-align:center}
.member .av{width:96px;height:96px;border-radius:50%;background:var(--black);color:var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--space-d);font-weight:700;font-size:2rem;margin:0 auto 14px}
.member h4{font-size:1.1rem}
.member span{color:var(--gray-mid);font-size:.9rem}

/* contact */
.cform{display:grid;gap:16px}
.cform label{font-weight:600;font-size:.92rem;font-family:var(--space-d)}
.cform input,.cform textarea,.cform select{
  width:100%;padding:13px 15px;border:1.5px solid var(--gray);border-radius:10px;font-family:var(--body);font-size:1rem;background:#fff;
}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.contact-line{display:flex;gap:14px;align-items:center;padding:18px 0;border-bottom:1px solid var(--gray)}
.contact-line .ci{width:46px;height:46px;flex:none;border-radius:12px;background:var(--black);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.contact-line b{font-family:var(--space-d)}
.contact-line a{color:var(--green-dim);font-weight:600}

/* blog */
.post{background:#fff;border:1.5px solid var(--gray);border-radius:var(--r);overflow:hidden;transition:transform .18s,border-color .2s}
.post:hover{transform:translateY(-4px);border-color:var(--green)}
.post .thumb{height:140px;background:var(--black);display:flex;align-items:center;justify-content:center;color:var(--green);font-family:var(--space-d);font-weight:700;font-size:1.1rem;padding:20px;text-align:center}
.post .body{padding:24px}
.post .cat{color:var(--green-dim);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}
.post h3{font-size:1.18rem;margin:8px 0 10px}
.post p{color:var(--gray-dark);font-size:.95rem}

/* faq */
.faq details{border:1.5px solid var(--gray);border-radius:12px;padding:18px 22px;margin-bottom:14px;background:#fff}
.faq summary{font-family:var(--space-d);font-weight:600;font-size:1.05rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between}
.faq summary::after{content:"+";color:var(--green-dim);font-size:1.5rem}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--gray-dark);margin-top:12px}

/* ---------- FOOTER ---------- */
.footer{background:var(--black);color:#c9c9c9;padding:64px 0 30px}
.footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.footer h5{color:#fff;font-family:var(--space-d);font-size:1rem;margin-bottom:16px}
.footer a{display:block;color:#9a9a9a;font-size:.93rem;padding:5px 0;transition:color .2s}
.footer a:hover{color:var(--green)}
.footer .brand{font-family:var(--space-d);font-weight:700;font-size:1.5rem;color:#fff}
.footer .brand .mark{color:var(--green)}
.footer .desc{margin-top:14px;max-width:34ch;font-size:.93rem}
.footer .bottom{border-top:1px solid #1f1f1f;margin-top:44px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.86rem;color:#777}

/* responsive */
@media(max-width:920px){
  .g4,.g3,.stats,.steps{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr}
  .footer .cols{grid-template-columns:1fr 1fr}
  .g2{grid-template-columns:1fr}
}
@media(max-width:680px){
  .navlinks{display:none;position:absolute;top:72px;left:0;right:0;background:var(--black);flex-direction:column;padding:18px 24px;gap:6px;border-bottom:1px solid #1f1f1f}
  .navlinks.open{display:flex}
  .navlinks a{padding:10px 0}
  .burger{display:block}
  .g4,.g3,.g2,.stats,.steps{grid-template-columns:1fr}
  section{padding:60px 0}
  .trust .wrap{gap:8px 22px;font-size:.85rem}
}
