/* ============================================================
   HAMZIO — Services pages (list + detail)
   Depends on styles.css (shared design system + inner-page components).
   ============================================================ */

/* ============================================================
   SERVICES LIST PAGE
   ============================================================ */
.svc-list{ margin-top:14px; }
.svc-row{ display:grid; grid-template-columns:64px 1fr auto; gap:28px; align-items:center;
  padding:30px; border-radius:var(--radius-lg); margin-bottom:16px;
  transition:transform .4s var(--ease), border-color .4s, box-shadow .4s; position:relative; overflow:hidden; }
.svc-row:hover{ transform:translateY(-3px); border-color:var(--border-2); box-shadow:inset 0 1px 0 rgba(255,255,255,0.07), 0 30px 60px -44px var(--glow-cyan); }
.svc-row .glow{ position:absolute; width:380px; height:380px; border-radius:50%; top:-200px; right:-120px; opacity:0; transition:opacity .45s; pointer-events:none; filter:blur(26px);
  background:radial-gradient(circle, var(--glow-cyan), transparent 70%); }
.svc-row:nth-child(even) .glow{ background:radial-gradient(circle, var(--glow-violet), transparent 70%); }
.svc-row:hover .glow{ opacity:0.45; }

.svc-row .svc-rn{ font-family:var(--font-mono); font-size:0.78rem; color:var(--text-3); align-self:flex-start; padding-top:6px; }
.svc-row .svc-ico{ display:none; }
.svc-row .svc-main{ }
.svc-row .svc-main h2{ font-family:var(--font-display); font-weight:600; font-size:1.55rem; letter-spacing:-0.025em; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.svc-row .svc-main h2 .ico{ width:38px; height:38px; border-radius:11px; background:var(--glass-2); border:1px solid var(--border); display:inline-flex; align-items:center; justify-content:center; flex:none; }
.svc-row .svc-main h2 .ico svg{ width:20px; height:20px; }
.svc-row .svc-main p{ color:var(--text-2); font-size:1rem; margin-top:12px; line-height:1.6; max-width:62ch; }
.svc-row .svc-tags{ display:flex; gap:8px; margin-top:16px; flex-wrap:wrap; }
.svc-row .svc-tags span{ font-family:var(--font-mono); font-size:0.68rem; color:var(--text-3); padding:5px 10px; border-radius:7px; border:1px solid var(--hairline); }
.svc-row .svc-aside{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:14px; flex:none; }
.svc-row .svc-price{ font-family:var(--font-mono); font-size:0.74rem; color:var(--text-3); }
.svc-row .svc-price b{ display:block; font-family:var(--font-display); font-size:1.15rem; color:var(--text); font-weight:600; margin-top:3px; letter-spacing:-0.01em; }
.svc-row .svc-go{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:0.92rem; color:var(--cyan); transition:gap .3s; white-space:nowrap; }
.svc-row:hover .svc-go{ gap:12px; }

/* ============================================================
   SERVICE DETAIL PAGE
   ============================================================ */
.detail-hero .ph-inner{ max-width:820px; }
.detail-meta{ display:flex; gap:30px; flex-wrap:wrap; margin-top:34px; padding-top:26px; border-top:1px solid var(--hairline); }
.detail-meta .dm{ }
.detail-meta .dm .k{ font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--text-3); }
.detail-meta .dm .v{ font-family:var(--font-display); font-weight:600; font-size:1.1rem; margin-top:7px; letter-spacing:-0.01em; }
.detail-meta .dm .v.cyan{ color:var(--cyan); }

/* deliverables */
.deliverables{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:40px; }
.deliverable{ display:flex; gap:15px; padding:22px; border-radius:var(--radius); align-items:flex-start; }
.deliverable .chk{ width:24px; height:24px; border-radius:7px; flex:none; background:rgba(var(--cyan-rgb),0.1); border:1px solid rgba(var(--cyan-rgb),0.3); display:flex; align-items:center; justify-content:center; margin-top:2px; }
.deliverable .chk svg{ width:13px; height:13px; }
.deliverable h4{ font-family:var(--font-display); font-weight:600; font-size:1.05rem; letter-spacing:-0.01em; }
.deliverable p{ color:var(--text-2); font-size:0.92rem; margin-top:6px; line-height:1.55; }

/* process */
.process{ margin-top:44px; display:grid; gap:0; }
.proc-step{ display:grid; grid-template-columns:auto 1fr; gap:26px; padding-bottom:34px; position:relative; }
.proc-step:last-child{ padding-bottom:0; }
.proc-rail{ display:flex; flex-direction:column; align-items:center; }
.proc-num{ width:46px; height:46px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--cyan);
  background:var(--glass-2); border:1px solid rgba(var(--cyan-rgb),0.3); box-shadow:0 0 22px -6px var(--glow-cyan); }
.proc-line{ width:1.6px; flex:1; margin-top:8px; background:linear-gradient(180deg, rgba(var(--cyan-rgb),0.4), transparent); }
.proc-step:last-child .proc-line{ display:none; }
.proc-body{ padding-top:6px; }
.proc-body h4{ font-family:var(--font-display); font-weight:600; font-size:1.22rem; letter-spacing:-0.02em; }
.proc-body .ph-tag{ font-family:var(--font-mono); font-size:0.66rem; color:var(--text-3); margin-left:10px; }
.proc-body p{ color:var(--text-2); font-size:0.98rem; margin-top:9px; line-height:1.6; max-width:60ch; }

/* use cases */
.usecases{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.usecase{ padding:26px; border-radius:var(--radius); }
.usecase .uc-ico{ width:42px; height:42px; border-radius:11px; background:var(--glass-2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.usecase .uc-ico svg{ width:21px; height:21px; }
.usecase h4{ font-family:var(--font-display); font-weight:600; font-size:1.12rem; letter-spacing:-0.015em; }
.usecase p{ color:var(--text-2); font-size:0.92rem; margin-top:9px; line-height:1.55; }

/* tech stack */
.techstack{ margin-top:40px; display:grid; gap:22px; }
.tech-group{ display:grid; grid-template-columns:180px 1fr; gap:24px; align-items:start; padding-bottom:22px; border-bottom:1px solid var(--hairline); }
.tech-group:last-child{ border-bottom:none; padding-bottom:0; }
.tech-group .tg-label{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--cyan); padding-top:6px; }
.tech-chips{ display:flex; gap:9px; flex-wrap:wrap; }
.tech-chips span{ font-size:0.88rem; color:var(--text-2); padding:8px 14px; border-radius:9px; border:1px solid var(--border); background:var(--glass); transition:.3s; }
.tech-chips span:hover{ border-color:var(--border-2); color:var(--text); }
.tech-chips span.ph{ font-family:var(--font-mono); font-size:0.74rem; color:var(--text-3); border-style:dashed; }

/* benefits / outcomes */
.benefits{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.benefit{ padding:28px; border-radius:var(--radius); }
.benefit b{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.8rem,3vw,2.4rem); letter-spacing:-0.03em;
  background:linear-gradient(180deg,#fff,var(--cyan)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; display:block; }
.benefit h4{ font-family:var(--font-display); font-weight:600; font-size:1.05rem; margin-top:12px; letter-spacing:-0.01em; }
.benefit p{ color:var(--text-2); font-size:0.9rem; margin-top:7px; line-height:1.5; }
.benefit em{ font-style:normal; font-family:var(--font-mono); font-size:0.6rem; color:var(--text-3); display:block; margin-top:10px; }

/* related services */
.related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.related-card{ padding:26px; border-radius:var(--radius); transition:transform .4s var(--ease), border-color .4s; display:flex; flex-direction:column; }
.related-card:hover{ transform:translateY(-4px); border-color:var(--border-2); }
.related-card .rc-ico{ width:40px; height:40px; border-radius:11px; background:var(--glass-2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.related-card .rc-ico svg{ width:20px; height:20px; }
.related-card h4{ font-family:var(--font-display); font-weight:600; font-size:1.12rem; letter-spacing:-0.015em; }
.related-card p{ color:var(--text-2); font-size:0.9rem; margin-top:8px; flex:1; }
.related-card .rc-go{ display:inline-flex; align-items:center; gap:7px; margin-top:16px; color:var(--cyan); font-weight:600; font-size:0.88rem; transition:gap .3s; }
.related-card:hover .rc-go{ gap:11px; }

/* detail final CTA */
.detail-cta{ position:relative; padding:clamp(36px,6vw,68px); border-radius:var(--radius-lg); overflow:hidden; text-align:center; margin:64px 0; }
.detail-cta::before{ content:''; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(640px 320px at 50% 0%, rgba(var(--cyan-rgb),0.18), transparent 65%),
             radial-gradient(560px 320px at 82% 120%, rgba(var(--violet-rgb),0.16), transparent 65%); }
.detail-cta h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.9rem,4vw,2.8rem); line-height:1.08; letter-spacing:-0.03em; max-width:20ch; margin:0 auto; }
.detail-cta p{ color:var(--text-2); font-size:1.05rem; margin:18px auto 0; max-width:52ch; }
.detail-cta .dc-actions{ display:flex; gap:14px; justify-content:center; margin-top:30px; flex-wrap:wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:880px){
  .svc-row{ grid-template-columns:1fr; gap:18px; }
  .svc-row .svc-rn{ padding-top:0; }
  .svc-row .svc-aside{ align-items:flex-start; text-align:left; flex-direction:row; justify-content:space-between; width:100%;
    padding-top:18px; border-top:1px solid var(--hairline); }
  .deliverables,.usecases,.benefits,.related-grid{ grid-template-columns:repeat(2,1fr); }
  .usecases,.benefits,.related-grid{ grid-template-columns:1fr; }
  .tech-group{ grid-template-columns:1fr; gap:12px; }
}
@media (max-width:560px){
  .deliverables{ grid-template-columns:1fr; }
  .detail-meta{ gap:20px; }
  .proc-step{ gap:18px; }
}
