/* === SHARED PAGES PATTERNS === */

.page-hero {
  min-height: 60vh;
  display: flex;
  align-items: center;
  position: relative;
  padding-top: 80px;
  overflow: hidden;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

@media (max-width: 1024px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; gap: 32px; }
}

/* Forms */
.form-group { margin-bottom: 24px; position: relative; }
.form-label { display: block; font-size: 13px; font-weight: 600; color: var(--color-text-muted); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.05em; }
.form-control { width: 100%; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-input); padding: 16px 20px; color: #fff; font-family: var(--font-body); font-size: 16px; outline: none; transition: border-color 0.3s; }
.form-control:focus { border-color: var(--color-accent-primary); }
textarea.form-control { min-height: 120px; resize: vertical; }

/* FAQ Accordion */
.accordion-item { border-bottom: 1px solid var(--color-border); }
.accordion-header { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 24px 0; background: transparent; border: none; color: #fff; font-family: var(--font-display); font-size: 18px; font-weight: 600; cursor: pointer; text-align: left; }
.accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; color: var(--color-text-muted); }
.accordion-item.active .accordion-content { max-height: 500px; padding-bottom: 24px; }

/* Pricing Tables */
.pricing-card { background: var(--color-surface); border-radius: var(--radius-card); padding: 40px; border: 1px solid var(--color-border); }
.pricing-card.featured { border-color: var(--color-accent-primary); box-shadow: var(--shadow-glow); transform: scale(1.05); background: var(--color-surface-2); }
@media (max-width: 1024px) { .pricing-card.featured { transform: scale(1); } }
.price-value { font-family: var(--font-display); font-size: 48px; font-weight: 800; margin: 24px 0; }
.pricing-list { margin: 32px 0; }
.pricing-list li { display: flex; gap: 12px; margin-bottom: 16px; color: var(--color-text-muted); }

/* Timeline */
.timeline { position: relative; max-width: 800px; margin: 0 auto; }
.timeline::before { content: ''; position: absolute; left: 24px; top: 0; bottom: 0; width: 2px; background: var(--color-border); }
.timeline-item { position: relative; padding-left: 72px; margin-bottom: 48px; }
.timeline-dot { position: absolute; left: 16px; top: 0; width: 18px; height: 18px; background: var(--color-bg); border: 2px solid var(--color-accent-primary); border-radius: 50%; box-shadow: 0 0 10px var(--color-accent-primary); }

/* === UTILITIES === */
.text-center { text-align: center; }
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-lg { font-size: var(--text-lg); }
.font-weight-600 { font-weight: 600; }
.border-t { border-top: 1px solid var(--color-border); }
.border-b { border-bottom: 1px solid var(--color-border); }
.mx-auto { margin-left: auto; margin-right: auto; }
.eyebrow { display: inline-block; margin-bottom: 20px; }

/* Icon tiles (hold inline SVG; svg should use stroke/fill currentColor) */
.icon-box {
  width: 56px; height: 56px; border-radius: 14px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-surface-2); color: var(--color-accent-primary);
  border: 1px solid var(--color-border);
}
.icon-box svg { width: 26px; height: 26px; }
.icon-box.cyan { color: var(--color-accent-secondary); }
.icon-box.green { color: var(--color-accent-tertiary); }
.icon-box.amber { color: var(--color-highlight); }
.icon-box.danger { color: var(--color-danger); }

/* Filter bar (portfolio, blog) — driven by filter.js */
.filter-bar { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin: 48px 0; }
.filter-btn {
  padding: 10px 22px; border-radius: var(--radius-btn); cursor: pointer;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  background: transparent; color: var(--color-text-muted);
  border: 1px solid var(--color-border); transition: all 0.3s;
}
.filter-btn:hover { color: #fff; border-color: var(--color-border-glow); }
.filter-btn.active { background: var(--gradient-primary); color: #fff; border-color: transparent; }
.filter-item { transition: opacity 0.3s ease; }

/* Segmented tabs (pricing toggle, segmented views) — driven by main.js */
.tab-bar { display: inline-flex; gap: 4px; padding: 4px; border-radius: var(--radius-btn); background: var(--color-surface); border: 1px solid var(--color-border); }
.tab-btn {
  padding: 10px 24px; border-radius: var(--radius-btn); cursor: pointer; border: none;
  font-family: var(--font-display); font-weight: 600; font-size: 14px;
  background: transparent; color: var(--color-text-muted); transition: all 0.3s;
}
.tab-btn.active { background: var(--gradient-primary); color: #fff; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* Multi-select pills (contact form) — driven by form.js */
.pill-group { display: flex; flex-wrap: wrap; gap: 12px; }
.pill-toggle {
  padding: 10px 20px; border-radius: var(--radius-btn); cursor: pointer;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  background: transparent; color: var(--color-text); border: 1px solid var(--color-border);
  transition: all 0.3s;
}
.pill-toggle.active { color: #fff; border-color: transparent; }
