/* =========================================================
   DigiForge — Service Detail Page styles
   Extends styles.css with the same ink + ember system.
   ========================================================= */

/* breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:12.5px;letter-spacing:.04em;color:var(--text-faint);}
.breadcrumb a{color:var(--text-faint);transition:color .25s;}
.breadcrumb a:hover{color:var(--ember);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb .here{color:var(--text-dim);}

/* ---------- SERVICE HERO ---------- */
.sp-hero{position:relative;overflow:hidden;padding-top:calc(var(--header-h) + clamp(40px,7vw,72px));padding-bottom:clamp(40px,6vw,64px);}
.sp-hero .hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.sp-hero-grid{display:grid;grid-template-columns:1.25fr 0.9fr;gap:clamp(32px,5vw,72px);align-items:center;position:relative;z-index:2;}
.sp-hero .sp-num{font-family:var(--f-mono);font-size:13px;color:var(--ember);letter-spacing:.16em;}
.sp-hero h1{font-size:clamp(34px,5.4vw,62px);margin-top:22px;}
.sp-hero .lead{color:var(--text-dim);font-size:clamp(16px,1.9vw,20px);max-width:560px;margin-top:22px;}
.sp-hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px;}

/* hero side card */
.sp-card{
  position:relative;border-radius:20px;padding:30px;overflow:hidden;
  background:linear-gradient(165deg,var(--ink-2),var(--ink-1));border:1px solid var(--line-2);
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9);
}
.sp-card .sp-bigico{
  width:64px;height:64px;border-radius:16px;display:grid;place-items:center;margin-bottom:22px;
  background:var(--ember-soft);border:1px solid rgba(255,106,61,0.24);color:var(--ember);
}
.sp-card .sp-bigico svg{width:32px;height:32px;}
.sp-meta-row{display:flex;flex-direction:column;gap:0;}
.sp-meta-item{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 0;border-top:1px solid var(--line);}
.sp-meta-item:first-of-type{border-top:none;}
.sp-meta-item .k{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);}
.sp-meta-item .v{font-family:var(--f-display);font-weight:500;font-size:15px;color:var(--text);text-align:right;}

/* ---------- INCLUDED FEATURES ---------- */
.sp-features-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));}
.sp-feature{
  position:relative;background:var(--ink-1);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;overflow:hidden;transition:transform .4s var(--ease),border-color .4s,background .4s;
}
.sp-feature::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;opacity:0;
  background:linear-gradient(140deg,var(--ember),transparent 42%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  transition:opacity .4s var(--ease);
}
.sp-feature:hover{transform:translateY(-5px);background:var(--ink-2);}
.sp-feature:hover::before{opacity:1;}
.sp-feature .fchk{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:16px;
  background:var(--ember-soft);border:1px solid rgba(255,106,61,0.2);color:var(--ember);transition:transform .4s var(--ease);
}
.sp-feature:hover .fchk{transform:rotate(-6deg) scale(1.06);}
.sp-feature .fchk svg{width:19px;height:19px;}
.sp-feature h3{font-size:17.5px;letter-spacing:-0.02em;}
.sp-feature p{color:var(--text-dim);font-size:14.5px;margin-top:9px;line-height:1.55;}

/* ---------- APPROACH ---------- */
.sp-approach{display:grid;gap:16px;}
.sp-step{
  display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
  background:var(--ink-1);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;transition:border-color .4s,background .4s,transform .4s var(--ease);
}
.sp-step:hover{border-color:var(--line-2);background:var(--ink-2);transform:translateX(4px);}
.sp-step .sp-step-n{
  font-family:var(--f-display);font-weight:600;font-size:20px;width:52px;height:52px;flex:none;
  border-radius:13px;display:grid;place-items:center;background:var(--ink-3);border:1px solid var(--line-2);
  color:var(--ember);transition:background .4s,border-color .4s;
}
.sp-step:hover .sp-step-n{background:var(--ember-soft);border-color:rgba(255,106,61,0.35);}
.sp-step h3{font-size:18px;}
.sp-step p{color:var(--text-dim);font-size:14.5px;margin-top:7px;max-width:640px;}

/* ---------- OUTCOMES / deliverable tags ---------- */
.sp-split{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(32px,5vw,64px);align-items:start;}
.sp-checklist{display:grid;gap:13px;}
.sp-checklist li{display:flex;gap:13px;align-items:flex-start;list-style:none;color:var(--text-dim);font-size:15.5px;line-height:1.5;}
.sp-checklist .ci{width:24px;height:24px;flex:none;border-radius:7px;display:grid;place-items:center;background:var(--ember-soft);color:var(--ember);margin-top:1px;}
.sp-checklist .ci svg{width:14px;height:14px;}
.sp-checklist ul{padding:0;margin:0;display:grid;gap:13px;}

/* ---------- RELATED ---------- */
.related-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}
.related-card{
  display:block;position:relative;background:var(--ink-1);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;overflow:hidden;transition:transform .4s var(--ease),border-color .4s,background .4s;
}
.related-card:hover{transform:translateY(-5px);border-color:rgba(255,106,61,0.3);background:var(--ink-2);}
.related-card .rico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:16px;background:var(--ember-soft);border:1px solid rgba(255,106,61,0.2);color:var(--ember);transition:transform .4s var(--ease);}
.related-card:hover .rico{transform:translateY(-3px) rotate(-4deg);}
.related-card .rico svg{width:21px;height:21px;}
.related-card h3{font-size:17px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.related-card h3 .arr{color:var(--text-faint);transition:transform .4s var(--ease),color .3s;}
.related-card:hover h3 .arr{color:var(--ember);transform:translate(3px,-3px);}
.related-card .arr svg{width:17px;height:17px;}
.related-card p{color:var(--text-dim);font-size:14px;margin-top:9px;}

/* ---------- FAQ ---------- */
.faq-list{display:grid;gap:12px;max-width:860px;}
.faq-item{background:var(--ink-1);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .3s,background .3s;}
.faq-item.open{border-color:var(--line-2);background:var(--ink-2);}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--text);font-family:var(--f-display);font-weight:500;font-size:clamp(15px,1.7vw,17.5px);letter-spacing:-0.01em;padding:21px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px;cursor:pointer;transition:color .25s;}
.faq-q:hover{color:var(--ember);}
.faq-qx{width:26px;height:26px;flex:none;border-radius:7px;display:grid;place-items:center;background:var(--ember-soft);color:var(--ember);position:relative;transition:transform .35s var(--ease);}
.faq-qx::before,.faq-qx::after{content:"";position:absolute;background:currentColor;border-radius:2px;}
.faq-qx::before{width:12px;height:2px;}
.faq-qx::after{width:2px;height:12px;transition:transform .35s var(--ease);}
.faq-item.open .faq-qx{transform:rotate(90deg);}
.faq-item.open .faq-qx::after{transform:scaleY(0);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .45s var(--ease);}
.faq-a-inner{overflow:hidden;}
.faq-item.open .faq-a{max-height:600px;}
.faq-a p{color:var(--text-dim);font-size:15px;line-height:1.65;padding:0 22px 22px;margin:0;}

@media (max-width:900px){
  .sp-hero-grid{grid-template-columns:1fr;}
  .sp-split{grid-template-columns:1fr;}
}
