/* ==========================================================================
   professional.css — theme for the Professional Services page ONLY.
   A clean, light, corporate look (distinct from the dark RPG/TTRPG themes)
   aimed at tech-company and small-business clients/employers. Everything is
   scoped under .ps-page so it never leaks into the rest of the site.
   The shared dark site header/footer are kept for consistent navigation.
   ========================================================================== */

.ps-page {
  --ps-bg:        #f4f7fb;
  --ps-bg-2:      #eaf0f8;
  --ps-surface:   #ffffff;
  --ps-surface-2: #f1f5fb;
  --ps-border:    #d9e2ee;
  --ps-ink:       #0f1b2d;
  --ps-ink-2:     #2b3a4f;
  --ps-muted:     #5c6b80;
  --ps-accent:    #2563eb;
  --ps-accent-2:  #1742b0;
  --ps-accent-soft:#e7eefc;
  --ps-teal:      #0d9488;
  --ps-shadow:    0 1px 2px rgba(15,27,45,.05), 0 14px 34px -18px rgba(15,27,45,.28);
  --ps-shadow-sm: 0 1px 2px rgba(15,27,45,.06);

  background: var(--ps-bg);
  color: var(--ps-ink);
}

.ps-page main { display: block; }
.ps-page .container { width: min(100% - 2.4rem, 1180px); margin-inline: auto; }

/* ----- Hero ------------------------------------------------------------- */
.ps-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 360px at 12% -10%, var(--ps-accent-soft), transparent 60%),
    linear-gradient(180deg, #ffffff, var(--ps-bg));
  border-bottom: 1px solid var(--ps-border);
}
.ps-hero::before {            /* faint blueprint grid */
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(180deg, #000, transparent 75%);
  pointer-events: none;
}
.ps-hero__inner {
  position: relative;
  padding-block: clamp(3rem, 7vw, 5.5rem);
  max-width: 820px;
}
.ps-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-display);
  font-weight: 700; font-size: .78rem; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--ps-accent);
  background: var(--ps-accent-soft);
  border: 1px solid #cfe0fb;
  padding: .4rem .8rem; border-radius: 999px;
  margin: 0 0 1.1rem;
}
.ps-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 5vw, 3.3rem);
  line-height: 1.08; letter-spacing: -.5px;
  margin: 0 0 1rem; color: var(--ps-ink);
}
.ps-hero h1 .ps-grad {
  background: linear-gradient(90deg, var(--ps-accent), var(--ps-teal));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ps-hero__lead {
  font-size: 1.15rem; line-height: 1.65; color: var(--ps-ink-2);
  max-width: 60ch; margin: 0 0 1.8rem;
}
.ps-actions { display: flex; flex-wrap: wrap; gap: .8rem; }

/* Buttons (light theme) */
.ps-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-display); font-weight: 700; font-size: .98rem;
  padding: .72rem 1.15rem; border-radius: 10px;
  border: 1px solid transparent; cursor: pointer;
  text-decoration: none; transition: transform .14s ease, box-shadow .14s ease, background .14s ease;
}
.ps-btn .icon { width: 20px; height: 20px; }
.ps-btn--primary { background: var(--ps-accent); color: #fff; box-shadow: var(--ps-shadow-sm); }
.ps-btn--primary:hover { background: var(--ps-accent-2); transform: translateY(-2px); box-shadow: var(--ps-shadow); }
.ps-btn--ghost { background: var(--ps-surface); color: var(--ps-ink); border-color: var(--ps-border); }
.ps-btn--ghost:hover { border-color: var(--ps-accent); color: var(--ps-accent); transform: translateY(-2px); }

/* ----- Credibility strip ----------------------------------------------- */
.ps-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
  margin-top: 2.4rem;
}
.ps-stat {
  background: var(--ps-surface); border: 1px solid var(--ps-border);
  border-radius: 12px; padding: 1rem 1.1rem; box-shadow: var(--ps-shadow-sm);
}
.ps-stat .num { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--ps-accent); }
.ps-stat .label { font-size: .85rem; color: var(--ps-muted); margin-top: .15rem; }

/* ----- Section scaffolding --------------------------------------------- */
.ps-section { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.ps-section--alt { background: var(--ps-bg-2); border-block: 1px solid var(--ps-border); }
.ps-section__head { max-width: 720px; margin-bottom: 2rem; }
.ps-section__head .kicker {
  font-family: var(--font-display); font-weight: 700; font-size: .8rem;
  letter-spacing: 1.2px; text-transform: uppercase; color: var(--ps-teal); margin: 0 0 .5rem;
}
.ps-section__head h2 {
  font-family: var(--font-display); font-size: clamp(1.6rem, 3.4vw, 2.1rem);
  letter-spacing: -.3px; margin: 0 0 .5rem; color: var(--ps-ink);
}
.ps-section__head p { color: var(--ps-muted); font-size: 1.02rem; margin: 0; }

/* ----- Project cards ---------------------------------------------------- */
.ps-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 1.2rem; }
.ps-card {
  display: flex; flex-direction: column;
  background: var(--ps-surface); border: 1px solid var(--ps-border);
  border-radius: 14px; padding: 1.4rem; box-shadow: var(--ps-shadow-sm);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.ps-card:hover { transform: translateY(-3px); box-shadow: var(--ps-shadow); border-color: #c2d4ee; }
.ps-card__top { display: flex; align-items: center; gap: .8rem; margin-bottom: .7rem; }
.ps-card__icon {
  flex: none; width: 42px; height: 42px; border-radius: 10px;
  display: grid; place-items: center;
  background: var(--ps-accent-soft); color: var(--ps-accent);
  border: 1px solid #cfe0fb;
}
.ps-card__icon .icon { width: 22px; height: 22px; }
.ps-card__title { font-family: var(--font-display); font-size: 1.12rem; margin: 0; color: var(--ps-ink); }
.ps-card__kind { font-size: .78rem; color: var(--ps-muted); margin-top: .1rem; }
.ps-card__desc { color: var(--ps-ink-2); font-size: .96rem; line-height: 1.6; margin: 0 0 1rem; }
.ps-card__desc:last-child { margin-bottom: 0; }
.ps-card .ps-tags { margin-top: auto; }

.ps-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: 0 0 1rem; padding: 0; list-style: none; }
.ps-tag {
  font-size: .76rem; font-weight: 600; color: var(--ps-ink-2);
  background: var(--ps-surface-2); border: 1px solid var(--ps-border);
  padding: .22rem .55rem; border-radius: 6px;
}
.ps-card__links { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1rem; }
.ps-card__links a {
  display: inline-flex; align-items: center; gap: .35rem;
  font-weight: 700; font-size: .9rem; color: var(--ps-accent); text-decoration: none;
}
.ps-card__links.is-stacked { flex-direction: column; align-items: flex-start; gap: .55rem; }
.ps-card__links a:hover { color: var(--ps-accent-2); text-decoration: underline; }
.ps-card__links .icon { width: 18px; height: 18px; }

/* ----- Capabilities / tech stack --------------------------------------- */
.ps-chips { display: flex; flex-wrap: wrap; gap: .55rem; list-style: none; margin: 0; padding: 0; }
.ps-chips li {
  font-family: var(--font-display); font-weight: 700; font-size: .9rem;
  color: var(--ps-ink-2); background: var(--ps-surface);
  border: 1px solid var(--ps-border); border-radius: 999px; padding: .45rem .9rem;
  box-shadow: var(--ps-shadow-sm);
}

/* ----- Contact CTA ------------------------------------------------------ */
.ps-cta {
  background: linear-gradient(135deg, #0f1b2d, #16315f);
  color: #eaf1ff; border-radius: 18px;
  padding: clamp(2rem, 5vw, 3rem);
  text-align: center; box-shadow: var(--ps-shadow);
}
.ps-cta h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 3.4vw, 2.2rem); margin: 0 0 .6rem; color: #fff; }
.ps-cta p { color: #b9c8e6; max-width: 56ch; margin: 0 auto 1.6rem; font-size: 1.05rem; }
.ps-cta .ps-actions { justify-content: center; }
.ps-cta .ps-btn--ghost { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.28); }
.ps-cta .ps-btn--ghost:hover { background: rgba(255,255,255,.14); color: #fff; border-color: #fff; }

/* ----- Responsive ------------------------------------------------------- */
@media (max-width: 760px) {
  .ps-stats { grid-template-columns: repeat(2, 1fr); }
  .ps-grid { grid-template-columns: 1fr; }
}
