/* ============================================================
   ITEZIA — Service Pages  (shared + per-page overrides)
   ============================================================ */

/* ── Root vars (overridden per page via inline style) ─────── */
.svc-page {
  --svc-c:      #6366F1;
  --svc-c2:     #8B5CF6;
  --svc-glow:   rgba(99,102,241,.18);
  --svc-dim:    rgba(99,102,241,.08);
  --svc-border: rgba(99,102,241,.22);
}

/* ── Back button ─────────────────────────────────────────── */
.svc-back {
  display: inline-flex; align-items: center; gap: var(--s2);
  font-size: var(--fs-xs); font-family: var(--mono); letter-spacing: .08em;
  color: var(--t4); cursor: pointer; padding: var(--s2) 0;
  margin-bottom: var(--s6); transition: color var(--t2s);
  text-transform: uppercase;
}
.svc-back:hover { color: var(--t1); }
.svc-back i { transition: transform var(--t2s); }
.svc-back:hover i { transform: translateX(-3px); }

/* ── Hero ────────────────────────────────────────────────── */
.svc-hero {
  min-height: 100vh; display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: calc(var(--nav-h) + var(--s20)) 0 var(--s20);
}

/* Inner grid — used by new-style pages */
.svc-hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s10); align-items: center;
  width: 100%; max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(var(--s6), 4vw, var(--s12));
  position: relative; z-index: 2;
}
.svc-hero-copy   { position: relative; z-index: 2; }
.svc-hero-visual {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  width: 100%; min-height: 340px;
}

/* Old-style pages use .container directly inside .svc-hero */
.svc-hero-left  { position: relative; z-index: 2; padding-right: var(--s10); }
.svc-hero-right { position: relative; z-index: 2; }

.svc-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 80% at 70% 50%, var(--svc-glow) 0%, transparent 65%),
    radial-gradient(ellipse 40% 60% at 20% 20%, rgba(255,255,255,.015) 0%, transparent 70%);
}
.svc-hero-grid {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, black 30%, transparent 100%);
}

.svc-kicker {
  display: flex; align-items: center; gap: var(--s3);
  font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .14em;
  text-transform: uppercase; color: var(--svc-c); margin-bottom: var(--s6);
  white-space: nowrap;
}
.svc-kicker-line { width: 28px; height: 1px; background: var(--svc-c); flex-shrink: 0; }

.svc-h1 {
  font-size: clamp(2.8rem, 5.5vw, 5.5rem);
  font-weight: 800; letter-spacing: -.04em; line-height: .93;
  color: var(--t1); margin-bottom: var(--s5);
}
.svc-h1 em { font-style: normal; color: var(--svc-c); }

.svc-hero-sub {
  font-family: var(--mono); font-size: var(--fs-sm); color: var(--t4);
  letter-spacing: .08em; margin-bottom: var(--s5);
}
.svc-hero-body {
  font-size: var(--fs-base); color: var(--t3); line-height: 1.85;
  max-width: 480px; margin-bottom: var(--s10);
}
.svc-hero-actions { display: flex; gap: var(--s4); flex-wrap: wrap; }

.svc-btn {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: 13px 26px; border-radius: var(--r2);
  font-size: var(--fs-sm); font-weight: 600; cursor: pointer;
  transition: all .22s var(--ease); text-decoration: none; border: none;
}
.svc-btn--primary {
  background: var(--svc-c); color: #fff;
  box-shadow: 0 0 32px rgba(0,0,0,.3), 0 0 0 0 var(--svc-c);
}
.svc-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 40px var(--svc-glow), 0 0 0 0 transparent;
  filter: brightness(1.12);
}
.svc-btn--ghost {
  background: rgba(255,255,255,.04); color: var(--t2);
  border: 1px solid rgba(255,255,255,.1);
}
.svc-btn--ghost:hover { border-color: rgba(255,255,255,.22); color: var(--t1); background: rgba(255,255,255,.07); }

/* ── Stats bar ───────────────────────────────────────────── */
.svc-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255,255,255,.06); border-radius: var(--r3);
  overflow: hidden;
  max-width: var(--max-w);
  width: calc(100% - 2 * clamp(var(--s6), 4vw, var(--s12)));
  margin: var(--s12) auto;
}
.svc-stat {
  padding: var(--s7) var(--s6); text-align: center;
  border-right: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.01); transition: background var(--t2s);
}
.svc-stat:last-child { border-right: none; }
.svc-stat:hover { background: rgba(255,255,255,.03); }
.svc-stat-val   { display: block; font-size: var(--fs-3xl); font-weight: 800; color: var(--svc-c); font-family: var(--mono); line-height: 1; }
.svc-stat-label { display: block; font-size: var(--fs-xs); color: var(--t4); text-transform: uppercase; letter-spacing: .08em; margin-top: var(--s2); }

/* ── Sections ────────────────────────────────────────────── */
.svc-section {
  padding: var(--s24) 0; position: relative;
}
.svc-section--alt {
  background: rgba(255,255,255,.015);
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.svc-eyebrow {
  font-size: 10px; font-family: var(--mono); letter-spacing: .16em;
  text-transform: uppercase; color: var(--svc-c); margin-bottom: var(--s4);
}
.svc-h2 {
  font-size: clamp(var(--fs-3xl), 3.5vw, var(--fs-5xl));
  font-weight: 700; letter-spacing: -.04em; line-height: 1.1;
  color: var(--t1); margin-bottom: var(--s4);
}
.svc-body {
  font-size: var(--fs-base); color: var(--t3); line-height: 1.85; max-width: 540px;
}

/* Split (2-col) layout */
.svc-split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s16); align-items: center;
}
.svc-split--rev > *:first-child { order: 2; }
.svc-split--rev > *:last-child  { order: 1; }

/* Feature grid */
.svc-feat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--s5); margin-top: var(--s12);
}
.svc-feat-card {
  background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--r3); padding: var(--s7);
  display: flex; flex-direction: column; gap: var(--s3);
  transition: border-color .22s, background .22s, transform .22s;
}
.svc-feat-card:hover {
  border-color: var(--svc-border);
  background: var(--svc-dim);
  transform: translateY(-4px);
}
.svc-feat-icon {
  width: 42px; height: 42px; border-radius: var(--r2);
  flex-shrink: 0; align-self: flex-start; margin-bottom: var(--s2);
  background: var(--svc-dim); border: 1px solid var(--svc-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--svc-c); font-size: 17px;
}
.svc-feat-title { font-size: var(--fs-base); font-weight: 600; color: var(--t1); margin-bottom: var(--s2); }
.svc-feat-desc  { font-size: var(--fs-sm); color: var(--t3); line-height: 1.7; }

/* Process / Steps */
.svc-steps {
  display: flex; flex-direction: column; gap: 0; margin-top: var(--s10);
  border-left: 1px solid rgba(255,255,255,.08); padding-left: var(--s8);
}
.svc-step {
  position: relative; padding-bottom: var(--s8);
}
.svc-step:last-child { padding-bottom: 0; }
.svc-step-num {
  position: absolute; left: calc(-1 * var(--s8) - 12px);
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--svc-c); color: #fff;
  font-size: 11px; font-weight: 700; font-family: var(--mono);
  display: flex; align-items: center; justify-content: center;
  top: 2px;
}
.svc-step-title { font-size: var(--fs-base); font-weight: 600; color: var(--t1); margin-bottom: var(--s2); }
.svc-step-desc  { font-size: var(--fs-sm); color: var(--t3); line-height: 1.7; }

/* Tech stack */
.svc-tech-grid {
  display: flex; flex-wrap: wrap; gap: var(--s3); margin-top: var(--s8);
}
.svc-chip {
  display: flex; align-items: center; gap: var(--s2);
  padding: 7px 16px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08); border-radius: var(--rfull);
  font-size: var(--fs-sm); font-family: var(--mono); color: var(--t2);
  transition: all .22s;
}
.svc-chip:hover { border-color: var(--svc-c); color: var(--svc-c); background: var(--svc-dim); }
.svc-chip-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--svc-c); flex-shrink: 0; }

/* CTA */
.svc-cta {
  padding: var(--s24) 0; text-align: center; position: relative; overflow: hidden;
}
.svc-cta-glow {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 50% 80% at 50% 50%, var(--svc-glow) 0%, transparent 70%);
}
.svc-cta-line {
  display: flex; flex-direction: column; align-items: center; gap: var(--s5);
  margin: 0 auto var(--s8);
  font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .14em;
  text-transform: uppercase; color: var(--svc-c);
}
.svc-cta-line::before {
  content: '';
  width: 1px; height: 80px;
  background: linear-gradient(to bottom, transparent, var(--svc-c), transparent);
}
.svc-cta-h2 {
  font-size: clamp(var(--fs-3xl), 4vw, var(--fs-5xl));
  font-weight: 700; letter-spacing: -.04em; color: var(--t1); margin-bottom: var(--s4);
}
.svc-cta-sub { font-size: var(--fs-lg); color: var(--t3); margin-bottom: var(--s10); }

/* ── Visual panels ───────────────────────────────────────── */
.svc-visual-panel {
  position: relative; width: 100%; aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center;
}

/* Float card (generic stat/info floating element) */
.svc-float {
  position: absolute; background: rgba(10,10,22,.92);
  border: 1px solid rgba(255,255,255,.1); border-radius: var(--r3);
  padding: var(--s4) var(--s5); backdrop-filter: blur(20px);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.svc-float-label { font-size: 10px; font-family: var(--mono); color: var(--t4); text-transform: uppercase; letter-spacing: .1em; }
.svc-float-val   { font-size: var(--fs-lg); font-weight: 700; color: var(--svc-c); font-family: var(--mono); }

/* Orb glow */
.svc-orb {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, var(--svc-c) 0%, transparent 70%);
  opacity: .12; filter: blur(40px);
  animation: svc-orb-drift 8s ease-in-out infinite;
}
@keyframes svc-orb-drift {
  0%, 100% { transform: translate(0, 0); }
  33%       { transform: translate(20px, -25px); }
  66%       { transform: translate(-15px, 15px); }
}

/* Pulse rings */
.svc-pulse {
  position: absolute; border-radius: 50%;
  border: 1px solid var(--svc-c);
  animation: svc-pulse-out 3s ease-out infinite;
}
@keyframes svc-pulse-out {
  0%   { opacity: .7; transform: scale(.3); }
  100% { opacity: 0;  transform: scale(2.2); }
}

/* Grid blueprint bg */
.svc-blueprint {
  position: absolute; inset: 0; border-radius: inherit;
  background-image:
    linear-gradient(var(--svc-c) 1px, transparent 1px),
    linear-gradient(90deg, var(--svc-c) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: .04;
}

/* ── Scroll reveal ───────────────────────────────────────── */
.sv-in { opacity: 0; transform: translateY(28px); transition: opacity .65s var(--ease), transform .65s var(--ease); }
.sv-in.sv-left  { transform: translateX(-28px); }
.sv-in.sv-right { transform: translateX(28px); }
.sv-in.sv-scale { transform: scale(.96); }
.sv-in.on { opacity: 1; transform: none; }

/* stagger delays */
.sv-d1 { transition-delay: .1s; }
.sv-d2 { transition-delay: .2s; }
.sv-d3 { transition-delay: .3s; }
.sv-d4 { transition-delay: .4s; }

/* ── Divider ─────────────────────────────────────────────── */
.svc-divider {
  height: 1px; margin: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent);
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .svc-hero         { grid-template-columns: 1fr; min-height: auto; padding-top: calc(var(--nav-h) + var(--s16)); }
  .svc-hero-right   { display: none; }
  .svc-hero-left    { padding-right: 0; }
  .svc-split        { grid-template-columns: 1fr; gap: var(--s10); }
  .svc-split--rev > *:first-child { order: 0; }
  .svc-split--rev > *:last-child  { order: 0; }
  .svc-feat-grid    { grid-template-columns: 1fr 1fr; }
  .svc-stats        { grid-template-columns: 1fr 1fr; }
  .svc-stat         { border-bottom: 1px solid rgba(255,255,255,.06); }
}
@media (max-width: 640px) {
  .svc-h1           { font-size: 2.5rem; }
  .svc-feat-grid    { grid-template-columns: 1fr; }
  .svc-stats        { grid-template-columns: 1fr 1fr; }
}

/* ────────────────────────────────────────────────────────────
   SERVICES HUB PAGE
   ──────────────────────────────────────────────────────────── */
.hub-hero {
  padding: calc(var(--nav-h) + var(--s20)) 0 var(--s16);
  text-align: center; position: relative; overflow: hidden;
}
.hub-hero-glow {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 55% 60% at 50% 0%, rgba(192,150,60,.07) 0%, transparent 70%);
}
.hub-eyebrow {
  font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .16em;
  text-transform: uppercase; color: var(--brand-l); margin-bottom: var(--s5);
}
.hub-h1 {
  font-size: clamp(3rem, 6vw, 6rem); font-weight: 800;
  letter-spacing: -.05em; line-height: .9; color: var(--t1); margin-bottom: var(--s6);
}
.hub-sub {
  font-size: var(--fs-lg); color: var(--t3); max-width: 540px; margin: 0 auto var(--s10); line-height: 1.75;
}

.hub-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--s5); padding: var(--s4) 0 var(--s20);
}
.hub-card {
  position: relative; background: var(--card);
  border: 1px solid var(--b-1); border-radius: var(--r4);
  padding: var(--s8); overflow: hidden; cursor: pointer;
  transition: border-color .25s, transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.hub-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 0% 0%, var(--hc) 0%, transparent 60%);
  opacity: 0; transition: opacity .3s;
}
.hub-card:hover { border-color: var(--b-2); transform: translateY(-4px); box-shadow: 0 16px 48px rgba(0,0,0,.5); }
.hub-card:hover::before { opacity: .06; }

.hub-card-num {
  font-size: var(--fs-xs); font-family: var(--mono); color: var(--t4);
  letter-spacing: .12em; margin-bottom: var(--s4);
}
.hub-card-icon {
  width: 40px; height: 40px; border-radius: 8px; margin-bottom: var(--s5);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--hc);
  transition: background .25s, border-color .25s;
}
.hub-card:hover .hub-card-icon {
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.16);
}
.hub-card-title { font-size: var(--fs-base); font-weight: 700; color: var(--t1); letter-spacing: -.01em; margin-bottom: var(--s3); }
.hub-card-desc  { font-size: var(--fs-sm); color: var(--t3); line-height: 1.75; flex: 1; margin-bottom: var(--s6); }
.hub-card-sub   { font-family: var(--mono); font-size: 10px; color: var(--t4); letter-spacing: .1em; margin-bottom: var(--s5); }
.hub-card-cta {
  display: flex; align-items: center; gap: var(--s2);
  font-size: var(--fs-sm); font-weight: 600; color: var(--hc);
  margin-top: auto; transition: gap .2s;
}
.hub-card:hover .hub-card-cta { gap: var(--s3); }
.hub-card-cta i { transition: transform .2s; }
.hub-card:hover .hub-card-cta i { transform: translateX(4px) rotate(-45deg); }

.hub-accent-bar {
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--hc), transparent);
  opacity: .5;
}

@media (max-width: 1024px) { .hub-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .hub-grid { grid-template-columns: 1fr; } }
