/*
 * Praktiga Services Offerings — Scoped Stylesheet
 * All rules are scoped under .pkt-services
 */

/* ── Design Tokens ── */
.pkt-services {
  --pkt-blue: #39a6ff;
  --pkt-dark: #004789;
  --pkt-orange: #f26524;
  --pkt-soft: #88a6c3;
  --pkt-white: #ffffff;
  --pkt-black: #1a1a1a;
  --pkt-off-white: #f5f7fa;
  --pkt-bg: #03234a;
  --pkt-bg-deep: #021d3f;
  --pkt-card-bg: rgba(255, 255, 255, 0.06);
  --pkt-card-border: rgba(255, 255, 255, 0.12);
  --pkt-card-hover-bg: rgba(255, 255, 255, 0.10);
  --pkt-card-blue-bg: rgba(57, 166, 255, 0.08);
  --pkt-card-blue-border: rgba(57, 166, 255, 0.35);
  --pkt-card-orange-bg: rgba(242, 101, 36, 0.08);
  --pkt-card-orange-border: rgba(242, 101, 36, 0.35);
  --pkt-font: 'Poppins', sans-serif;
  --pkt-radius-sm: 6px;
  --pkt-radius-md: 14px;
  --pkt-radius-lg: 16px;
  --pkt-radius-xl: 20px;
  --pkt-radius-pill: 100px;
  --pkt-track-label-width: 148px;
  --pkt-content-padding-x: 64px;
  --pkt-card-gap: 10px;
  --pkt-tag-cloud-bg: rgba(57, 166, 255, 0.20);
  --pkt-tag-cloud-color: #39a6ff;
  --pkt-tag-onprem-bg: rgba(136, 166, 195, 0.20);
  --pkt-tag-onprem-color: #88a6c3;
  --pkt-tag-both-bg: rgba(242, 101, 36, 0.15);
  --pkt-tag-both-color: #f26524;
  --pkt-badge-blue-bg: rgba(57, 166, 255, 0.15);
  --pkt-badge-blue-color: #39a6ff;
  --pkt-badge-orange-bg: rgba(242, 101, 36, 0.20);
  --pkt-badge-orange-color: #f26524;
  --pkt-badge-both-bg: rgba(136, 166, 195, 0.15);
  --pkt-badge-both-color: #88a6c3;
  --pkt-shadow-blue: 0 12px 32px rgba(57, 166, 255, 0.20);
  --pkt-shadow-orange: 0 12px 32px rgba(242, 101, 36, 0.15);
  --pkt-shadow-card: 0 12px 32px rgba(0, 0, 0, 0.30);
  --pkt-glow-blue: 0 0 40px rgba(57, 166, 255, 0.35);
  --pkt-divider: rgba(255, 255, 255, 0.08);
  --pkt-divider-faint: rgba(255, 255, 255, 0.05);
  --pkt-transition: all 0.2s ease;

  background-color: var(--pkt-bg);
  color: var(--pkt-white);
  font-family: var(--pkt-font);
}

.pkt-services *,
.pkt-services *::before,
.pkt-services *::after {
  box-sizing: border-box;
}

/* ── Overview Hero ── */
.pkt-services-hero {
  text-align: center;
  padding: 80px var(--pkt-content-padding-x) 60px;
}

.pkt-hero-eyebrow {
  display: inline-block;
  background: rgba(57, 166, 255, 0.12);
  color: var(--pkt-blue);
  border: 1px solid rgba(57, 166, 255, 0.25);
  border-radius: var(--pkt-radius-pill);
  padding: 5px 16px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.pkt-services-hero h1 {
  font-size: 44px;
  font-weight: 800;
  color: var(--pkt-white);
  line-height: 1.2;
  margin: 0 0 16px;
}

.pkt-blue-text { color: var(--pkt-blue); }
.pkt-orange-text { color: var(--pkt-orange); }

.pkt-services-hero p {
  font-size: 15px;
  font-weight: 300;
  color: var(--pkt-soft);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ── Journey ── */
.pkt-journey {
  padding: 0 var(--pkt-content-padding-x) 48px;
}

.pkt-track {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 20px 0;
}

.pkt-track-label {
  width: var(--pkt-track-label-width);
  min-width: var(--pkt-track-label-width);
  flex-shrink: 0;
  padding-right: 12px;
  padding-top: 4px;
}

.pkt-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--pkt-radius-pill);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}

.pkt-badge--blue { background: var(--pkt-badge-blue-bg); color: var(--pkt-badge-blue-color); }
.pkt-badge--orange { background: var(--pkt-badge-orange-bg); color: var(--pkt-badge-orange-color); }
.pkt-badge--both { background: var(--pkt-badge-both-bg); color: var(--pkt-badge-both-color); }

.pkt-track-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--pkt-white);
  margin: 0 0 2px;
  line-height: 1.3;
}

.pkt-track-sub {
  font-size: 10px;
  font-weight: 400;
  color: var(--pkt-soft);
  margin: 0;
  line-height: 1.4;
}

.pkt-steps {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pkt-card-gap);
  flex: 1;
}

/* ── Cards ── */
.pkt-card {
  background: var(--pkt-card-bg);
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-lg);
  padding: 14px 16px;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  display: block;
  min-width: 160px;
  max-width: 210px;
  transition: var(--pkt-transition);
  position: relative;
}

.pkt-card:hover {
  background: var(--pkt-card-hover-bg);
  transform: translateY(-2px);
  box-shadow: var(--pkt-shadow-card);
  color: inherit;
  text-decoration: none;
}

.pkt-card--blue { background: var(--pkt-card-blue-bg); border-color: var(--pkt-card-blue-border); }
.pkt-card--orange { background: var(--pkt-card-orange-bg); border-color: var(--pkt-card-orange-border); }

/* ── Tags ── */
.pkt-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--pkt-radius-pill);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

.pkt-tag--cloud { background: var(--pkt-tag-cloud-bg); color: var(--pkt-tag-cloud-color); }
.pkt-tag--onprem { background: var(--pkt-tag-onprem-bg); color: var(--pkt-tag-onprem-color); }
.pkt-tag--both { background: var(--pkt-tag-both-bg); color: var(--pkt-tag-both-color); }

.pkt-card-icon { font-size: 20px; line-height: 1; margin-bottom: 6px; display: block; }
.pkt-card-name { font-size: 12px; font-weight: 700; color: var(--pkt-white); margin: 0 0 4px; }
.pkt-plus { color: var(--pkt-blue); }
.pkt-plus-o { color: var(--pkt-orange); }
.pkt-card-desc { font-size: 10px; font-weight: 400; color: var(--pkt-soft); margin: 0; line-height: 1.4; }

.pkt-card-cta { font-size: 9px; color: var(--pkt-blue); margin-top: 8px; display: none; }
.pkt-card:hover .pkt-card-cta { display: block; }

.pkt-track-divider { height: 1px; background: var(--pkt-divider); margin-left: var(--pkt-track-label-width); }

/* ── Legend ── */
.pkt-legend {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 16px var(--pkt-content-padding-x);
  border-top: 1px solid var(--pkt-divider);
}

.pkt-legend-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--pkt-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.pkt-legend-text { font-size: 11px; color: var(--pkt-soft); }

/* ── Gartner Section ── */
.pkt-gartner {
  padding: 64px var(--pkt-content-padding-x);
  background: var(--pkt-bg-deep);
}

.pkt-gartner-eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--pkt-orange);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}

.pkt-gartner-eyebrow::after {
  content: '';
  width: 60px;
  height: 1px;
  background: var(--pkt-orange);
  opacity: 0.4;
}

.pkt-gartner-title { font-size: 26px; font-weight: 800; color: var(--pkt-white); margin: 0 0 8px; }
.pkt-gartner-sub { font-size: 13px; font-weight: 300; color: var(--pkt-soft); margin: 0 0 40px; }

.pkt-gartner-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }

.pkt-gartner-card {
  background: var(--pkt-card-bg);
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-xl);
  padding: 28px;
  position: relative;
  overflow: hidden;
}

.pkt-gartner-card::before {
  content: '\201C';
  position: absolute;
  top: -10px;
  left: 20px;
  font-size: 120px;
  font-weight: 900;
  color: rgba(57, 166, 255, 0.06);
  line-height: 1;
  pointer-events: none;
}

.pkt-gartner-stars { color: var(--pkt-orange); font-size: 14px; margin-bottom: 14px; letter-spacing: 2px; }
.pkt-gartner-quote { font-style: italic; font-size: 13px; font-weight: 300; color: var(--pkt-white); line-height: 1.6; margin: 0 0 20px; }
.pkt-placeholder { opacity: 0.45; font-size: 11px; }
.pkt-gartner-reviewer { font-size: 11px; font-weight: 500; color: var(--pkt-soft); margin-bottom: 12px; }

.pkt-gartner-badge {
  display: inline-block;
  background: rgba(242, 101, 36, 0.12);
  color: var(--pkt-orange);
  border: 1px solid rgba(242, 101, 36, 0.25);
  border-radius: var(--pkt-radius-pill);
  padding: 3px 10px;
  font-size: 10px;
  font-weight: 600;
  margin-bottom: 8px;
}

.pkt-gartner-source {
  font-size: 10px;
  color: var(--pkt-soft);
  opacity: 0.5;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pkt-gartner-source::before {
  content: '';
  width: 20px;
  height: 1px;
  background: currentColor;
  display: inline-block;
}

.pkt-gartner-cta { text-align: center; margin-top: 40px; }

/* ── Buttons ── */
.pkt-btn-primary {
  display: inline-block;
  background: var(--pkt-blue);
  color: var(--pkt-white) !important;
  border: none;
  border-radius: var(--pkt-radius-pill);
  padding: 12px 28px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--pkt-font);
  cursor: pointer;
  text-decoration: none !important;
  transition: var(--pkt-transition);
}

.pkt-btn-primary:hover { transform: translateY(-1px); box-shadow: var(--pkt-shadow-blue); opacity: 0.9; }

.pkt-btn-primary--orange { background: var(--pkt-orange); }
.pkt-btn-primary--orange:hover { box-shadow: var(--pkt-shadow-orange); }

.pkt-btn-outline {
  display: inline-block;
  background: transparent;
  color: var(--pkt-white) !important;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: var(--pkt-radius-pill);
  padding: 12px 28px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--pkt-font);
  cursor: pointer;
  text-decoration: none !important;
  transition: var(--pkt-transition);
}

.pkt-btn-outline:hover { transform: translateY(-1px); border-color: rgba(255, 255, 255, 0.6); background: rgba(255, 255, 255, 0.05); }

/* ── Detail Back Button ── */
.pkt-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--pkt-soft) !important;
  text-decoration: none !important;
  font-size: 13px;
  font-weight: 500;
  transition: var(--pkt-transition);
  padding: 24px var(--pkt-content-padding-x) 0;
}

.pkt-back-btn:hover { color: var(--pkt-blue) !important; }

/* ── Detail Hero ── */
.pkt-detail-hero {
  padding: 40px var(--pkt-content-padding-x) 60px;
  position: relative;
  overflow: hidden;
}

.pkt-detail-hero::before {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(57, 166, 255, 0.12) 0%, transparent 70%);
  pointer-events: none;
}

.pkt-detail-tag-row { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }

.pkt-detail-eyebrow {
  font-size: 12px;
  font-weight: 500;
  color: var(--pkt-soft);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pkt-detail-hero h1 { font-size: 48px; font-weight: 900; color: var(--pkt-white); margin: 0 0 16px; line-height: 1.1; }

.pkt-detail-desc {
  font-size: 16px;
  font-weight: 300;
  color: var(--pkt-soft);
  max-width: 640px;
  line-height: 1.7;
  margin: 0 0 32px;
}

.pkt-detail-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Detail Body ── */
.pkt-detail-body { padding: 0 var(--pkt-content-padding-x) 48px; }

/* ── Stats Row ── */
.pkt-stats-row {
  display: flex;
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-lg);
  overflow: hidden;
  margin-bottom: 48px;
  background: var(--pkt-card-bg);
}

.pkt-stat { flex: 1; padding: 24px 20px; text-align: center; border-right: 1px solid var(--pkt-card-border); }
.pkt-stat:last-child { border-right: none; }
.pkt-stat-num { font-size: 36px; font-weight: 900; color: var(--pkt-blue); line-height: 1; margin-bottom: 6px; }
.pkt-stat-num--orange { color: var(--pkt-orange); }
.pkt-stat-label { font-size: 11px; font-weight: 500; color: var(--pkt-soft); line-height: 1.3; }

/* ── Section Title ── */
.pkt-detail-section-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--pkt-blue);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.pkt-detail-section-title::after { content: ''; flex: 1; height: 1px; background: var(--pkt-divider); }
.pkt-detail-section-title--orange { color: var(--pkt-orange); }

/* ── Phases ── */
.pkt-phases {
  display: flex;
  gap: 0;
  position: relative;
  margin-bottom: 48px;
}

.pkt-phases::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 20px;
  right: 20px;
  height: 2px;
  background: rgba(255, 255, 255, 0.10);
  z-index: 0;
}

.pkt-phase { flex: 1; text-align: center; padding: 0 12px; position: relative; z-index: 1; }

.pkt-phase-num {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--pkt-card-blue-bg);
  border: 2px solid var(--pkt-blue);
  color: var(--pkt-blue);
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
}

.pkt-phase-num--orange { background: var(--pkt-card-orange-bg); border-color: var(--pkt-orange); color: var(--pkt-orange); }
.pkt-phase h4 { font-size: 13px; font-weight: 600; color: var(--pkt-white); margin: 0 0 6px; }
.pkt-phase p { font-size: 11px; font-weight: 400; color: var(--pkt-soft); margin: 0; line-height: 1.4; }

/* ── Detail Grids ── */
.pkt-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 48px; }
.pkt-detail-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 48px; }

.pkt-detail-card {
  background: var(--pkt-card-bg);
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-lg);
  padding: 24px;
}

.pkt-detail-card-icon { font-size: 24px; margin-bottom: 12px; display: block; }
.pkt-detail-card h3 { font-size: 15px; font-weight: 600; color: var(--pkt-white); margin: 0 0 8px; }
.pkt-detail-card p { font-size: 13px; font-weight: 300; color: var(--pkt-soft); line-height: 1.6; margin: 0 0 12px; }
.pkt-detail-card ul { margin: 0; padding: 0; list-style: none; }
.pkt-detail-card ul li { font-size: 12px; color: var(--pkt-soft); padding: 3px 0 3px 14px; position: relative; }
.pkt-detail-card ul li::before { content: '·'; position: absolute; left: 0; color: var(--pkt-blue); }

/* ── Tiers (CloudCARE+) ── */
.pkt-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 48px; align-items: start; }

.pkt-tier-card {
  background: var(--pkt-card-bg);
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-lg);
  padding: 28px 24px;
  position: relative;
}

.pkt-tier-card--featured { border-color: var(--pkt-blue); box-shadow: var(--pkt-glow-blue); }

.pkt-tier-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--pkt-blue);
  color: var(--pkt-white);
  font-size: 10px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: var(--pkt-radius-pill);
  white-space: nowrap;
}

.pkt-tier-name { font-size: 18px; font-weight: 700; color: var(--pkt-white); margin: 0 0 4px; }
.pkt-tier-tagline { font-size: 12px; color: var(--pkt-soft); margin: 0 0 20px; }
.pkt-tier-features { list-style: none; margin: 0; padding: 0; }
.pkt-tier-features li { font-size: 13px; color: var(--pkt-soft); padding: 6px 0; border-bottom: 1px solid var(--pkt-divider-faint); display: flex; align-items: center; gap: 8px; }
.pkt-check { color: var(--pkt-blue); font-weight: 700; }
.pkt-x { color: var(--pkt-soft); opacity: 0.4; }

/* ── Delivery Grid (PS:Delivery+) ── */
.pkt-delivery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 48px; }

.pkt-delivery-item {
  background: var(--pkt-card-bg);
  border: 1px solid var(--pkt-card-border);
  border-radius: var(--pkt-radius-lg);
  padding: 24px;
  position: relative;
  transition: var(--pkt-transition);
}

.pkt-delivery-item:hover { border-color: var(--pkt-card-blue-border); background: var(--pkt-card-blue-bg); }

.pkt-di-tag {
  position: absolute;
  top: 14px;
  right: 14px;
  background: rgba(57, 166, 255, 0.12);
  color: var(--pkt-blue);
  font-size: 9px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--pkt-radius-pill);
  text-transform: uppercase;
}

.pkt-delivery-icon { font-size: 24px; margin-bottom: 10px; display: block; }
.pkt-delivery-item h4 { font-size: 14px; font-weight: 600; color: var(--pkt-white); margin: 0 0 6px; padding-right: 44px; }
.pkt-delivery-item p { font-size: 12px; font-weight: 300; color: var(--pkt-soft); margin: 0; line-height: 1.5; }

.pkt-delivery-item--passive { opacity: 0.6; }
.pkt-delivery-item--passive:hover { border-color: var(--pkt-card-border); background: var(--pkt-card-bg); }

/* ── Highlight Strip ── */
.pkt-highlight-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: rgba(57, 166, 255, 0.08);
  border: 1px solid rgba(57, 166, 255, 0.2);
  border-radius: var(--pkt-radius-xl);
  padding: 28px 36px;
  margin-bottom: 48px;
}

.pkt-highlight-strip--orange { background: rgba(242, 101, 36, 0.08); border-color: rgba(242, 101, 36, 0.2); }
.pkt-hs-text h3 { font-size: 18px; font-weight: 700; color: var(--pkt-white); margin: 0 0 4px; }
.pkt-hs-text p { font-size: 13px; font-weight: 300; color: var(--pkt-soft); margin: 0; }

/* ── Responsive Breakpoints ── */
@media (max-width: 1100px) {
  .pkt-services { --pkt-content-padding-x: 32px; }
  .pkt-gartner-grid { grid-template-columns: 1fr 1fr; }
  .pkt-detail-grid-3 { grid-template-columns: 1fr 1fr; }
  .pkt-tiers { grid-template-columns: 1fr 1fr; }
  .pkt-delivery-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .pkt-services { --pkt-content-padding-x: 20px; }
  .pkt-services-hero h1 { font-size: 30px; }
  .pkt-detail-hero h1 { font-size: 32px; }
  .pkt-track { flex-direction: column; }
  .pkt-track-label { width: 100%; min-width: 100%; padding-right: 0; padding-bottom: 8px; }
  .pkt-steps { flex-direction: column; }
  .pkt-card { max-width: 100%; }
  .pkt-track-divider { margin-left: 0; }
  .pkt-legend { padding-left: 20px; }
  .pkt-gartner-grid,
  .pkt-detail-grid,
  .pkt-detail-grid-3,
  .pkt-tiers,
  .pkt-delivery-grid { grid-template-columns: 1fr; }
  .pkt-phases { flex-direction: column; }
  .pkt-phases::before { display: none; }
  .pkt-stats-row { flex-direction: column; }
  .pkt-stat { border-right: none; border-bottom: 1px solid var(--pkt-divider); }
  .pkt-stat:last-child { border-bottom: none; }
  .pkt-highlight-strip { flex-direction: column; align-items: flex-start; }
}

/* ═══════════════════════════════
   WIP CARD STYLES — Journey Page
═══════════════════════════════ */

/* Tags row wrapper — prevents tags overlapping the wip-pill */
.pkt-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 6px;
}
.pkt-card-tags .pkt-tag { margin-bottom: 0; }

/* WIP cards need right padding so tags don't slide under the absolute pill */
.pkt-card--wip .pkt-card-tags { padding-right: 70px; }

/* WIP card base */
.pkt-card--wip {
  opacity: 0.72;
  overflow: hidden;
}
.pkt-card--wip:hover {
  opacity: 1;
  border-color: rgba(136, 166, 195, 0.4) !important;
  background: rgba(136, 166, 195, 0.07) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  transform: translateY(-2px);
}
.pkt-card--wip .pkt-card-cta { color: var(--pkt-soft); display: none; }
.pkt-card--wip:hover .pkt-card-cta { display: block; }

/* "Coming Soon" pill — pulsing dot + text, absolute top-right */
.wip-pill {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 100px;
  background: rgba(136, 166, 195, 0.18);
  color: var(--pkt-soft);
  border: 1px solid rgba(136, 166, 195, 0.3);
  display: flex;
  align-items: center;
  gap: 4px;
}
.wip-pill::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--pkt-soft);
  animation: wip-pulse 2s ease-in-out infinite;
}
@keyframes wip-pulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%       { opacity: 1;   transform: scale(1.3); }
}

/* ═══════════════════════════════
   WIP FULL PAGE STYLES
═══════════════════════════════ */

.wip-page-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 64px;
  position: relative;
  min-height: 70vh;
}

/* 5× animated P-monogram background */
.wip-bg-pattern {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  opacity: 0.04;
}
.wip-bg-pattern svg {
  position: absolute;
  animation: wip-float 18s ease-in-out infinite;
}
.wip-bg-pattern svg:nth-child(1) { top: -60px;    left: -40px;  width: 280px; animation-delay: 0s; }
.wip-bg-pattern svg:nth-child(2) { top: 10%;      right: -60px; width: 200px; animation-delay: -6s; }
.wip-bg-pattern svg:nth-child(3) { bottom: -40px; left: 20%;    width: 240px; animation-delay: -12s; }
.wip-bg-pattern svg:nth-child(4) { top: 40%;      left: -80px;  width: 160px; animation-delay: -4s; }
.wip-bg-pattern svg:nth-child(5) { bottom: 10%;   right: 5%;    width: 300px; animation-delay: -9s; }
@keyframes wip-float {
  0%, 100% { transform: translateY(0px) rotate(335deg); }
  50%       { transform: translateY(-24px) rotate(340deg); }
}

/* Central blue glow blob */
.wip-glow {
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(57, 166, 255, 0.07) 0%, transparent 65%);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.wip-inner {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 640px;
}

/* Spinning orbital rings */
.wip-icon-wrap {
  position: relative;
  width: 120px;
  height: 120px;
  margin: 0 auto 36px;
}
.wip-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px dashed rgba(57, 166, 255, 0.25);
  animation: wip-spin 12s linear infinite;
}
.wip-ring-2 {
  position: absolute;
  inset: 12px;
  border-radius: 50%;
  border: 1px dashed rgba(136, 166, 195, 0.2);
  animation: wip-spin 8s linear infinite reverse;
}
@keyframes wip-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.wip-monogram {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wip-monogram svg { width: 52px; height: 52px; }

/* Pulsing "Work in Progress" status pill */
.wip-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(136, 166, 195, 0.12);
  border: 1px solid rgba(136, 166, 195, 0.25);
  color: var(--pkt-soft);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 7px 18px;
  border-radius: 100px;
  margin-bottom: 24px;
}
.wip-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--pkt-soft);
  animation: wip-pulse 2s ease-in-out infinite;
}

/* Dynamic title */
.wip-title {
  font-size: 42px;
  font-weight: 900;
  letter-spacing: -1px;
  line-height: 1.1;
  color: var(--pkt-white);
  margin-bottom: 8px;
}
.wip-title .plus   { color: var(--pkt-blue); }
.wip-title .plus-o { color: var(--pkt-orange); }

.wip-tagline {
  font-size: 14px;
  color: var(--pkt-soft);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 36px;
}
.wip-tagline strong { color: rgba(255, 255, 255, 0.6); font-weight: 500; }

/* Progress bar */
.wip-progress-wrap {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  padding: 24px 28px;
  margin-bottom: 36px;
  text-align: left;
}
.wip-progress-label {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--pkt-soft);
  font-weight: 500;
  margin-bottom: 10px;
}
.wip-progress-label span { color: var(--pkt-white); font-weight: 600; }
.wip-progress-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 100px;
  overflow: hidden;
  margin-bottom: 16px;
}
.wip-progress-fill {
  height: 100%;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--pkt-blue) 0%, rgba(57, 166, 255, 0.5) 100%);
  transition: width 0.8s cubic-bezier(.4, 0, .2, 1);
  position: relative;
}
/* Glowing white dot on leading edge of progress bar */
.wip-progress-fill::after {
  content: '';
  position: absolute;
  right: 0;
  top: -2px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--pkt-white);
  box-shadow: 0 0 8px rgba(57, 166, 255, 0.8);
}

/* Checklist grid — 2 columns */
.wip-checklist {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 20px;
}
.wip-checklist li {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.55);
  display: flex;
  align-items: center;
  gap: 7px;
}
.wip-checklist li.done { color: rgba(255, 255, 255, 0.85); }
.wip-check-icon { font-size: 11px; flex-shrink: 0; }
.wip-check-icon.done { color: var(--pkt-blue); }
.wip-check-icon.todo { color: rgba(255, 255, 255, 0.2); }

/* Contact CTA block — replaces notify form */
.wip-contact-block {
  max-width: 480px;
  margin: 0 auto 36px;
  text-align: center;
  background: rgba(57, 166, 255, 0.07);
  border: 1px solid rgba(57, 166, 255, 0.18);
  border-radius: 16px;
  padding: 20px 28px;
}
.wip-contact-block p {
  font-size: 13px;
  color: var(--pkt-soft);
  margin-bottom: 12px;
}
.wip-contact-btn {
  display: inline-block;
  background: var(--pkt-blue);
  color: var(--pkt-white) !important;
  text-decoration: none !important;
  border-radius: 100px;
  padding: 11px 28px;
  font-size: 13px;
  font-weight: 700;
  font-family: var(--pkt-font);
  transition: var(--pkt-transition);
}
.wip-contact-btn:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(57, 166, 255, 0.25); }

/* "Available Now" section heading */
.wip-available-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--pkt-blue);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.wip-available-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
  max-width: 120px;
}

/* "Available Now" related cards */
.wip-related {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 8px;
}
.wip-related-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: var(--pkt-transition);
  font-size: 12px;
  text-decoration: none !important;
  color: inherit;
}
.wip-related-card:hover {
  background: rgba(57, 166, 255, 0.08);
  border-color: rgba(57, 166, 255, 0.3);
  transform: translateY(-1px);
  color: inherit;
}
.wip-related-icon { font-size: 16px; }
.wip-related-name { font-weight: 600; color: var(--pkt-white); }
.wip-related-sub  { font-size: 10px; color: var(--pkt-soft); margin-top: 1px; }

/* WIP page footer note */
.wip-footer-note {
  text-align: center;
  padding: 24px var(--pkt-content-padding-x);
  border-top: 1px solid var(--pkt-divider);
  font-size: 11px;
  color: var(--pkt-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.wip-footer-note strong { color: var(--pkt-white); }
.wip-footer-note a { color: var(--pkt-blue); text-decoration: none; }

/* ── WIP Responsive ── */
@media (max-width: 1100px) {
  .wip-page-wrap { padding: 48px 32px; }
}
@media (max-width: 768px) {
  .wip-page-wrap { padding: 40px 20px; }
  .wip-title { font-size: 30px; }
  .wip-checklist { grid-template-columns: 1fr; }
  .wip-related { flex-direction: column; align-items: center; }
  .wip-contact-block { padding: 16px 20px; }
}
