/* =======================
   Services Page Specific
   ======================= */

/* -------- Hero -------- */
/* Service page special gradient */
/* Service page special gradient with glow */
.service-gradient {
  background: linear-gradient(
    90deg,
    #20e3b2 0%,   /* teal */
    #36c6ff 25%,  /* cyan */
    #3c7aff 50%,  /* blue */
    #a66bff 75%,  /* purple */
    #ff7a59 100%  /* coral */
  );
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent !important;
  font-weight: 800;
  display: inline-block;

  /* Glow */
  text-shadow: 0 0 10px rgba(255,255,255,0.35),
               0 0 20px rgba(255,255,255,0.25);

  /* Extra breathing room so shadow doesn’t overlap */
  padding-bottom: 8px;
}



/* Center hero content */
.service-hero {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: 100vh; /* full screen hero */
  overflow: hidden;
  color: #fff;
}
.service-hero .stars{
  color: #f5b300;
}


.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;  /* makes video cover whole section */
  z-index: -1;        /* sends video behind text */
}

.service-container {
  position: relative; /* keeps text above video */
  z-index: 1;
  max-width: 800px;
  margin: 0 auto;
}



.service-hero .hero-content {
  max-width: 800px;
}


.service-hero h1 {
  font-size: clamp(2.5rem, 4vw + 1rem, 3.8rem);
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 20px;
}

.service-hero p {
  font-size: 1.1rem;
  color: var(--muted);
  margin: 0 auto 28px;
  max-width: 620px;
}

.service-hero .cta-button {
  font-size: 1.05rem;
  display: inline-block;
  background-color: var(--brand, #38e6c1);
  color: #000;
  font-weight: 800;
  padding: 10px 18px;
  border-radius: 10px;
  text-decoration: none;
  transition: background-color .3s, box-shadow .3s, transform .3s;
  box-shadow: 0 0 8px var(--brand, #38e6c1);
}
.service-hero .cta-button:hover{
  background-color: var(--brand, #38e6c1);
  box-shadow: 0 0 15px var(--brand-200, #5cd0b8), 0 0 25px var(--brand-200, #5cd0b8);
  transform: scale(1.05);
}

/* -------- Overview Section (Light) -------- */
.service-overview {
  background: #fff;
  color: var(--soft-black);
  padding: clamp(70px, 8vw, 100px) 20px;
}
.rounded-rocket {
  border-radius: 20px;   /* makes corners rounded */
}


.service-overview__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  gap: clamp(28px, 4vw, 48px);
}

@media (min-width: 960px) {
  .service-overview__inner {
    grid-template-columns: 0.95fr 1.05fr; /* image | content */
    align-items: center;
  }
}

.service-overview__media img {
  width: 100%;
  height: auto;
  display: block;
}

.service-overview__content h2 {
  font-size: clamp(2rem, 2.5vw + 1rem, 3.2rem);
  font-weight: 800;
  margin: 0 0 16px;
  color: #111;
}

.service-overview__content p {
  font-weight: 400;
  font-size: 1.05rem;
  line-height: 1.7;
  margin: 0 0 14px;
  color: var(--soft-text);
}

/* -------- Packages (Dark cards) -------- */
.service-packages {
  background:#0d1117;
  color:var(--text);
  padding: clamp(70px, 8vw, 100px) 20px clamp(90px, 10vw, 140px);
}

.service-packages__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}

.service-packages h2 {
  font-size: clamp(2rem, 2.5vw + 1rem, 3rem);
  font-weight: 800;
  margin: 0 0 20px;
  text-align: center;
}

.service-packages p.sub {
  color: var(--muted);
  text-align: center;
  margin-bottom: 40px;
}

/* grid for 3 package cards */
.service-cards {
  display: grid;
  gap: 20px;
}
@media (min-width: 700px) {
  .service-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .service-cards { grid-template-columns: repeat(3, 1fr); }
}

/* package card */
.service-card {
  background:#121922;
  border:1px solid var(--ring);
  border-radius: var(--radius-lg);
  padding:28px;
  box-shadow:0 8px 28px rgba(0,0,0,.28);
  display:flex;
  flex-direction:column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(56,230,193,.3);
  border-color: var(--accent);
}

.service-card h3 { font-size:1.3rem; font-weight:800; margin:10px 0; }
.service-card p { flex-grow:1; color:var(--muted); }
.service-card ul { list-style:none; padding:0; margin:14px 0; }
.service-card ul li { display:flex; align-items:center; gap:8px; }
.service-card ul li::before { content:"✓"; color:var(--accent); font-weight:800; }

.service-card .card-cta {
  margin-top:auto; align-self:flex-start;
  padding:10px 16px; border-radius:10px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  color:#06251c; text-decoration:none; font-weight:700;
  box-shadow:0 4px 14px rgba(56,230,193,.25);
  transition: transform .2s ease;
}
.service-card .card-cta:hover { transform: translateY(-2px); }

/* ===== Price block ===== */
.price { display:flex; align-items:baseline; gap:8px; margin:10px 0; }
.price__amount { font-size:clamp(1.6rem,2vw + 1rem,2.3rem); font-weight:900; color:#fff; }
.price__term { color:var(--muted); font-weight:600; font-size:1rem; }
.price__note { margin:4px 0 10px; color:var(--muted); font-size:.9rem; }
.price--featured .price__amount {
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}


/* keep mobile full-width and nicely stacked */
@media (max-width: 700px){
  .service-card--custom{
    width: 100%;
    margin: 6px 0 0;
    padding: 18px;
  }
  .custom__wrap{ flex-direction: column; align-items: flex-start; }
  .card-cta--outline{ margin-top: 10px; }
}



/* =======================
   In-Depth Service (Light)
   ======================= */
.service-deep{
  background:#fff;
  color:var(--soft-black);
  padding: clamp(56px, 6vw, 96px) 20px;
  font-family: var(--font-sans, system-ui, -apple-system, Segoe UI, Roboto, Arial);
}
.service-deep__inner{ max-width: var(--maxw); margin-inline:auto; }

/* Header */
.service-deep__header{ text-align:center; max-width: 900px; margin: 0 auto clamp(28px, 4vw, 46px); }
.service-deep__title{
  margin:0 0 10px; line-height:1.1; letter-spacing:-.02em;
  font-weight:800; font-size: clamp(1.9rem, 2.6vw + 1rem, 3rem); color:#111; text-shadow:none;
}
.service-deep__intro{ color:#5a5f67; margin:0 auto 18px; }
.service-deep__toc{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top: 14px;
}
.toc-link{
  display:inline-block; padding:8px 12px; border-radius:999px;
  background:#f4f6f9; color:#222; text-decoration:none; font-weight:700; font-size:.95rem;
  border:1px solid #e7e9ee; transition: background .15s ease, transform .15s ease;
}
.toc-link:hover{ background:#eef2f7; transform: translateY(-1px); }

/* Blocks (image + content) */
.deep-block{
  display:grid; gap: clamp(18px, 3vw, 28px);
  grid-template-columns: 1fr; align-items:center;
  padding-block: clamp(24px, 4vw, 36px);
}
.deep-block--reverse{ }
.deep-block__content{ min-width:0; }
.deep-block__title{
  font-size: clamp(1.4rem, 1.8vw + .9rem, 2rem); font-weight:800; margin:0 0 8px; color:#111;
}
.deep-block__text{ color: var(--soft-text); margin:0 0 12px; }
.deep-block__media{ margin:0; }
.deep-block__media img{ width:100%; height:auto; display:block; border-radius: 14px; box-shadow: 0 8px 20px rgba(0,0,0,.06); }

@media (min-width: 960px){
  .deep-block{ grid-template-columns: 1.05fr .95fr; }
  .deep-block--reverse{ grid-template-columns: .95fr 1.05fr; }
  .deep-block--reverse .deep-block__content{ order:2; }
  .deep-block--reverse .deep-block__media{ order:1; }
}

/* Lists */
.deep-list{
  list-style:none;
  padding:0;
  margin:12px 0 0;
  display:grid;
  gap:10px;
}

.deep-list--ticks {
  list-style: none;   /* removes browser bullets */
  padding-left: 0;    /* optional: clears space */
  margin: 0;
}

.deep-list--ticks li {
  display: flex;
  gap: 10px;
  align-items: center;
  color: #1e2734;
  position: relative;
  padding-left: 32px; /* make room for the icon */
}

.deep-list--ticks li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: url("correct.png") no-repeat center center / contain;
}

/* Optional: slightly smaller icon on very small screens */
@media (max-width: 560px){
  .deep-list--ticks li { padding-left: 32px; }
  .deep-list--ticks li::before { width:18px; height:18px; }
}

/* Deliverables grid */
.deliverables-grid{
  display:grid; gap:14px; margin-top: 12px;
  grid-template-columns: 1fr;
}
.deliverable{
  background:#f7f9fc; border:1px solid #e7e9ee; border-radius:12px; padding:14px 16px;
}
.deliverable h4{ margin:0 0 6px; font-size:1.05rem; font-weight:800; color:#0e1621; }
.deliverable p{ margin:0; color:#3b4450; }

@media (min-width: 780px){
  .deliverables-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* Accordion (Process) */
.deep-acc{ padding-block: clamp(24px, 4vw, 36px); }
.deep-acc__title{
  font-size: clamp(1.4rem, 1.8vw + .9rem, 2rem); font-weight:800; margin:0 0 10px; color:#111;
}
.deep-acc__list{ list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.deep-acc__item details{
  border:1px solid #e7e9ee; border-radius:12px; background:#f8fbff; overflow:hidden;
}
.deep-acc__item summary{
  display:grid; grid-template-columns: 1fr auto; align-items:center; gap:10px;
  cursor:pointer; padding:14px 16px; font-weight:700;
}
.deep-acc__item summary em{ font-style:normal; color:#667085; font-weight:700; }
.deep-acc__item .panel{ padding:0 16px 14px; color:#3b4450; }

/* Stack cards */
.deep-stack{ padding-block: clamp(24px, 4vw, 36px); }
.deep-stack__title{
  font-size: clamp(1.4rem, 1.8vw + .9rem, 2rem); font-weight:800; margin:0 0 12px; color:#111;
}
.stack-grid{ display:grid; gap:14px; grid-template-columns: 1fr; }
.stack-card{
  background:#f6faf8; border:1px solid #e1f0eb; border-radius:12px; padding:16px;
}
.stack-card h4{ margin:0 0 8px; font-size:1.05rem; font-weight:800; color:#0e1621; }
.stack-card ul{ margin:0; padding-left:18px; color:#3b4450; }
@media (min-width: 900px){
  .stack-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}

/* Timeline */
.deep-timeline{ padding-block: clamp(24px, 4vw, 36px); }
.deep-timeline__title{
  font-size: clamp(1.4rem, 1.8vw + .9rem, 2rem); font-weight:800; margin:0 0 12px; color:#111;
}
.timeline-steps{
  counter-reset: step; list-style:none; padding:0; margin:0; display:grid; gap:10px;
}
.timeline-steps li{
  position:relative; background:#f7f9fc; border:1px solid #e7e9ee; border-radius:12px; padding:12px 14px;
}
.timeline-steps li span{ font-weight:800; color:#0f54b6; margin-right:8px; }
.timeline-note{ color:#667085; margin-top:10px; }

/* Case study highlight (glass card using your tokens) */
.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius: 18px;
  box-shadow: 0 10px 50px rgba(0,0,0,.1), inset 0 0 0 1px rgba(0,0,0,.06);
}
.deep-case{ padding-block: clamp(28px, 4vw, 40px); }
.deep-case__wrap{
  display:grid; gap:18px; grid-template-columns: 1fr; padding:18px; background:#0d1117; color:#e7eef5;
}
.deep-case__copy .deep-metrics{
  list-style:none; padding:0; margin:8px 0 12px; display:grid; gap:8px;
}
.deep-case__copy .deep-metrics li strong{ color:#38e6c1; }
.deep-case__media img{ width:100%; height:auto; border-radius:14px; }

.deep-case .startnow {
  font-size: 1.05rem;
  display: inline-block;
  background-color: var(--brand, #38e6c1);
  color: #000;
  font-weight: 800;
  padding: 10px 18px;
  border-radius: 10px;
  text-decoration: none;
  transition: background-color .3s, box-shadow .3s, transform .3s;
  box-shadow: 0 0 8px var(--brand, #38e6c1);
}
.deep-case .startnow:hover{
  background-color: var(--brand, #38e6c1);
  box-shadow: 0 0 15px var(--brand-200, #5cd0b8), 0 0 25px var(--brand-200, #5cd0b8);
  transform: scale(1.05);
}

@media (min-width: 960px){
  .deep-case__wrap{ grid-template-columns: 1.1fr .9fr; align-items:center; padding:22px; }
}

/* Compact tweaks on very small screens */
@media (max-width: 560px){
  .service-deep{ padding: 40px 16px; }
  .service-deep__header{ margin-bottom: 20px; }
  .deliverable, .stack-card, .timeline-steps li{ border-radius: 10px; }
}


/* -------- Process / Why Us -------- */
.service-process {
  background: #fff;
  color: #111;
  padding: clamp(60px, 8vw, 100px) 20px;
}
.service-process__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.service-process h2 {
  font-size: clamp(2rem, 2.5vw + 1rem, 3rem);
  font-weight: 800;
  margin: 0 0 24px;
}

/* -------- Testimonials -------- */
/* -------- Testimonials -------- */
.service-testimonials {
  background: #0d1117;
  color: var(--text);
  padding: clamp(56px, 8vw, 100px) 20px;
}
.service-testimonials__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  text-align: center;
}
.service-testimonials h2 {
  font-size: clamp(1.8rem, 2.5vw + 1rem, 2.8rem);
  font-weight: 800;
  margin-bottom: 16px;
}
.gradient-text{
  background: linear-gradient(90deg,#38e6c1,#5a8bff,#ff7a59);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Desktop: 3-up */
.testimonials__grid{
  display:grid;
  grid-template-columns: repeat(12,1fr);
  gap:20px;
}
.testimonial{
  grid-column: span 4;
  background: linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px rgba(231,238,245,.14), 0 8px 28px rgba(0,0,0,.28);
  padding: 18px;
  text-align: left;
}
.testimonial__text{ line-height:1.6; }

/* Tablet: 2-up */
@media (max-width: 920px){
  .testimonials__grid{ grid-template-columns: repeat(6,1fr); }
  .testimonial{ grid-column: span 3; }
}

/* Phone: stacked boxes */
@media (max-width: 640px){
  .testimonials__grid{
    display:block;            /* stack */
  }
  .testimonial{
    grid-column:auto;         /* ignore grid span */
    width:100%;
    margin-bottom: 16px;
    padding:16px;
    border-radius:14px;
  }
}


/* -------- FAQ -------- */
.service-faqs {
  background: #fff;
  color: #111;
  padding: clamp(60px, 8vw, 100px) 20px;
}
.service-faqs__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.service-faqs h2 {
  font-size: clamp(1.8rem, 2.5vw + 1rem, 2.8rem);
  font-weight: 800;
  margin-bottom: 28px;
}
/* Fix invisible FAQ heading */
.service-faqs h2,
.service-faqs h2 .gradient-text,
.service-faqs h2 .gradient-heading {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  -webkit-text-fill-color: #111 !important;
  color: #111 !important;
  text-shadow: none !important;
}

/* -------- CTA -------- */
.service-cta {
  background: #0d1117;
  color: var(--text);
  padding: clamp(60px, 8vw, 100px) 20px;
  text-align: center;
}
.service-cta h2 {
  font-size: clamp(2rem, 3vw + 1rem, 3.2rem);
  font-weight: 800;
  margin-bottom: 18px;
}
.service-cta p {
  max-width: 600px;
  margin: 0 auto 20px;
  color: var(--muted);
}
.service-cta .cta-button {
  font-size: 1.1rem;
}
/* ============= Featured Premium Card ============= */
/* ============= Premium (Always Expressive) ============= */
.service-card--featured {
  position: relative;
  z-index: 2;
  transform: scale(1.06);                 /* make it physically bigger */
  background:
    linear-gradient(#101722, #101722) padding-box,
    linear-gradient(135deg, var(--brand), var(--accent2) 45%, var(--brand-200)) border-box;
  border: 2px solid transparent;
  border-radius: var(--radius-lg);

  box-shadow:
    0 18px 48px rgba(56,230,193,.25),
    0 0 20px rgba(56,230,193,.25),         /* extra halo glow */
    0 0 0 1px rgba(56,230,193,.12) inset,
    0 1px 0 rgba(255,255,255,.06) inset;

  padding: 2.2rem 2rem;                   /* bigger breathing room */
}

/* keep a stronger hover lift */
.service-card--featured:hover {
  transform: scale(1.08);
  box-shadow:
    0 24px 70px rgba(56,230,193,.35),
    0 0 28px rgba(56,230,193,.35),
    0 0 0 1px rgba(56,230,193,.16) inset;
}

/* glow sheen overlay */
.service-card--featured::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  background: radial-gradient(120% 150% at 30% 0%, rgba(255,255,255,.08), transparent 55%);
  pointer-events: none;
}

/* badge styling */
.card-badge {
  position: absolute;
  top: -14px;
  left: 20px;
  padding: 7px 14px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .8rem;
  letter-spacing: .02em;
  color: #06251c;
  background: linear-gradient(90deg, var(--brand), var(--accent2));
  box-shadow: 0 10px 24px rgba(56,230,193,.28);
}

/* CTA stays bolder */
.card-cta--featured {
  background: linear-gradient(90deg, var(--brand), var(--accent2));
  color: #06251c;
  box-shadow: 0 8px 26px rgba(56,230,193,.32);
  font-weight: 700;
}
.card-cta--featured:hover {
  transform: translateY(-2px);
}

/* outline CTA variant */
.card-cta--outline{
  background: transparent;
  color: var(--text);
  border: 1.5px solid var(--brand);
  box-shadow: 0 0 0 6px rgba(56,230,193,.10);
}
.card-cta--outline:hover{
  background: linear-gradient(90deg, var(--brand), var(--accent2));
  color:#06251c;
  box-shadow: 0 10px 26px rgba(56,230,193,.22);
}

/* spacing harmony with your grid at all sizes */
@media (max-width: 700px){
  .custom__wrap{ flex-direction: column; align-items: flex-start; }
  .card-cta--outline{ margin-top: 10px; }
}
/* Premium outline: mint → blue → coral (matches your heading) */
.service-card--featured{
  position: relative;
  background:
    /* card fill */
    linear-gradient(#121922, #121922) padding-box,
    /* outline gradient (same as your heading) */
    linear-gradient(90deg, var(--cta-accent, #38e6c1),
                           var(--cta-accent2, #5a8bff) 55%,
                           var(--cta-accent3, #ff7a59)) border-box;
  border: 2px solid transparent;   /* reveals the gradient outline */
  border-radius: var(--radius-lg);
}

